From e7d41cd6b6242a431a98bb83c4f4e287b5f4716a Mon Sep 17 00:00:00 2001 From: Larry Poon Date: Fri, 14 Oct 2016 14:25:22 -0500 Subject: [PATCH 1/9] node --- node_modules/bcrypt-nodejs/.gitattributes | 22 + node_modules/bcrypt-nodejs/.npmignore | 163 + node_modules/bcrypt-nodejs/LICENSE | 25 + node_modules/bcrypt-nodejs/README.md | 90 + node_modules/bcrypt-nodejs/bCrypt.js | 707 + node_modules/bcrypt-nodejs/package.json | 63 + node_modules/bcrypt-nodejs/test-async.js | 71 + node_modules/bcrypt-nodejs/test-sync.js | 98 + node_modules/body-parser/HISTORY.md | 464 + node_modules/body-parser/LICENSE | 23 + node_modules/body-parser/README.md | 409 + node_modules/body-parser/index.js | 157 + node_modules/body-parser/lib/read.js | 188 + node_modules/body-parser/lib/types/json.js | 175 + node_modules/body-parser/lib/types/raw.js | 101 + node_modules/body-parser/lib/types/text.js | 121 + .../body-parser/lib/types/urlencoded.js | 279 + .../body-parser/node_modules/bytes/History.md | 70 + .../body-parser/node_modules/bytes/LICENSE | 23 + .../body-parser/node_modules/bytes/Readme.md | 114 + .../body-parser/node_modules/bytes/index.js | 157 + .../node_modules/bytes/package.json | 84 + .../node_modules/content-type/HISTORY.md | 14 + .../node_modules/content-type/LICENSE | 22 + .../node_modules/content-type/README.md | 92 + .../node_modules/content-type/index.js | 216 + .../node_modules/content-type/package.json | 70 + .../body-parser/node_modules/debug/.jshintrc | 3 + .../body-parser/node_modules/debug/.npmignore | 6 + .../body-parser/node_modules/debug/History.md | 195 + .../body-parser/node_modules/debug/Makefile | 36 + .../body-parser/node_modules/debug/Readme.md | 188 + .../body-parser/node_modules/debug/bower.json | 28 + .../body-parser/node_modules/debug/browser.js | 168 + .../node_modules/debug/component.json | 19 + .../body-parser/node_modules/debug/debug.js | 197 + .../body-parser/node_modules/debug/node.js | 209 + .../debug/node_modules/ms/.npmignore | 5 + .../debug/node_modules/ms/History.md | 66 + .../debug/node_modules/ms/LICENSE | 20 + .../debug/node_modules/ms/README.md | 35 + .../debug/node_modules/ms/index.js | 125 + .../debug/node_modules/ms/package.json | 48 + .../node_modules/debug/package.json | 73 + .../body-parser/node_modules/depd/History.md | 84 + .../body-parser/node_modules/depd/LICENSE | 22 + .../body-parser/node_modules/depd/Readme.md | 281 + .../body-parser/node_modules/depd/index.js | 521 + .../node_modules/depd/lib/browser/index.js | 79 + .../depd/lib/compat/buffer-concat.js | 35 + .../depd/lib/compat/callsite-tostring.js | 103 + .../depd/lib/compat/event-listener-count.js | 22 + .../node_modules/depd/lib/compat/index.js | 84 + .../node_modules/depd/package.json | 67 + .../node_modules/http-errors/HISTORY.md | 95 + .../node_modules/http-errors/LICENSE | 23 + .../node_modules/http-errors/README.md | 112 + .../node_modules/http-errors/index.js | 223 + .../http-errors/node_modules/inherits/LICENSE | 16 + .../node_modules/inherits/README.md | 42 + .../node_modules/inherits/inherits.js | 1 + .../node_modules/inherits/inherits_browser.js | 23 + .../node_modules/inherits/package.json | 50 + .../http-errors/node_modules/inherits/test.js | 25 + .../node_modules/setprototypeof/LICENSE | 13 + .../node_modules/setprototypeof/README.md | 21 + .../node_modules/setprototypeof/index.js | 11 + .../node_modules/setprototypeof/package.json | 53 + .../node_modules/statuses/HISTORY.md | 50 + .../http-errors/node_modules/statuses/LICENSE | 23 + .../node_modules/statuses/README.md | 114 + .../node_modules/statuses/codes.json | 65 + .../node_modules/statuses/index.js | 110 + .../node_modules/statuses/package.json | 104 + .../node_modules/http-errors/package.json | 96 + .../node_modules/iconv-lite/.npmignore | 6 + .../node_modules/iconv-lite/.travis.yml | 20 + .../node_modules/iconv-lite/Changelog.md | 93 + .../node_modules/iconv-lite/LICENSE | 21 + .../node_modules/iconv-lite/README.md | 157 + .../iconv-lite/encodings/dbcs-codec.js | 554 + .../iconv-lite/encodings/dbcs-data.js | 170 + .../iconv-lite/encodings/index.js | 22 + .../iconv-lite/encodings/internal.js | 187 + .../iconv-lite/encodings/sbcs-codec.js | 72 + .../encodings/sbcs-data-generated.js | 451 + .../iconv-lite/encodings/sbcs-data.js | 169 + .../encodings/tables/big5-added.json | 122 + .../iconv-lite/encodings/tables/cp936.json | 264 + .../iconv-lite/encodings/tables/cp949.json | 273 + .../iconv-lite/encodings/tables/cp950.json | 177 + .../iconv-lite/encodings/tables/eucjp.json | 182 + .../encodings/tables/gb18030-ranges.json | 1 + .../encodings/tables/gbk-added.json | 55 + .../iconv-lite/encodings/tables/shiftjis.json | 125 + .../iconv-lite/encodings/utf16.js | 174 + .../node_modules/iconv-lite/encodings/utf7.js | 289 + .../iconv-lite/lib/bom-handling.js | 52 + .../iconv-lite/lib/extend-node.js | 214 + .../node_modules/iconv-lite/lib/index.js | 141 + .../node_modules/iconv-lite/lib/streams.js | 120 + .../node_modules/iconv-lite/package.json | 119 + .../node_modules/on-finished/HISTORY.md | 88 + .../node_modules/on-finished/LICENSE | 23 + .../node_modules/on-finished/README.md | 154 + .../node_modules/on-finished/index.js | 196 + .../on-finished/node_modules/ee-first/LICENSE | 22 + .../node_modules/ee-first/README.md | 80 + .../node_modules/ee-first/index.js | 95 + .../node_modules/ee-first/package.json | 64 + .../node_modules/on-finished/package.json | 71 + .../body-parser/node_modules/qs/.eslintignore | 1 + .../body-parser/node_modules/qs/.eslintrc | 19 + .../body-parser/node_modules/qs/.jscs.json | 176 + .../body-parser/node_modules/qs/CHANGELOG.md | 120 + .../node_modules/qs/CONTRIBUTING.md | 1 + .../body-parser/node_modules/qs/LICENSE | 28 + .../body-parser/node_modules/qs/dist/qs.js | 487 + .../body-parser/node_modules/qs/lib/index.js | 9 + .../body-parser/node_modules/qs/lib/parse.js | 167 + .../node_modules/qs/lib/stringify.js | 137 + .../body-parser/node_modules/qs/lib/utils.js | 164 + .../body-parser/node_modules/qs/package.json | 86 + .../body-parser/node_modules/qs/test/index.js | 5 + .../body-parser/node_modules/qs/test/parse.js | 423 + .../node_modules/qs/test/stringify.js | 305 + .../body-parser/node_modules/qs/test/utils.js | 9 + .../node_modules/raw-body/HISTORY.md | 209 + .../body-parser/node_modules/raw-body/LICENSE | 22 + .../node_modules/raw-body/README.md | 126 + .../node_modules/raw-body/index.js | 320 + .../raw-body/node_modules/unpipe/HISTORY.md | 4 + .../raw-body/node_modules/unpipe/LICENSE | 22 + .../raw-body/node_modules/unpipe/README.md | 43 + .../raw-body/node_modules/unpipe/index.js | 69 + .../raw-body/node_modules/unpipe/package.json | 59 + .../node_modules/raw-body/package.json | 90 + .../node_modules/type-is/HISTORY.md | 206 + .../body-parser/node_modules/type-is/LICENSE | 23 + .../node_modules/type-is/README.md | 136 + .../body-parser/node_modules/type-is/index.js | 262 + .../node_modules/media-typer/HISTORY.md | 22 + .../type-is/node_modules/media-typer/LICENSE | 22 + .../node_modules/media-typer/README.md | 81 + .../type-is/node_modules/media-typer/index.js | 270 + .../node_modules/media-typer/package.json | 58 + .../node_modules/mime-types/HISTORY.md | 204 + .../type-is/node_modules/mime-types/LICENSE | 23 + .../type-is/node_modules/mime-types/README.md | 103 + .../type-is/node_modules/mime-types/index.js | 188 + .../node_modules/mime-db/HISTORY.md | 365 + .../mime-types/node_modules/mime-db/LICENSE | 22 + .../mime-types/node_modules/mime-db/README.md | 82 + .../mime-types/node_modules/mime-db/db.json | 6692 ++++++ .../mime-types/node_modules/mime-db/index.js | 11 + .../node_modules/mime-db/package.json | 99 + .../node_modules/mime-types/package.json | 94 + .../node_modules/type-is/package.json | 87 + node_modules/body-parser/package.json | 88 + node_modules/connect-flash/.travis.yml | 6 + node_modules/connect-flash/LICENSE | 20 + node_modules/connect-flash/README.md | 73 + node_modules/connect-flash/lib/flash.js | 82 + node_modules/connect-flash/lib/index.js | 4 + node_modules/connect-flash/package.json | 60 + node_modules/cookie-parser/HISTORY.md | 85 + node_modules/cookie-parser/LICENSE | 23 + node_modules/cookie-parser/README.md | 85 + node_modules/cookie-parser/index.js | 181 + .../node_modules/cookie-signature/.npmignore | 4 + .../node_modules/cookie-signature/History.md | 38 + .../node_modules/cookie-signature/Readme.md | 42 + .../node_modules/cookie-signature/index.js | 51 + .../cookie-signature/package.json | 59 + .../node_modules/cookie/HISTORY.md | 118 + .../cookie-parser/node_modules/cookie/LICENSE | 24 + .../node_modules/cookie/README.md | 220 + .../node_modules/cookie/index.js | 195 + .../node_modules/cookie/package.json | 72 + node_modules/cookie-parser/package.json | 80 + node_modules/express-session/HISTORY.md | 322 + node_modules/express-session/LICENSE | 24 + node_modules/express-session/README.md | 675 + node_modules/express-session/index.js | 647 + .../node_modules/cookie-signature/.npmignore | 4 + .../node_modules/cookie-signature/History.md | 38 + .../node_modules/cookie-signature/Readme.md | 42 + .../node_modules/cookie-signature/index.js | 51 + .../cookie-signature/package.json | 59 + .../node_modules/cookie/HISTORY.md | 118 + .../node_modules/cookie/LICENSE | 24 + .../node_modules/cookie/README.md | 220 + .../node_modules/cookie/index.js | 195 + .../node_modules/cookie/package.json | 72 + .../express-session/node_modules/crc/LICENSE | 22 + .../node_modules/crc/README.md | 100 + .../node_modules/crc/lib/crc1.js | 24 + .../node_modules/crc/lib/crc16.js | 27 + .../node_modules/crc/lib/crc16_ccitt.js | 27 + .../node_modules/crc/lib/crc16_kermit.js | 27 + .../node_modules/crc/lib/crc16_modbus.js | 27 + .../node_modules/crc/lib/crc16_xmodem.js | 31 + .../node_modules/crc/lib/crc24.js | 27 + .../node_modules/crc/lib/crc32.js | 27 + .../node_modules/crc/lib/crc8.js | 27 + .../node_modules/crc/lib/crc8_1wire.js | 27 + .../node_modules/crc/lib/define_crc.js | 16 + .../node_modules/crc/lib/index.js | 14 + .../node_modules/crc/package.json | 66 + .../node_modules/debug/.jshintrc | 3 + .../node_modules/debug/.npmignore | 6 + .../node_modules/debug/History.md | 195 + .../node_modules/debug/Makefile | 36 + .../node_modules/debug/Readme.md | 188 + .../node_modules/debug/bower.json | 28 + .../node_modules/debug/browser.js | 168 + .../node_modules/debug/component.json | 19 + .../node_modules/debug/debug.js | 197 + .../node_modules/debug/node.js | 209 + .../debug/node_modules/ms/.npmignore | 5 + .../debug/node_modules/ms/History.md | 66 + .../debug/node_modules/ms/LICENSE | 20 + .../debug/node_modules/ms/README.md | 35 + .../debug/node_modules/ms/index.js | 125 + .../debug/node_modules/ms/package.json | 48 + .../node_modules/debug/package.json | 73 + .../node_modules/depd/History.md | 84 + .../express-session/node_modules/depd/LICENSE | 22 + .../node_modules/depd/Readme.md | 281 + .../node_modules/depd/index.js | 521 + .../node_modules/depd/lib/browser/index.js | 79 + .../depd/lib/compat/buffer-concat.js | 35 + .../depd/lib/compat/callsite-tostring.js | 103 + .../depd/lib/compat/event-listener-count.js | 22 + .../node_modules/depd/lib/compat/index.js | 84 + .../node_modules/depd/package.json | 67 + .../node_modules/on-headers/HISTORY.md | 16 + .../node_modules/on-headers/LICENSE | 22 + .../node_modules/on-headers/README.md | 76 + .../node_modules/on-headers/index.js | 93 + .../node_modules/on-headers/package.json | 70 + .../node_modules/parseurl/HISTORY.md | 47 + .../node_modules/parseurl/LICENSE | 24 + .../node_modules/parseurl/README.md | 120 + .../node_modules/parseurl/index.js | 138 + .../node_modules/parseurl/package.json | 89 + .../node_modules/uid-safe/HISTORY.md | 46 + .../node_modules/uid-safe/LICENSE | 22 + .../node_modules/uid-safe/README.md | 77 + .../node_modules/uid-safe/index.js | 96 + .../uid-safe/node_modules/base64-url/LICENSE | 15 + .../node_modules/base64-url/README.md | 50 + .../uid-safe/node_modules/base64-url/index.js | 23 + .../node_modules/base64-url/package.json | 73 + .../node_modules/random-bytes/HISTORY.md | 4 + .../node_modules/random-bytes/LICENSE | 21 + .../node_modules/random-bytes/README.md | 77 + .../node_modules/random-bytes/index.js | 101 + .../node_modules/random-bytes/package.json | 67 + .../node_modules/uid-safe/package.json | 92 + .../node_modules/utils-merge/.travis.yml | 6 + .../node_modules/utils-merge/LICENSE | 20 + .../node_modules/utils-merge/README.md | 34 + .../node_modules/utils-merge/index.js | 23 + .../node_modules/utils-merge/package.json | 60 + node_modules/express-session/package.json | 95 + .../express-session/session/cookie.js | 130 + .../express-session/session/memory.js | 185 + .../express-session/session/session.js | 142 + node_modules/express-session/session/store.js | 94 + node_modules/express/History.md | 3142 +++ node_modules/express/LICENSE | 24 + node_modules/express/Readme.md | 142 + node_modules/express/index.js | 11 + node_modules/express/lib/application.js | 643 + node_modules/express/lib/express.js | 103 + node_modules/express/lib/middleware/init.js | 36 + node_modules/express/lib/middleware/query.js | 46 + node_modules/express/lib/request.js | 502 + node_modules/express/lib/response.js | 1065 + node_modules/express/lib/router/index.js | 645 + node_modules/express/lib/router/layer.js | 176 + node_modules/express/lib/router/route.js | 210 + node_modules/express/lib/utils.js | 299 + node_modules/express/lib/view.js | 173 + .../express/node_modules/accepts/HISTORY.md | 212 + .../express/node_modules/accepts/LICENSE | 23 + .../express/node_modules/accepts/README.md | 135 + .../express/node_modules/accepts/index.js | 231 + .../node_modules/mime-types/HISTORY.md | 204 + .../accepts/node_modules/mime-types/LICENSE | 23 + .../accepts/node_modules/mime-types/README.md | 103 + .../accepts/node_modules/mime-types/index.js | 188 + .../node_modules/mime-db/HISTORY.md | 365 + .../mime-types/node_modules/mime-db/LICENSE | 22 + .../mime-types/node_modules/mime-db/README.md | 82 + .../mime-types/node_modules/mime-db/db.json | 6692 ++++++ .../mime-types/node_modules/mime-db/index.js | 11 + .../node_modules/mime-db/package.json | 99 + .../node_modules/mime-types/package.json | 94 + .../node_modules/negotiator/HISTORY.md | 98 + .../accepts/node_modules/negotiator/LICENSE | 24 + .../accepts/node_modules/negotiator/README.md | 203 + .../accepts/node_modules/negotiator/index.js | 124 + .../node_modules/negotiator/lib/charset.js | 169 + .../node_modules/negotiator/lib/encoding.js | 184 + .../node_modules/negotiator/lib/language.js | 179 + .../node_modules/negotiator/lib/mediaType.js | 294 + .../node_modules/negotiator/package.json | 91 + .../express/node_modules/accepts/package.json | 79 + .../node_modules/array-flatten/LICENSE | 21 + .../node_modules/array-flatten/README.md | 43 + .../array-flatten/array-flatten.js | 64 + .../node_modules/array-flatten/package.json | 62 + .../content-disposition/HISTORY.md | 45 + .../node_modules/content-disposition/LICENSE | 22 + .../content-disposition/README.md | 141 + .../node_modules/content-disposition/index.js | 445 + .../content-disposition/package.json | 66 + .../node_modules/content-type/HISTORY.md | 14 + .../express/node_modules/content-type/LICENSE | 22 + .../node_modules/content-type/README.md | 92 + .../node_modules/content-type/index.js | 216 + .../node_modules/content-type/package.json | 70 + .../node_modules/cookie-signature/.npmignore | 4 + .../node_modules/cookie-signature/History.md | 38 + .../node_modules/cookie-signature/Readme.md | 42 + .../node_modules/cookie-signature/index.js | 51 + .../cookie-signature/package.json | 59 + .../express/node_modules/cookie/HISTORY.md | 118 + .../express/node_modules/cookie/LICENSE | 24 + .../express/node_modules/cookie/README.md | 220 + .../express/node_modules/cookie/index.js | 195 + .../express/node_modules/cookie/package.json | 72 + .../express/node_modules/debug/.jshintrc | 3 + .../express/node_modules/debug/.npmignore | 6 + .../express/node_modules/debug/History.md | 195 + .../express/node_modules/debug/Makefile | 36 + .../express/node_modules/debug/Readme.md | 188 + .../express/node_modules/debug/bower.json | 28 + .../express/node_modules/debug/browser.js | 168 + .../express/node_modules/debug/component.json | 19 + .../express/node_modules/debug/debug.js | 197 + .../express/node_modules/debug/node.js | 209 + .../debug/node_modules/ms/.npmignore | 5 + .../debug/node_modules/ms/History.md | 66 + .../debug/node_modules/ms/LICENSE | 20 + .../debug/node_modules/ms/README.md | 35 + .../debug/node_modules/ms/index.js | 125 + .../debug/node_modules/ms/package.json | 48 + .../express/node_modules/debug/package.json | 73 + .../express/node_modules/depd/History.md | 84 + .../express/node_modules/depd/LICENSE | 22 + .../express/node_modules/depd/Readme.md | 281 + .../express/node_modules/depd/index.js | 521 + .../node_modules/depd/lib/browser/index.js | 79 + .../depd/lib/compat/buffer-concat.js | 35 + .../depd/lib/compat/callsite-tostring.js | 103 + .../depd/lib/compat/event-listener-count.js | 22 + .../node_modules/depd/lib/compat/index.js | 84 + .../express/node_modules/depd/package.json | 67 + .../express/node_modules/encodeurl/HISTORY.md | 9 + .../express/node_modules/encodeurl/LICENSE | 22 + .../express/node_modules/encodeurl/README.md | 124 + .../express/node_modules/encodeurl/index.js | 60 + .../node_modules/encodeurl/package.json | 75 + .../express/node_modules/escape-html/LICENSE | 24 + .../node_modules/escape-html/Readme.md | 43 + .../express/node_modules/escape-html/index.js | 78 + .../node_modules/escape-html/package.json | 57 + .../express/node_modules/etag/HISTORY.md | 71 + .../express/node_modules/etag/LICENSE | 22 + .../express/node_modules/etag/README.md | 165 + .../express/node_modules/etag/index.js | 132 + .../express/node_modules/etag/package.json | 73 + .../node_modules/finalhandler/HISTORY.md | 108 + .../express/node_modules/finalhandler/LICENSE | 22 + .../node_modules/finalhandler/README.md | 142 + .../node_modules/finalhandler/index.js | 189 + .../node_modules/statuses/HISTORY.md | 50 + .../node_modules/statuses/LICENSE | 23 + .../node_modules/statuses/README.md | 114 + .../node_modules/statuses/codes.json | 65 + .../node_modules/statuses/index.js | 110 + .../node_modules/statuses/package.json | 104 + .../node_modules/unpipe/HISTORY.md | 4 + .../finalhandler/node_modules/unpipe/LICENSE | 22 + .../node_modules/unpipe/README.md | 43 + .../finalhandler/node_modules/unpipe/index.js | 69 + .../node_modules/unpipe/package.json | 59 + .../node_modules/finalhandler/package.json | 75 + .../express/node_modules/fresh/HISTORY.md | 38 + .../express/node_modules/fresh/LICENSE | 22 + .../express/node_modules/fresh/README.md | 58 + .../express/node_modules/fresh/index.js | 57 + .../express/node_modules/fresh/package.json | 87 + .../node_modules/merge-descriptors/HISTORY.md | 21 + .../node_modules/merge-descriptors/LICENSE | 23 + .../node_modules/merge-descriptors/README.md | 48 + .../node_modules/merge-descriptors/index.js | 60 + .../merge-descriptors/package.json | 138 + .../express/node_modules/methods/HISTORY.md | 29 + .../express/node_modules/methods/LICENSE | 24 + .../express/node_modules/methods/README.md | 51 + .../express/node_modules/methods/index.js | 69 + .../express/node_modules/methods/package.json | 88 + .../node_modules/on-finished/HISTORY.md | 88 + .../express/node_modules/on-finished/LICENSE | 23 + .../node_modules/on-finished/README.md | 154 + .../express/node_modules/on-finished/index.js | 196 + .../on-finished/node_modules/ee-first/LICENSE | 22 + .../node_modules/ee-first/README.md | 80 + .../node_modules/ee-first/index.js | 95 + .../node_modules/ee-first/package.json | 64 + .../node_modules/on-finished/package.json | 71 + .../express/node_modules/parseurl/HISTORY.md | 47 + .../express/node_modules/parseurl/LICENSE | 24 + .../express/node_modules/parseurl/README.md | 120 + .../express/node_modules/parseurl/index.js | 138 + .../node_modules/parseurl/package.json | 89 + .../node_modules/path-to-regexp/History.md | 36 + .../node_modules/path-to-regexp/LICENSE | 21 + .../node_modules/path-to-regexp/Readme.md | 35 + .../node_modules/path-to-regexp/index.js | 129 + .../node_modules/path-to-regexp/package.json | 184 + .../node_modules/proxy-addr/HISTORY.md | 99 + .../express/node_modules/proxy-addr/LICENSE | 22 + .../express/node_modules/proxy-addr/README.md | 136 + .../express/node_modules/proxy-addr/index.js | 321 + .../node_modules/forwarded/HISTORY.md | 4 + .../proxy-addr/node_modules/forwarded/LICENSE | 22 + .../node_modules/forwarded/README.md | 53 + .../node_modules/forwarded/index.js | 35 + .../node_modules/forwarded/package.json | 65 + .../node_modules/ipaddr.js/.npmignore | 2 + .../node_modules/ipaddr.js/.travis.yml | 10 + .../node_modules/ipaddr.js/Cakefile | 18 + .../proxy-addr/node_modules/ipaddr.js/LICENSE | 19 + .../node_modules/ipaddr.js/README.md | 209 + .../node_modules/ipaddr.js/bower.json | 29 + .../node_modules/ipaddr.js/ipaddr.min.js | 1 + .../node_modules/ipaddr.js/lib/ipaddr.js | 526 + .../node_modules/ipaddr.js/package.json | 64 + .../node_modules/ipaddr.js/src/ipaddr.coffee | 450 + .../ipaddr.js/test/ipaddr.test.coffee | 339 + .../node_modules/proxy-addr/package.json | 75 + .../express/node_modules/qs/.eslintignore | 1 + .../express/node_modules/qs/.eslintrc | 19 + .../express/node_modules/qs/.jscs.json | 176 + .../express/node_modules/qs/CHANGELOG.md | 120 + .../express/node_modules/qs/CONTRIBUTING.md | 1 + node_modules/express/node_modules/qs/LICENSE | 28 + .../express/node_modules/qs/dist/qs.js | 487 + .../express/node_modules/qs/lib/index.js | 9 + .../express/node_modules/qs/lib/parse.js | 167 + .../express/node_modules/qs/lib/stringify.js | 137 + .../express/node_modules/qs/lib/utils.js | 164 + .../express/node_modules/qs/package.json | 86 + .../express/node_modules/qs/test/index.js | 5 + .../express/node_modules/qs/test/parse.js | 423 + .../express/node_modules/qs/test/stringify.js | 305 + .../express/node_modules/qs/test/utils.js | 9 + .../node_modules/range-parser/HISTORY.md | 51 + .../express/node_modules/range-parser/LICENSE | 23 + .../node_modules/range-parser/README.md | 75 + .../node_modules/range-parser/index.js | 158 + .../node_modules/range-parser/package.json | 99 + .../express/node_modules/send/HISTORY.md | 346 + .../express/node_modules/send/LICENSE | 23 + .../express/node_modules/send/README.md | 247 + .../express/node_modules/send/index.js | 948 + .../node_modules/send/node_modules/.bin/mime | 15 + .../send/node_modules/.bin/mime.cmd | 7 + .../send/node_modules/destroy/LICENSE | 22 + .../send/node_modules/destroy/README.md | 60 + .../send/node_modules/destroy/index.js | 75 + .../send/node_modules/destroy/package.json | 72 + .../send/node_modules/http-errors/HISTORY.md | 95 + .../send/node_modules/http-errors/LICENSE | 23 + .../send/node_modules/http-errors/README.md | 112 + .../send/node_modules/http-errors/index.js | 223 + .../http-errors/node_modules/inherits/LICENSE | 16 + .../node_modules/inherits/README.md | 42 + .../node_modules/inherits/inherits.js | 1 + .../node_modules/inherits/inherits_browser.js | 23 + .../node_modules/inherits/package.json | 50 + .../http-errors/node_modules/inherits/test.js | 25 + .../node_modules/setprototypeof/LICENSE | 13 + .../node_modules/setprototypeof/README.md | 21 + .../node_modules/setprototypeof/index.js | 11 + .../node_modules/setprototypeof/package.json | 53 + .../node_modules/http-errors/package.json | 96 + .../send/node_modules/mime/.npmignore | 0 .../send/node_modules/mime/LICENSE | 19 + .../send/node_modules/mime/README.md | 90 + .../send/node_modules/mime/build/build.js | 11 + .../send/node_modules/mime/build/test.js | 57 + .../send/node_modules/mime/cli.js | 8 + .../send/node_modules/mime/mime.js | 108 + .../send/node_modules/mime/package.json | 73 + .../send/node_modules/mime/types.json | 1 + .../send/node_modules/ms/.npmignore | 5 + .../send/node_modules/ms/History.md | 66 + .../node_modules/send/node_modules/ms/LICENSE | 20 + .../send/node_modules/ms/README.md | 35 + .../send/node_modules/ms/index.js | 125 + .../send/node_modules/ms/package.json | 48 + .../send/node_modules/statuses/HISTORY.md | 50 + .../send/node_modules/statuses/LICENSE | 23 + .../send/node_modules/statuses/README.md | 114 + .../send/node_modules/statuses/codes.json | 65 + .../send/node_modules/statuses/index.js | 110 + .../send/node_modules/statuses/package.json | 104 + .../express/node_modules/send/package.json | 96 + .../node_modules/serve-static/HISTORY.md | 332 + .../express/node_modules/serve-static/LICENSE | 25 + .../node_modules/serve-static/README.md | 245 + .../node_modules/serve-static/index.js | 188 + .../node_modules/serve-static/package.json | 74 + .../express/node_modules/type-is/HISTORY.md | 206 + .../express/node_modules/type-is/LICENSE | 23 + .../express/node_modules/type-is/README.md | 136 + .../express/node_modules/type-is/index.js | 262 + .../node_modules/media-typer/HISTORY.md | 22 + .../type-is/node_modules/media-typer/LICENSE | 22 + .../node_modules/media-typer/README.md | 81 + .../type-is/node_modules/media-typer/index.js | 270 + .../node_modules/media-typer/package.json | 58 + .../node_modules/mime-types/HISTORY.md | 204 + .../type-is/node_modules/mime-types/LICENSE | 23 + .../type-is/node_modules/mime-types/README.md | 103 + .../type-is/node_modules/mime-types/index.js | 188 + .../node_modules/mime-db/HISTORY.md | 365 + .../mime-types/node_modules/mime-db/LICENSE | 22 + .../mime-types/node_modules/mime-db/README.md | 82 + .../mime-types/node_modules/mime-db/db.json | 6692 ++++++ .../mime-types/node_modules/mime-db/index.js | 11 + .../node_modules/mime-db/package.json | 99 + .../node_modules/mime-types/package.json | 94 + .../express/node_modules/type-is/package.json | 87 + .../node_modules/utils-merge/.travis.yml | 6 + .../express/node_modules/utils-merge/LICENSE | 20 + .../node_modules/utils-merge/README.md | 34 + .../express/node_modules/utils-merge/index.js | 23 + .../node_modules/utils-merge/package.json | 60 + .../express/node_modules/vary/HISTORY.md | 29 + .../express/node_modules/vary/LICENSE | 22 + .../express/node_modules/vary/README.md | 91 + .../express/node_modules/vary/index.js | 124 + .../express/node_modules/vary/package.json | 72 + node_modules/express/package.json | 160 + node_modules/method-override/HISTORY.md | 116 + node_modules/method-override/LICENSE | 23 + node_modules/method-override/README.md | 173 + node_modules/method-override/index.js | 132 + .../node_modules/debug/.jshintrc | 3 + .../node_modules/debug/.npmignore | 6 + .../node_modules/debug/History.md | 195 + .../node_modules/debug/Makefile | 36 + .../node_modules/debug/Readme.md | 188 + .../node_modules/debug/bower.json | 28 + .../node_modules/debug/browser.js | 168 + .../node_modules/debug/component.json | 19 + .../node_modules/debug/debug.js | 197 + .../node_modules/debug/node.js | 209 + .../debug/node_modules/ms/.npmignore | 5 + .../debug/node_modules/ms/History.md | 66 + .../debug/node_modules/ms/LICENSE | 20 + .../debug/node_modules/ms/README.md | 35 + .../debug/node_modules/ms/index.js | 125 + .../debug/node_modules/ms/package.json | 48 + .../node_modules/debug/package.json | 73 + .../node_modules/methods/HISTORY.md | 29 + .../node_modules/methods/LICENSE | 24 + .../node_modules/methods/README.md | 51 + .../node_modules/methods/index.js | 69 + .../node_modules/methods/package.json | 88 + .../node_modules/parseurl/HISTORY.md | 47 + .../node_modules/parseurl/LICENSE | 24 + .../node_modules/parseurl/README.md | 120 + .../node_modules/parseurl/index.js | 138 + .../node_modules/parseurl/package.json | 89 + .../node_modules/vary/HISTORY.md | 29 + .../method-override/node_modules/vary/LICENSE | 22 + .../node_modules/vary/README.md | 91 + .../node_modules/vary/index.js | 124 + .../node_modules/vary/package.json | 72 + node_modules/method-override/package.json | 100 + node_modules/mongoose/.eslintignore | 3 + node_modules/mongoose/.eslintrc.yml | 31 + node_modules/mongoose/.npmignore | 16 + node_modules/mongoose/.travis.yml | 14 + node_modules/mongoose/CONTRIBUTING.md | 56 + node_modules/mongoose/History.md | 3241 +++ node_modules/mongoose/README.md | 321 + node_modules/mongoose/examples/README.md | 41 + .../mongoose/examples/aggregate/aggregate.js | 103 + .../mongoose/examples/aggregate/package.json | 14 + .../mongoose/examples/aggregate/person.js | 17 + node_modules/mongoose/examples/doc-methods.js | 77 + .../mongoose/examples/express/README.md | 1 + .../express/connection-sharing/README.md | 6 + .../express/connection-sharing/app.js | 17 + .../express/connection-sharing/modelA.js | 5 + .../express/connection-sharing/package.json | 14 + .../express/connection-sharing/routes.js | 20 + .../examples/geospatial/geoJSONSchema.js | 22 + .../examples/geospatial/geoJSONexample.js | 56 + .../examples/geospatial/geospatial.js | 100 + .../mongoose/examples/geospatial/package.json | 14 + .../mongoose/examples/geospatial/person.js | 27 + .../examples/globalschemas/gs_example.js | 47 + .../mongoose/examples/globalschemas/person.js | 14 + node_modules/mongoose/examples/lean/lean.js | 84 + .../mongoose/examples/lean/package.json | 14 + node_modules/mongoose/examples/lean/person.js | 16 + .../mongoose/examples/mapreduce/mapreduce.js | 100 + .../mongoose/examples/mapreduce/package.json | 14 + .../mongoose/examples/mapreduce/person.js | 16 + .../population-across-three-collections.js | 134 + .../examples/population/population-basic.js | 103 + .../population/population-of-existing-doc.js | 109 + .../population-of-multiple-existing-docs.js | 124 + .../examples/population/population-options.js | 138 + .../population/population-plain-objects.js | 106 + .../mongoose/examples/promises/package.json | 14 + .../mongoose/examples/promises/person.js | 15 + .../mongoose/examples/promises/promise.js | 94 + .../examples/querybuilder/package.json | 14 + .../mongoose/examples/querybuilder/person.js | 15 + .../examples/querybuilder/querybuilder.js | 79 + .../examples/replicasets/package.json | 14 + .../mongoose/examples/replicasets/person.js | 15 + .../examples/replicasets/replica-sets.js | 71 + .../mongoose/examples/schema/schema.js | 119 + .../schema/storing-schemas-as-json/index.js | 27 + .../storing-schemas-as-json/schema.json | 9 + .../mongoose/examples/statics/person.js | 20 + .../mongoose/examples/statics/statics.js | 41 + node_modules/mongoose/index.js | 7 + node_modules/mongoose/lib/ES6Promise.js | 26 + node_modules/mongoose/lib/aggregate.js | 685 + node_modules/mongoose/lib/browser.js | 99 + node_modules/mongoose/lib/browserDocument.js | 103 + node_modules/mongoose/lib/cast.js | 255 + node_modules/mongoose/lib/collection.js | 206 + node_modules/mongoose/lib/connection.js | 796 + node_modules/mongoose/lib/connectionstate.js | 27 + node_modules/mongoose/lib/document.js | 2558 +++ .../mongoose/lib/document_provider.js | 21 + .../mongoose/lib/document_provider.web.js | 17 + node_modules/mongoose/lib/drivers/SPEC.md | 4 + .../lib/drivers/browser/ReadPreference.js | 5 + .../mongoose/lib/drivers/browser/binary.js | 12 + .../mongoose/lib/drivers/browser/index.js | 7 + .../mongoose/lib/drivers/browser/objectid.js | 14 + node_modules/mongoose/lib/drivers/index.js | 17 + .../mongoose/lib/drivers/index.web.js | 5 + .../node-mongodb-native/ReadPreference.js | 45 + .../lib/drivers/node-mongodb-native/binary.js | 8 + .../drivers/node-mongodb-native/collection.js | 259 + .../drivers/node-mongodb-native/connection.js | 386 + .../lib/drivers/node-mongodb-native/index.js | 7 + .../drivers/node-mongodb-native/objectid.js | 14 + node_modules/mongoose/lib/error.js | 55 + .../lib/error/browserMissingSchema.js | 32 + node_modules/mongoose/lib/error/cast.js | 49 + .../mongoose/lib/error/disconnected.js | 40 + .../mongoose/lib/error/divergentArray.js | 42 + node_modules/mongoose/lib/error/messages.js | 42 + .../mongoose/lib/error/missingSchema.js | 33 + .../mongoose/lib/error/objectExpected.js | 35 + .../mongoose/lib/error/overwriteModel.js | 31 + node_modules/mongoose/lib/error/strict.js | 35 + node_modules/mongoose/lib/error/validation.js | 63 + node_modules/mongoose/lib/error/validator.js | 81 + node_modules/mongoose/lib/error/version.js | 33 + node_modules/mongoose/lib/index.js | 803 + node_modules/mongoose/lib/internal.js | 31 + node_modules/mongoose/lib/model.js | 3354 +++ node_modules/mongoose/lib/promise.js | 314 + node_modules/mongoose/lib/promise_provider.js | 51 + node_modules/mongoose/lib/query.js | 3346 +++ node_modules/mongoose/lib/querycursor.js | 262 + node_modules/mongoose/lib/queryhelpers.js | 78 + node_modules/mongoose/lib/querystream.js | 367 + node_modules/mongoose/lib/schema.js | 1664 ++ node_modules/mongoose/lib/schema/array.js | 309 + node_modules/mongoose/lib/schema/boolean.js | 103 + node_modules/mongoose/lib/schema/buffer.js | 188 + node_modules/mongoose/lib/schema/date.js | 296 + .../mongoose/lib/schema/documentarray.js | 308 + node_modules/mongoose/lib/schema/embedded.js | 174 + node_modules/mongoose/lib/schema/index.js | 30 + node_modules/mongoose/lib/schema/mixed.js | 80 + node_modules/mongoose/lib/schema/number.js | 290 + node_modules/mongoose/lib/schema/objectid.js | 207 + .../mongoose/lib/schema/operators/bitwise.js | 36 + .../lib/schema/operators/geospatial.js | 100 + .../mongoose/lib/schema/operators/helpers.js | 34 + node_modules/mongoose/lib/schema/string.js | 509 + node_modules/mongoose/lib/schematype.js | 920 + node_modules/mongoose/lib/services/common.js | 87 + .../lib/services/setDefaultsOnInsert.js | 112 + .../mongoose/lib/services/updateValidators.js | 100 + node_modules/mongoose/lib/statemachine.js | 178 + node_modules/mongoose/lib/types/array.js | 777 + node_modules/mongoose/lib/types/buffer.js | 273 + .../mongoose/lib/types/documentarray.js | 256 + node_modules/mongoose/lib/types/embedded.js | 347 + node_modules/mongoose/lib/types/index.js | 15 + node_modules/mongoose/lib/types/objectid.js | 13 + .../mongoose/lib/types/subdocument.js | 152 + node_modules/mongoose/lib/utils.js | 847 + node_modules/mongoose/lib/virtualtype.js | 103 + .../mongoose/node_modules/async/CHANGELOG.md | 208 + .../mongoose/node_modules/async/LICENSE | 19 + .../mongoose/node_modules/async/README.md | 12 + .../mongoose/node_modules/async/apply.js | 62 + .../mongoose/node_modules/async/applyEach.js | 49 + .../node_modules/async/applyEachSeries.js | 37 + .../mongoose/node_modules/async/asyncify.js | 93 + .../mongoose/node_modules/async/auto.js | 285 + .../mongoose/node_modules/async/autoInject.js | 167 + .../mongoose/node_modules/async/bower.json | 17 + .../mongoose/node_modules/async/cargo.js | 95 + .../mongoose/node_modules/async/compose.js | 55 + .../mongoose/node_modules/async/concat.js | 45 + .../node_modules/async/concatSeries.js | 37 + .../mongoose/node_modules/async/constant.js | 65 + .../mongoose/node_modules/async/detect.js | 61 + .../node_modules/async/detectLimit.js | 48 + .../node_modules/async/detectSeries.js | 46 + .../mongoose/node_modules/async/dir.js | 42 + .../mongoose/node_modules/async/dist/async.js | 5215 +++++ .../node_modules/async/dist/async.min.js | 2 + .../mongoose/node_modules/async/doDuring.js | 60 + .../mongoose/node_modules/async/doUntil.js | 39 + .../mongoose/node_modules/async/doWhilst.js | 54 + .../mongoose/node_modules/async/during.js | 71 + .../mongoose/node_modules/async/each.js | 80 + .../mongoose/node_modules/async/eachLimit.js | 42 + .../mongoose/node_modules/async/eachOf.js | 105 + .../node_modules/async/eachOfLimit.js | 39 + .../node_modules/async/eachOfSeries.js | 37 + .../mongoose/node_modules/async/eachSeries.js | 38 + .../node_modules/async/ensureAsync.js | 69 + .../mongoose/node_modules/async/every.js | 50 + .../mongoose/node_modules/async/everyLimit.js | 42 + .../node_modules/async/everySeries.js | 37 + .../mongoose/node_modules/async/filter.js | 45 + .../node_modules/async/filterLimit.js | 37 + .../node_modules/async/filterSeries.js | 35 + .../mongoose/node_modules/async/forever.js | 61 + .../mongoose/node_modules/async/index.js | 505 + .../async/internal/DoublyLinkedList.js | 63 + .../node_modules/async/internal/applyEach.js | 33 + .../node_modules/async/internal/concat.js | 18 + .../async/internal/consoleFunc.js | 35 + .../async/internal/createTester.js | 51 + .../node_modules/async/internal/doLimit.js | 12 + .../node_modules/async/internal/doParallel.js | 19 + .../async/internal/doParallelLimit.js | 19 + .../node_modules/async/internal/doSeries.js | 19 + .../async/internal/eachOfLimit.js | 66 + .../node_modules/async/internal/filter.js | 50 + .../async/internal/findGetResult.js | 10 + .../async/internal/getIterator.js | 13 + .../async/internal/initialParams.js | 20 + .../node_modules/async/internal/iterator.js | 58 + .../node_modules/async/internal/map.js | 34 + .../node_modules/async/internal/notId.js | 10 + .../node_modules/async/internal/once.js | 15 + .../node_modules/async/internal/onlyOnce.js | 15 + .../node_modules/async/internal/parallel.js | 38 + .../node_modules/async/internal/queue.js | 184 + .../node_modules/async/internal/reject.js | 25 + .../async/internal/setImmediate.js | 41 + .../async/internal/withoutIndex.js | 12 + .../mongoose/node_modules/async/log.js | 41 + .../mongoose/node_modules/async/map.js | 54 + .../mongoose/node_modules/async/mapLimit.js | 37 + .../mongoose/node_modules/async/mapSeries.js | 36 + .../mongoose/node_modules/async/mapValues.js | 62 + .../node_modules/async/mapValuesLimit.js | 55 + .../node_modules/async/mapValuesSeries.js | 36 + .../mongoose/node_modules/async/memoize.js | 95 + .../mongoose/node_modules/async/nextTick.js | 51 + .../async/node_modules/lodash/LICENSE | 47 + .../async/node_modules/lodash/README.md | 39 + .../async/node_modules/lodash/_DataView.js | 7 + .../async/node_modules/lodash/_Hash.js | 32 + .../async/node_modules/lodash/_LazyWrapper.js | 28 + .../async/node_modules/lodash/_ListCache.js | 32 + .../node_modules/lodash/_LodashWrapper.js | 22 + .../async/node_modules/lodash/_Map.js | 7 + .../async/node_modules/lodash/_MapCache.js | 32 + .../async/node_modules/lodash/_Promise.js | 7 + .../async/node_modules/lodash/_Set.js | 7 + .../async/node_modules/lodash/_SetCache.js | 27 + .../async/node_modules/lodash/_Stack.js | 27 + .../async/node_modules/lodash/_Symbol.js | 6 + .../async/node_modules/lodash/_Uint8Array.js | 6 + .../async/node_modules/lodash/_WeakMap.js | 7 + .../async/node_modules/lodash/_addMapEntry.js | 15 + .../async/node_modules/lodash/_addSetEntry.js | 15 + .../async/node_modules/lodash/_apply.js | 21 + .../node_modules/lodash/_arrayAggregator.js | 22 + .../async/node_modules/lodash/_arrayEach.js | 22 + .../node_modules/lodash/_arrayEachRight.js | 21 + .../async/node_modules/lodash/_arrayEvery.js | 23 + .../async/node_modules/lodash/_arrayFilter.js | 25 + .../node_modules/lodash/_arrayIncludes.js | 17 + .../node_modules/lodash/_arrayIncludesWith.js | 22 + .../node_modules/lodash/_arrayLikeKeys.js | 49 + .../async/node_modules/lodash/_arrayMap.js | 21 + .../async/node_modules/lodash/_arrayPush.js | 20 + .../async/node_modules/lodash/_arrayReduce.js | 26 + .../node_modules/lodash/_arrayReduceRight.js | 24 + .../async/node_modules/lodash/_arraySample.js | 15 + .../node_modules/lodash/_arraySampleSize.js | 17 + .../node_modules/lodash/_arrayShuffle.js | 15 + .../async/node_modules/lodash/_arraySome.js | 23 + .../async/node_modules/lodash/_asciiSize.js | 12 + .../node_modules/lodash/_asciiToArray.js | 12 + .../async/node_modules/lodash/_asciiWords.js | 15 + .../node_modules/lodash/_assignInDefaults.js | 27 + .../node_modules/lodash/_assignMergeValue.js | 20 + .../async/node_modules/lodash/_assignValue.js | 28 + .../node_modules/lodash/_assocIndexOf.js | 21 + .../node_modules/lodash/_baseAggregator.js | 21 + .../async/node_modules/lodash/_baseAssign.js | 17 + .../node_modules/lodash/_baseAssignValue.js | 25 + .../async/node_modules/lodash/_baseAt.js | 23 + .../async/node_modules/lodash/_baseClamp.js | 22 + .../async/node_modules/lodash/_baseClone.js | 133 + .../node_modules/lodash/_baseConforms.js | 18 + .../node_modules/lodash/_baseConformsTo.js | 27 + .../async/node_modules/lodash/_baseCreate.js | 30 + .../async/node_modules/lodash/_baseDelay.js | 21 + .../node_modules/lodash/_baseDifference.js | 67 + .../async/node_modules/lodash/_baseEach.js | 14 + .../node_modules/lodash/_baseEachRight.js | 14 + .../async/node_modules/lodash/_baseEvery.js | 21 + .../node_modules/lodash/_baseExtremum.js | 32 + .../async/node_modules/lodash/_baseFill.js | 32 + .../async/node_modules/lodash/_baseFilter.js | 21 + .../node_modules/lodash/_baseFindIndex.js | 24 + .../async/node_modules/lodash/_baseFindKey.js | 23 + .../async/node_modules/lodash/_baseFlatten.js | 38 + .../async/node_modules/lodash/_baseFor.js | 16 + .../async/node_modules/lodash/_baseForOwn.js | 16 + .../node_modules/lodash/_baseForOwnRight.js | 16 + .../node_modules/lodash/_baseForRight.js | 15 + .../node_modules/lodash/_baseFunctions.js | 19 + .../async/node_modules/lodash/_baseGet.js | 25 + .../node_modules/lodash/_baseGetAllKeys.js | 20 + .../async/node_modules/lodash/_baseGetTag.js | 22 + .../async/node_modules/lodash/_baseGt.js | 14 + .../async/node_modules/lodash/_baseHas.js | 19 + .../async/node_modules/lodash/_baseHasIn.js | 13 + .../async/node_modules/lodash/_baseInRange.js | 18 + .../async/node_modules/lodash/_baseIndexOf.js | 20 + .../node_modules/lodash/_baseIndexOfWith.js | 23 + .../node_modules/lodash/_baseIntersection.js | 74 + .../node_modules/lodash/_baseInverter.js | 21 + .../async/node_modules/lodash/_baseInvoke.js | 28 + .../node_modules/lodash/_baseIsArguments.js | 27 + .../node_modules/lodash/_baseIsArrayBuffer.js | 26 + .../async/node_modules/lodash/_baseIsDate.js | 27 + .../async/node_modules/lodash/_baseIsEqual.js | 30 + .../node_modules/lodash/_baseIsEqualDeep.js | 89 + .../async/node_modules/lodash/_baseIsMap.js | 18 + .../async/node_modules/lodash/_baseIsMatch.js | 62 + .../async/node_modules/lodash/_baseIsNaN.js | 12 + .../node_modules/lodash/_baseIsNative.js | 47 + .../node_modules/lodash/_baseIsRegExp.js | 27 + .../async/node_modules/lodash/_baseIsSet.js | 18 + .../node_modules/lodash/_baseIsTypedArray.js | 69 + .../node_modules/lodash/_baseIteratee.js | 31 + .../async/node_modules/lodash/_baseKeys.js | 30 + .../async/node_modules/lodash/_baseKeysIn.js | 33 + .../async/node_modules/lodash/_baseLodash.js | 10 + .../async/node_modules/lodash/_baseLt.js | 14 + .../async/node_modules/lodash/_baseMap.js | 22 + .../async/node_modules/lodash/_baseMatches.js | 22 + .../lodash/_baseMatchesProperty.js | 33 + .../async/node_modules/lodash/_baseMean.js | 20 + .../async/node_modules/lodash/_baseMerge.js | 41 + .../node_modules/lodash/_baseMergeDeep.js | 93 + .../async/node_modules/lodash/_baseNth.js | 20 + .../async/node_modules/lodash/_baseOrderBy.js | 34 + .../async/node_modules/lodash/_basePick.js | 19 + .../async/node_modules/lodash/_basePickBy.js | 28 + .../node_modules/lodash/_baseProperty.js | 14 + .../node_modules/lodash/_basePropertyDeep.js | 16 + .../node_modules/lodash/_basePropertyOf.js | 14 + .../async/node_modules/lodash/_basePullAll.js | 51 + .../async/node_modules/lodash/_basePullAt.js | 50 + .../async/node_modules/lodash/_baseRandom.js | 18 + .../async/node_modules/lodash/_baseRange.js | 28 + .../async/node_modules/lodash/_baseReduce.js | 23 + .../async/node_modules/lodash/_baseRepeat.js | 35 + .../async/node_modules/lodash/_baseRest.js | 17 + .../async/node_modules/lodash/_baseSample.js | 15 + .../node_modules/lodash/_baseSampleSize.js | 18 + .../async/node_modules/lodash/_baseSet.js | 48 + .../async/node_modules/lodash/_baseSetData.js | 17 + .../node_modules/lodash/_baseSetToString.js | 22 + .../async/node_modules/lodash/_baseShuffle.js | 15 + .../async/node_modules/lodash/_baseSlice.js | 31 + .../async/node_modules/lodash/_baseSome.js | 22 + .../async/node_modules/lodash/_baseSortBy.js | 21 + .../node_modules/lodash/_baseSortedIndex.js | 42 + .../node_modules/lodash/_baseSortedIndexBy.js | 64 + .../node_modules/lodash/_baseSortedUniq.js | 30 + .../async/node_modules/lodash/_baseSum.js | 24 + .../async/node_modules/lodash/_baseTimes.js | 20 + .../node_modules/lodash/_baseToNumber.js | 24 + .../async/node_modules/lodash/_baseToPairs.js | 18 + .../node_modules/lodash/_baseToString.js | 37 + .../async/node_modules/lodash/_baseUnary.js | 14 + .../async/node_modules/lodash/_baseUniq.js | 72 + .../async/node_modules/lodash/_baseUnset.js | 29 + .../async/node_modules/lodash/_baseUpdate.js | 18 + .../async/node_modules/lodash/_baseValues.js | 19 + .../async/node_modules/lodash/_baseWhile.js | 26 + .../node_modules/lodash/_baseWrapperValue.js | 25 + .../async/node_modules/lodash/_baseXor.js | 30 + .../node_modules/lodash/_baseZipObject.js | 23 + .../async/node_modules/lodash/_cacheHas.js | 13 + .../lodash/_castArrayLikeObject.js | 14 + .../node_modules/lodash/_castFunction.js | 14 + .../async/node_modules/lodash/_castPath.js | 15 + .../async/node_modules/lodash/_castRest.js | 14 + .../async/node_modules/lodash/_castSlice.js | 18 + .../node_modules/lodash/_charsEndIndex.js | 19 + .../node_modules/lodash/_charsStartIndex.js | 20 + .../node_modules/lodash/_cloneArrayBuffer.js | 16 + .../async/node_modules/lodash/_cloneBuffer.js | 35 + .../node_modules/lodash/_cloneDataView.js | 16 + .../async/node_modules/lodash/_cloneMap.js | 19 + .../async/node_modules/lodash/_cloneRegExp.js | 17 + .../async/node_modules/lodash/_cloneSet.js | 19 + .../async/node_modules/lodash/_cloneSymbol.js | 18 + .../node_modules/lodash/_cloneTypedArray.js | 16 + .../node_modules/lodash/_compareAscending.js | 41 + .../node_modules/lodash/_compareMultiple.js | 44 + .../async/node_modules/lodash/_composeArgs.js | 39 + .../node_modules/lodash/_composeArgsRight.js | 41 + .../async/node_modules/lodash/_copyArray.js | 20 + .../async/node_modules/lodash/_copyObject.js | 40 + .../async/node_modules/lodash/_copySymbols.js | 16 + .../async/node_modules/lodash/_coreJsData.js | 6 + .../node_modules/lodash/_countHolders.js | 21 + .../node_modules/lodash/_createAggregator.js | 23 + .../node_modules/lodash/_createAssigner.js | 37 + .../node_modules/lodash/_createBaseEach.js | 32 + .../node_modules/lodash/_createBaseFor.js | 25 + .../async/node_modules/lodash/_createBind.js | 28 + .../node_modules/lodash/_createCaseFirst.js | 33 + .../node_modules/lodash/_createCompounder.js | 24 + .../async/node_modules/lodash/_createCtor.js | 37 + .../async/node_modules/lodash/_createCurry.js | 46 + .../async/node_modules/lodash/_createFind.js | 25 + .../async/node_modules/lodash/_createFlow.js | 82 + .../node_modules/lodash/_createHybrid.js | 92 + .../node_modules/lodash/_createInverter.js | 17 + .../lodash/_createMathOperation.js | 38 + .../async/node_modules/lodash/_createOver.js | 27 + .../node_modules/lodash/_createPadding.js | 33 + .../node_modules/lodash/_createPartial.js | 43 + .../async/node_modules/lodash/_createRange.js | 30 + .../node_modules/lodash/_createRecurry.js | 56 + .../lodash/_createRelationalOperation.js | 20 + .../async/node_modules/lodash/_createRound.js | 33 + .../async/node_modules/lodash/_createSet.js | 19 + .../node_modules/lodash/_createToPairs.js | 30 + .../async/node_modules/lodash/_createWrap.js | 107 + .../node_modules/lodash/_deburrLetter.js | 71 + .../node_modules/lodash/_defineProperty.js | 11 + .../async/node_modules/lodash/_equalArrays.js | 84 + .../async/node_modules/lodash/_equalByTag.js | 113 + .../node_modules/lodash/_equalObjects.js | 90 + .../node_modules/lodash/_escapeHtmlChar.js | 21 + .../node_modules/lodash/_escapeStringChar.js | 22 + .../async/node_modules/lodash/_flatRest.js | 16 + .../async/node_modules/lodash/_freeGlobal.js | 4 + .../async/node_modules/lodash/_getAllKeys.js | 16 + .../node_modules/lodash/_getAllKeysIn.js | 17 + .../async/node_modules/lodash/_getData.js | 15 + .../async/node_modules/lodash/_getFuncName.js | 31 + .../async/node_modules/lodash/_getHolder.js | 13 + .../async/node_modules/lodash/_getMapData.js | 18 + .../node_modules/lodash/_getMatchData.js | 24 + .../async/node_modules/lodash/_getNative.js | 17 + .../node_modules/lodash/_getPrototype.js | 6 + .../async/node_modules/lodash/_getSymbols.js | 16 + .../node_modules/lodash/_getSymbolsIn.js | 26 + .../async/node_modules/lodash/_getTag.js | 68 + .../async/node_modules/lodash/_getValue.js | 13 + .../async/node_modules/lodash/_getView.js | 33 + .../node_modules/lodash/_getWrapDetails.js | 17 + .../async/node_modules/lodash/_hasPath.js | 40 + .../async/node_modules/lodash/_hasUnicode.js | 24 + .../node_modules/lodash/_hasUnicodeWord.js | 15 + .../async/node_modules/lodash/_hashClear.js | 15 + .../async/node_modules/lodash/_hashDelete.js | 17 + .../async/node_modules/lodash/_hashGet.js | 30 + .../async/node_modules/lodash/_hashHas.js | 23 + .../async/node_modules/lodash/_hashSet.js | 23 + .../node_modules/lodash/_initCloneArray.js | 26 + .../node_modules/lodash/_initCloneByTag.js | 80 + .../node_modules/lodash/_initCloneObject.js | 18 + .../node_modules/lodash/_insertWrapDetails.js | 23 + .../node_modules/lodash/_isFlattenable.js | 20 + .../async/node_modules/lodash/_isIndex.js | 22 + .../node_modules/lodash/_isIterateeCall.js | 30 + .../async/node_modules/lodash/_isKey.js | 29 + .../async/node_modules/lodash/_isKeyable.js | 15 + .../async/node_modules/lodash/_isLaziable.js | 28 + .../async/node_modules/lodash/_isMaskable.js | 14 + .../async/node_modules/lodash/_isMasked.js | 20 + .../async/node_modules/lodash/_isPrototype.js | 18 + .../lodash/_isStrictComparable.js | 15 + .../node_modules/lodash/_iteratorToArray.js | 18 + .../async/node_modules/lodash/_lazyClone.js | 23 + .../async/node_modules/lodash/_lazyReverse.js | 23 + .../async/node_modules/lodash/_lazyValue.js | 73 + .../node_modules/lodash/_listCacheClear.js | 13 + .../node_modules/lodash/_listCacheDelete.js | 35 + .../node_modules/lodash/_listCacheGet.js | 19 + .../node_modules/lodash/_listCacheHas.js | 16 + .../node_modules/lodash/_listCacheSet.js | 26 + .../node_modules/lodash/_mapCacheClear.js | 21 + .../node_modules/lodash/_mapCacheDelete.js | 18 + .../async/node_modules/lodash/_mapCacheGet.js | 16 + .../async/node_modules/lodash/_mapCacheHas.js | 16 + .../async/node_modules/lodash/_mapCacheSet.js | 22 + .../async/node_modules/lodash/_mapToArray.js | 18 + .../lodash/_matchesStrictComparable.js | 20 + .../node_modules/lodash/_memoizeCapped.js | 26 + .../async/node_modules/lodash/_mergeData.js | 90 + .../node_modules/lodash/_mergeDefaults.js | 27 + .../async/node_modules/lodash/_metaMap.js | 6 + .../node_modules/lodash/_nativeCreate.js | 6 + .../async/node_modules/lodash/_nativeKeys.js | 6 + .../node_modules/lodash/_nativeKeysIn.js | 20 + .../async/node_modules/lodash/_nodeUtil.js | 22 + .../async/node_modules/lodash/_overArg.js | 15 + .../async/node_modules/lodash/_overRest.js | 36 + .../async/node_modules/lodash/_parent.js | 16 + .../async/node_modules/lodash/_reEscape.js | 4 + .../async/node_modules/lodash/_reEvaluate.js | 4 + .../node_modules/lodash/_reInterpolate.js | 4 + .../async/node_modules/lodash/_realNames.js | 4 + .../async/node_modules/lodash/_reorder.js | 29 + .../node_modules/lodash/_replaceHolders.js | 29 + .../async/node_modules/lodash/_root.js | 9 + .../async/node_modules/lodash/_setCacheAdd.js | 19 + .../async/node_modules/lodash/_setCacheHas.js | 14 + .../async/node_modules/lodash/_setData.js | 20 + .../async/node_modules/lodash/_setToArray.js | 18 + .../async/node_modules/lodash/_setToPairs.js | 18 + .../async/node_modules/lodash/_setToString.js | 14 + .../node_modules/lodash/_setWrapToString.js | 21 + .../async/node_modules/lodash/_shortOut.js | 37 + .../async/node_modules/lodash/_shuffleSelf.js | 28 + .../async/node_modules/lodash/_stackClear.js | 15 + .../async/node_modules/lodash/_stackDelete.js | 18 + .../async/node_modules/lodash/_stackGet.js | 14 + .../async/node_modules/lodash/_stackHas.js | 14 + .../async/node_modules/lodash/_stackSet.js | 34 + .../node_modules/lodash/_strictIndexOf.js | 23 + .../node_modules/lodash/_strictLastIndexOf.js | 21 + .../async/node_modules/lodash/_stringSize.js | 18 + .../node_modules/lodash/_stringToArray.js | 18 + .../node_modules/lodash/_stringToPath.js | 31 + .../async/node_modules/lodash/_toKey.js | 21 + .../async/node_modules/lodash/_toSource.js | 26 + .../node_modules/lodash/_unescapeHtmlChar.js | 21 + .../async/node_modules/lodash/_unicodeSize.js | 42 + .../node_modules/lodash/_unicodeToArray.js | 38 + .../node_modules/lodash/_unicodeWords.js | 63 + .../node_modules/lodash/_updateWrapDetails.js | 46 + .../node_modules/lodash/_wrapperClone.js | 23 + .../async/node_modules/lodash/add.js | 22 + .../async/node_modules/lodash/after.js | 42 + .../async/node_modules/lodash/array.js | 67 + .../async/node_modules/lodash/ary.js | 29 + .../async/node_modules/lodash/assign.js | 58 + .../async/node_modules/lodash/assignIn.js | 40 + .../async/node_modules/lodash/assignInWith.js | 38 + .../async/node_modules/lodash/assignWith.js | 37 + .../async/node_modules/lodash/at.js | 23 + .../async/node_modules/lodash/attempt.js | 35 + .../async/node_modules/lodash/before.js | 40 + .../async/node_modules/lodash/bind.js | 57 + .../async/node_modules/lodash/bindAll.js | 41 + .../async/node_modules/lodash/bindKey.js | 68 + .../async/node_modules/lodash/camelCase.js | 29 + .../async/node_modules/lodash/capitalize.js | 23 + .../async/node_modules/lodash/castArray.js | 44 + .../async/node_modules/lodash/ceil.js | 26 + .../async/node_modules/lodash/chain.js | 38 + .../async/node_modules/lodash/chunk.js | 50 + .../async/node_modules/lodash/clamp.js | 39 + .../async/node_modules/lodash/clone.js | 33 + .../async/node_modules/lodash/cloneDeep.js | 25 + .../node_modules/lodash/cloneDeepWith.js | 35 + .../async/node_modules/lodash/cloneWith.js | 38 + .../async/node_modules/lodash/collection.js | 30 + .../async/node_modules/lodash/commit.js | 33 + .../async/node_modules/lodash/compact.js | 31 + .../async/node_modules/lodash/concat.js | 43 + .../async/node_modules/lodash/cond.js | 60 + .../async/node_modules/lodash/conforms.js | 32 + .../async/node_modules/lodash/conformsTo.js | 32 + .../async/node_modules/lodash/constant.js | 26 + .../async/node_modules/lodash/core.js | 3831 ++++ .../async/node_modules/lodash/core.min.js | 29 + .../async/node_modules/lodash/countBy.js | 41 + .../async/node_modules/lodash/create.js | 43 + .../async/node_modules/lodash/curry.js | 57 + .../async/node_modules/lodash/curryRight.js | 54 + .../async/node_modules/lodash/date.js | 3 + .../async/node_modules/lodash/debounce.js | 188 + .../async/node_modules/lodash/deburr.js | 43 + .../async/node_modules/lodash/defaultTo.js | 25 + .../async/node_modules/lodash/defaults.js | 32 + .../async/node_modules/lodash/defaultsDeep.js | 30 + .../async/node_modules/lodash/defer.js | 26 + .../async/node_modules/lodash/delay.js | 28 + .../async/node_modules/lodash/difference.js | 33 + .../async/node_modules/lodash/differenceBy.js | 44 + .../node_modules/lodash/differenceWith.js | 40 + .../async/node_modules/lodash/divide.js | 22 + .../async/node_modules/lodash/drop.js | 38 + .../async/node_modules/lodash/dropRight.js | 39 + .../node_modules/lodash/dropRightWhile.js | 45 + .../async/node_modules/lodash/dropWhile.js | 46 + .../async/node_modules/lodash/each.js | 1 + .../async/node_modules/lodash/eachRight.js | 1 + .../async/node_modules/lodash/endsWith.js | 43 + .../async/node_modules/lodash/entries.js | 1 + .../async/node_modules/lodash/entriesIn.js | 1 + .../async/node_modules/lodash/eq.js | 37 + .../async/node_modules/lodash/escape.js | 43 + .../async/node_modules/lodash/escapeRegExp.js | 32 + .../async/node_modules/lodash/every.js | 57 + .../async/node_modules/lodash/extend.js | 1 + .../async/node_modules/lodash/extendWith.js | 1 + .../async/node_modules/lodash/fill.js | 45 + .../async/node_modules/lodash/filter.js | 49 + .../async/node_modules/lodash/find.js | 43 + .../async/node_modules/lodash/findIndex.js | 56 + .../async/node_modules/lodash/findKey.js | 44 + .../async/node_modules/lodash/findLast.js | 26 + .../node_modules/lodash/findLastIndex.js | 60 + .../async/node_modules/lodash/findLastKey.js | 44 + .../async/node_modules/lodash/first.js | 1 + .../async/node_modules/lodash/flatMap.js | 30 + .../async/node_modules/lodash/flatMapDeep.js | 32 + .../async/node_modules/lodash/flatMapDepth.js | 32 + .../async/node_modules/lodash/flatten.js | 22 + .../async/node_modules/lodash/flattenDeep.js | 25 + .../async/node_modules/lodash/flattenDepth.js | 33 + .../async/node_modules/lodash/flip.js | 28 + .../async/node_modules/lodash/floor.js | 26 + .../async/node_modules/lodash/flow.js | 27 + .../async/node_modules/lodash/flowRight.js | 26 + .../async/node_modules/lodash/forEach.js | 41 + .../async/node_modules/lodash/forEachRight.js | 31 + .../async/node_modules/lodash/forIn.js | 39 + .../async/node_modules/lodash/forInRight.js | 37 + .../async/node_modules/lodash/forOwn.js | 36 + .../async/node_modules/lodash/forOwnRight.js | 34 + .../async/node_modules/lodash/fp.js | 2 + .../async/node_modules/lodash/fp/F.js | 1 + .../async/node_modules/lodash/fp/T.js | 1 + .../async/node_modules/lodash/fp/__.js | 1 + .../node_modules/lodash/fp/_baseConvert.js | 535 + .../node_modules/lodash/fp/_convertBrowser.js | 18 + .../node_modules/lodash/fp/_falseOptions.js | 7 + .../async/node_modules/lodash/fp/_mapping.js | 367 + .../async/node_modules/lodash/fp/_util.js | 15 + .../async/node_modules/lodash/fp/add.js | 5 + .../async/node_modules/lodash/fp/after.js | 5 + .../async/node_modules/lodash/fp/all.js | 1 + .../async/node_modules/lodash/fp/allPass.js | 1 + .../async/node_modules/lodash/fp/always.js | 1 + .../async/node_modules/lodash/fp/any.js | 1 + .../async/node_modules/lodash/fp/anyPass.js | 1 + .../async/node_modules/lodash/fp/apply.js | 1 + .../async/node_modules/lodash/fp/array.js | 2 + .../async/node_modules/lodash/fp/ary.js | 5 + .../async/node_modules/lodash/fp/assign.js | 5 + .../async/node_modules/lodash/fp/assignAll.js | 5 + .../node_modules/lodash/fp/assignAllWith.js | 5 + .../async/node_modules/lodash/fp/assignIn.js | 5 + .../node_modules/lodash/fp/assignInAll.js | 5 + .../node_modules/lodash/fp/assignInAllWith.js | 5 + .../node_modules/lodash/fp/assignInWith.js | 5 + .../node_modules/lodash/fp/assignWith.js | 5 + .../async/node_modules/lodash/fp/assoc.js | 1 + .../async/node_modules/lodash/fp/assocPath.js | 1 + .../async/node_modules/lodash/fp/at.js | 5 + .../async/node_modules/lodash/fp/attempt.js | 5 + .../async/node_modules/lodash/fp/before.js | 5 + .../async/node_modules/lodash/fp/bind.js | 5 + .../async/node_modules/lodash/fp/bindAll.js | 5 + .../async/node_modules/lodash/fp/bindKey.js | 5 + .../async/node_modules/lodash/fp/camelCase.js | 5 + .../node_modules/lodash/fp/capitalize.js | 5 + .../async/node_modules/lodash/fp/castArray.js | 5 + .../async/node_modules/lodash/fp/ceil.js | 5 + .../async/node_modules/lodash/fp/chain.js | 5 + .../async/node_modules/lodash/fp/chunk.js | 5 + .../async/node_modules/lodash/fp/clamp.js | 5 + .../async/node_modules/lodash/fp/clone.js | 5 + .../async/node_modules/lodash/fp/cloneDeep.js | 5 + .../node_modules/lodash/fp/cloneDeepWith.js | 5 + .../async/node_modules/lodash/fp/cloneWith.js | 5 + .../node_modules/lodash/fp/collection.js | 2 + .../async/node_modules/lodash/fp/commit.js | 5 + .../async/node_modules/lodash/fp/compact.js | 5 + .../node_modules/lodash/fp/complement.js | 1 + .../async/node_modules/lodash/fp/compose.js | 1 + .../async/node_modules/lodash/fp/concat.js | 5 + .../async/node_modules/lodash/fp/cond.js | 5 + .../async/node_modules/lodash/fp/conforms.js | 1 + .../node_modules/lodash/fp/conformsTo.js | 5 + .../async/node_modules/lodash/fp/constant.js | 5 + .../async/node_modules/lodash/fp/contains.js | 1 + .../async/node_modules/lodash/fp/convert.js | 18 + .../async/node_modules/lodash/fp/countBy.js | 5 + .../async/node_modules/lodash/fp/create.js | 5 + .../async/node_modules/lodash/fp/curry.js | 5 + .../async/node_modules/lodash/fp/curryN.js | 5 + .../node_modules/lodash/fp/curryRight.js | 5 + .../node_modules/lodash/fp/curryRightN.js | 5 + .../async/node_modules/lodash/fp/date.js | 2 + .../async/node_modules/lodash/fp/debounce.js | 5 + .../async/node_modules/lodash/fp/deburr.js | 5 + .../async/node_modules/lodash/fp/defaultTo.js | 5 + .../async/node_modules/lodash/fp/defaults.js | 5 + .../node_modules/lodash/fp/defaultsAll.js | 5 + .../node_modules/lodash/fp/defaultsDeep.js | 5 + .../node_modules/lodash/fp/defaultsDeepAll.js | 5 + .../async/node_modules/lodash/fp/defer.js | 5 + .../async/node_modules/lodash/fp/delay.js | 5 + .../node_modules/lodash/fp/difference.js | 5 + .../node_modules/lodash/fp/differenceBy.js | 5 + .../node_modules/lodash/fp/differenceWith.js | 5 + .../async/node_modules/lodash/fp/dissoc.js | 1 + .../node_modules/lodash/fp/dissocPath.js | 1 + .../async/node_modules/lodash/fp/divide.js | 5 + .../async/node_modules/lodash/fp/drop.js | 5 + .../async/node_modules/lodash/fp/dropLast.js | 1 + .../node_modules/lodash/fp/dropLastWhile.js | 1 + .../async/node_modules/lodash/fp/dropRight.js | 5 + .../node_modules/lodash/fp/dropRightWhile.js | 5 + .../async/node_modules/lodash/fp/dropWhile.js | 5 + .../async/node_modules/lodash/fp/each.js | 1 + .../async/node_modules/lodash/fp/eachRight.js | 1 + .../async/node_modules/lodash/fp/endsWith.js | 5 + .../async/node_modules/lodash/fp/entries.js | 1 + .../async/node_modules/lodash/fp/entriesIn.js | 1 + .../async/node_modules/lodash/fp/eq.js | 5 + .../async/node_modules/lodash/fp/equals.js | 1 + .../async/node_modules/lodash/fp/escape.js | 5 + .../node_modules/lodash/fp/escapeRegExp.js | 5 + .../async/node_modules/lodash/fp/every.js | 5 + .../async/node_modules/lodash/fp/extend.js | 1 + .../async/node_modules/lodash/fp/extendAll.js | 1 + .../node_modules/lodash/fp/extendAllWith.js | 1 + .../node_modules/lodash/fp/extendWith.js | 1 + .../async/node_modules/lodash/fp/fill.js | 5 + .../async/node_modules/lodash/fp/filter.js | 5 + .../async/node_modules/lodash/fp/find.js | 5 + .../async/node_modules/lodash/fp/findFrom.js | 5 + .../async/node_modules/lodash/fp/findIndex.js | 5 + .../node_modules/lodash/fp/findIndexFrom.js | 5 + .../async/node_modules/lodash/fp/findKey.js | 5 + .../async/node_modules/lodash/fp/findLast.js | 5 + .../node_modules/lodash/fp/findLastFrom.js | 5 + .../node_modules/lodash/fp/findLastIndex.js | 5 + .../lodash/fp/findLastIndexFrom.js | 5 + .../node_modules/lodash/fp/findLastKey.js | 5 + .../async/node_modules/lodash/fp/first.js | 1 + .../async/node_modules/lodash/fp/flatMap.js | 5 + .../node_modules/lodash/fp/flatMapDeep.js | 5 + .../node_modules/lodash/fp/flatMapDepth.js | 5 + .../async/node_modules/lodash/fp/flatten.js | 5 + .../node_modules/lodash/fp/flattenDeep.js | 5 + .../node_modules/lodash/fp/flattenDepth.js | 5 + .../async/node_modules/lodash/fp/flip.js | 5 + .../async/node_modules/lodash/fp/floor.js | 5 + .../async/node_modules/lodash/fp/flow.js | 5 + .../async/node_modules/lodash/fp/flowRight.js | 5 + .../async/node_modules/lodash/fp/forEach.js | 5 + .../node_modules/lodash/fp/forEachRight.js | 5 + .../async/node_modules/lodash/fp/forIn.js | 5 + .../node_modules/lodash/fp/forInRight.js | 5 + .../async/node_modules/lodash/fp/forOwn.js | 5 + .../node_modules/lodash/fp/forOwnRight.js | 5 + .../async/node_modules/lodash/fp/fromPairs.js | 5 + .../async/node_modules/lodash/fp/function.js | 2 + .../async/node_modules/lodash/fp/functions.js | 5 + .../node_modules/lodash/fp/functionsIn.js | 5 + .../async/node_modules/lodash/fp/get.js | 5 + .../async/node_modules/lodash/fp/getOr.js | 5 + .../async/node_modules/lodash/fp/groupBy.js | 5 + .../async/node_modules/lodash/fp/gt.js | 5 + .../async/node_modules/lodash/fp/gte.js | 5 + .../async/node_modules/lodash/fp/has.js | 5 + .../async/node_modules/lodash/fp/hasIn.js | 5 + .../async/node_modules/lodash/fp/head.js | 5 + .../async/node_modules/lodash/fp/identical.js | 1 + .../async/node_modules/lodash/fp/identity.js | 5 + .../async/node_modules/lodash/fp/inRange.js | 5 + .../async/node_modules/lodash/fp/includes.js | 5 + .../node_modules/lodash/fp/includesFrom.js | 5 + .../async/node_modules/lodash/fp/indexBy.js | 1 + .../async/node_modules/lodash/fp/indexOf.js | 5 + .../node_modules/lodash/fp/indexOfFrom.js | 5 + .../async/node_modules/lodash/fp/init.js | 1 + .../async/node_modules/lodash/fp/initial.js | 5 + .../node_modules/lodash/fp/intersection.js | 5 + .../node_modules/lodash/fp/intersectionBy.js | 5 + .../lodash/fp/intersectionWith.js | 5 + .../async/node_modules/lodash/fp/invert.js | 5 + .../async/node_modules/lodash/fp/invertBy.js | 5 + .../async/node_modules/lodash/fp/invertObj.js | 1 + .../async/node_modules/lodash/fp/invoke.js | 5 + .../node_modules/lodash/fp/invokeArgs.js | 5 + .../node_modules/lodash/fp/invokeArgsMap.js | 5 + .../async/node_modules/lodash/fp/invokeMap.js | 5 + .../node_modules/lodash/fp/isArguments.js | 5 + .../async/node_modules/lodash/fp/isArray.js | 5 + .../node_modules/lodash/fp/isArrayBuffer.js | 5 + .../node_modules/lodash/fp/isArrayLike.js | 5 + .../lodash/fp/isArrayLikeObject.js | 5 + .../async/node_modules/lodash/fp/isBoolean.js | 5 + .../async/node_modules/lodash/fp/isBuffer.js | 5 + .../async/node_modules/lodash/fp/isDate.js | 5 + .../async/node_modules/lodash/fp/isElement.js | 5 + .../async/node_modules/lodash/fp/isEmpty.js | 5 + .../async/node_modules/lodash/fp/isEqual.js | 5 + .../node_modules/lodash/fp/isEqualWith.js | 5 + .../async/node_modules/lodash/fp/isError.js | 5 + .../async/node_modules/lodash/fp/isFinite.js | 5 + .../node_modules/lodash/fp/isFunction.js | 5 + .../async/node_modules/lodash/fp/isInteger.js | 5 + .../async/node_modules/lodash/fp/isLength.js | 5 + .../async/node_modules/lodash/fp/isMap.js | 5 + .../async/node_modules/lodash/fp/isMatch.js | 5 + .../node_modules/lodash/fp/isMatchWith.js | 5 + .../async/node_modules/lodash/fp/isNaN.js | 5 + .../async/node_modules/lodash/fp/isNative.js | 5 + .../async/node_modules/lodash/fp/isNil.js | 5 + .../async/node_modules/lodash/fp/isNull.js | 5 + .../async/node_modules/lodash/fp/isNumber.js | 5 + .../async/node_modules/lodash/fp/isObject.js | 5 + .../node_modules/lodash/fp/isObjectLike.js | 5 + .../node_modules/lodash/fp/isPlainObject.js | 5 + .../async/node_modules/lodash/fp/isRegExp.js | 5 + .../node_modules/lodash/fp/isSafeInteger.js | 5 + .../async/node_modules/lodash/fp/isSet.js | 5 + .../async/node_modules/lodash/fp/isString.js | 5 + .../async/node_modules/lodash/fp/isSymbol.js | 5 + .../node_modules/lodash/fp/isTypedArray.js | 5 + .../node_modules/lodash/fp/isUndefined.js | 5 + .../async/node_modules/lodash/fp/isWeakMap.js | 5 + .../async/node_modules/lodash/fp/isWeakSet.js | 5 + .../async/node_modules/lodash/fp/iteratee.js | 5 + .../async/node_modules/lodash/fp/join.js | 5 + .../async/node_modules/lodash/fp/juxt.js | 1 + .../async/node_modules/lodash/fp/kebabCase.js | 5 + .../async/node_modules/lodash/fp/keyBy.js | 5 + .../async/node_modules/lodash/fp/keys.js | 5 + .../async/node_modules/lodash/fp/keysIn.js | 5 + .../async/node_modules/lodash/fp/lang.js | 2 + .../async/node_modules/lodash/fp/last.js | 5 + .../node_modules/lodash/fp/lastIndexOf.js | 5 + .../node_modules/lodash/fp/lastIndexOfFrom.js | 5 + .../async/node_modules/lodash/fp/lowerCase.js | 5 + .../node_modules/lodash/fp/lowerFirst.js | 5 + .../async/node_modules/lodash/fp/lt.js | 5 + .../async/node_modules/lodash/fp/lte.js | 5 + .../async/node_modules/lodash/fp/map.js | 5 + .../async/node_modules/lodash/fp/mapKeys.js | 5 + .../async/node_modules/lodash/fp/mapValues.js | 5 + .../async/node_modules/lodash/fp/matches.js | 1 + .../node_modules/lodash/fp/matchesProperty.js | 5 + .../async/node_modules/lodash/fp/math.js | 2 + .../async/node_modules/lodash/fp/max.js | 5 + .../async/node_modules/lodash/fp/maxBy.js | 5 + .../async/node_modules/lodash/fp/mean.js | 5 + .../async/node_modules/lodash/fp/meanBy.js | 5 + .../async/node_modules/lodash/fp/memoize.js | 5 + .../async/node_modules/lodash/fp/merge.js | 5 + .../async/node_modules/lodash/fp/mergeAll.js | 5 + .../node_modules/lodash/fp/mergeAllWith.js | 5 + .../async/node_modules/lodash/fp/mergeWith.js | 5 + .../async/node_modules/lodash/fp/method.js | 5 + .../async/node_modules/lodash/fp/methodOf.js | 5 + .../async/node_modules/lodash/fp/min.js | 5 + .../async/node_modules/lodash/fp/minBy.js | 5 + .../async/node_modules/lodash/fp/mixin.js | 5 + .../async/node_modules/lodash/fp/multiply.js | 5 + .../async/node_modules/lodash/fp/nAry.js | 1 + .../async/node_modules/lodash/fp/negate.js | 5 + .../async/node_modules/lodash/fp/next.js | 5 + .../async/node_modules/lodash/fp/noop.js | 5 + .../async/node_modules/lodash/fp/now.js | 5 + .../async/node_modules/lodash/fp/nth.js | 5 + .../async/node_modules/lodash/fp/nthArg.js | 5 + .../async/node_modules/lodash/fp/number.js | 2 + .../async/node_modules/lodash/fp/object.js | 2 + .../async/node_modules/lodash/fp/omit.js | 5 + .../async/node_modules/lodash/fp/omitAll.js | 1 + .../async/node_modules/lodash/fp/omitBy.js | 5 + .../async/node_modules/lodash/fp/once.js | 5 + .../async/node_modules/lodash/fp/orderBy.js | 5 + .../async/node_modules/lodash/fp/over.js | 5 + .../async/node_modules/lodash/fp/overArgs.js | 5 + .../async/node_modules/lodash/fp/overEvery.js | 5 + .../async/node_modules/lodash/fp/overSome.js | 5 + .../async/node_modules/lodash/fp/pad.js | 5 + .../async/node_modules/lodash/fp/padChars.js | 5 + .../node_modules/lodash/fp/padCharsEnd.js | 5 + .../node_modules/lodash/fp/padCharsStart.js | 5 + .../async/node_modules/lodash/fp/padEnd.js | 5 + .../async/node_modules/lodash/fp/padStart.js | 5 + .../async/node_modules/lodash/fp/parseInt.js | 5 + .../async/node_modules/lodash/fp/partial.js | 5 + .../node_modules/lodash/fp/partialRight.js | 5 + .../async/node_modules/lodash/fp/partition.js | 5 + .../async/node_modules/lodash/fp/path.js | 1 + .../async/node_modules/lodash/fp/pathEq.js | 1 + .../async/node_modules/lodash/fp/pathOr.js | 1 + .../async/node_modules/lodash/fp/paths.js | 1 + .../async/node_modules/lodash/fp/pick.js | 5 + .../async/node_modules/lodash/fp/pickAll.js | 1 + .../async/node_modules/lodash/fp/pickBy.js | 5 + .../async/node_modules/lodash/fp/pipe.js | 1 + .../node_modules/lodash/fp/placeholder.js | 6 + .../async/node_modules/lodash/fp/plant.js | 5 + .../async/node_modules/lodash/fp/pluck.js | 1 + .../async/node_modules/lodash/fp/prop.js | 1 + .../async/node_modules/lodash/fp/propEq.js | 1 + .../async/node_modules/lodash/fp/propOr.js | 1 + .../async/node_modules/lodash/fp/property.js | 1 + .../node_modules/lodash/fp/propertyOf.js | 5 + .../async/node_modules/lodash/fp/props.js | 1 + .../async/node_modules/lodash/fp/pull.js | 5 + .../async/node_modules/lodash/fp/pullAll.js | 5 + .../async/node_modules/lodash/fp/pullAllBy.js | 5 + .../node_modules/lodash/fp/pullAllWith.js | 5 + .../async/node_modules/lodash/fp/pullAt.js | 5 + .../async/node_modules/lodash/fp/random.js | 5 + .../async/node_modules/lodash/fp/range.js | 5 + .../node_modules/lodash/fp/rangeRight.js | 5 + .../async/node_modules/lodash/fp/rangeStep.js | 5 + .../node_modules/lodash/fp/rangeStepRight.js | 5 + .../async/node_modules/lodash/fp/rearg.js | 5 + .../async/node_modules/lodash/fp/reduce.js | 5 + .../node_modules/lodash/fp/reduceRight.js | 5 + .../async/node_modules/lodash/fp/reject.js | 5 + .../async/node_modules/lodash/fp/remove.js | 5 + .../async/node_modules/lodash/fp/repeat.js | 5 + .../async/node_modules/lodash/fp/replace.js | 5 + .../async/node_modules/lodash/fp/rest.js | 5 + .../async/node_modules/lodash/fp/restFrom.js | 5 + .../async/node_modules/lodash/fp/result.js | 5 + .../async/node_modules/lodash/fp/reverse.js | 5 + .../async/node_modules/lodash/fp/round.js | 5 + .../async/node_modules/lodash/fp/sample.js | 5 + .../node_modules/lodash/fp/sampleSize.js | 5 + .../async/node_modules/lodash/fp/seq.js | 2 + .../async/node_modules/lodash/fp/set.js | 5 + .../async/node_modules/lodash/fp/setWith.js | 5 + .../async/node_modules/lodash/fp/shuffle.js | 5 + .../async/node_modules/lodash/fp/size.js | 5 + .../async/node_modules/lodash/fp/slice.js | 5 + .../async/node_modules/lodash/fp/snakeCase.js | 5 + .../async/node_modules/lodash/fp/some.js | 5 + .../async/node_modules/lodash/fp/sortBy.js | 5 + .../node_modules/lodash/fp/sortedIndex.js | 5 + .../node_modules/lodash/fp/sortedIndexBy.js | 5 + .../node_modules/lodash/fp/sortedIndexOf.js | 5 + .../node_modules/lodash/fp/sortedLastIndex.js | 5 + .../lodash/fp/sortedLastIndexBy.js | 5 + .../lodash/fp/sortedLastIndexOf.js | 5 + .../node_modules/lodash/fp/sortedUniq.js | 5 + .../node_modules/lodash/fp/sortedUniqBy.js | 5 + .../async/node_modules/lodash/fp/split.js | 5 + .../async/node_modules/lodash/fp/spread.js | 5 + .../node_modules/lodash/fp/spreadFrom.js | 5 + .../async/node_modules/lodash/fp/startCase.js | 5 + .../node_modules/lodash/fp/startsWith.js | 5 + .../async/node_modules/lodash/fp/string.js | 2 + .../async/node_modules/lodash/fp/stubArray.js | 5 + .../async/node_modules/lodash/fp/stubFalse.js | 5 + .../node_modules/lodash/fp/stubObject.js | 5 + .../node_modules/lodash/fp/stubString.js | 5 + .../async/node_modules/lodash/fp/stubTrue.js | 5 + .../async/node_modules/lodash/fp/subtract.js | 5 + .../async/node_modules/lodash/fp/sum.js | 5 + .../async/node_modules/lodash/fp/sumBy.js | 5 + .../lodash/fp/symmetricDifference.js | 1 + .../lodash/fp/symmetricDifferenceBy.js | 1 + .../lodash/fp/symmetricDifferenceWith.js | 1 + .../async/node_modules/lodash/fp/tail.js | 5 + .../async/node_modules/lodash/fp/take.js | 5 + .../async/node_modules/lodash/fp/takeLast.js | 1 + .../node_modules/lodash/fp/takeLastWhile.js | 1 + .../async/node_modules/lodash/fp/takeRight.js | 5 + .../node_modules/lodash/fp/takeRightWhile.js | 5 + .../async/node_modules/lodash/fp/takeWhile.js | 5 + .../async/node_modules/lodash/fp/tap.js | 5 + .../async/node_modules/lodash/fp/template.js | 5 + .../lodash/fp/templateSettings.js | 5 + .../async/node_modules/lodash/fp/throttle.js | 5 + .../async/node_modules/lodash/fp/thru.js | 5 + .../async/node_modules/lodash/fp/times.js | 5 + .../async/node_modules/lodash/fp/toArray.js | 5 + .../async/node_modules/lodash/fp/toFinite.js | 5 + .../async/node_modules/lodash/fp/toInteger.js | 5 + .../node_modules/lodash/fp/toIterator.js | 5 + .../async/node_modules/lodash/fp/toJSON.js | 5 + .../async/node_modules/lodash/fp/toLength.js | 5 + .../async/node_modules/lodash/fp/toLower.js | 5 + .../async/node_modules/lodash/fp/toNumber.js | 5 + .../async/node_modules/lodash/fp/toPairs.js | 5 + .../async/node_modules/lodash/fp/toPairsIn.js | 5 + .../async/node_modules/lodash/fp/toPath.js | 5 + .../node_modules/lodash/fp/toPlainObject.js | 5 + .../node_modules/lodash/fp/toSafeInteger.js | 5 + .../async/node_modules/lodash/fp/toString.js | 5 + .../async/node_modules/lodash/fp/toUpper.js | 5 + .../async/node_modules/lodash/fp/transform.js | 5 + .../async/node_modules/lodash/fp/trim.js | 5 + .../async/node_modules/lodash/fp/trimChars.js | 5 + .../node_modules/lodash/fp/trimCharsEnd.js | 5 + .../node_modules/lodash/fp/trimCharsStart.js | 5 + .../async/node_modules/lodash/fp/trimEnd.js | 5 + .../async/node_modules/lodash/fp/trimStart.js | 5 + .../async/node_modules/lodash/fp/truncate.js | 5 + .../async/node_modules/lodash/fp/unapply.js | 1 + .../async/node_modules/lodash/fp/unary.js | 5 + .../async/node_modules/lodash/fp/unescape.js | 5 + .../async/node_modules/lodash/fp/union.js | 5 + .../async/node_modules/lodash/fp/unionBy.js | 5 + .../async/node_modules/lodash/fp/unionWith.js | 5 + .../async/node_modules/lodash/fp/uniq.js | 5 + .../async/node_modules/lodash/fp/uniqBy.js | 5 + .../async/node_modules/lodash/fp/uniqWith.js | 5 + .../async/node_modules/lodash/fp/uniqueId.js | 5 + .../async/node_modules/lodash/fp/unnest.js | 1 + .../async/node_modules/lodash/fp/unset.js | 5 + .../async/node_modules/lodash/fp/unzip.js | 5 + .../async/node_modules/lodash/fp/unzipWith.js | 5 + .../async/node_modules/lodash/fp/update.js | 5 + .../node_modules/lodash/fp/updateWith.js | 5 + .../async/node_modules/lodash/fp/upperCase.js | 5 + .../node_modules/lodash/fp/upperFirst.js | 5 + .../async/node_modules/lodash/fp/useWith.js | 1 + .../async/node_modules/lodash/fp/util.js | 2 + .../async/node_modules/lodash/fp/value.js | 5 + .../async/node_modules/lodash/fp/valueOf.js | 5 + .../async/node_modules/lodash/fp/values.js | 5 + .../async/node_modules/lodash/fp/valuesIn.js | 5 + .../async/node_modules/lodash/fp/where.js | 1 + .../async/node_modules/lodash/fp/whereEq.js | 1 + .../async/node_modules/lodash/fp/without.js | 5 + .../async/node_modules/lodash/fp/words.js | 5 + .../async/node_modules/lodash/fp/wrap.js | 5 + .../async/node_modules/lodash/fp/wrapperAt.js | 5 + .../node_modules/lodash/fp/wrapperChain.js | 5 + .../node_modules/lodash/fp/wrapperLodash.js | 5 + .../node_modules/lodash/fp/wrapperReverse.js | 5 + .../node_modules/lodash/fp/wrapperValue.js | 5 + .../async/node_modules/lodash/fp/xor.js | 5 + .../async/node_modules/lodash/fp/xorBy.js | 5 + .../async/node_modules/lodash/fp/xorWith.js | 5 + .../async/node_modules/lodash/fp/zip.js | 5 + .../async/node_modules/lodash/fp/zipAll.js | 5 + .../async/node_modules/lodash/fp/zipObj.js | 1 + .../async/node_modules/lodash/fp/zipObject.js | 5 + .../node_modules/lodash/fp/zipObjectDeep.js | 5 + .../async/node_modules/lodash/fp/zipWith.js | 5 + .../async/node_modules/lodash/fromPairs.js | 28 + .../async/node_modules/lodash/function.js | 25 + .../async/node_modules/lodash/functions.js | 31 + .../async/node_modules/lodash/functionsIn.js | 31 + .../async/node_modules/lodash/get.js | 33 + .../async/node_modules/lodash/groupBy.js | 42 + .../async/node_modules/lodash/gt.js | 29 + .../async/node_modules/lodash/gte.js | 30 + .../async/node_modules/lodash/has.js | 35 + .../async/node_modules/lodash/hasIn.js | 34 + .../async/node_modules/lodash/head.js | 23 + .../async/node_modules/lodash/identity.js | 21 + .../async/node_modules/lodash/inRange.js | 55 + .../async/node_modules/lodash/includes.js | 53 + .../async/node_modules/lodash/index.js | 1 + .../async/node_modules/lodash/indexOf.js | 42 + .../async/node_modules/lodash/initial.js | 22 + .../async/node_modules/lodash/intersection.js | 30 + .../node_modules/lodash/intersectionBy.js | 45 + .../node_modules/lodash/intersectionWith.js | 42 + .../async/node_modules/lodash/invert.js | 27 + .../async/node_modules/lodash/invertBy.js | 44 + .../async/node_modules/lodash/invoke.js | 24 + .../async/node_modules/lodash/invokeMap.js | 44 + .../async/node_modules/lodash/isArguments.js | 36 + .../async/node_modules/lodash/isArray.js | 26 + .../node_modules/lodash/isArrayBuffer.js | 27 + .../async/node_modules/lodash/isArrayLike.js | 33 + .../node_modules/lodash/isArrayLikeObject.js | 33 + .../async/node_modules/lodash/isBoolean.js | 38 + .../async/node_modules/lodash/isBuffer.js | 38 + .../async/node_modules/lodash/isDate.js | 27 + .../async/node_modules/lodash/isElement.js | 25 + .../async/node_modules/lodash/isEmpty.js | 74 + .../async/node_modules/lodash/isEqual.js | 35 + .../async/node_modules/lodash/isEqualWith.js | 41 + .../async/node_modules/lodash/isError.js | 42 + .../async/node_modules/lodash/isFinite.js | 36 + .../async/node_modules/lodash/isFunction.js | 42 + .../async/node_modules/lodash/isInteger.js | 33 + .../async/node_modules/lodash/isLength.js | 35 + .../async/node_modules/lodash/isMap.js | 27 + .../async/node_modules/lodash/isMatch.js | 36 + .../async/node_modules/lodash/isMatchWith.js | 41 + .../async/node_modules/lodash/isNaN.js | 38 + .../async/node_modules/lodash/isNative.js | 40 + .../async/node_modules/lodash/isNil.js | 25 + .../async/node_modules/lodash/isNull.js | 22 + .../async/node_modules/lodash/isNumber.js | 47 + .../async/node_modules/lodash/isObject.js | 31 + .../async/node_modules/lodash/isObjectLike.js | 29 + .../node_modules/lodash/isPlainObject.js | 68 + .../async/node_modules/lodash/isRegExp.js | 27 + .../node_modules/lodash/isSafeInteger.js | 37 + .../async/node_modules/lodash/isSet.js | 27 + .../async/node_modules/lodash/isString.js | 39 + .../async/node_modules/lodash/isSymbol.js | 38 + .../async/node_modules/lodash/isTypedArray.js | 27 + .../async/node_modules/lodash/isUndefined.js | 22 + .../async/node_modules/lodash/isWeakMap.js | 28 + .../async/node_modules/lodash/isWeakSet.js | 37 + .../async/node_modules/lodash/iteratee.js | 50 + .../async/node_modules/lodash/join.js | 26 + .../async/node_modules/lodash/kebabCase.js | 28 + .../async/node_modules/lodash/keyBy.js | 37 + .../async/node_modules/lodash/keys.js | 37 + .../async/node_modules/lodash/keysIn.js | 32 + .../async/node_modules/lodash/lang.js | 58 + .../async/node_modules/lodash/last.js | 20 + .../async/node_modules/lodash/lastIndexOf.js | 46 + .../async/node_modules/lodash/lodash.js | 16982 ++++++++++++++++ .../async/node_modules/lodash/lodash.min.js | 134 + .../async/node_modules/lodash/lowerCase.js | 27 + .../async/node_modules/lodash/lowerFirst.js | 22 + .../async/node_modules/lodash/lt.js | 29 + .../async/node_modules/lodash/lte.js | 30 + .../async/node_modules/lodash/map.js | 53 + .../async/node_modules/lodash/mapKeys.js | 36 + .../async/node_modules/lodash/mapValues.js | 43 + .../async/node_modules/lodash/matches.js | 36 + .../node_modules/lodash/matchesProperty.js | 34 + .../async/node_modules/lodash/math.js | 17 + .../async/node_modules/lodash/max.js | 29 + .../async/node_modules/lodash/maxBy.js | 34 + .../async/node_modules/lodash/mean.js | 22 + .../async/node_modules/lodash/meanBy.js | 31 + .../async/node_modules/lodash/memoize.js | 73 + .../async/node_modules/lodash/merge.js | 39 + .../async/node_modules/lodash/mergeWith.js | 39 + .../async/node_modules/lodash/method.js | 34 + .../async/node_modules/lodash/methodOf.js | 33 + .../async/node_modules/lodash/min.js | 29 + .../async/node_modules/lodash/minBy.js | 34 + .../async/node_modules/lodash/mixin.js | 74 + .../async/node_modules/lodash/multiply.js | 22 + .../async/node_modules/lodash/negate.js | 40 + .../async/node_modules/lodash/next.js | 35 + .../async/node_modules/lodash/noop.js | 17 + .../async/node_modules/lodash/now.js | 23 + .../async/node_modules/lodash/nth.js | 29 + .../async/node_modules/lodash/nthArg.js | 32 + .../async/node_modules/lodash/number.js | 5 + .../async/node_modules/lodash/object.js | 49 + .../async/node_modules/lodash/omit.js | 35 + .../async/node_modules/lodash/omitBy.js | 29 + .../async/node_modules/lodash/once.js | 25 + .../async/node_modules/lodash/orderBy.js | 47 + .../async/node_modules/lodash/over.js | 24 + .../async/node_modules/lodash/overArgs.js | 61 + .../async/node_modules/lodash/overEvery.js | 30 + .../async/node_modules/lodash/overSome.js | 30 + .../async/node_modules/lodash/package.json | 79 + .../async/node_modules/lodash/pad.js | 49 + .../async/node_modules/lodash/padEnd.js | 39 + .../async/node_modules/lodash/padStart.js | 39 + .../async/node_modules/lodash/parseInt.js | 43 + .../async/node_modules/lodash/partial.js | 50 + .../async/node_modules/lodash/partialRight.js | 49 + .../async/node_modules/lodash/partition.js | 43 + .../async/node_modules/lodash/pick.js | 27 + .../async/node_modules/lodash/pickBy.js | 27 + .../async/node_modules/lodash/plant.js | 48 + .../async/node_modules/lodash/property.js | 32 + .../async/node_modules/lodash/propertyOf.js | 30 + .../async/node_modules/lodash/pull.js | 29 + .../async/node_modules/lodash/pullAll.js | 29 + .../async/node_modules/lodash/pullAllBy.js | 34 + .../async/node_modules/lodash/pullAllWith.js | 32 + .../async/node_modules/lodash/pullAt.js | 43 + .../async/node_modules/lodash/random.js | 82 + .../async/node_modules/lodash/range.js | 46 + .../async/node_modules/lodash/rangeRight.js | 41 + .../async/node_modules/lodash/rearg.js | 33 + .../async/node_modules/lodash/reduce.js | 51 + .../async/node_modules/lodash/reduceRight.js | 36 + .../async/node_modules/lodash/reject.js | 46 + .../async/node_modules/lodash/remove.js | 54 + .../async/node_modules/lodash/repeat.js | 37 + .../async/node_modules/lodash/replace.js | 29 + .../async/node_modules/lodash/rest.js | 40 + .../async/node_modules/lodash/result.js | 57 + .../async/node_modules/lodash/reverse.js | 34 + .../async/node_modules/lodash/round.js | 26 + .../async/node_modules/lodash/sample.js | 24 + .../async/node_modules/lodash/sampleSize.js | 37 + .../async/node_modules/lodash/seq.js | 16 + .../async/node_modules/lodash/set.js | 35 + .../async/node_modules/lodash/setWith.js | 32 + .../async/node_modules/lodash/shuffle.js | 25 + .../async/node_modules/lodash/size.js | 46 + .../async/node_modules/lodash/slice.js | 37 + .../async/node_modules/lodash/snakeCase.js | 28 + .../async/node_modules/lodash/some.js | 51 + .../async/node_modules/lodash/sortBy.js | 48 + .../async/node_modules/lodash/sortedIndex.js | 24 + .../node_modules/lodash/sortedIndexBy.js | 34 + .../node_modules/lodash/sortedIndexOf.js | 31 + .../node_modules/lodash/sortedLastIndex.js | 25 + .../node_modules/lodash/sortedLastIndexBy.js | 34 + .../node_modules/lodash/sortedLastIndexOf.js | 31 + .../async/node_modules/lodash/sortedUniq.js | 24 + .../async/node_modules/lodash/sortedUniqBy.js | 26 + .../async/node_modules/lodash/split.js | 52 + .../async/node_modules/lodash/spread.js | 63 + .../async/node_modules/lodash/startCase.js | 29 + .../async/node_modules/lodash/startsWith.js | 36 + .../async/node_modules/lodash/string.js | 33 + .../async/node_modules/lodash/stubArray.js | 23 + .../async/node_modules/lodash/stubFalse.js | 18 + .../async/node_modules/lodash/stubObject.js | 23 + .../async/node_modules/lodash/stubString.js | 18 + .../async/node_modules/lodash/stubTrue.js | 18 + .../async/node_modules/lodash/subtract.js | 22 + .../async/node_modules/lodash/sum.js | 24 + .../async/node_modules/lodash/sumBy.js | 33 + .../async/node_modules/lodash/tail.js | 22 + .../async/node_modules/lodash/take.js | 37 + .../async/node_modules/lodash/takeRight.js | 39 + .../node_modules/lodash/takeRightWhile.js | 46 + .../async/node_modules/lodash/takeWhile.js | 46 + .../async/node_modules/lodash/tap.js | 29 + .../async/node_modules/lodash/template.js | 238 + .../node_modules/lodash/templateSettings.js | 67 + .../async/node_modules/lodash/throttle.js | 69 + .../async/node_modules/lodash/thru.js | 28 + .../async/node_modules/lodash/times.js | 51 + .../async/node_modules/lodash/toArray.js | 58 + .../async/node_modules/lodash/toFinite.js | 42 + .../async/node_modules/lodash/toInteger.js | 36 + .../async/node_modules/lodash/toIterator.js | 23 + .../async/node_modules/lodash/toJSON.js | 1 + .../async/node_modules/lodash/toLength.js | 38 + .../async/node_modules/lodash/toLower.js | 28 + .../async/node_modules/lodash/toNumber.js | 66 + .../async/node_modules/lodash/toPairs.js | 30 + .../async/node_modules/lodash/toPairsIn.js | 30 + .../async/node_modules/lodash/toPath.js | 32 + .../node_modules/lodash/toPlainObject.js | 32 + .../node_modules/lodash/toSafeInteger.js | 35 + .../async/node_modules/lodash/toString.js | 28 + .../async/node_modules/lodash/toUpper.js | 28 + .../async/node_modules/lodash/transform.js | 65 + .../async/node_modules/lodash/trim.js | 49 + .../async/node_modules/lodash/trimEnd.js | 43 + .../async/node_modules/lodash/trimStart.js | 43 + .../async/node_modules/lodash/truncate.js | 111 + .../async/node_modules/lodash/unary.js | 22 + .../async/node_modules/lodash/unescape.js | 34 + .../async/node_modules/lodash/union.js | 26 + .../async/node_modules/lodash/unionBy.js | 40 + .../async/node_modules/lodash/unionWith.js | 36 + .../async/node_modules/lodash/uniq.js | 27 + .../async/node_modules/lodash/uniqBy.js | 34 + .../async/node_modules/lodash/uniqWith.js | 29 + .../async/node_modules/lodash/uniqueId.js | 28 + .../async/node_modules/lodash/unset.js | 34 + .../async/node_modules/lodash/unzip.js | 45 + .../async/node_modules/lodash/unzipWith.js | 39 + .../async/node_modules/lodash/update.js | 35 + .../async/node_modules/lodash/updateWith.js | 33 + .../async/node_modules/lodash/upperCase.js | 27 + .../async/node_modules/lodash/upperFirst.js | 22 + .../async/node_modules/lodash/util.js | 34 + .../async/node_modules/lodash/value.js | 1 + .../async/node_modules/lodash/valueOf.js | 1 + .../async/node_modules/lodash/values.js | 34 + .../async/node_modules/lodash/valuesIn.js | 32 + .../async/node_modules/lodash/without.js | 31 + .../async/node_modules/lodash/words.js | 35 + .../async/node_modules/lodash/wrap.js | 31 + .../async/node_modules/lodash/wrapperAt.js | 48 + .../async/node_modules/lodash/wrapperChain.js | 34 + .../node_modules/lodash/wrapperLodash.js | 147 + .../node_modules/lodash/wrapperReverse.js | 44 + .../async/node_modules/lodash/wrapperValue.js | 21 + .../async/node_modules/lodash/xor.js | 28 + .../async/node_modules/lodash/xorBy.js | 40 + .../async/node_modules/lodash/xorWith.js | 36 + .../async/node_modules/lodash/zip.js | 22 + .../async/node_modules/lodash/zipObject.js | 24 + .../node_modules/lodash/zipObjectDeep.js | 23 + .../async/node_modules/lodash/zipWith.js | 31 + .../mongoose/node_modules/async/package.json | 119 + .../mongoose/node_modules/async/parallel.js | 87 + .../node_modules/async/parallelLimit.js | 41 + .../node_modules/async/priorityQueue.js | 103 + .../mongoose/node_modules/async/queue.js | 120 + .../mongoose/node_modules/async/race.js | 71 + .../mongoose/node_modules/async/reduce.js | 73 + .../node_modules/async/reduceRight.js | 42 + .../mongoose/node_modules/async/reflect.js | 80 + .../mongoose/node_modules/async/reflectAll.js | 104 + .../mongoose/node_modules/async/reject.js | 44 + .../node_modules/async/rejectLimit.js | 36 + .../node_modules/async/rejectSeries.js | 34 + .../mongoose/node_modules/async/retry.js | 134 + .../mongoose/node_modules/async/retryable.js | 56 + .../mongoose/node_modules/async/seq.js | 79 + .../mongoose/node_modules/async/series.js | 85 + .../node_modules/async/setImmediate.js | 45 + .../mongoose/node_modules/async/some.js | 52 + .../mongoose/node_modules/async/someLimit.js | 43 + .../mongoose/node_modules/async/someSeries.js | 38 + .../mongoose/node_modules/async/sortBy.js | 85 + .../mongoose/node_modules/async/timeout.js | 66 + .../mongoose/node_modules/async/times.js | 50 + .../mongoose/node_modules/async/timesLimit.js | 37 + .../node_modules/async/timesSeries.js | 32 + .../mongoose/node_modules/async/transform.js | 85 + .../mongoose/node_modules/async/unmemoize.js | 25 + .../mongoose/node_modules/async/until.js | 42 + .../mongoose/node_modules/async/waterfall.js | 114 + .../mongoose/node_modules/async/whilst.js | 67 + .../mongoose/node_modules/bson/HISTORY.md | 170 + .../mongoose/node_modules/bson/LICENSE.md | 201 + .../bson/alternate_parsers/bson.js | 1574 ++ .../bson/alternate_parsers/faster_bson.js | 429 + .../mongoose/node_modules/bson/bower.json | 25 + .../node_modules/bson/browser_build/bson.js | 4843 +++++ .../bson/browser_build/package.json | 8 + .../node_modules/bson/deserializer_bak.js | 357 + .../node_modules/bson/lib/bson/binary.js | 347 + .../node_modules/bson/lib/bson/bson.js | 327 + .../node_modules/bson/lib/bson/code.js | 24 + .../node_modules/bson/lib/bson/db_ref.js | 32 + .../node_modules/bson/lib/bson/decimal128.js | 728 + .../node_modules/bson/lib/bson/double.js | 33 + .../bson/lib/bson/float_parser.js | 121 + .../node_modules/bson/lib/bson/index.js | 89 + .../node_modules/bson/lib/bson/int_32.js | 26 + .../node_modules/bson/lib/bson/long.js | 856 + .../node_modules/bson/lib/bson/map.js | 126 + .../node_modules/bson/lib/bson/max_key.js | 14 + .../node_modules/bson/lib/bson/min_key.js | 14 + .../node_modules/bson/lib/bson/objectid.js | 343 + .../bson/lib/bson/parser/calculate_size.js | 152 + .../bson/lib/bson/parser/deserializer.js | 653 + .../bson/lib/bson/parser/serializer.js | 976 + .../node_modules/bson/lib/bson/regexp.js | 30 + .../node_modules/bson/lib/bson/symbol.js | 47 + .../node_modules/bson/lib/bson/timestamp.js | 856 + .../mongoose/node_modules/bson/package.json | 81 + .../mongoose/node_modules/bson/tools/gleak.js | 21 + .../node_modules/hooks-fixed/.npmignore | 2 + .../node_modules/hooks-fixed/Makefile | 9 + .../node_modules/hooks-fixed/README.md | 369 + .../node_modules/hooks-fixed/hooks.alt.js | 134 + .../node_modules/hooks-fixed/hooks.js | 188 + .../node_modules/hooks-fixed/package.json | 70 + .../mongoose/node_modules/hooks-fixed/test.js | 786 + .../mongoose/node_modules/kareem/.npmignore | 28 + .../mongoose/node_modules/kareem/.travis.yml | 9 + .../mongoose/node_modules/kareem/LICENSE | 202 + .../mongoose/node_modules/kareem/Makefile | 5 + .../mongoose/node_modules/kareem/README.md | 379 + .../mongoose/node_modules/kareem/docs.js | 37 + .../mongoose/node_modules/kareem/gulpfile.js | 18 + .../mongoose/node_modules/kareem/index.js | 312 + .../mongoose/node_modules/kareem/package.json | 63 + .../node_modules/kareem/test/examples.test.js | 339 + .../node_modules/kareem/test/post.test.js | 155 + .../node_modules/kareem/test/pre.test.js | 256 + .../node_modules/kareem/test/wrap.test.js | 347 + .../node_modules/mongodb/.coveralls.yml | 1 + .../mongoose/node_modules/mongodb/HISTORY.md | 1532 ++ .../mongoose/node_modules/mongodb/LICENSE | 201 + .../mongoose/node_modules/mongodb/Makefile | 11 + .../node_modules/mongodb/boot_auth.js | 52 + .../mongoose/node_modules/mongodb/conf.json | 73 + .../mongoose/node_modules/mongodb/index.js | 55 + .../node_modules/mongodb/insert_bench.js | 231 + .../node_modules/mongodb/lib/admin.js | 581 + .../mongodb/lib/aggregation_cursor.js | 444 + .../mongoose/node_modules/mongodb/lib/apm.js | 619 + .../node_modules/mongodb/lib/bulk/common.js | 440 + .../node_modules/mongodb/lib/bulk/ordered.js | 540 + .../mongodb/lib/bulk/unordered.js | 542 + .../node_modules/mongodb/lib/collection.js | 3360 +++ .../mongodb/lib/command_cursor.js | 320 + .../node_modules/mongodb/lib/cursor.js | 1182 ++ .../mongoose/node_modules/mongodb/lib/db.js | 1886 ++ .../mongodb/lib/gridfs-stream/download.js | 387 + .../mongodb/lib/gridfs-stream/index.js | 366 + .../mongodb/lib/gridfs-stream/upload.js | 517 + .../node_modules/mongodb/lib/gridfs/chunk.js | 233 + .../mongodb/lib/gridfs/grid_store.js | 1956 ++ .../node_modules/mongodb/lib/metadata.js | 64 + .../node_modules/mongodb/lib/mongo_client.js | 328 + .../node_modules/mongodb/lib/mongos.js | 509 + .../mongodb/lib/read_preference.js | 133 + .../node_modules/mongodb/lib/replset.js | 559 + .../node_modules/mongodb/lib/server.js | 507 + .../node_modules/mongodb/lib/topology_base.js | 191 + .../node_modules/mongodb/lib/url_parser.js | 406 + .../node_modules/mongodb/lib/utils.js | 312 + .../node_modules/es6-promise/CHANGELOG.md | 65 + .../mongodb/node_modules/es6-promise/LICENSE | 19 + .../node_modules/es6-promise/README.md | 74 + .../es6-promise/dist/es6-promise.js | 959 + .../es6-promise/dist/es6-promise.min.js | 9 + .../es6-promise/lib/es6-promise.umd.js | 18 + .../es6-promise/lib/es6-promise/-internal.js | 273 + .../es6-promise/lib/es6-promise/asap.js | 119 + .../es6-promise/lib/es6-promise/enumerator.js | 118 + .../es6-promise/lib/es6-promise/polyfill.js | 26 + .../es6-promise/lib/es6-promise/promise.js | 384 + .../lib/es6-promise/promise/all.js | 52 + .../lib/es6-promise/promise/race.js | 86 + .../lib/es6-promise/promise/reject.js | 46 + .../lib/es6-promise/promise/resolve.js | 48 + .../es6-promise/lib/es6-promise/then.js | 34 + .../es6-promise/lib/es6-promise/utils.js | 22 + .../node_modules/es6-promise/package.json | 95 + .../node_modules/mongodb-core/.coveralls.yml | 1 + .../node_modules/mongodb-core/HISTORY.md | 550 + .../mongodb/node_modules/mongodb-core/LICENSE | 201 + .../node_modules/mongodb-core/Makefile | 11 + .../node_modules/mongodb-core/TESTING.md | 18 + .../node_modules/mongodb-core/conf.json | 59 + .../node_modules/mongodb-core/index.js | 38 + .../mongodb-core/lib/auth/gssapi.js | 277 + .../mongodb-core/lib/auth/mongocr.js | 192 + .../mongodb-core/lib/auth/plain.js | 173 + .../mongodb-core/lib/auth/scram.js | 345 + .../mongodb-core/lib/auth/sspi.js | 267 + .../mongodb-core/lib/auth/x509.js | 168 + .../lib/connection/command_result.js | 38 + .../mongodb-core/lib/connection/commands.js | 555 + .../mongodb-core/lib/connection/connection.js | 567 + .../mongodb-core/lib/connection/logger.js | 229 + .../mongodb-core/lib/connection/pool.js | 1176 ++ .../mongodb-core/lib/connection/utils.js | 67 + .../node_modules/mongodb-core/lib/cursor.js | 695 + .../node_modules/mongodb-core/lib/error.js | 44 + .../mongodb-core/lib/tools/smoke_plugin.js | 59 + .../mongodb-core/lib/topologies/mongos.js | 1112 + .../lib/topologies/read_preference.js | 119 + .../mongodb-core/lib/topologies/replset.js | 1374 ++ .../lib/topologies/replset_state.js | 947 + .../mongodb-core/lib/topologies/server.js | 842 + .../mongodb-core/lib/topologies/shared.js | 225 + .../lib/wireprotocol/2_4_support.js | 563 + .../lib/wireprotocol/2_6_support.js | 332 + .../lib/wireprotocol/3_2_support.js | 539 + .../mongodb-core/lib/wireprotocol/commands.js | 357 + .../mongodb-core/lib/wireprotocol/shared.js | 26 + .../node_modules/require_optional/.npmignore | 33 + .../node_modules/require_optional/.travis.yml | 6 + .../node_modules/require_optional/LICENSE | 201 + .../node_modules/require_optional/README.md | 2 + .../node_modules/require_optional/index.js | 109 + .../require_optional/node_modules/.bin/semver | 15 + .../node_modules/.bin/semver.cmd | 7 + .../node_modules/resolve-from/index.js | 23 + .../node_modules/resolve-from/license | 21 + .../node_modules/resolve-from/package.json | 64 + .../node_modules/resolve-from/readme.md | 58 + .../node_modules/semver/LICENSE | 15 + .../node_modules/semver/README.md | 350 + .../node_modules/semver/bin/semver | 133 + .../node_modules/semver/package.json | 60 + .../node_modules/semver/range.bnf | 16 + .../node_modules/semver/semver.js | 1203 ++ .../require_optional/package.json | 69 + .../test/require_optional_tests.js | 42 + .../node_modules/mongodb-core/package.json | 74 + .../simple_2_document_limit_toArray.dat | 11000 ++++++++++ .../mongodb/node_modules/mongodb-core/test.js | 71 + .../node_modules/mongodb-core/test1.js | 72 + .../node_modules/readable-stream/.npmignore | 8 + .../node_modules/readable-stream/.travis.yml | 49 + .../node_modules/readable-stream/LICENSE | 18 + .../node_modules/readable-stream/README.md | 36 + .../readable-stream/doc/stream.md | 2015 ++ .../doc/wg-meetings/2015-01-30.md | 60 + .../node_modules/readable-stream/duplex.js | 1 + .../readable-stream/lib/_stream_duplex.js | 75 + .../lib/_stream_passthrough.js | 26 + .../readable-stream/lib/_stream_readable.js | 937 + .../readable-stream/lib/_stream_transform.js | 180 + .../readable-stream/lib/_stream_writable.js | 526 + .../lib/internal/streams/BufferList.js | 64 + .../node_modules/buffer-shims/index.js | 108 + .../node_modules/buffer-shims/license.md | 19 + .../node_modules/buffer-shims/package.json | 51 + .../node_modules/buffer-shims/readme.md | 21 + .../node_modules/core-util-is/LICENSE | 19 + .../node_modules/core-util-is/README.md | 3 + .../node_modules/core-util-is/float.patch | 604 + .../node_modules/core-util-is/lib/util.js | 107 + .../node_modules/core-util-is/package.json | 60 + .../node_modules/core-util-is/test.js | 68 + .../node_modules/inherits/LICENSE | 16 + .../node_modules/inherits/README.md | 42 + .../node_modules/inherits/inherits.js | 7 + .../node_modules/inherits/inherits_browser.js | 23 + .../node_modules/inherits/package.json | 63 + .../node_modules/isarray/.npmignore | 1 + .../node_modules/isarray/.travis.yml | 4 + .../node_modules/isarray/Makefile | 6 + .../node_modules/isarray/README.md | 60 + .../node_modules/isarray/component.json | 19 + .../node_modules/isarray/index.js | 5 + .../node_modules/isarray/package.json | 71 + .../node_modules/isarray/test.js | 20 + .../process-nextick-args/.travis.yml | 12 + .../process-nextick-args/index.js | 43 + .../process-nextick-args/license.md | 19 + .../process-nextick-args/package.json | 49 + .../process-nextick-args/readme.md | 18 + .../node_modules/process-nextick-args/test.js | 24 + .../node_modules/string_decoder/.npmignore | 2 + .../node_modules/string_decoder/LICENSE | 20 + .../node_modules/string_decoder/README.md | 7 + .../node_modules/string_decoder/index.js | 221 + .../node_modules/string_decoder/package.json | 54 + .../node_modules/util-deprecate/History.md | 16 + .../node_modules/util-deprecate/LICENSE | 24 + .../node_modules/util-deprecate/README.md | 53 + .../node_modules/util-deprecate/browser.js | 67 + .../node_modules/util-deprecate/node.js | 6 + .../node_modules/util-deprecate/package.json | 54 + .../node_modules/readable-stream/package.json | 92 + .../readable-stream/passthrough.js | 1 + .../node_modules/readable-stream/readable.js | 16 + .../node_modules/readable-stream/transform.js | 1 + .../node_modules/readable-stream/writable.js | 1 + .../node_modules/mongodb/package.json | 89 + .../mongoose/node_modules/mpath/.npmignore | 2 + .../mongoose/node_modules/mpath/.travis.yml | 4 + .../mongoose/node_modules/mpath/History.md | 30 + .../mongoose/node_modules/mpath/LICENSE | 22 + .../mongoose/node_modules/mpath/Makefile | 8 + .../mongoose/node_modules/mpath/README.md | 278 + .../mongoose/node_modules/mpath/bench.js | 109 + .../mongoose/node_modules/mpath/bench.log | 0 .../mongoose/node_modules/mpath/bench.out | 69 + .../node_modules/mpath/component.json | 8 + .../mongoose/node_modules/mpath/index.js | 1 + .../mongoose/node_modules/mpath/lib/index.js | 215 + .../mongoose/node_modules/mpath/package.json | 53 + .../mongoose/node_modules/mpath/test/index.js | 1790 ++ .../mongoose/node_modules/mpromise/.npmignore | 4 + .../node_modules/mpromise/.travis.yml | 5 + .../mongoose/node_modules/mpromise/History.md | 80 + .../mongoose/node_modules/mpromise/LICENSE | 22 + .../mongoose/node_modules/mpromise/README.md | 224 + .../node_modules/mpromise/lib/promise.js | 445 + .../node_modules/mpromise/package.json | 65 + .../mpromise/test/promise.domain.test.js | 28 + .../mpromise/test/promise.test.js | 554 + .../mpromise/test/promises.Aplus.js | 15 + .../mongoose/node_modules/mquery/.npmignore | 3 + .../mongoose/node_modules/mquery/.travis.yml | 8 + .../mongoose/node_modules/mquery/History.md | 257 + .../mongoose/node_modules/mquery/LICENSE | 22 + .../mongoose/node_modules/mquery/Makefile | 22 + .../mongoose/node_modules/mquery/README.md | 1220 ++ .../mquery/lib/collection/collection.js | 42 + .../mquery/lib/collection/index.js | 13 + .../mquery/lib/collection/node.js | 108 + .../mongoose/node_modules/mquery/lib/env.js | 22 + .../node_modules/mquery/lib/mquery.js | 2728 +++ .../node_modules/mquery/lib/permissions.js | 88 + .../mongoose/node_modules/mquery/lib/utils.js | 342 + .../mquery/node_modules/bluebird/LICENSE | 21 + .../mquery/node_modules/bluebird/README.md | 679 + .../mquery/node_modules/bluebird/changelog.md | 1723 ++ .../bluebird/js/browser/bluebird.js | 4887 +++++ .../bluebird/js/browser/bluebird.min.js | 31 + .../node_modules/bluebird/js/main/any.js | 21 + .../node_modules/bluebird/js/main/assert.js | 55 + .../node_modules/bluebird/js/main/async.js | 150 + .../node_modules/bluebird/js/main/bind.js | 72 + .../node_modules/bluebird/js/main/bluebird.js | 11 + .../node_modules/bluebird/js/main/call_get.js | 123 + .../node_modules/bluebird/js/main/cancel.js | 48 + .../bluebird/js/main/captured_trace.js | 493 + .../bluebird/js/main/catch_filter.js | 66 + .../node_modules/bluebird/js/main/context.js | 38 + .../bluebird/js/main/debuggability.js | 162 + .../bluebird/js/main/direct_resolve.js | 63 + .../node_modules/bluebird/js/main/each.js | 12 + .../node_modules/bluebird/js/main/errors.js | 111 + .../node_modules/bluebird/js/main/es5.js | 80 + .../node_modules/bluebird/js/main/filter.js | 12 + .../node_modules/bluebird/js/main/finally.js | 98 + .../bluebird/js/main/generators.js | 136 + .../node_modules/bluebird/js/main/join.js | 107 + .../node_modules/bluebird/js/main/map.js | 133 + .../node_modules/bluebird/js/main/method.js | 44 + .../node_modules/bluebird/js/main/nodeify.js | 59 + .../node_modules/bluebird/js/main/progress.js | 76 + .../node_modules/bluebird/js/main/promise.js | 754 + .../bluebird/js/main/promise_array.js | 142 + .../bluebird/js/main/promise_resolver.js | 123 + .../bluebird/js/main/promisify.js | 307 + .../node_modules/bluebird/js/main/props.js | 79 + .../node_modules/bluebird/js/main/queue.js | 90 + .../node_modules/bluebird/js/main/race.js | 47 + .../node_modules/bluebird/js/main/reduce.js | 148 + .../node_modules/bluebird/js/main/schedule.js | 35 + .../node_modules/bluebird/js/main/settle.js | 40 + .../node_modules/bluebird/js/main/some.js | 125 + .../js/main/synchronous_inspection.js | 94 + .../bluebird/js/main/thenables.js | 84 + .../node_modules/bluebird/js/main/timers.js | 64 + .../node_modules/bluebird/js/main/using.js | 213 + .../node_modules/bluebird/js/main/util.js | 321 + .../mquery/node_modules/bluebird/package.json | 100 + .../mquery/node_modules/debug/.jshintrc | 3 + .../mquery/node_modules/debug/.npmignore | 6 + .../mquery/node_modules/debug/History.md | 195 + .../mquery/node_modules/debug/Makefile | 36 + .../mquery/node_modules/debug/Readme.md | 188 + .../mquery/node_modules/debug/bower.json | 28 + .../mquery/node_modules/debug/browser.js | 168 + .../mquery/node_modules/debug/component.json | 19 + .../mquery/node_modules/debug/debug.js | 197 + .../mquery/node_modules/debug/node.js | 209 + .../mquery/node_modules/debug/package.json | 73 + .../mquery/node_modules/sliced/.npmignore | 2 + .../mquery/node_modules/sliced/.travis.yml | 4 + .../mquery/node_modules/sliced/History.md | 30 + .../mquery/node_modules/sliced/LICENSE | 22 + .../mquery/node_modules/sliced/Makefile | 5 + .../mquery/node_modules/sliced/README.md | 62 + .../mquery/node_modules/sliced/bench.js | 95 + .../mquery/node_modules/sliced/component.json | 14 + .../mquery/node_modules/sliced/index.js | 1 + .../mquery/node_modules/sliced/lib/sliced.js | 33 + .../mquery/node_modules/sliced/package.json | 52 + .../mquery/node_modules/sliced/test/index.js | 80 + .../mongoose/node_modules/mquery/package.json | 72 + .../mquery/test/collection/browser.js | 0 .../mquery/test/collection/mongo.js | 0 .../mquery/test/collection/node.js | 29 + .../mongoose/node_modules/mquery/test/env.js | 20 + .../node_modules/mquery/test/index.js | 2891 +++ .../node_modules/mquery/test/utils.test.js | 143 + .../mongoose/node_modules/ms/.npmignore | 5 + .../mongoose/node_modules/ms/History.md | 66 + node_modules/mongoose/node_modules/ms/LICENSE | 20 + .../mongoose/node_modules/ms/README.md | 35 + .../mongoose/node_modules/ms/index.js | 125 + .../mongoose/node_modules/ms/package.json | 48 + .../mongoose/node_modules/muri/.npmignore | 2 + .../mongoose/node_modules/muri/.travis.yml | 4 + .../mongoose/node_modules/muri/History.md | 59 + .../mongoose/node_modules/muri/LICENSE | 22 + .../mongoose/node_modules/muri/Makefile | 5 + .../mongoose/node_modules/muri/README.md | 46 + .../mongoose/node_modules/muri/index.js | 1 + .../mongoose/node_modules/muri/lib/index.js | 241 + .../mongoose/node_modules/muri/package.json | 60 + .../mongoose/node_modules/muri/test/index.js | 328 + .../node_modules/regexp-clone/.npmignore | 2 + .../node_modules/regexp-clone/.travis.yml | 5 + .../node_modules/regexp-clone/History.md | 5 + .../node_modules/regexp-clone/LICENSE | 22 + .../node_modules/regexp-clone/Makefile | 5 + .../node_modules/regexp-clone/README.md | 18 + .../node_modules/regexp-clone/index.js | 20 + .../node_modules/regexp-clone/package.json | 51 + .../node_modules/regexp-clone/test/index.js | 112 + .../mongoose/node_modules/sliced/History.md | 41 + .../mongoose/node_modules/sliced/LICENSE | 22 + .../mongoose/node_modules/sliced/README.md | 62 + .../mongoose/node_modules/sliced/index.js | 33 + .../mongoose/node_modules/sliced/package.json | 60 + node_modules/mongoose/package.json | 134 + node_modules/mongoose/release-items.md | 28 + node_modules/mongoose/static.js | 24 + node_modules/mongoose/website.js | 87 + node_modules/morgan/HISTORY.md | 158 + node_modules/morgan/LICENSE | 23 + node_modules/morgan/README.md | 324 + node_modules/morgan/index.js | 501 + .../morgan/node_modules/basic-auth/HISTORY.md | 35 + .../morgan/node_modules/basic-auth/LICENSE | 24 + .../morgan/node_modules/basic-auth/README.md | 78 + .../morgan/node_modules/basic-auth/index.js | 108 + .../node_modules/basic-auth/package.json | 76 + .../morgan/node_modules/debug/.jshintrc | 3 + .../morgan/node_modules/debug/.npmignore | 6 + .../morgan/node_modules/debug/History.md | 195 + .../morgan/node_modules/debug/Makefile | 36 + .../morgan/node_modules/debug/Readme.md | 188 + .../morgan/node_modules/debug/bower.json | 28 + .../morgan/node_modules/debug/browser.js | 168 + .../morgan/node_modules/debug/component.json | 19 + .../morgan/node_modules/debug/debug.js | 197 + .../morgan/node_modules/debug/node.js | 209 + .../debug/node_modules/ms/.npmignore | 5 + .../debug/node_modules/ms/History.md | 66 + .../debug/node_modules/ms/LICENSE | 20 + .../debug/node_modules/ms/README.md | 35 + .../debug/node_modules/ms/index.js | 125 + .../debug/node_modules/ms/package.json | 48 + .../morgan/node_modules/debug/package.json | 73 + .../morgan/node_modules/depd/History.md | 84 + node_modules/morgan/node_modules/depd/LICENSE | 22 + .../morgan/node_modules/depd/Readme.md | 281 + .../morgan/node_modules/depd/index.js | 521 + .../node_modules/depd/lib/browser/index.js | 79 + .../depd/lib/compat/buffer-concat.js | 35 + .../depd/lib/compat/callsite-tostring.js | 103 + .../depd/lib/compat/event-listener-count.js | 22 + .../node_modules/depd/lib/compat/index.js | 84 + .../morgan/node_modules/depd/package.json | 67 + .../node_modules/on-finished/HISTORY.md | 88 + .../morgan/node_modules/on-finished/LICENSE | 23 + .../morgan/node_modules/on-finished/README.md | 154 + .../morgan/node_modules/on-finished/index.js | 196 + .../on-finished/node_modules/ee-first/LICENSE | 22 + .../node_modules/ee-first/README.md | 80 + .../node_modules/ee-first/index.js | 95 + .../node_modules/ee-first/package.json | 64 + .../node_modules/on-finished/package.json | 71 + .../morgan/node_modules/on-headers/HISTORY.md | 16 + .../morgan/node_modules/on-headers/LICENSE | 22 + .../morgan/node_modules/on-headers/README.md | 76 + .../morgan/node_modules/on-headers/index.js | 93 + .../node_modules/on-headers/package.json | 70 + node_modules/morgan/package.json | 98 + node_modules/oauth/.npmignore | 1 + node_modules/oauth/LICENSE | 8 + node_modules/oauth/Makefile | 7 + node_modules/oauth/Readme.md | 187 + .../oauth/examples/express-gdata/server.js | 168 + .../express-gdata/views/google_calendars.ejs | 21 + .../express-gdata/views/google_contacts.ejs | 24 + .../examples/express-gdata/views/layout.ejs | 9 + node_modules/oauth/examples/github-example.js | 73 + .../oauth/examples/term.ie.oauth-HMAC-SHA1.js | 31 + node_modules/oauth/index.js | 3 + node_modules/oauth/lib/_utils.js | 4 + node_modules/oauth/lib/oauth.js | 581 + node_modules/oauth/lib/oauth2.js | 214 + node_modules/oauth/lib/sha1.js | 334 + node_modules/oauth/package.json | 53 + node_modules/oauth/tests/oauth2tests.js | 290 + node_modules/oauth/tests/oauthtests.js | 1064 + node_modules/oauth/tests/sha1tests.js | 13 + node_modules/oauth/tests/shared.js | 26 + node_modules/qs/.eslintignore | 1 + node_modules/qs/.eslintrc | 19 + node_modules/qs/CHANGELOG.md | 130 + node_modules/qs/CONTRIBUTING.md | 1 + node_modules/qs/LICENSE | 28 + node_modules/qs/README.md | 376 + node_modules/qs/dist/qs.js | 486 + node_modules/qs/lib/index.js | 9 + node_modules/qs/lib/parse.js | 166 + node_modules/qs/lib/stringify.js | 137 + node_modules/qs/lib/utils.js | 164 + node_modules/qs/package.json | 87 + node_modules/qs/test/index.js | 5 + node_modules/qs/test/parse.js | 451 + node_modules/qs/test/stringify.js | 305 + node_modules/qs/test/utils.js | 9 + node_modules/toastr/.gitattributes | 15 + node_modules/toastr/.jscsrc | 90 + node_modules/toastr/.jshintrc | 63 + node_modules/toastr/.npmignore | 58 + node_modules/toastr/.travis.yml | 19 + node_modules/toastr/CHANGELOG.md | 138 + node_modules/toastr/README.md | 220 + node_modules/toastr/build/toastr.css | 200 + node_modules/toastr/build/toastr.js.map | 1 + node_modules/toastr/build/toastr.min.css | 1 + node_modules/toastr/build/toastr.min.js | 2 + node_modules/toastr/demo.html | 325 + node_modules/toastr/gulpfile.js | 200 + node_modules/toastr/karma.conf.js | 79 + .../toastr/nuget/content/content/toastr.css | 180 + .../toastr/nuget/content/content/toastr.less | 232 + .../nuget/content/content/toastr.min.css | 1 + .../toastr/nuget/content/content/toastr.scss | 183 + .../toastr/nuget/content/scripts/toastr.js | 338 + .../nuget/content/scripts/toastr.min.js | 1 + .../nuget/content/scripts/toastr.min.js.map | 8 + node_modules/toastr/nuget/toastr.1.0.0.nupkg | Bin 0 -> 7341 bytes node_modules/toastr/nuget/toastr.1.0.0.nuspec | 35 + node_modules/toastr/nuget/toastr.1.0.1.nupkg | Bin 0 -> 7745 bytes node_modules/toastr/nuget/toastr.1.0.1.nuspec | Bin 0 -> 3764 bytes node_modules/toastr/nuget/toastr.1.0.2.nupkg | Bin 0 -> 7794 bytes node_modules/toastr/nuget/toastr.1.0.2.nuspec | Bin 0 -> 3914 bytes node_modules/toastr/nuget/toastr.1.0.3.nupkg | Bin 0 -> 7761 bytes node_modules/toastr/nuget/toastr.1.0.3.nuspec | 38 + node_modules/toastr/nuget/toastr.1.1.0.nupkg | Bin 0 -> 7789 bytes node_modules/toastr/nuget/toastr.1.1.0.nuspec | 35 + node_modules/toastr/nuget/toastr.1.1.1.nupkg | Bin 0 -> 7789 bytes node_modules/toastr/nuget/toastr.1.1.1.nuspec | 35 + node_modules/toastr/nuget/toastr.1.1.2.nupkg | Bin 0 -> 7850 bytes node_modules/toastr/nuget/toastr.1.1.2.nuspec | 35 + node_modules/toastr/nuget/toastr.1.1.3.nupkg | Bin 0 -> 11781 bytes .../toastr/nuget/toastr.1.1.4.1.nupkg | Bin 0 -> 11768 bytes .../toastr/nuget/toastr.1.1.4.1.nuspec | 40 + .../toastr/nuget/toastr.1.1.4.2.nupkg | Bin 0 -> 11772 bytes .../toastr/nuget/toastr.1.1.4.2.nuspec | 40 + node_modules/toastr/nuget/toastr.1.1.4.nupkg | Bin 0 -> 11802 bytes node_modules/toastr/nuget/toastr.1.1.4.nuspec | 40 + node_modules/toastr/nuget/toastr.1.1.5.nupkg | Bin 0 -> 11634 bytes node_modules/toastr/nuget/toastr.1.1.5.nuspec | 38 + node_modules/toastr/nuget/toastr.1.2.0.nupkg | Bin 0 -> 11716 bytes node_modules/toastr/nuget/toastr.1.2.0.nuspec | 40 + node_modules/toastr/nuget/toastr.1.2.1.nupkg | Bin 0 -> 11728 bytes node_modules/toastr/nuget/toastr.1.2.1.nuspec | 40 + node_modules/toastr/nuget/toastr.1.2.2.nupkg | Bin 0 -> 11719 bytes node_modules/toastr/nuget/toastr.1.2.2.nuspec | 40 + node_modules/toastr/nuget/toastr.1.3.0.nupkg | Bin 0 -> 15020 bytes node_modules/toastr/nuget/toastr.1.3.0.nuspec | 48 + node_modules/toastr/nuget/toastr.1.3.1.nupkg | Bin 0 -> 15568 bytes node_modules/toastr/nuget/toastr.1.3.1.nuspec | 63 + .../toastr/nuget/toastr.2.0.0-rc1.nupkg | Bin 0 -> 19421 bytes .../toastr/nuget/toastr.2.0.0-rc1.nuspec | 49 + node_modules/toastr/nuget/toastr.2.0.1.nupkg | Bin 0 -> 19400 bytes node_modules/toastr/nuget/toastr.2.0.1.nuspec | 49 + node_modules/toastr/nuget/toastr.2.0.2.nupkg | Bin 0 -> 23037 bytes node_modules/toastr/nuget/toastr.2.0.2.nuspec | 41 + node_modules/toastr/nuget/toastr.2.0.3.nupkg | Bin 0 -> 23027 bytes node_modules/toastr/nuget/toastr.2.0.3.nuspec | 41 + node_modules/toastr/package.json | 83 + node_modules/toastr/package/.gitattributes | 15 + node_modules/toastr/package/.jscsrc | 90 + node_modules/toastr/package/.jshintrc | 61 + node_modules/toastr/package/.npmignore | 58 + node_modules/toastr/package/.travis.yml | 19 + node_modules/toastr/package/CHANGELOG.md | 120 + .../toastr/package/build/toastr.js.map | 1 + .../toastr/package/build/toastr.min.css | 1 + .../toastr/package/build/toastr.min.js | 2 + node_modules/toastr/package/demo.html | 325 + node_modules/toastr/package/gulpfile.js | 198 + node_modules/toastr/package/karma.conf.js | 79 + .../package/nuget/content/content/toastr.css | 180 + .../package/nuget/content/content/toastr.less | 232 + .../nuget/content/content/toastr.min.css | 1 + .../package/nuget/content/content/toastr.scss | 183 + .../package/nuget/content/scripts/toastr.js | 338 + .../nuget/content/scripts/toastr.min.js | 1 + .../nuget/content/scripts/toastr.min.js.map | 8 + .../toastr/package/nuget/toastr.1.0.0.nupkg | Bin 0 -> 7341 bytes .../toastr/package/nuget/toastr.1.0.0.nuspec | 35 + .../toastr/package/nuget/toastr.1.0.1.nupkg | Bin 0 -> 7745 bytes .../toastr/package/nuget/toastr.1.0.1.nuspec | Bin 0 -> 3764 bytes .../toastr/package/nuget/toastr.1.0.2.nupkg | Bin 0 -> 7794 bytes .../toastr/package/nuget/toastr.1.0.2.nuspec | Bin 0 -> 3914 bytes .../toastr/package/nuget/toastr.1.0.3.nupkg | Bin 0 -> 7761 bytes .../toastr/package/nuget/toastr.1.0.3.nuspec | 38 + .../toastr/package/nuget/toastr.1.1.0.nupkg | Bin 0 -> 7789 bytes .../toastr/package/nuget/toastr.1.1.0.nuspec | 35 + .../toastr/package/nuget/toastr.1.1.1.nupkg | Bin 0 -> 7789 bytes .../toastr/package/nuget/toastr.1.1.1.nuspec | 35 + .../toastr/package/nuget/toastr.1.1.2.nupkg | Bin 0 -> 7850 bytes .../toastr/package/nuget/toastr.1.1.2.nuspec | 35 + .../toastr/package/nuget/toastr.1.1.3.nupkg | Bin 0 -> 11781 bytes .../toastr/package/nuget/toastr.1.1.4.1.nupkg | Bin 0 -> 11768 bytes .../package/nuget/toastr.1.1.4.1.nuspec | 40 + .../toastr/package/nuget/toastr.1.1.4.2.nupkg | Bin 0 -> 11772 bytes .../package/nuget/toastr.1.1.4.2.nuspec | 40 + .../toastr/package/nuget/toastr.1.1.4.nupkg | Bin 0 -> 11802 bytes .../toastr/package/nuget/toastr.1.1.4.nuspec | 40 + .../toastr/package/nuget/toastr.1.1.5.nupkg | Bin 0 -> 11634 bytes .../toastr/package/nuget/toastr.1.1.5.nuspec | 38 + .../toastr/package/nuget/toastr.1.2.0.nupkg | Bin 0 -> 11716 bytes .../toastr/package/nuget/toastr.1.2.0.nuspec | 40 + .../toastr/package/nuget/toastr.1.2.1.nupkg | Bin 0 -> 11728 bytes .../toastr/package/nuget/toastr.1.2.1.nuspec | 40 + .../toastr/package/nuget/toastr.1.2.2.nupkg | Bin 0 -> 11719 bytes .../toastr/package/nuget/toastr.1.2.2.nuspec | 40 + .../toastr/package/nuget/toastr.1.3.0.nupkg | Bin 0 -> 15020 bytes .../toastr/package/nuget/toastr.1.3.0.nuspec | 48 + .../toastr/package/nuget/toastr.1.3.1.nupkg | Bin 0 -> 15568 bytes .../toastr/package/nuget/toastr.1.3.1.nuspec | 63 + .../package/nuget/toastr.2.0.0-rc1.nupkg | Bin 0 -> 19421 bytes .../package/nuget/toastr.2.0.0-rc1.nuspec | 49 + .../toastr/package/nuget/toastr.2.0.1.nupkg | Bin 0 -> 19400 bytes .../toastr/package/nuget/toastr.2.0.1.nuspec | 49 + .../toastr/package/nuget/toastr.2.0.2.nupkg | Bin 0 -> 23037 bytes .../toastr/package/nuget/toastr.2.0.2.nuspec | 41 + .../toastr/package/nuget/toastr.2.0.3.nupkg | Bin 0 -> 23027 bytes .../toastr/package/nuget/toastr.2.0.3.nuspec | 41 + node_modules/toastr/package/package.json | 68 + .../toastr/package/package/.gitattributes | 15 + node_modules/toastr/package/package/.jscsrc | 90 + node_modules/toastr/package/package/.jshintrc | 61 + .../toastr/package/package/.npmignore | 58 + .../toastr/package/package/.travis.yml | 19 + .../toastr/package/package/CHANGELOG.md | 120 + .../package/package/build/toastr.js.map | 1 + .../package/package/build/toastr.min.css | 1 + .../package/package/build/toastr.min.js | 2 + node_modules/toastr/package/package/demo.html | 325 + .../toastr/package/package/gulpfile.js | 198 + .../toastr/package/package/karma.conf.js | 79 + .../package/nuget/content/content/toastr.css | 180 + .../package/nuget/content/content/toastr.less | 232 + .../nuget/content/content/toastr.min.css | 1 + .../package/nuget/content/content/toastr.scss | 183 + .../package/nuget/content/scripts/toastr.js | 338 + .../nuget/content/scripts/toastr.min.js | 1 + .../nuget/content/scripts/toastr.min.js.map | 8 + .../package/package/nuget/toastr.1.0.0.nupkg | Bin 0 -> 7341 bytes .../package/package/nuget/toastr.1.0.0.nuspec | 35 + .../package/package/nuget/toastr.1.0.1.nupkg | Bin 0 -> 7745 bytes .../package/package/nuget/toastr.1.0.1.nuspec | Bin 0 -> 3764 bytes .../package/package/nuget/toastr.1.0.2.nupkg | Bin 0 -> 7794 bytes .../package/package/nuget/toastr.1.0.2.nuspec | Bin 0 -> 3914 bytes .../package/package/nuget/toastr.1.0.3.nupkg | Bin 0 -> 7761 bytes .../package/package/nuget/toastr.1.0.3.nuspec | 38 + .../package/package/nuget/toastr.1.1.0.nupkg | Bin 0 -> 7789 bytes .../package/package/nuget/toastr.1.1.0.nuspec | 35 + .../package/package/nuget/toastr.1.1.1.nupkg | Bin 0 -> 7789 bytes .../package/package/nuget/toastr.1.1.1.nuspec | 35 + .../package/package/nuget/toastr.1.1.2.nupkg | Bin 0 -> 7850 bytes .../package/package/nuget/toastr.1.1.2.nuspec | 35 + .../package/package/nuget/toastr.1.1.3.nupkg | Bin 0 -> 11781 bytes .../package/nuget/toastr.1.1.4.1.nupkg | Bin 0 -> 11768 bytes .../package/nuget/toastr.1.1.4.1.nuspec | 40 + .../package/nuget/toastr.1.1.4.2.nupkg | Bin 0 -> 11772 bytes .../package/nuget/toastr.1.1.4.2.nuspec | 40 + .../package/package/nuget/toastr.1.1.4.nupkg | Bin 0 -> 11802 bytes .../package/package/nuget/toastr.1.1.4.nuspec | 40 + .../package/package/nuget/toastr.1.1.5.nupkg | Bin 0 -> 11634 bytes .../package/package/nuget/toastr.1.1.5.nuspec | 38 + .../package/package/nuget/toastr.1.2.0.nupkg | Bin 0 -> 11716 bytes .../package/package/nuget/toastr.1.2.0.nuspec | 40 + .../package/package/nuget/toastr.1.2.1.nupkg | Bin 0 -> 11728 bytes .../package/package/nuget/toastr.1.2.1.nuspec | 40 + .../package/package/nuget/toastr.1.2.2.nupkg | Bin 0 -> 11719 bytes .../package/package/nuget/toastr.1.2.2.nuspec | 40 + .../package/package/nuget/toastr.1.3.0.nupkg | Bin 0 -> 15020 bytes .../package/package/nuget/toastr.1.3.0.nuspec | 48 + .../package/package/nuget/toastr.1.3.1.nupkg | Bin 0 -> 15568 bytes .../package/package/nuget/toastr.1.3.1.nuspec | 63 + .../package/nuget/toastr.2.0.0-rc1.nupkg | Bin 0 -> 19421 bytes .../package/nuget/toastr.2.0.0-rc1.nuspec | 49 + .../package/package/nuget/toastr.2.0.1.nupkg | Bin 0 -> 19400 bytes .../package/package/nuget/toastr.2.0.1.nuspec | 49 + .../package/package/nuget/toastr.2.0.2.nupkg | Bin 0 -> 23037 bytes .../package/package/nuget/toastr.2.0.2.nuspec | 41 + .../package/package/nuget/toastr.2.0.3.nupkg | Bin 0 -> 23027 bytes .../package/package/nuget/toastr.2.0.3.nuspec | 41 + .../toastr/package/package/package.json | 68 + node_modules/toastr/package/package/readme.md | 181 + .../package/package/release checklist.md | 32 + .../package/package/tests/qunit/qunit.css | 244 + .../package/package/tests/qunit/qunit.js | 2212 ++ .../package/package/tests/toastr-tests.html | 21 + .../package/tests/unit/qunit-helper.js | 13 + .../package/tests/unit/toastr-tests.js | 625 + .../toastr/package/package/tests/unit/x.js | 3 + .../toastr/package/package/toastr-2.1.2.tgz | Bin 0 -> 435047 bytes .../toastr/package/package/toastr-icon.png | Bin 0 -> 25510 bytes .../toastr/package/package/toastr.css | 197 + node_modules/toastr/package/package/toastr.js | 415 + .../toastr/package/package/toastr.less | 264 + .../toastr/package/package/toastr.scss | 199 + node_modules/toastr/package/readme.md | 181 + .../toastr/package/release checklist.md | 32 + .../toastr/package/tests/qunit/qunit.css | 244 + .../toastr/package/tests/qunit/qunit.js | 2212 ++ .../toastr/package/tests/toastr-tests.html | 21 + .../toastr/package/tests/unit/qunit-helper.js | 13 + .../toastr/package/tests/unit/toastr-tests.js | 625 + node_modules/toastr/package/tests/unit/x.js | 3 + node_modules/toastr/package/toastr-2.1.2.tgz | Bin 0 -> 1491899 bytes node_modules/toastr/package/toastr-icon.png | Bin 0 -> 25510 bytes node_modules/toastr/package/toastr.css | 197 + node_modules/toastr/package/toastr.js | 415 + node_modules/toastr/package/toastr.less | 264 + node_modules/toastr/package/toastr.scss | 199 + node_modules/toastr/release checklist.md | 32 + node_modules/toastr/tests/qunit/qunit.css | 244 + node_modules/toastr/tests/qunit/qunit.js | 2212 ++ node_modules/toastr/tests/toastr-tests.html | 21 + .../toastr/tests/unit/qunit-helper.js | 13 + .../toastr/tests/unit/toastr-tests.js | 698 + node_modules/toastr/tests/unit/x.js | 3 + node_modules/toastr/toastr-icon.png | Bin 0 -> 25510 bytes node_modules/toastr/toastr.js | 435 + node_modules/toastr/toastr.less | 267 + node_modules/toastr/toastr.scss | 199 + package.json | 21 + server.js | 23 + 2540 files changed, 298299 insertions(+) create mode 100644 node_modules/bcrypt-nodejs/.gitattributes create mode 100644 node_modules/bcrypt-nodejs/.npmignore create mode 100644 node_modules/bcrypt-nodejs/LICENSE create mode 100644 node_modules/bcrypt-nodejs/README.md create mode 100644 node_modules/bcrypt-nodejs/bCrypt.js create mode 100644 node_modules/bcrypt-nodejs/package.json create mode 100644 node_modules/bcrypt-nodejs/test-async.js create mode 100644 node_modules/bcrypt-nodejs/test-sync.js create mode 100644 node_modules/body-parser/HISTORY.md create mode 100644 node_modules/body-parser/LICENSE create mode 100644 node_modules/body-parser/README.md create mode 100644 node_modules/body-parser/index.js create mode 100644 node_modules/body-parser/lib/read.js create mode 100644 node_modules/body-parser/lib/types/json.js create mode 100644 node_modules/body-parser/lib/types/raw.js create mode 100644 node_modules/body-parser/lib/types/text.js create mode 100644 node_modules/body-parser/lib/types/urlencoded.js create mode 100644 node_modules/body-parser/node_modules/bytes/History.md create mode 100644 node_modules/body-parser/node_modules/bytes/LICENSE create mode 100644 node_modules/body-parser/node_modules/bytes/Readme.md create mode 100644 node_modules/body-parser/node_modules/bytes/index.js create mode 100644 node_modules/body-parser/node_modules/bytes/package.json create mode 100644 node_modules/body-parser/node_modules/content-type/HISTORY.md create mode 100644 node_modules/body-parser/node_modules/content-type/LICENSE create mode 100644 node_modules/body-parser/node_modules/content-type/README.md create mode 100644 node_modules/body-parser/node_modules/content-type/index.js create mode 100644 node_modules/body-parser/node_modules/content-type/package.json create mode 100644 node_modules/body-parser/node_modules/debug/.jshintrc create mode 100644 node_modules/body-parser/node_modules/debug/.npmignore create mode 100644 node_modules/body-parser/node_modules/debug/History.md create mode 100644 node_modules/body-parser/node_modules/debug/Makefile create mode 100644 node_modules/body-parser/node_modules/debug/Readme.md create mode 100644 node_modules/body-parser/node_modules/debug/bower.json create mode 100644 node_modules/body-parser/node_modules/debug/browser.js create mode 100644 node_modules/body-parser/node_modules/debug/component.json create mode 100644 node_modules/body-parser/node_modules/debug/debug.js create mode 100644 node_modules/body-parser/node_modules/debug/node.js create mode 100644 node_modules/body-parser/node_modules/debug/node_modules/ms/.npmignore create mode 100644 node_modules/body-parser/node_modules/debug/node_modules/ms/History.md create mode 100644 node_modules/body-parser/node_modules/debug/node_modules/ms/LICENSE create mode 100644 node_modules/body-parser/node_modules/debug/node_modules/ms/README.md create mode 100644 node_modules/body-parser/node_modules/debug/node_modules/ms/index.js create mode 100644 node_modules/body-parser/node_modules/debug/node_modules/ms/package.json create mode 100644 node_modules/body-parser/node_modules/debug/package.json create mode 100644 node_modules/body-parser/node_modules/depd/History.md create mode 100644 node_modules/body-parser/node_modules/depd/LICENSE create mode 100644 node_modules/body-parser/node_modules/depd/Readme.md create mode 100644 node_modules/body-parser/node_modules/depd/index.js create mode 100644 node_modules/body-parser/node_modules/depd/lib/browser/index.js create mode 100644 node_modules/body-parser/node_modules/depd/lib/compat/buffer-concat.js create mode 100644 node_modules/body-parser/node_modules/depd/lib/compat/callsite-tostring.js create mode 100644 node_modules/body-parser/node_modules/depd/lib/compat/event-listener-count.js create mode 100644 node_modules/body-parser/node_modules/depd/lib/compat/index.js create mode 100644 node_modules/body-parser/node_modules/depd/package.json create mode 100644 node_modules/body-parser/node_modules/http-errors/HISTORY.md create mode 100644 node_modules/body-parser/node_modules/http-errors/LICENSE create mode 100644 node_modules/body-parser/node_modules/http-errors/README.md create mode 100644 node_modules/body-parser/node_modules/http-errors/index.js create mode 100644 node_modules/body-parser/node_modules/http-errors/node_modules/inherits/LICENSE create mode 100644 node_modules/body-parser/node_modules/http-errors/node_modules/inherits/README.md create mode 100644 node_modules/body-parser/node_modules/http-errors/node_modules/inherits/inherits.js create mode 100644 node_modules/body-parser/node_modules/http-errors/node_modules/inherits/inherits_browser.js create mode 100644 node_modules/body-parser/node_modules/http-errors/node_modules/inherits/package.json create mode 100644 node_modules/body-parser/node_modules/http-errors/node_modules/inherits/test.js create mode 100644 node_modules/body-parser/node_modules/http-errors/node_modules/setprototypeof/LICENSE create mode 100644 node_modules/body-parser/node_modules/http-errors/node_modules/setprototypeof/README.md create mode 100644 node_modules/body-parser/node_modules/http-errors/node_modules/setprototypeof/index.js create mode 100644 node_modules/body-parser/node_modules/http-errors/node_modules/setprototypeof/package.json create mode 100644 node_modules/body-parser/node_modules/http-errors/node_modules/statuses/HISTORY.md create mode 100644 node_modules/body-parser/node_modules/http-errors/node_modules/statuses/LICENSE create mode 100644 node_modules/body-parser/node_modules/http-errors/node_modules/statuses/README.md create mode 100644 node_modules/body-parser/node_modules/http-errors/node_modules/statuses/codes.json create mode 100644 node_modules/body-parser/node_modules/http-errors/node_modules/statuses/index.js create mode 100644 node_modules/body-parser/node_modules/http-errors/node_modules/statuses/package.json create mode 100644 node_modules/body-parser/node_modules/http-errors/package.json create mode 100644 node_modules/body-parser/node_modules/iconv-lite/.npmignore create mode 100644 node_modules/body-parser/node_modules/iconv-lite/.travis.yml create mode 100644 node_modules/body-parser/node_modules/iconv-lite/Changelog.md create mode 100644 node_modules/body-parser/node_modules/iconv-lite/LICENSE create mode 100644 node_modules/body-parser/node_modules/iconv-lite/README.md create mode 100644 node_modules/body-parser/node_modules/iconv-lite/encodings/dbcs-codec.js create mode 100644 node_modules/body-parser/node_modules/iconv-lite/encodings/dbcs-data.js create mode 100644 node_modules/body-parser/node_modules/iconv-lite/encodings/index.js create mode 100644 node_modules/body-parser/node_modules/iconv-lite/encodings/internal.js create mode 100644 node_modules/body-parser/node_modules/iconv-lite/encodings/sbcs-codec.js create mode 100644 node_modules/body-parser/node_modules/iconv-lite/encodings/sbcs-data-generated.js create mode 100644 node_modules/body-parser/node_modules/iconv-lite/encodings/sbcs-data.js create mode 100644 node_modules/body-parser/node_modules/iconv-lite/encodings/tables/big5-added.json create mode 100644 node_modules/body-parser/node_modules/iconv-lite/encodings/tables/cp936.json create mode 100644 node_modules/body-parser/node_modules/iconv-lite/encodings/tables/cp949.json create mode 100644 node_modules/body-parser/node_modules/iconv-lite/encodings/tables/cp950.json create mode 100644 node_modules/body-parser/node_modules/iconv-lite/encodings/tables/eucjp.json create mode 100644 node_modules/body-parser/node_modules/iconv-lite/encodings/tables/gb18030-ranges.json create mode 100644 node_modules/body-parser/node_modules/iconv-lite/encodings/tables/gbk-added.json create mode 100644 node_modules/body-parser/node_modules/iconv-lite/encodings/tables/shiftjis.json create mode 100644 node_modules/body-parser/node_modules/iconv-lite/encodings/utf16.js create mode 100644 node_modules/body-parser/node_modules/iconv-lite/encodings/utf7.js create mode 100644 node_modules/body-parser/node_modules/iconv-lite/lib/bom-handling.js create mode 100644 node_modules/body-parser/node_modules/iconv-lite/lib/extend-node.js create mode 100644 node_modules/body-parser/node_modules/iconv-lite/lib/index.js create mode 100644 node_modules/body-parser/node_modules/iconv-lite/lib/streams.js create mode 100644 node_modules/body-parser/node_modules/iconv-lite/package.json create mode 100644 node_modules/body-parser/node_modules/on-finished/HISTORY.md create mode 100644 node_modules/body-parser/node_modules/on-finished/LICENSE create mode 100644 node_modules/body-parser/node_modules/on-finished/README.md create mode 100644 node_modules/body-parser/node_modules/on-finished/index.js create mode 100644 node_modules/body-parser/node_modules/on-finished/node_modules/ee-first/LICENSE create mode 100644 node_modules/body-parser/node_modules/on-finished/node_modules/ee-first/README.md create mode 100644 node_modules/body-parser/node_modules/on-finished/node_modules/ee-first/index.js create mode 100644 node_modules/body-parser/node_modules/on-finished/node_modules/ee-first/package.json create mode 100644 node_modules/body-parser/node_modules/on-finished/package.json create mode 100644 node_modules/body-parser/node_modules/qs/.eslintignore create mode 100644 node_modules/body-parser/node_modules/qs/.eslintrc create mode 100644 node_modules/body-parser/node_modules/qs/.jscs.json create mode 100644 node_modules/body-parser/node_modules/qs/CHANGELOG.md create mode 100644 node_modules/body-parser/node_modules/qs/CONTRIBUTING.md create mode 100644 node_modules/body-parser/node_modules/qs/LICENSE create mode 100644 node_modules/body-parser/node_modules/qs/dist/qs.js create mode 100644 node_modules/body-parser/node_modules/qs/lib/index.js create mode 100644 node_modules/body-parser/node_modules/qs/lib/parse.js create mode 100644 node_modules/body-parser/node_modules/qs/lib/stringify.js create mode 100644 node_modules/body-parser/node_modules/qs/lib/utils.js create mode 100644 node_modules/body-parser/node_modules/qs/package.json create mode 100644 node_modules/body-parser/node_modules/qs/test/index.js create mode 100644 node_modules/body-parser/node_modules/qs/test/parse.js create mode 100644 node_modules/body-parser/node_modules/qs/test/stringify.js create mode 100644 node_modules/body-parser/node_modules/qs/test/utils.js create mode 100644 node_modules/body-parser/node_modules/raw-body/HISTORY.md create mode 100644 node_modules/body-parser/node_modules/raw-body/LICENSE create mode 100644 node_modules/body-parser/node_modules/raw-body/README.md create mode 100644 node_modules/body-parser/node_modules/raw-body/index.js create mode 100644 node_modules/body-parser/node_modules/raw-body/node_modules/unpipe/HISTORY.md create mode 100644 node_modules/body-parser/node_modules/raw-body/node_modules/unpipe/LICENSE create mode 100644 node_modules/body-parser/node_modules/raw-body/node_modules/unpipe/README.md create mode 100644 node_modules/body-parser/node_modules/raw-body/node_modules/unpipe/index.js create mode 100644 node_modules/body-parser/node_modules/raw-body/node_modules/unpipe/package.json create mode 100644 node_modules/body-parser/node_modules/raw-body/package.json create mode 100644 node_modules/body-parser/node_modules/type-is/HISTORY.md create mode 100644 node_modules/body-parser/node_modules/type-is/LICENSE create mode 100644 node_modules/body-parser/node_modules/type-is/README.md create mode 100644 node_modules/body-parser/node_modules/type-is/index.js create mode 100644 node_modules/body-parser/node_modules/type-is/node_modules/media-typer/HISTORY.md create mode 100644 node_modules/body-parser/node_modules/type-is/node_modules/media-typer/LICENSE create mode 100644 node_modules/body-parser/node_modules/type-is/node_modules/media-typer/README.md create mode 100644 node_modules/body-parser/node_modules/type-is/node_modules/media-typer/index.js create mode 100644 node_modules/body-parser/node_modules/type-is/node_modules/media-typer/package.json create mode 100644 node_modules/body-parser/node_modules/type-is/node_modules/mime-types/HISTORY.md create mode 100644 node_modules/body-parser/node_modules/type-is/node_modules/mime-types/LICENSE create mode 100644 node_modules/body-parser/node_modules/type-is/node_modules/mime-types/README.md create mode 100644 node_modules/body-parser/node_modules/type-is/node_modules/mime-types/index.js create mode 100644 node_modules/body-parser/node_modules/type-is/node_modules/mime-types/node_modules/mime-db/HISTORY.md create mode 100644 node_modules/body-parser/node_modules/type-is/node_modules/mime-types/node_modules/mime-db/LICENSE create mode 100644 node_modules/body-parser/node_modules/type-is/node_modules/mime-types/node_modules/mime-db/README.md create mode 100644 node_modules/body-parser/node_modules/type-is/node_modules/mime-types/node_modules/mime-db/db.json create mode 100644 node_modules/body-parser/node_modules/type-is/node_modules/mime-types/node_modules/mime-db/index.js create mode 100644 node_modules/body-parser/node_modules/type-is/node_modules/mime-types/node_modules/mime-db/package.json create mode 100644 node_modules/body-parser/node_modules/type-is/node_modules/mime-types/package.json create mode 100644 node_modules/body-parser/node_modules/type-is/package.json create mode 100644 node_modules/body-parser/package.json create mode 100644 node_modules/connect-flash/.travis.yml create mode 100644 node_modules/connect-flash/LICENSE create mode 100644 node_modules/connect-flash/README.md create mode 100644 node_modules/connect-flash/lib/flash.js create mode 100644 node_modules/connect-flash/lib/index.js create mode 100644 node_modules/connect-flash/package.json create mode 100644 node_modules/cookie-parser/HISTORY.md create mode 100644 node_modules/cookie-parser/LICENSE create mode 100644 node_modules/cookie-parser/README.md create mode 100644 node_modules/cookie-parser/index.js create mode 100644 node_modules/cookie-parser/node_modules/cookie-signature/.npmignore create mode 100644 node_modules/cookie-parser/node_modules/cookie-signature/History.md create mode 100644 node_modules/cookie-parser/node_modules/cookie-signature/Readme.md create mode 100644 node_modules/cookie-parser/node_modules/cookie-signature/index.js create mode 100644 node_modules/cookie-parser/node_modules/cookie-signature/package.json create mode 100644 node_modules/cookie-parser/node_modules/cookie/HISTORY.md create mode 100644 node_modules/cookie-parser/node_modules/cookie/LICENSE create mode 100644 node_modules/cookie-parser/node_modules/cookie/README.md create mode 100644 node_modules/cookie-parser/node_modules/cookie/index.js create mode 100644 node_modules/cookie-parser/node_modules/cookie/package.json create mode 100644 node_modules/cookie-parser/package.json create mode 100644 node_modules/express-session/HISTORY.md create mode 100644 node_modules/express-session/LICENSE create mode 100644 node_modules/express-session/README.md create mode 100644 node_modules/express-session/index.js create mode 100644 node_modules/express-session/node_modules/cookie-signature/.npmignore create mode 100644 node_modules/express-session/node_modules/cookie-signature/History.md create mode 100644 node_modules/express-session/node_modules/cookie-signature/Readme.md create mode 100644 node_modules/express-session/node_modules/cookie-signature/index.js create mode 100644 node_modules/express-session/node_modules/cookie-signature/package.json create mode 100644 node_modules/express-session/node_modules/cookie/HISTORY.md create mode 100644 node_modules/express-session/node_modules/cookie/LICENSE create mode 100644 node_modules/express-session/node_modules/cookie/README.md create mode 100644 node_modules/express-session/node_modules/cookie/index.js create mode 100644 node_modules/express-session/node_modules/cookie/package.json create mode 100644 node_modules/express-session/node_modules/crc/LICENSE create mode 100644 node_modules/express-session/node_modules/crc/README.md create mode 100644 node_modules/express-session/node_modules/crc/lib/crc1.js create mode 100644 node_modules/express-session/node_modules/crc/lib/crc16.js create mode 100644 node_modules/express-session/node_modules/crc/lib/crc16_ccitt.js create mode 100644 node_modules/express-session/node_modules/crc/lib/crc16_kermit.js create mode 100644 node_modules/express-session/node_modules/crc/lib/crc16_modbus.js create mode 100644 node_modules/express-session/node_modules/crc/lib/crc16_xmodem.js create mode 100644 node_modules/express-session/node_modules/crc/lib/crc24.js create mode 100644 node_modules/express-session/node_modules/crc/lib/crc32.js create mode 100644 node_modules/express-session/node_modules/crc/lib/crc8.js create mode 100644 node_modules/express-session/node_modules/crc/lib/crc8_1wire.js create mode 100644 node_modules/express-session/node_modules/crc/lib/define_crc.js create mode 100644 node_modules/express-session/node_modules/crc/lib/index.js create mode 100644 node_modules/express-session/node_modules/crc/package.json create mode 100644 node_modules/express-session/node_modules/debug/.jshintrc create mode 100644 node_modules/express-session/node_modules/debug/.npmignore create mode 100644 node_modules/express-session/node_modules/debug/History.md create mode 100644 node_modules/express-session/node_modules/debug/Makefile create mode 100644 node_modules/express-session/node_modules/debug/Readme.md create mode 100644 node_modules/express-session/node_modules/debug/bower.json create mode 100644 node_modules/express-session/node_modules/debug/browser.js create mode 100644 node_modules/express-session/node_modules/debug/component.json create mode 100644 node_modules/express-session/node_modules/debug/debug.js create mode 100644 node_modules/express-session/node_modules/debug/node.js create mode 100644 node_modules/express-session/node_modules/debug/node_modules/ms/.npmignore create mode 100644 node_modules/express-session/node_modules/debug/node_modules/ms/History.md create mode 100644 node_modules/express-session/node_modules/debug/node_modules/ms/LICENSE create mode 100644 node_modules/express-session/node_modules/debug/node_modules/ms/README.md create mode 100644 node_modules/express-session/node_modules/debug/node_modules/ms/index.js create mode 100644 node_modules/express-session/node_modules/debug/node_modules/ms/package.json create mode 100644 node_modules/express-session/node_modules/debug/package.json create mode 100644 node_modules/express-session/node_modules/depd/History.md create mode 100644 node_modules/express-session/node_modules/depd/LICENSE create mode 100644 node_modules/express-session/node_modules/depd/Readme.md create mode 100644 node_modules/express-session/node_modules/depd/index.js create mode 100644 node_modules/express-session/node_modules/depd/lib/browser/index.js create mode 100644 node_modules/express-session/node_modules/depd/lib/compat/buffer-concat.js create mode 100644 node_modules/express-session/node_modules/depd/lib/compat/callsite-tostring.js create mode 100644 node_modules/express-session/node_modules/depd/lib/compat/event-listener-count.js create mode 100644 node_modules/express-session/node_modules/depd/lib/compat/index.js create mode 100644 node_modules/express-session/node_modules/depd/package.json create mode 100644 node_modules/express-session/node_modules/on-headers/HISTORY.md create mode 100644 node_modules/express-session/node_modules/on-headers/LICENSE create mode 100644 node_modules/express-session/node_modules/on-headers/README.md create mode 100644 node_modules/express-session/node_modules/on-headers/index.js create mode 100644 node_modules/express-session/node_modules/on-headers/package.json create mode 100644 node_modules/express-session/node_modules/parseurl/HISTORY.md create mode 100644 node_modules/express-session/node_modules/parseurl/LICENSE create mode 100644 node_modules/express-session/node_modules/parseurl/README.md create mode 100644 node_modules/express-session/node_modules/parseurl/index.js create mode 100644 node_modules/express-session/node_modules/parseurl/package.json create mode 100644 node_modules/express-session/node_modules/uid-safe/HISTORY.md create mode 100644 node_modules/express-session/node_modules/uid-safe/LICENSE create mode 100644 node_modules/express-session/node_modules/uid-safe/README.md create mode 100644 node_modules/express-session/node_modules/uid-safe/index.js create mode 100644 node_modules/express-session/node_modules/uid-safe/node_modules/base64-url/LICENSE create mode 100644 node_modules/express-session/node_modules/uid-safe/node_modules/base64-url/README.md create mode 100644 node_modules/express-session/node_modules/uid-safe/node_modules/base64-url/index.js create mode 100644 node_modules/express-session/node_modules/uid-safe/node_modules/base64-url/package.json create mode 100644 node_modules/express-session/node_modules/uid-safe/node_modules/random-bytes/HISTORY.md create mode 100644 node_modules/express-session/node_modules/uid-safe/node_modules/random-bytes/LICENSE create mode 100644 node_modules/express-session/node_modules/uid-safe/node_modules/random-bytes/README.md create mode 100644 node_modules/express-session/node_modules/uid-safe/node_modules/random-bytes/index.js create mode 100644 node_modules/express-session/node_modules/uid-safe/node_modules/random-bytes/package.json create mode 100644 node_modules/express-session/node_modules/uid-safe/package.json create mode 100644 node_modules/express-session/node_modules/utils-merge/.travis.yml create mode 100644 node_modules/express-session/node_modules/utils-merge/LICENSE create mode 100644 node_modules/express-session/node_modules/utils-merge/README.md create mode 100644 node_modules/express-session/node_modules/utils-merge/index.js create mode 100644 node_modules/express-session/node_modules/utils-merge/package.json create mode 100644 node_modules/express-session/package.json create mode 100644 node_modules/express-session/session/cookie.js create mode 100644 node_modules/express-session/session/memory.js create mode 100644 node_modules/express-session/session/session.js create mode 100644 node_modules/express-session/session/store.js create mode 100644 node_modules/express/History.md create mode 100644 node_modules/express/LICENSE create mode 100644 node_modules/express/Readme.md create mode 100644 node_modules/express/index.js create mode 100644 node_modules/express/lib/application.js create mode 100644 node_modules/express/lib/express.js create mode 100644 node_modules/express/lib/middleware/init.js create mode 100644 node_modules/express/lib/middleware/query.js create mode 100644 node_modules/express/lib/request.js create mode 100644 node_modules/express/lib/response.js create mode 100644 node_modules/express/lib/router/index.js create mode 100644 node_modules/express/lib/router/layer.js create mode 100644 node_modules/express/lib/router/route.js create mode 100644 node_modules/express/lib/utils.js create mode 100644 node_modules/express/lib/view.js create mode 100644 node_modules/express/node_modules/accepts/HISTORY.md create mode 100644 node_modules/express/node_modules/accepts/LICENSE create mode 100644 node_modules/express/node_modules/accepts/README.md create mode 100644 node_modules/express/node_modules/accepts/index.js create mode 100644 node_modules/express/node_modules/accepts/node_modules/mime-types/HISTORY.md create mode 100644 node_modules/express/node_modules/accepts/node_modules/mime-types/LICENSE create mode 100644 node_modules/express/node_modules/accepts/node_modules/mime-types/README.md create mode 100644 node_modules/express/node_modules/accepts/node_modules/mime-types/index.js create mode 100644 node_modules/express/node_modules/accepts/node_modules/mime-types/node_modules/mime-db/HISTORY.md create mode 100644 node_modules/express/node_modules/accepts/node_modules/mime-types/node_modules/mime-db/LICENSE create mode 100644 node_modules/express/node_modules/accepts/node_modules/mime-types/node_modules/mime-db/README.md create mode 100644 node_modules/express/node_modules/accepts/node_modules/mime-types/node_modules/mime-db/db.json create mode 100644 node_modules/express/node_modules/accepts/node_modules/mime-types/node_modules/mime-db/index.js create mode 100644 node_modules/express/node_modules/accepts/node_modules/mime-types/node_modules/mime-db/package.json create mode 100644 node_modules/express/node_modules/accepts/node_modules/mime-types/package.json create mode 100644 node_modules/express/node_modules/accepts/node_modules/negotiator/HISTORY.md create mode 100644 node_modules/express/node_modules/accepts/node_modules/negotiator/LICENSE create mode 100644 node_modules/express/node_modules/accepts/node_modules/negotiator/README.md create mode 100644 node_modules/express/node_modules/accepts/node_modules/negotiator/index.js create mode 100644 node_modules/express/node_modules/accepts/node_modules/negotiator/lib/charset.js create mode 100644 node_modules/express/node_modules/accepts/node_modules/negotiator/lib/encoding.js create mode 100644 node_modules/express/node_modules/accepts/node_modules/negotiator/lib/language.js create mode 100644 node_modules/express/node_modules/accepts/node_modules/negotiator/lib/mediaType.js create mode 100644 node_modules/express/node_modules/accepts/node_modules/negotiator/package.json create mode 100644 node_modules/express/node_modules/accepts/package.json create mode 100644 node_modules/express/node_modules/array-flatten/LICENSE create mode 100644 node_modules/express/node_modules/array-flatten/README.md create mode 100644 node_modules/express/node_modules/array-flatten/array-flatten.js create mode 100644 node_modules/express/node_modules/array-flatten/package.json create mode 100644 node_modules/express/node_modules/content-disposition/HISTORY.md create mode 100644 node_modules/express/node_modules/content-disposition/LICENSE create mode 100644 node_modules/express/node_modules/content-disposition/README.md create mode 100644 node_modules/express/node_modules/content-disposition/index.js create mode 100644 node_modules/express/node_modules/content-disposition/package.json create mode 100644 node_modules/express/node_modules/content-type/HISTORY.md create mode 100644 node_modules/express/node_modules/content-type/LICENSE create mode 100644 node_modules/express/node_modules/content-type/README.md create mode 100644 node_modules/express/node_modules/content-type/index.js create mode 100644 node_modules/express/node_modules/content-type/package.json create mode 100644 node_modules/express/node_modules/cookie-signature/.npmignore create mode 100644 node_modules/express/node_modules/cookie-signature/History.md create mode 100644 node_modules/express/node_modules/cookie-signature/Readme.md create mode 100644 node_modules/express/node_modules/cookie-signature/index.js create mode 100644 node_modules/express/node_modules/cookie-signature/package.json create mode 100644 node_modules/express/node_modules/cookie/HISTORY.md create mode 100644 node_modules/express/node_modules/cookie/LICENSE create mode 100644 node_modules/express/node_modules/cookie/README.md create mode 100644 node_modules/express/node_modules/cookie/index.js create mode 100644 node_modules/express/node_modules/cookie/package.json create mode 100644 node_modules/express/node_modules/debug/.jshintrc create mode 100644 node_modules/express/node_modules/debug/.npmignore create mode 100644 node_modules/express/node_modules/debug/History.md create mode 100644 node_modules/express/node_modules/debug/Makefile create mode 100644 node_modules/express/node_modules/debug/Readme.md create mode 100644 node_modules/express/node_modules/debug/bower.json create mode 100644 node_modules/express/node_modules/debug/browser.js create mode 100644 node_modules/express/node_modules/debug/component.json create mode 100644 node_modules/express/node_modules/debug/debug.js create mode 100644 node_modules/express/node_modules/debug/node.js create mode 100644 node_modules/express/node_modules/debug/node_modules/ms/.npmignore create mode 100644 node_modules/express/node_modules/debug/node_modules/ms/History.md create mode 100644 node_modules/express/node_modules/debug/node_modules/ms/LICENSE create mode 100644 node_modules/express/node_modules/debug/node_modules/ms/README.md create mode 100644 node_modules/express/node_modules/debug/node_modules/ms/index.js create mode 100644 node_modules/express/node_modules/debug/node_modules/ms/package.json create mode 100644 node_modules/express/node_modules/debug/package.json create mode 100644 node_modules/express/node_modules/depd/History.md create mode 100644 node_modules/express/node_modules/depd/LICENSE create mode 100644 node_modules/express/node_modules/depd/Readme.md create mode 100644 node_modules/express/node_modules/depd/index.js create mode 100644 node_modules/express/node_modules/depd/lib/browser/index.js create mode 100644 node_modules/express/node_modules/depd/lib/compat/buffer-concat.js create mode 100644 node_modules/express/node_modules/depd/lib/compat/callsite-tostring.js create mode 100644 node_modules/express/node_modules/depd/lib/compat/event-listener-count.js create mode 100644 node_modules/express/node_modules/depd/lib/compat/index.js create mode 100644 node_modules/express/node_modules/depd/package.json create mode 100644 node_modules/express/node_modules/encodeurl/HISTORY.md create mode 100644 node_modules/express/node_modules/encodeurl/LICENSE create mode 100644 node_modules/express/node_modules/encodeurl/README.md create mode 100644 node_modules/express/node_modules/encodeurl/index.js create mode 100644 node_modules/express/node_modules/encodeurl/package.json create mode 100644 node_modules/express/node_modules/escape-html/LICENSE create mode 100644 node_modules/express/node_modules/escape-html/Readme.md create mode 100644 node_modules/express/node_modules/escape-html/index.js create mode 100644 node_modules/express/node_modules/escape-html/package.json create mode 100644 node_modules/express/node_modules/etag/HISTORY.md create mode 100644 node_modules/express/node_modules/etag/LICENSE create mode 100644 node_modules/express/node_modules/etag/README.md create mode 100644 node_modules/express/node_modules/etag/index.js create mode 100644 node_modules/express/node_modules/etag/package.json create mode 100644 node_modules/express/node_modules/finalhandler/HISTORY.md create mode 100644 node_modules/express/node_modules/finalhandler/LICENSE create mode 100644 node_modules/express/node_modules/finalhandler/README.md create mode 100644 node_modules/express/node_modules/finalhandler/index.js create mode 100644 node_modules/express/node_modules/finalhandler/node_modules/statuses/HISTORY.md create mode 100644 node_modules/express/node_modules/finalhandler/node_modules/statuses/LICENSE create mode 100644 node_modules/express/node_modules/finalhandler/node_modules/statuses/README.md create mode 100644 node_modules/express/node_modules/finalhandler/node_modules/statuses/codes.json create mode 100644 node_modules/express/node_modules/finalhandler/node_modules/statuses/index.js create mode 100644 node_modules/express/node_modules/finalhandler/node_modules/statuses/package.json create mode 100644 node_modules/express/node_modules/finalhandler/node_modules/unpipe/HISTORY.md create mode 100644 node_modules/express/node_modules/finalhandler/node_modules/unpipe/LICENSE create mode 100644 node_modules/express/node_modules/finalhandler/node_modules/unpipe/README.md create mode 100644 node_modules/express/node_modules/finalhandler/node_modules/unpipe/index.js create mode 100644 node_modules/express/node_modules/finalhandler/node_modules/unpipe/package.json create mode 100644 node_modules/express/node_modules/finalhandler/package.json create mode 100644 node_modules/express/node_modules/fresh/HISTORY.md create mode 100644 node_modules/express/node_modules/fresh/LICENSE create mode 100644 node_modules/express/node_modules/fresh/README.md create mode 100644 node_modules/express/node_modules/fresh/index.js create mode 100644 node_modules/express/node_modules/fresh/package.json create mode 100644 node_modules/express/node_modules/merge-descriptors/HISTORY.md create mode 100644 node_modules/express/node_modules/merge-descriptors/LICENSE create mode 100644 node_modules/express/node_modules/merge-descriptors/README.md create mode 100644 node_modules/express/node_modules/merge-descriptors/index.js create mode 100644 node_modules/express/node_modules/merge-descriptors/package.json create mode 100644 node_modules/express/node_modules/methods/HISTORY.md create mode 100644 node_modules/express/node_modules/methods/LICENSE create mode 100644 node_modules/express/node_modules/methods/README.md create mode 100644 node_modules/express/node_modules/methods/index.js create mode 100644 node_modules/express/node_modules/methods/package.json create mode 100644 node_modules/express/node_modules/on-finished/HISTORY.md create mode 100644 node_modules/express/node_modules/on-finished/LICENSE create mode 100644 node_modules/express/node_modules/on-finished/README.md create mode 100644 node_modules/express/node_modules/on-finished/index.js create mode 100644 node_modules/express/node_modules/on-finished/node_modules/ee-first/LICENSE create mode 100644 node_modules/express/node_modules/on-finished/node_modules/ee-first/README.md create mode 100644 node_modules/express/node_modules/on-finished/node_modules/ee-first/index.js create mode 100644 node_modules/express/node_modules/on-finished/node_modules/ee-first/package.json create mode 100644 node_modules/express/node_modules/on-finished/package.json create mode 100644 node_modules/express/node_modules/parseurl/HISTORY.md create mode 100644 node_modules/express/node_modules/parseurl/LICENSE create mode 100644 node_modules/express/node_modules/parseurl/README.md create mode 100644 node_modules/express/node_modules/parseurl/index.js create mode 100644 node_modules/express/node_modules/parseurl/package.json create mode 100644 node_modules/express/node_modules/path-to-regexp/History.md create mode 100644 node_modules/express/node_modules/path-to-regexp/LICENSE create mode 100644 node_modules/express/node_modules/path-to-regexp/Readme.md create mode 100644 node_modules/express/node_modules/path-to-regexp/index.js create mode 100644 node_modules/express/node_modules/path-to-regexp/package.json create mode 100644 node_modules/express/node_modules/proxy-addr/HISTORY.md create mode 100644 node_modules/express/node_modules/proxy-addr/LICENSE create mode 100644 node_modules/express/node_modules/proxy-addr/README.md create mode 100644 node_modules/express/node_modules/proxy-addr/index.js create mode 100644 node_modules/express/node_modules/proxy-addr/node_modules/forwarded/HISTORY.md create mode 100644 node_modules/express/node_modules/proxy-addr/node_modules/forwarded/LICENSE create mode 100644 node_modules/express/node_modules/proxy-addr/node_modules/forwarded/README.md create mode 100644 node_modules/express/node_modules/proxy-addr/node_modules/forwarded/index.js create mode 100644 node_modules/express/node_modules/proxy-addr/node_modules/forwarded/package.json create mode 100644 node_modules/express/node_modules/proxy-addr/node_modules/ipaddr.js/.npmignore create mode 100644 node_modules/express/node_modules/proxy-addr/node_modules/ipaddr.js/.travis.yml create mode 100644 node_modules/express/node_modules/proxy-addr/node_modules/ipaddr.js/Cakefile create mode 100644 node_modules/express/node_modules/proxy-addr/node_modules/ipaddr.js/LICENSE create mode 100644 node_modules/express/node_modules/proxy-addr/node_modules/ipaddr.js/README.md create mode 100644 node_modules/express/node_modules/proxy-addr/node_modules/ipaddr.js/bower.json create mode 100644 node_modules/express/node_modules/proxy-addr/node_modules/ipaddr.js/ipaddr.min.js create mode 100644 node_modules/express/node_modules/proxy-addr/node_modules/ipaddr.js/lib/ipaddr.js create mode 100644 node_modules/express/node_modules/proxy-addr/node_modules/ipaddr.js/package.json create mode 100644 node_modules/express/node_modules/proxy-addr/node_modules/ipaddr.js/src/ipaddr.coffee create mode 100644 node_modules/express/node_modules/proxy-addr/node_modules/ipaddr.js/test/ipaddr.test.coffee create mode 100644 node_modules/express/node_modules/proxy-addr/package.json create mode 100644 node_modules/express/node_modules/qs/.eslintignore create mode 100644 node_modules/express/node_modules/qs/.eslintrc create mode 100644 node_modules/express/node_modules/qs/.jscs.json create mode 100644 node_modules/express/node_modules/qs/CHANGELOG.md create mode 100644 node_modules/express/node_modules/qs/CONTRIBUTING.md create mode 100644 node_modules/express/node_modules/qs/LICENSE create mode 100644 node_modules/express/node_modules/qs/dist/qs.js create mode 100644 node_modules/express/node_modules/qs/lib/index.js create mode 100644 node_modules/express/node_modules/qs/lib/parse.js create mode 100644 node_modules/express/node_modules/qs/lib/stringify.js create mode 100644 node_modules/express/node_modules/qs/lib/utils.js create mode 100644 node_modules/express/node_modules/qs/package.json create mode 100644 node_modules/express/node_modules/qs/test/index.js create mode 100644 node_modules/express/node_modules/qs/test/parse.js create mode 100644 node_modules/express/node_modules/qs/test/stringify.js create mode 100644 node_modules/express/node_modules/qs/test/utils.js create mode 100644 node_modules/express/node_modules/range-parser/HISTORY.md create mode 100644 node_modules/express/node_modules/range-parser/LICENSE create mode 100644 node_modules/express/node_modules/range-parser/README.md create mode 100644 node_modules/express/node_modules/range-parser/index.js create mode 100644 node_modules/express/node_modules/range-parser/package.json create mode 100644 node_modules/express/node_modules/send/HISTORY.md create mode 100644 node_modules/express/node_modules/send/LICENSE create mode 100644 node_modules/express/node_modules/send/README.md create mode 100644 node_modules/express/node_modules/send/index.js create mode 100644 node_modules/express/node_modules/send/node_modules/.bin/mime create mode 100644 node_modules/express/node_modules/send/node_modules/.bin/mime.cmd create mode 100644 node_modules/express/node_modules/send/node_modules/destroy/LICENSE create mode 100644 node_modules/express/node_modules/send/node_modules/destroy/README.md create mode 100644 node_modules/express/node_modules/send/node_modules/destroy/index.js create mode 100644 node_modules/express/node_modules/send/node_modules/destroy/package.json create mode 100644 node_modules/express/node_modules/send/node_modules/http-errors/HISTORY.md create mode 100644 node_modules/express/node_modules/send/node_modules/http-errors/LICENSE create mode 100644 node_modules/express/node_modules/send/node_modules/http-errors/README.md create mode 100644 node_modules/express/node_modules/send/node_modules/http-errors/index.js create mode 100644 node_modules/express/node_modules/send/node_modules/http-errors/node_modules/inherits/LICENSE create mode 100644 node_modules/express/node_modules/send/node_modules/http-errors/node_modules/inherits/README.md create mode 100644 node_modules/express/node_modules/send/node_modules/http-errors/node_modules/inherits/inherits.js create mode 100644 node_modules/express/node_modules/send/node_modules/http-errors/node_modules/inherits/inherits_browser.js create mode 100644 node_modules/express/node_modules/send/node_modules/http-errors/node_modules/inherits/package.json create mode 100644 node_modules/express/node_modules/send/node_modules/http-errors/node_modules/inherits/test.js create mode 100644 node_modules/express/node_modules/send/node_modules/http-errors/node_modules/setprototypeof/LICENSE create mode 100644 node_modules/express/node_modules/send/node_modules/http-errors/node_modules/setprototypeof/README.md create mode 100644 node_modules/express/node_modules/send/node_modules/http-errors/node_modules/setprototypeof/index.js create mode 100644 node_modules/express/node_modules/send/node_modules/http-errors/node_modules/setprototypeof/package.json create mode 100644 node_modules/express/node_modules/send/node_modules/http-errors/package.json create mode 100644 node_modules/express/node_modules/send/node_modules/mime/.npmignore create mode 100644 node_modules/express/node_modules/send/node_modules/mime/LICENSE create mode 100644 node_modules/express/node_modules/send/node_modules/mime/README.md create mode 100644 node_modules/express/node_modules/send/node_modules/mime/build/build.js create mode 100644 node_modules/express/node_modules/send/node_modules/mime/build/test.js create mode 100644 node_modules/express/node_modules/send/node_modules/mime/cli.js create mode 100644 node_modules/express/node_modules/send/node_modules/mime/mime.js create mode 100644 node_modules/express/node_modules/send/node_modules/mime/package.json create mode 100644 node_modules/express/node_modules/send/node_modules/mime/types.json create mode 100644 node_modules/express/node_modules/send/node_modules/ms/.npmignore create mode 100644 node_modules/express/node_modules/send/node_modules/ms/History.md create mode 100644 node_modules/express/node_modules/send/node_modules/ms/LICENSE create mode 100644 node_modules/express/node_modules/send/node_modules/ms/README.md create mode 100644 node_modules/express/node_modules/send/node_modules/ms/index.js create mode 100644 node_modules/express/node_modules/send/node_modules/ms/package.json create mode 100644 node_modules/express/node_modules/send/node_modules/statuses/HISTORY.md create mode 100644 node_modules/express/node_modules/send/node_modules/statuses/LICENSE create mode 100644 node_modules/express/node_modules/send/node_modules/statuses/README.md create mode 100644 node_modules/express/node_modules/send/node_modules/statuses/codes.json create mode 100644 node_modules/express/node_modules/send/node_modules/statuses/index.js create mode 100644 node_modules/express/node_modules/send/node_modules/statuses/package.json create mode 100644 node_modules/express/node_modules/send/package.json create mode 100644 node_modules/express/node_modules/serve-static/HISTORY.md create mode 100644 node_modules/express/node_modules/serve-static/LICENSE create mode 100644 node_modules/express/node_modules/serve-static/README.md create mode 100644 node_modules/express/node_modules/serve-static/index.js create mode 100644 node_modules/express/node_modules/serve-static/package.json create mode 100644 node_modules/express/node_modules/type-is/HISTORY.md create mode 100644 node_modules/express/node_modules/type-is/LICENSE create mode 100644 node_modules/express/node_modules/type-is/README.md create mode 100644 node_modules/express/node_modules/type-is/index.js create mode 100644 node_modules/express/node_modules/type-is/node_modules/media-typer/HISTORY.md create mode 100644 node_modules/express/node_modules/type-is/node_modules/media-typer/LICENSE create mode 100644 node_modules/express/node_modules/type-is/node_modules/media-typer/README.md create mode 100644 node_modules/express/node_modules/type-is/node_modules/media-typer/index.js create mode 100644 node_modules/express/node_modules/type-is/node_modules/media-typer/package.json create mode 100644 node_modules/express/node_modules/type-is/node_modules/mime-types/HISTORY.md create mode 100644 node_modules/express/node_modules/type-is/node_modules/mime-types/LICENSE create mode 100644 node_modules/express/node_modules/type-is/node_modules/mime-types/README.md create mode 100644 node_modules/express/node_modules/type-is/node_modules/mime-types/index.js create mode 100644 node_modules/express/node_modules/type-is/node_modules/mime-types/node_modules/mime-db/HISTORY.md create mode 100644 node_modules/express/node_modules/type-is/node_modules/mime-types/node_modules/mime-db/LICENSE create mode 100644 node_modules/express/node_modules/type-is/node_modules/mime-types/node_modules/mime-db/README.md create mode 100644 node_modules/express/node_modules/type-is/node_modules/mime-types/node_modules/mime-db/db.json create mode 100644 node_modules/express/node_modules/type-is/node_modules/mime-types/node_modules/mime-db/index.js create mode 100644 node_modules/express/node_modules/type-is/node_modules/mime-types/node_modules/mime-db/package.json create mode 100644 node_modules/express/node_modules/type-is/node_modules/mime-types/package.json create mode 100644 node_modules/express/node_modules/type-is/package.json create mode 100644 node_modules/express/node_modules/utils-merge/.travis.yml create mode 100644 node_modules/express/node_modules/utils-merge/LICENSE create mode 100644 node_modules/express/node_modules/utils-merge/README.md create mode 100644 node_modules/express/node_modules/utils-merge/index.js create mode 100644 node_modules/express/node_modules/utils-merge/package.json create mode 100644 node_modules/express/node_modules/vary/HISTORY.md create mode 100644 node_modules/express/node_modules/vary/LICENSE create mode 100644 node_modules/express/node_modules/vary/README.md create mode 100644 node_modules/express/node_modules/vary/index.js create mode 100644 node_modules/express/node_modules/vary/package.json create mode 100644 node_modules/express/package.json create mode 100644 node_modules/method-override/HISTORY.md create mode 100644 node_modules/method-override/LICENSE create mode 100644 node_modules/method-override/README.md create mode 100644 node_modules/method-override/index.js create mode 100644 node_modules/method-override/node_modules/debug/.jshintrc create mode 100644 node_modules/method-override/node_modules/debug/.npmignore create mode 100644 node_modules/method-override/node_modules/debug/History.md create mode 100644 node_modules/method-override/node_modules/debug/Makefile create mode 100644 node_modules/method-override/node_modules/debug/Readme.md create mode 100644 node_modules/method-override/node_modules/debug/bower.json create mode 100644 node_modules/method-override/node_modules/debug/browser.js create mode 100644 node_modules/method-override/node_modules/debug/component.json create mode 100644 node_modules/method-override/node_modules/debug/debug.js create mode 100644 node_modules/method-override/node_modules/debug/node.js create mode 100644 node_modules/method-override/node_modules/debug/node_modules/ms/.npmignore create mode 100644 node_modules/method-override/node_modules/debug/node_modules/ms/History.md create mode 100644 node_modules/method-override/node_modules/debug/node_modules/ms/LICENSE create mode 100644 node_modules/method-override/node_modules/debug/node_modules/ms/README.md create mode 100644 node_modules/method-override/node_modules/debug/node_modules/ms/index.js create mode 100644 node_modules/method-override/node_modules/debug/node_modules/ms/package.json create mode 100644 node_modules/method-override/node_modules/debug/package.json create mode 100644 node_modules/method-override/node_modules/methods/HISTORY.md create mode 100644 node_modules/method-override/node_modules/methods/LICENSE create mode 100644 node_modules/method-override/node_modules/methods/README.md create mode 100644 node_modules/method-override/node_modules/methods/index.js create mode 100644 node_modules/method-override/node_modules/methods/package.json create mode 100644 node_modules/method-override/node_modules/parseurl/HISTORY.md create mode 100644 node_modules/method-override/node_modules/parseurl/LICENSE create mode 100644 node_modules/method-override/node_modules/parseurl/README.md create mode 100644 node_modules/method-override/node_modules/parseurl/index.js create mode 100644 node_modules/method-override/node_modules/parseurl/package.json create mode 100644 node_modules/method-override/node_modules/vary/HISTORY.md create mode 100644 node_modules/method-override/node_modules/vary/LICENSE create mode 100644 node_modules/method-override/node_modules/vary/README.md create mode 100644 node_modules/method-override/node_modules/vary/index.js create mode 100644 node_modules/method-override/node_modules/vary/package.json create mode 100644 node_modules/method-override/package.json create mode 100644 node_modules/mongoose/.eslintignore create mode 100644 node_modules/mongoose/.eslintrc.yml create mode 100644 node_modules/mongoose/.npmignore create mode 100644 node_modules/mongoose/.travis.yml create mode 100644 node_modules/mongoose/CONTRIBUTING.md create mode 100644 node_modules/mongoose/History.md create mode 100644 node_modules/mongoose/README.md create mode 100644 node_modules/mongoose/examples/README.md create mode 100644 node_modules/mongoose/examples/aggregate/aggregate.js create mode 100644 node_modules/mongoose/examples/aggregate/package.json create mode 100644 node_modules/mongoose/examples/aggregate/person.js create mode 100644 node_modules/mongoose/examples/doc-methods.js create mode 100644 node_modules/mongoose/examples/express/README.md create mode 100644 node_modules/mongoose/examples/express/connection-sharing/README.md create mode 100644 node_modules/mongoose/examples/express/connection-sharing/app.js create mode 100644 node_modules/mongoose/examples/express/connection-sharing/modelA.js create mode 100644 node_modules/mongoose/examples/express/connection-sharing/package.json create mode 100644 node_modules/mongoose/examples/express/connection-sharing/routes.js create mode 100644 node_modules/mongoose/examples/geospatial/geoJSONSchema.js create mode 100644 node_modules/mongoose/examples/geospatial/geoJSONexample.js create mode 100644 node_modules/mongoose/examples/geospatial/geospatial.js create mode 100644 node_modules/mongoose/examples/geospatial/package.json create mode 100644 node_modules/mongoose/examples/geospatial/person.js create mode 100644 node_modules/mongoose/examples/globalschemas/gs_example.js create mode 100644 node_modules/mongoose/examples/globalschemas/person.js create mode 100644 node_modules/mongoose/examples/lean/lean.js create mode 100644 node_modules/mongoose/examples/lean/package.json create mode 100644 node_modules/mongoose/examples/lean/person.js create mode 100644 node_modules/mongoose/examples/mapreduce/mapreduce.js create mode 100644 node_modules/mongoose/examples/mapreduce/package.json create mode 100644 node_modules/mongoose/examples/mapreduce/person.js create mode 100644 node_modules/mongoose/examples/population/population-across-three-collections.js create mode 100644 node_modules/mongoose/examples/population/population-basic.js create mode 100644 node_modules/mongoose/examples/population/population-of-existing-doc.js create mode 100644 node_modules/mongoose/examples/population/population-of-multiple-existing-docs.js create mode 100644 node_modules/mongoose/examples/population/population-options.js create mode 100644 node_modules/mongoose/examples/population/population-plain-objects.js create mode 100644 node_modules/mongoose/examples/promises/package.json create mode 100644 node_modules/mongoose/examples/promises/person.js create mode 100644 node_modules/mongoose/examples/promises/promise.js create mode 100644 node_modules/mongoose/examples/querybuilder/package.json create mode 100644 node_modules/mongoose/examples/querybuilder/person.js create mode 100644 node_modules/mongoose/examples/querybuilder/querybuilder.js create mode 100644 node_modules/mongoose/examples/replicasets/package.json create mode 100644 node_modules/mongoose/examples/replicasets/person.js create mode 100644 node_modules/mongoose/examples/replicasets/replica-sets.js create mode 100644 node_modules/mongoose/examples/schema/schema.js create mode 100644 node_modules/mongoose/examples/schema/storing-schemas-as-json/index.js create mode 100644 node_modules/mongoose/examples/schema/storing-schemas-as-json/schema.json create mode 100644 node_modules/mongoose/examples/statics/person.js create mode 100644 node_modules/mongoose/examples/statics/statics.js create mode 100644 node_modules/mongoose/index.js create mode 100644 node_modules/mongoose/lib/ES6Promise.js create mode 100644 node_modules/mongoose/lib/aggregate.js create mode 100644 node_modules/mongoose/lib/browser.js create mode 100644 node_modules/mongoose/lib/browserDocument.js create mode 100644 node_modules/mongoose/lib/cast.js create mode 100644 node_modules/mongoose/lib/collection.js create mode 100644 node_modules/mongoose/lib/connection.js create mode 100644 node_modules/mongoose/lib/connectionstate.js create mode 100644 node_modules/mongoose/lib/document.js create mode 100644 node_modules/mongoose/lib/document_provider.js create mode 100644 node_modules/mongoose/lib/document_provider.web.js create mode 100644 node_modules/mongoose/lib/drivers/SPEC.md create mode 100644 node_modules/mongoose/lib/drivers/browser/ReadPreference.js create mode 100644 node_modules/mongoose/lib/drivers/browser/binary.js create mode 100644 node_modules/mongoose/lib/drivers/browser/index.js create mode 100644 node_modules/mongoose/lib/drivers/browser/objectid.js create mode 100644 node_modules/mongoose/lib/drivers/index.js create mode 100644 node_modules/mongoose/lib/drivers/index.web.js create mode 100644 node_modules/mongoose/lib/drivers/node-mongodb-native/ReadPreference.js create mode 100644 node_modules/mongoose/lib/drivers/node-mongodb-native/binary.js create mode 100644 node_modules/mongoose/lib/drivers/node-mongodb-native/collection.js create mode 100644 node_modules/mongoose/lib/drivers/node-mongodb-native/connection.js create mode 100644 node_modules/mongoose/lib/drivers/node-mongodb-native/index.js create mode 100644 node_modules/mongoose/lib/drivers/node-mongodb-native/objectid.js create mode 100644 node_modules/mongoose/lib/error.js create mode 100644 node_modules/mongoose/lib/error/browserMissingSchema.js create mode 100644 node_modules/mongoose/lib/error/cast.js create mode 100644 node_modules/mongoose/lib/error/disconnected.js create mode 100644 node_modules/mongoose/lib/error/divergentArray.js create mode 100644 node_modules/mongoose/lib/error/messages.js create mode 100644 node_modules/mongoose/lib/error/missingSchema.js create mode 100644 node_modules/mongoose/lib/error/objectExpected.js create mode 100644 node_modules/mongoose/lib/error/overwriteModel.js create mode 100644 node_modules/mongoose/lib/error/strict.js create mode 100644 node_modules/mongoose/lib/error/validation.js create mode 100644 node_modules/mongoose/lib/error/validator.js create mode 100644 node_modules/mongoose/lib/error/version.js create mode 100644 node_modules/mongoose/lib/index.js create mode 100644 node_modules/mongoose/lib/internal.js create mode 100644 node_modules/mongoose/lib/model.js create mode 100644 node_modules/mongoose/lib/promise.js create mode 100644 node_modules/mongoose/lib/promise_provider.js create mode 100644 node_modules/mongoose/lib/query.js create mode 100644 node_modules/mongoose/lib/querycursor.js create mode 100644 node_modules/mongoose/lib/queryhelpers.js create mode 100644 node_modules/mongoose/lib/querystream.js create mode 100644 node_modules/mongoose/lib/schema.js create mode 100644 node_modules/mongoose/lib/schema/array.js create mode 100644 node_modules/mongoose/lib/schema/boolean.js create mode 100644 node_modules/mongoose/lib/schema/buffer.js create mode 100644 node_modules/mongoose/lib/schema/date.js create mode 100644 node_modules/mongoose/lib/schema/documentarray.js create mode 100644 node_modules/mongoose/lib/schema/embedded.js create mode 100644 node_modules/mongoose/lib/schema/index.js create mode 100644 node_modules/mongoose/lib/schema/mixed.js create mode 100644 node_modules/mongoose/lib/schema/number.js create mode 100644 node_modules/mongoose/lib/schema/objectid.js create mode 100644 node_modules/mongoose/lib/schema/operators/bitwise.js create mode 100644 node_modules/mongoose/lib/schema/operators/geospatial.js create mode 100644 node_modules/mongoose/lib/schema/operators/helpers.js create mode 100644 node_modules/mongoose/lib/schema/string.js create mode 100644 node_modules/mongoose/lib/schematype.js create mode 100644 node_modules/mongoose/lib/services/common.js create mode 100644 node_modules/mongoose/lib/services/setDefaultsOnInsert.js create mode 100644 node_modules/mongoose/lib/services/updateValidators.js create mode 100644 node_modules/mongoose/lib/statemachine.js create mode 100644 node_modules/mongoose/lib/types/array.js create mode 100644 node_modules/mongoose/lib/types/buffer.js create mode 100644 node_modules/mongoose/lib/types/documentarray.js create mode 100644 node_modules/mongoose/lib/types/embedded.js create mode 100644 node_modules/mongoose/lib/types/index.js create mode 100644 node_modules/mongoose/lib/types/objectid.js create mode 100644 node_modules/mongoose/lib/types/subdocument.js create mode 100644 node_modules/mongoose/lib/utils.js create mode 100644 node_modules/mongoose/lib/virtualtype.js create mode 100644 node_modules/mongoose/node_modules/async/CHANGELOG.md create mode 100644 node_modules/mongoose/node_modules/async/LICENSE create mode 100644 node_modules/mongoose/node_modules/async/README.md create mode 100644 node_modules/mongoose/node_modules/async/apply.js create mode 100644 node_modules/mongoose/node_modules/async/applyEach.js create mode 100644 node_modules/mongoose/node_modules/async/applyEachSeries.js create mode 100644 node_modules/mongoose/node_modules/async/asyncify.js create mode 100644 node_modules/mongoose/node_modules/async/auto.js create mode 100644 node_modules/mongoose/node_modules/async/autoInject.js create mode 100644 node_modules/mongoose/node_modules/async/bower.json create mode 100644 node_modules/mongoose/node_modules/async/cargo.js create mode 100644 node_modules/mongoose/node_modules/async/compose.js create mode 100644 node_modules/mongoose/node_modules/async/concat.js create mode 100644 node_modules/mongoose/node_modules/async/concatSeries.js create mode 100644 node_modules/mongoose/node_modules/async/constant.js create mode 100644 node_modules/mongoose/node_modules/async/detect.js create mode 100644 node_modules/mongoose/node_modules/async/detectLimit.js create mode 100644 node_modules/mongoose/node_modules/async/detectSeries.js create mode 100644 node_modules/mongoose/node_modules/async/dir.js create mode 100644 node_modules/mongoose/node_modules/async/dist/async.js create mode 100644 node_modules/mongoose/node_modules/async/dist/async.min.js create mode 100644 node_modules/mongoose/node_modules/async/doDuring.js create mode 100644 node_modules/mongoose/node_modules/async/doUntil.js create mode 100644 node_modules/mongoose/node_modules/async/doWhilst.js create mode 100644 node_modules/mongoose/node_modules/async/during.js create mode 100644 node_modules/mongoose/node_modules/async/each.js create mode 100644 node_modules/mongoose/node_modules/async/eachLimit.js create mode 100644 node_modules/mongoose/node_modules/async/eachOf.js create mode 100644 node_modules/mongoose/node_modules/async/eachOfLimit.js create mode 100644 node_modules/mongoose/node_modules/async/eachOfSeries.js create mode 100644 node_modules/mongoose/node_modules/async/eachSeries.js create mode 100644 node_modules/mongoose/node_modules/async/ensureAsync.js create mode 100644 node_modules/mongoose/node_modules/async/every.js create mode 100644 node_modules/mongoose/node_modules/async/everyLimit.js create mode 100644 node_modules/mongoose/node_modules/async/everySeries.js create mode 100644 node_modules/mongoose/node_modules/async/filter.js create mode 100644 node_modules/mongoose/node_modules/async/filterLimit.js create mode 100644 node_modules/mongoose/node_modules/async/filterSeries.js create mode 100644 node_modules/mongoose/node_modules/async/forever.js create mode 100644 node_modules/mongoose/node_modules/async/index.js create mode 100644 node_modules/mongoose/node_modules/async/internal/DoublyLinkedList.js create mode 100644 node_modules/mongoose/node_modules/async/internal/applyEach.js create mode 100644 node_modules/mongoose/node_modules/async/internal/concat.js create mode 100644 node_modules/mongoose/node_modules/async/internal/consoleFunc.js create mode 100644 node_modules/mongoose/node_modules/async/internal/createTester.js create mode 100644 node_modules/mongoose/node_modules/async/internal/doLimit.js create mode 100644 node_modules/mongoose/node_modules/async/internal/doParallel.js create mode 100644 node_modules/mongoose/node_modules/async/internal/doParallelLimit.js create mode 100644 node_modules/mongoose/node_modules/async/internal/doSeries.js create mode 100644 node_modules/mongoose/node_modules/async/internal/eachOfLimit.js create mode 100644 node_modules/mongoose/node_modules/async/internal/filter.js create mode 100644 node_modules/mongoose/node_modules/async/internal/findGetResult.js create mode 100644 node_modules/mongoose/node_modules/async/internal/getIterator.js create mode 100644 node_modules/mongoose/node_modules/async/internal/initialParams.js create mode 100644 node_modules/mongoose/node_modules/async/internal/iterator.js create mode 100644 node_modules/mongoose/node_modules/async/internal/map.js create mode 100644 node_modules/mongoose/node_modules/async/internal/notId.js create mode 100644 node_modules/mongoose/node_modules/async/internal/once.js create mode 100644 node_modules/mongoose/node_modules/async/internal/onlyOnce.js create mode 100644 node_modules/mongoose/node_modules/async/internal/parallel.js create mode 100644 node_modules/mongoose/node_modules/async/internal/queue.js create mode 100644 node_modules/mongoose/node_modules/async/internal/reject.js create mode 100644 node_modules/mongoose/node_modules/async/internal/setImmediate.js create mode 100644 node_modules/mongoose/node_modules/async/internal/withoutIndex.js create mode 100644 node_modules/mongoose/node_modules/async/log.js create mode 100644 node_modules/mongoose/node_modules/async/map.js create mode 100644 node_modules/mongoose/node_modules/async/mapLimit.js create mode 100644 node_modules/mongoose/node_modules/async/mapSeries.js create mode 100644 node_modules/mongoose/node_modules/async/mapValues.js create mode 100644 node_modules/mongoose/node_modules/async/mapValuesLimit.js create mode 100644 node_modules/mongoose/node_modules/async/mapValuesSeries.js create mode 100644 node_modules/mongoose/node_modules/async/memoize.js create mode 100644 node_modules/mongoose/node_modules/async/nextTick.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/LICENSE create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/README.md create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_DataView.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_Hash.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_LazyWrapper.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_ListCache.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_LodashWrapper.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_Map.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_MapCache.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_Promise.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_Set.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_SetCache.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_Stack.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_Symbol.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_Uint8Array.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_WeakMap.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_addMapEntry.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_addSetEntry.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_apply.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayAggregator.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayEach.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayEachRight.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayEvery.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayFilter.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayIncludes.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayIncludesWith.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayLikeKeys.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayMap.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayPush.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayReduce.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayReduceRight.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_arraySample.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_arraySampleSize.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayShuffle.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_arraySome.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_asciiSize.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_asciiToArray.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_asciiWords.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_assignInDefaults.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_assignMergeValue.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_assignValue.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_assocIndexOf.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseAggregator.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseAssign.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseAssignValue.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseAt.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseClamp.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseClone.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseConforms.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseConformsTo.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseCreate.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseDelay.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseDifference.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseEach.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseEachRight.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseEvery.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseExtremum.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseFill.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseFilter.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseFindIndex.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseFindKey.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseFlatten.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseFor.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseForOwn.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseForOwnRight.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseForRight.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseFunctions.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseGet.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseGetAllKeys.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseGetTag.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseGt.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseHas.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseHasIn.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseInRange.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIndexOf.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIndexOfWith.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIntersection.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseInverter.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseInvoke.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIsArguments.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIsArrayBuffer.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIsDate.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIsEqual.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIsEqualDeep.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIsMap.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIsMatch.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIsNaN.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIsNative.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIsRegExp.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIsSet.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIsTypedArray.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIteratee.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseKeys.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseKeysIn.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseLodash.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseLt.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseMap.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseMatches.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseMatchesProperty.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseMean.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseMerge.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseMergeDeep.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseNth.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseOrderBy.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_basePick.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_basePickBy.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseProperty.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_basePropertyDeep.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_basePropertyOf.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_basePullAll.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_basePullAt.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseRandom.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseRange.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseReduce.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseRepeat.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseRest.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseSample.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseSampleSize.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseSet.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseSetData.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseSetToString.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseShuffle.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseSlice.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseSome.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseSortBy.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseSortedIndex.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseSortedIndexBy.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseSortedUniq.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseSum.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseTimes.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseToNumber.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseToPairs.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseToString.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseUnary.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseUniq.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseUnset.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseUpdate.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseValues.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseWhile.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseWrapperValue.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseXor.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_baseZipObject.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_cacheHas.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_castArrayLikeObject.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_castFunction.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_castPath.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_castRest.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_castSlice.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_charsEndIndex.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_charsStartIndex.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_cloneArrayBuffer.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_cloneBuffer.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_cloneDataView.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_cloneMap.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_cloneRegExp.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_cloneSet.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_cloneSymbol.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_cloneTypedArray.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_compareAscending.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_compareMultiple.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_composeArgs.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_composeArgsRight.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_copyArray.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_copyObject.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_copySymbols.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_coreJsData.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_countHolders.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_createAggregator.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_createAssigner.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_createBaseEach.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_createBaseFor.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_createBind.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_createCaseFirst.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_createCompounder.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_createCtor.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_createCurry.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_createFind.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_createFlow.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_createHybrid.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_createInverter.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_createMathOperation.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_createOver.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_createPadding.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_createPartial.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_createRange.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_createRecurry.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_createRelationalOperation.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_createRound.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_createSet.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_createToPairs.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_createWrap.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_deburrLetter.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_defineProperty.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_equalArrays.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_equalByTag.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_equalObjects.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_escapeHtmlChar.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_escapeStringChar.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_flatRest.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_freeGlobal.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_getAllKeys.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_getAllKeysIn.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_getData.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_getFuncName.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_getHolder.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_getMapData.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_getMatchData.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_getNative.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_getPrototype.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_getSymbols.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_getSymbolsIn.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_getTag.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_getValue.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_getView.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_getWrapDetails.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_hasPath.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_hasUnicode.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_hasUnicodeWord.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_hashClear.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_hashDelete.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_hashGet.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_hashHas.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_hashSet.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_initCloneArray.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_initCloneByTag.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_initCloneObject.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_insertWrapDetails.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_isFlattenable.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_isIndex.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_isIterateeCall.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_isKey.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_isKeyable.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_isLaziable.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_isMaskable.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_isMasked.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_isPrototype.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_isStrictComparable.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_iteratorToArray.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_lazyClone.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_lazyReverse.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_lazyValue.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_listCacheClear.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_listCacheDelete.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_listCacheGet.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_listCacheHas.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_listCacheSet.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_mapCacheClear.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_mapCacheDelete.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_mapCacheGet.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_mapCacheHas.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_mapCacheSet.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_mapToArray.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_matchesStrictComparable.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_memoizeCapped.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_mergeData.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_mergeDefaults.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_metaMap.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_nativeCreate.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_nativeKeys.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_nativeKeysIn.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_nodeUtil.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_overArg.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_overRest.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_parent.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_reEscape.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_reEvaluate.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_reInterpolate.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_realNames.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_reorder.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_replaceHolders.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_root.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_setCacheAdd.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_setCacheHas.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_setData.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_setToArray.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_setToPairs.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_setToString.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_setWrapToString.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_shortOut.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_shuffleSelf.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_stackClear.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_stackDelete.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_stackGet.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_stackHas.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_stackSet.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_strictIndexOf.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_strictLastIndexOf.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_stringSize.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_stringToArray.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_stringToPath.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_toKey.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_toSource.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_unescapeHtmlChar.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_unicodeSize.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_unicodeToArray.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_unicodeWords.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_updateWrapDetails.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/_wrapperClone.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/add.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/after.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/array.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/ary.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/assign.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/assignIn.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/assignInWith.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/assignWith.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/at.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/attempt.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/before.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/bind.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/bindAll.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/bindKey.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/camelCase.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/capitalize.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/castArray.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/ceil.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/chain.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/chunk.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/clamp.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/clone.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/cloneDeep.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/cloneDeepWith.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/cloneWith.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/collection.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/commit.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/compact.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/concat.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/cond.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/conforms.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/conformsTo.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/constant.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/core.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/core.min.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/countBy.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/create.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/curry.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/curryRight.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/date.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/debounce.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/deburr.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/defaultTo.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/defaults.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/defaultsDeep.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/defer.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/delay.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/difference.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/differenceBy.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/differenceWith.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/divide.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/drop.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/dropRight.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/dropRightWhile.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/dropWhile.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/each.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/eachRight.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/endsWith.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/entries.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/entriesIn.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/eq.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/escape.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/escapeRegExp.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/every.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/extend.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/extendWith.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fill.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/filter.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/find.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/findIndex.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/findKey.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/findLast.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/findLastIndex.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/findLastKey.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/first.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/flatMap.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/flatMapDeep.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/flatMapDepth.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/flatten.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/flattenDeep.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/flattenDepth.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/flip.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/floor.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/flow.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/flowRight.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/forEach.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/forEachRight.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/forIn.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/forInRight.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/forOwn.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/forOwnRight.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/F.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/T.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/__.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/_baseConvert.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/_convertBrowser.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/_falseOptions.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/_mapping.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/_util.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/add.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/after.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/all.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/allPass.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/always.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/any.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/anyPass.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/apply.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/array.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/ary.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/assign.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/assignAll.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/assignAllWith.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/assignIn.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/assignInAll.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/assignInAllWith.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/assignInWith.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/assignWith.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/assoc.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/assocPath.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/at.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/attempt.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/before.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/bind.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/bindAll.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/bindKey.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/camelCase.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/capitalize.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/castArray.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/ceil.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/chain.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/chunk.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/clamp.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/clone.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/cloneDeep.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/cloneDeepWith.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/cloneWith.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/collection.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/commit.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/compact.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/complement.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/compose.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/concat.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/cond.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/conforms.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/conformsTo.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/constant.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/contains.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/convert.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/countBy.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/create.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/curry.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/curryN.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/curryRight.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/curryRightN.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/date.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/debounce.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/deburr.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/defaultTo.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/defaults.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/defaultsAll.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/defaultsDeep.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/defaultsDeepAll.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/defer.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/delay.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/difference.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/differenceBy.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/differenceWith.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/dissoc.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/dissocPath.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/divide.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/drop.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/dropLast.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/dropLastWhile.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/dropRight.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/dropRightWhile.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/dropWhile.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/each.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/eachRight.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/endsWith.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/entries.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/entriesIn.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/eq.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/equals.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/escape.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/escapeRegExp.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/every.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/extend.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/extendAll.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/extendAllWith.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/extendWith.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/fill.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/filter.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/find.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/findFrom.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/findIndex.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/findIndexFrom.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/findKey.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/findLast.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/findLastFrom.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/findLastIndex.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/findLastIndexFrom.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/findLastKey.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/first.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/flatMap.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/flatMapDeep.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/flatMapDepth.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/flatten.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/flattenDeep.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/flattenDepth.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/flip.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/floor.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/flow.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/flowRight.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/forEach.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/forEachRight.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/forIn.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/forInRight.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/forOwn.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/forOwnRight.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/fromPairs.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/function.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/functions.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/functionsIn.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/get.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/getOr.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/groupBy.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/gt.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/gte.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/has.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/hasIn.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/head.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/identical.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/identity.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/inRange.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/includes.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/includesFrom.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/indexBy.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/indexOf.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/indexOfFrom.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/init.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/initial.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/intersection.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/intersectionBy.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/intersectionWith.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/invert.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/invertBy.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/invertObj.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/invoke.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/invokeArgs.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/invokeArgsMap.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/invokeMap.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isArguments.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isArray.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isArrayBuffer.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isArrayLike.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isArrayLikeObject.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isBoolean.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isBuffer.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isDate.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isElement.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isEmpty.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isEqual.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isEqualWith.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isError.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isFinite.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isFunction.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isInteger.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isLength.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isMap.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isMatch.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isMatchWith.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isNaN.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isNative.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isNil.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isNull.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isNumber.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isObject.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isObjectLike.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isPlainObject.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isRegExp.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isSafeInteger.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isSet.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isString.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isSymbol.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isTypedArray.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isUndefined.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isWeakMap.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isWeakSet.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/iteratee.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/join.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/juxt.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/kebabCase.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/keyBy.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/keys.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/keysIn.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/lang.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/last.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/lastIndexOf.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/lastIndexOfFrom.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/lowerCase.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/lowerFirst.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/lt.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/lte.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/map.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/mapKeys.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/mapValues.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/matches.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/matchesProperty.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/math.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/max.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/maxBy.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/mean.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/meanBy.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/memoize.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/merge.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/mergeAll.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/mergeAllWith.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/mergeWith.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/method.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/methodOf.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/min.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/minBy.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/mixin.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/multiply.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/nAry.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/negate.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/next.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/noop.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/now.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/nth.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/nthArg.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/number.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/object.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/omit.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/omitAll.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/omitBy.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/once.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/orderBy.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/over.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/overArgs.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/overEvery.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/overSome.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pad.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/padChars.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/padCharsEnd.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/padCharsStart.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/padEnd.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/padStart.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/parseInt.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/partial.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/partialRight.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/partition.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/path.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pathEq.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pathOr.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/paths.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pick.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pickAll.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pickBy.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pipe.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/placeholder.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/plant.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pluck.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/prop.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/propEq.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/propOr.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/property.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/propertyOf.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/props.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pull.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pullAll.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pullAllBy.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pullAllWith.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pullAt.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/random.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/range.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/rangeRight.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/rangeStep.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/rangeStepRight.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/rearg.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/reduce.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/reduceRight.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/reject.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/remove.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/repeat.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/replace.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/rest.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/restFrom.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/result.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/reverse.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/round.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sample.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sampleSize.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/seq.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/set.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/setWith.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/shuffle.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/size.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/slice.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/snakeCase.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/some.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sortBy.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sortedIndex.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sortedIndexBy.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sortedIndexOf.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sortedLastIndex.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sortedLastIndexBy.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sortedLastIndexOf.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sortedUniq.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sortedUniqBy.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/split.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/spread.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/spreadFrom.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/startCase.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/startsWith.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/string.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/stubArray.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/stubFalse.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/stubObject.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/stubString.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/stubTrue.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/subtract.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sum.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sumBy.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/symmetricDifference.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/symmetricDifferenceBy.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/symmetricDifferenceWith.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/tail.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/take.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/takeLast.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/takeLastWhile.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/takeRight.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/takeRightWhile.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/takeWhile.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/tap.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/template.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/templateSettings.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/throttle.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/thru.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/times.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toArray.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toFinite.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toInteger.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toIterator.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toJSON.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toLength.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toLower.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toNumber.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toPairs.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toPairsIn.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toPath.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toPlainObject.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toSafeInteger.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toString.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toUpper.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/transform.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/trim.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/trimChars.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/trimCharsEnd.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/trimCharsStart.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/trimEnd.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/trimStart.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/truncate.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/unapply.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/unary.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/unescape.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/union.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/unionBy.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/unionWith.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/uniq.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/uniqBy.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/uniqWith.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/uniqueId.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/unnest.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/unset.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/unzip.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/unzipWith.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/update.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/updateWith.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/upperCase.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/upperFirst.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/useWith.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/util.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/value.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/valueOf.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/values.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/valuesIn.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/where.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/whereEq.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/without.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/words.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/wrap.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/wrapperAt.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/wrapperChain.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/wrapperLodash.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/wrapperReverse.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/wrapperValue.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/xor.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/xorBy.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/xorWith.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/zip.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/zipAll.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/zipObj.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/zipObject.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/zipObjectDeep.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fp/zipWith.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/fromPairs.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/function.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/functions.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/functionsIn.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/get.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/groupBy.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/gt.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/gte.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/has.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/hasIn.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/head.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/identity.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/inRange.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/includes.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/index.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/indexOf.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/initial.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/intersection.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/intersectionBy.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/intersectionWith.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/invert.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/invertBy.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/invoke.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/invokeMap.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/isArguments.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/isArray.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/isArrayBuffer.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/isArrayLike.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/isArrayLikeObject.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/isBoolean.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/isBuffer.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/isDate.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/isElement.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/isEmpty.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/isEqual.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/isEqualWith.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/isError.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/isFinite.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/isFunction.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/isInteger.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/isLength.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/isMap.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/isMatch.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/isMatchWith.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/isNaN.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/isNative.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/isNil.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/isNull.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/isNumber.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/isObject.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/isObjectLike.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/isPlainObject.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/isRegExp.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/isSafeInteger.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/isSet.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/isString.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/isSymbol.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/isTypedArray.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/isUndefined.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/isWeakMap.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/isWeakSet.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/iteratee.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/join.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/kebabCase.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/keyBy.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/keys.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/keysIn.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/lang.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/last.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/lastIndexOf.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/lodash.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/lodash.min.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/lowerCase.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/lowerFirst.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/lt.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/lte.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/map.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/mapKeys.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/mapValues.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/matches.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/matchesProperty.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/math.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/max.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/maxBy.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/mean.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/meanBy.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/memoize.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/merge.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/mergeWith.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/method.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/methodOf.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/min.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/minBy.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/mixin.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/multiply.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/negate.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/next.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/noop.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/now.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/nth.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/nthArg.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/number.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/object.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/omit.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/omitBy.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/once.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/orderBy.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/over.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/overArgs.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/overEvery.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/overSome.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/package.json create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/pad.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/padEnd.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/padStart.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/parseInt.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/partial.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/partialRight.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/partition.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/pick.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/pickBy.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/plant.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/property.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/propertyOf.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/pull.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/pullAll.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/pullAllBy.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/pullAllWith.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/pullAt.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/random.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/range.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/rangeRight.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/rearg.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/reduce.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/reduceRight.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/reject.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/remove.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/repeat.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/replace.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/rest.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/result.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/reverse.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/round.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/sample.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/sampleSize.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/seq.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/set.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/setWith.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/shuffle.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/size.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/slice.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/snakeCase.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/some.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/sortBy.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/sortedIndex.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/sortedIndexBy.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/sortedIndexOf.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/sortedLastIndex.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/sortedLastIndexBy.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/sortedLastIndexOf.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/sortedUniq.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/sortedUniqBy.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/split.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/spread.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/startCase.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/startsWith.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/string.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/stubArray.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/stubFalse.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/stubObject.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/stubString.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/stubTrue.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/subtract.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/sum.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/sumBy.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/tail.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/take.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/takeRight.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/takeRightWhile.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/takeWhile.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/tap.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/template.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/templateSettings.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/throttle.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/thru.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/times.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/toArray.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/toFinite.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/toInteger.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/toIterator.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/toJSON.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/toLength.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/toLower.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/toNumber.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/toPairs.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/toPairsIn.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/toPath.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/toPlainObject.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/toSafeInteger.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/toString.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/toUpper.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/transform.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/trim.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/trimEnd.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/trimStart.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/truncate.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/unary.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/unescape.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/union.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/unionBy.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/unionWith.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/uniq.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/uniqBy.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/uniqWith.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/uniqueId.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/unset.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/unzip.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/unzipWith.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/update.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/updateWith.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/upperCase.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/upperFirst.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/util.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/value.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/valueOf.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/values.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/valuesIn.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/without.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/words.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/wrap.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/wrapperAt.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/wrapperChain.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/wrapperLodash.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/wrapperReverse.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/wrapperValue.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/xor.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/xorBy.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/xorWith.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/zip.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/zipObject.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/zipObjectDeep.js create mode 100644 node_modules/mongoose/node_modules/async/node_modules/lodash/zipWith.js create mode 100644 node_modules/mongoose/node_modules/async/package.json create mode 100644 node_modules/mongoose/node_modules/async/parallel.js create mode 100644 node_modules/mongoose/node_modules/async/parallelLimit.js create mode 100644 node_modules/mongoose/node_modules/async/priorityQueue.js create mode 100644 node_modules/mongoose/node_modules/async/queue.js create mode 100644 node_modules/mongoose/node_modules/async/race.js create mode 100644 node_modules/mongoose/node_modules/async/reduce.js create mode 100644 node_modules/mongoose/node_modules/async/reduceRight.js create mode 100644 node_modules/mongoose/node_modules/async/reflect.js create mode 100644 node_modules/mongoose/node_modules/async/reflectAll.js create mode 100644 node_modules/mongoose/node_modules/async/reject.js create mode 100644 node_modules/mongoose/node_modules/async/rejectLimit.js create mode 100644 node_modules/mongoose/node_modules/async/rejectSeries.js create mode 100644 node_modules/mongoose/node_modules/async/retry.js create mode 100644 node_modules/mongoose/node_modules/async/retryable.js create mode 100644 node_modules/mongoose/node_modules/async/seq.js create mode 100644 node_modules/mongoose/node_modules/async/series.js create mode 100644 node_modules/mongoose/node_modules/async/setImmediate.js create mode 100644 node_modules/mongoose/node_modules/async/some.js create mode 100644 node_modules/mongoose/node_modules/async/someLimit.js create mode 100644 node_modules/mongoose/node_modules/async/someSeries.js create mode 100644 node_modules/mongoose/node_modules/async/sortBy.js create mode 100644 node_modules/mongoose/node_modules/async/timeout.js create mode 100644 node_modules/mongoose/node_modules/async/times.js create mode 100644 node_modules/mongoose/node_modules/async/timesLimit.js create mode 100644 node_modules/mongoose/node_modules/async/timesSeries.js create mode 100644 node_modules/mongoose/node_modules/async/transform.js create mode 100644 node_modules/mongoose/node_modules/async/unmemoize.js create mode 100644 node_modules/mongoose/node_modules/async/until.js create mode 100644 node_modules/mongoose/node_modules/async/waterfall.js create mode 100644 node_modules/mongoose/node_modules/async/whilst.js create mode 100644 node_modules/mongoose/node_modules/bson/HISTORY.md create mode 100644 node_modules/mongoose/node_modules/bson/LICENSE.md create mode 100644 node_modules/mongoose/node_modules/bson/alternate_parsers/bson.js create mode 100644 node_modules/mongoose/node_modules/bson/alternate_parsers/faster_bson.js create mode 100644 node_modules/mongoose/node_modules/bson/bower.json create mode 100644 node_modules/mongoose/node_modules/bson/browser_build/bson.js create mode 100644 node_modules/mongoose/node_modules/bson/browser_build/package.json create mode 100644 node_modules/mongoose/node_modules/bson/deserializer_bak.js create mode 100644 node_modules/mongoose/node_modules/bson/lib/bson/binary.js create mode 100644 node_modules/mongoose/node_modules/bson/lib/bson/bson.js create mode 100644 node_modules/mongoose/node_modules/bson/lib/bson/code.js create mode 100644 node_modules/mongoose/node_modules/bson/lib/bson/db_ref.js create mode 100644 node_modules/mongoose/node_modules/bson/lib/bson/decimal128.js create mode 100644 node_modules/mongoose/node_modules/bson/lib/bson/double.js create mode 100644 node_modules/mongoose/node_modules/bson/lib/bson/float_parser.js create mode 100644 node_modules/mongoose/node_modules/bson/lib/bson/index.js create mode 100644 node_modules/mongoose/node_modules/bson/lib/bson/int_32.js create mode 100644 node_modules/mongoose/node_modules/bson/lib/bson/long.js create mode 100644 node_modules/mongoose/node_modules/bson/lib/bson/map.js create mode 100644 node_modules/mongoose/node_modules/bson/lib/bson/max_key.js create mode 100644 node_modules/mongoose/node_modules/bson/lib/bson/min_key.js create mode 100644 node_modules/mongoose/node_modules/bson/lib/bson/objectid.js create mode 100644 node_modules/mongoose/node_modules/bson/lib/bson/parser/calculate_size.js create mode 100644 node_modules/mongoose/node_modules/bson/lib/bson/parser/deserializer.js create mode 100644 node_modules/mongoose/node_modules/bson/lib/bson/parser/serializer.js create mode 100644 node_modules/mongoose/node_modules/bson/lib/bson/regexp.js create mode 100644 node_modules/mongoose/node_modules/bson/lib/bson/symbol.js create mode 100644 node_modules/mongoose/node_modules/bson/lib/bson/timestamp.js create mode 100644 node_modules/mongoose/node_modules/bson/package.json create mode 100644 node_modules/mongoose/node_modules/bson/tools/gleak.js create mode 100644 node_modules/mongoose/node_modules/hooks-fixed/.npmignore create mode 100644 node_modules/mongoose/node_modules/hooks-fixed/Makefile create mode 100644 node_modules/mongoose/node_modules/hooks-fixed/README.md create mode 100644 node_modules/mongoose/node_modules/hooks-fixed/hooks.alt.js create mode 100644 node_modules/mongoose/node_modules/hooks-fixed/hooks.js create mode 100644 node_modules/mongoose/node_modules/hooks-fixed/package.json create mode 100644 node_modules/mongoose/node_modules/hooks-fixed/test.js create mode 100644 node_modules/mongoose/node_modules/kareem/.npmignore create mode 100644 node_modules/mongoose/node_modules/kareem/.travis.yml create mode 100644 node_modules/mongoose/node_modules/kareem/LICENSE create mode 100644 node_modules/mongoose/node_modules/kareem/Makefile create mode 100644 node_modules/mongoose/node_modules/kareem/README.md create mode 100644 node_modules/mongoose/node_modules/kareem/docs.js create mode 100644 node_modules/mongoose/node_modules/kareem/gulpfile.js create mode 100644 node_modules/mongoose/node_modules/kareem/index.js create mode 100644 node_modules/mongoose/node_modules/kareem/package.json create mode 100644 node_modules/mongoose/node_modules/kareem/test/examples.test.js create mode 100644 node_modules/mongoose/node_modules/kareem/test/post.test.js create mode 100644 node_modules/mongoose/node_modules/kareem/test/pre.test.js create mode 100644 node_modules/mongoose/node_modules/kareem/test/wrap.test.js create mode 100644 node_modules/mongoose/node_modules/mongodb/.coveralls.yml create mode 100644 node_modules/mongoose/node_modules/mongodb/HISTORY.md create mode 100644 node_modules/mongoose/node_modules/mongodb/LICENSE create mode 100644 node_modules/mongoose/node_modules/mongodb/Makefile create mode 100644 node_modules/mongoose/node_modules/mongodb/boot_auth.js create mode 100644 node_modules/mongoose/node_modules/mongodb/conf.json create mode 100644 node_modules/mongoose/node_modules/mongodb/index.js create mode 100644 node_modules/mongoose/node_modules/mongodb/insert_bench.js create mode 100644 node_modules/mongoose/node_modules/mongodb/lib/admin.js create mode 100644 node_modules/mongoose/node_modules/mongodb/lib/aggregation_cursor.js create mode 100644 node_modules/mongoose/node_modules/mongodb/lib/apm.js create mode 100644 node_modules/mongoose/node_modules/mongodb/lib/bulk/common.js create mode 100644 node_modules/mongoose/node_modules/mongodb/lib/bulk/ordered.js create mode 100644 node_modules/mongoose/node_modules/mongodb/lib/bulk/unordered.js create mode 100644 node_modules/mongoose/node_modules/mongodb/lib/collection.js create mode 100644 node_modules/mongoose/node_modules/mongodb/lib/command_cursor.js create mode 100644 node_modules/mongoose/node_modules/mongodb/lib/cursor.js create mode 100644 node_modules/mongoose/node_modules/mongodb/lib/db.js create mode 100644 node_modules/mongoose/node_modules/mongodb/lib/gridfs-stream/download.js create mode 100644 node_modules/mongoose/node_modules/mongodb/lib/gridfs-stream/index.js create mode 100644 node_modules/mongoose/node_modules/mongodb/lib/gridfs-stream/upload.js create mode 100644 node_modules/mongoose/node_modules/mongodb/lib/gridfs/chunk.js create mode 100644 node_modules/mongoose/node_modules/mongodb/lib/gridfs/grid_store.js create mode 100644 node_modules/mongoose/node_modules/mongodb/lib/metadata.js create mode 100644 node_modules/mongoose/node_modules/mongodb/lib/mongo_client.js create mode 100644 node_modules/mongoose/node_modules/mongodb/lib/mongos.js create mode 100644 node_modules/mongoose/node_modules/mongodb/lib/read_preference.js create mode 100644 node_modules/mongoose/node_modules/mongodb/lib/replset.js create mode 100644 node_modules/mongoose/node_modules/mongodb/lib/server.js create mode 100644 node_modules/mongoose/node_modules/mongodb/lib/topology_base.js create mode 100644 node_modules/mongoose/node_modules/mongodb/lib/url_parser.js create mode 100644 node_modules/mongoose/node_modules/mongodb/lib/utils.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/es6-promise/CHANGELOG.md create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/es6-promise/LICENSE create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/es6-promise/README.md create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/es6-promise/dist/es6-promise.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/es6-promise/dist/es6-promise.min.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/es6-promise/lib/es6-promise.umd.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/es6-promise/lib/es6-promise/-internal.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/es6-promise/lib/es6-promise/asap.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/es6-promise/lib/es6-promise/enumerator.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/es6-promise/lib/es6-promise/polyfill.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/es6-promise/lib/es6-promise/promise.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/es6-promise/lib/es6-promise/promise/all.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/es6-promise/lib/es6-promise/promise/race.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/es6-promise/lib/es6-promise/promise/reject.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/es6-promise/lib/es6-promise/promise/resolve.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/es6-promise/lib/es6-promise/then.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/es6-promise/lib/es6-promise/utils.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/es6-promise/package.json create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/.coveralls.yml create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/HISTORY.md create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/LICENSE create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/Makefile create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/TESTING.md create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/conf.json create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/index.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/lib/auth/gssapi.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/lib/auth/mongocr.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/lib/auth/plain.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/lib/auth/scram.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/lib/auth/sspi.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/lib/auth/x509.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/lib/connection/command_result.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/lib/connection/commands.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/lib/connection/connection.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/lib/connection/logger.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/lib/connection/pool.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/lib/connection/utils.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/lib/cursor.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/lib/error.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/lib/tools/smoke_plugin.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/lib/topologies/mongos.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/lib/topologies/read_preference.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/lib/topologies/replset.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/lib/topologies/replset_state.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/lib/topologies/server.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/lib/topologies/shared.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/lib/wireprotocol/2_4_support.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/lib/wireprotocol/2_6_support.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/lib/wireprotocol/3_2_support.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/lib/wireprotocol/commands.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/lib/wireprotocol/shared.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/node_modules/require_optional/.npmignore create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/node_modules/require_optional/.travis.yml create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/node_modules/require_optional/LICENSE create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/node_modules/require_optional/README.md create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/node_modules/require_optional/index.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/node_modules/require_optional/node_modules/.bin/semver create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/node_modules/require_optional/node_modules/.bin/semver.cmd create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/node_modules/require_optional/node_modules/resolve-from/index.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/node_modules/require_optional/node_modules/resolve-from/license create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/node_modules/require_optional/node_modules/resolve-from/package.json create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/node_modules/require_optional/node_modules/resolve-from/readme.md create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/node_modules/require_optional/node_modules/semver/LICENSE create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/node_modules/require_optional/node_modules/semver/README.md create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/node_modules/require_optional/node_modules/semver/bin/semver create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/node_modules/require_optional/node_modules/semver/package.json create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/node_modules/require_optional/node_modules/semver/range.bnf create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/node_modules/require_optional/node_modules/semver/semver.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/node_modules/require_optional/package.json create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/node_modules/require_optional/test/require_optional_tests.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/package.json create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/simple_2_document_limit_toArray.dat create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/test.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/mongodb-core/test1.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/.npmignore create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/.travis.yml create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/LICENSE create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/README.md create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/doc/stream.md create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/doc/wg-meetings/2015-01-30.md create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/duplex.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/lib/_stream_duplex.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/lib/_stream_passthrough.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/lib/_stream_readable.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/lib/_stream_transform.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/lib/_stream_writable.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/lib/internal/streams/BufferList.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/node_modules/buffer-shims/index.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/node_modules/buffer-shims/license.md create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/node_modules/buffer-shims/package.json create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/node_modules/buffer-shims/readme.md create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/node_modules/core-util-is/LICENSE create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/node_modules/core-util-is/README.md create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/node_modules/core-util-is/float.patch create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/node_modules/core-util-is/lib/util.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/node_modules/core-util-is/package.json create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/node_modules/core-util-is/test.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/node_modules/inherits/LICENSE create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/node_modules/inherits/README.md create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/node_modules/inherits/inherits.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/node_modules/inherits/inherits_browser.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/node_modules/inherits/package.json create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/node_modules/isarray/.npmignore create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/node_modules/isarray/.travis.yml create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/node_modules/isarray/Makefile create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/node_modules/isarray/README.md create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/node_modules/isarray/component.json create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/node_modules/isarray/index.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/node_modules/isarray/package.json create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/node_modules/isarray/test.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/node_modules/process-nextick-args/.travis.yml create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/node_modules/process-nextick-args/index.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/node_modules/process-nextick-args/license.md create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/node_modules/process-nextick-args/package.json create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/node_modules/process-nextick-args/readme.md create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/node_modules/process-nextick-args/test.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/node_modules/string_decoder/.npmignore create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/node_modules/string_decoder/LICENSE create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/node_modules/string_decoder/README.md create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/node_modules/string_decoder/index.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/node_modules/string_decoder/package.json create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/node_modules/util-deprecate/History.md create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/node_modules/util-deprecate/LICENSE create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/node_modules/util-deprecate/README.md create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/node_modules/util-deprecate/browser.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/node_modules/util-deprecate/node.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/node_modules/util-deprecate/package.json create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/package.json create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/passthrough.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/readable.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/transform.js create mode 100644 node_modules/mongoose/node_modules/mongodb/node_modules/readable-stream/writable.js create mode 100644 node_modules/mongoose/node_modules/mongodb/package.json create mode 100644 node_modules/mongoose/node_modules/mpath/.npmignore create mode 100644 node_modules/mongoose/node_modules/mpath/.travis.yml create mode 100644 node_modules/mongoose/node_modules/mpath/History.md create mode 100644 node_modules/mongoose/node_modules/mpath/LICENSE create mode 100644 node_modules/mongoose/node_modules/mpath/Makefile create mode 100644 node_modules/mongoose/node_modules/mpath/README.md create mode 100644 node_modules/mongoose/node_modules/mpath/bench.js create mode 100644 node_modules/mongoose/node_modules/mpath/bench.log create mode 100644 node_modules/mongoose/node_modules/mpath/bench.out create mode 100644 node_modules/mongoose/node_modules/mpath/component.json create mode 100644 node_modules/mongoose/node_modules/mpath/index.js create mode 100644 node_modules/mongoose/node_modules/mpath/lib/index.js create mode 100644 node_modules/mongoose/node_modules/mpath/package.json create mode 100644 node_modules/mongoose/node_modules/mpath/test/index.js create mode 100644 node_modules/mongoose/node_modules/mpromise/.npmignore create mode 100644 node_modules/mongoose/node_modules/mpromise/.travis.yml create mode 100644 node_modules/mongoose/node_modules/mpromise/History.md create mode 100644 node_modules/mongoose/node_modules/mpromise/LICENSE create mode 100644 node_modules/mongoose/node_modules/mpromise/README.md create mode 100644 node_modules/mongoose/node_modules/mpromise/lib/promise.js create mode 100644 node_modules/mongoose/node_modules/mpromise/package.json create mode 100644 node_modules/mongoose/node_modules/mpromise/test/promise.domain.test.js create mode 100644 node_modules/mongoose/node_modules/mpromise/test/promise.test.js create mode 100644 node_modules/mongoose/node_modules/mpromise/test/promises.Aplus.js create mode 100644 node_modules/mongoose/node_modules/mquery/.npmignore create mode 100644 node_modules/mongoose/node_modules/mquery/.travis.yml create mode 100644 node_modules/mongoose/node_modules/mquery/History.md create mode 100644 node_modules/mongoose/node_modules/mquery/LICENSE create mode 100644 node_modules/mongoose/node_modules/mquery/Makefile create mode 100644 node_modules/mongoose/node_modules/mquery/README.md create mode 100644 node_modules/mongoose/node_modules/mquery/lib/collection/collection.js create mode 100644 node_modules/mongoose/node_modules/mquery/lib/collection/index.js create mode 100644 node_modules/mongoose/node_modules/mquery/lib/collection/node.js create mode 100644 node_modules/mongoose/node_modules/mquery/lib/env.js create mode 100644 node_modules/mongoose/node_modules/mquery/lib/mquery.js create mode 100644 node_modules/mongoose/node_modules/mquery/lib/permissions.js create mode 100644 node_modules/mongoose/node_modules/mquery/lib/utils.js create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/bluebird/LICENSE create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/bluebird/README.md create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/bluebird/changelog.md create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/bluebird/js/browser/bluebird.js create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/bluebird/js/browser/bluebird.min.js create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/bluebird/js/main/any.js create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/bluebird/js/main/assert.js create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/bluebird/js/main/async.js create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/bluebird/js/main/bind.js create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/bluebird/js/main/bluebird.js create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/bluebird/js/main/call_get.js create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/bluebird/js/main/cancel.js create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/bluebird/js/main/captured_trace.js create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/bluebird/js/main/catch_filter.js create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/bluebird/js/main/context.js create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/bluebird/js/main/debuggability.js create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/bluebird/js/main/direct_resolve.js create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/bluebird/js/main/each.js create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/bluebird/js/main/errors.js create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/bluebird/js/main/es5.js create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/bluebird/js/main/filter.js create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/bluebird/js/main/finally.js create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/bluebird/js/main/generators.js create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/bluebird/js/main/join.js create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/bluebird/js/main/map.js create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/bluebird/js/main/method.js create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/bluebird/js/main/nodeify.js create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/bluebird/js/main/progress.js create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/bluebird/js/main/promise.js create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/bluebird/js/main/promise_array.js create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/bluebird/js/main/promise_resolver.js create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/bluebird/js/main/promisify.js create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/bluebird/js/main/props.js create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/bluebird/js/main/queue.js create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/bluebird/js/main/race.js create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/bluebird/js/main/reduce.js create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/bluebird/js/main/schedule.js create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/bluebird/js/main/settle.js create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/bluebird/js/main/some.js create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/bluebird/js/main/synchronous_inspection.js create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/bluebird/js/main/thenables.js create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/bluebird/js/main/timers.js create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/bluebird/js/main/using.js create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/bluebird/js/main/util.js create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/bluebird/package.json create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/debug/.jshintrc create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/debug/.npmignore create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/debug/History.md create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/debug/Makefile create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/debug/Readme.md create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/debug/bower.json create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/debug/browser.js create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/debug/component.json create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/debug/debug.js create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/debug/node.js create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/debug/package.json create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/sliced/.npmignore create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/sliced/.travis.yml create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/sliced/History.md create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/sliced/LICENSE create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/sliced/Makefile create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/sliced/README.md create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/sliced/bench.js create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/sliced/component.json create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/sliced/index.js create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/sliced/lib/sliced.js create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/sliced/package.json create mode 100644 node_modules/mongoose/node_modules/mquery/node_modules/sliced/test/index.js create mode 100644 node_modules/mongoose/node_modules/mquery/package.json create mode 100644 node_modules/mongoose/node_modules/mquery/test/collection/browser.js create mode 100644 node_modules/mongoose/node_modules/mquery/test/collection/mongo.js create mode 100644 node_modules/mongoose/node_modules/mquery/test/collection/node.js create mode 100644 node_modules/mongoose/node_modules/mquery/test/env.js create mode 100644 node_modules/mongoose/node_modules/mquery/test/index.js create mode 100644 node_modules/mongoose/node_modules/mquery/test/utils.test.js create mode 100644 node_modules/mongoose/node_modules/ms/.npmignore create mode 100644 node_modules/mongoose/node_modules/ms/History.md create mode 100644 node_modules/mongoose/node_modules/ms/LICENSE create mode 100644 node_modules/mongoose/node_modules/ms/README.md create mode 100644 node_modules/mongoose/node_modules/ms/index.js create mode 100644 node_modules/mongoose/node_modules/ms/package.json create mode 100644 node_modules/mongoose/node_modules/muri/.npmignore create mode 100644 node_modules/mongoose/node_modules/muri/.travis.yml create mode 100644 node_modules/mongoose/node_modules/muri/History.md create mode 100644 node_modules/mongoose/node_modules/muri/LICENSE create mode 100644 node_modules/mongoose/node_modules/muri/Makefile create mode 100644 node_modules/mongoose/node_modules/muri/README.md create mode 100644 node_modules/mongoose/node_modules/muri/index.js create mode 100644 node_modules/mongoose/node_modules/muri/lib/index.js create mode 100644 node_modules/mongoose/node_modules/muri/package.json create mode 100644 node_modules/mongoose/node_modules/muri/test/index.js create mode 100644 node_modules/mongoose/node_modules/regexp-clone/.npmignore create mode 100644 node_modules/mongoose/node_modules/regexp-clone/.travis.yml create mode 100644 node_modules/mongoose/node_modules/regexp-clone/History.md create mode 100644 node_modules/mongoose/node_modules/regexp-clone/LICENSE create mode 100644 node_modules/mongoose/node_modules/regexp-clone/Makefile create mode 100644 node_modules/mongoose/node_modules/regexp-clone/README.md create mode 100644 node_modules/mongoose/node_modules/regexp-clone/index.js create mode 100644 node_modules/mongoose/node_modules/regexp-clone/package.json create mode 100644 node_modules/mongoose/node_modules/regexp-clone/test/index.js create mode 100644 node_modules/mongoose/node_modules/sliced/History.md create mode 100644 node_modules/mongoose/node_modules/sliced/LICENSE create mode 100644 node_modules/mongoose/node_modules/sliced/README.md create mode 100644 node_modules/mongoose/node_modules/sliced/index.js create mode 100644 node_modules/mongoose/node_modules/sliced/package.json create mode 100644 node_modules/mongoose/package.json create mode 100644 node_modules/mongoose/release-items.md create mode 100644 node_modules/mongoose/static.js create mode 100644 node_modules/mongoose/website.js create mode 100644 node_modules/morgan/HISTORY.md create mode 100644 node_modules/morgan/LICENSE create mode 100644 node_modules/morgan/README.md create mode 100644 node_modules/morgan/index.js create mode 100644 node_modules/morgan/node_modules/basic-auth/HISTORY.md create mode 100644 node_modules/morgan/node_modules/basic-auth/LICENSE create mode 100644 node_modules/morgan/node_modules/basic-auth/README.md create mode 100644 node_modules/morgan/node_modules/basic-auth/index.js create mode 100644 node_modules/morgan/node_modules/basic-auth/package.json create mode 100644 node_modules/morgan/node_modules/debug/.jshintrc create mode 100644 node_modules/morgan/node_modules/debug/.npmignore create mode 100644 node_modules/morgan/node_modules/debug/History.md create mode 100644 node_modules/morgan/node_modules/debug/Makefile create mode 100644 node_modules/morgan/node_modules/debug/Readme.md create mode 100644 node_modules/morgan/node_modules/debug/bower.json create mode 100644 node_modules/morgan/node_modules/debug/browser.js create mode 100644 node_modules/morgan/node_modules/debug/component.json create mode 100644 node_modules/morgan/node_modules/debug/debug.js create mode 100644 node_modules/morgan/node_modules/debug/node.js create mode 100644 node_modules/morgan/node_modules/debug/node_modules/ms/.npmignore create mode 100644 node_modules/morgan/node_modules/debug/node_modules/ms/History.md create mode 100644 node_modules/morgan/node_modules/debug/node_modules/ms/LICENSE create mode 100644 node_modules/morgan/node_modules/debug/node_modules/ms/README.md create mode 100644 node_modules/morgan/node_modules/debug/node_modules/ms/index.js create mode 100644 node_modules/morgan/node_modules/debug/node_modules/ms/package.json create mode 100644 node_modules/morgan/node_modules/debug/package.json create mode 100644 node_modules/morgan/node_modules/depd/History.md create mode 100644 node_modules/morgan/node_modules/depd/LICENSE create mode 100644 node_modules/morgan/node_modules/depd/Readme.md create mode 100644 node_modules/morgan/node_modules/depd/index.js create mode 100644 node_modules/morgan/node_modules/depd/lib/browser/index.js create mode 100644 node_modules/morgan/node_modules/depd/lib/compat/buffer-concat.js create mode 100644 node_modules/morgan/node_modules/depd/lib/compat/callsite-tostring.js create mode 100644 node_modules/morgan/node_modules/depd/lib/compat/event-listener-count.js create mode 100644 node_modules/morgan/node_modules/depd/lib/compat/index.js create mode 100644 node_modules/morgan/node_modules/depd/package.json create mode 100644 node_modules/morgan/node_modules/on-finished/HISTORY.md create mode 100644 node_modules/morgan/node_modules/on-finished/LICENSE create mode 100644 node_modules/morgan/node_modules/on-finished/README.md create mode 100644 node_modules/morgan/node_modules/on-finished/index.js create mode 100644 node_modules/morgan/node_modules/on-finished/node_modules/ee-first/LICENSE create mode 100644 node_modules/morgan/node_modules/on-finished/node_modules/ee-first/README.md create mode 100644 node_modules/morgan/node_modules/on-finished/node_modules/ee-first/index.js create mode 100644 node_modules/morgan/node_modules/on-finished/node_modules/ee-first/package.json create mode 100644 node_modules/morgan/node_modules/on-finished/package.json create mode 100644 node_modules/morgan/node_modules/on-headers/HISTORY.md create mode 100644 node_modules/morgan/node_modules/on-headers/LICENSE create mode 100644 node_modules/morgan/node_modules/on-headers/README.md create mode 100644 node_modules/morgan/node_modules/on-headers/index.js create mode 100644 node_modules/morgan/node_modules/on-headers/package.json create mode 100644 node_modules/morgan/package.json create mode 100644 node_modules/oauth/.npmignore create mode 100644 node_modules/oauth/LICENSE create mode 100644 node_modules/oauth/Makefile create mode 100644 node_modules/oauth/Readme.md create mode 100644 node_modules/oauth/examples/express-gdata/server.js create mode 100644 node_modules/oauth/examples/express-gdata/views/google_calendars.ejs create mode 100644 node_modules/oauth/examples/express-gdata/views/google_contacts.ejs create mode 100644 node_modules/oauth/examples/express-gdata/views/layout.ejs create mode 100644 node_modules/oauth/examples/github-example.js create mode 100644 node_modules/oauth/examples/term.ie.oauth-HMAC-SHA1.js create mode 100644 node_modules/oauth/index.js create mode 100644 node_modules/oauth/lib/_utils.js create mode 100644 node_modules/oauth/lib/oauth.js create mode 100644 node_modules/oauth/lib/oauth2.js create mode 100644 node_modules/oauth/lib/sha1.js create mode 100644 node_modules/oauth/package.json create mode 100644 node_modules/oauth/tests/oauth2tests.js create mode 100644 node_modules/oauth/tests/oauthtests.js create mode 100644 node_modules/oauth/tests/sha1tests.js create mode 100644 node_modules/oauth/tests/shared.js create mode 100644 node_modules/qs/.eslintignore create mode 100644 node_modules/qs/.eslintrc create mode 100644 node_modules/qs/CHANGELOG.md create mode 100644 node_modules/qs/CONTRIBUTING.md create mode 100644 node_modules/qs/LICENSE create mode 100644 node_modules/qs/README.md create mode 100644 node_modules/qs/dist/qs.js create mode 100644 node_modules/qs/lib/index.js create mode 100644 node_modules/qs/lib/parse.js create mode 100644 node_modules/qs/lib/stringify.js create mode 100644 node_modules/qs/lib/utils.js create mode 100644 node_modules/qs/package.json create mode 100644 node_modules/qs/test/index.js create mode 100644 node_modules/qs/test/parse.js create mode 100644 node_modules/qs/test/stringify.js create mode 100644 node_modules/qs/test/utils.js create mode 100644 node_modules/toastr/.gitattributes create mode 100644 node_modules/toastr/.jscsrc create mode 100644 node_modules/toastr/.jshintrc create mode 100644 node_modules/toastr/.npmignore create mode 100644 node_modules/toastr/.travis.yml create mode 100644 node_modules/toastr/CHANGELOG.md create mode 100644 node_modules/toastr/README.md create mode 100644 node_modules/toastr/build/toastr.css create mode 100644 node_modules/toastr/build/toastr.js.map create mode 100644 node_modules/toastr/build/toastr.min.css create mode 100644 node_modules/toastr/build/toastr.min.js create mode 100644 node_modules/toastr/demo.html create mode 100644 node_modules/toastr/gulpfile.js create mode 100644 node_modules/toastr/karma.conf.js create mode 100644 node_modules/toastr/nuget/content/content/toastr.css create mode 100644 node_modules/toastr/nuget/content/content/toastr.less create mode 100644 node_modules/toastr/nuget/content/content/toastr.min.css create mode 100644 node_modules/toastr/nuget/content/content/toastr.scss create mode 100644 node_modules/toastr/nuget/content/scripts/toastr.js create mode 100644 node_modules/toastr/nuget/content/scripts/toastr.min.js create mode 100644 node_modules/toastr/nuget/content/scripts/toastr.min.js.map create mode 100644 node_modules/toastr/nuget/toastr.1.0.0.nupkg create mode 100644 node_modules/toastr/nuget/toastr.1.0.0.nuspec create mode 100644 node_modules/toastr/nuget/toastr.1.0.1.nupkg create mode 100644 node_modules/toastr/nuget/toastr.1.0.1.nuspec create mode 100644 node_modules/toastr/nuget/toastr.1.0.2.nupkg create mode 100644 node_modules/toastr/nuget/toastr.1.0.2.nuspec create mode 100644 node_modules/toastr/nuget/toastr.1.0.3.nupkg create mode 100644 node_modules/toastr/nuget/toastr.1.0.3.nuspec create mode 100644 node_modules/toastr/nuget/toastr.1.1.0.nupkg create mode 100644 node_modules/toastr/nuget/toastr.1.1.0.nuspec create mode 100644 node_modules/toastr/nuget/toastr.1.1.1.nupkg create mode 100644 node_modules/toastr/nuget/toastr.1.1.1.nuspec create mode 100644 node_modules/toastr/nuget/toastr.1.1.2.nupkg create mode 100644 node_modules/toastr/nuget/toastr.1.1.2.nuspec create mode 100644 node_modules/toastr/nuget/toastr.1.1.3.nupkg create mode 100644 node_modules/toastr/nuget/toastr.1.1.4.1.nupkg create mode 100644 node_modules/toastr/nuget/toastr.1.1.4.1.nuspec create mode 100644 node_modules/toastr/nuget/toastr.1.1.4.2.nupkg create mode 100644 node_modules/toastr/nuget/toastr.1.1.4.2.nuspec create mode 100644 node_modules/toastr/nuget/toastr.1.1.4.nupkg create mode 100644 node_modules/toastr/nuget/toastr.1.1.4.nuspec create mode 100644 node_modules/toastr/nuget/toastr.1.1.5.nupkg create mode 100644 node_modules/toastr/nuget/toastr.1.1.5.nuspec create mode 100644 node_modules/toastr/nuget/toastr.1.2.0.nupkg create mode 100644 node_modules/toastr/nuget/toastr.1.2.0.nuspec create mode 100644 node_modules/toastr/nuget/toastr.1.2.1.nupkg create mode 100644 node_modules/toastr/nuget/toastr.1.2.1.nuspec create mode 100644 node_modules/toastr/nuget/toastr.1.2.2.nupkg create mode 100644 node_modules/toastr/nuget/toastr.1.2.2.nuspec create mode 100644 node_modules/toastr/nuget/toastr.1.3.0.nupkg create mode 100644 node_modules/toastr/nuget/toastr.1.3.0.nuspec create mode 100644 node_modules/toastr/nuget/toastr.1.3.1.nupkg create mode 100644 node_modules/toastr/nuget/toastr.1.3.1.nuspec create mode 100644 node_modules/toastr/nuget/toastr.2.0.0-rc1.nupkg create mode 100644 node_modules/toastr/nuget/toastr.2.0.0-rc1.nuspec create mode 100644 node_modules/toastr/nuget/toastr.2.0.1.nupkg create mode 100644 node_modules/toastr/nuget/toastr.2.0.1.nuspec create mode 100644 node_modules/toastr/nuget/toastr.2.0.2.nupkg create mode 100644 node_modules/toastr/nuget/toastr.2.0.2.nuspec create mode 100644 node_modules/toastr/nuget/toastr.2.0.3.nupkg create mode 100644 node_modules/toastr/nuget/toastr.2.0.3.nuspec create mode 100644 node_modules/toastr/package.json create mode 100644 node_modules/toastr/package/.gitattributes create mode 100644 node_modules/toastr/package/.jscsrc create mode 100644 node_modules/toastr/package/.jshintrc create mode 100644 node_modules/toastr/package/.npmignore create mode 100644 node_modules/toastr/package/.travis.yml create mode 100644 node_modules/toastr/package/CHANGELOG.md create mode 100644 node_modules/toastr/package/build/toastr.js.map create mode 100644 node_modules/toastr/package/build/toastr.min.css create mode 100644 node_modules/toastr/package/build/toastr.min.js create mode 100644 node_modules/toastr/package/demo.html create mode 100644 node_modules/toastr/package/gulpfile.js create mode 100644 node_modules/toastr/package/karma.conf.js create mode 100644 node_modules/toastr/package/nuget/content/content/toastr.css create mode 100644 node_modules/toastr/package/nuget/content/content/toastr.less create mode 100644 node_modules/toastr/package/nuget/content/content/toastr.min.css create mode 100644 node_modules/toastr/package/nuget/content/content/toastr.scss create mode 100644 node_modules/toastr/package/nuget/content/scripts/toastr.js create mode 100644 node_modules/toastr/package/nuget/content/scripts/toastr.min.js create mode 100644 node_modules/toastr/package/nuget/content/scripts/toastr.min.js.map create mode 100644 node_modules/toastr/package/nuget/toastr.1.0.0.nupkg create mode 100644 node_modules/toastr/package/nuget/toastr.1.0.0.nuspec create mode 100644 node_modules/toastr/package/nuget/toastr.1.0.1.nupkg create mode 100644 node_modules/toastr/package/nuget/toastr.1.0.1.nuspec create mode 100644 node_modules/toastr/package/nuget/toastr.1.0.2.nupkg create mode 100644 node_modules/toastr/package/nuget/toastr.1.0.2.nuspec create mode 100644 node_modules/toastr/package/nuget/toastr.1.0.3.nupkg create mode 100644 node_modules/toastr/package/nuget/toastr.1.0.3.nuspec create mode 100644 node_modules/toastr/package/nuget/toastr.1.1.0.nupkg create mode 100644 node_modules/toastr/package/nuget/toastr.1.1.0.nuspec create mode 100644 node_modules/toastr/package/nuget/toastr.1.1.1.nupkg create mode 100644 node_modules/toastr/package/nuget/toastr.1.1.1.nuspec create mode 100644 node_modules/toastr/package/nuget/toastr.1.1.2.nupkg create mode 100644 node_modules/toastr/package/nuget/toastr.1.1.2.nuspec create mode 100644 node_modules/toastr/package/nuget/toastr.1.1.3.nupkg create mode 100644 node_modules/toastr/package/nuget/toastr.1.1.4.1.nupkg create mode 100644 node_modules/toastr/package/nuget/toastr.1.1.4.1.nuspec create mode 100644 node_modules/toastr/package/nuget/toastr.1.1.4.2.nupkg create mode 100644 node_modules/toastr/package/nuget/toastr.1.1.4.2.nuspec create mode 100644 node_modules/toastr/package/nuget/toastr.1.1.4.nupkg create mode 100644 node_modules/toastr/package/nuget/toastr.1.1.4.nuspec create mode 100644 node_modules/toastr/package/nuget/toastr.1.1.5.nupkg create mode 100644 node_modules/toastr/package/nuget/toastr.1.1.5.nuspec create mode 100644 node_modules/toastr/package/nuget/toastr.1.2.0.nupkg create mode 100644 node_modules/toastr/package/nuget/toastr.1.2.0.nuspec create mode 100644 node_modules/toastr/package/nuget/toastr.1.2.1.nupkg create mode 100644 node_modules/toastr/package/nuget/toastr.1.2.1.nuspec create mode 100644 node_modules/toastr/package/nuget/toastr.1.2.2.nupkg create mode 100644 node_modules/toastr/package/nuget/toastr.1.2.2.nuspec create mode 100644 node_modules/toastr/package/nuget/toastr.1.3.0.nupkg create mode 100644 node_modules/toastr/package/nuget/toastr.1.3.0.nuspec create mode 100644 node_modules/toastr/package/nuget/toastr.1.3.1.nupkg create mode 100644 node_modules/toastr/package/nuget/toastr.1.3.1.nuspec create mode 100644 node_modules/toastr/package/nuget/toastr.2.0.0-rc1.nupkg create mode 100644 node_modules/toastr/package/nuget/toastr.2.0.0-rc1.nuspec create mode 100644 node_modules/toastr/package/nuget/toastr.2.0.1.nupkg create mode 100644 node_modules/toastr/package/nuget/toastr.2.0.1.nuspec create mode 100644 node_modules/toastr/package/nuget/toastr.2.0.2.nupkg create mode 100644 node_modules/toastr/package/nuget/toastr.2.0.2.nuspec create mode 100644 node_modules/toastr/package/nuget/toastr.2.0.3.nupkg create mode 100644 node_modules/toastr/package/nuget/toastr.2.0.3.nuspec create mode 100644 node_modules/toastr/package/package.json create mode 100644 node_modules/toastr/package/package/.gitattributes create mode 100644 node_modules/toastr/package/package/.jscsrc create mode 100644 node_modules/toastr/package/package/.jshintrc create mode 100644 node_modules/toastr/package/package/.npmignore create mode 100644 node_modules/toastr/package/package/.travis.yml create mode 100644 node_modules/toastr/package/package/CHANGELOG.md create mode 100644 node_modules/toastr/package/package/build/toastr.js.map create mode 100644 node_modules/toastr/package/package/build/toastr.min.css create mode 100644 node_modules/toastr/package/package/build/toastr.min.js create mode 100644 node_modules/toastr/package/package/demo.html create mode 100644 node_modules/toastr/package/package/gulpfile.js create mode 100644 node_modules/toastr/package/package/karma.conf.js create mode 100644 node_modules/toastr/package/package/nuget/content/content/toastr.css create mode 100644 node_modules/toastr/package/package/nuget/content/content/toastr.less create mode 100644 node_modules/toastr/package/package/nuget/content/content/toastr.min.css create mode 100644 node_modules/toastr/package/package/nuget/content/content/toastr.scss create mode 100644 node_modules/toastr/package/package/nuget/content/scripts/toastr.js create mode 100644 node_modules/toastr/package/package/nuget/content/scripts/toastr.min.js create mode 100644 node_modules/toastr/package/package/nuget/content/scripts/toastr.min.js.map create mode 100644 node_modules/toastr/package/package/nuget/toastr.1.0.0.nupkg create mode 100644 node_modules/toastr/package/package/nuget/toastr.1.0.0.nuspec create mode 100644 node_modules/toastr/package/package/nuget/toastr.1.0.1.nupkg create mode 100644 node_modules/toastr/package/package/nuget/toastr.1.0.1.nuspec create mode 100644 node_modules/toastr/package/package/nuget/toastr.1.0.2.nupkg create mode 100644 node_modules/toastr/package/package/nuget/toastr.1.0.2.nuspec create mode 100644 node_modules/toastr/package/package/nuget/toastr.1.0.3.nupkg create mode 100644 node_modules/toastr/package/package/nuget/toastr.1.0.3.nuspec create mode 100644 node_modules/toastr/package/package/nuget/toastr.1.1.0.nupkg create mode 100644 node_modules/toastr/package/package/nuget/toastr.1.1.0.nuspec create mode 100644 node_modules/toastr/package/package/nuget/toastr.1.1.1.nupkg create mode 100644 node_modules/toastr/package/package/nuget/toastr.1.1.1.nuspec create mode 100644 node_modules/toastr/package/package/nuget/toastr.1.1.2.nupkg create mode 100644 node_modules/toastr/package/package/nuget/toastr.1.1.2.nuspec create mode 100644 node_modules/toastr/package/package/nuget/toastr.1.1.3.nupkg create mode 100644 node_modules/toastr/package/package/nuget/toastr.1.1.4.1.nupkg create mode 100644 node_modules/toastr/package/package/nuget/toastr.1.1.4.1.nuspec create mode 100644 node_modules/toastr/package/package/nuget/toastr.1.1.4.2.nupkg create mode 100644 node_modules/toastr/package/package/nuget/toastr.1.1.4.2.nuspec create mode 100644 node_modules/toastr/package/package/nuget/toastr.1.1.4.nupkg create mode 100644 node_modules/toastr/package/package/nuget/toastr.1.1.4.nuspec create mode 100644 node_modules/toastr/package/package/nuget/toastr.1.1.5.nupkg create mode 100644 node_modules/toastr/package/package/nuget/toastr.1.1.5.nuspec create mode 100644 node_modules/toastr/package/package/nuget/toastr.1.2.0.nupkg create mode 100644 node_modules/toastr/package/package/nuget/toastr.1.2.0.nuspec create mode 100644 node_modules/toastr/package/package/nuget/toastr.1.2.1.nupkg create mode 100644 node_modules/toastr/package/package/nuget/toastr.1.2.1.nuspec create mode 100644 node_modules/toastr/package/package/nuget/toastr.1.2.2.nupkg create mode 100644 node_modules/toastr/package/package/nuget/toastr.1.2.2.nuspec create mode 100644 node_modules/toastr/package/package/nuget/toastr.1.3.0.nupkg create mode 100644 node_modules/toastr/package/package/nuget/toastr.1.3.0.nuspec create mode 100644 node_modules/toastr/package/package/nuget/toastr.1.3.1.nupkg create mode 100644 node_modules/toastr/package/package/nuget/toastr.1.3.1.nuspec create mode 100644 node_modules/toastr/package/package/nuget/toastr.2.0.0-rc1.nupkg create mode 100644 node_modules/toastr/package/package/nuget/toastr.2.0.0-rc1.nuspec create mode 100644 node_modules/toastr/package/package/nuget/toastr.2.0.1.nupkg create mode 100644 node_modules/toastr/package/package/nuget/toastr.2.0.1.nuspec create mode 100644 node_modules/toastr/package/package/nuget/toastr.2.0.2.nupkg create mode 100644 node_modules/toastr/package/package/nuget/toastr.2.0.2.nuspec create mode 100644 node_modules/toastr/package/package/nuget/toastr.2.0.3.nupkg create mode 100644 node_modules/toastr/package/package/nuget/toastr.2.0.3.nuspec create mode 100644 node_modules/toastr/package/package/package.json create mode 100644 node_modules/toastr/package/package/readme.md create mode 100644 node_modules/toastr/package/package/release checklist.md create mode 100644 node_modules/toastr/package/package/tests/qunit/qunit.css create mode 100644 node_modules/toastr/package/package/tests/qunit/qunit.js create mode 100644 node_modules/toastr/package/package/tests/toastr-tests.html create mode 100644 node_modules/toastr/package/package/tests/unit/qunit-helper.js create mode 100644 node_modules/toastr/package/package/tests/unit/toastr-tests.js create mode 100644 node_modules/toastr/package/package/tests/unit/x.js create mode 100644 node_modules/toastr/package/package/toastr-2.1.2.tgz create mode 100644 node_modules/toastr/package/package/toastr-icon.png create mode 100644 node_modules/toastr/package/package/toastr.css create mode 100644 node_modules/toastr/package/package/toastr.js create mode 100644 node_modules/toastr/package/package/toastr.less create mode 100644 node_modules/toastr/package/package/toastr.scss create mode 100644 node_modules/toastr/package/readme.md create mode 100644 node_modules/toastr/package/release checklist.md create mode 100644 node_modules/toastr/package/tests/qunit/qunit.css create mode 100644 node_modules/toastr/package/tests/qunit/qunit.js create mode 100644 node_modules/toastr/package/tests/toastr-tests.html create mode 100644 node_modules/toastr/package/tests/unit/qunit-helper.js create mode 100644 node_modules/toastr/package/tests/unit/toastr-tests.js create mode 100644 node_modules/toastr/package/tests/unit/x.js create mode 100644 node_modules/toastr/package/toastr-2.1.2.tgz create mode 100644 node_modules/toastr/package/toastr-icon.png create mode 100644 node_modules/toastr/package/toastr.css create mode 100644 node_modules/toastr/package/toastr.js create mode 100644 node_modules/toastr/package/toastr.less create mode 100644 node_modules/toastr/package/toastr.scss create mode 100644 node_modules/toastr/release checklist.md create mode 100644 node_modules/toastr/tests/qunit/qunit.css create mode 100644 node_modules/toastr/tests/qunit/qunit.js create mode 100644 node_modules/toastr/tests/toastr-tests.html create mode 100644 node_modules/toastr/tests/unit/qunit-helper.js create mode 100644 node_modules/toastr/tests/unit/toastr-tests.js create mode 100644 node_modules/toastr/tests/unit/x.js create mode 100644 node_modules/toastr/toastr-icon.png create mode 100644 node_modules/toastr/toastr.js create mode 100644 node_modules/toastr/toastr.less create mode 100644 node_modules/toastr/toastr.scss create mode 100644 package.json create mode 100644 server.js diff --git a/node_modules/bcrypt-nodejs/.gitattributes b/node_modules/bcrypt-nodejs/.gitattributes new file mode 100644 index 0000000..412eeda --- /dev/null +++ b/node_modules/bcrypt-nodejs/.gitattributes @@ -0,0 +1,22 @@ +# Auto detect text files and perform LF normalization +* text=auto + +# Custom for Visual Studio +*.cs diff=csharp +*.sln merge=union +*.csproj merge=union +*.vbproj merge=union +*.fsproj merge=union +*.dbproj merge=union + +# Standard to msysgit +*.doc diff=astextplain +*.DOC diff=astextplain +*.docx diff=astextplain +*.DOCX diff=astextplain +*.dot diff=astextplain +*.DOT diff=astextplain +*.pdf diff=astextplain +*.PDF diff=astextplain +*.rtf diff=astextplain +*.RTF diff=astextplain diff --git a/node_modules/bcrypt-nodejs/.npmignore b/node_modules/bcrypt-nodejs/.npmignore new file mode 100644 index 0000000..5ebd21a --- /dev/null +++ b/node_modules/bcrypt-nodejs/.npmignore @@ -0,0 +1,163 @@ +################# +## Eclipse +################# + +*.pydevproject +.project +.metadata +bin/ +tmp/ +*.tmp +*.bak +*.swp +*~.nib +local.properties +.classpath +.settings/ +.loadpath + +# External tool builders +.externalToolBuilders/ + +# Locally stored "Eclipse launch configurations" +*.launch + +# CDT-specific +.cproject + +# PDT-specific +.buildpath + + +################# +## Visual Studio +################# + +## Ignore Visual Studio temporary files, build results, and +## files generated by popular Visual Studio add-ons. + +# User-specific files +*.suo +*.user +*.sln.docstates + +# Build results +[Dd]ebug/ +[Rr]elease/ +*_i.c +*_p.c +*.ilk +*.meta +*.obj +*.pch +*.pdb +*.pgc +*.pgd +*.rsp +*.sbr +*.tlb +*.tli +*.tlh +*.tmp +*.vspscc +.builds +*.dotCover + +## TODO: If you have NuGet Package Restore enabled, uncomment this +#packages/ + +# Visual C++ cache files +ipch/ +*.aps +*.ncb +*.opensdf +*.sdf + +# Visual Studio profiler +*.psess +*.vsp + +# ReSharper is a .NET coding add-in +_ReSharper* + +# Installshield output folder +[Ee]xpress + +# DocProject is a documentation generator add-in +DocProject/buildhelp/ +DocProject/Help/*.HxT +DocProject/Help/*.HxC +DocProject/Help/*.hhc +DocProject/Help/*.hhk +DocProject/Help/*.hhp +DocProject/Help/Html2 +DocProject/Help/html + +# Click-Once directory +publish + +# Others +[Bb]in +[Oo]bj +sql +TestResults +*.Cache +ClientBin +stylecop.* +~$* +*.dbmdl +Generated_Code #added for RIA/Silverlight projects + +# Backup & report files from converting an old project file to a newer +# Visual Studio version. Backup files are not needed, because we have git ;-) +_UpgradeReport_Files/ +Backup*/ +UpgradeLog*.XML + + + +############ +## Windows +############ + +# Windows image file caches +Thumbs.db + +# Folder config file +Desktop.ini + + +############# +## Python +############# + +*.py[co] + +# Packages +*.egg +*.egg-info +dist +build +eggs +parts +bin +var +sdist +develop-eggs +.installed.cfg + +# Installer logs +pip-log.txt + +# Unit test / coverage reports +.coverage +.tox + +#Translations +*.mo + +#Mr Developer +.mr.developer.cfg + +# Mac crap +.DS_Store diff --git a/node_modules/bcrypt-nodejs/LICENSE b/node_modules/bcrypt-nodejs/LICENSE new file mode 100644 index 0000000..0a33601 --- /dev/null +++ b/node_modules/bcrypt-nodejs/LICENSE @@ -0,0 +1,25 @@ +Copyright (c) 2012 Nevins Bartolomeo +Copyright (c) 2012 Shane Girish +All rights reserved. + +Redistribution and use in source and binary forms, with or without +modification, are permitted provided that the following conditions +are met: +1. Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. +2. Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. +3. The name of the author may not be used to endorse or promote products + derived from this software without specific prior written permission. + +THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR +IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES +OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. +IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, +INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT +NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, +DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY +THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT +(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF +THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. \ No newline at end of file diff --git a/node_modules/bcrypt-nodejs/README.md b/node_modules/bcrypt-nodejs/README.md new file mode 100644 index 0000000..d73a1c4 --- /dev/null +++ b/node_modules/bcrypt-nodejs/README.md @@ -0,0 +1,90 @@ +bcrypt-nodejs +=========================================== + +Warning : A change was made in v0.0.3 to allow encoding of UTF-8 encoded strings. This causes strings encoded in v0.0.2 or earlier to not work in v0.0.3 anymore. + +Native JS implementation of BCrypt for Node. +Has the same functionality as [node.bcrypt.js] expect for a few tiny differences. +Mainly, it doesn't let you set the seed length for creating the random byte array. + +I created this version due to a small [problem](https://github.com/ncb000gt/node.bcrypt.js/issues/102) I faced with [node.bcrypt.js]. +Basically, to deploy one of my apps which uses [node.bcrypt.js] on a winx64 platform, I have to force the user to download about 1.6gb of sdks, buildtools and other requirements of which some fail to install ! Microsoft :( + +This code is based on [javascript-bcrypt] and uses [crypto] (http://nodejs.org/api/crypto.html) to create random byte arrays. + +Basic usage: +----------- +Synchronous +``` +var hash = bcrypt.hashSync("bacon"); + +bcrypt.compareSync("bacon", hash); // true +bcrypt.compareSync("veggies", hash); // false +``` + +Asynchronous +``` +bcrypt.hash("bacon", null, null, function(err, hash) { + // Store hash in your password DB. +}); + +// Load hash from your password DB. +bcrypt.compare("bacon", hash, function(err, res) { + // res == true +}); +bcrypt.compare("veggies", hash, function(err, res) { + // res = false +}); +``` + +In the above examples, the salt is automatically generated and attached to the hash. +Though you can use your custom salt and there is no need for salts to be persisted as it will always be included in the final hash result and can be retrieved. + +API +------------------------- +* `genSaltSync(rounds)` + * `rounds` - [OPTIONAL] - the number of rounds to process the data for. (default - 10) +* `genSalt(rounds, callback)` + * `rounds` - [OPTIONAL] - the number of rounds to process the data for. (default - 10) + * `callback` - [REQUIRED] - a callback to be fired once the salt has been generated. + * `error` - First parameter to the callback detailing any errors. + * `result` - Second parameter to the callback providing the generated salt. +* `hashSync(data, salt)` + * `data` - [REQUIRED] - the data to be encrypted. + * `salt` - [REQUIRED] - the salt to be used in encryption. +* `hash(data, salt, progress, cb)` + * `data` - [REQUIRED] - the data to be encrypted. + * `salt` - [REQUIRED] - the salt to be used to hash the password. + * `progress` - a callback to be called during the hash calculation to signify progress + * `callback` - [REQUIRED] - a callback to be fired once the data has been encrypted. + * `error` - First parameter to the callback detailing any errors. + * `result` - Second parameter to the callback providing the encrypted form. +* `compareSync(data, encrypted)` + * `data` - [REQUIRED] - data to compare. + * `encrypted` - [REQUIRED] - data to be compared to. +* `compare(data, encrypted, cb)` + * `data` - [REQUIRED] - data to compare. + * `encrypted` - [REQUIRED] - data to be compared to. + * `callback` - [REQUIRED] - a callback to be fired once the data has been compared. + * `error` - First parameter to the callback detailing any errors. + * `result` - Second parameter to the callback providing whether the data and encrypted forms match [true | false]. +* `getRounds(encrypted)` - return the number of rounds used to encrypt a given hash + * `encrypted` - [REQUIRED] - hash from which the number of rounds used should be extracted. + +Contributors +============ + +* [Alex Murray][alexmurray] +* [Nicolas Pelletier][NicolasPelletier] +* [Josh Rogers][geekymole] + +Credits +------------------------- +I heavily reused code from [javascript-bcrypt]. Though "Clipperz Javascript Crypto Library" was removed and its functionality replaced with "crypto". + +[node.bcrypt.js]:https://github.com/ncb000gt/node.bcrypt.js.git +[javascript-bcrypt]:http://code.google.com/p/javascript-bcrypt/ + +[alexmurray]:https://github.com/alexmurray +[NicolasPelletier]:https://github.com/NicolasPelletier +[geekymole]:https://github.com/geekymole \ No newline at end of file diff --git a/node_modules/bcrypt-nodejs/bCrypt.js b/node_modules/bcrypt-nodejs/bCrypt.js new file mode 100644 index 0000000..fcb2132 --- /dev/null +++ b/node_modules/bcrypt-nodejs/bCrypt.js @@ -0,0 +1,707 @@ +var crypto = require("crypto"); + +var BCRYPT_SALT_LEN = 16; + +var GENSALT_DEFAULT_LOG2_ROUNDS = 10; +var BLOWFISH_NUM_ROUNDS = 16; + +var MAX_EXECUTION_TIME = 100; +var P_orig = [0x243f6a88, 0x85a308d3, 0x13198a2e, 0x03707344, 0xa4093822, + 0x299f31d0, 0x082efa98, 0xec4e6c89, 0x452821e6, 0x38d01377, + 0xbe5466cf, 0x34e90c6c, 0xc0ac29b7, 0xc97c50dd, 0x3f84d5b5, + 0xb5470917, 0x9216d5d9, 0x8979fb1b]; +var S_orig = [0xd1310ba6, 0x98dfb5ac, 0x2ffd72db, 0xd01adfb7, 0xb8e1afed, + 0x6a267e96, 0xba7c9045, 0xf12c7f99, 0x24a19947, 0xb3916cf7, + 0x0801f2e2, 0x858efc16, 0x636920d8, 0x71574e69, 0xa458fea3, + 0xf4933d7e, 0x0d95748f, 0x728eb658, 0x718bcd58, 0x82154aee, + 0x7b54a41d, 0xc25a59b5, 0x9c30d539, 0x2af26013, 0xc5d1b023, + 0x286085f0, 0xca417918, 0xb8db38ef, 0x8e79dcb0, 0x603a180e, + 0x6c9e0e8b, 0xb01e8a3e, 0xd71577c1, 0xbd314b27, 0x78af2fda, + 0x55605c60, 0xe65525f3, 0xaa55ab94, 0x57489862, 0x63e81440, + 0x55ca396a, 0x2aab10b6, 0xb4cc5c34, 0x1141e8ce, 0xa15486af, + 0x7c72e993, 0xb3ee1411, 0x636fbc2a, 0x2ba9c55d, 0x741831f6, + 0xce5c3e16, 0x9b87931e, 0xafd6ba33, 0x6c24cf5c, 0x7a325381, + 0x28958677, 0x3b8f4898, 0x6b4bb9af, 0xc4bfe81b, 0x66282193, + 0x61d809cc, 0xfb21a991, 0x487cac60, 0x5dec8032, 0xef845d5d, + 0xe98575b1, 0xdc262302, 0xeb651b88, 0x23893e81, 0xd396acc5, + 0x0f6d6ff3, 0x83f44239, 0x2e0b4482, 0xa4842004, 0x69c8f04a, + 0x9e1f9b5e, 0x21c66842, 0xf6e96c9a, 0x670c9c61, 0xabd388f0, + 0x6a51a0d2, 0xd8542f68, 0x960fa728, 0xab5133a3, 0x6eef0b6c, + 0x137a3be4, 0xba3bf050, 0x7efb2a98, 0xa1f1651d, 0x39af0176, + 0x66ca593e, 0x82430e88, 0x8cee8619, 0x456f9fb4, 0x7d84a5c3, + 0x3b8b5ebe, 0xe06f75d8, 0x85c12073, 0x401a449f, 0x56c16aa6, + 0x4ed3aa62, 0x363f7706, 0x1bfedf72, 0x429b023d, 0x37d0d724, + 0xd00a1248, 0xdb0fead3, 0x49f1c09b, 0x075372c9, 0x80991b7b, + 0x25d479d8, 0xf6e8def7, 0xe3fe501a, 0xb6794c3b, 0x976ce0bd, + 0x04c006ba, 0xc1a94fb6, 0x409f60c4, 0x5e5c9ec2, 0x196a2463, + 0x68fb6faf, 0x3e6c53b5, 0x1339b2eb, 0x3b52ec6f, 0x6dfc511f, + 0x9b30952c, 0xcc814544, 0xaf5ebd09, 0xbee3d004, 0xde334afd, + 0x660f2807, 0x192e4bb3, 0xc0cba857, 0x45c8740f, 0xd20b5f39, + 0xb9d3fbdb, 0x5579c0bd, 0x1a60320a, 0xd6a100c6, 0x402c7279, + 0x679f25fe, 0xfb1fa3cc, 0x8ea5e9f8, 0xdb3222f8, 0x3c7516df, + 0xfd616b15, 0x2f501ec8, 0xad0552ab, 0x323db5fa, 0xfd238760, + 0x53317b48, 0x3e00df82, 0x9e5c57bb, 0xca6f8ca0, 0x1a87562e, + 0xdf1769db, 0xd542a8f6, 0x287effc3, 0xac6732c6, 0x8c4f5573, + 0x695b27b0, 0xbbca58c8, 0xe1ffa35d, 0xb8f011a0, 0x10fa3d98, + 0xfd2183b8, 0x4afcb56c, 0x2dd1d35b, 0x9a53e479, 0xb6f84565, + 0xd28e49bc, 0x4bfb9790, 0xe1ddf2da, 0xa4cb7e33, 0x62fb1341, + 0xcee4c6e8, 0xef20cada, 0x36774c01, 0xd07e9efe, 0x2bf11fb4, + 0x95dbda4d, 0xae909198, 0xeaad8e71, 0x6b93d5a0, 0xd08ed1d0, + 0xafc725e0, 0x8e3c5b2f, 0x8e7594b7, 0x8ff6e2fb, 0xf2122b64, + 0x8888b812, 0x900df01c, 0x4fad5ea0, 0x688fc31c, 0xd1cff191, + 0xb3a8c1ad, 0x2f2f2218, 0xbe0e1777, 0xea752dfe, 0x8b021fa1, + 0xe5a0cc0f, 0xb56f74e8, 0x18acf3d6, 0xce89e299, 0xb4a84fe0, + 0xfd13e0b7, 0x7cc43b81, 0xd2ada8d9, 0x165fa266, 0x80957705, + 0x93cc7314, 0x211a1477, 0xe6ad2065, 0x77b5fa86, 0xc75442f5, + 0xfb9d35cf, 0xebcdaf0c, 0x7b3e89a0, 0xd6411bd3, 0xae1e7e49, + 0x00250e2d, 0x2071b35e, 0x226800bb, 0x57b8e0af, 0x2464369b, + 0xf009b91e, 0x5563911d, 0x59dfa6aa, 0x78c14389, 0xd95a537f, + 0x207d5ba2, 0x02e5b9c5, 0x83260376, 0x6295cfa9, 0x11c81968, + 0x4e734a41, 0xb3472dca, 0x7b14a94a, 0x1b510052, 0x9a532915, + 0xd60f573f, 0xbc9bc6e4, 0x2b60a476, 0x81e67400, 0x08ba6fb5, + 0x571be91f, 0xf296ec6b, 0x2a0dd915, 0xb6636521, 0xe7b9f9b6, + 0xff34052e, 0xc5855664, 0x53b02d5d, 0xa99f8fa1, 0x08ba4799, + 0x6e85076a, 0x4b7a70e9, 0xb5b32944, 0xdb75092e, 0xc4192623, + 0xad6ea6b0, 0x49a7df7d, 0x9cee60b8, 0x8fedb266, 0xecaa8c71, + 0x699a17ff, 0x5664526c, 0xc2b19ee1, 0x193602a5, 0x75094c29, + 0xa0591340, 0xe4183a3e, 0x3f54989a, 0x5b429d65, 0x6b8fe4d6, + 0x99f73fd6, 0xa1d29c07, 0xefe830f5, 0x4d2d38e6, 0xf0255dc1, + 0x4cdd2086, 0x8470eb26, 0x6382e9c6, 0x021ecc5e, 0x09686b3f, + 0x3ebaefc9, 0x3c971814, 0x6b6a70a1, 0x687f3584, 0x52a0e286, + 0xb79c5305, 0xaa500737, 0x3e07841c, 0x7fdeae5c, 0x8e7d44ec, + 0x5716f2b8, 0xb03ada37, 0xf0500c0d, 0xf01c1f04, 0x0200b3ff, + 0xae0cf51a, 0x3cb574b2, 0x25837a58, 0xdc0921bd, 0xd19113f9, + 0x7ca92ff6, 0x94324773, 0x22f54701, 0x3ae5e581, 0x37c2dadc, + 0xc8b57634, 0x9af3dda7, 0xa9446146, 0x0fd0030e, 0xecc8c73e, + 0xa4751e41, 0xe238cd99, 0x3bea0e2f, 0x3280bba1, 0x183eb331, + 0x4e548b38, 0x4f6db908, 0x6f420d03, 0xf60a04bf, 0x2cb81290, + 0x24977c79, 0x5679b072, 0xbcaf89af, 0xde9a771f, 0xd9930810, + 0xb38bae12, 0xdccf3f2e, 0x5512721f, 0x2e6b7124, 0x501adde6, + 0x9f84cd87, 0x7a584718, 0x7408da17, 0xbc9f9abc, 0xe94b7d8c, + 0xec7aec3a, 0xdb851dfa, 0x63094366, 0xc464c3d2, 0xef1c1847, + 0x3215d908, 0xdd433b37, 0x24c2ba16, 0x12a14d43, 0x2a65c451, + 0x50940002, 0x133ae4dd, 0x71dff89e, 0x10314e55, 0x81ac77d6, + 0x5f11199b, 0x043556f1, 0xd7a3c76b, 0x3c11183b, 0x5924a509, + 0xf28fe6ed, 0x97f1fbfa, 0x9ebabf2c, 0x1e153c6e, 0x86e34570, + 0xeae96fb1, 0x860e5e0a, 0x5a3e2ab3, 0x771fe71c, 0x4e3d06fa, + 0x2965dcb9, 0x99e71d0f, 0x803e89d6, 0x5266c825, 0x2e4cc978, + 0x9c10b36a, 0xc6150eba, 0x94e2ea78, 0xa5fc3c53, 0x1e0a2df4, + 0xf2f74ea7, 0x361d2b3d, 0x1939260f, 0x19c27960, 0x5223a708, + 0xf71312b6, 0xebadfe6e, 0xeac31f66, 0xe3bc4595, 0xa67bc883, + 0xb17f37d1, 0x018cff28, 0xc332ddef, 0xbe6c5aa5, 0x65582185, + 0x68ab9802, 0xeecea50f, 0xdb2f953b, 0x2aef7dad, 0x5b6e2f84, + 0x1521b628, 0x29076170, 0xecdd4775, 0x619f1510, 0x13cca830, + 0xeb61bd96, 0x0334fe1e, 0xaa0363cf, 0xb5735c90, 0x4c70a239, + 0xd59e9e0b, 0xcbaade14, 0xeecc86bc, 0x60622ca7, 0x9cab5cab, + 0xb2f3846e, 0x648b1eaf, 0x19bdf0ca, 0xa02369b9, 0x655abb50, + 0x40685a32, 0x3c2ab4b3, 0x319ee9d5, 0xc021b8f7, 0x9b540b19, + 0x875fa099, 0x95f7997e, 0x623d7da8, 0xf837889a, 0x97e32d77, + 0x11ed935f, 0x16681281, 0x0e358829, 0xc7e61fd6, 0x96dedfa1, + 0x7858ba99, 0x57f584a5, 0x1b227263, 0x9b83c3ff, 0x1ac24696, + 0xcdb30aeb, 0x532e3054, 0x8fd948e4, 0x6dbc3128, 0x58ebf2ef, + 0x34c6ffea, 0xfe28ed61, 0xee7c3c73, 0x5d4a14d9, 0xe864b7e3, + 0x42105d14, 0x203e13e0, 0x45eee2b6, 0xa3aaabea, 0xdb6c4f15, + 0xfacb4fd0, 0xc742f442, 0xef6abbb5, 0x654f3b1d, 0x41cd2105, + 0xd81e799e, 0x86854dc7, 0xe44b476a, 0x3d816250, 0xcf62a1f2, + 0x5b8d2646, 0xfc8883a0, 0xc1c7b6a3, 0x7f1524c3, 0x69cb7492, + 0x47848a0b, 0x5692b285, 0x095bbf00, 0xad19489d, 0x1462b174, + 0x23820e00, 0x58428d2a, 0x0c55f5ea, 0x1dadf43e, 0x233f7061, + 0x3372f092, 0x8d937e41, 0xd65fecf1, 0x6c223bdb, 0x7cde3759, + 0xcbee7460, 0x4085f2a7, 0xce77326e, 0xa6078084, 0x19f8509e, + 0xe8efd855, 0x61d99735, 0xa969a7aa, 0xc50c06c2, 0x5a04abfc, + 0x800bcadc, 0x9e447a2e, 0xc3453484, 0xfdd56705, 0x0e1e9ec9, + 0xdb73dbd3, 0x105588cd, 0x675fda79, 0xe3674340, 0xc5c43465, + 0x713e38d8, 0x3d28f89e, 0xf16dff20, 0x153e21e7, 0x8fb03d4a, + 0xe6e39f2b, 0xdb83adf7, 0xe93d5a68, 0x948140f7, 0xf64c261c, + 0x94692934, 0x411520f7, 0x7602d4f7, 0xbcf46b2e, 0xd4a20068, + 0xd4082471, 0x3320f46a, 0x43b7d4b7, 0x500061af, 0x1e39f62e, + 0x97244546, 0x14214f74, 0xbf8b8840, 0x4d95fc1d, 0x96b591af, + 0x70f4ddd3, 0x66a02f45, 0xbfbc09ec, 0x03bd9785, 0x7fac6dd0, + 0x31cb8504, 0x96eb27b3, 0x55fd3941, 0xda2547e6, 0xabca0a9a, + 0x28507825, 0x530429f4, 0x0a2c86da, 0xe9b66dfb, 0x68dc1462, + 0xd7486900, 0x680ec0a4, 0x27a18dee, 0x4f3ffea2, 0xe887ad8c, + 0xb58ce006, 0x7af4d6b6, 0xaace1e7c, 0xd3375fec, 0xce78a399, + 0x406b2a42, 0x20fe9e35, 0xd9f385b9, 0xee39d7ab, 0x3b124e8b, + 0x1dc9faf7, 0x4b6d1856, 0x26a36631, 0xeae397b2, 0x3a6efa74, + 0xdd5b4332, 0x6841e7f7, 0xca7820fb, 0xfb0af54e, 0xd8feb397, + 0x454056ac, 0xba489527, 0x55533a3a, 0x20838d87, 0xfe6ba9b7, + 0xd096954b, 0x55a867bc, 0xa1159a58, 0xcca92963, 0x99e1db33, + 0xa62a4a56, 0x3f3125f9, 0x5ef47e1c, 0x9029317c, 0xfdf8e802, + 0x04272f70, 0x80bb155c, 0x05282ce3, 0x95c11548, 0xe4c66d22, + 0x48c1133f, 0xc70f86dc, 0x07f9c9ee, 0x41041f0f, 0x404779a4, + 0x5d886e17, 0x325f51eb, 0xd59bc0d1, 0xf2bcc18f, 0x41113564, + 0x257b7834, 0x602a9c60, 0xdff8e8a3, 0x1f636c1b, 0x0e12b4c2, + 0x02e1329e, 0xaf664fd1, 0xcad18115, 0x6b2395e0, 0x333e92e1, + 0x3b240b62, 0xeebeb922, 0x85b2a20e, 0xe6ba0d99, 0xde720c8c, + 0x2da2f728, 0xd0127845, 0x95b794fd, 0x647d0862, 0xe7ccf5f0, + 0x5449a36f, 0x877d48fa, 0xc39dfd27, 0xf33e8d1e, 0x0a476341, + 0x992eff74, 0x3a6f6eab, 0xf4f8fd37, 0xa812dc60, 0xa1ebddf8, + 0x991be14c, 0xdb6e6b0d, 0xc67b5510, 0x6d672c37, 0x2765d43b, + 0xdcd0e804, 0xf1290dc7, 0xcc00ffa3, 0xb5390f92, 0x690fed0b, + 0x667b9ffb, 0xcedb7d9c, 0xa091cf0b, 0xd9155ea3, 0xbb132f88, + 0x515bad24, 0x7b9479bf, 0x763bd6eb, 0x37392eb3, 0xcc115979, + 0x8026e297, 0xf42e312d, 0x6842ada7, 0xc66a2b3b, 0x12754ccc, + 0x782ef11c, 0x6a124237, 0xb79251e7, 0x06a1bbe6, 0x4bfb6350, + 0x1a6b1018, 0x11caedfa, 0x3d25bdd8, 0xe2e1c3c9, 0x44421659, + 0x0a121386, 0xd90cec6e, 0xd5abea2a, 0x64af674e, 0xda86a85f, + 0xbebfe988, 0x64e4c3fe, 0x9dbc8057, 0xf0f7c086, 0x60787bf8, + 0x6003604d, 0xd1fd8346, 0xf6381fb0, 0x7745ae04, 0xd736fccc, + 0x83426b33, 0xf01eab71, 0xb0804187, 0x3c005e5f, 0x77a057be, + 0xbde8ae24, 0x55464299, 0xbf582e61, 0x4e58f48f, 0xf2ddfda2, + 0xf474ef38, 0x8789bdc2, 0x5366f9c3, 0xc8b38e74, 0xb475f255, + 0x46fcd9b9, 0x7aeb2661, 0x8b1ddf84, 0x846a0e79, 0x915f95e2, + 0x466e598e, 0x20b45770, 0x8cd55591, 0xc902de4c, 0xb90bace1, + 0xbb8205d0, 0x11a86248, 0x7574a99e, 0xb77f19b6, 0xe0a9dc09, + 0x662d09a1, 0xc4324633, 0xe85a1f02, 0x09f0be8c, 0x4a99a025, + 0x1d6efe10, 0x1ab93d1d, 0x0ba5a4df, 0xa186f20f, 0x2868f169, + 0xdcb7da83, 0x573906fe, 0xa1e2ce9b, 0x4fcd7f52, 0x50115e01, + 0xa70683fa, 0xa002b5c4, 0x0de6d027, 0x9af88c27, 0x773f8641, + 0xc3604c06, 0x61a806b5, 0xf0177a28, 0xc0f586e0, 0x006058aa, + 0x30dc7d62, 0x11e69ed7, 0x2338ea63, 0x53c2dd94, 0xc2c21634, + 0xbbcbee56, 0x90bcb6de, 0xebfc7da1, 0xce591d76, 0x6f05e409, + 0x4b7c0188, 0x39720a3d, 0x7c927c24, 0x86e3725f, 0x724d9db9, + 0x1ac15bb4, 0xd39eb8fc, 0xed545578, 0x08fca5b5, 0xd83d7cd3, + 0x4dad0fc4, 0x1e50ef5e, 0xb161e6f8, 0xa28514d9, 0x6c51133c, + 0x6fd5c7e7, 0x56e14ec4, 0x362abfce, 0xddc6c837, 0xd79a3234, + 0x92638212, 0x670efa8e, 0x406000e0, 0x3a39ce37, 0xd3faf5cf, + 0xabc27737, 0x5ac52d1b, 0x5cb0679e, 0x4fa33742, 0xd3822740, + 0x99bc9bbe, 0xd5118e9d, 0xbf0f7315, 0xd62d1c7e, 0xc700c47b, + 0xb78c1b6b, 0x21a19045, 0xb26eb1be, 0x6a366eb4, 0x5748ab2f, + 0xbc946e79, 0xc6a376d2, 0x6549c2c8, 0x530ff8ee, 0x468dde7d, + 0xd5730a1d, 0x4cd04dc6, 0x2939bbdb, 0xa9ba4650, 0xac9526e8, + 0xbe5ee304, 0xa1fad5f0, 0x6a2d519a, 0x63ef8ce2, 0x9a86ee22, + 0xc089c2b8, 0x43242ef6, 0xa51e03aa, 0x9cf2d0a4, 0x83c061ba, + 0x9be96a4d, 0x8fe51550, 0xba645bd6, 0x2826a2f9, 0xa73a3ae1, + 0x4ba99586, 0xef5562e9, 0xc72fefd3, 0xf752f7da, 0x3f046f69, + 0x77fa0a59, 0x80e4a915, 0x87b08601, 0x9b09e6ad, 0x3b3ee593, + 0xe990fd5a, 0x9e34d797, 0x2cf0b7d9, 0x022b8b51, 0x96d5ac3a, + 0x017da67d, 0xd1cf3ed6, 0x7c7d2d28, 0x1f9f25cf, 0xadf2b89b, + 0x5ad6b472, 0x5a88f54c, 0xe029ac71, 0xe019a5e6, 0x47b0acfd, + 0xed93fa9b, 0xe8d3c48d, 0x283b57cc, 0xf8d56629, 0x79132e28, + 0x785f0191, 0xed756055, 0xf7960e44, 0xe3d35e8c, 0x15056dd4, + 0x88f46dba, 0x03a16125, 0x0564f0bd, 0xc3eb9e15, 0x3c9057a2, + 0x97271aec, 0xa93a072a, 0x1b3f6d9b, 0x1e6321f5, 0xf59c66fb, + 0x26dcf319, 0x7533d928, 0xb155fdf5, 0x03563482, 0x8aba3cbb, + 0x28517711, 0xc20ad9f8, 0xabcc5167, 0xccad925f, 0x4de81751, + 0x3830dc8e, 0x379d5862, 0x9320f991, 0xea7a90c2, 0xfb3e7bce, + 0x5121ce64, 0x774fbe32, 0xa8b6e37e, 0xc3293d46, 0x48de5369, + 0x6413e680, 0xa2ae0810, 0xdd6db224, 0x69852dfd, 0x09072166, + 0xb39a460a, 0x6445c0dd, 0x586cdecf, 0x1c20c8ae, 0x5bbef7dd, + 0x1b588d40, 0xccd2017f, 0x6bb4e3bb, 0xdda26a7e, 0x3a59ff45, + 0x3e350a44, 0xbcb4cdd5, 0x72eacea8, 0xfa6484bb, 0x8d6612ae, + 0xbf3c6f47, 0xd29be463, 0x542f5d9e, 0xaec2771b, 0xf64e6370, + 0x740e0d8d, 0xe75b1357, 0xf8721671, 0xaf537d5d, 0x4040cb08, + 0x4eb4e2cc, 0x34d2466a, 0x0115af84, 0xe1b00428, 0x95983a1d, + 0x06b89fb4, 0xce6ea048, 0x6f3f3b82, 0x3520ab82, 0x011a1d4b, + 0x277227f8, 0x611560b1, 0xe7933fdc, 0xbb3a792b, 0x344525bd, + 0xa08839e1, 0x51ce794b, 0x2f32c9b7, 0xa01fbac9, 0xe01cc87e, + 0xbcc7d1f6, 0xcf0111c3, 0xa1e8aac7, 0x1a908749, 0xd44fbd9a, + 0xd0dadecb, 0xd50ada38, 0x0339c32a, 0xc6913667, 0x8df9317c, + 0xe0b12b4f, 0xf79e59b7, 0x43f5bb3a, 0xf2d519ff, 0x27d9459c, + 0xbf97222c, 0x15e6fc2a, 0x0f91fc71, 0x9b941525, 0xfae59361, + 0xceb69ceb, 0xc2a86459, 0x12baa8d1, 0xb6c1075e, 0xe3056a0c, + 0x10d25065, 0xcb03a442, 0xe0ec6e0e, 0x1698db3b, 0x4c98a0be, + 0x3278e964, 0x9f1f9532, 0xe0d392df, 0xd3a0342b, 0x8971f21e, + 0x1b0a7441, 0x4ba3348c, 0xc5be7120, 0xc37632d8, 0xdf359f8d, + 0x9b992f2e, 0xe60b6f47, 0x0fe3f11d, 0xe54cda54, 0x1edad891, + 0xce6279cf, 0xcd3e7e6f, 0x1618b166, 0xfd2c1d05, 0x848fd2c5, + 0xf6fb2299, 0xf523f357, 0xa6327623, 0x93a83531, 0x56cccd02, + 0xacf08162, 0x5a75ebb5, 0x6e163697, 0x88d273cc, 0xde966292, + 0x81b949d0, 0x4c50901b, 0x71c65614, 0xe6c6c7bd, 0x327a140a, + 0x45e1d006, 0xc3f27b9a, 0xc9aa53fd, 0x62a80f00, 0xbb25bfe2, + 0x35bdd2f6, 0x71126905, 0xb2040222, 0xb6cbcf7c, 0xcd769c2b, + 0x53113ec0, 0x1640e3d3, 0x38abbd60, 0x2547adf0, 0xba38209c, + 0xf746ce76, 0x77afa1c5, 0x20756060, 0x85cbfe4e, 0x8ae88dd8, + 0x7aaaf9b0, 0x4cf9aa7e, 0x1948c25c, 0x02fb8a8c, 0x01c36ae4, + 0xd6ebe1f9, 0x90d4f869, 0xa65cdea0, 0x3f09252d, 0xc208e69f, + 0xb74e6132, 0xce77e25b, 0x578fdfe3, 0x3ac372e6]; +var bf_crypt_ciphertext = [0x4f727068, 0x65616e42, 0x65686f6c, 0x64657253, + 0x63727944, 0x6f756274]; +var base64_code = ['.', '/', 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', + 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', + 'W', 'X', 'Y', 'Z', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', + 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', + 'w', 'x', 'y', 'z', '0', '1', '2', '3', '4', '5', '6', '7', '8', + '9']; +var index_64 = [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, + -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, + -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 0, 1, + 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, -1, -1, -1, -1, -1, -1, -1, + 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, + 21, 22, 23, 24, 25, 26, 27, -1, -1, -1, -1, -1, -1, 28, 29, 30, 31, + 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, + 49, 50, 51, 52, 53, -1, -1, -1, -1, -1]; + +function getByte(c) { + var ret = 0; + try { + var b = c.charCodeAt(0); + } catch (err) { + b = c; + } + if (b > 127) { + return -128 + (b % 128); + } else { + return b; + } +}; + +function encode_base64(d, len) { + var off = 0; + var rs = []; + var c1; + var c2; + if (len <= 0 || len > d.length) + throw "Invalid len"; + while (off < len) { + c1 = d[off++] & 0xff; + rs.push(base64_code[(c1 >> 2) & 0x3f]); + c1 = (c1 & 0x03) << 4; + if (off >= len) { + rs.push(base64_code[c1 & 0x3f]); + break; + } + c2 = d[off++] & 0xff; + c1 |= (c2 >> 4) & 0x0f; + rs.push(base64_code[c1 & 0x3f]); + c1 = (c2 & 0x0f) << 2; + if (off >= len) { + rs.push(base64_code[c1 & 0x3f]); + break; + } + c2 = d[off++] & 0xff; + c1 |= (c2 >> 6) & 0x03; + rs.push(base64_code[c1 & 0x3f]); + rs.push(base64_code[c2 & 0x3f]); + } + return rs.join(''); +}; + +function char64(x) { + var code = x.charCodeAt(0); + if (code < 0 || code > index_64.length) { + return -1; + } + return index_64[code]; +}; + +function decode_base64(s, maxolen) { + var off = 0; + var slen = s.length; + var olen = 0; + var rs = []; + var c1, c2, c3, c4, o; + if (maxolen <= 0) throw "Invalid maxolen"; + while (off < slen - 1 && olen < maxolen) { + c1 = char64(s.charAt(off++)); + c2 = char64(s.charAt(off++)); + if (c1 == -1 || c2 == -1) { + break; + } + o = getByte(c1 << 2); + o |= (c2 & 0x30) >> 4; + rs.push(String.fromCharCode(o)); + if (++olen >= maxolen || off >= slen) { + break; + } + c3 = char64(s.charAt(off++)); + if (c3 == -1) { + break; + } + o = getByte((c2 & 0x0f) << 4); + o |= (c3 & 0x3c) >> 2; + rs.push(String.fromCharCode(o)); + if (++olen >= maxolen || off >= slen) { + break; + } + c4 = char64(s.charAt(off++)); + o = getByte((c3 & 0x03) << 6); + o |= c4; + rs.push(String.fromCharCode(o)); + ++olen; + } + var ret = []; + for (off = 0; off < olen; off++) { + ret.push(getByte(rs[off])); + } + return ret; +}; + +function encipher(lr, off, P, S) { + var i; + var n; + var l = lr[off]; + var r = lr[off + 1]; + + l ^= P[0]; + for (i = 0; i <= BLOWFISH_NUM_ROUNDS - 2;) { + // Feistel substitution on left word + n = S[(l >> 24) & 0xff]; + n += S[0x100 | ((l >> 16) & 0xff)]; + n ^= S[0x200 | ((l >> 8) & 0xff)]; + n += S[0x300 | (l & 0xff)]; + r ^= n ^ P[++i]; + + // Feistel substitution on right word + n = S[(r >> 24) & 0xff]; + n += S[0x100 | ((r >> 16) & 0xff)]; + n ^= S[0x200 | ((r >> 8) & 0xff)]; + n += S[0x300 | (r & 0xff)]; + l ^= n ^ P[++i]; + } + lr[off] = r ^ P[BLOWFISH_NUM_ROUNDS + 1]; + lr[off + 1] = l; + return lr; +}; + +function streamtoword(data, offp) { + var i; + var word = 0; + for (i = 0; i < 4; i++) { + word = (word << 8) | (data[offp] & 0xff); + offp = (offp + 1) % data.length; + } + return {key:word, offp:offp}; +}; + +function key(key, P, S) { + var i; + var offp = 0; + var lr = new Array(0x00000000, 0x00000000); + var plen = P.length; + var slen = S.length; + + for (i = 0; i < plen; i++) { + var sw = streamtoword(key, offp); + offp = sw.offp; + P[i] = P[i] ^ sw.key; + } + for (i = 0; i < plen; i += 2) { + lr = encipher(lr, 0, P, S); + P[i] = lr[0]; + P[i + 1] = lr[1]; + } + + for (i = 0; i < slen; i += 2) { + lr = encipher(lr, 0, P, S); + S[i] = lr[0]; + S[i + 1] = lr[1]; + } +}; + +function ekskey(data, key, P, S) { + var i; + var offp = 0; + var lr = new Array(0x00000000, 0x00000000); + var plen = P.length; + var slen = S.length; + var sw; + + for (i = 0; i < plen; i++) { + sw = streamtoword(key, offp); + offp = sw.offp; + P[i] = P[i] ^ sw.key; + } + offp = 0; + for (i = 0; i < plen; i += 2) { + sw = streamtoword(data, offp); + offp = sw.offp; + lr[0] ^= sw.key; + + sw = streamtoword(data, offp); + offp = sw.offp; + lr[1] ^= sw.key; + + lr = encipher(lr, 0, P, S); + P[i] = lr[0]; + P[i + 1] = lr[1]; + } + for (i = 0; i < slen; i += 2) { + sw = streamtoword(data, offp); + offp = sw.offp; + lr[0] ^= sw.key; + + sw = streamtoword(data, offp); + offp = sw.offp; + lr[1] ^= sw.key; + + lr = encipher(lr, 0, P, S); + S[i] = lr[0]; + S[i + 1] = lr[1]; + } +}; + +function crypt_raw(password, salt, log_rounds, progress) { + var rounds; + var j; + var cdata = bf_crypt_ciphertext.slice(); + var clen = cdata.length; + var one_percent; + + if (log_rounds < 4 || log_rounds > 31) + throw "Bad number of rounds"; + if (salt.length != BCRYPT_SALT_LEN) + throw "Bad salt length"; + + rounds = 1 << log_rounds; + one_percent = Math.floor(rounds / 100) + 1; + + var P = P_orig.slice(); + var S = S_orig.slice(); + + ekskey(salt, password, P, S); + + var i = 0; + + while(true) { + if(i < rounds){ + var start = new Date(); + for (; i < rounds;) { + i = i + 1; + key(password, P, S); + key(salt, P, S); + if(i % one_percent == 0){ + progress(); + } + if((new Date() - start) > MAX_EXECUTION_TIME){ + break; + } + } + } else { + for (i = 0; i < 64; i++) { + for (j = 0; j < (clen >> 1); j++) { + lr = encipher(cdata, j << 1, P, S); + } + } + var ret = []; + for (i = 0; i < clen; i++) { + ret.push(getByte((cdata[i] >> 24) & 0xff)); + ret.push(getByte((cdata[i] >> 16) & 0xff)); + ret.push(getByte((cdata[i] >> 8) & 0xff)); + ret.push(getByte(cdata[i] & 0xff)); + } + return(ret); + } + } +}; + +function hashpw(password, salt, progress) { + var real_salt; + var passwordb = []; + var saltb = []; + var hashed = []; + var minor = String.fromCharCode(0); + var rounds = 0; + var off = 0; + + if (!progress){ + var progress = function() {}; + } + + if (salt.charAt(0) != '$' || salt.charAt(1) != '2') + throw "Invalid salt version"; + if (salt.charAt(2) == '$') + off = 3; + else { + minor = salt.charAt(2); + if (minor != 'a' || salt.charAt(3) != '$') + throw "Invalid salt revision"; + off = 4; + } + + // Extract number of rounds + if (salt.charAt(off + 2) > '$') + throw "Missing salt rounds"; + var r1 = parseInt(salt.substring(off, off + 1)) * 10; + var r2 = parseInt(salt.substring(off + 1, off + 2)); + rounds = r1 + r2; + real_salt = salt.substring(off + 3, off + 25); + password = password + (minor >= 'a' ? "\000" : ""); + + var buf = new Buffer(password); + for (var r = 0; r < buf.length; r++) { + passwordb.push(buf[r]); + } + saltb = decode_base64(real_salt, BCRYPT_SALT_LEN); + var hashed = crypt_raw(passwordb, saltb, rounds, progress); + + var rs = []; + rs.push("$2"); + if (minor >= 'a') + rs.push(minor); + rs.push("$"); + if (rounds < 10) + rs.push("0"); + rs.push(rounds.toString()); + rs.push("$"); + rs.push(encode_base64(saltb, saltb.length)); + rs.push(encode_base64(hashed, bf_crypt_ciphertext.length * 4 - 1)); + + return(rs.join('')); +}; + +function gensalt(rounds) { + var iteration_count = rounds; + if (iteration_count < 4 || iteration_count > 31) { + iteration_count = GENSALT_DEFAULT_LOG2_ROUNDS; + } + var output = []; + output.push("$2a$"); + if (iteration_count < 10) + output.push("0"); + output.push(iteration_count.toString()); + output.push('$'); + + var rand_buf; + try { + rand_buf = crypto.randomBytes(BCRYPT_SALT_LEN); + } catch (ex) { + throw ex; + } + + output.push(encode_base64(rand_buf, BCRYPT_SALT_LEN)); + return output.join(''); +}; + +function genSaltSync(rounds) { + /* + rounds - [OPTIONAL] - the number of rounds to process the data for. (default - 10) + seed_length - [OPTIONAL] - RAND_bytes wants a length. to make that a bit flexible, you can specify a seed_length. (default - 20) + */ + if(!rounds) { + rounds = GENSALT_DEFAULT_LOG2_ROUNDS; + } + return gensalt(rounds); +} + +function genSalt(rounds, callback) { + /* + rounds - [OPTIONAL] - the number of rounds to process the data for. (default - 10) + seed_length - [OPTIONAL] - RAND_bytes wants a length. to make that a bit flexible, you can specify a seed_length. (default - 20) + callback - [REQUIRED] - a callback to be fired once the salt has been generated. uses eio making it asynchronous. + error - First parameter to the callback detailing any errors. + salt - Second parameter to the callback providing the generated salt. + */ + if(!callback) { + throw "No callback function was given." + } + process.nextTick(function() { + var result = null; + var error = null; + try { + result = genSaltSync(rounds) + } catch(err) { + error = err; + } + callback(error, result); + }); +} + +function hashSync(data, salt, progress) { + /* + data - [REQUIRED] - the data to be encrypted. + salt - [REQUIRED] - the salt to be used in encryption. + */ + if(!salt) { + salt = genSaltSync(); + } + return hashpw(data, salt, progress); +} + +function hash(data, salt, progress, callback) { + /* + data - [REQUIRED] - the data to be encrypted. + salt - [REQUIRED] - the salt to be used to hash the password. if specified as a number then a salt will be generated and used (see examples). + progress - a callback to be called during the hash calculation to signify progress + callback - [REQUIRED] - a callback to be fired once the data has been encrypted. uses eio making it asynchronous. + error - First parameter to the callback detailing any errors. + encrypted - Second parameter to the callback providing the encrypted form. + */ + if(!callback) { + throw "No callback function was given." + } + process.nextTick(function() { + var result = null; + var error = null; + try { + result = hashSync(data, salt, progress) + } catch(err) { + error = err; + } + callback(error, result); + }); +} + +function compareSync(data, encrypted) { + /* + data - [REQUIRED] - data to compare. + encrypted - [REQUIRED] - data to be compared to. + */ + + if(typeof data != "string" || typeof encrypted != "string") { + throw "Incorrect arguments"; + } + + var encrypted_length = encrypted.length; + + if(encrypted_length != 60) { + throw "Not a valid BCrypt hash."; + } + + var same = true; + var hash_data = hashSync(data, encrypted.substr(0, encrypted_length-31)); + var hash_data_length = hash_data.length; + + same = hash_data_length == encrypted_length; + + var max_length = (hash_data_length < encrypted_length) ? hash_data_length : encrypted_length; + + // to prevent timing attacks, should check entire string + // don't exit after found to be false + for (var i = 0; i < max_length; ++i) { + if (hash_data_length >= i && encrypted_length >= i && hash_data[i] != encrypted[i]) { + same = false; + } + } + + return same; +} + +function compare(data, encrypted, callback) { + /* + data - [REQUIRED] - data to compare. + encrypted - [REQUIRED] - data to be compared to. + callback - [REQUIRED] - a callback to be fired once the data has been compared. uses eio making it asynchronous. + error - First parameter to the callback detailing any errors. + same - Second parameter to the callback providing whether the data and encrypted forms match [true | false]. + */ + if(!callback) { + throw "No callback function was given." + } + process.nextTick(function() { + var result = null; + var error = null; + try { + result = compareSync(data, encrypted) + } catch(err) { + error = err; + } + callback(error, result); + }); +} + +function getRounds(encrypted) { + //encrypted - [REQUIRED] - hash from which the number of rounds used should be extracted. + if(typeof encrypted != "string") { + throw "Incorrect arguments"; + } + return Number(encrypted.split("$")[2]); +} + +exports.genSaltSync = genSaltSync; +exports.genSalt = genSalt; +exports.hashSync = hashSync; +exports.hash = hash; +exports.compareSync = compareSync; +exports.compare = compare; +exports.getRounds = getRounds; diff --git a/node_modules/bcrypt-nodejs/package.json b/node_modules/bcrypt-nodejs/package.json new file mode 100644 index 0000000..6d6d5c9 --- /dev/null +++ b/node_modules/bcrypt-nodejs/package.json @@ -0,0 +1,63 @@ +{ + "name": "bcrypt-nodejs", + "description": "A native JS bcrypt library for NodeJS.", + "main": "./bCrypt", + "author": { + "name": "Shane Girish", + "email": "shaneGirish@gmail.com" + }, + "version": "0.0.3", + "repository": { + "type": "git", + "url": "https://github.com/shaneGirish/bcryptJS.git" + }, + "bugs": { + "url": "https://github.com/shaneGirish/bcrypt-nodejs/issues" + }, + "contributors": [ + { + "name": "Alex Murray", + "url": "https://github.com/alexmurray" + }, + { + "name": "Nicolas Pelletier", + "url": "https://github.com/NicolasPelletier" + }, + { + "name": "Josh Rogers", + "url": "https://github.com/geekymole" + } + ], + "keywords": [ + "bcrypt", + "javascript", + "js", + "hash", + "password", + "auth", + "authentication", + "encryption", + "crypt", + "crypto" + ], + "_id": "bcrypt-nodejs@0.0.3", + "dist": { + "shasum": "c60917f26dc235661566c681061c303c2b28842b", + "tarball": "https://registry.npmjs.org/bcrypt-nodejs/-/bcrypt-nodejs-0.0.3.tgz" + }, + "_npmVersion": "1.2.0", + "_npmUser": { + "name": "shanegirish", + "email": "shaneGirish@gmail.com" + }, + "maintainers": [ + { + "name": "shanegirish", + "email": "shanegirish@gmail.com" + } + ], + "directories": {}, + "_shasum": "c60917f26dc235661566c681061c303c2b28842b", + "_resolved": "http://registry.npmjs.org/bcrypt-nodejs/-/bcrypt-nodejs-0.0.3.tgz", + "_from": "bcrypt-nodejs@latest" +} diff --git a/node_modules/bcrypt-nodejs/test-async.js b/node_modules/bcrypt-nodejs/test-async.js new file mode 100644 index 0000000..42ce654 --- /dev/null +++ b/node_modules/bcrypt-nodejs/test-async.js @@ -0,0 +1,71 @@ +var bCrypt = require("./bCrypt"); + +var compares = 0; +var salts = []; +var hashes = []; + +console.log("\n\n Salts \n"); +bCrypt.genSalt(8, saltCallback); +bCrypt.genSalt(10, saltCallback); + +function saltCallback(error, result) { + if(!error) { + console.log(result); + } else { + console.log(error); + } + salts.push(result); + if(salts.length == 2) { + console.log("\n\n Hashes \n"); + createHash(salts[0]); + } +} + +function createHash(salt) { + bCrypt.hash("bacon", salt, null, hashCallback); + bCrypt.hash("bacon", salt, null, hashCallback); +} + +function hashCallback(error, result) { + if(!error) { + console.log(result); + } else { + console.log(error); + } + hashes.push(result); + if(hashes.length == 2) { + createHash(salts[1]); + } else if(hashes.length == 4) { + console.log("\n\n True Compares \n"); + compares = 0; + startCompares("bacon", trueCompareCallback); + } +} + +function startCompares(string, callback) { + bCrypt.compare(string, hashes[0], callback); + bCrypt.compare(string, hashes[1], callback); + bCrypt.compare(string, hashes[2], callback); + bCrypt.compare(string, hashes[3], callback); +} + +function trueCompareCallback(error, result) { + if(!error) { + console.log(result); + } else { + console.log(error); + } + if(++compares == 4) { + console.log("\n\n False Compares \n"); + compares = 0; + startCompares("veggies", falseCompareCallback); + } +} + +function falseCompareCallback(error, result) { + if(!error) { + console.log(result); + } else { + console.log(error); + } +} \ No newline at end of file diff --git a/node_modules/bcrypt-nodejs/test-sync.js b/node_modules/bcrypt-nodejs/test-sync.js new file mode 100644 index 0000000..598945d --- /dev/null +++ b/node_modules/bcrypt-nodejs/test-sync.js @@ -0,0 +1,98 @@ +/*jslint node: true, indent: 4, stupid: true */ +var bCrypt = require("./bCrypt"); + +console.log("\n\n Salts \n"); + +var salt1 = bCrypt.genSaltSync(8); +console.log(salt1); + +var salt2 = bCrypt.genSaltSync(10); +console.log(salt2); + + +console.log("\n\n Hashes \n"); + +var hash1 = bCrypt.hashSync("super secret", salt1, null); +console.log(hash1); + +var hash2 = bCrypt.hashSync("super secret", salt1, null); +console.log(hash2); + +var hash3 = bCrypt.hashSync("supersecret", salt1, null); +console.log(hash3); + +var hash4 = bCrypt.hashSync("supersecret", salt1, null); +console.log(hash4); + +var hash5 = bCrypt.hashSync("super secret", salt2, null); +console.log(hash5); + +var hash6 = bCrypt.hashSync("super secret", salt2, null); +console.log(hash6); + +var hash7 = bCrypt.hashSync("supersecret", salt2, null); +console.log(hash7); + +var hash8 = bCrypt.hashSync("supersecret", salt2, null); +console.log(hash8); + +var hash9 = bCrypt.hashSync("super secret", null, null); +console.log(hash9); + +var hash0 = bCrypt.hashSync("supersecret", null, null); +console.log(hash0); + +console.log("\n\n First Set of Compares \n"); + +console.log(bCrypt.compareSync("super secret", hash1) ? 'PASSED' : 'FAILED'); +console.log(bCrypt.compareSync("super secret", hash2) ? 'PASSED' : 'FAILED'); +console.log(bCrypt.compareSync("super secret", hash5) ? 'PASSED' : 'FAILED'); +console.log(bCrypt.compareSync("super secret", hash6) ? 'PASSED' : 'FAILED'); +console.log(bCrypt.compareSync("super secret", hash9) ? 'PASSED' : 'FAILED'); +console.log(bCrypt.compareSync("super secret", hash3) ? 'FAILED' : 'PASSED'); +console.log(bCrypt.compareSync("super secret", hash4) ? 'FAILED' : 'PASSED'); +console.log(bCrypt.compareSync("super secret", hash7) ? 'FAILED' : 'PASSED'); +console.log(bCrypt.compareSync("super secret", hash8) ? 'FAILED' : 'PASSED'); +console.log(bCrypt.compareSync("super secret", hash0) ? 'FAILED' : 'PASSED'); + +console.log("\n\n Second Set of Compares \n"); + +console.log(bCrypt.compareSync("supersecret", hash1) ? 'FAILED' : 'PASSED'); +console.log(bCrypt.compareSync("supersecret", hash2) ? 'FAILED' : 'PASSED'); +console.log(bCrypt.compareSync("supersecret", hash5) ? 'FAILED' : 'PASSED'); +console.log(bCrypt.compareSync("supersecret", hash6) ? 'FAILED' : 'PASSED'); +console.log(bCrypt.compareSync("supersecret", hash9) ? 'FAILED' : 'PASSED'); +console.log(bCrypt.compareSync("supersecret", hash3) ? 'PASSED' : 'FAILED'); +console.log(bCrypt.compareSync("supersecret", hash4) ? 'PASSED' : 'FAILED'); +console.log(bCrypt.compareSync("supersecret", hash7) ? 'PASSED' : 'FAILED'); +console.log(bCrypt.compareSync("supersecret", hash8) ? 'PASSED' : 'FAILED'); +console.log(bCrypt.compareSync("supersecret", hash0) ? 'PASSED' : 'FAILED'); + + +console.log('\n\n -------------------- UTF-8 passwords --------------------'); +var pw1 = '\u6e2f', // http://www.fileformat.info/info/unicode/char/6e2f/index.htm + pw2 = '港', // Character 0x6e2f same as pw1. + pw3 = '\u6f2f', // http://www.fileformat.info/info/unicode/char/6f2f/index.htm + pw4 = '漯', // Character 0x6f2f same as pw3. + salt = '$2a$05$0000000000000000000000', + hash_pw1 = bCrypt.hashSync(pw1, salt, null), + hash_pw2 = bCrypt.hashSync(pw2, salt, null), + hash_pw3 = bCrypt.hashSync(pw3, salt, null), + hash_pw4 = bCrypt.hashSync(pw4, salt, null); + +console.log("\n\n Hashes \n"); +console.log(hash_pw1); +console.log(hash_pw2); +console.log(hash_pw3); +console.log(hash_pw4); + +console.log("\n\n Third Set of Compares \n"); + +console.log(bCrypt.compareSync(pw1, hash_pw1) ? 'PASSED' : 'FAILED'); +console.log(bCrypt.compareSync(pw2, hash_pw2) ? 'PASSED' : 'FAILED'); +console.log(bCrypt.compareSync(pw3, hash_pw3) ? 'PASSED' : 'FAILED'); +console.log(bCrypt.compareSync(pw4, hash_pw4) ? 'PASSED' : 'FAILED'); +console.log('Hashes 1 and 3 are different: ' + (hash_pw1 !== hash_pw3) ? 'PASSED' : 'FAILED'); +console.log('Hashes 2 and 4 are different: ' + (hash_pw2 !== hash_pw4) ? 'PASSED' : 'FAILED'); +console.log('Hashes 1 and 2 are the same: ' + (hash_pw1 !== hash_pw2) ? 'PASSED' : 'FAILED'); +console.log('Hashes 3 and 4 are the same: ' + (hash_pw3 !== hash_pw4) ? 'PASSED' : 'FAILED'); diff --git a/node_modules/body-parser/HISTORY.md b/node_modules/body-parser/HISTORY.md new file mode 100644 index 0000000..f3ea28c --- /dev/null +++ b/node_modules/body-parser/HISTORY.md @@ -0,0 +1,464 @@ +1.15.2 / 2016-06-19 +=================== + + * deps: bytes@2.4.0 + * deps: content-type@~1.0.2 + - perf: enable strict mode + * deps: http-errors@~1.5.0 + - Use `setprototypeof` module to replace `__proto__` setting + - deps: statuses@'>= 1.3.0 < 2' + - perf: enable strict mode + * deps: qs@6.2.0 + * deps: raw-body@~2.1.7 + - deps: bytes@2.4.0 + - perf: remove double-cleanup on happy path + * deps: type-is@~1.6.13 + - deps: mime-types@~2.1.11 + +1.15.1 / 2016-05-05 +=================== + + * deps: bytes@2.3.0 + - Drop partial bytes on all parsed units + - Fix parsing byte string that looks like hex + * deps: raw-body@~2.1.6 + - deps: bytes@2.3.0 + * deps: type-is@~1.6.12 + - deps: mime-types@~2.1.10 + +1.15.0 / 2016-02-10 +=================== + + * deps: http-errors@~1.4.0 + - Add `HttpError` export, for `err instanceof createError.HttpError` + - deps: inherits@2.0.1 + - deps: statuses@'>= 1.2.1 < 2' + * deps: qs@6.1.0 + * deps: type-is@~1.6.11 + - deps: mime-types@~2.1.9 + +1.14.2 / 2015-12-16 +=================== + + * deps: bytes@2.2.0 + * deps: iconv-lite@0.4.13 + * deps: qs@5.2.0 + * deps: raw-body@~2.1.5 + - deps: bytes@2.2.0 + - deps: iconv-lite@0.4.13 + * deps: type-is@~1.6.10 + - deps: mime-types@~2.1.8 + +1.14.1 / 2015-09-27 +=================== + + * Fix issue where invalid charset results in 400 when `verify` used + * deps: iconv-lite@0.4.12 + - Fix CESU-8 decoding in Node.js 4.x + * deps: raw-body@~2.1.4 + - Fix masking critical errors from `iconv-lite` + - deps: iconv-lite@0.4.12 + * deps: type-is@~1.6.9 + - deps: mime-types@~2.1.7 + +1.14.0 / 2015-09-16 +=================== + + * Fix JSON strict parse error to match syntax errors + * Provide static `require` analysis in `urlencoded` parser + * deps: depd@~1.1.0 + - Support web browser loading + * deps: qs@5.1.0 + * deps: raw-body@~2.1.3 + - Fix sync callback when attaching data listener causes sync read + * deps: type-is@~1.6.8 + - Fix type error when given invalid type to match against + - deps: mime-types@~2.1.6 + +1.13.3 / 2015-07-31 +=================== + + * deps: type-is@~1.6.6 + - deps: mime-types@~2.1.4 + +1.13.2 / 2015-07-05 +=================== + + * deps: iconv-lite@0.4.11 + * deps: qs@4.0.0 + - Fix dropping parameters like `hasOwnProperty` + - Fix user-visible incompatibilities from 3.1.0 + - Fix various parsing edge cases + * deps: raw-body@~2.1.2 + - Fix error stack traces to skip `makeError` + - deps: iconv-lite@0.4.11 + * deps: type-is@~1.6.4 + - deps: mime-types@~2.1.2 + - perf: enable strict mode + - perf: remove argument reassignment + +1.13.1 / 2015-06-16 +=================== + + * deps: qs@2.4.2 + - Downgraded from 3.1.0 because of user-visible incompatibilities + +1.13.0 / 2015-06-14 +=================== + + * Add `statusCode` property on `Error`s, in addition to `status` + * Change `type` default to `application/json` for JSON parser + * Change `type` default to `application/x-www-form-urlencoded` for urlencoded parser + * Provide static `require` analysis + * Use the `http-errors` module to generate errors + * deps: bytes@2.1.0 + - Slight optimizations + * deps: iconv-lite@0.4.10 + - The encoding UTF-16 without BOM now defaults to UTF-16LE when detection fails + - Leading BOM is now removed when decoding + * deps: on-finished@~2.3.0 + - Add defined behavior for HTTP `CONNECT` requests + - Add defined behavior for HTTP `Upgrade` requests + - deps: ee-first@1.1.1 + * deps: qs@3.1.0 + - Fix dropping parameters like `hasOwnProperty` + - Fix various parsing edge cases + - Parsed object now has `null` prototype + * deps: raw-body@~2.1.1 + - Use `unpipe` module for unpiping requests + - deps: iconv-lite@0.4.10 + * deps: type-is@~1.6.3 + - deps: mime-types@~2.1.1 + - perf: reduce try block size + - perf: remove bitwise operations + * perf: enable strict mode + * perf: remove argument reassignment + * perf: remove delete call + +1.12.4 / 2015-05-10 +=================== + + * deps: debug@~2.2.0 + * deps: qs@2.4.2 + - Fix allowing parameters like `constructor` + * deps: on-finished@~2.2.1 + * deps: raw-body@~2.0.1 + - Fix a false-positive when unpiping in Node.js 0.8 + - deps: bytes@2.0.1 + * deps: type-is@~1.6.2 + - deps: mime-types@~2.0.11 + +1.12.3 / 2015-04-15 +=================== + + * Slight efficiency improvement when not debugging + * deps: depd@~1.0.1 + * deps: iconv-lite@0.4.8 + - Add encoding alias UNICODE-1-1-UTF-7 + * deps: raw-body@1.3.4 + - Fix hanging callback if request aborts during read + - deps: iconv-lite@0.4.8 + +1.12.2 / 2015-03-16 +=================== + + * deps: qs@2.4.1 + - Fix error when parameter `hasOwnProperty` is present + +1.12.1 / 2015-03-15 +=================== + + * deps: debug@~2.1.3 + - Fix high intensity foreground color for bold + - deps: ms@0.7.0 + * deps: type-is@~1.6.1 + - deps: mime-types@~2.0.10 + +1.12.0 / 2015-02-13 +=================== + + * add `debug` messages + * accept a function for the `type` option + * use `content-type` to parse `Content-Type` headers + * deps: iconv-lite@0.4.7 + - Gracefully support enumerables on `Object.prototype` + * deps: raw-body@1.3.3 + - deps: iconv-lite@0.4.7 + * deps: type-is@~1.6.0 + - fix argument reassignment + - fix false-positives in `hasBody` `Transfer-Encoding` check + - support wildcard for both type and subtype (`*/*`) + - deps: mime-types@~2.0.9 + +1.11.0 / 2015-01-30 +=================== + + * make internal `extended: true` depth limit infinity + * deps: type-is@~1.5.6 + - deps: mime-types@~2.0.8 + +1.10.2 / 2015-01-20 +=================== + + * deps: iconv-lite@0.4.6 + - Fix rare aliases of single-byte encodings + * deps: raw-body@1.3.2 + - deps: iconv-lite@0.4.6 + +1.10.1 / 2015-01-01 +=================== + + * deps: on-finished@~2.2.0 + * deps: type-is@~1.5.5 + - deps: mime-types@~2.0.7 + +1.10.0 / 2014-12-02 +=================== + + * make internal `extended: true` array limit dynamic + +1.9.3 / 2014-11-21 +================== + + * deps: iconv-lite@0.4.5 + - Fix Windows-31J and X-SJIS encoding support + * deps: qs@2.3.3 + - Fix `arrayLimit` behavior + * deps: raw-body@1.3.1 + - deps: iconv-lite@0.4.5 + * deps: type-is@~1.5.3 + - deps: mime-types@~2.0.3 + +1.9.2 / 2014-10-27 +================== + + * deps: qs@2.3.2 + - Fix parsing of mixed objects and values + +1.9.1 / 2014-10-22 +================== + + * deps: on-finished@~2.1.1 + - Fix handling of pipelined requests + * deps: qs@2.3.0 + - Fix parsing of mixed implicit and explicit arrays + * deps: type-is@~1.5.2 + - deps: mime-types@~2.0.2 + +1.9.0 / 2014-09-24 +================== + + * include the charset in "unsupported charset" error message + * include the encoding in "unsupported content encoding" error message + * deps: depd@~1.0.0 + +1.8.4 / 2014-09-23 +================== + + * fix content encoding to be case-insensitive + +1.8.3 / 2014-09-19 +================== + + * deps: qs@2.2.4 + - Fix issue with object keys starting with numbers truncated + +1.8.2 / 2014-09-15 +================== + + * deps: depd@0.4.5 + +1.8.1 / 2014-09-07 +================== + + * deps: media-typer@0.3.0 + * deps: type-is@~1.5.1 + +1.8.0 / 2014-09-05 +================== + + * make empty-body-handling consistent between chunked requests + - empty `json` produces `{}` + - empty `raw` produces `new Buffer(0)` + - empty `text` produces `''` + - empty `urlencoded` produces `{}` + * deps: qs@2.2.3 + - Fix issue where first empty value in array is discarded + * deps: type-is@~1.5.0 + - fix `hasbody` to be true for `content-length: 0` + +1.7.0 / 2014-09-01 +================== + + * add `parameterLimit` option to `urlencoded` parser + * change `urlencoded` extended array limit to 100 + * respond with 413 when over `parameterLimit` in `urlencoded` + +1.6.7 / 2014-08-29 +================== + + * deps: qs@2.2.2 + - Remove unnecessary cloning + +1.6.6 / 2014-08-27 +================== + + * deps: qs@2.2.0 + - Array parsing fix + - Performance improvements + +1.6.5 / 2014-08-16 +================== + + * deps: on-finished@2.1.0 + +1.6.4 / 2014-08-14 +================== + + * deps: qs@1.2.2 + +1.6.3 / 2014-08-10 +================== + + * deps: qs@1.2.1 + +1.6.2 / 2014-08-07 +================== + + * deps: qs@1.2.0 + - Fix parsing array of objects + +1.6.1 / 2014-08-06 +================== + + * deps: qs@1.1.0 + - Accept urlencoded square brackets + - Accept empty values in implicit array notation + +1.6.0 / 2014-08-05 +================== + + * deps: qs@1.0.2 + - Complete rewrite + - Limits array length to 20 + - Limits object depth to 5 + - Limits parameters to 1,000 + +1.5.2 / 2014-07-27 +================== + + * deps: depd@0.4.4 + - Work-around v8 generating empty stack traces + +1.5.1 / 2014-07-26 +================== + + * deps: depd@0.4.3 + - Fix exception when global `Error.stackTraceLimit` is too low + +1.5.0 / 2014-07-20 +================== + + * deps: depd@0.4.2 + - Add `TRACE_DEPRECATION` environment variable + - Remove non-standard grey color from color output + - Support `--no-deprecation` argument + - Support `--trace-deprecation` argument + * deps: iconv-lite@0.4.4 + - Added encoding UTF-7 + * deps: raw-body@1.3.0 + - deps: iconv-lite@0.4.4 + - Added encoding UTF-7 + - Fix `Cannot switch to old mode now` error on Node.js 0.10+ + * deps: type-is@~1.3.2 + +1.4.3 / 2014-06-19 +================== + + * deps: type-is@1.3.1 + - fix global variable leak + +1.4.2 / 2014-06-19 +================== + + * deps: type-is@1.3.0 + - improve type parsing + +1.4.1 / 2014-06-19 +================== + + * fix urlencoded extended deprecation message + +1.4.0 / 2014-06-19 +================== + + * add `text` parser + * add `raw` parser + * check accepted charset in content-type (accepts utf-8) + * check accepted encoding in content-encoding (accepts identity) + * deprecate `bodyParser()` middleware; use `.json()` and `.urlencoded()` as needed + * deprecate `urlencoded()` without provided `extended` option + * lazy-load urlencoded parsers + * parsers split into files for reduced mem usage + * support gzip and deflate bodies + - set `inflate: false` to turn off + * deps: raw-body@1.2.2 + - Support all encodings from `iconv-lite` + +1.3.1 / 2014-06-11 +================== + + * deps: type-is@1.2.1 + - Switch dependency from mime to mime-types@1.0.0 + +1.3.0 / 2014-05-31 +================== + + * add `extended` option to urlencoded parser + +1.2.2 / 2014-05-27 +================== + + * deps: raw-body@1.1.6 + - assert stream encoding on node.js 0.8 + - assert stream encoding on node.js < 0.10.6 + - deps: bytes@1 + +1.2.1 / 2014-05-26 +================== + + * invoke `next(err)` after request fully read + - prevents hung responses and socket hang ups + +1.2.0 / 2014-05-11 +================== + + * add `verify` option + * deps: type-is@1.2.0 + - support suffix matching + +1.1.2 / 2014-05-11 +================== + + * improve json parser speed + +1.1.1 / 2014-05-11 +================== + + * fix repeated limit parsing with every request + +1.1.0 / 2014-05-10 +================== + + * add `type` option + * deps: pin for safety and consistency + +1.0.2 / 2014-04-14 +================== + + * use `type-is` module + +1.0.1 / 2014-03-20 +================== + + * lower default limits to 100kb diff --git a/node_modules/body-parser/LICENSE b/node_modules/body-parser/LICENSE new file mode 100644 index 0000000..386b7b6 --- /dev/null +++ b/node_modules/body-parser/LICENSE @@ -0,0 +1,23 @@ +(The MIT License) + +Copyright (c) 2014 Jonathan Ong +Copyright (c) 2014-2015 Douglas Christopher Wilson + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/body-parser/README.md b/node_modules/body-parser/README.md new file mode 100644 index 0000000..6376536 --- /dev/null +++ b/node_modules/body-parser/README.md @@ -0,0 +1,409 @@ +# body-parser + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Build Status][travis-image]][travis-url] +[![Test Coverage][coveralls-image]][coveralls-url] +[![Gratipay][gratipay-image]][gratipay-url] + +Node.js body parsing middleware. + +Parse incoming request bodies in a middleware before your handlers, availabe +under the `req.body` property. + +[Learn about the anatomy of an HTTP transaction in Node.js](https://nodejs.org/en/docs/guides/anatomy-of-an-http-transaction/). + +_This does not handle multipart bodies_, due to their complex and typically +large nature. For multipart bodies, you may be interested in the following +modules: + + * [busboy](https://www.npmjs.org/package/busboy#readme) and + [connect-busboy](https://www.npmjs.org/package/connect-busboy#readme) + * [multiparty](https://www.npmjs.org/package/multiparty#readme) and + [connect-multiparty](https://www.npmjs.org/package/connect-multiparty#readme) + * [formidable](https://www.npmjs.org/package/formidable#readme) + * [multer](https://www.npmjs.org/package/multer#readme) + +This module provides the following parsers: + + * [JSON body parser](#bodyparserjsonoptions) + * [Raw body parser](#bodyparserrawoptions) + * [Text body parser](#bodyparsertextoptions) + * [URL-encoded form body parser](#bodyparserurlencodedoptions) + +Other body parsers you might be interested in: + +- [body](https://www.npmjs.org/package/body#readme) +- [co-body](https://www.npmjs.org/package/co-body#readme) + +## Installation + +```sh +$ npm install body-parser +``` + +## API + +```js +var bodyParser = require('body-parser') +``` + +The `bodyParser` object exposes various factories to create middlewares. All +middlewares will populate the `req.body` property with the parsed body, or an +empty object (`{}`) if there was no body to parse (or an error was returned). + +The various errors returned by this module are described in the +[errors section](#errors). + +### bodyParser.json(options) + +Returns middleware that only parses `json`. This parser accepts any Unicode +encoding of the body and supports automatic inflation of `gzip` and `deflate` +encodings. + +A new `body` object containing the parsed data is populated on the `request` +object after the middleware (i.e. `req.body`). + +#### Options + +The `json` function takes an option `options` object that may contain any of +the following keys: + +##### inflate + +When set to `true`, then deflated (compressed) bodies will be inflated; when +`false`, deflated bodies are rejected. Defaults to `true`. + +##### limit + +Controls the maximum request body size. If this is a number, then the value +specifies the number of bytes; if it is a string, the value is passed to the +[bytes](https://www.npmjs.com/package/bytes) library for parsing. Defaults +to `'100kb'`. + +##### reviver + +The `reviver` option is passed directly to `JSON.parse` as the second +argument. You can find more information on this argument +[in the MDN documentation about JSON.parse](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/parse#Example.3A_Using_the_reviver_parameter). + +##### strict + +When set to `true`, will only accept arrays and objects; when `false` will +accept anything `JSON.parse` accepts. Defaults to `true`. + +##### type + +The `type` option is used to determine what media type the middleware will +parse. This option can be a function or a string. If a string, `type` option +is passed directly to the [type-is](https://www.npmjs.org/package/type-is#readme) +library and this can be an extension name (like `json`), a mime type (like +`application/json`), or a mime type with a wildcard (like `*/*` or `*/json`). +If a function, the `type` option is called as `fn(req)` and the request is +parsed if it returns a truthy value. Defaults to `application/json`. + +##### verify + +The `verify` option, if supplied, is called as `verify(req, res, buf, encoding)`, +where `buf` is a `Buffer` of the raw request body and `encoding` is the +encoding of the request. The parsing can be aborted by throwing an error. + +### bodyParser.raw(options) + +Returns middleware that parses all bodies as a `Buffer`. This parser +supports automatic inflation of `gzip` and `deflate` encodings. + +A new `body` object containing the parsed data is populated on the `request` +object after the middleware (i.e. `req.body`). This will be a `Buffer` object +of the body. + +#### Options + +The `raw` function takes an option `options` object that may contain any of +the following keys: + +##### inflate + +When set to `true`, then deflated (compressed) bodies will be inflated; when +`false`, deflated bodies are rejected. Defaults to `true`. + +##### limit + +Controls the maximum request body size. If this is a number, then the value +specifies the number of bytes; if it is a string, the value is passed to the +[bytes](https://www.npmjs.com/package/bytes) library for parsing. Defaults +to `'100kb'`. + +##### type + +The `type` option is used to determine what media type the middleware will +parse. This option can be a function or a string. If a string, `type` option +is passed directly to the [type-is](https://www.npmjs.org/package/type-is#readme) +library and this can be an extension name (like `bin`), a mime type (like +`application/octet-stream`), or a mime type with a wildcard (like `*/*` or +`application/*`). If a function, the `type` option is called as `fn(req)` +and the request is parsed if it returns a truthy value. Defaults to +`application/octet-stream`. + +##### verify + +The `verify` option, if supplied, is called as `verify(req, res, buf, encoding)`, +where `buf` is a `Buffer` of the raw request body and `encoding` is the +encoding of the request. The parsing can be aborted by throwing an error. + +### bodyParser.text(options) + +Returns middleware that parses all bodies as a string. This parser supports +automatic inflation of `gzip` and `deflate` encodings. + +A new `body` string containing the parsed data is populated on the `request` +object after the middleware (i.e. `req.body`). This will be a string of the +body. + +#### Options + +The `text` function takes an option `options` object that may contain any of +the following keys: + +##### defaultCharset + +Specify the default character set for the text content if the charset is not +specified in the `Content-Type` header of the request. Defaults to `utf-8`. + +##### inflate + +When set to `true`, then deflated (compressed) bodies will be inflated; when +`false`, deflated bodies are rejected. Defaults to `true`. + +##### limit + +Controls the maximum request body size. If this is a number, then the value +specifies the number of bytes; if it is a string, the value is passed to the +[bytes](https://www.npmjs.com/package/bytes) library for parsing. Defaults +to `'100kb'`. + +##### type + +The `type` option is used to determine what media type the middleware will +parse. This option can be a function or a string. If a string, `type` option +is passed directly to the [type-is](https://www.npmjs.org/package/type-is#readme) +library and this can be an extension name (like `txt`), a mime type (like +`text/plain`), or a mime type with a wildcard (like `*/*` or `text/*`). +If a function, the `type` option is called as `fn(req)` and the request is +parsed if it returns a truthy value. Defaults to `text/plain`. + +##### verify + +The `verify` option, if supplied, is called as `verify(req, res, buf, encoding)`, +where `buf` is a `Buffer` of the raw request body and `encoding` is the +encoding of the request. The parsing can be aborted by throwing an error. + +### bodyParser.urlencoded(options) + +Returns middleware that only parses `urlencoded` bodies. This parser accepts +only UTF-8 encoding of the body and supports automatic inflation of `gzip` +and `deflate` encodings. + +A new `body` object containing the parsed data is populated on the `request` +object after the middleware (i.e. `req.body`). This object will contain +key-value pairs, where the value can be a string or array (when `extended` is +`false`), or any type (when `extended` is `true`). + +#### Options + +The `urlencoded` function takes an option `options` object that may contain +any of the following keys: + +##### extended + +The `extended` option allows to choose between parsing the URL-encoded data +with the `querystring` library (when `false`) or the `qs` library (when +`true`). The "extended" syntax allows for rich objects and arrays to be +encoded into the URL-encoded format, allowing for a JSON-like experience +with URL-encoded. For more information, please +[see the qs library](https://www.npmjs.org/package/qs#readme). + +Defaults to `true`, but using the default has been deprecated. Please +research into the difference between `qs` and `querystring` and choose the +appropriate setting. + +##### inflate + +When set to `true`, then deflated (compressed) bodies will be inflated; when +`false`, deflated bodies are rejected. Defaults to `true`. + +##### limit + +Controls the maximum request body size. If this is a number, then the value +specifies the number of bytes; if it is a string, the value is passed to the +[bytes](https://www.npmjs.com/package/bytes) library for parsing. Defaults +to `'100kb'`. + +##### parameterLimit + +The `parameterLimit` option controls the maximum number of parameters that +are allowed in the URL-encoded data. If a request contains more parameters +than this value, a 413 will be returned to the client. Defaults to `1000`. + +##### type + +The `type` option is used to determine what media type the middleware will +parse. This option can be a function or a string. If a string, `type` option +is passed directly to the [type-is](https://www.npmjs.org/package/type-is#readme) +library and this can be an extension name (like `urlencoded`), a mime type (like +`application/x-www-form-urlencoded`), or a mime type with a wildcard (like +`*/x-www-form-urlencoded`). If a function, the `type` option is called as +`fn(req)` and the request is parsed if it returns a truthy value. Defaults +to `application/x-www-form-urlencoded`. + +##### verify + +The `verify` option, if supplied, is called as `verify(req, res, buf, encoding)`, +where `buf` is a `Buffer` of the raw request body and `encoding` is the +encoding of the request. The parsing can be aborted by throwing an error. + +## Errors + +The middlewares provided by this module create errors depending on the error +condition during parsing. The errors will typically have a `status` property +that contains the suggested HTTP response code and a `body` property containing +the read body, if available. + +The following are the common errors emitted, though any error can come through +for various reasons. + +### content encoding unsupported + +This error will occur when the request had a `Content-Encoding` header that +contained an encoding but the "inflation" option was set to `false`. The +`status` property is set to `415`. + +### request aborted + +This error will occur when the request is aborted by the client before reading +the body has finished. The `received` property will be set to the number of +bytes received before the request was aborted and the `expected` property is +set to the number of expected bytes. The `status` property is set to `400`. + +### request entity too large + +This error will occur when the request body's size is larger than the "limit" +option. The `limit` property will be set to the byte limit and the `length` +property will be set to the request body's length. The `status` property is +set to `413`. + +### request size did not match content length + +This error will occur when the request's length did not match the length from +the `Content-Length` header. This typically occurs when the request is malformed, +typically when the `Content-Length` header was calculated based on characters +instead of bytes. The `status` property is set to `400`. + +### stream encoding should not be set + +This error will occur when something called the `req.setEncoding` method prior +to this middleware. This module operates directly on bytes only and you cannot +call `req.setEncoding` when using this module. The `status` property is set to +`500`. + +### unsupported charset "BOGUS" + +This error will occur when the request had a charset parameter in the +`Content-Type` header, but the `iconv-lite` module does not support it OR the +parser does not support it. The charset is contained in the message as well +as in the `charset` property. The `status` property is set to `415`. + +### unsupported content encoding "bogus" + +This error will occur when the request had a `Content-Encoding` header that +contained an unsupported encoding. The encoding is contained in the message +as well as in the `encoding` property. The `status` property is set to `415`. + +## Examples + +### Express/Connect top-level generic + +This example demonstrates adding a generic JSON and URL-encoded parser as a +top-level middleware, which will parse the bodies of all incoming requests. +This is the simplest setup. + +```js +var express = require('express') +var bodyParser = require('body-parser') + +var app = express() + +// parse application/x-www-form-urlencoded +app.use(bodyParser.urlencoded({ extended: false })) + +// parse application/json +app.use(bodyParser.json()) + +app.use(function (req, res) { + res.setHeader('Content-Type', 'text/plain') + res.write('you posted:\n') + res.end(JSON.stringify(req.body, null, 2)) +}) +``` + +### Express route-specific + +This example demonstrates adding body parsers specifically to the routes that +need them. In general, this is the most recommended way to use body-parser with +Express. + +```js +var express = require('express') +var bodyParser = require('body-parser') + +var app = express() + +// create application/json parser +var jsonParser = bodyParser.json() + +// create application/x-www-form-urlencoded parser +var urlencodedParser = bodyParser.urlencoded({ extended: false }) + +// POST /login gets urlencoded bodies +app.post('/login', urlencodedParser, function (req, res) { + if (!req.body) return res.sendStatus(400) + res.send('welcome, ' + req.body.username) +}) + +// POST /api/users gets JSON bodies +app.post('/api/users', jsonParser, function (req, res) { + if (!req.body) return res.sendStatus(400) + // create user in req.body +}) +``` + +### Change accepted type for parsers + +All the parsers accept a `type` option which allows you to change the +`Content-Type` that the middleware will parse. + +```js +// parse various different custom JSON types as JSON +app.use(bodyParser.json({ type: 'application/*+json' })) + +// parse some custom thing into a Buffer +app.use(bodyParser.raw({ type: 'application/vnd.custom-type' })) + +// parse an HTML body into a string +app.use(bodyParser.text({ type: 'text/html' })) +``` + +## License + +[MIT](LICENSE) + +[npm-image]: https://img.shields.io/npm/v/body-parser.svg +[npm-url]: https://npmjs.org/package/body-parser +[travis-image]: https://img.shields.io/travis/expressjs/body-parser/master.svg +[travis-url]: https://travis-ci.org/expressjs/body-parser +[coveralls-image]: https://img.shields.io/coveralls/expressjs/body-parser/master.svg +[coveralls-url]: https://coveralls.io/r/expressjs/body-parser?branch=master +[downloads-image]: https://img.shields.io/npm/dm/body-parser.svg +[downloads-url]: https://npmjs.org/package/body-parser +[gratipay-image]: https://img.shields.io/gratipay/dougwilson.svg +[gratipay-url]: https://www.gratipay.com/dougwilson/ diff --git a/node_modules/body-parser/index.js b/node_modules/body-parser/index.js new file mode 100644 index 0000000..93c3a1f --- /dev/null +++ b/node_modules/body-parser/index.js @@ -0,0 +1,157 @@ +/*! + * body-parser + * Copyright(c) 2014-2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module dependencies. + * @private + */ + +var deprecate = require('depd')('body-parser') + +/** + * Cache of loaded parsers. + * @private + */ + +var parsers = Object.create(null) + +/** + * @typedef Parsers + * @type {function} + * @property {function} json + * @property {function} raw + * @property {function} text + * @property {function} urlencoded + */ + +/** + * Module exports. + * @type {Parsers} + */ + +exports = module.exports = deprecate.function(bodyParser, + 'bodyParser: use individual json/urlencoded middlewares') + +/** + * JSON parser. + * @public + */ + +Object.defineProperty(exports, 'json', { + configurable: true, + enumerable: true, + get: createParserGetter('json') +}) + +/** + * Raw parser. + * @public + */ + +Object.defineProperty(exports, 'raw', { + configurable: true, + enumerable: true, + get: createParserGetter('raw') +}) + +/** + * Text parser. + * @public + */ + +Object.defineProperty(exports, 'text', { + configurable: true, + enumerable: true, + get: createParserGetter('text') +}) + +/** + * URL-encoded parser. + * @public + */ + +Object.defineProperty(exports, 'urlencoded', { + configurable: true, + enumerable: true, + get: createParserGetter('urlencoded') +}) + +/** + * Create a middleware to parse json and urlencoded bodies. + * + * @param {object} [options] + * @return {function} + * @deprecated + * @public + */ + +function bodyParser (options) { + var opts = {} + + // exclude type option + if (options) { + for (var prop in options) { + if (prop !== 'type') { + opts[prop] = options[prop] + } + } + } + + var _urlencoded = exports.urlencoded(opts) + var _json = exports.json(opts) + + return function bodyParser (req, res, next) { + _json(req, res, function (err) { + if (err) return next(err) + _urlencoded(req, res, next) + }) + } +} + +/** + * Create a getter for loading a parser. + * @private + */ + +function createParserGetter (name) { + return function get () { + return loadParser(name) + } +} + +/** + * Load a parser module. + * @private + */ + +function loadParser (parserName) { + var parser = parsers[parserName] + + if (parser !== undefined) { + return parser + } + + // this uses a switch for static require analysis + switch (parserName) { + case 'json': + parser = require('./lib/types/json') + break + case 'raw': + parser = require('./lib/types/raw') + break + case 'text': + parser = require('./lib/types/text') + break + case 'urlencoded': + parser = require('./lib/types/urlencoded') + break + } + + // store to prevent invoking require() + return (parsers[parserName] = parser) +} diff --git a/node_modules/body-parser/lib/read.js b/node_modules/body-parser/lib/read.js new file mode 100644 index 0000000..3c0fe93 --- /dev/null +++ b/node_modules/body-parser/lib/read.js @@ -0,0 +1,188 @@ +/*! + * body-parser + * Copyright(c) 2014-2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module dependencies. + * @private + */ + +var createError = require('http-errors') +var getBody = require('raw-body') +var iconv = require('iconv-lite') +var onFinished = require('on-finished') +var zlib = require('zlib') + +/** + * Module exports. + */ + +module.exports = read + +/** + * Read a request into a buffer and parse. + * + * @param {object} req + * @param {object} res + * @param {function} next + * @param {function} parse + * @param {function} debug + * @param {object} [options] + * @api private + */ + +function read (req, res, next, parse, debug, options) { + var length + var opts = options || {} + var stream + + // flag as parsed + req._body = true + + // read options + var encoding = opts.encoding !== null + ? opts.encoding || 'utf-8' + : null + var verify = opts.verify + + try { + // get the content stream + stream = contentstream(req, debug, opts.inflate) + length = stream.length + stream.length = undefined + } catch (err) { + return next(err) + } + + // set raw-body options + opts.length = length + opts.encoding = verify + ? null + : encoding + + // assert charset is supported + if (opts.encoding === null && encoding !== null && !iconv.encodingExists(encoding)) { + return next(createError(415, 'unsupported charset "' + encoding.toUpperCase() + '"', { + charset: encoding.toLowerCase() + })) + } + + // read body + debug('read body') + getBody(stream, opts, function (err, body) { + if (err) { + // default to 400 + setErrorStatus(err, 400) + + // echo back charset + if (err.type === 'encoding.unsupported') { + err = createError(415, 'unsupported charset "' + encoding.toUpperCase() + '"', { + charset: encoding.toLowerCase() + }) + } + + // read off entire request + stream.resume() + onFinished(req, function onfinished () { + next(err) + }) + return + } + + // verify + if (verify) { + try { + debug('verify body') + verify(req, res, body, encoding) + } catch (err) { + // default to 403 + setErrorStatus(err, 403) + next(err) + return + } + } + + // parse + var str + try { + debug('parse body') + str = typeof body !== 'string' && encoding !== null + ? iconv.decode(body, encoding) + : body + req.body = parse(str) + } catch (err) { + err.body = str === undefined + ? body + : str + + // default to 400 + setErrorStatus(err, 400) + + next(err) + return + } + + next() + }) +} + +/** + * Get the content stream of the request. + * + * @param {object} req + * @param {function} debug + * @param {boolean} [inflate=true] + * @return {object} + * @api private + */ + +function contentstream (req, debug, inflate) { + var encoding = (req.headers['content-encoding'] || 'identity').toLowerCase() + var length = req.headers['content-length'] + var stream + + debug('content-encoding "%s"', encoding) + + if (inflate === false && encoding !== 'identity') { + throw createError(415, 'content encoding unsupported') + } + + switch (encoding) { + case 'deflate': + stream = zlib.createInflate() + debug('inflate body') + req.pipe(stream) + break + case 'gzip': + stream = zlib.createGunzip() + debug('gunzip body') + req.pipe(stream) + break + case 'identity': + stream = req + stream.length = length + break + default: + throw createError(415, 'unsupported content encoding "' + encoding + '"', { + encoding: encoding + }) + } + + return stream +} + +/** + * Set a status on an error object, if ones does not exist + * @private + */ + +function setErrorStatus (error, status) { + if (!error.status && !error.statusCode) { + error.status = status + error.statusCode = status + } +} diff --git a/node_modules/body-parser/lib/types/json.js b/node_modules/body-parser/lib/types/json.js new file mode 100644 index 0000000..d0023c7 --- /dev/null +++ b/node_modules/body-parser/lib/types/json.js @@ -0,0 +1,175 @@ +/*! + * body-parser + * Copyright(c) 2014 Jonathan Ong + * Copyright(c) 2014-2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module dependencies. + * @private + */ + +var bytes = require('bytes') +var contentType = require('content-type') +var createError = require('http-errors') +var debug = require('debug')('body-parser:json') +var read = require('../read') +var typeis = require('type-is') + +/** + * Module exports. + */ + +module.exports = json + +/** + * RegExp to match the first non-space in a string. + * + * Allowed whitespace is defined in RFC 7159: + * + * ws = *( + * %x20 / ; Space + * %x09 / ; Horizontal tab + * %x0A / ; Line feed or New line + * %x0D ) ; Carriage return + */ + +var FIRST_CHAR_REGEXP = /^[\x20\x09\x0a\x0d]*(.)/ // eslint-disable-line no-control-regex + +/** + * Create a middleware to parse JSON bodies. + * + * @param {object} [options] + * @return {function} + * @public + */ + +function json (options) { + var opts = options || {} + + var limit = typeof opts.limit !== 'number' + ? bytes.parse(opts.limit || '100kb') + : opts.limit + var inflate = opts.inflate !== false + var reviver = opts.reviver + var strict = opts.strict !== false + var type = opts.type || 'application/json' + var verify = opts.verify || false + + if (verify !== false && typeof verify !== 'function') { + throw new TypeError('option verify must be function') + } + + // create the appropriate type checking function + var shouldParse = typeof type !== 'function' + ? typeChecker(type) + : type + + function parse (body) { + if (body.length === 0) { + // special-case empty json body, as it's a common client-side mistake + // TODO: maybe make this configurable or part of "strict" option + return {} + } + + if (strict) { + var first = firstchar(body) + + if (first !== '{' && first !== '[') { + debug('strict violation') + throw new SyntaxError('Unexpected token ' + first) + } + } + + debug('parse json') + return JSON.parse(body, reviver) + } + + return function jsonParser (req, res, next) { + if (req._body) { + debug('body already parsed') + next() + return + } + + req.body = req.body || {} + + // skip requests without bodies + if (!typeis.hasBody(req)) { + debug('skip empty body') + next() + return + } + + debug('content-type %j', req.headers['content-type']) + + // determine if request should be parsed + if (!shouldParse(req)) { + debug('skip parsing') + next() + return + } + + // assert charset per RFC 7159 sec 8.1 + var charset = getCharset(req) || 'utf-8' + if (charset.substr(0, 4) !== 'utf-') { + debug('invalid charset') + next(createError(415, 'unsupported charset "' + charset.toUpperCase() + '"', { + charset: charset + })) + return + } + + // read + read(req, res, next, parse, debug, { + encoding: charset, + inflate: inflate, + limit: limit, + verify: verify + }) + } +} + +/** + * Get the first non-whitespace character in a string. + * + * @param {string} str + * @return {function} + * @api public + */ + +function firstchar (str) { + var match = FIRST_CHAR_REGEXP.exec(str) + return match ? match[1] : '' +} + +/** + * Get the charset of a request. + * + * @param {object} req + * @api private + */ + +function getCharset (req) { + try { + return contentType.parse(req).parameters.charset.toLowerCase() + } catch (e) { + return undefined + } +} + +/** + * Get the simple type checker. + * + * @param {string} type + * @return {function} + */ + +function typeChecker (type) { + return function checkType (req) { + return Boolean(typeis(req, type)) + } +} diff --git a/node_modules/body-parser/lib/types/raw.js b/node_modules/body-parser/lib/types/raw.js new file mode 100644 index 0000000..f5d1b67 --- /dev/null +++ b/node_modules/body-parser/lib/types/raw.js @@ -0,0 +1,101 @@ +/*! + * body-parser + * Copyright(c) 2014-2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module dependencies. + */ + +var bytes = require('bytes') +var debug = require('debug')('body-parser:raw') +var read = require('../read') +var typeis = require('type-is') + +/** + * Module exports. + */ + +module.exports = raw + +/** + * Create a middleware to parse raw bodies. + * + * @param {object} [options] + * @return {function} + * @api public + */ + +function raw (options) { + var opts = options || {} + + var inflate = opts.inflate !== false + var limit = typeof opts.limit !== 'number' + ? bytes.parse(opts.limit || '100kb') + : opts.limit + var type = opts.type || 'application/octet-stream' + var verify = opts.verify || false + + if (verify !== false && typeof verify !== 'function') { + throw new TypeError('option verify must be function') + } + + // create the appropriate type checking function + var shouldParse = typeof type !== 'function' + ? typeChecker(type) + : type + + function parse (buf) { + return buf + } + + return function rawParser (req, res, next) { + if (req._body) { + debug('body already parsed') + next() + return + } + + req.body = req.body || {} + + // skip requests without bodies + if (!typeis.hasBody(req)) { + debug('skip empty body') + next() + return + } + + debug('content-type %j', req.headers['content-type']) + + // determine if request should be parsed + if (!shouldParse(req)) { + debug('skip parsing') + next() + return + } + + // read + read(req, res, next, parse, debug, { + encoding: null, + inflate: inflate, + limit: limit, + verify: verify + }) + } +} + +/** + * Get the simple type checker. + * + * @param {string} type + * @return {function} + */ + +function typeChecker (type) { + return function checkType (req) { + return Boolean(typeis(req, type)) + } +} diff --git a/node_modules/body-parser/lib/types/text.js b/node_modules/body-parser/lib/types/text.js new file mode 100644 index 0000000..8bf2637 --- /dev/null +++ b/node_modules/body-parser/lib/types/text.js @@ -0,0 +1,121 @@ +/*! + * body-parser + * Copyright(c) 2014-2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module dependencies. + */ + +var bytes = require('bytes') +var contentType = require('content-type') +var debug = require('debug')('body-parser:text') +var read = require('../read') +var typeis = require('type-is') + +/** + * Module exports. + */ + +module.exports = text + +/** + * Create a middleware to parse text bodies. + * + * @param {object} [options] + * @return {function} + * @api public + */ + +function text (options) { + var opts = options || {} + + var defaultCharset = opts.defaultCharset || 'utf-8' + var inflate = opts.inflate !== false + var limit = typeof opts.limit !== 'number' + ? bytes.parse(opts.limit || '100kb') + : opts.limit + var type = opts.type || 'text/plain' + var verify = opts.verify || false + + if (verify !== false && typeof verify !== 'function') { + throw new TypeError('option verify must be function') + } + + // create the appropriate type checking function + var shouldParse = typeof type !== 'function' + ? typeChecker(type) + : type + + function parse (buf) { + return buf + } + + return function textParser (req, res, next) { + if (req._body) { + debug('body already parsed') + next() + return + } + + req.body = req.body || {} + + // skip requests without bodies + if (!typeis.hasBody(req)) { + debug('skip empty body') + next() + return + } + + debug('content-type %j', req.headers['content-type']) + + // determine if request should be parsed + if (!shouldParse(req)) { + debug('skip parsing') + next() + return + } + + // get charset + var charset = getCharset(req) || defaultCharset + + // read + read(req, res, next, parse, debug, { + encoding: charset, + inflate: inflate, + limit: limit, + verify: verify + }) + } +} + +/** + * Get the charset of a request. + * + * @param {object} req + * @api private + */ + +function getCharset (req) { + try { + return contentType.parse(req).parameters.charset.toLowerCase() + } catch (e) { + return undefined + } +} + +/** + * Get the simple type checker. + * + * @param {string} type + * @return {function} + */ + +function typeChecker (type) { + return function checkType (req) { + return Boolean(typeis(req, type)) + } +} diff --git a/node_modules/body-parser/lib/types/urlencoded.js b/node_modules/body-parser/lib/types/urlencoded.js new file mode 100644 index 0000000..08157ae --- /dev/null +++ b/node_modules/body-parser/lib/types/urlencoded.js @@ -0,0 +1,279 @@ +/*! + * body-parser + * Copyright(c) 2014 Jonathan Ong + * Copyright(c) 2014-2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module dependencies. + * @private + */ + +var bytes = require('bytes') +var contentType = require('content-type') +var createError = require('http-errors') +var debug = require('debug')('body-parser:urlencoded') +var deprecate = require('depd')('body-parser') +var read = require('../read') +var typeis = require('type-is') + +/** + * Module exports. + */ + +module.exports = urlencoded + +/** + * Cache of parser modules. + */ + +var parsers = Object.create(null) + +/** + * Create a middleware to parse urlencoded bodies. + * + * @param {object} [options] + * @return {function} + * @public + */ + +function urlencoded (options) { + var opts = options || {} + + // notice because option default will flip in next major + if (opts.extended === undefined) { + deprecate('undefined extended: provide extended option') + } + + var extended = opts.extended !== false + var inflate = opts.inflate !== false + var limit = typeof opts.limit !== 'number' + ? bytes.parse(opts.limit || '100kb') + : opts.limit + var type = opts.type || 'application/x-www-form-urlencoded' + var verify = opts.verify || false + + if (verify !== false && typeof verify !== 'function') { + throw new TypeError('option verify must be function') + } + + // create the appropriate query parser + var queryparse = extended + ? extendedparser(opts) + : simpleparser(opts) + + // create the appropriate type checking function + var shouldParse = typeof type !== 'function' + ? typeChecker(type) + : type + + function parse (body) { + return body.length + ? queryparse(body) + : {} + } + + return function urlencodedParser (req, res, next) { + if (req._body) { + debug('body already parsed') + next() + return + } + + req.body = req.body || {} + + // skip requests without bodies + if (!typeis.hasBody(req)) { + debug('skip empty body') + next() + return + } + + debug('content-type %j', req.headers['content-type']) + + // determine if request should be parsed + if (!shouldParse(req)) { + debug('skip parsing') + next() + return + } + + // assert charset + var charset = getCharset(req) || 'utf-8' + if (charset !== 'utf-8') { + debug('invalid charset') + next(createError(415, 'unsupported charset "' + charset.toUpperCase() + '"', { + charset: charset + })) + return + } + + // read + read(req, res, next, parse, debug, { + debug: debug, + encoding: charset, + inflate: inflate, + limit: limit, + verify: verify + }) + } +} + +/** + * Get the extended query parser. + * + * @param {object} options + */ + +function extendedparser (options) { + var parameterLimit = options.parameterLimit !== undefined + ? options.parameterLimit + : 1000 + var parse = parser('qs') + + if (isNaN(parameterLimit) || parameterLimit < 1) { + throw new TypeError('option parameterLimit must be a positive number') + } + + if (isFinite(parameterLimit)) { + parameterLimit = parameterLimit | 0 + } + + return function queryparse (body) { + var paramCount = parameterCount(body, parameterLimit) + + if (paramCount === undefined) { + debug('too many parameters') + throw createError(413, 'too many parameters') + } + + var arrayLimit = Math.max(100, paramCount) + + debug('parse extended urlencoding') + return parse(body, { + allowPrototypes: true, + arrayLimit: arrayLimit, + depth: Infinity, + parameterLimit: parameterLimit + }) + } +} + +/** + * Get the charset of a request. + * + * @param {object} req + * @api private + */ + +function getCharset (req) { + try { + return contentType.parse(req).parameters.charset.toLowerCase() + } catch (e) { + return undefined + } +} + +/** + * Count the number of parameters, stopping once limit reached + * + * @param {string} body + * @param {number} limit + * @api private + */ + +function parameterCount (body, limit) { + var count = 0 + var index = 0 + + while ((index = body.indexOf('&', index)) !== -1) { + count++ + index++ + + if (count === limit) { + return undefined + } + } + + return count +} + +/** + * Get parser for module name dynamically. + * + * @param {string} name + * @return {function} + * @api private + */ + +function parser (name) { + var mod = parsers[name] + + if (mod !== undefined) { + return mod.parse + } + + // this uses a switch for static require analysis + switch (name) { + case 'qs': + mod = require('qs') + break + case 'querystring': + mod = require('querystring') + break + } + + // store to prevent invoking require() + parsers[name] = mod + + return mod.parse +} + +/** + * Get the simple query parser. + * + * @param {object} options + */ + +function simpleparser (options) { + var parameterLimit = options.parameterLimit !== undefined + ? options.parameterLimit + : 1000 + var parse = parser('querystring') + + if (isNaN(parameterLimit) || parameterLimit < 1) { + throw new TypeError('option parameterLimit must be a positive number') + } + + if (isFinite(parameterLimit)) { + parameterLimit = parameterLimit | 0 + } + + return function queryparse (body) { + var paramCount = parameterCount(body, parameterLimit) + + if (paramCount === undefined) { + debug('too many parameters') + throw createError(413, 'too many parameters') + } + + debug('parse urlencoding') + return parse(body, undefined, undefined, {maxKeys: parameterLimit}) + } +} + +/** + * Get the simple type checker. + * + * @param {string} type + * @return {function} + */ + +function typeChecker (type) { + return function checkType (req) { + return Boolean(typeis(req, type)) + } +} diff --git a/node_modules/body-parser/node_modules/bytes/History.md b/node_modules/body-parser/node_modules/bytes/History.md new file mode 100644 index 0000000..56932a4 --- /dev/null +++ b/node_modules/body-parser/node_modules/bytes/History.md @@ -0,0 +1,70 @@ +2.4.0 / 2016-06-01 +================== + + * Add option "unitSeparator" + +2.3.0 / 2016-02-15 +================== + + * Drop partial bytes on all parsed units + * Fix non-finite numbers to `.format` to return `null` + * Fix parsing byte string that looks like hex + * perf: hoist regular expressions + +2.2.0 / 2015-11-13 +================== + + * add option "decimalPlaces" + * add option "fixedDecimals" + +2.1.0 / 2015-05-21 +================== + + * add `.format` export + * add `.parse` export + +2.0.2 / 2015-05-20 +================== + + * remove map recreation + * remove unnecessary object construction + +2.0.1 / 2015-05-07 +================== + + * fix browserify require + * remove node.extend dependency + +2.0.0 / 2015-04-12 +================== + + * add option "case" + * add option "thousandsSeparator" + * return "null" on invalid parse input + * support proper round-trip: bytes(bytes(num)) === num + * units no longer case sensitive when parsing + +1.0.0 / 2014-05-05 +================== + + * add negative support. fixes #6 + +0.3.0 / 2014-03-19 +================== + + * added terabyte support + +0.2.1 / 2013-04-01 +================== + + * add .component + +0.2.0 / 2012-10-28 +================== + + * bytes(200).should.eql('200b') + +0.1.0 / 2012-07-04 +================== + + * add bytes to string conversion [yields] diff --git a/node_modules/body-parser/node_modules/bytes/LICENSE b/node_modules/body-parser/node_modules/bytes/LICENSE new file mode 100644 index 0000000..63e95a9 --- /dev/null +++ b/node_modules/body-parser/node_modules/bytes/LICENSE @@ -0,0 +1,23 @@ +(The MIT License) + +Copyright (c) 2012-2014 TJ Holowaychuk +Copyright (c) 2015 Jed Watson + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/body-parser/node_modules/bytes/Readme.md b/node_modules/body-parser/node_modules/bytes/Readme.md new file mode 100644 index 0000000..7465fde --- /dev/null +++ b/node_modules/body-parser/node_modules/bytes/Readme.md @@ -0,0 +1,114 @@ +# Bytes utility + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Build Status][travis-image]][travis-url] + +Utility to parse a string bytes (ex: `1TB`) to bytes (`1099511627776`) and vice-versa. + +## Usage + +```js +var bytes = require('bytes'); +``` + +#### bytes.format(number value, [options]): string|null + +Format the given value in bytes into a string. If the value is negative, it is kept as such. If it is a float, it is + rounded. + +**Arguments** + +| Name | Type | Description | +|---------|--------|--------------------| +| value | `number` | Value in bytes | +| options | `Object` | Conversion options | + +**Options** + +| Property | Type | Description | +|-------------------|--------|-----------------------------------------------------------------------------------------| +| decimalPlaces | `number`|`null` | Maximum number of decimal places to include in output. Default value to `2`. | +| fixedDecimals | `boolean`|`null` | Whether to always display the maximum number of decimal places. Default value to `false` | +| thousandsSeparator | `string`|`null` | Example of values: `' '`, `','` and `.`... Default value to `' '`. | +| unitSeparator | `string`|`null` | Separator to use between number and unit. Default value to `''`. | + +**Returns** + +| Name | Type | Description | +|---------|-------------|-------------------------| +| results | `string`|`null` | Return null upon error. String value otherwise. | + +**Example** + +```js +bytes(1024); +// output: '1kB' + +bytes(1000); +// output: '1000B' + +bytes(1000, {thousandsSeparator: ' '}); +// output: '1 000B' + +bytes(1024 * 1.7, {decimalPlaces: 0}); +// output: '2kB' + +bytes(1024, {unitSeparator: ' '}); +// output: '1 kB' + +``` + +#### bytes.parse(string value): number|null + +Parse the string value into an integer in bytes. If no unit is given, it is assumed the value is in bytes. + +Supported units and abbreviations are as follows and are case-insensitive: + + * "b" for bytes + * "kb" for kilobytes + * "mb" for megabytes + * "gb" for gigabytes + * "tb" for terabytes + +The units are in powers of two, not ten. This means 1kb = 1024b according to this parser. + +**Arguments** + +| Name | Type | Description | +|---------------|--------|--------------------| +| value | `string` | String to parse. | + +**Returns** + +| Name | Type | Description | +|---------|-------------|-------------------------| +| results | `number`|`null` | Return null upon error. Value in bytes otherwise. | + +**Example** + +```js +bytes('1kB'); +// output: 1024 + +bytes('1024'); +// output: 1024 +``` + +## Installation + +```bash +npm install bytes --save +component install visionmedia/bytes.js +``` + +## License + +[![npm](https://img.shields.io/npm/l/express.svg)](https://github.com/visionmedia/bytes.js/blob/master/LICENSE) + +[downloads-image]: https://img.shields.io/npm/dm/bytes.svg +[downloads-url]: https://npmjs.org/package/bytes +[npm-image]: https://img.shields.io/npm/v/bytes.svg +[npm-url]: https://npmjs.org/package/bytes +[travis-image]: https://img.shields.io/travis/visionmedia/bytes.js/master.svg +[travis-url]: https://travis-ci.org/visionmedia/bytes.js diff --git a/node_modules/body-parser/node_modules/bytes/index.js b/node_modules/body-parser/node_modules/bytes/index.js new file mode 100644 index 0000000..aa24231 --- /dev/null +++ b/node_modules/body-parser/node_modules/bytes/index.js @@ -0,0 +1,157 @@ +/*! + * bytes + * Copyright(c) 2012-2014 TJ Holowaychuk + * Copyright(c) 2015 Jed Watson + * MIT Licensed + */ + +'use strict'; + +/** + * Module exports. + * @public + */ + +module.exports = bytes; +module.exports.format = format; +module.exports.parse = parse; + +/** + * Module variables. + * @private + */ + +var formatThousandsRegExp = /\B(?=(\d{3})+(?!\d))/g; + +var formatDecimalsRegExp = /(?:\.0*|(\.[^0]+)0+)$/; + +var map = { + b: 1, + kb: 1 << 10, + mb: 1 << 20, + gb: 1 << 30, + tb: ((1 << 30) * 1024) +}; + +// TODO: use is-finite module? +var numberIsFinite = Number.isFinite || function (v) { return typeof v === 'number' && isFinite(v); }; + +var parseRegExp = /^((-|\+)?(\d+(?:\.\d+)?)) *(kb|mb|gb|tb)$/i; + +/** + * Convert the given value in bytes into a string or parse to string to an integer in bytes. + * + * @param {string|number} value + * @param {{ + * case: [string], + * decimalPlaces: [number] + * fixedDecimals: [boolean] + * thousandsSeparator: [string] + * unitSeparator: [string] + * }} [options] bytes options. + * + * @returns {string|number|null} + */ + +function bytes(value, options) { + if (typeof value === 'string') { + return parse(value); + } + + if (typeof value === 'number') { + return format(value, options); + } + + return null; +} + +/** + * Format the given value in bytes into a string. + * + * If the value is negative, it is kept as such. If it is a float, + * it is rounded. + * + * @param {number} value + * @param {object} [options] + * @param {number} [options.decimalPlaces=2] + * @param {number} [options.fixedDecimals=false] + * @param {string} [options.thousandsSeparator=] + * @param {string} [options.unitSeparator=] + * + * @returns {string|null} + * @public + */ + +function format(value, options) { + if (!numberIsFinite(value)) { + return null; + } + + var mag = Math.abs(value); + var thousandsSeparator = (options && options.thousandsSeparator) || ''; + var unitSeparator = (options && options.unitSeparator) || ''; + var decimalPlaces = (options && options.decimalPlaces !== undefined) ? options.decimalPlaces : 2; + var fixedDecimals = Boolean(options && options.fixedDecimals); + var unit = 'B'; + + if (mag >= map.tb) { + unit = 'TB'; + } else if (mag >= map.gb) { + unit = 'GB'; + } else if (mag >= map.mb) { + unit = 'MB'; + } else if (mag >= map.kb) { + unit = 'kB'; + } + + var val = value / map[unit.toLowerCase()]; + var str = val.toFixed(decimalPlaces); + + if (!fixedDecimals) { + str = str.replace(formatDecimalsRegExp, '$1'); + } + + if (thousandsSeparator) { + str = str.replace(formatThousandsRegExp, thousandsSeparator); + } + + return str + unitSeparator + unit; +} + +/** + * Parse the string value into an integer in bytes. + * + * If no unit is given, it is assumed the value is in bytes. + * + * @param {number|string} val + * + * @returns {number|null} + * @public + */ + +function parse(val) { + if (typeof val === 'number' && !isNaN(val)) { + return val; + } + + if (typeof val !== 'string') { + return null; + } + + // Test if the string passed is valid + var results = parseRegExp.exec(val); + var floatValue; + var unit = 'b'; + + if (!results) { + // Nothing could be extracted from the given string + floatValue = parseInt(val, 10); + unit = 'b' + } else { + // Retrieve the value and the unit + floatValue = parseFloat(results[1]); + unit = results[4].toLowerCase(); + } + + return Math.floor(map[unit] * floatValue); +} diff --git a/node_modules/body-parser/node_modules/bytes/package.json b/node_modules/body-parser/node_modules/bytes/package.json new file mode 100644 index 0000000..90869de --- /dev/null +++ b/node_modules/body-parser/node_modules/bytes/package.json @@ -0,0 +1,84 @@ +{ + "name": "bytes", + "description": "Utility to parse a string bytes to bytes and vice-versa", + "version": "2.4.0", + "author": { + "name": "TJ Holowaychuk", + "email": "tj@vision-media.ca", + "url": "http://tjholowaychuk.com" + }, + "contributors": [ + { + "name": "Jed Watson", + "email": "jed.watson@me.com" + }, + { + "name": "Théo FIDRY", + "email": "theo.fidry@gmail.com" + } + ], + "license": "MIT", + "keywords": [ + "byte", + "bytes", + "utility", + "parse", + "parser", + "convert", + "converter" + ], + "repository": { + "type": "git", + "url": "https://github.com/visionmedia/bytes.js" + }, + "component": { + "scripts": { + "bytes/index.js": "index.js" + } + }, + "devDependencies": { + "mocha": "1.21.5" + }, + "files": [ + "History.md", + "LICENSE", + "Readme.md", + "index.js" + ], + "scripts": { + "test": "mocha --check-leaks --reporter spec" + }, + "gitHead": "2a598442bdfa796df8d01a96cc54495cda550e70", + "bugs": { + "url": "https://github.com/visionmedia/bytes.js/issues" + }, + "homepage": "https://github.com/visionmedia/bytes.js", + "_id": "bytes@2.4.0", + "_shasum": "7d97196f9d5baf7f6935e25985549edd2a6c2339", + "_from": "bytes@2.4.0", + "_npmVersion": "1.4.28", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "maintainers": [ + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "tjholowaychuk", + "email": "tj@vision-media.ca" + } + ], + "dist": { + "shasum": "7d97196f9d5baf7f6935e25985549edd2a6c2339", + "tarball": "https://registry.npmjs.org/bytes/-/bytes-2.4.0.tgz" + }, + "_npmOperationalInternal": { + "host": "packages-16-east.internal.npmjs.com", + "tmp": "tmp/bytes-2.4.0.tgz_1464812473023_0.6271433881483972" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/bytes/-/bytes-2.4.0.tgz" +} diff --git a/node_modules/body-parser/node_modules/content-type/HISTORY.md b/node_modules/body-parser/node_modules/content-type/HISTORY.md new file mode 100644 index 0000000..01652ff --- /dev/null +++ b/node_modules/body-parser/node_modules/content-type/HISTORY.md @@ -0,0 +1,14 @@ +1.0.2 / 2016-05-09 +================== + + * perf: enable strict mode + +1.0.1 / 2015-02-13 +================== + + * Improve missing `Content-Type` header error message + +1.0.0 / 2015-02-01 +================== + + * Initial implementation, derived from `media-typer@0.3.0` diff --git a/node_modules/body-parser/node_modules/content-type/LICENSE b/node_modules/body-parser/node_modules/content-type/LICENSE new file mode 100644 index 0000000..34b1a2d --- /dev/null +++ b/node_modules/body-parser/node_modules/content-type/LICENSE @@ -0,0 +1,22 @@ +(The MIT License) + +Copyright (c) 2015 Douglas Christopher Wilson + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/body-parser/node_modules/content-type/README.md b/node_modules/body-parser/node_modules/content-type/README.md new file mode 100644 index 0000000..3ed6741 --- /dev/null +++ b/node_modules/body-parser/node_modules/content-type/README.md @@ -0,0 +1,92 @@ +# content-type + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Node.js Version][node-version-image]][node-version-url] +[![Build Status][travis-image]][travis-url] +[![Test Coverage][coveralls-image]][coveralls-url] + +Create and parse HTTP Content-Type header according to RFC 7231 + +## Installation + +```sh +$ npm install content-type +``` + +## API + +```js +var contentType = require('content-type') +``` + +### contentType.parse(string) + +```js +var obj = contentType.parse('image/svg+xml; charset=utf-8') +``` + +Parse a content type string. This will return an object with the following +properties (examples are shown for the string `'image/svg+xml; charset=utf-8'`): + + - `type`: The media type (the type and subtype, always lower case). + Example: `'image/svg+xml'` + + - `parameters`: An object of the parameters in the media type (name of parameter + always lower case). Example: `{charset: 'utf-8'}` + +Throws a `TypeError` if the string is missing or invalid. + +### contentType.parse(req) + +```js +var obj = contentType.parse(req) +``` + +Parse the `content-type` header from the given `req`. Short-cut for +`contentType.parse(req.headers['content-type'])`. + +Throws a `TypeError` if the `Content-Type` header is missing or invalid. + +### contentType.parse(res) + +```js +var obj = contentType.parse(res) +``` + +Parse the `content-type` header set on the given `res`. Short-cut for +`contentType.parse(res.getHeader('content-type'))`. + +Throws a `TypeError` if the `Content-Type` header is missing or invalid. + +### contentType.format(obj) + +```js +var str = contentType.format({type: 'image/svg+xml'}) +``` + +Format an object into a content type string. This will return a string of the +content type for the given object with the following properties (examples are +shown that produce the string `'image/svg+xml; charset=utf-8'`): + + - `type`: The media type (will be lower-cased). Example: `'image/svg+xml'` + + - `parameters`: An object of the parameters in the media type (name of the + parameter will be lower-cased). Example: `{charset: 'utf-8'}` + +Throws a `TypeError` if the object contains an invalid type or parameter names. + +## License + +[MIT](LICENSE) + +[npm-image]: https://img.shields.io/npm/v/content-type.svg +[npm-url]: https://npmjs.org/package/content-type +[node-version-image]: https://img.shields.io/node/v/content-type.svg +[node-version-url]: http://nodejs.org/download/ +[travis-image]: https://img.shields.io/travis/jshttp/content-type/master.svg +[travis-url]: https://travis-ci.org/jshttp/content-type +[coveralls-image]: https://img.shields.io/coveralls/jshttp/content-type/master.svg +[coveralls-url]: https://coveralls.io/r/jshttp/content-type +[downloads-image]: https://img.shields.io/npm/dm/content-type.svg +[downloads-url]: https://npmjs.org/package/content-type diff --git a/node_modules/body-parser/node_modules/content-type/index.js b/node_modules/body-parser/node_modules/content-type/index.js new file mode 100644 index 0000000..61ba6b5 --- /dev/null +++ b/node_modules/body-parser/node_modules/content-type/index.js @@ -0,0 +1,216 @@ +/*! + * content-type + * Copyright(c) 2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * RegExp to match *( ";" parameter ) in RFC 7231 sec 3.1.1.1 + * + * parameter = token "=" ( token / quoted-string ) + * token = 1*tchar + * tchar = "!" / "#" / "$" / "%" / "&" / "'" / "*" + * / "+" / "-" / "." / "^" / "_" / "`" / "|" / "~" + * / DIGIT / ALPHA + * ; any VCHAR, except delimiters + * quoted-string = DQUOTE *( qdtext / quoted-pair ) DQUOTE + * qdtext = HTAB / SP / %x21 / %x23-5B / %x5D-7E / obs-text + * obs-text = %x80-FF + * quoted-pair = "\" ( HTAB / SP / VCHAR / obs-text ) + */ +var paramRegExp = /; *([!#$%&'\*\+\-\.\^_`\|~0-9A-Za-z]+) *= *("(?:[\u000b\u0020\u0021\u0023-\u005b\u005d-\u007e\u0080-\u00ff]|\\[\u000b\u0020-\u00ff])*"|[!#$%&'\*\+\-\.\^_`\|~0-9A-Za-z]+) */g +var textRegExp = /^[\u000b\u0020-\u007e\u0080-\u00ff]+$/ +var tokenRegExp = /^[!#$%&'\*\+\-\.\^_`\|~0-9A-Za-z]+$/ + +/** + * RegExp to match quoted-pair in RFC 7230 sec 3.2.6 + * + * quoted-pair = "\" ( HTAB / SP / VCHAR / obs-text ) + * obs-text = %x80-FF + */ +var qescRegExp = /\\([\u000b\u0020-\u00ff])/g + +/** + * RegExp to match chars that must be quoted-pair in RFC 7230 sec 3.2.6 + */ +var quoteRegExp = /([\\"])/g + +/** + * RegExp to match type in RFC 6838 + * + * media-type = type "/" subtype + * type = token + * subtype = token + */ +var typeRegExp = /^[!#$%&'\*\+\-\.\^_`\|~0-9A-Za-z]+\/[!#$%&'\*\+\-\.\^_`\|~0-9A-Za-z]+$/ + +/** + * Module exports. + * @public + */ + +exports.format = format +exports.parse = parse + +/** + * Format object to media type. + * + * @param {object} obj + * @return {string} + * @public + */ + +function format(obj) { + if (!obj || typeof obj !== 'object') { + throw new TypeError('argument obj is required') + } + + var parameters = obj.parameters + var type = obj.type + + if (!type || !typeRegExp.test(type)) { + throw new TypeError('invalid type') + } + + var string = type + + // append parameters + if (parameters && typeof parameters === 'object') { + var param + var params = Object.keys(parameters).sort() + + for (var i = 0; i < params.length; i++) { + param = params[i] + + if (!tokenRegExp.test(param)) { + throw new TypeError('invalid parameter name') + } + + string += '; ' + param + '=' + qstring(parameters[param]) + } + } + + return string +} + +/** + * Parse media type to object. + * + * @param {string|object} string + * @return {Object} + * @public + */ + +function parse(string) { + if (!string) { + throw new TypeError('argument string is required') + } + + if (typeof string === 'object') { + // support req/res-like objects as argument + string = getcontenttype(string) + + if (typeof string !== 'string') { + throw new TypeError('content-type header is missing from object'); + } + } + + if (typeof string !== 'string') { + throw new TypeError('argument string is required to be a string') + } + + var index = string.indexOf(';') + var type = index !== -1 + ? string.substr(0, index).trim() + : string.trim() + + if (!typeRegExp.test(type)) { + throw new TypeError('invalid media type') + } + + var key + var match + var obj = new ContentType(type.toLowerCase()) + var value + + paramRegExp.lastIndex = index + + while (match = paramRegExp.exec(string)) { + if (match.index !== index) { + throw new TypeError('invalid parameter format') + } + + index += match[0].length + key = match[1].toLowerCase() + value = match[2] + + if (value[0] === '"') { + // remove quotes and escapes + value = value + .substr(1, value.length - 2) + .replace(qescRegExp, '$1') + } + + obj.parameters[key] = value + } + + if (index !== -1 && index !== string.length) { + throw new TypeError('invalid parameter format') + } + + return obj +} + +/** + * Get content-type from req/res objects. + * + * @param {object} + * @return {Object} + * @private + */ + +function getcontenttype(obj) { + if (typeof obj.getHeader === 'function') { + // res-like + return obj.getHeader('content-type') + } + + if (typeof obj.headers === 'object') { + // req-like + return obj.headers && obj.headers['content-type'] + } +} + +/** + * Quote a string if necessary. + * + * @param {string} val + * @return {string} + * @private + */ + +function qstring(val) { + var str = String(val) + + // no need to quote tokens + if (tokenRegExp.test(str)) { + return str + } + + if (str.length > 0 && !textRegExp.test(str)) { + throw new TypeError('invalid parameter value') + } + + return '"' + str.replace(quoteRegExp, '\\$1') + '"' +} + +/** + * Class to represent a content type. + * @private + */ +function ContentType(type) { + this.parameters = Object.create(null) + this.type = type +} diff --git a/node_modules/body-parser/node_modules/content-type/package.json b/node_modules/body-parser/node_modules/content-type/package.json new file mode 100644 index 0000000..aaa2211 --- /dev/null +++ b/node_modules/body-parser/node_modules/content-type/package.json @@ -0,0 +1,70 @@ +{ + "name": "content-type", + "description": "Create and parse HTTP Content-Type header", + "version": "1.0.2", + "author": { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + }, + "license": "MIT", + "keywords": [ + "content-type", + "http", + "req", + "res", + "rfc7231" + ], + "repository": { + "type": "git", + "url": "git+https://github.com/jshttp/content-type.git" + }, + "devDependencies": { + "istanbul": "0.4.3", + "mocha": "~1.21.5" + }, + "files": [ + "LICENSE", + "HISTORY.md", + "README.md", + "index.js" + ], + "engines": { + "node": ">= 0.6" + }, + "scripts": { + "test": "mocha --reporter spec --check-leaks --bail test/", + "test-ci": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter spec --check-leaks test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot --check-leaks test/" + }, + "gitHead": "8118763adfbbac80cf1254191889330aec8b8be7", + "bugs": { + "url": "https://github.com/jshttp/content-type/issues" + }, + "homepage": "https://github.com/jshttp/content-type#readme", + "_id": "content-type@1.0.2", + "_shasum": "b7d113aee7a8dd27bd21133c4dc2529df1721eed", + "_from": "content-type@>=1.0.2 <1.1.0", + "_npmVersion": "2.15.1", + "_nodeVersion": "4.4.3", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "dist": { + "shasum": "b7d113aee7a8dd27bd21133c4dc2529df1721eed", + "tarball": "https://registry.npmjs.org/content-type/-/content-type-1.0.2.tgz" + }, + "maintainers": [ + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + } + ], + "_npmOperationalInternal": { + "host": "packages-12-west.internal.npmjs.com", + "tmp": "tmp/content-type-1.0.2.tgz_1462852785748_0.5491233412176371" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/content-type/-/content-type-1.0.2.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/body-parser/node_modules/debug/.jshintrc b/node_modules/body-parser/node_modules/debug/.jshintrc new file mode 100644 index 0000000..299877f --- /dev/null +++ b/node_modules/body-parser/node_modules/debug/.jshintrc @@ -0,0 +1,3 @@ +{ + "laxbreak": true +} diff --git a/node_modules/body-parser/node_modules/debug/.npmignore b/node_modules/body-parser/node_modules/debug/.npmignore new file mode 100644 index 0000000..7e6163d --- /dev/null +++ b/node_modules/body-parser/node_modules/debug/.npmignore @@ -0,0 +1,6 @@ +support +test +examples +example +*.sock +dist diff --git a/node_modules/body-parser/node_modules/debug/History.md b/node_modules/body-parser/node_modules/debug/History.md new file mode 100644 index 0000000..854c971 --- /dev/null +++ b/node_modules/body-parser/node_modules/debug/History.md @@ -0,0 +1,195 @@ + +2.2.0 / 2015-05-09 +================== + + * package: update "ms" to v0.7.1 (#202, @dougwilson) + * README: add logging to file example (#193, @DanielOchoa) + * README: fixed a typo (#191, @amir-s) + * browser: expose `storage` (#190, @stephenmathieson) + * Makefile: add a `distclean` target (#189, @stephenmathieson) + +2.1.3 / 2015-03-13 +================== + + * Updated stdout/stderr example (#186) + * Updated example/stdout.js to match debug current behaviour + * Renamed example/stderr.js to stdout.js + * Update Readme.md (#184) + * replace high intensity foreground color for bold (#182, #183) + +2.1.2 / 2015-03-01 +================== + + * dist: recompile + * update "ms" to v0.7.0 + * package: update "browserify" to v9.0.3 + * component: fix "ms.js" repo location + * changed bower package name + * updated documentation about using debug in a browser + * fix: security error on safari (#167, #168, @yields) + +2.1.1 / 2014-12-29 +================== + + * browser: use `typeof` to check for `console` existence + * browser: check for `console.log` truthiness (fix IE 8/9) + * browser: add support for Chrome apps + * Readme: added Windows usage remarks + * Add `bower.json` to properly support bower install + +2.1.0 / 2014-10-15 +================== + + * node: implement `DEBUG_FD` env variable support + * package: update "browserify" to v6.1.0 + * package: add "license" field to package.json (#135, @panuhorsmalahti) + +2.0.0 / 2014-09-01 +================== + + * package: update "browserify" to v5.11.0 + * node: use stderr rather than stdout for logging (#29, @stephenmathieson) + +1.0.4 / 2014-07-15 +================== + + * dist: recompile + * example: remove `console.info()` log usage + * example: add "Content-Type" UTF-8 header to browser example + * browser: place %c marker after the space character + * browser: reset the "content" color via `color: inherit` + * browser: add colors support for Firefox >= v31 + * debug: prefer an instance `log()` function over the global one (#119) + * Readme: update documentation about styled console logs for FF v31 (#116, @wryk) + +1.0.3 / 2014-07-09 +================== + + * Add support for multiple wildcards in namespaces (#122, @seegno) + * browser: fix lint + +1.0.2 / 2014-06-10 +================== + + * browser: update color palette (#113, @gscottolson) + * common: make console logging function configurable (#108, @timoxley) + * node: fix %o colors on old node <= 0.8.x + * Makefile: find node path using shell/which (#109, @timoxley) + +1.0.1 / 2014-06-06 +================== + + * browser: use `removeItem()` to clear localStorage + * browser, node: don't set DEBUG if namespaces is undefined (#107, @leedm777) + * package: add "contributors" section + * node: fix comment typo + * README: list authors + +1.0.0 / 2014-06-04 +================== + + * make ms diff be global, not be scope + * debug: ignore empty strings in enable() + * node: make DEBUG_COLORS able to disable coloring + * *: export the `colors` array + * npmignore: don't publish the `dist` dir + * Makefile: refactor to use browserify + * package: add "browserify" as a dev dependency + * Readme: add Web Inspector Colors section + * node: reset terminal color for the debug content + * node: map "%o" to `util.inspect()` + * browser: map "%j" to `JSON.stringify()` + * debug: add custom "formatters" + * debug: use "ms" module for humanizing the diff + * Readme: add "bash" syntax highlighting + * browser: add Firebug color support + * browser: add colors for WebKit browsers + * node: apply log to `console` + * rewrite: abstract common logic for Node & browsers + * add .jshintrc file + +0.8.1 / 2014-04-14 +================== + + * package: re-add the "component" section + +0.8.0 / 2014-03-30 +================== + + * add `enable()` method for nodejs. Closes #27 + * change from stderr to stdout + * remove unnecessary index.js file + +0.7.4 / 2013-11-13 +================== + + * remove "browserify" key from package.json (fixes something in browserify) + +0.7.3 / 2013-10-30 +================== + + * fix: catch localStorage security error when cookies are blocked (Chrome) + * add debug(err) support. Closes #46 + * add .browser prop to package.json. Closes #42 + +0.7.2 / 2013-02-06 +================== + + * fix package.json + * fix: Mobile Safari (private mode) is broken with debug + * fix: Use unicode to send escape character to shell instead of octal to work with strict mode javascript + +0.7.1 / 2013-02-05 +================== + + * add repository URL to package.json + * add DEBUG_COLORED to force colored output + * add browserify support + * fix component. Closes #24 + +0.7.0 / 2012-05-04 +================== + + * Added .component to package.json + * Added debug.component.js build + +0.6.0 / 2012-03-16 +================== + + * Added support for "-" prefix in DEBUG [Vinay Pulim] + * Added `.enabled` flag to the node version [TooTallNate] + +0.5.0 / 2012-02-02 +================== + + * Added: humanize diffs. Closes #8 + * Added `debug.disable()` to the CS variant + * Removed padding. Closes #10 + * Fixed: persist client-side variant again. Closes #9 + +0.4.0 / 2012-02-01 +================== + + * Added browser variant support for older browsers [TooTallNate] + * Added `debug.enable('project:*')` to browser variant [TooTallNate] + * Added padding to diff (moved it to the right) + +0.3.0 / 2012-01-26 +================== + + * Added millisecond diff when isatty, otherwise UTC string + +0.2.0 / 2012-01-22 +================== + + * Added wildcard support + +0.1.0 / 2011-12-02 +================== + + * Added: remove colors unless stderr isatty [TooTallNate] + +0.0.1 / 2010-01-03 +================== + + * Initial release diff --git a/node_modules/body-parser/node_modules/debug/Makefile b/node_modules/body-parser/node_modules/debug/Makefile new file mode 100644 index 0000000..5cf4a59 --- /dev/null +++ b/node_modules/body-parser/node_modules/debug/Makefile @@ -0,0 +1,36 @@ + +# get Makefile directory name: http://stackoverflow.com/a/5982798/376773 +THIS_MAKEFILE_PATH:=$(word $(words $(MAKEFILE_LIST)),$(MAKEFILE_LIST)) +THIS_DIR:=$(shell cd $(dir $(THIS_MAKEFILE_PATH));pwd) + +# BIN directory +BIN := $(THIS_DIR)/node_modules/.bin + +# applications +NODE ?= $(shell which node) +NPM ?= $(NODE) $(shell which npm) +BROWSERIFY ?= $(NODE) $(BIN)/browserify + +all: dist/debug.js + +install: node_modules + +clean: + @rm -rf dist + +dist: + @mkdir -p $@ + +dist/debug.js: node_modules browser.js debug.js dist + @$(BROWSERIFY) \ + --standalone debug \ + . > $@ + +distclean: clean + @rm -rf node_modules + +node_modules: package.json + @NODE_ENV= $(NPM) install + @touch node_modules + +.PHONY: all install clean distclean diff --git a/node_modules/body-parser/node_modules/debug/Readme.md b/node_modules/body-parser/node_modules/debug/Readme.md new file mode 100644 index 0000000..b4f45e3 --- /dev/null +++ b/node_modules/body-parser/node_modules/debug/Readme.md @@ -0,0 +1,188 @@ +# debug + + tiny node.js debugging utility modelled after node core's debugging technique. + +## Installation + +```bash +$ npm install debug +``` + +## Usage + + With `debug` you simply invoke the exported function to generate your debug function, passing it a name which will determine if a noop function is returned, or a decorated `console.error`, so all of the `console` format string goodies you're used to work fine. A unique color is selected per-function for visibility. + +Example _app.js_: + +```js +var debug = require('debug')('http') + , http = require('http') + , name = 'My App'; + +// fake app + +debug('booting %s', name); + +http.createServer(function(req, res){ + debug(req.method + ' ' + req.url); + res.end('hello\n'); +}).listen(3000, function(){ + debug('listening'); +}); + +// fake worker of some kind + +require('./worker'); +``` + +Example _worker.js_: + +```js +var debug = require('debug')('worker'); + +setInterval(function(){ + debug('doing some work'); +}, 1000); +``` + + The __DEBUG__ environment variable is then used to enable these based on space or comma-delimited names. Here are some examples: + + ![debug http and worker](http://f.cl.ly/items/18471z1H402O24072r1J/Screenshot.png) + + ![debug worker](http://f.cl.ly/items/1X413v1a3M0d3C2c1E0i/Screenshot.png) + +#### Windows note + + On Windows the environment variable is set using the `set` command. + + ```cmd + set DEBUG=*,-not_this + ``` + +Then, run the program to be debugged as usual. + +## Millisecond diff + + When actively developing an application it can be useful to see when the time spent between one `debug()` call and the next. Suppose for example you invoke `debug()` before requesting a resource, and after as well, the "+NNNms" will show you how much time was spent between calls. + + ![](http://f.cl.ly/items/2i3h1d3t121M2Z1A3Q0N/Screenshot.png) + + When stdout is not a TTY, `Date#toUTCString()` is used, making it more useful for logging the debug information as shown below: + + ![](http://f.cl.ly/items/112H3i0e0o0P0a2Q2r11/Screenshot.png) + +## Conventions + + If you're using this in one or more of your libraries, you _should_ use the name of your library so that developers may toggle debugging as desired without guessing names. If you have more than one debuggers you _should_ prefix them with your library name and use ":" to separate features. For example "bodyParser" from Connect would then be "connect:bodyParser". + +## Wildcards + + The `*` character may be used as a wildcard. Suppose for example your library has debuggers named "connect:bodyParser", "connect:compress", "connect:session", instead of listing all three with `DEBUG=connect:bodyParser,connect:compress,connect:session`, you may simply do `DEBUG=connect:*`, or to run everything using this module simply use `DEBUG=*`. + + You can also exclude specific debuggers by prefixing them with a "-" character. For example, `DEBUG=*,-connect:*` would include all debuggers except those starting with "connect:". + +## Browser support + + Debug works in the browser as well, currently persisted by `localStorage`. Consider the situation shown below where you have `worker:a` and `worker:b`, and wish to debug both. Somewhere in the code on your page, include: + +```js +window.myDebug = require("debug"); +``` + + ("debug" is a global object in the browser so we give this object a different name.) When your page is open in the browser, type the following in the console: + +```js +myDebug.enable("worker:*") +``` + + Refresh the page. Debug output will continue to be sent to the console until it is disabled by typing `myDebug.disable()` in the console. + +```js +a = debug('worker:a'); +b = debug('worker:b'); + +setInterval(function(){ + a('doing some work'); +}, 1000); + +setInterval(function(){ + b('doing some work'); +}, 1200); +``` + +#### Web Inspector Colors + + Colors are also enabled on "Web Inspectors" that understand the `%c` formatting + option. These are WebKit web inspectors, Firefox ([since version + 31](https://hacks.mozilla.org/2014/05/editable-box-model-multiple-selection-sublime-text-keys-much-more-firefox-developer-tools-episode-31/)) + and the Firebug plugin for Firefox (any version). + + Colored output looks something like: + + ![](https://cloud.githubusercontent.com/assets/71256/3139768/b98c5fd8-e8ef-11e3-862a-f7253b6f47c6.png) + +### stderr vs stdout + +You can set an alternative logging method per-namespace by overriding the `log` method on a per-namespace or globally: + +Example _stdout.js_: + +```js +var debug = require('debug'); +var error = debug('app:error'); + +// by default stderr is used +error('goes to stderr!'); + +var log = debug('app:log'); +// set this namespace to log via console.log +log.log = console.log.bind(console); // don't forget to bind to console! +log('goes to stdout'); +error('still goes to stderr!'); + +// set all output to go via console.info +// overrides all per-namespace log settings +debug.log = console.info.bind(console); +error('now goes to stdout via console.info'); +log('still goes to stdout, but via console.info now'); +``` + +### Save debug output to a file + +You can save all debug statements to a file by piping them. + +Example: + +```bash +$ DEBUG_FD=3 node your-app.js 3> whatever.log +``` + +## Authors + + - TJ Holowaychuk + - Nathan Rajlich + +## License + +(The MIT License) + +Copyright (c) 2014 TJ Holowaychuk <tj@vision-media.ca> + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/body-parser/node_modules/debug/bower.json b/node_modules/body-parser/node_modules/debug/bower.json new file mode 100644 index 0000000..6af573f --- /dev/null +++ b/node_modules/body-parser/node_modules/debug/bower.json @@ -0,0 +1,28 @@ +{ + "name": "visionmedia-debug", + "main": "dist/debug.js", + "version": "2.2.0", + "homepage": "https://github.com/visionmedia/debug", + "authors": [ + "TJ Holowaychuk " + ], + "description": "visionmedia-debug", + "moduleType": [ + "amd", + "es6", + "globals", + "node" + ], + "keywords": [ + "visionmedia", + "debug" + ], + "license": "MIT", + "ignore": [ + "**/.*", + "node_modules", + "bower_components", + "test", + "tests" + ] +} diff --git a/node_modules/body-parser/node_modules/debug/browser.js b/node_modules/body-parser/node_modules/debug/browser.js new file mode 100644 index 0000000..7c76452 --- /dev/null +++ b/node_modules/body-parser/node_modules/debug/browser.js @@ -0,0 +1,168 @@ + +/** + * This is the web browser implementation of `debug()`. + * + * Expose `debug()` as the module. + */ + +exports = module.exports = require('./debug'); +exports.log = log; +exports.formatArgs = formatArgs; +exports.save = save; +exports.load = load; +exports.useColors = useColors; +exports.storage = 'undefined' != typeof chrome + && 'undefined' != typeof chrome.storage + ? chrome.storage.local + : localstorage(); + +/** + * Colors. + */ + +exports.colors = [ + 'lightseagreen', + 'forestgreen', + 'goldenrod', + 'dodgerblue', + 'darkorchid', + 'crimson' +]; + +/** + * Currently only WebKit-based Web Inspectors, Firefox >= v31, + * and the Firebug extension (any Firefox version) are known + * to support "%c" CSS customizations. + * + * TODO: add a `localStorage` variable to explicitly enable/disable colors + */ + +function useColors() { + // is webkit? http://stackoverflow.com/a/16459606/376773 + return ('WebkitAppearance' in document.documentElement.style) || + // is firebug? http://stackoverflow.com/a/398120/376773 + (window.console && (console.firebug || (console.exception && console.table))) || + // is firefox >= v31? + // https://developer.mozilla.org/en-US/docs/Tools/Web_Console#Styling_messages + (navigator.userAgent.toLowerCase().match(/firefox\/(\d+)/) && parseInt(RegExp.$1, 10) >= 31); +} + +/** + * Map %j to `JSON.stringify()`, since no Web Inspectors do that by default. + */ + +exports.formatters.j = function(v) { + return JSON.stringify(v); +}; + + +/** + * Colorize log arguments if enabled. + * + * @api public + */ + +function formatArgs() { + var args = arguments; + var useColors = this.useColors; + + args[0] = (useColors ? '%c' : '') + + this.namespace + + (useColors ? ' %c' : ' ') + + args[0] + + (useColors ? '%c ' : ' ') + + '+' + exports.humanize(this.diff); + + if (!useColors) return args; + + var c = 'color: ' + this.color; + args = [args[0], c, 'color: inherit'].concat(Array.prototype.slice.call(args, 1)); + + // the final "%c" is somewhat tricky, because there could be other + // arguments passed either before or after the %c, so we need to + // figure out the correct index to insert the CSS into + var index = 0; + var lastC = 0; + args[0].replace(/%[a-z%]/g, function(match) { + if ('%%' === match) return; + index++; + if ('%c' === match) { + // we only are interested in the *last* %c + // (the user may have provided their own) + lastC = index; + } + }); + + args.splice(lastC, 0, c); + return args; +} + +/** + * Invokes `console.log()` when available. + * No-op when `console.log` is not a "function". + * + * @api public + */ + +function log() { + // this hackery is required for IE8/9, where + // the `console.log` function doesn't have 'apply' + return 'object' === typeof console + && console.log + && Function.prototype.apply.call(console.log, console, arguments); +} + +/** + * Save `namespaces`. + * + * @param {String} namespaces + * @api private + */ + +function save(namespaces) { + try { + if (null == namespaces) { + exports.storage.removeItem('debug'); + } else { + exports.storage.debug = namespaces; + } + } catch(e) {} +} + +/** + * Load `namespaces`. + * + * @return {String} returns the previously persisted debug modes + * @api private + */ + +function load() { + var r; + try { + r = exports.storage.debug; + } catch(e) {} + return r; +} + +/** + * Enable namespaces listed in `localStorage.debug` initially. + */ + +exports.enable(load()); + +/** + * Localstorage attempts to return the localstorage. + * + * This is necessary because safari throws + * when a user disables cookies/localstorage + * and you attempt to access it. + * + * @return {LocalStorage} + * @api private + */ + +function localstorage(){ + try { + return window.localStorage; + } catch (e) {} +} diff --git a/node_modules/body-parser/node_modules/debug/component.json b/node_modules/body-parser/node_modules/debug/component.json new file mode 100644 index 0000000..ca10637 --- /dev/null +++ b/node_modules/body-parser/node_modules/debug/component.json @@ -0,0 +1,19 @@ +{ + "name": "debug", + "repo": "visionmedia/debug", + "description": "small debugging utility", + "version": "2.2.0", + "keywords": [ + "debug", + "log", + "debugger" + ], + "main": "browser.js", + "scripts": [ + "browser.js", + "debug.js" + ], + "dependencies": { + "rauchg/ms.js": "0.7.1" + } +} diff --git a/node_modules/body-parser/node_modules/debug/debug.js b/node_modules/body-parser/node_modules/debug/debug.js new file mode 100644 index 0000000..7571a86 --- /dev/null +++ b/node_modules/body-parser/node_modules/debug/debug.js @@ -0,0 +1,197 @@ + +/** + * This is the common logic for both the Node.js and web browser + * implementations of `debug()`. + * + * Expose `debug()` as the module. + */ + +exports = module.exports = debug; +exports.coerce = coerce; +exports.disable = disable; +exports.enable = enable; +exports.enabled = enabled; +exports.humanize = require('ms'); + +/** + * The currently active debug mode names, and names to skip. + */ + +exports.names = []; +exports.skips = []; + +/** + * Map of special "%n" handling functions, for the debug "format" argument. + * + * Valid key names are a single, lowercased letter, i.e. "n". + */ + +exports.formatters = {}; + +/** + * Previously assigned color. + */ + +var prevColor = 0; + +/** + * Previous log timestamp. + */ + +var prevTime; + +/** + * Select a color. + * + * @return {Number} + * @api private + */ + +function selectColor() { + return exports.colors[prevColor++ % exports.colors.length]; +} + +/** + * Create a debugger with the given `namespace`. + * + * @param {String} namespace + * @return {Function} + * @api public + */ + +function debug(namespace) { + + // define the `disabled` version + function disabled() { + } + disabled.enabled = false; + + // define the `enabled` version + function enabled() { + + var self = enabled; + + // set `diff` timestamp + var curr = +new Date(); + var ms = curr - (prevTime || curr); + self.diff = ms; + self.prev = prevTime; + self.curr = curr; + prevTime = curr; + + // add the `color` if not set + if (null == self.useColors) self.useColors = exports.useColors(); + if (null == self.color && self.useColors) self.color = selectColor(); + + var args = Array.prototype.slice.call(arguments); + + args[0] = exports.coerce(args[0]); + + if ('string' !== typeof args[0]) { + // anything else let's inspect with %o + args = ['%o'].concat(args); + } + + // apply any `formatters` transformations + var index = 0; + args[0] = args[0].replace(/%([a-z%])/g, function(match, format) { + // if we encounter an escaped % then don't increase the array index + if (match === '%%') return match; + index++; + var formatter = exports.formatters[format]; + if ('function' === typeof formatter) { + var val = args[index]; + match = formatter.call(self, val); + + // now we need to remove `args[index]` since it's inlined in the `format` + args.splice(index, 1); + index--; + } + return match; + }); + + if ('function' === typeof exports.formatArgs) { + args = exports.formatArgs.apply(self, args); + } + var logFn = enabled.log || exports.log || console.log.bind(console); + logFn.apply(self, args); + } + enabled.enabled = true; + + var fn = exports.enabled(namespace) ? enabled : disabled; + + fn.namespace = namespace; + + return fn; +} + +/** + * Enables a debug mode by namespaces. This can include modes + * separated by a colon and wildcards. + * + * @param {String} namespaces + * @api public + */ + +function enable(namespaces) { + exports.save(namespaces); + + var split = (namespaces || '').split(/[\s,]+/); + var len = split.length; + + for (var i = 0; i < len; i++) { + if (!split[i]) continue; // ignore empty strings + namespaces = split[i].replace(/\*/g, '.*?'); + if (namespaces[0] === '-') { + exports.skips.push(new RegExp('^' + namespaces.substr(1) + '$')); + } else { + exports.names.push(new RegExp('^' + namespaces + '$')); + } + } +} + +/** + * Disable debug output. + * + * @api public + */ + +function disable() { + exports.enable(''); +} + +/** + * Returns true if the given mode name is enabled, false otherwise. + * + * @param {String} name + * @return {Boolean} + * @api public + */ + +function enabled(name) { + var i, len; + for (i = 0, len = exports.skips.length; i < len; i++) { + if (exports.skips[i].test(name)) { + return false; + } + } + for (i = 0, len = exports.names.length; i < len; i++) { + if (exports.names[i].test(name)) { + return true; + } + } + return false; +} + +/** + * Coerce `val`. + * + * @param {Mixed} val + * @return {Mixed} + * @api private + */ + +function coerce(val) { + if (val instanceof Error) return val.stack || val.message; + return val; +} diff --git a/node_modules/body-parser/node_modules/debug/node.js b/node_modules/body-parser/node_modules/debug/node.js new file mode 100644 index 0000000..1d392a8 --- /dev/null +++ b/node_modules/body-parser/node_modules/debug/node.js @@ -0,0 +1,209 @@ + +/** + * Module dependencies. + */ + +var tty = require('tty'); +var util = require('util'); + +/** + * This is the Node.js implementation of `debug()`. + * + * Expose `debug()` as the module. + */ + +exports = module.exports = require('./debug'); +exports.log = log; +exports.formatArgs = formatArgs; +exports.save = save; +exports.load = load; +exports.useColors = useColors; + +/** + * Colors. + */ + +exports.colors = [6, 2, 3, 4, 5, 1]; + +/** + * The file descriptor to write the `debug()` calls to. + * Set the `DEBUG_FD` env variable to override with another value. i.e.: + * + * $ DEBUG_FD=3 node script.js 3>debug.log + */ + +var fd = parseInt(process.env.DEBUG_FD, 10) || 2; +var stream = 1 === fd ? process.stdout : + 2 === fd ? process.stderr : + createWritableStdioStream(fd); + +/** + * Is stdout a TTY? Colored output is enabled when `true`. + */ + +function useColors() { + var debugColors = (process.env.DEBUG_COLORS || '').trim().toLowerCase(); + if (0 === debugColors.length) { + return tty.isatty(fd); + } else { + return '0' !== debugColors + && 'no' !== debugColors + && 'false' !== debugColors + && 'disabled' !== debugColors; + } +} + +/** + * Map %o to `util.inspect()`, since Node doesn't do that out of the box. + */ + +var inspect = (4 === util.inspect.length ? + // node <= 0.8.x + function (v, colors) { + return util.inspect(v, void 0, void 0, colors); + } : + // node > 0.8.x + function (v, colors) { + return util.inspect(v, { colors: colors }); + } +); + +exports.formatters.o = function(v) { + return inspect(v, this.useColors) + .replace(/\s*\n\s*/g, ' '); +}; + +/** + * Adds ANSI color escape codes if enabled. + * + * @api public + */ + +function formatArgs() { + var args = arguments; + var useColors = this.useColors; + var name = this.namespace; + + if (useColors) { + var c = this.color; + + args[0] = ' \u001b[3' + c + ';1m' + name + ' ' + + '\u001b[0m' + + args[0] + '\u001b[3' + c + 'm' + + ' +' + exports.humanize(this.diff) + '\u001b[0m'; + } else { + args[0] = new Date().toUTCString() + + ' ' + name + ' ' + args[0]; + } + return args; +} + +/** + * Invokes `console.error()` with the specified arguments. + */ + +function log() { + return stream.write(util.format.apply(this, arguments) + '\n'); +} + +/** + * Save `namespaces`. + * + * @param {String} namespaces + * @api private + */ + +function save(namespaces) { + if (null == namespaces) { + // If you set a process.env field to null or undefined, it gets cast to the + // string 'null' or 'undefined'. Just delete instead. + delete process.env.DEBUG; + } else { + process.env.DEBUG = namespaces; + } +} + +/** + * Load `namespaces`. + * + * @return {String} returns the previously persisted debug modes + * @api private + */ + +function load() { + return process.env.DEBUG; +} + +/** + * Copied from `node/src/node.js`. + * + * XXX: It's lame that node doesn't expose this API out-of-the-box. It also + * relies on the undocumented `tty_wrap.guessHandleType()` which is also lame. + */ + +function createWritableStdioStream (fd) { + var stream; + var tty_wrap = process.binding('tty_wrap'); + + // Note stream._type is used for test-module-load-list.js + + switch (tty_wrap.guessHandleType(fd)) { + case 'TTY': + stream = new tty.WriteStream(fd); + stream._type = 'tty'; + + // Hack to have stream not keep the event loop alive. + // See https://github.com/joyent/node/issues/1726 + if (stream._handle && stream._handle.unref) { + stream._handle.unref(); + } + break; + + case 'FILE': + var fs = require('fs'); + stream = new fs.SyncWriteStream(fd, { autoClose: false }); + stream._type = 'fs'; + break; + + case 'PIPE': + case 'TCP': + var net = require('net'); + stream = new net.Socket({ + fd: fd, + readable: false, + writable: true + }); + + // FIXME Should probably have an option in net.Socket to create a + // stream from an existing fd which is writable only. But for now + // we'll just add this hack and set the `readable` member to false. + // Test: ./node test/fixtures/echo.js < /etc/passwd + stream.readable = false; + stream.read = null; + stream._type = 'pipe'; + + // FIXME Hack to have stream not keep the event loop alive. + // See https://github.com/joyent/node/issues/1726 + if (stream._handle && stream._handle.unref) { + stream._handle.unref(); + } + break; + + default: + // Probably an error on in uv_guess_handle() + throw new Error('Implement me. Unknown stream file type!'); + } + + // For supporting legacy API we put the FD here. + stream.fd = fd; + + stream._isStdio = true; + + return stream; +} + +/** + * Enable namespaces listed in `process.env.DEBUG` initially. + */ + +exports.enable(load()); diff --git a/node_modules/body-parser/node_modules/debug/node_modules/ms/.npmignore b/node_modules/body-parser/node_modules/debug/node_modules/ms/.npmignore new file mode 100644 index 0000000..d1aa0ce --- /dev/null +++ b/node_modules/body-parser/node_modules/debug/node_modules/ms/.npmignore @@ -0,0 +1,5 @@ +node_modules +test +History.md +Makefile +component.json diff --git a/node_modules/body-parser/node_modules/debug/node_modules/ms/History.md b/node_modules/body-parser/node_modules/debug/node_modules/ms/History.md new file mode 100644 index 0000000..32fdfc1 --- /dev/null +++ b/node_modules/body-parser/node_modules/debug/node_modules/ms/History.md @@ -0,0 +1,66 @@ + +0.7.1 / 2015-04-20 +================== + + * prevent extraordinary long inputs (@evilpacket) + * Fixed broken readme link + +0.7.0 / 2014-11-24 +================== + + * add time abbreviations, updated tests and readme for the new units + * fix example in the readme. + * add LICENSE file + +0.6.2 / 2013-12-05 +================== + + * Adding repository section to package.json to suppress warning from NPM. + +0.6.1 / 2013-05-10 +================== + + * fix singularization [visionmedia] + +0.6.0 / 2013-03-15 +================== + + * fix minutes + +0.5.1 / 2013-02-24 +================== + + * add component namespace + +0.5.0 / 2012-11-09 +================== + + * add short formatting as default and .long option + * add .license property to component.json + * add version to component.json + +0.4.0 / 2012-10-22 +================== + + * add rounding to fix crazy decimals + +0.3.0 / 2012-09-07 +================== + + * fix `ms()` [visionmedia] + +0.2.0 / 2012-09-03 +================== + + * add component.json [visionmedia] + * add days support [visionmedia] + * add hours support [visionmedia] + * add minutes support [visionmedia] + * add seconds support [visionmedia] + * add ms string support [visionmedia] + * refactor tests to facilitate ms(number) [visionmedia] + +0.1.0 / 2012-03-07 +================== + + * Initial release diff --git a/node_modules/body-parser/node_modules/debug/node_modules/ms/LICENSE b/node_modules/body-parser/node_modules/debug/node_modules/ms/LICENSE new file mode 100644 index 0000000..6c07561 --- /dev/null +++ b/node_modules/body-parser/node_modules/debug/node_modules/ms/LICENSE @@ -0,0 +1,20 @@ +(The MIT License) + +Copyright (c) 2014 Guillermo Rauch + +Permission is hereby granted, free of charge, to any person obtaining a copy of +this software and associated documentation files (the "Software"), to deal in +the Software without restriction, including without limitation the rights to +use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of +the Software, and to permit persons to whom the Software is furnished to do so, +subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS +FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR +COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER +IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN +CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/body-parser/node_modules/debug/node_modules/ms/README.md b/node_modules/body-parser/node_modules/debug/node_modules/ms/README.md new file mode 100644 index 0000000..9b4fd03 --- /dev/null +++ b/node_modules/body-parser/node_modules/debug/node_modules/ms/README.md @@ -0,0 +1,35 @@ +# ms.js: miliseconds conversion utility + +```js +ms('2 days') // 172800000 +ms('1d') // 86400000 +ms('10h') // 36000000 +ms('2.5 hrs') // 9000000 +ms('2h') // 7200000 +ms('1m') // 60000 +ms('5s') // 5000 +ms('100') // 100 +``` + +```js +ms(60000) // "1m" +ms(2 * 60000) // "2m" +ms(ms('10 hours')) // "10h" +``` + +```js +ms(60000, { long: true }) // "1 minute" +ms(2 * 60000, { long: true }) // "2 minutes" +ms(ms('10 hours'), { long: true }) // "10 hours" +``` + +- Node/Browser compatible. Published as [`ms`](https://www.npmjs.org/package/ms) in [NPM](http://nodejs.org/download). +- If a number is supplied to `ms`, a string with a unit is returned. +- If a string that contains the number is supplied, it returns it as +a number (e.g: it returns `100` for `'100'`). +- If you pass a string with a number and a valid unit, the number of +equivalent ms is returned. + +## License + +MIT diff --git a/node_modules/body-parser/node_modules/debug/node_modules/ms/index.js b/node_modules/body-parser/node_modules/debug/node_modules/ms/index.js new file mode 100644 index 0000000..4f92771 --- /dev/null +++ b/node_modules/body-parser/node_modules/debug/node_modules/ms/index.js @@ -0,0 +1,125 @@ +/** + * Helpers. + */ + +var s = 1000; +var m = s * 60; +var h = m * 60; +var d = h * 24; +var y = d * 365.25; + +/** + * Parse or format the given `val`. + * + * Options: + * + * - `long` verbose formatting [false] + * + * @param {String|Number} val + * @param {Object} options + * @return {String|Number} + * @api public + */ + +module.exports = function(val, options){ + options = options || {}; + if ('string' == typeof val) return parse(val); + return options.long + ? long(val) + : short(val); +}; + +/** + * Parse the given `str` and return milliseconds. + * + * @param {String} str + * @return {Number} + * @api private + */ + +function parse(str) { + str = '' + str; + if (str.length > 10000) return; + var match = /^((?:\d+)?\.?\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|years?|yrs?|y)?$/i.exec(str); + if (!match) return; + var n = parseFloat(match[1]); + var type = (match[2] || 'ms').toLowerCase(); + switch (type) { + case 'years': + case 'year': + case 'yrs': + case 'yr': + case 'y': + return n * y; + case 'days': + case 'day': + case 'd': + return n * d; + case 'hours': + case 'hour': + case 'hrs': + case 'hr': + case 'h': + return n * h; + case 'minutes': + case 'minute': + case 'mins': + case 'min': + case 'm': + return n * m; + case 'seconds': + case 'second': + case 'secs': + case 'sec': + case 's': + return n * s; + case 'milliseconds': + case 'millisecond': + case 'msecs': + case 'msec': + case 'ms': + return n; + } +} + +/** + * Short format for `ms`. + * + * @param {Number} ms + * @return {String} + * @api private + */ + +function short(ms) { + if (ms >= d) return Math.round(ms / d) + 'd'; + if (ms >= h) return Math.round(ms / h) + 'h'; + if (ms >= m) return Math.round(ms / m) + 'm'; + if (ms >= s) return Math.round(ms / s) + 's'; + return ms + 'ms'; +} + +/** + * Long format for `ms`. + * + * @param {Number} ms + * @return {String} + * @api private + */ + +function long(ms) { + return plural(ms, d, 'day') + || plural(ms, h, 'hour') + || plural(ms, m, 'minute') + || plural(ms, s, 'second') + || ms + ' ms'; +} + +/** + * Pluralization helper. + */ + +function plural(ms, n, name) { + if (ms < n) return; + if (ms < n * 1.5) return Math.floor(ms / n) + ' ' + name; + return Math.ceil(ms / n) + ' ' + name + 's'; +} diff --git a/node_modules/body-parser/node_modules/debug/node_modules/ms/package.json b/node_modules/body-parser/node_modules/debug/node_modules/ms/package.json new file mode 100644 index 0000000..64818de --- /dev/null +++ b/node_modules/body-parser/node_modules/debug/node_modules/ms/package.json @@ -0,0 +1,48 @@ +{ + "name": "ms", + "version": "0.7.1", + "description": "Tiny ms conversion utility", + "repository": { + "type": "git", + "url": "git://github.com/guille/ms.js.git" + }, + "main": "./index", + "devDependencies": { + "mocha": "*", + "expect.js": "*", + "serve": "*" + }, + "component": { + "scripts": { + "ms/index.js": "index.js" + } + }, + "gitHead": "713dcf26d9e6fd9dbc95affe7eff9783b7f1b909", + "bugs": { + "url": "https://github.com/guille/ms.js/issues" + }, + "homepage": "https://github.com/guille/ms.js", + "_id": "ms@0.7.1", + "scripts": {}, + "_shasum": "9cd13c03adbff25b65effde7ce864ee952017098", + "_from": "ms@0.7.1", + "_npmVersion": "2.7.5", + "_nodeVersion": "0.12.2", + "_npmUser": { + "name": "rauchg", + "email": "rauchg@gmail.com" + }, + "maintainers": [ + { + "name": "rauchg", + "email": "rauchg@gmail.com" + } + ], + "dist": { + "shasum": "9cd13c03adbff25b65effde7ce864ee952017098", + "tarball": "https://registry.npmjs.org/ms/-/ms-0.7.1.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/ms/-/ms-0.7.1.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/body-parser/node_modules/debug/package.json b/node_modules/body-parser/node_modules/debug/package.json new file mode 100644 index 0000000..5228b80 --- /dev/null +++ b/node_modules/body-parser/node_modules/debug/package.json @@ -0,0 +1,73 @@ +{ + "name": "debug", + "version": "2.2.0", + "repository": { + "type": "git", + "url": "git://github.com/visionmedia/debug.git" + }, + "description": "small debugging utility", + "keywords": [ + "debug", + "log", + "debugger" + ], + "author": { + "name": "TJ Holowaychuk", + "email": "tj@vision-media.ca" + }, + "contributors": [ + { + "name": "Nathan Rajlich", + "email": "nathan@tootallnate.net", + "url": "http://n8.io" + } + ], + "license": "MIT", + "dependencies": { + "ms": "0.7.1" + }, + "devDependencies": { + "browserify": "9.0.3", + "mocha": "*" + }, + "main": "./node.js", + "browser": "./browser.js", + "component": { + "scripts": { + "debug/index.js": "browser.js", + "debug/debug.js": "debug.js" + } + }, + "gitHead": "b38458422b5aa8aa6d286b10dfe427e8a67e2b35", + "bugs": { + "url": "https://github.com/visionmedia/debug/issues" + }, + "homepage": "https://github.com/visionmedia/debug", + "_id": "debug@2.2.0", + "scripts": {}, + "_shasum": "f87057e995b1a1f6ae6a4960664137bc56f039da", + "_from": "debug@>=2.2.0 <2.3.0", + "_npmVersion": "2.7.4", + "_nodeVersion": "0.12.2", + "_npmUser": { + "name": "tootallnate", + "email": "nathan@tootallnate.net" + }, + "maintainers": [ + { + "name": "tjholowaychuk", + "email": "tj@vision-media.ca" + }, + { + "name": "tootallnate", + "email": "nathan@tootallnate.net" + } + ], + "dist": { + "shasum": "f87057e995b1a1f6ae6a4960664137bc56f039da", + "tarball": "https://registry.npmjs.org/debug/-/debug-2.2.0.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/debug/-/debug-2.2.0.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/body-parser/node_modules/depd/History.md b/node_modules/body-parser/node_modules/depd/History.md new file mode 100644 index 0000000..ace1171 --- /dev/null +++ b/node_modules/body-parser/node_modules/depd/History.md @@ -0,0 +1,84 @@ +1.1.0 / 2015-09-14 +================== + + * Enable strict mode in more places + * Support io.js 3.x + * Support io.js 2.x + * Support web browser loading + - Requires bundler like Browserify or webpack + +1.0.1 / 2015-04-07 +================== + + * Fix `TypeError`s when under `'use strict'` code + * Fix useless type name on auto-generated messages + * Support io.js 1.x + * Support Node.js 0.12 + +1.0.0 / 2014-09-17 +================== + + * No changes + +0.4.5 / 2014-09-09 +================== + + * Improve call speed to functions using the function wrapper + * Support Node.js 0.6 + +0.4.4 / 2014-07-27 +================== + + * Work-around v8 generating empty stack traces + +0.4.3 / 2014-07-26 +================== + + * Fix exception when global `Error.stackTraceLimit` is too low + +0.4.2 / 2014-07-19 +================== + + * Correct call site for wrapped functions and properties + +0.4.1 / 2014-07-19 +================== + + * Improve automatic message generation for function properties + +0.4.0 / 2014-07-19 +================== + + * Add `TRACE_DEPRECATION` environment variable + * Remove non-standard grey color from color output + * Support `--no-deprecation` argument + * Support `--trace-deprecation` argument + * Support `deprecate.property(fn, prop, message)` + +0.3.0 / 2014-06-16 +================== + + * Add `NO_DEPRECATION` environment variable + +0.2.0 / 2014-06-15 +================== + + * Add `deprecate.property(obj, prop, message)` + * Remove `supports-color` dependency for node.js 0.8 + +0.1.0 / 2014-06-15 +================== + + * Add `deprecate.function(fn, message)` + * Add `process.on('deprecation', fn)` emitter + * Automatically generate message when omitted from `deprecate()` + +0.0.1 / 2014-06-15 +================== + + * Fix warning for dynamic calls at singe call site + +0.0.0 / 2014-06-15 +================== + + * Initial implementation diff --git a/node_modules/body-parser/node_modules/depd/LICENSE b/node_modules/body-parser/node_modules/depd/LICENSE new file mode 100644 index 0000000..142ede3 --- /dev/null +++ b/node_modules/body-parser/node_modules/depd/LICENSE @@ -0,0 +1,22 @@ +(The MIT License) + +Copyright (c) 2014-2015 Douglas Christopher Wilson + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/body-parser/node_modules/depd/Readme.md b/node_modules/body-parser/node_modules/depd/Readme.md new file mode 100644 index 0000000..09bb979 --- /dev/null +++ b/node_modules/body-parser/node_modules/depd/Readme.md @@ -0,0 +1,281 @@ +# depd + +[![NPM Version][npm-version-image]][npm-url] +[![NPM Downloads][npm-downloads-image]][npm-url] +[![Node.js Version][node-image]][node-url] +[![Linux Build][travis-image]][travis-url] +[![Windows Build][appveyor-image]][appveyor-url] +[![Coverage Status][coveralls-image]][coveralls-url] +[![Gratipay][gratipay-image]][gratipay-url] + +Deprecate all the things + +> With great modules comes great responsibility; mark things deprecated! + +## Install + +This module is installed directly using `npm`: + +```sh +$ npm install depd +``` + +This module can also be bundled with systems like +[Browserify](http://browserify.org/) or [webpack](https://webpack.github.io/), +though by default this module will alter it's API to no longer display or +track deprecations. + +## API + +```js +var deprecate = require('depd')('my-module') +``` + +This library allows you to display deprecation messages to your users. +This library goes above and beyond with deprecation warnings by +introspection of the call stack (but only the bits that it is interested +in). + +Instead of just warning on the first invocation of a deprecated +function and never again, this module will warn on the first invocation +of a deprecated function per unique call site, making it ideal to alert +users of all deprecated uses across the code base, rather than just +whatever happens to execute first. + +The deprecation warnings from this module also include the file and line +information for the call into the module that the deprecated function was +in. + +**NOTE** this library has a similar interface to the `debug` module, and +this module uses the calling file to get the boundary for the call stacks, +so you should always create a new `deprecate` object in each file and not +within some central file. + +### depd(namespace) + +Create a new deprecate function that uses the given namespace name in the +messages and will display the call site prior to the stack entering the +file this function was called from. It is highly suggested you use the +name of your module as the namespace. + +### deprecate(message) + +Call this function from deprecated code to display a deprecation message. +This message will appear once per unique caller site. Caller site is the +first call site in the stack in a different file from the caller of this +function. + +If the message is omitted, a message is generated for you based on the site +of the `deprecate()` call and will display the name of the function called, +similar to the name displayed in a stack trace. + +### deprecate.function(fn, message) + +Call this function to wrap a given function in a deprecation message on any +call to the function. An optional message can be supplied to provide a custom +message. + +### deprecate.property(obj, prop, message) + +Call this function to wrap a given property on object in a deprecation message +on any accessing or setting of the property. An optional message can be supplied +to provide a custom message. + +The method must be called on the object where the property belongs (not +inherited from the prototype). + +If the property is a data descriptor, it will be converted to an accessor +descriptor in order to display the deprecation message. + +### process.on('deprecation', fn) + +This module will allow easy capturing of deprecation errors by emitting the +errors as the type "deprecation" on the global `process`. If there are no +listeners for this type, the errors are written to STDERR as normal, but if +there are any listeners, nothing will be written to STDERR and instead only +emitted. From there, you can write the errors in a different format or to a +logging source. + +The error represents the deprecation and is emitted only once with the same +rules as writing to STDERR. The error has the following properties: + + - `message` - This is the message given by the library + - `name` - This is always `'DeprecationError'` + - `namespace` - This is the namespace the deprecation came from + - `stack` - This is the stack of the call to the deprecated thing + +Example `error.stack` output: + +``` +DeprecationError: my-cool-module deprecated oldfunction + at Object. ([eval]-wrapper:6:22) + at Module._compile (module.js:456:26) + at evalScript (node.js:532:25) + at startup (node.js:80:7) + at node.js:902:3 +``` + +### process.env.NO_DEPRECATION + +As a user of modules that are deprecated, the environment variable `NO_DEPRECATION` +is provided as a quick solution to silencing deprecation warnings from being +output. The format of this is similar to that of `DEBUG`: + +```sh +$ NO_DEPRECATION=my-module,othermod node app.js +``` + +This will suppress deprecations from being output for "my-module" and "othermod". +The value is a list of comma-separated namespaces. To suppress every warning +across all namespaces, use the value `*` for a namespace. + +Providing the argument `--no-deprecation` to the `node` executable will suppress +all deprecations (only available in Node.js 0.8 or higher). + +**NOTE** This will not suppress the deperecations given to any "deprecation" +event listeners, just the output to STDERR. + +### process.env.TRACE_DEPRECATION + +As a user of modules that are deprecated, the environment variable `TRACE_DEPRECATION` +is provided as a solution to getting more detailed location information in deprecation +warnings by including the entire stack trace. The format of this is the same as +`NO_DEPRECATION`: + +```sh +$ TRACE_DEPRECATION=my-module,othermod node app.js +``` + +This will include stack traces for deprecations being output for "my-module" and +"othermod". The value is a list of comma-separated namespaces. To trace every +warning across all namespaces, use the value `*` for a namespace. + +Providing the argument `--trace-deprecation` to the `node` executable will trace +all deprecations (only available in Node.js 0.8 or higher). + +**NOTE** This will not trace the deperecations silenced by `NO_DEPRECATION`. + +## Display + +![message](files/message.png) + +When a user calls a function in your library that you mark deprecated, they +will see the following written to STDERR (in the given colors, similar colors +and layout to the `debug` module): + +``` +bright cyan bright yellow +| | reset cyan +| | | | +▼ ▼ ▼ ▼ +my-cool-module deprecated oldfunction [eval]-wrapper:6:22 +▲ ▲ ▲ ▲ +| | | | +namespace | | location of mycoolmod.oldfunction() call + | deprecation message + the word "deprecated" +``` + +If the user redirects their STDERR to a file or somewhere that does not support +colors, they see (similar layout to the `debug` module): + +``` +Sun, 15 Jun 2014 05:21:37 GMT my-cool-module deprecated oldfunction at [eval]-wrapper:6:22 +▲ ▲ ▲ ▲ ▲ +| | | | | +timestamp of message namespace | | location of mycoolmod.oldfunction() call + | deprecation message + the word "deprecated" +``` + +## Examples + +### Deprecating all calls to a function + +This will display a deprecated message about "oldfunction" being deprecated +from "my-module" on STDERR. + +```js +var deprecate = require('depd')('my-cool-module') + +// message automatically derived from function name +// Object.oldfunction +exports.oldfunction = deprecate.function(function oldfunction() { + // all calls to function are deprecated +}) + +// specific message +exports.oldfunction = deprecate.function(function () { + // all calls to function are deprecated +}, 'oldfunction') +``` + +### Conditionally deprecating a function call + +This will display a deprecated message about "weirdfunction" being deprecated +from "my-module" on STDERR when called with less than 2 arguments. + +```js +var deprecate = require('depd')('my-cool-module') + +exports.weirdfunction = function () { + if (arguments.length < 2) { + // calls with 0 or 1 args are deprecated + deprecate('weirdfunction args < 2') + } +} +``` + +When calling `deprecate` as a function, the warning is counted per call site +within your own module, so you can display different deprecations depending +on different situations and the users will still get all the warnings: + +```js +var deprecate = require('depd')('my-cool-module') + +exports.weirdfunction = function () { + if (arguments.length < 2) { + // calls with 0 or 1 args are deprecated + deprecate('weirdfunction args < 2') + } else if (typeof arguments[0] !== 'string') { + // calls with non-string first argument are deprecated + deprecate('weirdfunction non-string first arg') + } +} +``` + +### Deprecating property access + +This will display a deprecated message about "oldprop" being deprecated +from "my-module" on STDERR when accessed. A deprecation will be displayed +when setting the value and when getting the value. + +```js +var deprecate = require('depd')('my-cool-module') + +exports.oldprop = 'something' + +// message automatically derives from property name +deprecate.property(exports, 'oldprop') + +// explicit message +deprecate.property(exports, 'oldprop', 'oldprop >= 0.10') +``` + +## License + +[MIT](LICENSE) + +[npm-version-image]: https://img.shields.io/npm/v/depd.svg +[npm-downloads-image]: https://img.shields.io/npm/dm/depd.svg +[npm-url]: https://npmjs.org/package/depd +[travis-image]: https://img.shields.io/travis/dougwilson/nodejs-depd/master.svg?label=linux +[travis-url]: https://travis-ci.org/dougwilson/nodejs-depd +[appveyor-image]: https://img.shields.io/appveyor/ci/dougwilson/nodejs-depd/master.svg?label=windows +[appveyor-url]: https://ci.appveyor.com/project/dougwilson/nodejs-depd +[coveralls-image]: https://img.shields.io/coveralls/dougwilson/nodejs-depd/master.svg +[coveralls-url]: https://coveralls.io/r/dougwilson/nodejs-depd?branch=master +[node-image]: https://img.shields.io/node/v/depd.svg +[node-url]: http://nodejs.org/download/ +[gratipay-image]: https://img.shields.io/gratipay/dougwilson.svg +[gratipay-url]: https://www.gratipay.com/dougwilson/ diff --git a/node_modules/body-parser/node_modules/depd/index.js b/node_modules/body-parser/node_modules/depd/index.js new file mode 100644 index 0000000..fddcae8 --- /dev/null +++ b/node_modules/body-parser/node_modules/depd/index.js @@ -0,0 +1,521 @@ +/*! + * depd + * Copyright(c) 2014-2015 Douglas Christopher Wilson + * MIT Licensed + */ + +/** + * Module dependencies. + */ + +var callSiteToString = require('./lib/compat').callSiteToString +var eventListenerCount = require('./lib/compat').eventListenerCount +var relative = require('path').relative + +/** + * Module exports. + */ + +module.exports = depd + +/** + * Get the path to base files on. + */ + +var basePath = process.cwd() + +/** + * Determine if namespace is contained in the string. + */ + +function containsNamespace(str, namespace) { + var val = str.split(/[ ,]+/) + + namespace = String(namespace).toLowerCase() + + for (var i = 0 ; i < val.length; i++) { + if (!(str = val[i])) continue; + + // namespace contained + if (str === '*' || str.toLowerCase() === namespace) { + return true + } + } + + return false +} + +/** + * Convert a data descriptor to accessor descriptor. + */ + +function convertDataDescriptorToAccessor(obj, prop, message) { + var descriptor = Object.getOwnPropertyDescriptor(obj, prop) + var value = descriptor.value + + descriptor.get = function getter() { return value } + + if (descriptor.writable) { + descriptor.set = function setter(val) { return value = val } + } + + delete descriptor.value + delete descriptor.writable + + Object.defineProperty(obj, prop, descriptor) + + return descriptor +} + +/** + * Create arguments string to keep arity. + */ + +function createArgumentsString(arity) { + var str = '' + + for (var i = 0; i < arity; i++) { + str += ', arg' + i + } + + return str.substr(2) +} + +/** + * Create stack string from stack. + */ + +function createStackString(stack) { + var str = this.name + ': ' + this.namespace + + if (this.message) { + str += ' deprecated ' + this.message + } + + for (var i = 0; i < stack.length; i++) { + str += '\n at ' + callSiteToString(stack[i]) + } + + return str +} + +/** + * Create deprecate for namespace in caller. + */ + +function depd(namespace) { + if (!namespace) { + throw new TypeError('argument namespace is required') + } + + var stack = getStack() + var site = callSiteLocation(stack[1]) + var file = site[0] + + function deprecate(message) { + // call to self as log + log.call(deprecate, message) + } + + deprecate._file = file + deprecate._ignored = isignored(namespace) + deprecate._namespace = namespace + deprecate._traced = istraced(namespace) + deprecate._warned = Object.create(null) + + deprecate.function = wrapfunction + deprecate.property = wrapproperty + + return deprecate +} + +/** + * Determine if namespace is ignored. + */ + +function isignored(namespace) { + /* istanbul ignore next: tested in a child processs */ + if (process.noDeprecation) { + // --no-deprecation support + return true + } + + var str = process.env.NO_DEPRECATION || '' + + // namespace ignored + return containsNamespace(str, namespace) +} + +/** + * Determine if namespace is traced. + */ + +function istraced(namespace) { + /* istanbul ignore next: tested in a child processs */ + if (process.traceDeprecation) { + // --trace-deprecation support + return true + } + + var str = process.env.TRACE_DEPRECATION || '' + + // namespace traced + return containsNamespace(str, namespace) +} + +/** + * Display deprecation message. + */ + +function log(message, site) { + var haslisteners = eventListenerCount(process, 'deprecation') !== 0 + + // abort early if no destination + if (!haslisteners && this._ignored) { + return + } + + var caller + var callFile + var callSite + var i = 0 + var seen = false + var stack = getStack() + var file = this._file + + if (site) { + // provided site + callSite = callSiteLocation(stack[1]) + callSite.name = site.name + file = callSite[0] + } else { + // get call site + i = 2 + site = callSiteLocation(stack[i]) + callSite = site + } + + // get caller of deprecated thing in relation to file + for (; i < stack.length; i++) { + caller = callSiteLocation(stack[i]) + callFile = caller[0] + + if (callFile === file) { + seen = true + } else if (callFile === this._file) { + file = this._file + } else if (seen) { + break + } + } + + var key = caller + ? site.join(':') + '__' + caller.join(':') + : undefined + + if (key !== undefined && key in this._warned) { + // already warned + return + } + + this._warned[key] = true + + // generate automatic message from call site + if (!message) { + message = callSite === site || !callSite.name + ? defaultMessage(site) + : defaultMessage(callSite) + } + + // emit deprecation if listeners exist + if (haslisteners) { + var err = DeprecationError(this._namespace, message, stack.slice(i)) + process.emit('deprecation', err) + return + } + + // format and write message + var format = process.stderr.isTTY + ? formatColor + : formatPlain + var msg = format.call(this, message, caller, stack.slice(i)) + process.stderr.write(msg + '\n', 'utf8') + + return +} + +/** + * Get call site location as array. + */ + +function callSiteLocation(callSite) { + var file = callSite.getFileName() || '' + var line = callSite.getLineNumber() + var colm = callSite.getColumnNumber() + + if (callSite.isEval()) { + file = callSite.getEvalOrigin() + ', ' + file + } + + var site = [file, line, colm] + + site.callSite = callSite + site.name = callSite.getFunctionName() + + return site +} + +/** + * Generate a default message from the site. + */ + +function defaultMessage(site) { + var callSite = site.callSite + var funcName = site.name + + // make useful anonymous name + if (!funcName) { + funcName = '' + } + + var context = callSite.getThis() + var typeName = context && callSite.getTypeName() + + // ignore useless type name + if (typeName === 'Object') { + typeName = undefined + } + + // make useful type name + if (typeName === 'Function') { + typeName = context.name || typeName + } + + return typeName && callSite.getMethodName() + ? typeName + '.' + funcName + : funcName +} + +/** + * Format deprecation message without color. + */ + +function formatPlain(msg, caller, stack) { + var timestamp = new Date().toUTCString() + + var formatted = timestamp + + ' ' + this._namespace + + ' deprecated ' + msg + + // add stack trace + if (this._traced) { + for (var i = 0; i < stack.length; i++) { + formatted += '\n at ' + callSiteToString(stack[i]) + } + + return formatted + } + + if (caller) { + formatted += ' at ' + formatLocation(caller) + } + + return formatted +} + +/** + * Format deprecation message with color. + */ + +function formatColor(msg, caller, stack) { + var formatted = '\x1b[36;1m' + this._namespace + '\x1b[22;39m' // bold cyan + + ' \x1b[33;1mdeprecated\x1b[22;39m' // bold yellow + + ' \x1b[0m' + msg + '\x1b[39m' // reset + + // add stack trace + if (this._traced) { + for (var i = 0; i < stack.length; i++) { + formatted += '\n \x1b[36mat ' + callSiteToString(stack[i]) + '\x1b[39m' // cyan + } + + return formatted + } + + if (caller) { + formatted += ' \x1b[36m' + formatLocation(caller) + '\x1b[39m' // cyan + } + + return formatted +} + +/** + * Format call site location. + */ + +function formatLocation(callSite) { + return relative(basePath, callSite[0]) + + ':' + callSite[1] + + ':' + callSite[2] +} + +/** + * Get the stack as array of call sites. + */ + +function getStack() { + var limit = Error.stackTraceLimit + var obj = {} + var prep = Error.prepareStackTrace + + Error.prepareStackTrace = prepareObjectStackTrace + Error.stackTraceLimit = Math.max(10, limit) + + // capture the stack + Error.captureStackTrace(obj) + + // slice this function off the top + var stack = obj.stack.slice(1) + + Error.prepareStackTrace = prep + Error.stackTraceLimit = limit + + return stack +} + +/** + * Capture call site stack from v8. + */ + +function prepareObjectStackTrace(obj, stack) { + return stack +} + +/** + * Return a wrapped function in a deprecation message. + */ + +function wrapfunction(fn, message) { + if (typeof fn !== 'function') { + throw new TypeError('argument fn must be a function') + } + + var args = createArgumentsString(fn.length) + var deprecate = this + var stack = getStack() + var site = callSiteLocation(stack[1]) + + site.name = fn.name + + var deprecatedfn = eval('(function (' + args + ') {\n' + + '"use strict"\n' + + 'log.call(deprecate, message, site)\n' + + 'return fn.apply(this, arguments)\n' + + '})') + + return deprecatedfn +} + +/** + * Wrap property in a deprecation message. + */ + +function wrapproperty(obj, prop, message) { + if (!obj || (typeof obj !== 'object' && typeof obj !== 'function')) { + throw new TypeError('argument obj must be object') + } + + var descriptor = Object.getOwnPropertyDescriptor(obj, prop) + + if (!descriptor) { + throw new TypeError('must call property on owner object') + } + + if (!descriptor.configurable) { + throw new TypeError('property must be configurable') + } + + var deprecate = this + var stack = getStack() + var site = callSiteLocation(stack[1]) + + // set site name + site.name = prop + + // convert data descriptor + if ('value' in descriptor) { + descriptor = convertDataDescriptorToAccessor(obj, prop, message) + } + + var get = descriptor.get + var set = descriptor.set + + // wrap getter + if (typeof get === 'function') { + descriptor.get = function getter() { + log.call(deprecate, message, site) + return get.apply(this, arguments) + } + } + + // wrap setter + if (typeof set === 'function') { + descriptor.set = function setter() { + log.call(deprecate, message, site) + return set.apply(this, arguments) + } + } + + Object.defineProperty(obj, prop, descriptor) +} + +/** + * Create DeprecationError for deprecation + */ + +function DeprecationError(namespace, message, stack) { + var error = new Error() + var stackString + + Object.defineProperty(error, 'constructor', { + value: DeprecationError + }) + + Object.defineProperty(error, 'message', { + configurable: true, + enumerable: false, + value: message, + writable: true + }) + + Object.defineProperty(error, 'name', { + enumerable: false, + configurable: true, + value: 'DeprecationError', + writable: true + }) + + Object.defineProperty(error, 'namespace', { + configurable: true, + enumerable: false, + value: namespace, + writable: true + }) + + Object.defineProperty(error, 'stack', { + configurable: true, + enumerable: false, + get: function () { + if (stackString !== undefined) { + return stackString + } + + // prepare stack trace + return stackString = createStackString.call(this, stack) + }, + set: function setter(val) { + stackString = val + } + }) + + return error +} diff --git a/node_modules/body-parser/node_modules/depd/lib/browser/index.js b/node_modules/body-parser/node_modules/depd/lib/browser/index.js new file mode 100644 index 0000000..f464e05 --- /dev/null +++ b/node_modules/body-parser/node_modules/depd/lib/browser/index.js @@ -0,0 +1,79 @@ +/*! + * depd + * Copyright(c) 2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module exports. + * @public + */ + +module.exports = depd + +/** + * Create deprecate for namespace in caller. + */ + +function depd(namespace) { + if (!namespace) { + throw new TypeError('argument namespace is required') + } + + function deprecate(message) { + // no-op in browser + } + + deprecate._file = undefined + deprecate._ignored = true + deprecate._namespace = namespace + deprecate._traced = false + deprecate._warned = Object.create(null) + + deprecate.function = wrapfunction + deprecate.property = wrapproperty + + return deprecate +} + +/** + * Return a wrapped function in a deprecation message. + * + * This is a no-op version of the wrapper, which does nothing but call + * validation. + */ + +function wrapfunction(fn, message) { + if (typeof fn !== 'function') { + throw new TypeError('argument fn must be a function') + } + + return fn +} + +/** + * Wrap property in a deprecation message. + * + * This is a no-op version of the wrapper, which does nothing but call + * validation. + */ + +function wrapproperty(obj, prop, message) { + if (!obj || (typeof obj !== 'object' && typeof obj !== 'function')) { + throw new TypeError('argument obj must be object') + } + + var descriptor = Object.getOwnPropertyDescriptor(obj, prop) + + if (!descriptor) { + throw new TypeError('must call property on owner object') + } + + if (!descriptor.configurable) { + throw new TypeError('property must be configurable') + } + + return +} diff --git a/node_modules/body-parser/node_modules/depd/lib/compat/buffer-concat.js b/node_modules/body-parser/node_modules/depd/lib/compat/buffer-concat.js new file mode 100644 index 0000000..4b73381 --- /dev/null +++ b/node_modules/body-parser/node_modules/depd/lib/compat/buffer-concat.js @@ -0,0 +1,35 @@ +/*! + * depd + * Copyright(c) 2014 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module exports. + */ + +module.exports = bufferConcat + +/** + * Concatenate an array of Buffers. + */ + +function bufferConcat(bufs) { + var length = 0 + + for (var i = 0, len = bufs.length; i < len; i++) { + length += bufs[i].length + } + + var buf = new Buffer(length) + var pos = 0 + + for (var i = 0, len = bufs.length; i < len; i++) { + bufs[i].copy(buf, pos) + pos += bufs[i].length + } + + return buf +} diff --git a/node_modules/body-parser/node_modules/depd/lib/compat/callsite-tostring.js b/node_modules/body-parser/node_modules/depd/lib/compat/callsite-tostring.js new file mode 100644 index 0000000..9ecef34 --- /dev/null +++ b/node_modules/body-parser/node_modules/depd/lib/compat/callsite-tostring.js @@ -0,0 +1,103 @@ +/*! + * depd + * Copyright(c) 2014 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module exports. + */ + +module.exports = callSiteToString + +/** + * Format a CallSite file location to a string. + */ + +function callSiteFileLocation(callSite) { + var fileName + var fileLocation = '' + + if (callSite.isNative()) { + fileLocation = 'native' + } else if (callSite.isEval()) { + fileName = callSite.getScriptNameOrSourceURL() + if (!fileName) { + fileLocation = callSite.getEvalOrigin() + } + } else { + fileName = callSite.getFileName() + } + + if (fileName) { + fileLocation += fileName + + var lineNumber = callSite.getLineNumber() + if (lineNumber != null) { + fileLocation += ':' + lineNumber + + var columnNumber = callSite.getColumnNumber() + if (columnNumber) { + fileLocation += ':' + columnNumber + } + } + } + + return fileLocation || 'unknown source' +} + +/** + * Format a CallSite to a string. + */ + +function callSiteToString(callSite) { + var addSuffix = true + var fileLocation = callSiteFileLocation(callSite) + var functionName = callSite.getFunctionName() + var isConstructor = callSite.isConstructor() + var isMethodCall = !(callSite.isToplevel() || isConstructor) + var line = '' + + if (isMethodCall) { + var methodName = callSite.getMethodName() + var typeName = getConstructorName(callSite) + + if (functionName) { + if (typeName && functionName.indexOf(typeName) !== 0) { + line += typeName + '.' + } + + line += functionName + + if (methodName && functionName.lastIndexOf('.' + methodName) !== functionName.length - methodName.length - 1) { + line += ' [as ' + methodName + ']' + } + } else { + line += typeName + '.' + (methodName || '') + } + } else if (isConstructor) { + line += 'new ' + (functionName || '') + } else if (functionName) { + line += functionName + } else { + addSuffix = false + line += fileLocation + } + + if (addSuffix) { + line += ' (' + fileLocation + ')' + } + + return line +} + +/** + * Get constructor name of reviver. + */ + +function getConstructorName(obj) { + var receiver = obj.receiver + return (receiver.constructor && receiver.constructor.name) || null +} diff --git a/node_modules/body-parser/node_modules/depd/lib/compat/event-listener-count.js b/node_modules/body-parser/node_modules/depd/lib/compat/event-listener-count.js new file mode 100644 index 0000000..a05fceb --- /dev/null +++ b/node_modules/body-parser/node_modules/depd/lib/compat/event-listener-count.js @@ -0,0 +1,22 @@ +/*! + * depd + * Copyright(c) 2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module exports. + * @public + */ + +module.exports = eventListenerCount + +/** + * Get the count of listeners on an event emitter of a specific type. + */ + +function eventListenerCount(emitter, type) { + return emitter.listeners(type).length +} diff --git a/node_modules/body-parser/node_modules/depd/lib/compat/index.js b/node_modules/body-parser/node_modules/depd/lib/compat/index.js new file mode 100644 index 0000000..aa3c1de --- /dev/null +++ b/node_modules/body-parser/node_modules/depd/lib/compat/index.js @@ -0,0 +1,84 @@ +/*! + * depd + * Copyright(c) 2014-2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module dependencies. + * @private + */ + +var Buffer = require('buffer') +var EventEmitter = require('events').EventEmitter + +/** + * Module exports. + * @public + */ + +lazyProperty(module.exports, 'bufferConcat', function bufferConcat() { + return Buffer.concat || require('./buffer-concat') +}) + +lazyProperty(module.exports, 'callSiteToString', function callSiteToString() { + var limit = Error.stackTraceLimit + var obj = {} + var prep = Error.prepareStackTrace + + function prepareObjectStackTrace(obj, stack) { + return stack + } + + Error.prepareStackTrace = prepareObjectStackTrace + Error.stackTraceLimit = 2 + + // capture the stack + Error.captureStackTrace(obj) + + // slice the stack + var stack = obj.stack.slice() + + Error.prepareStackTrace = prep + Error.stackTraceLimit = limit + + return stack[0].toString ? toString : require('./callsite-tostring') +}) + +lazyProperty(module.exports, 'eventListenerCount', function eventListenerCount() { + return EventEmitter.listenerCount || require('./event-listener-count') +}) + +/** + * Define a lazy property. + */ + +function lazyProperty(obj, prop, getter) { + function get() { + var val = getter() + + Object.defineProperty(obj, prop, { + configurable: true, + enumerable: true, + value: val + }) + + return val + } + + Object.defineProperty(obj, prop, { + configurable: true, + enumerable: true, + get: get + }) +} + +/** + * Call toString() on the obj + */ + +function toString(obj) { + return obj.toString() +} diff --git a/node_modules/body-parser/node_modules/depd/package.json b/node_modules/body-parser/node_modules/depd/package.json new file mode 100644 index 0000000..57bfc94 --- /dev/null +++ b/node_modules/body-parser/node_modules/depd/package.json @@ -0,0 +1,67 @@ +{ + "name": "depd", + "description": "Deprecate all the things", + "version": "1.1.0", + "author": { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + }, + "license": "MIT", + "keywords": [ + "deprecate", + "deprecated" + ], + "repository": { + "type": "git", + "url": "git+https://github.com/dougwilson/nodejs-depd.git" + }, + "browser": "lib/browser/index.js", + "devDependencies": { + "benchmark": "1.0.0", + "beautify-benchmark": "0.2.4", + "istanbul": "0.3.5", + "mocha": "~1.21.5" + }, + "files": [ + "lib/", + "History.md", + "LICENSE", + "index.js", + "Readme.md" + ], + "engines": { + "node": ">= 0.6" + }, + "scripts": { + "bench": "node benchmark/index.js", + "test": "mocha --reporter spec --bail test/", + "test-ci": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter spec --no-exit test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot test/" + }, + "gitHead": "78c659de20283e3a6bee92bda455e6daff01686a", + "bugs": { + "url": "https://github.com/dougwilson/nodejs-depd/issues" + }, + "homepage": "https://github.com/dougwilson/nodejs-depd", + "_id": "depd@1.1.0", + "_shasum": "e1bd82c6aab6ced965b97b88b17ed3e528ca18c3", + "_from": "depd@>=1.1.0 <1.2.0", + "_npmVersion": "1.4.28", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "maintainers": [ + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + } + ], + "dist": { + "shasum": "e1bd82c6aab6ced965b97b88b17ed3e528ca18c3", + "tarball": "https://registry.npmjs.org/depd/-/depd-1.1.0.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/depd/-/depd-1.1.0.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/body-parser/node_modules/http-errors/HISTORY.md b/node_modules/body-parser/node_modules/http-errors/HISTORY.md new file mode 100644 index 0000000..0dfb7ac --- /dev/null +++ b/node_modules/body-parser/node_modules/http-errors/HISTORY.md @@ -0,0 +1,95 @@ +2016-05-18 / 1.5.0 +================== + + * Support new code `421 Misdirected Request` + * Use `setprototypeof` module to replace `__proto__` setting + * deps: statuses@'>= 1.3.0 < 2' + - Add `421 Misdirected Request` + - perf: enable strict mode + * perf: enable strict mode + +2016-01-28 / 1.4.0 +================== + + * Add `HttpError` export, for `err instanceof createError.HttpError` + * deps: inherits@2.0.1 + * deps: statuses@'>= 1.2.1 < 2' + - Fix message for status 451 + - Remove incorrect nginx status code + +2015-02-02 / 1.3.1 +================== + + * Fix regression where status can be overwritten in `createError` `props` + +2015-02-01 / 1.3.0 +================== + + * Construct errors using defined constructors from `createError` + * Fix error names that are not identifiers + - `createError["I'mateapot"]` is now `createError.ImATeapot` + * Set a meaningful `name` property on constructed errors + +2014-12-09 / 1.2.8 +================== + + * Fix stack trace from exported function + * Remove `arguments.callee` usage + +2014-10-14 / 1.2.7 +================== + + * Remove duplicate line + +2014-10-02 / 1.2.6 +================== + + * Fix `expose` to be `true` for `ClientError` constructor + +2014-09-28 / 1.2.5 +================== + + * deps: statuses@1 + +2014-09-21 / 1.2.4 +================== + + * Fix dependency version to work with old `npm`s + +2014-09-21 / 1.2.3 +================== + + * deps: statuses@~1.1.0 + +2014-09-21 / 1.2.2 +================== + + * Fix publish error + +2014-09-21 / 1.2.1 +================== + + * Support Node.js 0.6 + * Use `inherits` instead of `util` + +2014-09-09 / 1.2.0 +================== + + * Fix the way inheriting functions + * Support `expose` being provided in properties argument + +2014-09-08 / 1.1.0 +================== + + * Default status to 500 + * Support provided `error` to extend + +2014-09-08 / 1.0.1 +================== + + * Fix accepting string message + +2014-09-08 / 1.0.0 +================== + + * Initial release diff --git a/node_modules/body-parser/node_modules/http-errors/LICENSE b/node_modules/body-parser/node_modules/http-errors/LICENSE new file mode 100644 index 0000000..82af4df --- /dev/null +++ b/node_modules/body-parser/node_modules/http-errors/LICENSE @@ -0,0 +1,23 @@ + +The MIT License (MIT) + +Copyright (c) 2014 Jonathan Ong me@jongleberry.com +Copyright (c) 2016 Douglas Christopher Wilson doug@somethingdoug.com + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. diff --git a/node_modules/body-parser/node_modules/http-errors/README.md b/node_modules/body-parser/node_modules/http-errors/README.md new file mode 100644 index 0000000..be80f9b --- /dev/null +++ b/node_modules/body-parser/node_modules/http-errors/README.md @@ -0,0 +1,112 @@ +# http-errors + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Node.js Version][node-version-image]][node-version-url] +[![Build Status][travis-image]][travis-url] +[![Test Coverage][coveralls-image]][coveralls-url] + +Create HTTP errors for Express, Koa, Connect, etc. with ease. + +## Example + +```js +var createError = require('http-errors'); + +app.use(function (req, res, next) { + if (!req.user) return next(createError(401, 'Please login to view this page.')); + next(); +}) +``` + +## API + +This is the current API, currently extracted from Koa and subject to change. + +All errors inherit from JavaScript `Error` and the exported `createError.HttpError`. + +### Error Properties + +- `expose` - can be used to signal if `message` should be sent to the client, defaulting to `false` when `status` >= 500 +- `message` +- `status` and `statusCode` - the status code of the error, defaulting to `500` + +### createError([status], [message], [properties]) + +```js +var err = createError(404, 'This video does not exist!'); +``` + +- `status: 500` - the status code as a number +- `message` - the message of the error, defaulting to node's text for that status code. +- `properties` - custom properties to attach to the object + +### new createError\[code || name\](\[msg]\)) + +```js +var err = new createError.NotFound(); +``` + +- `code` - the status code as a number +- `name` - the name of the error as a "bumpy case", i.e. `NotFound` or `InternalServerError`. + +#### List of all constructors + +|Status Code|Constructor Name | +|-----------|-----------------------------| +|400 |BadRequest | +|401 |Unauthorized | +|402 |PaymentRequired | +|403 |Forbidden | +|404 |NotFound | +|405 |MethodNotAllowed | +|406 |NotAcceptable | +|407 |ProxyAuthenticationRequired | +|408 |RequestTimeout | +|409 |Conflict | +|410 |Gone | +|411 |LengthRequired | +|412 |PreconditionFailed | +|413 |PayloadTooLarge | +|414 |URITooLong | +|415 |UnsupportedMediaType | +|416 |RangeNotSatisfiable | +|417 |ExpectationFailed | +|418 |ImATeapot | +|421 |MisdirectedRequest | +|422 |UnprocessableEntity | +|423 |Locked | +|424 |FailedDependency | +|425 |UnorderedCollection | +|426 |UpgradeRequired | +|428 |PreconditionRequired | +|429 |TooManyRequests | +|431 |RequestHeaderFieldsTooLarge | +|451 |UnavailableForLegalReasons | +|500 |InternalServerError | +|501 |NotImplemented | +|502 |BadGateway | +|503 |ServiceUnavailable | +|504 |GatewayTimeout | +|505 |HTTPVersionNotSupported | +|506 |VariantAlsoNegotiates | +|507 |InsufficientStorage | +|508 |LoopDetected | +|509 |BandwidthLimitExceeded | +|510 |NotExtended | +|511 |NetworkAuthenticationRequired| + +## License + +[MIT](LICENSE) + +[npm-image]: https://img.shields.io/npm/v/http-errors.svg?style=flat +[npm-url]: https://npmjs.org/package/http-errors +[node-version-image]: https://img.shields.io/node/v/http-errors.svg?style=flat +[node-version-url]: https://nodejs.org/en/download/ +[travis-image]: https://img.shields.io/travis/jshttp/http-errors.svg?style=flat +[travis-url]: https://travis-ci.org/jshttp/http-errors +[coveralls-image]: https://img.shields.io/coveralls/jshttp/http-errors.svg?style=flat +[coveralls-url]: https://coveralls.io/r/jshttp/http-errors +[downloads-image]: https://img.shields.io/npm/dm/http-errors.svg?style=flat +[downloads-url]: https://npmjs.org/package/http-errors diff --git a/node_modules/body-parser/node_modules/http-errors/index.js b/node_modules/body-parser/node_modules/http-errors/index.js new file mode 100644 index 0000000..6130db8 --- /dev/null +++ b/node_modules/body-parser/node_modules/http-errors/index.js @@ -0,0 +1,223 @@ +/*! + * http-errors + * Copyright(c) 2014 Jonathan Ong + * Copyright(c) 2016 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module dependencies. + * @private + */ + +var setPrototypeOf = require('setprototypeof') +var statuses = require('statuses') +var inherits = require('inherits') + +/** + * Module exports. + * @public + */ + +module.exports = createError +module.exports.HttpError = createHttpErrorConstructor() + +// Populate exports for all constructors +populateConstructorExports(module.exports, statuses.codes, module.exports.HttpError) + +/** + * Create a new HTTP Error. + * + * @returns {Error} + * @public + */ + +function createError () { + // so much arity going on ~_~ + var err + var msg + var status = 500 + var props = {} + for (var i = 0; i < arguments.length; i++) { + var arg = arguments[i] + if (arg instanceof Error) { + err = arg + status = err.status || err.statusCode || status + continue + } + switch (typeof arg) { + case 'string': + msg = arg + break + case 'number': + status = arg + break + case 'object': + props = arg + break + } + } + + if (typeof status !== 'number' || !statuses[status]) { + status = 500 + } + + // constructor + var HttpError = createError[status] + + if (!err) { + // create error + err = HttpError + ? new HttpError(msg) + : new Error(msg || statuses[status]) + Error.captureStackTrace(err, createError) + } + + if (!HttpError || !(err instanceof HttpError)) { + // add properties to generic error + err.expose = status < 500 + err.status = err.statusCode = status + } + + for (var key in props) { + if (key !== 'status' && key !== 'statusCode') { + err[key] = props[key] + } + } + + return err +} + +/** + * Create HTTP error abstract base class. + * @private + */ + +function createHttpErrorConstructor () { + function HttpError () { + throw new TypeError('cannot construct abstract class') + } + + inherits(HttpError, Error) + + return HttpError +} + +/** + * Create a constructor for a client error. + * @private + */ + +function createClientErrorConstructor (HttpError, name, code) { + var className = name.match(/Error$/) ? name : name + 'Error' + + function ClientError (message) { + // create the error object + var err = new Error(message != null ? message : statuses[code]) + + // capture a stack trace to the construction point + Error.captureStackTrace(err, ClientError) + + // adjust the [[Prototype]] + setPrototypeOf(err, ClientError.prototype) + + // redefine the error name + Object.defineProperty(err, 'name', { + enumerable: false, + configurable: true, + value: className, + writable: true + }) + + return err + } + + inherits(ClientError, HttpError) + + ClientError.prototype.status = code + ClientError.prototype.statusCode = code + ClientError.prototype.expose = true + + return ClientError +} + +/** + * Create a constructor for a server error. + * @private + */ + +function createServerErrorConstructor (HttpError, name, code) { + var className = name.match(/Error$/) ? name : name + 'Error' + + function ServerError (message) { + // create the error object + var err = new Error(message != null ? message : statuses[code]) + + // capture a stack trace to the construction point + Error.captureStackTrace(err, ServerError) + + // adjust the [[Prototype]] + setPrototypeOf(err, ServerError.prototype) + + // redefine the error name + Object.defineProperty(err, 'name', { + enumerable: false, + configurable: true, + value: className, + writable: true + }) + + return err + } + + inherits(ServerError, HttpError) + + ServerError.prototype.status = code + ServerError.prototype.statusCode = code + ServerError.prototype.expose = false + + return ServerError +} + +/** + * Populate the exports object with constructors for every error class. + * @private + */ + +function populateConstructorExports (exports, codes, HttpError) { + codes.forEach(function forEachCode (code) { + var CodeError + var name = toIdentifier(statuses[code]) + + switch (String(code).charAt(0)) { + case '4': + CodeError = createClientErrorConstructor(HttpError, name, code) + break + case '5': + CodeError = createServerErrorConstructor(HttpError, name, code) + break + } + + if (CodeError) { + // export the constructor + exports[code] = CodeError + exports[name] = CodeError + } + }) + + // backwards-compatibility + exports["I'mateapot"] = exports.ImATeapot +} + +/** + * Convert a string of words to a JavaScript identifier. + * @private + */ + +function toIdentifier (str) { + return str.split(' ').map(function (token) { + return token.slice(0, 1).toUpperCase() + token.slice(1) + }).join('').replace(/[^ _0-9a-z]/gi, '') +} diff --git a/node_modules/body-parser/node_modules/http-errors/node_modules/inherits/LICENSE b/node_modules/body-parser/node_modules/http-errors/node_modules/inherits/LICENSE new file mode 100644 index 0000000..dea3013 --- /dev/null +++ b/node_modules/body-parser/node_modules/http-errors/node_modules/inherits/LICENSE @@ -0,0 +1,16 @@ +The ISC License + +Copyright (c) Isaac Z. Schlueter + +Permission to use, copy, modify, and/or distribute this software for any +purpose with or without fee is hereby granted, provided that the above +copyright notice and this permission notice appear in all copies. + +THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH +REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND +FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, +INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM +LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR +OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR +PERFORMANCE OF THIS SOFTWARE. + diff --git a/node_modules/body-parser/node_modules/http-errors/node_modules/inherits/README.md b/node_modules/body-parser/node_modules/http-errors/node_modules/inherits/README.md new file mode 100644 index 0000000..b1c5665 --- /dev/null +++ b/node_modules/body-parser/node_modules/http-errors/node_modules/inherits/README.md @@ -0,0 +1,42 @@ +Browser-friendly inheritance fully compatible with standard node.js +[inherits](http://nodejs.org/api/util.html#util_util_inherits_constructor_superconstructor). + +This package exports standard `inherits` from node.js `util` module in +node environment, but also provides alternative browser-friendly +implementation through [browser +field](https://gist.github.com/shtylman/4339901). Alternative +implementation is a literal copy of standard one located in standalone +module to avoid requiring of `util`. It also has a shim for old +browsers with no `Object.create` support. + +While keeping you sure you are using standard `inherits` +implementation in node.js environment, it allows bundlers such as +[browserify](https://github.com/substack/node-browserify) to not +include full `util` package to your client code if all you need is +just `inherits` function. It worth, because browser shim for `util` +package is large and `inherits` is often the single function you need +from it. + +It's recommended to use this package instead of +`require('util').inherits` for any code that has chances to be used +not only in node.js but in browser too. + +## usage + +```js +var inherits = require('inherits'); +// then use exactly as the standard one +``` + +## note on version ~1.0 + +Version ~1.0 had completely different motivation and is not compatible +neither with 2.0 nor with standard node.js `inherits`. + +If you are using version ~1.0 and planning to switch to ~2.0, be +careful: + +* new version uses `super_` instead of `super` for referencing + superclass +* new version overwrites current prototype while old one preserves any + existing fields on it diff --git a/node_modules/body-parser/node_modules/http-errors/node_modules/inherits/inherits.js b/node_modules/body-parser/node_modules/http-errors/node_modules/inherits/inherits.js new file mode 100644 index 0000000..29f5e24 --- /dev/null +++ b/node_modules/body-parser/node_modules/http-errors/node_modules/inherits/inherits.js @@ -0,0 +1 @@ +module.exports = require('util').inherits diff --git a/node_modules/body-parser/node_modules/http-errors/node_modules/inherits/inherits_browser.js b/node_modules/body-parser/node_modules/http-errors/node_modules/inherits/inherits_browser.js new file mode 100644 index 0000000..c1e78a7 --- /dev/null +++ b/node_modules/body-parser/node_modules/http-errors/node_modules/inherits/inherits_browser.js @@ -0,0 +1,23 @@ +if (typeof Object.create === 'function') { + // implementation from standard node.js 'util' module + module.exports = function inherits(ctor, superCtor) { + ctor.super_ = superCtor + ctor.prototype = Object.create(superCtor.prototype, { + constructor: { + value: ctor, + enumerable: false, + writable: true, + configurable: true + } + }); + }; +} else { + // old school shim for old browsers + module.exports = function inherits(ctor, superCtor) { + ctor.super_ = superCtor + var TempCtor = function () {} + TempCtor.prototype = superCtor.prototype + ctor.prototype = new TempCtor() + ctor.prototype.constructor = ctor + } +} diff --git a/node_modules/body-parser/node_modules/http-errors/node_modules/inherits/package.json b/node_modules/body-parser/node_modules/http-errors/node_modules/inherits/package.json new file mode 100644 index 0000000..546e984 --- /dev/null +++ b/node_modules/body-parser/node_modules/http-errors/node_modules/inherits/package.json @@ -0,0 +1,50 @@ +{ + "name": "inherits", + "description": "Browser-friendly inheritance fully compatible with standard node.js inherits()", + "version": "2.0.1", + "keywords": [ + "inheritance", + "class", + "klass", + "oop", + "object-oriented", + "inherits", + "browser", + "browserify" + ], + "main": "./inherits.js", + "browser": "./inherits_browser.js", + "repository": { + "type": "git", + "url": "git://github.com/isaacs/inherits.git" + }, + "license": "ISC", + "scripts": { + "test": "node test" + }, + "bugs": { + "url": "https://github.com/isaacs/inherits/issues" + }, + "_id": "inherits@2.0.1", + "dist": { + "shasum": "b17d08d326b4423e568eff719f91b0b1cbdf69f1", + "tarball": "https://registry.npmjs.org/inherits/-/inherits-2.0.1.tgz" + }, + "_from": "inherits@2.0.1", + "_npmVersion": "1.3.8", + "_npmUser": { + "name": "isaacs", + "email": "i@izs.me" + }, + "maintainers": [ + { + "name": "isaacs", + "email": "i@izs.me" + } + ], + "directories": {}, + "_shasum": "b17d08d326b4423e568eff719f91b0b1cbdf69f1", + "_resolved": "http://registry.npmjs.org/inherits/-/inherits-2.0.1.tgz", + "readme": "ERROR: No README data found!", + "homepage": "https://github.com/isaacs/inherits#readme" +} diff --git a/node_modules/body-parser/node_modules/http-errors/node_modules/inherits/test.js b/node_modules/body-parser/node_modules/http-errors/node_modules/inherits/test.js new file mode 100644 index 0000000..fc53012 --- /dev/null +++ b/node_modules/body-parser/node_modules/http-errors/node_modules/inherits/test.js @@ -0,0 +1,25 @@ +var inherits = require('./inherits.js') +var assert = require('assert') + +function test(c) { + assert(c.constructor === Child) + assert(c.constructor.super_ === Parent) + assert(Object.getPrototypeOf(c) === Child.prototype) + assert(Object.getPrototypeOf(Object.getPrototypeOf(c)) === Parent.prototype) + assert(c instanceof Child) + assert(c instanceof Parent) +} + +function Child() { + Parent.call(this) + test(this) +} + +function Parent() {} + +inherits(Child, Parent) + +var c = new Child +test(c) + +console.log('ok') diff --git a/node_modules/body-parser/node_modules/http-errors/node_modules/setprototypeof/LICENSE b/node_modules/body-parser/node_modules/http-errors/node_modules/setprototypeof/LICENSE new file mode 100644 index 0000000..61afa2f --- /dev/null +++ b/node_modules/body-parser/node_modules/http-errors/node_modules/setprototypeof/LICENSE @@ -0,0 +1,13 @@ +Copyright (c) 2015, Wes Todd + +Permission to use, copy, modify, and/or distribute this software for any +purpose with or without fee is hereby granted, provided that the above +copyright notice and this permission notice appear in all copies. + +THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES +WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF +MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY +SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES +WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION +OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN +CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. diff --git a/node_modules/body-parser/node_modules/http-errors/node_modules/setprototypeof/README.md b/node_modules/body-parser/node_modules/http-errors/node_modules/setprototypeof/README.md new file mode 100644 index 0000000..01d7947 --- /dev/null +++ b/node_modules/body-parser/node_modules/http-errors/node_modules/setprototypeof/README.md @@ -0,0 +1,21 @@ +# Polyfill for `Object.setPrototypeOf` + +A simple cross platform implementation to set the prototype of an instianted object. Supports all modern browsers and at least back to IE8. + +## Usage: + +``` +$ npm install --save setprototypeof +``` + +```javascript +var setPrototypeOf = require('setprototypeof'); + +var obj = {}; +setPrototypeOf(obj, { + foo: function() { + return 'bar'; + } +}); +obj.foo(); // bar +``` diff --git a/node_modules/body-parser/node_modules/http-errors/node_modules/setprototypeof/index.js b/node_modules/body-parser/node_modules/http-errors/node_modules/setprototypeof/index.js new file mode 100644 index 0000000..086a879 --- /dev/null +++ b/node_modules/body-parser/node_modules/http-errors/node_modules/setprototypeof/index.js @@ -0,0 +1,11 @@ +module.exports = Object.setPrototypeOf || ({__proto__:[]} instanceof Array ? setProtoOf : mixinProperties); + +function setProtoOf(obj, proto) { + obj.__proto__ = proto; +} + +function mixinProperties(obj, proto) { + for (var prop in proto) { + obj[prop] = proto[prop]; + } +} diff --git a/node_modules/body-parser/node_modules/http-errors/node_modules/setprototypeof/package.json b/node_modules/body-parser/node_modules/http-errors/node_modules/setprototypeof/package.json new file mode 100644 index 0000000..62b8a11 --- /dev/null +++ b/node_modules/body-parser/node_modules/http-errors/node_modules/setprototypeof/package.json @@ -0,0 +1,53 @@ +{ + "name": "setprototypeof", + "version": "1.0.1", + "description": "A small polyfill for Object.setprototypeof", + "main": "index.js", + "scripts": { + "test": "echo \"Error: no test specified\" && exit 1" + }, + "repository": { + "type": "git", + "url": "git+https://github.com/wesleytodd/setprototypeof.git" + }, + "keywords": [ + "polyfill", + "object", + "setprototypeof" + ], + "author": { + "name": "Wes Todd" + }, + "license": "ISC", + "bugs": { + "url": "https://github.com/wesleytodd/setprototypeof/issues" + }, + "homepage": "https://github.com/wesleytodd/setprototypeof", + "gitHead": "1e3d0cde6b7f4a9fba10cd28e62b200c9d8f899f", + "_id": "setprototypeof@1.0.1", + "_shasum": "52009b27888c4dc48f591949c0a8275834c1ca7e", + "_from": "setprototypeof@1.0.1", + "_npmVersion": "3.3.6", + "_nodeVersion": "5.0.0", + "_npmUser": { + "name": "wesleytodd", + "email": "wes@wesleytodd.com" + }, + "dist": { + "shasum": "52009b27888c4dc48f591949c0a8275834c1ca7e", + "tarball": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.0.1.tgz" + }, + "maintainers": [ + { + "name": "wesleytodd", + "email": "wes@wesleytodd.com" + } + ], + "_npmOperationalInternal": { + "host": "packages-5-east.internal.npmjs.com", + "tmp": "tmp/setprototypeof-1.0.1.tgz_1454803015119_0.7522649802267551" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/setprototypeof/-/setprototypeof-1.0.1.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/body-parser/node_modules/http-errors/node_modules/statuses/HISTORY.md b/node_modules/body-parser/node_modules/http-errors/node_modules/statuses/HISTORY.md new file mode 100644 index 0000000..b175575 --- /dev/null +++ b/node_modules/body-parser/node_modules/http-errors/node_modules/statuses/HISTORY.md @@ -0,0 +1,50 @@ +1.3.0 / 2016-05-17 +================== + + * Add `421 Misdirected Request` + * perf: enable strict mode + +1.2.1 / 2015-02-01 +================== + + * Fix message for status 451 + - `451 Unavailable For Legal Reasons` + +1.2.0 / 2014-09-28 +================== + + * Add `208 Already Repored` + * Add `226 IM Used` + * Add `306 (Unused)` + * Add `415 Unable For Legal Reasons` + * Add `508 Loop Detected` + +1.1.1 / 2014-09-24 +================== + + * Add missing 308 to `codes.json` + +1.1.0 / 2014-09-21 +================== + + * Add `codes.json` for universal support + +1.0.4 / 2014-08-20 +================== + + * Package cleanup + +1.0.3 / 2014-06-08 +================== + + * Add 308 to `.redirect` category + +1.0.2 / 2014-03-13 +================== + + * Add `.retry` category + +1.0.1 / 2014-03-12 +================== + + * Initial release diff --git a/node_modules/body-parser/node_modules/http-errors/node_modules/statuses/LICENSE b/node_modules/body-parser/node_modules/http-errors/node_modules/statuses/LICENSE new file mode 100644 index 0000000..82af4df --- /dev/null +++ b/node_modules/body-parser/node_modules/http-errors/node_modules/statuses/LICENSE @@ -0,0 +1,23 @@ + +The MIT License (MIT) + +Copyright (c) 2014 Jonathan Ong me@jongleberry.com +Copyright (c) 2016 Douglas Christopher Wilson doug@somethingdoug.com + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. diff --git a/node_modules/body-parser/node_modules/http-errors/node_modules/statuses/README.md b/node_modules/body-parser/node_modules/http-errors/node_modules/statuses/README.md new file mode 100644 index 0000000..1a699da --- /dev/null +++ b/node_modules/body-parser/node_modules/http-errors/node_modules/statuses/README.md @@ -0,0 +1,114 @@ +# Statuses + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Node.js Version][node-version-image]][node-version-url] +[![Build Status][travis-image]][travis-url] +[![Test Coverage][coveralls-image]][coveralls-url] + +HTTP status utility for node. + +## API + +```js +var status = require('statuses') +``` + +### var code = status(Integer || String) + +If `Integer` or `String` is a valid HTTP code or status message, then the appropriate `code` will be returned. Otherwise, an error will be thrown. + +```js +status(403) // => 403 +status('403') // => 403 +status('forbidden') // => 403 +status('Forbidden') // => 403 +status(306) // throws, as it's not supported by node.js +``` + +### status.codes + +Returns an array of all the status codes as `Integer`s. + +### var msg = status[code] + +Map of `code` to `status message`. `undefined` for invalid `code`s. + +```js +status[404] // => 'Not Found' +``` + +### var code = status[msg] + +Map of `status message` to `code`. `msg` can either be title-cased or lower-cased. `undefined` for invalid `status message`s. + +```js +status['not found'] // => 404 +status['Not Found'] // => 404 +``` + +### status.redirect[code] + +Returns `true` if a status code is a valid redirect status. + +```js +status.redirect[200] // => undefined +status.redirect[301] // => true +``` + +### status.empty[code] + +Returns `true` if a status code expects an empty body. + +```js +status.empty[200] // => undefined +status.empty[204] // => true +status.empty[304] // => true +``` + +### status.retry[code] + +Returns `true` if you should retry the rest. + +```js +status.retry[501] // => undefined +status.retry[503] // => true +``` + +### statuses/codes.json + +```js +var codes = require('statuses/codes.json') +``` + +This is a JSON file of the status codes +taken from `require('http').STATUS_CODES`. +This is saved so that codes are consistent even in older node.js versions. +For example, `308` will be added in v0.12. + +## Adding Status Codes + +The status codes are primarily sourced from http://www.iana.org/assignments/http-status-codes/http-status-codes-1.csv. +Additionally, custom codes are added from http://en.wikipedia.org/wiki/List_of_HTTP_status_codes. +These are added manually in the `lib/*.json` files. +If you would like to add a status code, add it to the appropriate JSON file. + +To rebuild `codes.json`, run the following: + +```bash +# update src/iana.json +npm run fetch +# build codes.json +npm run build +``` + +[npm-image]: https://img.shields.io/npm/v/statuses.svg +[npm-url]: https://npmjs.org/package/statuses +[node-version-image]: https://img.shields.io/badge/node.js-%3E%3D_0.6-brightgreen.svg +[node-version-url]: https://nodejs.org/en/download +[travis-image]: https://img.shields.io/travis/jshttp/statuses.svg +[travis-url]: https://travis-ci.org/jshttp/statuses +[coveralls-image]: https://img.shields.io/coveralls/jshttp/statuses.svg +[coveralls-url]: https://coveralls.io/r/jshttp/statuses?branch=master +[downloads-image]: https://img.shields.io/npm/dm/statuses.svg +[downloads-url]: https://npmjs.org/package/statuses diff --git a/node_modules/body-parser/node_modules/http-errors/node_modules/statuses/codes.json b/node_modules/body-parser/node_modules/http-errors/node_modules/statuses/codes.json new file mode 100644 index 0000000..e765123 --- /dev/null +++ b/node_modules/body-parser/node_modules/http-errors/node_modules/statuses/codes.json @@ -0,0 +1,65 @@ +{ + "100": "Continue", + "101": "Switching Protocols", + "102": "Processing", + "200": "OK", + "201": "Created", + "202": "Accepted", + "203": "Non-Authoritative Information", + "204": "No Content", + "205": "Reset Content", + "206": "Partial Content", + "207": "Multi-Status", + "208": "Already Reported", + "226": "IM Used", + "300": "Multiple Choices", + "301": "Moved Permanently", + "302": "Found", + "303": "See Other", + "304": "Not Modified", + "305": "Use Proxy", + "306": "(Unused)", + "307": "Temporary Redirect", + "308": "Permanent Redirect", + "400": "Bad Request", + "401": "Unauthorized", + "402": "Payment Required", + "403": "Forbidden", + "404": "Not Found", + "405": "Method Not Allowed", + "406": "Not Acceptable", + "407": "Proxy Authentication Required", + "408": "Request Timeout", + "409": "Conflict", + "410": "Gone", + "411": "Length Required", + "412": "Precondition Failed", + "413": "Payload Too Large", + "414": "URI Too Long", + "415": "Unsupported Media Type", + "416": "Range Not Satisfiable", + "417": "Expectation Failed", + "418": "I'm a teapot", + "421": "Misdirected Request", + "422": "Unprocessable Entity", + "423": "Locked", + "424": "Failed Dependency", + "425": "Unordered Collection", + "426": "Upgrade Required", + "428": "Precondition Required", + "429": "Too Many Requests", + "431": "Request Header Fields Too Large", + "451": "Unavailable For Legal Reasons", + "500": "Internal Server Error", + "501": "Not Implemented", + "502": "Bad Gateway", + "503": "Service Unavailable", + "504": "Gateway Timeout", + "505": "HTTP Version Not Supported", + "506": "Variant Also Negotiates", + "507": "Insufficient Storage", + "508": "Loop Detected", + "509": "Bandwidth Limit Exceeded", + "510": "Not Extended", + "511": "Network Authentication Required" +} \ No newline at end of file diff --git a/node_modules/body-parser/node_modules/http-errors/node_modules/statuses/index.js b/node_modules/body-parser/node_modules/http-errors/node_modules/statuses/index.js new file mode 100644 index 0000000..c2b555a --- /dev/null +++ b/node_modules/body-parser/node_modules/http-errors/node_modules/statuses/index.js @@ -0,0 +1,110 @@ +/*! + * statuses + * Copyright(c) 2014 Jonathan Ong + * Copyright(c) 2016 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module dependencies. + * @private + */ + +var codes = require('./codes.json') + +/** + * Module exports. + * @public + */ + +module.exports = status + +// array of status codes +status.codes = populateStatusesMap(status, codes) + +// status codes for redirects +status.redirect = { + 300: true, + 301: true, + 302: true, + 303: true, + 305: true, + 307: true, + 308: true +} + +// status codes for empty bodies +status.empty = { + 204: true, + 205: true, + 304: true +} + +// status codes for when you should retry the request +status.retry = { + 502: true, + 503: true, + 504: true +} + +/** + * Populate the statuses map for given codes. + * @private + */ + +function populateStatusesMap (statuses, codes) { + var arr = [] + + Object.keys(codes).forEach(function forEachCode (code) { + var message = codes[code] + var status = Number(code) + + // Populate properties + statuses[status] = message + statuses[message] = status + statuses[message.toLowerCase()] = status + + // Add to array + arr.push(status) + }) + + return arr +} + +/** + * Get the status code. + * + * Given a number, this will throw if it is not a known status + * code, otherwise the code will be returned. Given a string, + * the string will be parsed for a number and return the code + * if valid, otherwise will lookup the code assuming this is + * the status message. + * + * @param {string|number} code + * @returns {string} + * @public + */ + +function status (code) { + if (typeof code === 'number') { + if (!status[code]) throw new Error('invalid status code: ' + code) + return code + } + + if (typeof code !== 'string') { + throw new TypeError('code must be a number or string') + } + + // '403' + var n = parseInt(code, 10) + if (!isNaN(n)) { + if (!status[n]) throw new Error('invalid status code: ' + n) + return n + } + + n = status[code.toLowerCase()] + if (!n) throw new Error('invalid status message: "' + code + '"') + return n +} diff --git a/node_modules/body-parser/node_modules/http-errors/node_modules/statuses/package.json b/node_modules/body-parser/node_modules/http-errors/node_modules/statuses/package.json new file mode 100644 index 0000000..a2a4fa0 --- /dev/null +++ b/node_modules/body-parser/node_modules/http-errors/node_modules/statuses/package.json @@ -0,0 +1,104 @@ +{ + "name": "statuses", + "description": "HTTP status utility", + "version": "1.3.0", + "contributors": [ + { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "Jonathan Ong", + "email": "me@jongleberry.com", + "url": "http://jongleberry.com" + } + ], + "repository": { + "type": "git", + "url": "git+https://github.com/jshttp/statuses.git" + }, + "license": "MIT", + "keywords": [ + "http", + "status", + "code" + ], + "files": [ + "HISTORY.md", + "index.js", + "codes.json", + "LICENSE" + ], + "devDependencies": { + "csv-parse": "1.0.1", + "eslint": "2.10.2", + "eslint-config-standard": "5.3.1", + "eslint-plugin-promise": "1.1.0", + "eslint-plugin-standard": "1.3.2", + "istanbul": "0.4.3", + "mocha": "1.21.5", + "stream-to-array": "2.2.0" + }, + "engines": { + "node": ">= 0.6" + }, + "scripts": { + "build": "node scripts/build.js", + "fetch": "node scripts/fetch.js", + "lint": "eslint **/*.js", + "test": "mocha --reporter spec --check-leaks --bail test/", + "test-ci": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter spec --check-leaks test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot --check-leaks test/", + "update": "npm run fetch && npm run build" + }, + "gitHead": "b3e31e8c32dd8107e898b44b8c0b2dfff3cba495", + "bugs": { + "url": "https://github.com/jshttp/statuses/issues" + }, + "homepage": "https://github.com/jshttp/statuses", + "_id": "statuses@1.3.0", + "_shasum": "8e55758cb20e7682c1f4fce8dcab30bf01d1e07a", + "_from": "statuses@>=1.3.0 <2.0.0", + "_npmVersion": "1.4.28", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "maintainers": [ + { + "name": "defunctzombie", + "email": "shtylman@gmail.com" + }, + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "fishrock123", + "email": "fishrock123@rocketmail.com" + }, + { + "name": "jongleberry", + "email": "jonathanrichardong@gmail.com" + }, + { + "name": "mscdex", + "email": "mscdex@mscdex.net" + }, + { + "name": "tjholowaychuk", + "email": "tj@vision-media.ca" + } + ], + "dist": { + "shasum": "8e55758cb20e7682c1f4fce8dcab30bf01d1e07a", + "tarball": "https://registry.npmjs.org/statuses/-/statuses-1.3.0.tgz" + }, + "_npmOperationalInternal": { + "host": "packages-12-west.internal.npmjs.com", + "tmp": "tmp/statuses-1.3.0.tgz_1463517875633_0.19560232176445425" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/statuses/-/statuses-1.3.0.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/body-parser/node_modules/http-errors/package.json b/node_modules/body-parser/node_modules/http-errors/package.json new file mode 100644 index 0000000..4bbc546 --- /dev/null +++ b/node_modules/body-parser/node_modules/http-errors/package.json @@ -0,0 +1,96 @@ +{ + "name": "http-errors", + "description": "Create HTTP error objects", + "version": "1.5.0", + "author": { + "name": "Jonathan Ong", + "email": "me@jongleberry.com", + "url": "http://jongleberry.com" + }, + "contributors": [ + { + "name": "Alan Plum", + "email": "me@pluma.io" + }, + { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + } + ], + "license": "MIT", + "repository": { + "type": "git", + "url": "git+https://github.com/jshttp/http-errors.git" + }, + "dependencies": { + "inherits": "2.0.1", + "setprototypeof": "1.0.1", + "statuses": ">= 1.3.0 < 2" + }, + "devDependencies": { + "eslint": "2.10.2", + "eslint-config-standard": "5.3.1", + "eslint-plugin-promise": "1.1.0", + "eslint-plugin-standard": "1.3.2", + "istanbul": "0.4.3", + "mocha": "1.21.5" + }, + "engines": { + "node": ">= 0.6" + }, + "scripts": { + "lint": "eslint **/*.js", + "test": "mocha --reporter spec --bail", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot", + "test-travis": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter dot" + }, + "keywords": [ + "http", + "error" + ], + "files": [ + "index.js", + "HISTORY.md", + "LICENSE", + "README.md" + ], + "gitHead": "1a826d7ac31dde16931b9c566041697939ebd0e0", + "bugs": { + "url": "https://github.com/jshttp/http-errors/issues" + }, + "homepage": "https://github.com/jshttp/http-errors#readme", + "_id": "http-errors@1.5.0", + "_shasum": "b1cb3d8260fd8e2386cad3189045943372d48211", + "_from": "http-errors@>=1.5.0 <1.6.0", + "_npmVersion": "2.15.1", + "_nodeVersion": "4.4.3", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "dist": { + "shasum": "b1cb3d8260fd8e2386cad3189045943372d48211", + "tarball": "https://registry.npmjs.org/http-errors/-/http-errors-1.5.0.tgz" + }, + "maintainers": [ + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "egeste", + "email": "npm@egeste.net" + }, + { + "name": "jongleberry", + "email": "jonathanrichardong@gmail.com" + } + ], + "_npmOperationalInternal": { + "host": "packages-16-east.internal.npmjs.com", + "tmp": "tmp/http-errors-1.5.0.tgz_1463621678183_0.44013352948240936" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/http-errors/-/http-errors-1.5.0.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/body-parser/node_modules/iconv-lite/.npmignore b/node_modules/body-parser/node_modules/iconv-lite/.npmignore new file mode 100644 index 0000000..5cd2673 --- /dev/null +++ b/node_modules/body-parser/node_modules/iconv-lite/.npmignore @@ -0,0 +1,6 @@ +*~ +*sublime-* +generation +test +wiki +coverage diff --git a/node_modules/body-parser/node_modules/iconv-lite/.travis.yml b/node_modules/body-parser/node_modules/iconv-lite/.travis.yml new file mode 100644 index 0000000..f5343f1 --- /dev/null +++ b/node_modules/body-parser/node_modules/iconv-lite/.travis.yml @@ -0,0 +1,20 @@ + sudo: false + env: + - CXX=g++-4.8 + language: node_js + node_js: + - "0.8" + - "0.10" + - "0.11" + - "0.12" + - "iojs" + - "4.0" + addons: + apt: + sources: + - ubuntu-toolchain-r-test + packages: + - gcc-4.8 + - g++-4.8 + before_install: + - "test $TRAVIS_NODE_VERSION != '0.8' || npm install -g npm@1.2.8000" diff --git a/node_modules/body-parser/node_modules/iconv-lite/Changelog.md b/node_modules/body-parser/node_modules/iconv-lite/Changelog.md new file mode 100644 index 0000000..421b1e2 --- /dev/null +++ b/node_modules/body-parser/node_modules/iconv-lite/Changelog.md @@ -0,0 +1,93 @@ + +# 0.4.13 / 2015-10-01 + + * Fix silly mistake in deprecation notice. + + +# 0.4.12 / 2015-09-26 + + * Node v4 support: + * Added CESU-8 decoding (#106) + * Added deprecation notice for `extendNodeEncodings` + * Added Travis tests for Node v4 and io.js latest (#105 by @Mithgol) + + +# 0.4.11 / 2015-07-03 + + * Added CESU-8 encoding. + + +# 0.4.10 / 2015-05-26 + + * Changed UTF-16 endianness heuristic to take into account any ASCII chars, not + just spaces. This should minimize the importance of "default" endianness. + + +# 0.4.9 / 2015-05-24 + + * Streamlined BOM handling: strip BOM by default, add BOM when encoding if + addBOM: true. Added docs to Readme. + * UTF16 now uses UTF16-LE by default. + * Fixed minor issue with big5 encoding. + * Added io.js testing on Travis; updated node-iconv version to test against. + Now we just skip testing SBCS encodings that node-iconv doesn't support. + * (internal refactoring) Updated codec interface to use classes. + * Use strict mode in all files. + + +# 0.4.8 / 2015-04-14 + + * added alias UNICODE-1-1-UTF-7 for UTF-7 encoding (#94) + + +# 0.4.7 / 2015-02-05 + + * stop official support of Node.js v0.8. Should still work, but no guarantees. + reason: Packages needed for testing are hard to get on Travis CI. + * work in environment where Object.prototype is monkey patched with enumerable + props (#89). + + +# 0.4.6 / 2015-01-12 + + * fix rare aliases of single-byte encodings (thanks @mscdex) + * double the timeout for dbcs tests to make them less flaky on travis + + +# 0.4.5 / 2014-11-20 + + * fix windows-31j and x-sjis encoding support (@nleush) + * minor fix: undefined variable reference when internal error happens + + +# 0.4.4 / 2014-07-16 + + * added encodings UTF-7 (RFC2152) and UTF-7-IMAP (RFC3501 Section 5.1.3) + * fixed streaming base64 encoding + + +# 0.4.3 / 2014-06-14 + + * added encodings UTF-16BE and UTF-16 with BOM + + +# 0.4.2 / 2014-06-12 + + * don't throw exception if `extendNodeEncodings()` is called more than once + + +# 0.4.1 / 2014-06-11 + + * codepage 808 added + + +# 0.4.0 / 2014-06-10 + + * code is rewritten from scratch + * all widespread encodings are supported + * streaming interface added + * browserify compatibility added + * (optional) extend core primitive encodings to make usage even simpler + * moved from vows to mocha as the testing framework + + diff --git a/node_modules/body-parser/node_modules/iconv-lite/LICENSE b/node_modules/body-parser/node_modules/iconv-lite/LICENSE new file mode 100644 index 0000000..d518d83 --- /dev/null +++ b/node_modules/body-parser/node_modules/iconv-lite/LICENSE @@ -0,0 +1,21 @@ +Copyright (c) 2011 Alexander Shtuchkin + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +"Software"), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND +NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE +LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION +OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION +WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + diff --git a/node_modules/body-parser/node_modules/iconv-lite/README.md b/node_modules/body-parser/node_modules/iconv-lite/README.md new file mode 100644 index 0000000..160b7cf --- /dev/null +++ b/node_modules/body-parser/node_modules/iconv-lite/README.md @@ -0,0 +1,157 @@ +## Pure JS character encoding conversion [![Build Status](https://travis-ci.org/ashtuchkin/iconv-lite.svg?branch=master)](https://travis-ci.org/ashtuchkin/iconv-lite) + + * Doesn't need native code compilation. Works on Windows and in sandboxed environments like [Cloud9](http://c9.io). + * Used in popular projects like [Express.js (body_parser)](https://github.com/expressjs/body-parser), + [Grunt](http://gruntjs.com/), [Nodemailer](http://www.nodemailer.com/), [Yeoman](http://yeoman.io/) and others. + * Faster than [node-iconv](https://github.com/bnoordhuis/node-iconv) (see below for performance comparison). + * Intuitive encode/decode API + * Streaming support for Node v0.10+ + * [Deprecated] Can extend Node.js primitives (buffers, streams) to support all iconv-lite encodings. + * In-browser usage via [Browserify](https://github.com/substack/node-browserify) (~180k gzip compressed with Buffer shim included). + * License: MIT. + +[![NPM Stats](https://nodei.co/npm/iconv-lite.png?downloads=true&downloadRank=true)](https://npmjs.org/packages/iconv-lite/) + +## Usage +### Basic API +```javascript +var iconv = require('iconv-lite'); + +// Convert from an encoded buffer to js string. +str = iconv.decode(new Buffer([0x68, 0x65, 0x6c, 0x6c, 0x6f]), 'win1251'); + +// Convert from js string to an encoded buffer. +buf = iconv.encode("Sample input string", 'win1251'); + +// Check if encoding is supported +iconv.encodingExists("us-ascii") +``` + +### Streaming API (Node v0.10+) +```javascript + +// Decode stream (from binary stream to js strings) +http.createServer(function(req, res) { + var converterStream = iconv.decodeStream('win1251'); + req.pipe(converterStream); + + converterStream.on('data', function(str) { + console.log(str); // Do something with decoded strings, chunk-by-chunk. + }); +}); + +// Convert encoding streaming example +fs.createReadStream('file-in-win1251.txt') + .pipe(iconv.decodeStream('win1251')) + .pipe(iconv.encodeStream('ucs2')) + .pipe(fs.createWriteStream('file-in-ucs2.txt')); + +// Sugar: all encode/decode streams have .collect(cb) method to accumulate data. +http.createServer(function(req, res) { + req.pipe(iconv.decodeStream('win1251')).collect(function(err, body) { + assert(typeof body == 'string'); + console.log(body); // full request body string + }); +}); +``` + +### [Deprecated] Extend Node.js own encodings +> NOTE: This doesn't work on latest Node versions. See [details](https://github.com/ashtuchkin/iconv-lite/wiki/Node-v4-compatibility). + +```javascript +// After this call all Node basic primitives will understand iconv-lite encodings. +iconv.extendNodeEncodings(); + +// Examples: +buf = new Buffer(str, 'win1251'); +buf.write(str, 'gbk'); +str = buf.toString('latin1'); +assert(Buffer.isEncoding('iso-8859-15')); +Buffer.byteLength(str, 'us-ascii'); + +http.createServer(function(req, res) { + req.setEncoding('big5'); + req.collect(function(err, body) { + console.log(body); + }); +}); + +fs.createReadStream("file.txt", "shift_jis"); + +// External modules are also supported (if they use Node primitives, which they probably do). +request = require('request'); +request({ + url: "http://github.com/", + encoding: "cp932" +}); + +// To remove extensions +iconv.undoExtendNodeEncodings(); +``` + +## Supported encodings + + * All node.js native encodings: utf8, ucs2 / utf16-le, ascii, binary, base64, hex. + * Additional unicode encodings: utf16, utf16-be, utf-7, utf-7-imap. + * All widespread singlebyte encodings: Windows 125x family, ISO-8859 family, + IBM/DOS codepages, Macintosh family, KOI8 family, all others supported by iconv library. + Aliases like 'latin1', 'us-ascii' also supported. + * All widespread multibyte encodings: CP932, CP936, CP949, CP950, GB2313, GBK, GB18030, Big5, Shift_JIS, EUC-JP. + +See [all supported encodings on wiki](https://github.com/ashtuchkin/iconv-lite/wiki/Supported-Encodings). + +Most singlebyte encodings are generated automatically from [node-iconv](https://github.com/bnoordhuis/node-iconv). Thank you Ben Noordhuis and libiconv authors! + +Multibyte encodings are generated from [Unicode.org mappings](http://www.unicode.org/Public/MAPPINGS/) and [WHATWG Encoding Standard mappings](http://encoding.spec.whatwg.org/). Thank you, respective authors! + + +## Encoding/decoding speed + +Comparison with node-iconv module (1000x256kb, on MacBook Pro, Core i5/2.6 GHz, Node v0.12.0). +Note: your results may vary, so please always check on your hardware. + + operation iconv@2.1.4 iconv-lite@0.4.7 + ---------------------------------------------------------- + encode('win1251') ~96 Mb/s ~320 Mb/s + decode('win1251') ~95 Mb/s ~246 Mb/s + +## BOM handling + + * Decoding: BOM is stripped by default, unless overridden by passing `stripBOM: false` in options + (f.ex. `iconv.decode(buf, enc, {stripBOM: false})`). + A callback might also be given as a `stripBOM` parameter - it'll be called if BOM character was actually found. + * Encoding: No BOM added, unless overridden by `addBOM: true` option. + +## UTF-16 Encodings + +This library supports UTF-16LE, UTF-16BE and UTF-16 encodings. First two are straightforward, but UTF-16 is trying to be +smart about endianness in the following ways: + * Decoding: uses BOM and 'spaces heuristic' to determine input endianness. Default is UTF-16LE, but can be + overridden with `defaultEncoding: 'utf-16be'` option. Strips BOM unless `stripBOM: false`. + * Encoding: uses UTF-16LE and writes BOM by default. Use `addBOM: false` to override. + +## Other notes + +When decoding, be sure to supply a Buffer to decode() method, otherwise [bad things usually happen](https://github.com/ashtuchkin/iconv-lite/wiki/Use-Buffers-when-decoding). +Untranslatable characters are set to � or ?. No transliteration is currently supported. +Node versions 0.10.31 and 0.11.13 are buggy, don't use them (see #65, #77). + +## Testing + +```bash +$ git clone git@github.com:ashtuchkin/iconv-lite.git +$ cd iconv-lite +$ npm install +$ npm test + +$ # To view performance: +$ node test/performance.js + +$ # To view test coverage: +$ npm run coverage +$ open coverage/lcov-report/index.html +``` + +## Adoption +[![NPM](https://nodei.co/npm-dl/iconv-lite.png)](https://nodei.co/npm/iconv-lite/) +[![Codeship Status for ashtuchkin/iconv-lite](https://www.codeship.io/projects/81670840-fa72-0131-4520-4a01a6c01acc/status)](https://www.codeship.io/projects/29053) diff --git a/node_modules/body-parser/node_modules/iconv-lite/encodings/dbcs-codec.js b/node_modules/body-parser/node_modules/iconv-lite/encodings/dbcs-codec.js new file mode 100644 index 0000000..366809e --- /dev/null +++ b/node_modules/body-parser/node_modules/iconv-lite/encodings/dbcs-codec.js @@ -0,0 +1,554 @@ +"use strict" + +// Multibyte codec. In this scheme, a character is represented by 1 or more bytes. +// Our codec supports UTF-16 surrogates, extensions for GB18030 and unicode sequences. +// To save memory and loading time, we read table files only when requested. + +exports._dbcs = DBCSCodec; + +var UNASSIGNED = -1, + GB18030_CODE = -2, + SEQ_START = -10, + NODE_START = -1000, + UNASSIGNED_NODE = new Array(0x100), + DEF_CHAR = -1; + +for (var i = 0; i < 0x100; i++) + UNASSIGNED_NODE[i] = UNASSIGNED; + + +// Class DBCSCodec reads and initializes mapping tables. +function DBCSCodec(codecOptions, iconv) { + this.encodingName = codecOptions.encodingName; + if (!codecOptions) + throw new Error("DBCS codec is called without the data.") + if (!codecOptions.table) + throw new Error("Encoding '" + this.encodingName + "' has no data."); + + // Load tables. + var mappingTable = codecOptions.table(); + + + // Decode tables: MBCS -> Unicode. + + // decodeTables is a trie, encoded as an array of arrays of integers. Internal arrays are trie nodes and all have len = 256. + // Trie root is decodeTables[0]. + // Values: >= 0 -> unicode character code. can be > 0xFFFF + // == UNASSIGNED -> unknown/unassigned sequence. + // == GB18030_CODE -> this is the end of a GB18030 4-byte sequence. + // <= NODE_START -> index of the next node in our trie to process next byte. + // <= SEQ_START -> index of the start of a character code sequence, in decodeTableSeq. + this.decodeTables = []; + this.decodeTables[0] = UNASSIGNED_NODE.slice(0); // Create root node. + + // Sometimes a MBCS char corresponds to a sequence of unicode chars. We store them as arrays of integers here. + this.decodeTableSeq = []; + + // Actual mapping tables consist of chunks. Use them to fill up decode tables. + for (var i = 0; i < mappingTable.length; i++) + this._addDecodeChunk(mappingTable[i]); + + this.defaultCharUnicode = iconv.defaultCharUnicode; + + + // Encode tables: Unicode -> DBCS. + + // `encodeTable` is array mapping from unicode char to encoded char. All its values are integers for performance. + // Because it can be sparse, it is represented as array of buckets by 256 chars each. Bucket can be null. + // Values: >= 0 -> it is a normal char. Write the value (if <=256 then 1 byte, if <=65536 then 2 bytes, etc.). + // == UNASSIGNED -> no conversion found. Output a default char. + // <= SEQ_START -> it's an index in encodeTableSeq, see below. The character starts a sequence. + this.encodeTable = []; + + // `encodeTableSeq` is used when a sequence of unicode characters is encoded as a single code. We use a tree of + // objects where keys correspond to characters in sequence and leafs are the encoded dbcs values. A special DEF_CHAR key + // means end of sequence (needed when one sequence is a strict subsequence of another). + // Objects are kept separately from encodeTable to increase performance. + this.encodeTableSeq = []; + + // Some chars can be decoded, but need not be encoded. + var skipEncodeChars = {}; + if (codecOptions.encodeSkipVals) + for (var i = 0; i < codecOptions.encodeSkipVals.length; i++) { + var val = codecOptions.encodeSkipVals[i]; + if (typeof val === 'number') + skipEncodeChars[val] = true; + else + for (var j = val.from; j <= val.to; j++) + skipEncodeChars[j] = true; + } + + // Use decode trie to recursively fill out encode tables. + this._fillEncodeTable(0, 0, skipEncodeChars); + + // Add more encoding pairs when needed. + if (codecOptions.encodeAdd) { + for (var uChar in codecOptions.encodeAdd) + if (Object.prototype.hasOwnProperty.call(codecOptions.encodeAdd, uChar)) + this._setEncodeChar(uChar.charCodeAt(0), codecOptions.encodeAdd[uChar]); + } + + this.defCharSB = this.encodeTable[0][iconv.defaultCharSingleByte.charCodeAt(0)]; + if (this.defCharSB === UNASSIGNED) this.defCharSB = this.encodeTable[0]['?']; + if (this.defCharSB === UNASSIGNED) this.defCharSB = "?".charCodeAt(0); + + + // Load & create GB18030 tables when needed. + if (typeof codecOptions.gb18030 === 'function') { + this.gb18030 = codecOptions.gb18030(); // Load GB18030 ranges. + + // Add GB18030 decode tables. + var thirdByteNodeIdx = this.decodeTables.length; + var thirdByteNode = this.decodeTables[thirdByteNodeIdx] = UNASSIGNED_NODE.slice(0); + + var fourthByteNodeIdx = this.decodeTables.length; + var fourthByteNode = this.decodeTables[fourthByteNodeIdx] = UNASSIGNED_NODE.slice(0); + + for (var i = 0x81; i <= 0xFE; i++) { + var secondByteNodeIdx = NODE_START - this.decodeTables[0][i]; + var secondByteNode = this.decodeTables[secondByteNodeIdx]; + for (var j = 0x30; j <= 0x39; j++) + secondByteNode[j] = NODE_START - thirdByteNodeIdx; + } + for (var i = 0x81; i <= 0xFE; i++) + thirdByteNode[i] = NODE_START - fourthByteNodeIdx; + for (var i = 0x30; i <= 0x39; i++) + fourthByteNode[i] = GB18030_CODE + } +} + +DBCSCodec.prototype.encoder = DBCSEncoder; +DBCSCodec.prototype.decoder = DBCSDecoder; + +// Decoder helpers +DBCSCodec.prototype._getDecodeTrieNode = function(addr) { + var bytes = []; + for (; addr > 0; addr >>= 8) + bytes.push(addr & 0xFF); + if (bytes.length == 0) + bytes.push(0); + + var node = this.decodeTables[0]; + for (var i = bytes.length-1; i > 0; i--) { // Traverse nodes deeper into the trie. + var val = node[bytes[i]]; + + if (val == UNASSIGNED) { // Create new node. + node[bytes[i]] = NODE_START - this.decodeTables.length; + this.decodeTables.push(node = UNASSIGNED_NODE.slice(0)); + } + else if (val <= NODE_START) { // Existing node. + node = this.decodeTables[NODE_START - val]; + } + else + throw new Error("Overwrite byte in " + this.encodingName + ", addr: " + addr.toString(16)); + } + return node; +} + + +DBCSCodec.prototype._addDecodeChunk = function(chunk) { + // First element of chunk is the hex mbcs code where we start. + var curAddr = parseInt(chunk[0], 16); + + // Choose the decoding node where we'll write our chars. + var writeTable = this._getDecodeTrieNode(curAddr); + curAddr = curAddr & 0xFF; + + // Write all other elements of the chunk to the table. + for (var k = 1; k < chunk.length; k++) { + var part = chunk[k]; + if (typeof part === "string") { // String, write as-is. + for (var l = 0; l < part.length;) { + var code = part.charCodeAt(l++); + if (0xD800 <= code && code < 0xDC00) { // Decode surrogate + var codeTrail = part.charCodeAt(l++); + if (0xDC00 <= codeTrail && codeTrail < 0xE000) + writeTable[curAddr++] = 0x10000 + (code - 0xD800) * 0x400 + (codeTrail - 0xDC00); + else + throw new Error("Incorrect surrogate pair in " + this.encodingName + " at chunk " + chunk[0]); + } + else if (0x0FF0 < code && code <= 0x0FFF) { // Character sequence (our own encoding used) + var len = 0xFFF - code + 2; + var seq = []; + for (var m = 0; m < len; m++) + seq.push(part.charCodeAt(l++)); // Simple variation: don't support surrogates or subsequences in seq. + + writeTable[curAddr++] = SEQ_START - this.decodeTableSeq.length; + this.decodeTableSeq.push(seq); + } + else + writeTable[curAddr++] = code; // Basic char + } + } + else if (typeof part === "number") { // Integer, meaning increasing sequence starting with prev character. + var charCode = writeTable[curAddr - 1] + 1; + for (var l = 0; l < part; l++) + writeTable[curAddr++] = charCode++; + } + else + throw new Error("Incorrect type '" + typeof part + "' given in " + this.encodingName + " at chunk " + chunk[0]); + } + if (curAddr > 0xFF) + throw new Error("Incorrect chunk in " + this.encodingName + " at addr " + chunk[0] + ": too long" + curAddr); +} + +// Encoder helpers +DBCSCodec.prototype._getEncodeBucket = function(uCode) { + var high = uCode >> 8; // This could be > 0xFF because of astral characters. + if (this.encodeTable[high] === undefined) + this.encodeTable[high] = UNASSIGNED_NODE.slice(0); // Create bucket on demand. + return this.encodeTable[high]; +} + +DBCSCodec.prototype._setEncodeChar = function(uCode, dbcsCode) { + var bucket = this._getEncodeBucket(uCode); + var low = uCode & 0xFF; + if (bucket[low] <= SEQ_START) + this.encodeTableSeq[SEQ_START-bucket[low]][DEF_CHAR] = dbcsCode; // There's already a sequence, set a single-char subsequence of it. + else if (bucket[low] == UNASSIGNED) + bucket[low] = dbcsCode; +} + +DBCSCodec.prototype._setEncodeSequence = function(seq, dbcsCode) { + + // Get the root of character tree according to first character of the sequence. + var uCode = seq[0]; + var bucket = this._getEncodeBucket(uCode); + var low = uCode & 0xFF; + + var node; + if (bucket[low] <= SEQ_START) { + // There's already a sequence with - use it. + node = this.encodeTableSeq[SEQ_START-bucket[low]]; + } + else { + // There was no sequence object - allocate a new one. + node = {}; + if (bucket[low] !== UNASSIGNED) node[DEF_CHAR] = bucket[low]; // If a char was set before - make it a single-char subsequence. + bucket[low] = SEQ_START - this.encodeTableSeq.length; + this.encodeTableSeq.push(node); + } + + // Traverse the character tree, allocating new nodes as needed. + for (var j = 1; j < seq.length-1; j++) { + var oldVal = node[uCode]; + if (typeof oldVal === 'object') + node = oldVal; + else { + node = node[uCode] = {} + if (oldVal !== undefined) + node[DEF_CHAR] = oldVal + } + } + + // Set the leaf to given dbcsCode. + uCode = seq[seq.length-1]; + node[uCode] = dbcsCode; +} + +DBCSCodec.prototype._fillEncodeTable = function(nodeIdx, prefix, skipEncodeChars) { + var node = this.decodeTables[nodeIdx]; + for (var i = 0; i < 0x100; i++) { + var uCode = node[i]; + var mbCode = prefix + i; + if (skipEncodeChars[mbCode]) + continue; + + if (uCode >= 0) + this._setEncodeChar(uCode, mbCode); + else if (uCode <= NODE_START) + this._fillEncodeTable(NODE_START - uCode, mbCode << 8, skipEncodeChars); + else if (uCode <= SEQ_START) + this._setEncodeSequence(this.decodeTableSeq[SEQ_START - uCode], mbCode); + } +} + + + +// == Encoder ================================================================== + +function DBCSEncoder(options, codec) { + // Encoder state + this.leadSurrogate = -1; + this.seqObj = undefined; + + // Static data + this.encodeTable = codec.encodeTable; + this.encodeTableSeq = codec.encodeTableSeq; + this.defaultCharSingleByte = codec.defCharSB; + this.gb18030 = codec.gb18030; +} + +DBCSEncoder.prototype.write = function(str) { + var newBuf = new Buffer(str.length * (this.gb18030 ? 4 : 3)), + leadSurrogate = this.leadSurrogate, + seqObj = this.seqObj, nextChar = -1, + i = 0, j = 0; + + while (true) { + // 0. Get next character. + if (nextChar === -1) { + if (i == str.length) break; + var uCode = str.charCodeAt(i++); + } + else { + var uCode = nextChar; + nextChar = -1; + } + + // 1. Handle surrogates. + if (0xD800 <= uCode && uCode < 0xE000) { // Char is one of surrogates. + if (uCode < 0xDC00) { // We've got lead surrogate. + if (leadSurrogate === -1) { + leadSurrogate = uCode; + continue; + } else { + leadSurrogate = uCode; + // Double lead surrogate found. + uCode = UNASSIGNED; + } + } else { // We've got trail surrogate. + if (leadSurrogate !== -1) { + uCode = 0x10000 + (leadSurrogate - 0xD800) * 0x400 + (uCode - 0xDC00); + leadSurrogate = -1; + } else { + // Incomplete surrogate pair - only trail surrogate found. + uCode = UNASSIGNED; + } + + } + } + else if (leadSurrogate !== -1) { + // Incomplete surrogate pair - only lead surrogate found. + nextChar = uCode; uCode = UNASSIGNED; // Write an error, then current char. + leadSurrogate = -1; + } + + // 2. Convert uCode character. + var dbcsCode = UNASSIGNED; + if (seqObj !== undefined && uCode != UNASSIGNED) { // We are in the middle of the sequence + var resCode = seqObj[uCode]; + if (typeof resCode === 'object') { // Sequence continues. + seqObj = resCode; + continue; + + } else if (typeof resCode == 'number') { // Sequence finished. Write it. + dbcsCode = resCode; + + } else if (resCode == undefined) { // Current character is not part of the sequence. + + // Try default character for this sequence + resCode = seqObj[DEF_CHAR]; + if (resCode !== undefined) { + dbcsCode = resCode; // Found. Write it. + nextChar = uCode; // Current character will be written too in the next iteration. + + } else { + // TODO: What if we have no default? (resCode == undefined) + // Then, we should write first char of the sequence as-is and try the rest recursively. + // Didn't do it for now because no encoding has this situation yet. + // Currently, just skip the sequence and write current char. + } + } + seqObj = undefined; + } + else if (uCode >= 0) { // Regular character + var subtable = this.encodeTable[uCode >> 8]; + if (subtable !== undefined) + dbcsCode = subtable[uCode & 0xFF]; + + if (dbcsCode <= SEQ_START) { // Sequence start + seqObj = this.encodeTableSeq[SEQ_START-dbcsCode]; + continue; + } + + if (dbcsCode == UNASSIGNED && this.gb18030) { + // Use GB18030 algorithm to find character(s) to write. + var idx = findIdx(this.gb18030.uChars, uCode); + if (idx != -1) { + var dbcsCode = this.gb18030.gbChars[idx] + (uCode - this.gb18030.uChars[idx]); + newBuf[j++] = 0x81 + Math.floor(dbcsCode / 12600); dbcsCode = dbcsCode % 12600; + newBuf[j++] = 0x30 + Math.floor(dbcsCode / 1260); dbcsCode = dbcsCode % 1260; + newBuf[j++] = 0x81 + Math.floor(dbcsCode / 10); dbcsCode = dbcsCode % 10; + newBuf[j++] = 0x30 + dbcsCode; + continue; + } + } + } + + // 3. Write dbcsCode character. + if (dbcsCode === UNASSIGNED) + dbcsCode = this.defaultCharSingleByte; + + if (dbcsCode < 0x100) { + newBuf[j++] = dbcsCode; + } + else if (dbcsCode < 0x10000) { + newBuf[j++] = dbcsCode >> 8; // high byte + newBuf[j++] = dbcsCode & 0xFF; // low byte + } + else { + newBuf[j++] = dbcsCode >> 16; + newBuf[j++] = (dbcsCode >> 8) & 0xFF; + newBuf[j++] = dbcsCode & 0xFF; + } + } + + this.seqObj = seqObj; + this.leadSurrogate = leadSurrogate; + return newBuf.slice(0, j); +} + +DBCSEncoder.prototype.end = function() { + if (this.leadSurrogate === -1 && this.seqObj === undefined) + return; // All clean. Most often case. + + var newBuf = new Buffer(10), j = 0; + + if (this.seqObj) { // We're in the sequence. + var dbcsCode = this.seqObj[DEF_CHAR]; + if (dbcsCode !== undefined) { // Write beginning of the sequence. + if (dbcsCode < 0x100) { + newBuf[j++] = dbcsCode; + } + else { + newBuf[j++] = dbcsCode >> 8; // high byte + newBuf[j++] = dbcsCode & 0xFF; // low byte + } + } else { + // See todo above. + } + this.seqObj = undefined; + } + + if (this.leadSurrogate !== -1) { + // Incomplete surrogate pair - only lead surrogate found. + newBuf[j++] = this.defaultCharSingleByte; + this.leadSurrogate = -1; + } + + return newBuf.slice(0, j); +} + +// Export for testing +DBCSEncoder.prototype.findIdx = findIdx; + + +// == Decoder ================================================================== + +function DBCSDecoder(options, codec) { + // Decoder state + this.nodeIdx = 0; + this.prevBuf = new Buffer(0); + + // Static data + this.decodeTables = codec.decodeTables; + this.decodeTableSeq = codec.decodeTableSeq; + this.defaultCharUnicode = codec.defaultCharUnicode; + this.gb18030 = codec.gb18030; +} + +DBCSDecoder.prototype.write = function(buf) { + var newBuf = new Buffer(buf.length*2), + nodeIdx = this.nodeIdx, + prevBuf = this.prevBuf, prevBufOffset = this.prevBuf.length, + seqStart = -this.prevBuf.length, // idx of the start of current parsed sequence. + uCode; + + if (prevBufOffset > 0) // Make prev buf overlap a little to make it easier to slice later. + prevBuf = Buffer.concat([prevBuf, buf.slice(0, 10)]); + + for (var i = 0, j = 0; i < buf.length; i++) { + var curByte = (i >= 0) ? buf[i] : prevBuf[i + prevBufOffset]; + + // Lookup in current trie node. + var uCode = this.decodeTables[nodeIdx][curByte]; + + if (uCode >= 0) { + // Normal character, just use it. + } + else if (uCode === UNASSIGNED) { // Unknown char. + // TODO: Callback with seq. + //var curSeq = (seqStart >= 0) ? buf.slice(seqStart, i+1) : prevBuf.slice(seqStart + prevBufOffset, i+1 + prevBufOffset); + i = seqStart; // Try to parse again, after skipping first byte of the sequence ('i' will be incremented by 'for' cycle). + uCode = this.defaultCharUnicode.charCodeAt(0); + } + else if (uCode === GB18030_CODE) { + var curSeq = (seqStart >= 0) ? buf.slice(seqStart, i+1) : prevBuf.slice(seqStart + prevBufOffset, i+1 + prevBufOffset); + var ptr = (curSeq[0]-0x81)*12600 + (curSeq[1]-0x30)*1260 + (curSeq[2]-0x81)*10 + (curSeq[3]-0x30); + var idx = findIdx(this.gb18030.gbChars, ptr); + uCode = this.gb18030.uChars[idx] + ptr - this.gb18030.gbChars[idx]; + } + else if (uCode <= NODE_START) { // Go to next trie node. + nodeIdx = NODE_START - uCode; + continue; + } + else if (uCode <= SEQ_START) { // Output a sequence of chars. + var seq = this.decodeTableSeq[SEQ_START - uCode]; + for (var k = 0; k < seq.length - 1; k++) { + uCode = seq[k]; + newBuf[j++] = uCode & 0xFF; + newBuf[j++] = uCode >> 8; + } + uCode = seq[seq.length-1]; + } + else + throw new Error("iconv-lite internal error: invalid decoding table value " + uCode + " at " + nodeIdx + "/" + curByte); + + // Write the character to buffer, handling higher planes using surrogate pair. + if (uCode > 0xFFFF) { + uCode -= 0x10000; + var uCodeLead = 0xD800 + Math.floor(uCode / 0x400); + newBuf[j++] = uCodeLead & 0xFF; + newBuf[j++] = uCodeLead >> 8; + + uCode = 0xDC00 + uCode % 0x400; + } + newBuf[j++] = uCode & 0xFF; + newBuf[j++] = uCode >> 8; + + // Reset trie node. + nodeIdx = 0; seqStart = i+1; + } + + this.nodeIdx = nodeIdx; + this.prevBuf = (seqStart >= 0) ? buf.slice(seqStart) : prevBuf.slice(seqStart + prevBufOffset); + return newBuf.slice(0, j).toString('ucs2'); +} + +DBCSDecoder.prototype.end = function() { + var ret = ''; + + // Try to parse all remaining chars. + while (this.prevBuf.length > 0) { + // Skip 1 character in the buffer. + ret += this.defaultCharUnicode; + var buf = this.prevBuf.slice(1); + + // Parse remaining as usual. + this.prevBuf = new Buffer(0); + this.nodeIdx = 0; + if (buf.length > 0) + ret += this.write(buf); + } + + this.nodeIdx = 0; + return ret; +} + +// Binary search for GB18030. Returns largest i such that table[i] <= val. +function findIdx(table, val) { + if (table[0] > val) + return -1; + + var l = 0, r = table.length; + while (l < r-1) { // always table[l] <= val < table[r] + var mid = l + Math.floor((r-l+1)/2); + if (table[mid] <= val) + l = mid; + else + r = mid; + } + return l; +} + diff --git a/node_modules/body-parser/node_modules/iconv-lite/encodings/dbcs-data.js b/node_modules/body-parser/node_modules/iconv-lite/encodings/dbcs-data.js new file mode 100644 index 0000000..2bf7415 --- /dev/null +++ b/node_modules/body-parser/node_modules/iconv-lite/encodings/dbcs-data.js @@ -0,0 +1,170 @@ +"use strict" + +// Description of supported double byte encodings and aliases. +// Tables are not require()-d until they are needed to speed up library load. +// require()-s are direct to support Browserify. + +module.exports = { + + // == Japanese/ShiftJIS ==================================================== + // All japanese encodings are based on JIS X set of standards: + // JIS X 0201 - Single-byte encoding of ASCII + ¥ + Kana chars at 0xA1-0xDF. + // JIS X 0208 - Main set of 6879 characters, placed in 94x94 plane, to be encoded by 2 bytes. + // Has several variations in 1978, 1983, 1990 and 1997. + // JIS X 0212 - Supplementary plane of 6067 chars in 94x94 plane. 1990. Effectively dead. + // JIS X 0213 - Extension and modern replacement of 0208 and 0212. Total chars: 11233. + // 2 planes, first is superset of 0208, second - revised 0212. + // Introduced in 2000, revised 2004. Some characters are in Unicode Plane 2 (0x2xxxx) + + // Byte encodings are: + // * Shift_JIS: Compatible with 0201, uses not defined chars in top half as lead bytes for double-byte + // encoding of 0208. Lead byte ranges: 0x81-0x9F, 0xE0-0xEF; Trail byte ranges: 0x40-0x7E, 0x80-0x9E, 0x9F-0xFC. + // Windows CP932 is a superset of Shift_JIS. Some companies added more chars, notably KDDI. + // * EUC-JP: Up to 3 bytes per character. Used mostly on *nixes. + // 0x00-0x7F - lower part of 0201 + // 0x8E, 0xA1-0xDF - upper part of 0201 + // (0xA1-0xFE)x2 - 0208 plane (94x94). + // 0x8F, (0xA1-0xFE)x2 - 0212 plane (94x94). + // * JIS X 208: 7-bit, direct encoding of 0208. Byte ranges: 0x21-0x7E (94 values). Uncommon. + // Used as-is in ISO2022 family. + // * ISO2022-JP: Stateful encoding, with escape sequences to switch between ASCII, + // 0201-1976 Roman, 0208-1978, 0208-1983. + // * ISO2022-JP-1: Adds esc seq for 0212-1990. + // * ISO2022-JP-2: Adds esc seq for GB2313-1980, KSX1001-1992, ISO8859-1, ISO8859-7. + // * ISO2022-JP-3: Adds esc seq for 0201-1976 Kana set, 0213-2000 Planes 1, 2. + // * ISO2022-JP-2004: Adds 0213-2004 Plane 1. + // + // After JIS X 0213 appeared, Shift_JIS-2004, EUC-JISX0213 and ISO2022-JP-2004 followed, with just changing the planes. + // + // Overall, it seems that it's a mess :( http://www8.plala.or.jp/tkubota1/unicode-symbols-map2.html + + + 'shiftjis': { + type: '_dbcs', + table: function() { return require('./tables/shiftjis.json') }, + encodeAdd: {'\u00a5': 0x5C, '\u203E': 0x7E}, + encodeSkipVals: [{from: 0xED40, to: 0xF940}], + }, + 'csshiftjis': 'shiftjis', + 'mskanji': 'shiftjis', + 'sjis': 'shiftjis', + 'windows31j': 'shiftjis', + 'xsjis': 'shiftjis', + 'windows932': 'shiftjis', + '932': 'shiftjis', + 'cp932': 'shiftjis', + + 'eucjp': { + type: '_dbcs', + table: function() { return require('./tables/eucjp.json') }, + encodeAdd: {'\u00a5': 0x5C, '\u203E': 0x7E}, + }, + + // TODO: KDDI extension to Shift_JIS + // TODO: IBM CCSID 942 = CP932, but F0-F9 custom chars and other char changes. + // TODO: IBM CCSID 943 = Shift_JIS = CP932 with original Shift_JIS lower 128 chars. + + // == Chinese/GBK ========================================================== + // http://en.wikipedia.org/wiki/GBK + + // Oldest GB2312 (1981, ~7600 chars) is a subset of CP936 + 'gb2312': 'cp936', + 'gb231280': 'cp936', + 'gb23121980': 'cp936', + 'csgb2312': 'cp936', + 'csiso58gb231280': 'cp936', + 'euccn': 'cp936', + 'isoir58': 'gbk', + + // Microsoft's CP936 is a subset and approximation of GBK. + // TODO: Euro = 0x80 in cp936, but not in GBK (where it's valid but undefined) + 'windows936': 'cp936', + '936': 'cp936', + 'cp936': { + type: '_dbcs', + table: function() { return require('./tables/cp936.json') }, + }, + + // GBK (~22000 chars) is an extension of CP936 that added user-mapped chars and some other. + 'gbk': { + type: '_dbcs', + table: function() { return require('./tables/cp936.json').concat(require('./tables/gbk-added.json')) }, + }, + 'xgbk': 'gbk', + + // GB18030 is an algorithmic extension of GBK. + 'gb18030': { + type: '_dbcs', + table: function() { return require('./tables/cp936.json').concat(require('./tables/gbk-added.json')) }, + gb18030: function() { return require('./tables/gb18030-ranges.json') }, + }, + + 'chinese': 'gb18030', + + // TODO: Support GB18030 (~27000 chars + whole unicode mapping, cp54936) + // http://icu-project.org/docs/papers/gb18030.html + // http://source.icu-project.org/repos/icu/data/trunk/charset/data/xml/gb-18030-2000.xml + // http://www.khngai.com/chinese/charmap/tblgbk.php?page=0 + + // == Korean =============================================================== + // EUC-KR, KS_C_5601 and KS X 1001 are exactly the same. + 'windows949': 'cp949', + '949': 'cp949', + 'cp949': { + type: '_dbcs', + table: function() { return require('./tables/cp949.json') }, + }, + + 'cseuckr': 'cp949', + 'csksc56011987': 'cp949', + 'euckr': 'cp949', + 'isoir149': 'cp949', + 'korean': 'cp949', + 'ksc56011987': 'cp949', + 'ksc56011989': 'cp949', + 'ksc5601': 'cp949', + + + // == Big5/Taiwan/Hong Kong ================================================ + // There are lots of tables for Big5 and cp950. Please see the following links for history: + // http://moztw.org/docs/big5/ http://www.haible.de/bruno/charsets/conversion-tables/Big5.html + // Variations, in roughly number of defined chars: + // * Windows CP 950: Microsoft variant of Big5. Canonical: http://www.unicode.org/Public/MAPPINGS/VENDORS/MICSFT/WINDOWS/CP950.TXT + // * Windows CP 951: Microsoft variant of Big5-HKSCS-2001. Seems to be never public. http://me.abelcheung.org/articles/research/what-is-cp951/ + // * Big5-2003 (Taiwan standard) almost superset of cp950. + // * Unicode-at-on (UAO) / Mozilla 1.8. Falling out of use on the Web. Not supported by other browsers. + // * Big5-HKSCS (-2001, -2004, -2008). Hong Kong standard. + // many unicode code points moved from PUA to Supplementary plane (U+2XXXX) over the years. + // Plus, it has 4 combining sequences. + // Seems that Mozilla refused to support it for 10 yrs. https://bugzilla.mozilla.org/show_bug.cgi?id=162431 https://bugzilla.mozilla.org/show_bug.cgi?id=310299 + // because big5-hkscs is the only encoding to include astral characters in non-algorithmic way. + // Implementations are not consistent within browsers; sometimes labeled as just big5. + // MS Internet Explorer switches from big5 to big5-hkscs when a patch applied. + // Great discussion & recap of what's going on https://bugzilla.mozilla.org/show_bug.cgi?id=912470#c31 + // In the encoder, it might make sense to support encoding old PUA mappings to Big5 bytes seq-s. + // Official spec: http://www.ogcio.gov.hk/en/business/tech_promotion/ccli/terms/doc/2003cmp_2008.txt + // http://www.ogcio.gov.hk/tc/business/tech_promotion/ccli/terms/doc/hkscs-2008-big5-iso.txt + // + // Current understanding of how to deal with Big5(-HKSCS) is in the Encoding Standard, http://encoding.spec.whatwg.org/#big5-encoder + // Unicode mapping (http://www.unicode.org/Public/MAPPINGS/OBSOLETE/EASTASIA/OTHER/BIG5.TXT) is said to be wrong. + + 'windows950': 'cp950', + '950': 'cp950', + 'cp950': { + type: '_dbcs', + table: function() { return require('./tables/cp950.json') }, + }, + + // Big5 has many variations and is an extension of cp950. We use Encoding Standard's as a consensus. + 'big5': 'big5hkscs', + 'big5hkscs': { + type: '_dbcs', + table: function() { return require('./tables/cp950.json').concat(require('./tables/big5-added.json')) }, + encodeSkipVals: [0xa2cc], + }, + + 'cnbig5': 'big5hkscs', + 'csbig5': 'big5hkscs', + 'xxbig5': 'big5hkscs', + +}; diff --git a/node_modules/body-parser/node_modules/iconv-lite/encodings/index.js b/node_modules/body-parser/node_modules/iconv-lite/encodings/index.js new file mode 100644 index 0000000..f7892fa --- /dev/null +++ b/node_modules/body-parser/node_modules/iconv-lite/encodings/index.js @@ -0,0 +1,22 @@ +"use strict" + +// Update this array if you add/rename/remove files in this directory. +// We support Browserify by skipping automatic module discovery and requiring modules directly. +var modules = [ + require("./internal"), + require("./utf16"), + require("./utf7"), + require("./sbcs-codec"), + require("./sbcs-data"), + require("./sbcs-data-generated"), + require("./dbcs-codec"), + require("./dbcs-data"), +]; + +// Put all encoding/alias/codec definitions to single object and export it. +for (var i = 0; i < modules.length; i++) { + var module = modules[i]; + for (var enc in module) + if (Object.prototype.hasOwnProperty.call(module, enc)) + exports[enc] = module[enc]; +} diff --git a/node_modules/body-parser/node_modules/iconv-lite/encodings/internal.js b/node_modules/body-parser/node_modules/iconv-lite/encodings/internal.js new file mode 100644 index 0000000..a8ae512 --- /dev/null +++ b/node_modules/body-parser/node_modules/iconv-lite/encodings/internal.js @@ -0,0 +1,187 @@ +"use strict" + +// Export Node.js internal encodings. + +module.exports = { + // Encodings + utf8: { type: "_internal", bomAware: true}, + cesu8: { type: "_internal", bomAware: true}, + unicode11utf8: "utf8", + + ucs2: { type: "_internal", bomAware: true}, + utf16le: "ucs2", + + binary: { type: "_internal" }, + base64: { type: "_internal" }, + hex: { type: "_internal" }, + + // Codec. + _internal: InternalCodec, +}; + +//------------------------------------------------------------------------------ + +function InternalCodec(codecOptions, iconv) { + this.enc = codecOptions.encodingName; + this.bomAware = codecOptions.bomAware; + + if (this.enc === "base64") + this.encoder = InternalEncoderBase64; + else if (this.enc === "cesu8") { + this.enc = "utf8"; // Use utf8 for decoding. + this.encoder = InternalEncoderCesu8; + + // Add decoder for versions of Node not supporting CESU-8 + if (new Buffer("eda080", 'hex').toString().length == 3) { + this.decoder = InternalDecoderCesu8; + this.defaultCharUnicode = iconv.defaultCharUnicode; + } + } +} + +InternalCodec.prototype.encoder = InternalEncoder; +InternalCodec.prototype.decoder = InternalDecoder; + +//------------------------------------------------------------------------------ + +// We use node.js internal decoder. Its signature is the same as ours. +var StringDecoder = require('string_decoder').StringDecoder; + +if (!StringDecoder.prototype.end) // Node v0.8 doesn't have this method. + StringDecoder.prototype.end = function() {}; + + +function InternalDecoder(options, codec) { + StringDecoder.call(this, codec.enc); +} + +InternalDecoder.prototype = StringDecoder.prototype; + + +//------------------------------------------------------------------------------ +// Encoder is mostly trivial + +function InternalEncoder(options, codec) { + this.enc = codec.enc; +} + +InternalEncoder.prototype.write = function(str) { + return new Buffer(str, this.enc); +} + +InternalEncoder.prototype.end = function() { +} + + +//------------------------------------------------------------------------------ +// Except base64 encoder, which must keep its state. + +function InternalEncoderBase64(options, codec) { + this.prevStr = ''; +} + +InternalEncoderBase64.prototype.write = function(str) { + str = this.prevStr + str; + var completeQuads = str.length - (str.length % 4); + this.prevStr = str.slice(completeQuads); + str = str.slice(0, completeQuads); + + return new Buffer(str, "base64"); +} + +InternalEncoderBase64.prototype.end = function() { + return new Buffer(this.prevStr, "base64"); +} + + +//------------------------------------------------------------------------------ +// CESU-8 encoder is also special. + +function InternalEncoderCesu8(options, codec) { +} + +InternalEncoderCesu8.prototype.write = function(str) { + var buf = new Buffer(str.length * 3), bufIdx = 0; + for (var i = 0; i < str.length; i++) { + var charCode = str.charCodeAt(i); + // Naive implementation, but it works because CESU-8 is especially easy + // to convert from UTF-16 (which all JS strings are encoded in). + if (charCode < 0x80) + buf[bufIdx++] = charCode; + else if (charCode < 0x800) { + buf[bufIdx++] = 0xC0 + (charCode >>> 6); + buf[bufIdx++] = 0x80 + (charCode & 0x3f); + } + else { // charCode will always be < 0x10000 in javascript. + buf[bufIdx++] = 0xE0 + (charCode >>> 12); + buf[bufIdx++] = 0x80 + ((charCode >>> 6) & 0x3f); + buf[bufIdx++] = 0x80 + (charCode & 0x3f); + } + } + return buf.slice(0, bufIdx); +} + +InternalEncoderCesu8.prototype.end = function() { +} + +//------------------------------------------------------------------------------ +// CESU-8 decoder is not implemented in Node v4.0+ + +function InternalDecoderCesu8(options, codec) { + this.acc = 0; + this.contBytes = 0; + this.accBytes = 0; + this.defaultCharUnicode = codec.defaultCharUnicode; +} + +InternalDecoderCesu8.prototype.write = function(buf) { + var acc = this.acc, contBytes = this.contBytes, accBytes = this.accBytes, + res = ''; + for (var i = 0; i < buf.length; i++) { + var curByte = buf[i]; + if ((curByte & 0xC0) !== 0x80) { // Leading byte + if (contBytes > 0) { // Previous code is invalid + res += this.defaultCharUnicode; + contBytes = 0; + } + + if (curByte < 0x80) { // Single-byte code + res += String.fromCharCode(curByte); + } else if (curByte < 0xE0) { // Two-byte code + acc = curByte & 0x1F; + contBytes = 1; accBytes = 1; + } else if (curByte < 0xF0) { // Three-byte code + acc = curByte & 0x0F; + contBytes = 2; accBytes = 1; + } else { // Four or more are not supported for CESU-8. + res += this.defaultCharUnicode; + } + } else { // Continuation byte + if (contBytes > 0) { // We're waiting for it. + acc = (acc << 6) | (curByte & 0x3f); + contBytes--; accBytes++; + if (contBytes === 0) { + // Check for overlong encoding, but support Modified UTF-8 (encoding NULL as C0 80) + if (accBytes === 2 && acc < 0x80 && acc > 0) + res += this.defaultCharUnicode; + else if (accBytes === 3 && acc < 0x800) + res += this.defaultCharUnicode; + else + // Actually add character. + res += String.fromCharCode(acc); + } + } else { // Unexpected continuation byte + res += this.defaultCharUnicode; + } + } + } + this.acc = acc; this.contBytes = contBytes; this.accBytes = accBytes; + return res; +} + +InternalDecoderCesu8.prototype.end = function() { + var res = 0; + if (this.contBytes > 0) + res += this.defaultCharUnicode; + return res; +} diff --git a/node_modules/body-parser/node_modules/iconv-lite/encodings/sbcs-codec.js b/node_modules/body-parser/node_modules/iconv-lite/encodings/sbcs-codec.js new file mode 100644 index 0000000..ca00171 --- /dev/null +++ b/node_modules/body-parser/node_modules/iconv-lite/encodings/sbcs-codec.js @@ -0,0 +1,72 @@ +"use strict" + +// Single-byte codec. Needs a 'chars' string parameter that contains 256 or 128 chars that +// correspond to encoded bytes (if 128 - then lower half is ASCII). + +exports._sbcs = SBCSCodec; +function SBCSCodec(codecOptions, iconv) { + if (!codecOptions) + throw new Error("SBCS codec is called without the data.") + + // Prepare char buffer for decoding. + if (!codecOptions.chars || (codecOptions.chars.length !== 128 && codecOptions.chars.length !== 256)) + throw new Error("Encoding '"+codecOptions.type+"' has incorrect 'chars' (must be of len 128 or 256)"); + + if (codecOptions.chars.length === 128) { + var asciiString = ""; + for (var i = 0; i < 128; i++) + asciiString += String.fromCharCode(i); + codecOptions.chars = asciiString + codecOptions.chars; + } + + this.decodeBuf = new Buffer(codecOptions.chars, 'ucs2'); + + // Encoding buffer. + var encodeBuf = new Buffer(65536); + encodeBuf.fill(iconv.defaultCharSingleByte.charCodeAt(0)); + + for (var i = 0; i < codecOptions.chars.length; i++) + encodeBuf[codecOptions.chars.charCodeAt(i)] = i; + + this.encodeBuf = encodeBuf; +} + +SBCSCodec.prototype.encoder = SBCSEncoder; +SBCSCodec.prototype.decoder = SBCSDecoder; + + +function SBCSEncoder(options, codec) { + this.encodeBuf = codec.encodeBuf; +} + +SBCSEncoder.prototype.write = function(str) { + var buf = new Buffer(str.length); + for (var i = 0; i < str.length; i++) + buf[i] = this.encodeBuf[str.charCodeAt(i)]; + + return buf; +} + +SBCSEncoder.prototype.end = function() { +} + + +function SBCSDecoder(options, codec) { + this.decodeBuf = codec.decodeBuf; +} + +SBCSDecoder.prototype.write = function(buf) { + // Strings are immutable in JS -> we use ucs2 buffer to speed up computations. + var decodeBuf = this.decodeBuf; + var newBuf = new Buffer(buf.length*2); + var idx1 = 0, idx2 = 0; + for (var i = 0; i < buf.length; i++) { + idx1 = buf[i]*2; idx2 = i*2; + newBuf[idx2] = decodeBuf[idx1]; + newBuf[idx2+1] = decodeBuf[idx1+1]; + } + return newBuf.toString('ucs2'); +} + +SBCSDecoder.prototype.end = function() { +} diff --git a/node_modules/body-parser/node_modules/iconv-lite/encodings/sbcs-data-generated.js b/node_modules/body-parser/node_modules/iconv-lite/encodings/sbcs-data-generated.js new file mode 100644 index 0000000..2308c91 --- /dev/null +++ b/node_modules/body-parser/node_modules/iconv-lite/encodings/sbcs-data-generated.js @@ -0,0 +1,451 @@ +"use strict" + +// Generated data for sbcs codec. Don't edit manually. Regenerate using generation/gen-sbcs.js script. +module.exports = { + "437": "cp437", + "737": "cp737", + "775": "cp775", + "850": "cp850", + "852": "cp852", + "855": "cp855", + "856": "cp856", + "857": "cp857", + "858": "cp858", + "860": "cp860", + "861": "cp861", + "862": "cp862", + "863": "cp863", + "864": "cp864", + "865": "cp865", + "866": "cp866", + "869": "cp869", + "874": "windows874", + "922": "cp922", + "1046": "cp1046", + "1124": "cp1124", + "1125": "cp1125", + "1129": "cp1129", + "1133": "cp1133", + "1161": "cp1161", + "1162": "cp1162", + "1163": "cp1163", + "1250": "windows1250", + "1251": "windows1251", + "1252": "windows1252", + "1253": "windows1253", + "1254": "windows1254", + "1255": "windows1255", + "1256": "windows1256", + "1257": "windows1257", + "1258": "windows1258", + "28591": "iso88591", + "28592": "iso88592", + "28593": "iso88593", + "28594": "iso88594", + "28595": "iso88595", + "28596": "iso88596", + "28597": "iso88597", + "28598": "iso88598", + "28599": "iso88599", + "28600": "iso885910", + "28601": "iso885911", + "28603": "iso885913", + "28604": "iso885914", + "28605": "iso885915", + "28606": "iso885916", + "windows874": { + "type": "_sbcs", + "chars": "€����…�����������‘’“”•–—�������� กขฃคฅฆงจฉชซฌญฎฏฐฑฒณดตถทธนบปผฝพฟภมยรฤลฦวศษสหฬอฮฯะัาำิีึืฺุู����฿เแโใไๅๆ็่้๊๋์ํ๎๏๐๑๒๓๔๕๖๗๘๙๚๛����" + }, + "win874": "windows874", + "cp874": "windows874", + "windows1250": { + "type": "_sbcs", + "chars": "€�‚�„…†‡�‰Š‹ŚŤŽŹ�‘’“”•–—�™š›śťžź ˇ˘Ł¤Ą¦§¨©Ş«¬­®Ż°±˛ł´µ¶·¸ąş»Ľ˝ľżŔÁÂĂÄĹĆÇČÉĘËĚÍÎĎĐŃŇÓÔŐÖ×ŘŮÚŰÜÝŢßŕáâăäĺćçčéęëěíîďđńňóôőö÷řůúűüýţ˙" + }, + "win1250": "windows1250", + "cp1250": "windows1250", + "windows1251": { + "type": "_sbcs", + "chars": "ЂЃ‚ѓ„…†‡€‰Љ‹ЊЌЋЏђ‘’“”•–—�™љ›њќћџ ЎўЈ¤Ґ¦§Ё©Є«¬­®Ї°±Ііґµ¶·ё№є»јЅѕїАБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯабвгдежзийклмнопрстуфхцчшщъыьэюя" + }, + "win1251": "windows1251", + "cp1251": "windows1251", + "windows1252": { + "type": "_sbcs", + "chars": "€�‚ƒ„…†‡ˆ‰Š‹Œ�Ž��‘’“”•–—˜™š›œ�žŸ ¡¢£¤¥¦§¨©ª«¬­®¯°±²³´µ¶·¸¹º»¼½¾¿ÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÐÑÒÓÔÕÖרÙÚÛÜÝÞßàáâãäåæçèéêëìíîïðñòóôõö÷øùúûüýþÿ" + }, + "win1252": "windows1252", + "cp1252": "windows1252", + "windows1253": { + "type": "_sbcs", + "chars": "€�‚ƒ„…†‡�‰�‹�����‘’“”•–—�™�›���� ΅Ά£¤¥¦§¨©�«¬­®―°±²³΄µ¶·ΈΉΊ»Ό½ΎΏΐΑΒΓΔΕΖΗΘΙΚΛΜΝΞΟΠΡ�ΣΤΥΦΧΨΩΪΫάέήίΰαβγδεζηθικλμνξοπρςστυφχψωϊϋόύώ�" + }, + "win1253": "windows1253", + "cp1253": "windows1253", + "windows1254": { + "type": "_sbcs", + "chars": "€�‚ƒ„…†‡ˆ‰Š‹Œ����‘’“”•–—˜™š›œ��Ÿ ¡¢£¤¥¦§¨©ª«¬­®¯°±²³´µ¶·¸¹º»¼½¾¿ÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏĞÑÒÓÔÕÖרÙÚÛÜİŞßàáâãäåæçèéêëìíîïğñòóôõö÷øùúûüışÿ" + }, + "win1254": "windows1254", + "cp1254": "windows1254", + "windows1255": { + "type": "_sbcs", + "chars": "€�‚ƒ„…†‡ˆ‰�‹�����‘’“”•–—˜™�›���� ¡¢£₪¥¦§¨©×«¬­®¯°±²³´µ¶·¸¹÷»¼½¾¿ְֱֲֳִֵֶַָֹ�ֻּֽ־ֿ׀ׁׂ׃װױײ׳״�������אבגדהוזחטיךכלםמןנסעףפץצקרשת��‎‏�" + }, + "win1255": "windows1255", + "cp1255": "windows1255", + "windows1256": { + "type": "_sbcs", + "chars": "€پ‚ƒ„…†‡ˆ‰ٹ‹Œچژڈگ‘’“”•–—ک™ڑ›œ‌‍ں ،¢£¤¥¦§¨©ھ«¬­®¯°±²³´µ¶·¸¹؛»¼½¾؟ہءآأؤإئابةتثجحخدذرزسشصض×طظعغـفقكàلâمنهوçèéêëىيîïًٌٍَôُِ÷ّùْûü‎‏ے" + }, + "win1256": "windows1256", + "cp1256": "windows1256", + "windows1257": { + "type": "_sbcs", + "chars": "€�‚�„…†‡�‰�‹�¨ˇ¸�‘’“”•–—�™�›�¯˛� �¢£¤�¦§Ø©Ŗ«¬­®Æ°±²³´µ¶·ø¹ŗ»¼½¾æĄĮĀĆÄÅĘĒČÉŹĖĢĶĪĻŠŃŅÓŌÕÖ×ŲŁŚŪÜŻŽßąįāćäåęēčéźėģķīļšńņóōõö÷ųłśūüżž˙" + }, + "win1257": "windows1257", + "cp1257": "windows1257", + "windows1258": { + "type": "_sbcs", + "chars": "€�‚ƒ„…†‡ˆ‰�‹Œ����‘’“”•–—˜™�›œ��Ÿ ¡¢£¤¥¦§¨©ª«¬­®¯°±²³´µ¶·¸¹º»¼½¾¿ÀÁÂĂÄÅÆÇÈÉÊË̀ÍÎÏĐÑ̉ÓÔƠÖרÙÚÛÜỮßàáâăäåæçèéêë́íîïđṇ̃óôơö÷øùúûüư₫ÿ" + }, + "win1258": "windows1258", + "cp1258": "windows1258", + "iso88591": { + "type": "_sbcs", + "chars": "€‚ƒ„…†‡ˆ‰Š‹ŒŽ‘’“”•–—˜™š›œžŸ ¡¢£¤¥¦§¨©ª«¬­®¯°±²³´µ¶·¸¹º»¼½¾¿ÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÐÑÒÓÔÕÖרÙÚÛÜÝÞßàáâãäåæçèéêëìíîïðñòóôõö÷øùúûüýþÿ" + }, + "cp28591": "iso88591", + "iso88592": { + "type": "_sbcs", + "chars": "€‚ƒ„…†‡ˆ‰Š‹ŒŽ‘’“”•–—˜™š›œžŸ Ą˘Ł¤ĽŚ§¨ŠŞŤŹ­ŽŻ°ą˛ł´ľśˇ¸šşťź˝žżŔÁÂĂÄĹĆÇČÉĘËĚÍÎĎĐŃŇÓÔŐÖ×ŘŮÚŰÜÝŢßŕáâăäĺćçčéęëěíîďđńňóôőö÷řůúűüýţ˙" + }, + "cp28592": "iso88592", + "iso88593": { + "type": "_sbcs", + "chars": "€‚ƒ„…†‡ˆ‰Š‹ŒŽ‘’“”•–—˜™š›œžŸ Ħ˘£¤�Ĥ§¨İŞĞĴ­�ݰħ²³´µĥ·¸ışğĵ½�żÀÁÂ�ÄĊĈÇÈÉÊËÌÍÎÏ�ÑÒÓÔĠÖ×ĜÙÚÛÜŬŜßàáâ�äċĉçèéêëìíîï�ñòóôġö÷ĝùúûüŭŝ˙" + }, + "cp28593": "iso88593", + "iso88594": { + "type": "_sbcs", + "chars": "€‚ƒ„…†‡ˆ‰Š‹ŒŽ‘’“”•–—˜™š›œžŸ ĄĸŖ¤Ĩϧ¨ŠĒĢŦ­Ž¯°ą˛ŗ´ĩšēģŧŊžŋĀÁÂÃÄÅÆĮČÉĘËĖÍÎĪĐŅŌĶÔÕÖרŲÚÛÜŨŪßāáâãäåæįčéęëėíîīđņōķôõö÷øųúûüũū˙" + }, + "cp28594": "iso88594", + "iso88595": { + "type": "_sbcs", + "chars": "€‚ƒ„…†‡ˆ‰Š‹ŒŽ‘’“”•–—˜™š›œžŸ ЁЂЃЄЅІЇЈЉЊЋЌ­ЎЏАБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯабвгдежзийклмнопрстуфхцчшщъыьэюя№ёђѓєѕіїјљњћќ§ўџ" + }, + "cp28595": "iso88595", + "iso88596": { + "type": "_sbcs", + "chars": "€‚ƒ„…†‡ˆ‰Š‹ŒŽ‘’“”•–—˜™š›œžŸ ���¤�������،­�������������؛���؟�ءآأؤإئابةتثجحخدذرزسشصضطظعغ�����ـفقكلمنهوىيًٌٍَُِّْ�������������" + }, + "cp28596": "iso88596", + "iso88597": { + "type": "_sbcs", + "chars": "€‚ƒ„…†‡ˆ‰Š‹ŒŽ‘’“”•–—˜™š›œžŸ ‘’£€₯¦§¨©ͺ«¬­�―°±²³΄΅Ά·ΈΉΊ»Ό½ΎΏΐΑΒΓΔΕΖΗΘΙΚΛΜΝΞΟΠΡ�ΣΤΥΦΧΨΩΪΫάέήίΰαβγδεζηθικλμνξοπρςστυφχψωϊϋόύώ�" + }, + "cp28597": "iso88597", + "iso88598": { + "type": "_sbcs", + "chars": "€‚ƒ„…†‡ˆ‰Š‹ŒŽ‘’“”•–—˜™š›œžŸ �¢£¤¥¦§¨©×«¬­®¯°±²³´µ¶·¸¹÷»¼½¾��������������������������������‗אבגדהוזחטיךכלםמןנסעףפץצקרשת��‎‏�" + }, + "cp28598": "iso88598", + "iso88599": { + "type": "_sbcs", + "chars": "€‚ƒ„…†‡ˆ‰Š‹ŒŽ‘’“”•–—˜™š›œžŸ ¡¢£¤¥¦§¨©ª«¬­®¯°±²³´µ¶·¸¹º»¼½¾¿ÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏĞÑÒÓÔÕÖרÙÚÛÜİŞßàáâãäåæçèéêëìíîïğñòóôõö÷øùúûüışÿ" + }, + "cp28599": "iso88599", + "iso885910": { + "type": "_sbcs", + "chars": "€‚ƒ„…†‡ˆ‰Š‹ŒŽ‘’“”•–—˜™š›œžŸ ĄĒĢĪĨͧĻĐŠŦŽ­ŪŊ°ąēģīĩķ·ļđšŧž―ūŋĀÁÂÃÄÅÆĮČÉĘËĖÍÎÏÐŅŌÓÔÕÖŨØŲÚÛÜÝÞßāáâãäåæįčéęëėíîïðņōóôõöũøųúûüýþĸ" + }, + "cp28600": "iso885910", + "iso885911": { + "type": "_sbcs", + "chars": "€‚ƒ„…†‡ˆ‰Š‹ŒŽ‘’“”•–—˜™š›œžŸ กขฃคฅฆงจฉชซฌญฎฏฐฑฒณดตถทธนบปผฝพฟภมยรฤลฦวศษสหฬอฮฯะัาำิีึืฺุู����฿เแโใไๅๆ็่้๊๋์ํ๎๏๐๑๒๓๔๕๖๗๘๙๚๛����" + }, + "cp28601": "iso885911", + "iso885913": { + "type": "_sbcs", + "chars": "€‚ƒ„…†‡ˆ‰Š‹ŒŽ‘’“”•–—˜™š›œžŸ ”¢£¤„¦§Ø©Ŗ«¬­®Æ°±²³“µ¶·ø¹ŗ»¼½¾æĄĮĀĆÄÅĘĒČÉŹĖĢĶĪĻŠŃŅÓŌÕÖ×ŲŁŚŪÜŻŽßąįāćäåęēčéźėģķīļšńņóōõö÷ųłśūüżž’" + }, + "cp28603": "iso885913", + "iso885914": { + "type": "_sbcs", + "chars": "€‚ƒ„…†‡ˆ‰Š‹ŒŽ‘’“”•–—˜™š›œžŸ Ḃḃ£ĊċḊ§Ẁ©ẂḋỲ­®ŸḞḟĠġṀṁ¶ṖẁṗẃṠỳẄẅṡÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏŴÑÒÓÔÕÖṪØÙÚÛÜÝŶßàáâãäåæçèéêëìíîïŵñòóôõöṫøùúûüýŷÿ" + }, + "cp28604": "iso885914", + "iso885915": { + "type": "_sbcs", + "chars": "€‚ƒ„…†‡ˆ‰Š‹ŒŽ‘’“”•–—˜™š›œžŸ ¡¢£€¥Š§š©ª«¬­®¯°±²³Žµ¶·ž¹º»ŒœŸ¿ÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÐÑÒÓÔÕÖרÙÚÛÜÝÞßàáâãäåæçèéêëìíîïðñòóôõö÷øùúûüýþÿ" + }, + "cp28605": "iso885915", + "iso885916": { + "type": "_sbcs", + "chars": "€‚ƒ„…†‡ˆ‰Š‹ŒŽ‘’“”•–—˜™š›œžŸ ĄąŁ€„Чš©Ș«Ź­źŻ°±ČłŽ”¶·žčș»ŒœŸżÀÁÂĂÄĆÆÇÈÉÊËÌÍÎÏĐŃÒÓÔŐÖŚŰÙÚÛÜĘȚßàáâăäćæçèéêëìíîïđńòóôőöśűùúûüęțÿ" + }, + "cp28606": "iso885916", + "cp437": { + "type": "_sbcs", + "chars": "ÇüéâäàåçêëèïîìÄÅÉæÆôöòûùÿÖÜ¢£¥₧ƒáíóúñѪº¿⌐¬½¼¡«»░▒▓│┤╡╢╖╕╣║╗╝╜╛┐└┴┬├─┼╞╟╚╔╩╦╠═╬╧╨╤╥╙╘╒╓╫╪┘┌█▄▌▐▀αßΓπΣσµτΦΘΩδ∞φε∩≡±≥≤⌠⌡÷≈°∙·√ⁿ²■ " + }, + "ibm437": "cp437", + "csibm437": "cp437", + "cp737": { + "type": "_sbcs", + "chars": "ΑΒΓΔΕΖΗΘΙΚΛΜΝΞΟΠΡΣΤΥΦΧΨΩαβγδεζηθικλμνξοπρσςτυφχψ░▒▓│┤╡╢╖╕╣║╗╝╜╛┐└┴┬├─┼╞╟╚╔╩╦╠═╬╧╨╤╥╙╘╒╓╫╪┘┌█▄▌▐▀ωάέήϊίόύϋώΆΈΉΊΌΎΏ±≥≤ΪΫ÷≈°∙·√ⁿ²■ " + }, + "ibm737": "cp737", + "csibm737": "cp737", + "cp775": { + "type": "_sbcs", + "chars": "ĆüéāäģåćłēŖŗīŹÄÅÉæÆōöĢ¢ŚśÖÜø£Ø×¤ĀĪóŻżź”¦©®¬½¼Ł«»░▒▓│┤ĄČĘĖ╣║╗╝ĮŠ┐└┴┬├─┼ŲŪ╚╔╩╦╠═╬Žąčęėįšųūž┘┌█▄▌▐▀ÓßŌŃõÕµńĶķĻļņĒŅ’­±“¾¶§÷„°∙·¹³²■ " + }, + "ibm775": "cp775", + "csibm775": "cp775", + "cp850": { + "type": "_sbcs", + "chars": "ÇüéâäàåçêëèïîìÄÅÉæÆôöòûùÿÖÜø£Ø×ƒáíóúñѪº¿®¬½¼¡«»░▒▓│┤ÁÂÀ©╣║╗╝¢¥┐└┴┬├─┼ãÃ╚╔╩╦╠═╬¤ðÐÊËÈıÍÎÏ┘┌█▄¦Ì▀ÓßÔÒõÕµþÞÚÛÙýݯ´­±‗¾¶§÷¸°¨·¹³²■ " + }, + "ibm850": "cp850", + "csibm850": "cp850", + "cp852": { + "type": "_sbcs", + "chars": "ÇüéâäůćçłëŐőîŹÄĆÉĹĺôöĽľŚśÖÜŤťŁ×čáíóúĄąŽžĘ꬟Ⱥ«»░▒▓│┤ÁÂĚŞ╣║╗╝Żż┐└┴┬├─┼Ăă╚╔╩╦╠═╬¤đĐĎËďŇÍÎě┘┌█▄ŢŮ▀ÓßÔŃńňŠšŔÚŕŰýÝţ´­˝˛ˇ˘§÷¸°¨˙űŘř■ " + }, + "ibm852": "cp852", + "csibm852": "cp852", + "cp855": { + "type": "_sbcs", + "chars": "ђЂѓЃёЁєЄѕЅіІїЇјЈљЉњЊћЋќЌўЎџЏюЮъЪаАбБцЦдДеЕфФгГ«»░▒▓│┤хХиИ╣║╗╝йЙ┐└┴┬├─┼кК╚╔╩╦╠═╬¤лЛмМнНоОп┘┌█▄Пя▀ЯрРсСтТуУжЖвВьЬ№­ыЫзЗшШэЭщЩчЧ§■ " + }, + "ibm855": "cp855", + "csibm855": "cp855", + "cp856": { + "type": "_sbcs", + "chars": "אבגדהוזחטיךכלםמןנסעףפץצקרשת�£�×����������®¬½¼�«»░▒▓│┤���©╣║╗╝¢¥┐└┴┬├─┼��╚╔╩╦╠═╬¤���������┘┌█▄¦�▀������µ�������¯´­±‗¾¶§÷¸°¨·¹³²■ " + }, + "ibm856": "cp856", + "csibm856": "cp856", + "cp857": { + "type": "_sbcs", + "chars": "ÇüéâäàåçêëèïîıÄÅÉæÆôöòûùİÖÜø£ØŞşáíóúñÑĞ𿮬½¼¡«»░▒▓│┤ÁÂÀ©╣║╗╝¢¥┐└┴┬├─┼ãÃ╚╔╩╦╠═╬¤ºªÊËÈ�ÍÎÏ┘┌█▄¦Ì▀ÓßÔÒõÕµ�×ÚÛÙìÿ¯´­±�¾¶§÷¸°¨·¹³²■ " + }, + "ibm857": "cp857", + "csibm857": "cp857", + "cp858": { + "type": "_sbcs", + "chars": "ÇüéâäàåçêëèïîìÄÅÉæÆôöòûùÿÖÜø£Ø×ƒáíóúñѪº¿®¬½¼¡«»░▒▓│┤ÁÂÀ©╣║╗╝¢¥┐└┴┬├─┼ãÃ╚╔╩╦╠═╬¤ðÐÊËÈ€ÍÎÏ┘┌█▄¦Ì▀ÓßÔÒõÕµþÞÚÛÙýݯ´­±‗¾¶§÷¸°¨·¹³²■ " + }, + "ibm858": "cp858", + "csibm858": "cp858", + "cp860": { + "type": "_sbcs", + "chars": "ÇüéâãàÁçêÊèÍÔìÃÂÉÀÈôõòÚùÌÕÜ¢£Ù₧ÓáíóúñѪº¿Ò¬½¼¡«»░▒▓│┤╡╢╖╕╣║╗╝╜╛┐└┴┬├─┼╞╟╚╔╩╦╠═╬╧╨╤╥╙╘╒╓╫╪┘┌█▄▌▐▀αßΓπΣσµτΦΘΩδ∞φε∩≡±≥≤⌠⌡÷≈°∙·√ⁿ²■ " + }, + "ibm860": "cp860", + "csibm860": "cp860", + "cp861": { + "type": "_sbcs", + "chars": "ÇüéâäàåçêëèÐðÞÄÅÉæÆôöþûÝýÖÜø£Ø₧ƒáíóúÁÍÓÚ¿⌐¬½¼¡«»░▒▓│┤╡╢╖╕╣║╗╝╜╛┐└┴┬├─┼╞╟╚╔╩╦╠═╬╧╨╤╥╙╘╒╓╫╪┘┌█▄▌▐▀αßΓπΣσµτΦΘΩδ∞φε∩≡±≥≤⌠⌡÷≈°∙·√ⁿ²■ " + }, + "ibm861": "cp861", + "csibm861": "cp861", + "cp862": { + "type": "_sbcs", + "chars": "אבגדהוזחטיךכלםמןנסעףפץצקרשת¢£¥₧ƒáíóúñѪº¿⌐¬½¼¡«»░▒▓│┤╡╢╖╕╣║╗╝╜╛┐└┴┬├─┼╞╟╚╔╩╦╠═╬╧╨╤╥╙╘╒╓╫╪┘┌█▄▌▐▀αßΓπΣσµτΦΘΩδ∞φε∩≡±≥≤⌠⌡÷≈°∙·√ⁿ²■ " + }, + "ibm862": "cp862", + "csibm862": "cp862", + "cp863": { + "type": "_sbcs", + "chars": "ÇüéâÂà¶çêëèïî‗À§ÉÈÊôËÏûù¤ÔÜ¢£ÙÛƒ¦´óú¨¸³¯Î⌐¬½¼¾«»░▒▓│┤╡╢╖╕╣║╗╝╜╛┐└┴┬├─┼╞╟╚╔╩╦╠═╬╧╨╤╥╙╘╒╓╫╪┘┌█▄▌▐▀αßΓπΣσµτΦΘΩδ∞φε∩≡±≥≤⌠⌡÷≈°∙·√ⁿ²■ " + }, + "ibm863": "cp863", + "csibm863": "cp863", + "cp864": { + "type": "_sbcs", + "chars": "\u0000\u0001\u0002\u0003\u0004\u0005\u0006\u0007\b\t\n\u000b\f\r\u000e\u000f\u0010\u0011\u0012\u0013\u0014\u0015\u0016\u0017\u0018\u0019\u001a\u001b\u001c\u001d\u001e\u001f !\"#$٪&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\]^_`abcdefghijklmnopqrstuvwxyz{|}~°·∙√▒─│┼┤┬├┴┐┌└┘β∞φ±½¼≈«»ﻷﻸ��ﻻﻼ� ­ﺂ£¤ﺄ��ﺎﺏﺕﺙ،ﺝﺡﺥ٠١٢٣٤٥٦٧٨٩ﻑ؛ﺱﺵﺹ؟¢ﺀﺁﺃﺅﻊﺋﺍﺑﺓﺗﺛﺟﺣﺧﺩﺫﺭﺯﺳﺷﺻﺿﻁﻅﻋﻏ¦¬÷×ﻉـﻓﻗﻛﻟﻣﻧﻫﻭﻯﻳﺽﻌﻎﻍﻡﹽّﻥﻩﻬﻰﻲﻐﻕﻵﻶﻝﻙﻱ■�" + }, + "ibm864": "cp864", + "csibm864": "cp864", + "cp865": { + "type": "_sbcs", + "chars": "ÇüéâäàåçêëèïîìÄÅÉæÆôöòûùÿÖÜø£Ø₧ƒáíóúñѪº¿⌐¬½¼¡«¤░▒▓│┤╡╢╖╕╣║╗╝╜╛┐└┴┬├─┼╞╟╚╔╩╦╠═╬╧╨╤╥╙╘╒╓╫╪┘┌█▄▌▐▀αßΓπΣσµτΦΘΩδ∞φε∩≡±≥≤⌠⌡÷≈°∙·√ⁿ²■ " + }, + "ibm865": "cp865", + "csibm865": "cp865", + "cp866": { + "type": "_sbcs", + "chars": "АБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯабвгдежзийклмноп░▒▓│┤╡╢╖╕╣║╗╝╜╛┐└┴┬├─┼╞╟╚╔╩╦╠═╬╧╨╤╥╙╘╒╓╫╪┘┌█▄▌▐▀рстуфхцчшщъыьэюяЁёЄєЇїЎў°∙·√№¤■ " + }, + "ibm866": "cp866", + "csibm866": "cp866", + "cp869": { + "type": "_sbcs", + "chars": "������Ά�·¬¦‘’Έ―ΉΊΪΌ��ΎΫ©Ώ²³ά£έήίϊΐόύΑΒΓΔΕΖΗ½ΘΙ«»░▒▓│┤ΚΛΜΝ╣║╗╝ΞΟ┐└┴┬├─┼ΠΡ╚╔╩╦╠═╬ΣΤΥΦΧΨΩαβγ┘┌█▄δε▀ζηθικλμνξοπρσςτ΄­±υφχ§ψ΅°¨ωϋΰώ■ " + }, + "ibm869": "cp869", + "csibm869": "cp869", + "cp922": { + "type": "_sbcs", + "chars": "€‚ƒ„…†‡ˆ‰Š‹ŒŽ‘’“”•–—˜™š›œžŸ ¡¢£¤¥¦§¨©ª«¬­®‾°±²³´µ¶·¸¹º»¼½¾¿ÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏŠÑÒÓÔÕÖרÙÚÛÜÝŽßàáâãäåæçèéêëìíîïšñòóôõö÷øùúûüýžÿ" + }, + "ibm922": "cp922", + "csibm922": "cp922", + "cp1046": { + "type": "_sbcs", + "chars": "ﺈ×÷ﹱˆ■│─┐┌└┘ﹹﹻﹽﹿﹷﺊﻰﻳﻲﻎﻏﻐﻶﻸﻺﻼ ¤ﺋﺑﺗﺛﺟﺣ،­ﺧﺳ٠١٢٣٤٥٦٧٨٩ﺷ؛ﺻﺿﻊ؟ﻋءآأؤإئابةتثجحخدذرزسشصضطﻇعغﻌﺂﺄﺎﻓـفقكلمنهوىيًٌٍَُِّْﻗﻛﻟﻵﻷﻹﻻﻣﻧﻬﻩ�" + }, + "ibm1046": "cp1046", + "csibm1046": "cp1046", + "cp1124": { + "type": "_sbcs", + "chars": "€‚ƒ„…†‡ˆ‰Š‹ŒŽ‘’“”•–—˜™š›œžŸ ЁЂҐЄЅІЇЈЉЊЋЌ­ЎЏАБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯабвгдежзийклмнопрстуфхцчшщъыьэюя№ёђґєѕіїјљњћќ§ўџ" + }, + "ibm1124": "cp1124", + "csibm1124": "cp1124", + "cp1125": { + "type": "_sbcs", + "chars": "АБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯабвгдежзийклмноп░▒▓│┤╡╢╖╕╣║╗╝╜╛┐└┴┬├─┼╞╟╚╔╩╦╠═╬╧╨╤╥╙╘╒╓╫╪┘┌█▄▌▐▀рстуфхцчшщъыьэюяЁёҐґЄєІіЇї·√№¤■ " + }, + "ibm1125": "cp1125", + "csibm1125": "cp1125", + "cp1129": { + "type": "_sbcs", + "chars": "€‚ƒ„…†‡ˆ‰Š‹ŒŽ‘’“”•–—˜™š›œžŸ ¡¢£¤¥¦§œ©ª«¬­®¯°±²³Ÿµ¶·Œ¹º»¼½¾¿ÀÁÂĂÄÅÆÇÈÉÊË̀ÍÎÏĐÑ̉ÓÔƠÖרÙÚÛÜỮßàáâăäåæçèéêë́íîïđṇ̃óôơö÷øùúûüư₫ÿ" + }, + "ibm1129": "cp1129", + "csibm1129": "cp1129", + "cp1133": { + "type": "_sbcs", + "chars": "€‚ƒ„…†‡ˆ‰Š‹ŒŽ‘’“”•–—˜™š›œžŸ ກຂຄງຈສຊຍດຕຖທນບປຜຝພຟມຢຣລວຫອຮ���ຯະາຳິີຶືຸູຼັົຽ���ເແໂໃໄ່້໊໋໌ໍໆ�ໜໝ₭����������������໐໑໒໓໔໕໖໗໘໙��¢¬¦�" + }, + "ibm1133": "cp1133", + "csibm1133": "cp1133", + "cp1161": { + "type": "_sbcs", + "chars": "��������������������������������่กขฃคฅฆงจฉชซฌญฎฏฐฑฒณดตถทธนบปผฝพฟภมยรฤลฦวศษสหฬอฮฯะัาำิีึืฺุู้๊๋€฿เแโใไๅๆ็่้๊๋์ํ๎๏๐๑๒๓๔๕๖๗๘๙๚๛¢¬¦ " + }, + "ibm1161": "cp1161", + "csibm1161": "cp1161", + "cp1162": { + "type": "_sbcs", + "chars": "€‚ƒ„…†‡ˆ‰Š‹ŒŽ‘’“”•–—˜™š›œžŸ กขฃคฅฆงจฉชซฌญฎฏฐฑฒณดตถทธนบปผฝพฟภมยรฤลฦวศษสหฬอฮฯะัาำิีึืฺุู����฿เแโใไๅๆ็่้๊๋์ํ๎๏๐๑๒๓๔๕๖๗๘๙๚๛����" + }, + "ibm1162": "cp1162", + "csibm1162": "cp1162", + "cp1163": { + "type": "_sbcs", + "chars": "€‚ƒ„…†‡ˆ‰Š‹ŒŽ‘’“”•–—˜™š›œžŸ ¡¢£€¥¦§œ©ª«¬­®¯°±²³Ÿµ¶·Œ¹º»¼½¾¿ÀÁÂĂÄÅÆÇÈÉÊË̀ÍÎÏĐÑ̉ÓÔƠÖרÙÚÛÜỮßàáâăäåæçèéêë́íîïđṇ̃óôơö÷øùúûüư₫ÿ" + }, + "ibm1163": "cp1163", + "csibm1163": "cp1163", + "maccroatian": { + "type": "_sbcs", + "chars": "ÄÅÇÉÑÖÜáàâäãåçéèêëíìîïñóòôöõúùûü†°¢£§•¶ß®Š™´¨≠ŽØ∞±≤≥∆µ∂∑∏š∫ªºΩžø¿¡¬√ƒ≈ƫȅ ÀÃÕŒœĐ—“”‘’÷◊�©⁄¤‹›Æ»–·‚„‰ÂćÁčÈÍÎÏÌÓÔđÒÚÛÙıˆ˜¯πË˚¸Êæˇ" + }, + "maccyrillic": { + "type": "_sbcs", + "chars": "АБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯ†°¢£§•¶І®©™Ђђ≠Ѓѓ∞±≤≥іµ∂ЈЄєЇїЉљЊњјЅ¬√ƒ≈∆«»… ЋћЌќѕ–—“”‘’÷„ЎўЏџ№Ёёяабвгдежзийклмнопрстуфхцчшщъыьэю¤" + }, + "macgreek": { + "type": "_sbcs", + "chars": "Ĺ²É³ÖÜ΅àâä΄¨çéèê룙î‰ôö¦­ùûü†ΓΔΘΛΞΠß®©ΣΪ§≠°·Α±≤≥¥ΒΕΖΗΙΚΜΦΫΨΩάΝ¬ΟΡ≈Τ«»… ΥΧΆΈœ–―“”‘’÷ΉΊΌΎέήίόΏύαβψδεφγηιξκλμνοπώρστθωςχυζϊϋΐΰ�" + }, + "maciceland": { + "type": "_sbcs", + "chars": "ÄÅÇÉÑÖÜáàâäãåçéèêëíìîïñóòôöõúùûüݰ¢£§•¶ß®©™´¨≠ÆØ∞±≤≥¥µ∂∑∏π∫ªºΩæø¿¡¬√ƒ≈∆«»… ÀÃÕŒœ–—“”‘’÷◊ÿŸ⁄¤ÐðÞþý·‚„‰ÂÊÁËÈÍÎÏÌÓÔ�ÒÚÛÙıˆ˜¯˘˙˚¸˝˛ˇ" + }, + "macroman": { + "type": "_sbcs", + "chars": "ÄÅÇÉÑÖÜáàâäãåçéèêëíìîïñóòôöõúùûü†°¢£§•¶ß®©™´¨≠ÆØ∞±≤≥¥µ∂∑∏π∫ªºΩæø¿¡¬√ƒ≈∆«»… ÀÃÕŒœ–—“”‘’÷◊ÿŸ⁄¤‹›fifl‡·‚„‰ÂÊÁËÈÍÎÏÌÓÔ�ÒÚÛÙıˆ˜¯˘˙˚¸˝˛ˇ" + }, + "macromania": { + "type": "_sbcs", + "chars": "ÄÅÇÉÑÖÜáàâäãåçéèêëíìîïñóòôöõúùûü†°¢£§•¶ß®©™´¨≠ĂŞ∞±≤≥¥µ∂∑∏π∫ªºΩăş¿¡¬√ƒ≈∆«»… ÀÃÕŒœ–—“”‘’÷◊ÿŸ⁄¤‹›Ţţ‡·‚„‰ÂÊÁËÈÍÎÏÌÓÔ�ÒÚÛÙıˆ˜¯˘˙˚¸˝˛ˇ" + }, + "macthai": { + "type": "_sbcs", + "chars": "«»…“”�•‘’� กขฃคฅฆงจฉชซฌญฎฏฐฑฒณดตถทธนบปผฝพฟภมยรฤลฦวศษสหฬอฮฯะัาำิีึืฺุู​–—฿เแโใไๅๆ็่้๊๋์ํ™๏๐๑๒๓๔๕๖๗๘๙®©����" + }, + "macturkish": { + "type": "_sbcs", + "chars": "ÄÅÇÉÑÖÜáàâäãåçéèêëíìîïñóòôöõúùûü†°¢£§•¶ß®©™´¨≠ÆØ∞±≤≥¥µ∂∑∏π∫ªºΩæø¿¡¬√ƒ≈∆«»… ÀÃÕŒœ–—“”‘’÷◊ÿŸĞğİıŞş‡·‚„‰ÂÊÁËÈÍÎÏÌÓÔ�ÒÚÛÙ�ˆ˜¯˘˙˚¸˝˛ˇ" + }, + "macukraine": { + "type": "_sbcs", + "chars": "АБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯ†°Ґ£§•¶І®©™Ђђ≠Ѓѓ∞±≤≥іµґЈЄєЇїЉљЊњјЅ¬√ƒ≈∆«»… ЋћЌќѕ–—“”‘’÷„ЎўЏџ№Ёёяабвгдежзийклмнопрстуфхцчшщъыьэю¤" + }, + "koi8r": { + "type": "_sbcs", + "chars": "─│┌┐└┘├┤┬┴┼▀▄█▌▐░▒▓⌠■∙√≈≤≥ ⌡°²·÷═║╒ё╓╔╕╖╗╘╙╚╛╜╝╞╟╠╡Ё╢╣╤╥╦╧╨╩╪╫╬©юабцдефгхийклмнопярстужвьызшэщчъЮАБЦДЕФГХИЙКЛМНОПЯРСТУЖВЬЫЗШЭЩЧЪ" + }, + "koi8u": { + "type": "_sbcs", + "chars": "─│┌┐└┘├┤┬┴┼▀▄█▌▐░▒▓⌠■∙√≈≤≥ ⌡°²·÷═║╒ёє╔ії╗╘╙╚╛ґ╝╞╟╠╡ЁЄ╣ІЇ╦╧╨╩╪Ґ╬©юабцдефгхийклмнопярстужвьызшэщчъЮАБЦДЕФГХИЙКЛМНОПЯРСТУЖВЬЫЗШЭЩЧЪ" + }, + "koi8ru": { + "type": "_sbcs", + "chars": "─│┌┐└┘├┤┬┴┼▀▄█▌▐░▒▓⌠■∙√≈≤≥ ⌡°²·÷═║╒ёє╔ії╗╘╙╚╛ґў╞╟╠╡ЁЄ╣ІЇ╦╧╨╩╪ҐЎ©юабцдефгхийклмнопярстужвьызшэщчъЮАБЦДЕФГХИЙКЛМНОПЯРСТУЖВЬЫЗШЭЩЧЪ" + }, + "koi8t": { + "type": "_sbcs", + "chars": "қғ‚Ғ„…†‡�‰ҳ‹ҲҷҶ�Қ‘’“”•–—�™�›�����ӯӮё¤ӣ¦§���«¬­®�°±²Ё�Ӣ¶·�№�»���©юабцдефгхийклмнопярстужвьызшэщчъЮАБЦДЕФГХИЙКЛМНОПЯРСТУЖВЬЫЗШЭЩЧЪ" + }, + "armscii8": { + "type": "_sbcs", + "chars": "€‚ƒ„…†‡ˆ‰Š‹ŒŽ‘’“”•–—˜™š›œžŸ �և։)(»«—.՝,-֊…՜՛՞ԱաԲբԳգԴդԵեԶզԷէԸըԹթԺժԻիԼլԽխԾծԿկՀհՁձՂղՃճՄմՅյՆնՇշՈոՉչՊպՋջՌռՍսՎվՏտՐրՑցՒւՓփՔքՕօՖֆ՚�" + }, + "rk1048": { + "type": "_sbcs", + "chars": "ЂЃ‚ѓ„…†‡€‰Љ‹ЊҚҺЏђ‘’“”•–—�™љ›њқһџ ҰұӘ¤Ө¦§Ё©Ғ«¬­®Ү°±Ііөµ¶·ё№ғ»әҢңүАБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯабвгдежзийклмнопрстуфхцчшщъыьэюя" + }, + "tcvn": { + "type": "_sbcs", + "chars": "\u0000ÚỤ\u0003ỪỬỮ\u0007\b\t\n\u000b\f\r\u000e\u000f\u0010ỨỰỲỶỸÝỴ\u0018\u0019\u001a\u001b\u001c\u001d\u001e\u001f !\"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\]^_`abcdefghijklmnopqrstuvwxyz{|}~ÀẢÃÁẠẶẬÈẺẼÉẸỆÌỈĨÍỊÒỎÕÓỌỘỜỞỠỚỢÙỦŨ ĂÂÊÔƠƯĐăâêôơưđẶ̀̀̉̃́àảãáạẲằẳẵắẴẮẦẨẪẤỀặầẩẫấậèỂẻẽéẹềểễếệìỉỄẾỒĩíịòỔỏõóọồổỗốộờởỡớợùỖủũúụừửữứựỳỷỹýỵỐ" + }, + "georgianacademy": { + "type": "_sbcs", + "chars": "€‚ƒ„…†‡ˆ‰Š‹ŒŽ‘’“”•–—˜™š›œžŸ ¡¢£¤¥¦§¨©ª«¬­®¯°±²³´µ¶·¸¹º»¼½¾¿აბგდევზთიკლმნოპჟრსტუფქღყშჩცძწჭხჯჰჱჲჳჴჵჶçèéêëìíîïðñòóôõö÷øùúûüýþÿ" + }, + "georgianps": { + "type": "_sbcs", + "chars": "€‚ƒ„…†‡ˆ‰Š‹ŒŽ‘’“”•–—˜™š›œžŸ ¡¢£¤¥¦§¨©ª«¬­®¯°±²³´µ¶·¸¹º»¼½¾¿აბგდევზჱთიკლმნჲოპჟრსტჳუფქღყშჩცძწჭხჴჯჰჵæçèéêëìíîïðñòóôõö÷øùúûüýþÿ" + }, + "pt154": { + "type": "_sbcs", + "chars": "ҖҒӮғ„…ҶҮҲүҠӢҢҚҺҸҗ‘’“”•–—ҳҷҡӣңқһҹ ЎўЈӨҘҰ§Ё©Ә«¬ӯ®Ҝ°ұІіҙө¶·ё№ә»јҪҫҝАБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯабвгдежзийклмнопрстуфхцчшщъыьэюя" + }, + "viscii": { + "type": "_sbcs", + "chars": "\u0000\u0001Ẳ\u0003\u0004ẴẪ\u0007\b\t\n\u000b\f\r\u000e\u000f\u0010\u0011\u0012\u0013Ỷ\u0015\u0016\u0017\u0018Ỹ\u001a\u001b\u001c\u001dỴ\u001f !\"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\]^_`abcdefghijklmnopqrstuvwxyz{|}~ẠẮẰẶẤẦẨẬẼẸẾỀỂỄỆỐỒỔỖỘỢỚỜỞỊỎỌỈỦŨỤỲÕắằặấầẩậẽẹếềểễệốồổỗỠƠộờởịỰỨỪỬơớƯÀÁÂÃẢĂẳẵÈÉÊẺÌÍĨỳĐứÒÓÔạỷừửÙÚỹỵÝỡưàáâãảăữẫèéêẻìíĩỉđựòóôõỏọụùúũủýợỮ" + }, + "iso646cn": { + "type": "_sbcs", + "chars": "\u0000\u0001\u0002\u0003\u0004\u0005\u0006\u0007\b\t\n\u000b\f\r\u000e\u000f\u0010\u0011\u0012\u0013\u0014\u0015\u0016\u0017\u0018\u0019\u001a\u001b\u001c\u001d\u001e\u001f !\"#¥%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\]^_`abcdefghijklmnopqrstuvwxyz{|}‾��������������������������������������������������������������������������������������������������������������������������������" + }, + "iso646jp": { + "type": "_sbcs", + "chars": "\u0000\u0001\u0002\u0003\u0004\u0005\u0006\u0007\b\t\n\u000b\f\r\u000e\u000f\u0010\u0011\u0012\u0013\u0014\u0015\u0016\u0017\u0018\u0019\u001a\u001b\u001c\u001d\u001e\u001f !\"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[¥]^_`abcdefghijklmnopqrstuvwxyz{|}‾��������������������������������������������������������������������������������������������������������������������������������" + }, + "hproman8": { + "type": "_sbcs", + "chars": "€‚ƒ„…†‡ˆ‰Š‹ŒŽ‘’“”•–—˜™š›œžŸ ÀÂÈÊËÎÏ´ˋˆ¨˜ÙÛ₤¯Ýý°ÇçÑñ¡¿¤£¥§ƒ¢âêôûáéóúàèòùäëöüÅîØÆåíøæÄìÖÜÉïßÔÁÃãÐðÍÌÓÒÕõŠšÚŸÿÞþ·µ¶¾—¼½ªº«■»±�" + }, + "macintosh": { + "type": "_sbcs", + "chars": "ÄÅÇÉÑÖÜáàâäãåçéèêëíìîïñóòôöõúùûü†°¢£§•¶ß®©™´¨≠ÆØ∞±≤≥¥µ∂∑∏π∫ªºΩæø¿¡¬√ƒ≈∆«»… ÀÃÕŒœ–—“”‘’÷◊ÿŸ⁄¤‹›fifl‡·‚„‰ÂÊÁËÈÍÎÏÌÓÔ�ÒÚÛÙıˆ˜¯˘˙˚¸˝˛ˇ" + }, + "ascii": { + "type": "_sbcs", + "chars": "��������������������������������������������������������������������������������������������������������������������������������" + }, + "tis620": { + "type": "_sbcs", + "chars": "���������������������������������กขฃคฅฆงจฉชซฌญฎฏฐฑฒณดตถทธนบปผฝพฟภมยรฤลฦวศษสหฬอฮฯะัาำิีึืฺุู����฿เแโใไๅๆ็่้๊๋์ํ๎๏๐๑๒๓๔๕๖๗๘๙๚๛����" + } +} \ No newline at end of file diff --git a/node_modules/body-parser/node_modules/iconv-lite/encodings/sbcs-data.js b/node_modules/body-parser/node_modules/iconv-lite/encodings/sbcs-data.js new file mode 100644 index 0000000..2058a71 --- /dev/null +++ b/node_modules/body-parser/node_modules/iconv-lite/encodings/sbcs-data.js @@ -0,0 +1,169 @@ +"use strict" + +// Manually added data to be used by sbcs codec in addition to generated one. + +module.exports = { + // Not supported by iconv, not sure why. + "10029": "maccenteuro", + "maccenteuro": { + "type": "_sbcs", + "chars": "ÄĀāÉĄÖÜáąČäčĆć鏟ĎíďĒēĖóėôöõúĚěü†°Ę£§•¶ß®©™ę¨≠ģĮįĪ≤≥īĶ∂∑łĻļĽľĹĺŅņѬ√ńŇ∆«»… ňŐÕőŌ–—“”‘’÷◊ōŔŕŘ‹›řŖŗŠ‚„šŚśÁŤťÍŽžŪÓÔūŮÚůŰűŲųÝýķŻŁżĢˇ" + }, + + "808": "cp808", + "ibm808": "cp808", + "cp808": { + "type": "_sbcs", + "chars": "АБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯабвгдежзийклмноп░▒▓│┤╡╢╖╕╣║╗╝╜╛┐└┴┬├─┼╞╟╚╔╩╦╠═╬╧╨╤╥╙╘╒╓╫╪┘┌█▄▌▐▀рстуфхцчшщъыьэюяЁёЄєЇїЎў°∙·√№€■ " + }, + + // Aliases of generated encodings. + "ascii8bit": "ascii", + "usascii": "ascii", + "ansix34": "ascii", + "ansix341968": "ascii", + "ansix341986": "ascii", + "csascii": "ascii", + "cp367": "ascii", + "ibm367": "ascii", + "isoir6": "ascii", + "iso646us": "ascii", + "iso646irv": "ascii", + "us": "ascii", + + "latin1": "iso88591", + "latin2": "iso88592", + "latin3": "iso88593", + "latin4": "iso88594", + "latin5": "iso88599", + "latin6": "iso885910", + "latin7": "iso885913", + "latin8": "iso885914", + "latin9": "iso885915", + "latin10": "iso885916", + + "csisolatin1": "iso88591", + "csisolatin2": "iso88592", + "csisolatin3": "iso88593", + "csisolatin4": "iso88594", + "csisolatincyrillic": "iso88595", + "csisolatinarabic": "iso88596", + "csisolatingreek" : "iso88597", + "csisolatinhebrew": "iso88598", + "csisolatin5": "iso88599", + "csisolatin6": "iso885910", + + "l1": "iso88591", + "l2": "iso88592", + "l3": "iso88593", + "l4": "iso88594", + "l5": "iso88599", + "l6": "iso885910", + "l7": "iso885913", + "l8": "iso885914", + "l9": "iso885915", + "l10": "iso885916", + + "isoir14": "iso646jp", + "isoir57": "iso646cn", + "isoir100": "iso88591", + "isoir101": "iso88592", + "isoir109": "iso88593", + "isoir110": "iso88594", + "isoir144": "iso88595", + "isoir127": "iso88596", + "isoir126": "iso88597", + "isoir138": "iso88598", + "isoir148": "iso88599", + "isoir157": "iso885910", + "isoir166": "tis620", + "isoir179": "iso885913", + "isoir199": "iso885914", + "isoir203": "iso885915", + "isoir226": "iso885916", + + "cp819": "iso88591", + "ibm819": "iso88591", + + "cyrillic": "iso88595", + + "arabic": "iso88596", + "arabic8": "iso88596", + "ecma114": "iso88596", + "asmo708": "iso88596", + + "greek" : "iso88597", + "greek8" : "iso88597", + "ecma118" : "iso88597", + "elot928" : "iso88597", + + "hebrew": "iso88598", + "hebrew8": "iso88598", + + "turkish": "iso88599", + "turkish8": "iso88599", + + "thai": "iso885911", + "thai8": "iso885911", + + "celtic": "iso885914", + "celtic8": "iso885914", + "isoceltic": "iso885914", + + "tis6200": "tis620", + "tis62025291": "tis620", + "tis62025330": "tis620", + + "10000": "macroman", + "10006": "macgreek", + "10007": "maccyrillic", + "10079": "maciceland", + "10081": "macturkish", + + "cspc8codepage437": "cp437", + "cspc775baltic": "cp775", + "cspc850multilingual": "cp850", + "cspcp852": "cp852", + "cspc862latinhebrew": "cp862", + "cpgr": "cp869", + + "msee": "cp1250", + "mscyrl": "cp1251", + "msansi": "cp1252", + "msgreek": "cp1253", + "msturk": "cp1254", + "mshebr": "cp1255", + "msarab": "cp1256", + "winbaltrim": "cp1257", + + "cp20866": "koi8r", + "20866": "koi8r", + "ibm878": "koi8r", + "cskoi8r": "koi8r", + + "cp21866": "koi8u", + "21866": "koi8u", + "ibm1168": "koi8u", + + "strk10482002": "rk1048", + + "tcvn5712": "tcvn", + "tcvn57121": "tcvn", + + "gb198880": "iso646cn", + "cn": "iso646cn", + + "csiso14jisc6220ro": "iso646jp", + "jisc62201969ro": "iso646jp", + "jp": "iso646jp", + + "cshproman8": "hproman8", + "r8": "hproman8", + "roman8": "hproman8", + "xroman8": "hproman8", + "ibm1051": "hproman8", + + "mac": "macintosh", + "csmacintosh": "macintosh", +}; + diff --git a/node_modules/body-parser/node_modules/iconv-lite/encodings/tables/big5-added.json b/node_modules/body-parser/node_modules/iconv-lite/encodings/tables/big5-added.json new file mode 100644 index 0000000..3c3d3c2 --- /dev/null +++ b/node_modules/body-parser/node_modules/iconv-lite/encodings/tables/big5-added.json @@ -0,0 +1,122 @@ +[ +["8740","䏰䰲䘃䖦䕸𧉧䵷䖳𧲱䳢𧳅㮕䜶䝄䱇䱀𤊿𣘗𧍒𦺋𧃒䱗𪍑䝏䗚䲅𧱬䴇䪤䚡𦬣爥𥩔𡩣𣸆𣽡晍囻"], +["8767","綕夝𨮹㷴霴𧯯寛𡵞媤㘥𩺰嫑宷峼杮薓𩥅瑡璝㡵𡵓𣚞𦀡㻬"], +["87a1","𥣞㫵竼龗𤅡𨤍𣇪𠪊𣉞䌊蒄龖鐯䤰蘓墖靊鈘秐稲晠権袝瑌篅枂稬剏遆㓦珄𥶹瓆鿇垳䤯呌䄱𣚎堘穲𧭥讏䚮𦺈䆁𥶙箮𢒼鿈𢓁𢓉𢓌鿉蔄𣖻䂴鿊䓡𪷿拁灮鿋"], +["8840","㇀",4,"𠄌㇅𠃑𠃍㇆㇇𠃋𡿨㇈𠃊㇉㇊㇋㇌𠄎㇍㇎ĀÁǍÀĒÉĚÈŌÓǑÒ࿿Ê̄Ế࿿Ê̌ỀÊāáǎàɑēéěèīíǐìōóǒòūúǔùǖǘǚ"], +["88a1","ǜü࿿ê̄ế࿿ê̌ềêɡ⏚⏛"], +["8940","𪎩𡅅"], +["8943","攊"], +["8946","丽滝鵎釟"], +["894c","𧜵撑会伨侨兖兴农凤务动医华发变团声处备夲头学实実岚庆总斉柾栄桥济炼电纤纬纺织经统缆缷艺苏药视设询车轧轮"], +["89a1","琑糼緍楆竉刧"], +["89ab","醌碸酞肼"], +["89b0","贋胶𠧧"], +["89b5","肟黇䳍鷉鸌䰾𩷶𧀎鸊𪄳㗁"], +["89c1","溚舾甙"], +["89c5","䤑马骏龙禇𨑬𡷊𠗐𢫦两亁亀亇亿仫伷㑌侽㹈倃傈㑽㒓㒥円夅凛凼刅争剹劐匧㗇厩㕑厰㕓参吣㕭㕲㚁咓咣咴咹哐哯唘唣唨㖘唿㖥㖿嗗㗅"], +["8a40","𧶄唥"], +["8a43","𠱂𠴕𥄫喐𢳆㧬𠍁蹆𤶸𩓥䁓𨂾睺𢰸㨴䟕𨅝𦧲𤷪擝𠵼𠾴𠳕𡃴撍蹾𠺖𠰋𠽤𢲩𨉖𤓓"], +["8a64","𠵆𩩍𨃩䟴𤺧𢳂骲㩧𩗴㿭㔆𥋇𩟔𧣈𢵄鵮頕"], +["8a76","䏙𦂥撴哣𢵌𢯊𡁷㧻𡁯"], +["8aa1","𦛚𦜖𧦠擪𥁒𠱃蹨𢆡𨭌𠜱"], +["8aac","䠋𠆩㿺塳𢶍"], +["8ab2","𤗈𠓼𦂗𠽌𠶖啹䂻䎺"], +["8abb","䪴𢩦𡂝膪飵𠶜捹㧾𢝵跀嚡摼㹃"], +["8ac9","𪘁𠸉𢫏𢳉"], +["8ace","𡃈𣧂㦒㨆𨊛㕸𥹉𢃇噒𠼱𢲲𩜠㒼氽𤸻"], +["8adf","𧕴𢺋𢈈𪙛𨳍𠹺𠰴𦠜羓𡃏𢠃𢤹㗻𥇣𠺌𠾍𠺪㾓𠼰𠵇𡅏𠹌"], +["8af6","𠺫𠮩𠵈𡃀𡄽㿹𢚖搲𠾭"], +["8b40","𣏴𧘹𢯎𠵾𠵿𢱑𢱕㨘𠺘𡃇𠼮𪘲𦭐𨳒𨶙𨳊閪哌苄喹"], +["8b55","𩻃鰦骶𧝞𢷮煀腭胬尜𦕲脴㞗卟𨂽醶𠻺𠸏𠹷𠻻㗝𤷫㘉𠳖嚯𢞵𡃉𠸐𠹸𡁸𡅈𨈇𡑕𠹹𤹐𢶤婔𡀝𡀞𡃵𡃶垜𠸑"], +["8ba1","𧚔𨋍𠾵𠹻𥅾㜃𠾶𡆀𥋘𪊽𤧚𡠺𤅷𨉼墙剨㘚𥜽箲孨䠀䬬鼧䧧鰟鮍𥭴𣄽嗻㗲嚉丨夂𡯁屮靑𠂆乛亻㔾尣彑忄㣺扌攵歺氵氺灬爫丬犭𤣩罒礻糹罓𦉪㓁"], +["8bde","𦍋耂肀𦘒𦥑卝衤见𧢲讠贝钅镸长门𨸏韦页风飞饣𩠐鱼鸟黄歯龜丷𠂇阝户钢"], +["8c40","倻淾𩱳龦㷉袏𤅎灷峵䬠𥇍㕙𥴰愢𨨲辧釶熑朙玺𣊁𪄇㲋𡦀䬐磤琂冮𨜏䀉橣𪊺䈣蘏𠩯稪𩥇𨫪靕灍匤𢁾鏴盙𨧣龧矝亣俰傼丯众龨吴綋墒壐𡶶庒庙忂𢜒斋"], +["8ca1","𣏹椙橃𣱣泿"], +["8ca7","爀𤔅玌㻛𤨓嬕璹讃𥲤𥚕窓篬糃繬苸薗龩袐龪躹龫迏蕟駠鈡龬𨶹𡐿䁱䊢娚"], +["8cc9","顨杫䉶圽"], +["8cce","藖𤥻芿𧄍䲁𦵴嵻𦬕𦾾龭龮宖龯曧繛湗秊㶈䓃𣉖𢞖䎚䔶"], +["8ce6","峕𣬚諹屸㴒𣕑嵸龲煗䕘𤃬𡸣䱷㥸㑊𠆤𦱁諌侴𠈹妿腬顖𩣺弻"], +["8d40","𠮟"], +["8d42","𢇁𨥭䄂䚻𩁹㼇龳𪆵䃸㟖䛷𦱆䅼𨚲𧏿䕭㣔𥒚䕡䔛䶉䱻䵶䗪㿈𤬏㙡䓞䒽䇭崾嵈嵖㷼㠏嶤嶹㠠㠸幂庽弥徃㤈㤔㤿㥍惗愽峥㦉憷憹懏㦸戬抐拥挘㧸嚱"], +["8da1","㨃揢揻搇摚㩋擀崕嘡龟㪗斆㪽旿晓㫲暒㬢朖㭂枤栀㭘桊梄㭲㭱㭻椉楃牜楤榟榅㮼槖㯝橥橴橱檂㯬檙㯲檫檵櫔櫶殁毁毪汵沪㳋洂洆洦涁㳯涤涱渕渘温溆𨧀溻滢滚齿滨滩漤漴㵆𣽁澁澾㵪㵵熷岙㶊瀬㶑灐灔灯灿炉𠌥䏁㗱𠻘"], +["8e40","𣻗垾𦻓焾𥟠㙎榢𨯩孴穉𥣡𩓙穥穽𥦬窻窰竂竃燑𦒍䇊竚竝竪䇯咲𥰁笋筕笩𥌎𥳾箢筯莜𥮴𦱿篐萡箒箸𥴠㶭𥱥蒒篺簆簵𥳁籄粃𤢂粦晽𤕸糉糇糦籴糳糵糎"], +["8ea1","繧䔝𦹄絝𦻖璍綉綫焵綳緒𤁗𦀩緤㴓緵𡟹緥𨍭縝𦄡𦅚繮纒䌫鑬縧罀罁罇礶𦋐駡羗𦍑羣𡙡𠁨䕜𣝦䔃𨌺翺𦒉者耈耝耨耯𪂇𦳃耻耼聡𢜔䦉𦘦𣷣𦛨朥肧𨩈脇脚墰𢛶汿𦒘𤾸擧𡒊舘𡡞橓𤩥𤪕䑺舩𠬍𦩒𣵾俹𡓽蓢荢𦬊𤦧𣔰𡝳𣷸芪椛芳䇛"], +["8f40","蕋苐茚𠸖𡞴㛁𣅽𣕚艻苢茘𣺋𦶣𦬅𦮗𣗎㶿茝嗬莅䔋𦶥莬菁菓㑾𦻔橗蕚㒖𦹂𢻯葘𥯤葱㷓䓤檧葊𣲵祘蒨𦮖𦹷𦹃蓞萏莑䒠蒓蓤𥲑䉀𥳀䕃蔴嫲𦺙䔧蕳䔖枿蘖"], +["8fa1","𨘥𨘻藁𧂈蘂𡖂𧃍䕫䕪蘨㙈𡢢号𧎚虾蝱𪃸蟮𢰧螱蟚蠏噡虬桖䘏衅衆𧗠𣶹𧗤衞袜䙛袴袵揁装睷𧜏覇覊覦覩覧覼𨨥觧𧤤𧪽誜瞓釾誐𧩙竩𧬺𣾏䜓𧬸煼謌謟𥐰𥕥謿譌譍誩𤩺讐讛誯𡛟䘕衏貛𧵔𧶏貫㜥𧵓賖𧶘𧶽贒贃𡤐賛灜贑𤳉㻐起"], +["9040","趩𨀂𡀔𤦊㭼𨆼𧄌竧躭躶軃鋔輙輭𨍥𨐒辥錃𪊟𠩐辳䤪𨧞𨔽𣶻廸𣉢迹𪀔𨚼𨔁𢌥㦀𦻗逷𨔼𧪾遡𨕬𨘋邨𨜓郄𨛦邮都酧㫰醩釄粬𨤳𡺉鈎沟鉁鉢𥖹銹𨫆𣲛𨬌𥗛"], +["90a1","𠴱錬鍫𨫡𨯫炏嫃𨫢𨫥䥥鉄𨯬𨰹𨯿鍳鑛躼閅閦鐦閠濶䊹𢙺𨛘𡉼𣸮䧟氜陻隖䅬隣𦻕懚隶磵𨫠隽双䦡𦲸𠉴𦐐𩂯𩃥𤫑𡤕𣌊霱虂霶䨏䔽䖅𤫩灵孁霛靜𩇕靗孊𩇫靟鐥僐𣂷𣂼鞉鞟鞱鞾韀韒韠𥑬韮琜𩐳響韵𩐝𧥺䫑頴頳顋顦㬎𧅵㵑𠘰𤅜"], +["9140","𥜆飊颷飈飇䫿𦴧𡛓喰飡飦飬鍸餹𤨩䭲𩡗𩤅駵騌騻騐驘𥜥㛄𩂱𩯕髠髢𩬅髴䰎鬔鬭𨘀倴鬴𦦨㣃𣁽魐魀𩴾婅𡡣鮎𤉋鰂鯿鰌𩹨鷔𩾷𪆒𪆫𪃡𪄣𪇟鵾鶃𪄴鸎梈"], +["91a1","鷄𢅛𪆓𪈠𡤻𪈳鴹𪂹𪊴麐麕麞麢䴴麪麯𤍤黁㭠㧥㴝伲㞾𨰫鼂鼈䮖鐤𦶢鼗鼖鼹嚟嚊齅馸𩂋韲葿齢齩竜龎爖䮾𤥵𤦻煷𤧸𤍈𤩑玞𨯚𡣺禟𨥾𨸶鍩鏳𨩄鋬鎁鏋𨥬𤒹爗㻫睲穃烐𤑳𤏸煾𡟯炣𡢾𣖙㻇𡢅𥐯𡟸㜢𡛻𡠹㛡𡝴𡣑𥽋㜣𡛀坛𤨥𡏾𡊨"], +["9240","𡏆𡒶蔃𣚦蔃葕𤦔𧅥𣸱𥕜𣻻𧁒䓴𣛮𩦝𦼦柹㜳㰕㷧塬𡤢栐䁗𣜿𤃡𤂋𤄏𦰡哋嚞𦚱嚒𠿟𠮨𠸍鏆𨬓鎜仸儫㠙𤐶亼𠑥𠍿佋侊𥙑婨𠆫𠏋㦙𠌊𠐔㐵伩𠋀𨺳𠉵諚𠈌亘"], +["92a1","働儍侢伃𤨎𣺊佂倮偬傁俌俥偘僼兙兛兝兞湶𣖕𣸹𣺿浲𡢄𣺉冨凃𠗠䓝𠒣𠒒𠒑赺𨪜𠜎剙劤𠡳勡鍮䙺熌𤎌𠰠𤦬𡃤槑𠸝瑹㻞璙琔瑖玘䮎𤪼𤂍叐㖄爏𤃉喴𠍅响𠯆圝鉝雴鍦埝垍坿㘾壋媙𨩆𡛺𡝯𡜐娬妸銏婾嫏娒𥥆𡧳𡡡𤊕㛵洅瑃娡𥺃"], +["9340","媁𨯗𠐓鏠璌𡌃焅䥲鐈𨧻鎽㞠尞岞幞幈𡦖𡥼𣫮廍孏𡤃𡤄㜁𡢠㛝𡛾㛓脪𨩇𡶺𣑲𨦨弌弎𡤧𡞫婫𡜻孄蘔𧗽衠恾𢡠𢘫忛㺸𢖯𢖾𩂈𦽳懀𠀾𠁆𢘛憙憘恵𢲛𢴇𤛔𩅍"], +["93a1","摱𤙥𢭪㨩𢬢𣑐𩣪𢹸挷𪑛撶挱揑𤧣𢵧护𢲡搻敫楲㯴𣂎𣊭𤦉𣊫唍𣋠𡣙𩐿曎𣊉𣆳㫠䆐𥖄𨬢𥖏𡛼𥕛𥐥磮𣄃𡠪𣈴㑤𣈏𣆂𤋉暎𦴤晫䮓昰𧡰𡷫晣𣋒𣋡昞𥡲㣑𣠺𣞼㮙𣞢𣏾瓐㮖枏𤘪梶栞㯄檾㡣𣟕𤒇樳橒櫉欅𡤒攑梘橌㯗橺歗𣿀𣲚鎠鋲𨯪𨫋"], +["9440","銉𨀞𨧜鑧涥漋𤧬浧𣽿㶏渄𤀼娽渊塇洤硂焻𤌚𤉶烱牐犇犔𤞏𤜥兹𤪤𠗫瑺𣻸𣙟𤩊𤤗𥿡㼆㺱𤫟𨰣𣼵悧㻳瓌琼鎇琷䒟𦷪䕑疃㽣𤳙𤴆㽘畕癳𪗆㬙瑨𨫌𤦫𤦎㫻"], +["94a1","㷍𤩎㻿𤧅𤣳釺圲鍂𨫣𡡤僟𥈡𥇧睸𣈲眎眏睻𤚗𣞁㩞𤣰琸璛㺿𤪺𤫇䃈𤪖𦆮錇𥖁砞碍碈磒珐祙𧝁𥛣䄎禛蒖禥樭𣻺稺秴䅮𡛦䄲鈵秱𠵌𤦌𠊙𣶺𡝮㖗啫㕰㚪𠇔𠰍竢婙𢛵𥪯𥪜娍𠉛磰娪𥯆竾䇹籝籭䈑𥮳𥺼𥺦糍𤧹𡞰粎籼粮檲緜縇緓罎𦉡"], +["9540","𦅜𧭈綗𥺂䉪𦭵𠤖柖𠁎𣗏埄𦐒𦏸𤥢翝笧𠠬𥫩𥵃笌𥸎駦虅驣樜𣐿㧢𤧷𦖭騟𦖠蒀𧄧𦳑䓪脷䐂胆脉腂𦞴飃𦩂艢艥𦩑葓𦶧蘐𧈛媆䅿𡡀嬫𡢡嫤𡣘蚠蜨𣶏蠭𧐢娂"], +["95a1","衮佅袇袿裦襥襍𥚃襔𧞅𧞄𨯵𨯙𨮜𨧹㺭蒣䛵䛏㟲訽訜𩑈彍鈫𤊄旔焩烄𡡅鵭貟賩𧷜妚矃姰䍮㛔踪躧𤰉輰轊䋴汘澻𢌡䢛潹溋𡟚鯩㚵𤤯邻邗啱䤆醻鐄𨩋䁢𨫼鐧𨰝𨰻蓥訫閙閧閗閖𨴴瑅㻂𤣿𤩂𤏪㻧𣈥随𨻧𨹦𨹥㻌𤧭𤩸𣿮琒瑫㻼靁𩂰"], +["9640","桇䨝𩂓𥟟靝鍨𨦉𨰦𨬯𦎾銺嬑譩䤼珹𤈛鞛靱餸𠼦巁𨯅𤪲頟𩓚鋶𩗗釥䓀𨭐𤩧𨭤飜𨩅㼀鈪䤥萔餻饍𧬆㷽馛䭯馪驜𨭥𥣈檏騡嫾騯𩣱䮐𩥈馼䮽䮗鍽塲𡌂堢𤦸"], +["96a1","𡓨硄𢜟𣶸棅㵽鑘㤧慐𢞁𢥫愇鱏鱓鱻鰵鰐魿鯏𩸭鮟𪇵𪃾鴡䲮𤄄鸘䲰鴌𪆴𪃭𪃳𩤯鶥蒽𦸒𦿟𦮂藼䔳𦶤𦺄𦷰萠藮𦸀𣟗𦁤秢𣖜𣙀䤭𤧞㵢鏛銾鍈𠊿碹鉷鑍俤㑀遤𥕝砽硔碶硋𡝗𣇉𤥁㚚佲濚濙瀞瀞吔𤆵垻壳垊鴖埗焴㒯𤆬燫𦱀𤾗嬨𡞵𨩉"], +["9740","愌嫎娋䊼𤒈㜬䭻𨧼鎻鎸𡣖𠼝葲𦳀𡐓𤋺𢰦𤏁妔𣶷𦝁綨𦅛𦂤𤦹𤦋𨧺鋥珢㻩璴𨭣𡢟㻡𤪳櫘珳珻㻖𤨾𤪔𡟙𤩦𠎧𡐤𤧥瑈𤤖炥𤥶銄珦鍟𠓾錱𨫎𨨖鎆𨯧𥗕䤵𨪂煫"], +["97a1","𤥃𠳿嚤𠘚𠯫𠲸唂秄𡟺緾𡛂𤩐𡡒䔮鐁㜊𨫀𤦭妰𡢿𡢃𧒄媡㛢𣵛㚰鉟婹𨪁𡡢鍴㳍𠪴䪖㦊僴㵩㵌𡎜煵䋻𨈘渏𩃤䓫浗𧹏灧沯㳖𣿭𣸭渂漌㵯𠏵畑㚼㓈䚀㻚䡱姄鉮䤾轁𨰜𦯀堒埈㛖𡑒烾𤍢𤩱𢿣𡊰𢎽梹楧𡎘𣓥𧯴𣛟𨪃𣟖𣏺𤲟樚𣚭𦲷萾䓟䓎"], +["9840","𦴦𦵑𦲂𦿞漗𧄉茽𡜺菭𦲀𧁓𡟛妉媂𡞳婡婱𡤅𤇼㜭姯𡜼㛇熎鎐暚𤊥婮娫𤊓樫𣻹𧜶𤑛𤋊焝𤉙𨧡侰𦴨峂𤓎𧹍𤎽樌𤉖𡌄炦焳𤏩㶥泟勇𤩏繥姫崯㷳彜𤩝𡟟綤萦"], +["98a1","咅𣫺𣌀𠈔坾𠣕𠘙㿥𡾞𪊶瀃𩅛嵰玏糓𨩙𩐠俈翧狍猐𧫴猸猹𥛶獁獈㺩𧬘遬燵𤣲珡臶㻊県㻑沢国琙琞琟㻢㻰㻴㻺瓓㼎㽓畂畭畲疍㽼痈痜㿀癍㿗癴㿜発𤽜熈嘣覀塩䀝睃䀹条䁅㗛瞘䁪䁯属瞾矋売砘点砜䂨砹硇硑硦葈𥔵礳栃礲䄃"], +["9940","䄉禑禙辻稆込䅧窑䆲窼艹䇄竏竛䇏両筢筬筻簒簛䉠䉺类粜䊌粸䊔糭输烀𠳏総緔緐緽羮羴犟䎗耠耥笹耮耱联㷌垴炠肷胩䏭脌猪脎脒畠脔䐁㬹腖腙腚"], +["99a1","䐓堺腼膄䐥膓䐭膥埯臁臤艔䒏芦艶苊苘苿䒰荗险榊萅烵葤惣蒈䔄蒾蓡蓸蔐蔸蕒䔻蕯蕰藠䕷虲蚒蚲蛯际螋䘆䘗袮裿褤襇覑𧥧訩訸誔誴豑賔賲贜䞘塟跃䟭仮踺嗘坔蹱嗵躰䠷軎転軤軭軲辷迁迊迌逳駄䢭飠鈓䤞鈨鉘鉫銱銮銿"], +["9a40","鋣鋫鋳鋴鋽鍃鎄鎭䥅䥑麿鐗匁鐝鐭鐾䥪鑔鑹锭関䦧间阳䧥枠䨤靀䨵鞲韂噔䫤惨颹䬙飱塄餎餙冴餜餷饂饝饢䭰駅䮝騼鬏窃魩鮁鯝鯱鯴䱭鰠㝯𡯂鵉鰺"], +["9aa1","黾噐鶓鶽鷀鷼银辶鹻麬麱麽黆铜黢黱黸竈齄𠂔𠊷𠎠椚铃妬𠓗塀铁㞹𠗕𠘕𠙶𡚺块煳𠫂𠫍𠮿呪吆𠯋咞𠯻𠰻𠱓𠱥𠱼惧𠲍噺𠲵𠳝𠳭𠵯𠶲𠷈楕鰯螥𠸄𠸎𠻗𠾐𠼭𠹳尠𠾼帋𡁜𡁏𡁶朞𡁻𡂈𡂖㙇𡂿𡃓𡄯𡄻卤蒭𡋣𡍵𡌶讁𡕷𡘙𡟃𡟇乸炻𡠭𡥪"], +["9b40","𡨭𡩅𡰪𡱰𡲬𡻈拃𡻕𡼕熘桕𢁅槩㛈𢉼𢏗𢏺𢜪𢡱𢥏苽𢥧𢦓𢫕覥𢫨辠𢬎鞸𢬿顇骽𢱌"], +["9b62","𢲈𢲷𥯨𢴈𢴒𢶷𢶕𢹂𢽴𢿌𣀳𣁦𣌟𣏞徱晈暿𧩹𣕧𣗳爁𤦺矗𣘚𣜖纇𠍆墵朎"], +["9ba1","椘𣪧𧙗𥿢𣸑𣺹𧗾𢂚䣐䪸𤄙𨪚𤋮𤌍𤀻𤌴𤎖𤩅𠗊凒𠘑妟𡺨㮾𣳿𤐄𤓖垈𤙴㦛𤜯𨗨𩧉㝢𢇃譞𨭎駖𤠒𤣻𤨕爉𤫀𠱸奥𤺥𤾆𠝹軚𥀬劏圿煱𥊙𥐙𣽊𤪧喼𥑆𥑮𦭒釔㑳𥔿𧘲𥕞䜘𥕢𥕦𥟇𤤿𥡝偦㓻𣏌惞𥤃䝼𨥈𥪮𥮉𥰆𡶐垡煑澶𦄂𧰒遖𦆲𤾚譢𦐂𦑊"], +["9c40","嵛𦯷輶𦒄𡤜諪𤧶𦒈𣿯𦔒䯀𦖿𦚵𢜛鑥𥟡憕娧晉侻嚹𤔡𦛼乪𤤴陖涏𦲽㘘襷𦞙𦡮𦐑𦡞營𦣇筂𩃀𠨑𦤦鄄𦤹穅鷰𦧺騦𦨭㙟𦑩𠀡禃𦨴𦭛崬𣔙菏𦮝䛐𦲤画补𦶮墶"], +["9ca1","㜜𢖍𧁋𧇍㱔𧊀𧊅銁𢅺𧊋錰𧋦𤧐氹钟𧑐𠻸蠧裵𢤦𨑳𡞱溸𤨪𡠠㦤㚹尐秣䔿暶𩲭𩢤襃𧟌𧡘囖䃟𡘊㦡𣜯𨃨𡏅熭荦𧧝𩆨婧䲷𧂯𨦫𧧽𧨊𧬋𧵦𤅺筃祾𨀉澵𪋟樃𨌘厢𦸇鎿栶靝𨅯𨀣𦦵𡏭𣈯𨁈嶅𨰰𨂃圕頣𨥉嶫𤦈斾槕叒𤪥𣾁㰑朶𨂐𨃴𨄮𡾡𨅏"], +["9d40","𨆉𨆯𨈚𨌆𨌯𨎊㗊𨑨𨚪䣺揦𨥖砈鉕𨦸䏲𨧧䏟𨧨𨭆𨯔姸𨰉輋𨿅𩃬筑𩄐𩄼㷷𩅞𤫊运犏嚋𩓧𩗩𩖰𩖸𩜲𩣑𩥉𩥪𩧃𩨨𩬎𩵚𩶛纟𩻸𩼣䲤镇𪊓熢𪋿䶑递𪗋䶜𠲜达嗁"], +["9da1","辺𢒰边𤪓䔉繿潖檱仪㓤𨬬𧢝㜺躀𡟵𨀤𨭬𨮙𧨾𦚯㷫𧙕𣲷𥘵𥥖亚𥺁𦉘嚿𠹭踎孭𣺈𤲞揞拐𡟶𡡻攰嘭𥱊吚𥌑㷆𩶘䱽嘢嘞罉𥻘奵𣵀蝰东𠿪𠵉𣚺脗鵞贘瘻鱅癎瞹鍅吲腈苷嘥脲萘肽嗪祢噃吖𠺝㗎嘅嗱曱𨋢㘭甴嗰喺咗啲𠱁𠲖廐𥅈𠹶𢱢"], +["9e40","𠺢麫絚嗞𡁵抝靭咔賍燶酶揼掹揾啩𢭃鱲𢺳冚㓟𠶧冧呍唞唓癦踭𦢊疱肶蠄螆裇膶萜𡃁䓬猄𤜆宐茋𦢓噻𢛴𧴯𤆣𧵳𦻐𧊶酰𡇙鈈𣳼𪚩𠺬𠻹牦𡲢䝎𤿂𧿹𠿫䃺"], +["9ea1","鱝攟𢶠䣳𤟠𩵼𠿬𠸊恢𧖣𠿭"], +["9ead","𦁈𡆇熣纎鵐业丄㕷嬍沲卧㚬㧜卽㚥𤘘墚𤭮舭呋垪𥪕𠥹"], +["9ec5","㩒𢑥獴𩺬䴉鯭𣳾𩼰䱛𤾩𩖞𩿞葜𣶶𧊲𦞳𣜠挮紥𣻷𣸬㨪逈勌㹴㙺䗩𠒎癀嫰𠺶硺𧼮墧䂿噼鮋嵴癔𪐴麅䳡痹㟻愙𣃚𤏲"], +["9ef5","噝𡊩垧𤥣𩸆刴𧂮㖭汊鵼"], +["9f40","籖鬹埞𡝬屓擓𩓐𦌵𧅤蚭𠴨𦴢𤫢𠵱"], +["9f4f","凾𡼏嶎霃𡷑麁遌笟鬂峑箣扨挵髿篏鬪籾鬮籂粆鰕篼鬉鼗鰛𤤾齚啳寃俽麘俲剠㸆勑坧偖妷帒韈鶫轜呩鞴饀鞺匬愰"], +["9fa1","椬叚鰊鴂䰻陁榀傦畆𡝭駚剳"], +["9fae","酙隁酜"], +["9fb2","酑𨺗捿𦴣櫊嘑醎畺抅𠏼獏籰𥰡𣳽"], +["9fc1","𤤙盖鮝个𠳔莾衂"], +["9fc9","届槀僭坺刟巵从氱𠇲伹咜哚劚趂㗾弌㗳"], +["9fdb","歒酼龥鮗頮颴骺麨麄煺笔"], +["9fe7","毺蠘罸"], +["9feb","嘠𪙊蹷齓"], +["9ff0","跔蹏鸜踁抂𨍽踨蹵竓𤩷稾磘泪詧瘇"], +["a040","𨩚鼦泎蟖痃𪊲硓咢贌狢獱謭猂瓱賫𤪻蘯徺袠䒷"], +["a055","𡠻𦸅"], +["a058","詾𢔛"], +["a05b","惽癧髗鵄鍮鮏蟵"], +["a063","蠏賷猬霡鮰㗖犲䰇籑饊𦅙慙䰄麖慽"], +["a073","坟慯抦戹拎㩜懢厪𣏵捤栂㗒"], +["a0a1","嵗𨯂迚𨸹"], +["a0a6","僙𡵆礆匲阸𠼻䁥"], +["a0ae","矾"], +["a0b0","糂𥼚糚稭聦聣絍甅瓲覔舚朌聢𧒆聛瓰脃眤覉𦟌畓𦻑螩蟎臈螌詉貭譃眫瓸蓚㘵榲趦"], +["a0d4","覩瑨涹蟁𤀑瓧㷛煶悤憜㳑煢恷"], +["a0e2","罱𨬭牐惩䭾删㰘𣳇𥻗𧙖𥔱𡥄𡋾𩤃𦷜𧂭峁𦆭𨨏𣙷𠃮𦡆𤼎䕢嬟𦍌齐麦𦉫"], +["a3c0","␀",31,"␡"], +["c6a1","①",9,"⑴",9,"ⅰ",9,"丶丿亅亠冂冖冫勹匸卩厶夊宀巛⼳广廴彐彡攴无疒癶辵隶¨ˆヽヾゝゞ〃仝々〆〇ー[]✽ぁ",23], +["c740","す",58,"ァアィイ"], +["c7a1","ゥ",81,"А",5,"ЁЖ",4], +["c840","Л",26,"ёж",25,"⇧↸↹㇏𠃌乚𠂊刂䒑"], +["c8a1","龰冈龱𧘇"], +["c8cd","¬¦'"㈱№℡゛゜⺀⺄⺆⺇⺈⺊⺌⺍⺕⺜⺝⺥⺧⺪⺬⺮⺶⺼⺾⻆⻊⻌⻍⻏⻖⻗⻞⻣"], +["c8f5","ʃɐɛɔɵœøŋʊɪ"], +["f9fe","■"], +["fa40","𠕇鋛𠗟𣿅蕌䊵珯况㙉𤥂𨧤鍄𡧛苮𣳈砼杄拟𤤳𨦪𠊠𦮳𡌅侫𢓭倈𦴩𧪄𣘀𤪱𢔓倩𠍾徤𠎀𠍇滛𠐟偽儁㑺儎顬㝃萖𤦤𠒇兠𣎴兪𠯿𢃼𠋥𢔰𠖎𣈳𡦃宂蝽𠖳𣲙冲冸"], +["faa1","鴴凉减凑㳜凓𤪦决凢卂凭菍椾𣜭彻刋刦刼劵剗劔効勅簕蕂勠蘍𦬓包𨫞啉滙𣾀𠥔𣿬匳卄𠯢泋𡜦栛珕恊㺪㣌𡛨燝䒢卭却𨚫卾卿𡖖𡘓矦厓𨪛厠厫厮玧𥝲㽙玜叁叅汉义埾叙㪫𠮏叠𣿫𢶣叶𠱷吓灹唫晗浛呭𦭓𠵴啝咏咤䞦𡜍𠻝㶴𠵍"], +["fb40","𨦼𢚘啇䳭启琗喆喩嘅𡣗𤀺䕒𤐵暳𡂴嘷曍𣊊暤暭噍噏磱囱鞇叾圀囯园𨭦㘣𡉏坆𤆥汮炋坂㚱𦱾埦𡐖堃𡑔𤍣堦𤯵塜墪㕡壠壜𡈼壻寿坃𪅐𤉸鏓㖡够梦㛃湙"], +["fba1","𡘾娤啓𡚒蔅姉𠵎𦲁𦴪𡟜姙𡟻𡞲𦶦浱𡠨𡛕姹𦹅媫婣㛦𤦩婷㜈媖瑥嫓𦾡𢕔㶅𡤑㜲𡚸広勐孶斈孼𧨎䀄䡝𠈄寕慠𡨴𥧌𠖥寳宝䴐尅𡭄尓珎尔𡲥𦬨屉䣝岅峩峯嶋𡷹𡸷崐崘嵆𡺤岺巗苼㠭𤤁𢁉𢅳芇㠶㯂帮檊幵幺𤒼𠳓厦亷廐厨𡝱帉廴𨒂"], +["fc40","廹廻㢠廼栾鐛弍𠇁弢㫞䢮𡌺强𦢈𢏐彘𢑱彣鞽𦹮彲鍀𨨶徧嶶㵟𥉐𡽪𧃸𢙨釖𠊞𨨩怱暅𡡷㥣㷇㘹垐𢞴祱㹀悞悤悳𤦂𤦏𧩓璤僡媠慤萤慂慈𦻒憁凴𠙖憇宪𣾷"], +["fca1","𢡟懓𨮝𩥝懐㤲𢦀𢣁怣慜攞掋𠄘担𡝰拕𢸍捬𤧟㨗搸揸𡎎𡟼撐澊𢸶頔𤂌𥜝擡擥鑻㩦携㩗敍漖𤨨𤨣斅敭敟𣁾斵𤥀䬷旑䃘𡠩无旣忟𣐀昘𣇷𣇸晄𣆤𣆥晋𠹵晧𥇦晳晴𡸽𣈱𨗴𣇈𥌓矅𢣷馤朂𤎜𤨡㬫槺𣟂杞杧杢𤇍𩃭柗䓩栢湐鈼栁𣏦𦶠桝"], +["fd40","𣑯槡樋𨫟楳棃𣗍椁椀㴲㨁𣘼㮀枬楡𨩊䋼椶榘㮡𠏉荣傐槹𣙙𢄪橅𣜃檝㯳枱櫈𩆜㰍欝𠤣惞欵歴𢟍溵𣫛𠎵𡥘㝀吡𣭚毡𣻼毜氷𢒋𤣱𦭑汚舦汹𣶼䓅𣶽𤆤𤤌𤤀"], +["fda1","𣳉㛥㳫𠴲鮃𣇹𢒑羏样𦴥𦶡𦷫涖浜湼漄𤥿𤂅𦹲蔳𦽴凇沜渝萮𨬡港𣸯瑓𣾂秌湏媑𣁋濸㜍澝𣸰滺𡒗𤀽䕕鏰潄潜㵎潴𩅰㴻澟𤅄濓𤂑𤅕𤀹𣿰𣾴𤄿凟𤅖𤅗𤅀𦇝灋灾炧炁烌烕烖烟䄄㷨熴熖𤉷焫煅媈煊煮岜𤍥煏鍢𤋁焬𤑚𤨧𤨢熺𨯨炽爎"], +["fe40","鑂爕夑鑃爤鍁𥘅爮牀𤥴梽牕牗㹕𣁄栍漽犂猪猫𤠣𨠫䣭𨠄猨献珏玪𠰺𦨮珉瑉𤇢𡛧𤨤昣㛅𤦷𤦍𤧻珷琕椃𤨦琹𠗃㻗瑜𢢭瑠𨺲瑇珤瑶莹瑬㜰瑴鏱樬璂䥓𤪌"], +["fea1","𤅟𤩹𨮏孆𨰃𡢞瓈𡦈甎瓩甞𨻙𡩋寗𨺬鎅畍畊畧畮𤾂㼄𤴓疎瑝疞疴瘂瘬癑癏癯癶𦏵皐臯㟸𦤑𦤎皡皥皷盌𦾟葢𥂝𥅽𡸜眞眦着撯𥈠睘𣊬瞯𨥤𨥨𡛁矴砉𡍶𤨒棊碯磇磓隥礮𥗠磗礴碱𧘌辸袄𨬫𦂃𢘜禆褀椂禀𥡗禝𧬹礼禩渪𧄦㺨秆𩄍秔"] +] diff --git a/node_modules/body-parser/node_modules/iconv-lite/encodings/tables/cp936.json b/node_modules/body-parser/node_modules/iconv-lite/encodings/tables/cp936.json new file mode 100644 index 0000000..49ddb9a --- /dev/null +++ b/node_modules/body-parser/node_modules/iconv-lite/encodings/tables/cp936.json @@ -0,0 +1,264 @@ +[ +["0","\u0000",127,"€"], +["8140","丂丄丅丆丏丒丗丟丠両丣並丩丮丯丱丳丵丷丼乀乁乂乄乆乊乑乕乗乚乛乢乣乤乥乧乨乪",5,"乲乴",9,"乿",6,"亇亊"], +["8180","亐亖亗亙亜亝亞亣亪亯亰亱亴亶亷亸亹亼亽亾仈仌仏仐仒仚仛仜仠仢仦仧仩仭仮仯仱仴仸仹仺仼仾伀伂",6,"伋伌伒",4,"伜伝伡伣伨伩伬伭伮伱伳伵伷伹伻伾",4,"佄佅佇",5,"佒佔佖佡佢佦佨佪佫佭佮佱佲併佷佸佹佺佽侀侁侂侅來侇侊侌侎侐侒侓侕侖侘侙侚侜侞侟価侢"], +["8240","侤侫侭侰",4,"侶",8,"俀俁係俆俇俈俉俋俌俍俒",4,"俙俛俠俢俤俥俧俫俬俰俲俴俵俶俷俹俻俼俽俿",11], +["8280","個倎倐們倓倕倖倗倛倝倞倠倢倣値倧倫倯",10,"倻倽倿偀偁偂偄偅偆偉偊偋偍偐",4,"偖偗偘偙偛偝",7,"偦",5,"偭",8,"偸偹偺偼偽傁傂傃傄傆傇傉傊傋傌傎",20,"傤傦傪傫傭",4,"傳",6,"傼"], +["8340","傽",17,"僐",5,"僗僘僙僛",10,"僨僩僪僫僯僰僱僲僴僶",4,"僼",9,"儈"], +["8380","儉儊儌",5,"儓",13,"儢",28,"兂兇兊兌兎兏児兒兓兗兘兙兛兝",4,"兣兤兦內兩兪兯兲兺兾兿冃冄円冇冊冋冎冏冐冑冓冔冘冚冝冞冟冡冣冦",4,"冭冮冴冸冹冺冾冿凁凂凃凅凈凊凍凎凐凒",5], +["8440","凘凙凚凜凞凟凢凣凥",5,"凬凮凱凲凴凷凾刄刅刉刋刌刏刐刓刔刕刜刞刟刡刢刣別刦刧刪刬刯刱刲刴刵刼刾剄",5,"剋剎剏剒剓剕剗剘"], +["8480","剙剚剛剝剟剠剢剣剤剦剨剫剬剭剮剰剱剳",9,"剾劀劃",4,"劉",6,"劑劒劔",6,"劜劤劥劦劧劮劯劰労",9,"勀勁勂勄勅勆勈勊勌勍勎勏勑勓勔動勗務",5,"勠勡勢勣勥",10,"勱",7,"勻勼勽匁匂匃匄匇匉匊匋匌匎"], +["8540","匑匒匓匔匘匛匜匞匟匢匤匥匧匨匩匫匬匭匯",9,"匼匽區卂卄卆卋卌卍卐協単卙卛卝卥卨卪卬卭卲卶卹卻卼卽卾厀厁厃厇厈厊厎厏"], +["8580","厐",4,"厖厗厙厛厜厞厠厡厤厧厪厫厬厭厯",6,"厷厸厹厺厼厽厾叀參",4,"収叏叐叒叓叕叚叜叝叞叡叢叧叴叺叾叿吀吂吅吇吋吔吘吙吚吜吢吤吥吪吰吳吶吷吺吽吿呁呂呄呅呇呉呌呍呎呏呑呚呝",4,"呣呥呧呩",7,"呴呹呺呾呿咁咃咅咇咈咉咊咍咑咓咗咘咜咞咟咠咡"], +["8640","咢咥咮咰咲咵咶咷咹咺咼咾哃哅哊哋哖哘哛哠",4,"哫哬哯哰哱哴",5,"哻哾唀唂唃唄唅唈唊",4,"唒唓唕",5,"唜唝唞唟唡唥唦"], +["8680","唨唩唫唭唲唴唵唶唸唹唺唻唽啀啂啅啇啈啋",4,"啑啒啓啔啗",4,"啝啞啟啠啢啣啨啩啫啯",5,"啹啺啽啿喅喆喌喍喎喐喒喓喕喖喗喚喛喞喠",6,"喨",8,"喲喴営喸喺喼喿",4,"嗆嗇嗈嗊嗋嗎嗏嗐嗕嗗",4,"嗞嗠嗢嗧嗩嗭嗮嗰嗱嗴嗶嗸",4,"嗿嘂嘃嘄嘅"], +["8740","嘆嘇嘊嘋嘍嘐",7,"嘙嘚嘜嘝嘠嘡嘢嘥嘦嘨嘩嘪嘫嘮嘯嘰嘳嘵嘷嘸嘺嘼嘽嘾噀",11,"噏",4,"噕噖噚噛噝",4], +["8780","噣噥噦噧噭噮噯噰噲噳噴噵噷噸噹噺噽",7,"嚇",6,"嚐嚑嚒嚔",14,"嚤",10,"嚰",6,"嚸嚹嚺嚻嚽",12,"囋",8,"囕囖囘囙囜団囥",5,"囬囮囯囲図囶囷囸囻囼圀圁圂圅圇國",6], +["8840","園",9,"圝圞圠圡圢圤圥圦圧圫圱圲圴",4,"圼圽圿坁坃坄坅坆坈坉坋坒",4,"坘坙坢坣坥坧坬坮坰坱坲坴坵坸坹坺坽坾坿垀"], +["8880","垁垇垈垉垊垍",4,"垔",6,"垜垝垞垟垥垨垪垬垯垰垱垳垵垶垷垹",8,"埄",6,"埌埍埐埑埓埖埗埛埜埞埡埢埣埥",7,"埮埰埱埲埳埵埶執埻埼埾埿堁堃堄堅堈堉堊堌堎堏堐堒堓堔堖堗堘堚堛堜堝堟堢堣堥",4,"堫",4,"報堲堳場堶",7], +["8940","堾",5,"塅",6,"塎塏塐塒塓塕塖塗塙",4,"塟",5,"塦",4,"塭",16,"塿墂墄墆墇墈墊墋墌"], +["8980","墍",4,"墔",4,"墛墜墝墠",7,"墪",17,"墽墾墿壀壂壃壄壆",10,"壒壓壔壖",13,"壥",5,"壭壯壱売壴壵壷壸壺",7,"夃夅夆夈",4,"夎夐夑夒夓夗夘夛夝夞夠夡夢夣夦夨夬夰夲夳夵夶夻"], +["8a40","夽夾夿奀奃奅奆奊奌奍奐奒奓奙奛",4,"奡奣奤奦",12,"奵奷奺奻奼奾奿妀妅妉妋妌妎妏妐妑妔妕妘妚妛妜妝妟妠妡妢妦"], +["8a80","妧妬妭妰妱妳",5,"妺妼妽妿",6,"姇姈姉姌姍姎姏姕姖姙姛姞",4,"姤姦姧姩姪姫姭",11,"姺姼姽姾娀娂娊娋娍娎娏娐娒娔娕娖娗娙娚娛娝娞娡娢娤娦娧娨娪",6,"娳娵娷",4,"娽娾娿婁",4,"婇婈婋",9,"婖婗婘婙婛",5], +["8b40","婡婣婤婥婦婨婩婫",8,"婸婹婻婼婽婾媀",17,"媓",6,"媜",13,"媫媬"], +["8b80","媭",4,"媴媶媷媹",4,"媿嫀嫃",5,"嫊嫋嫍",4,"嫓嫕嫗嫙嫚嫛嫝嫞嫟嫢嫤嫥嫧嫨嫪嫬",4,"嫲",22,"嬊",11,"嬘",25,"嬳嬵嬶嬸",7,"孁",6], +["8c40","孈",7,"孒孖孞孠孡孧孨孫孭孮孯孲孴孶孷學孹孻孼孾孿宂宆宊宍宎宐宑宒宔宖実宧宨宩宬宭宮宯宱宲宷宺宻宼寀寁寃寈寉寊寋寍寎寏"], +["8c80","寑寔",8,"寠寢寣實寧審",4,"寯寱",6,"寽対尀専尃尅將專尋尌對導尐尒尓尗尙尛尞尟尠尡尣尦尨尩尪尫尭尮尯尰尲尳尵尶尷屃屄屆屇屌屍屒屓屔屖屗屘屚屛屜屝屟屢層屧",6,"屰屲",6,"屻屼屽屾岀岃",4,"岉岊岋岎岏岒岓岕岝",4,"岤",4], +["8d40","岪岮岯岰岲岴岶岹岺岻岼岾峀峂峃峅",5,"峌",5,"峓",5,"峚",6,"峢峣峧峩峫峬峮峯峱",9,"峼",4], +["8d80","崁崄崅崈",5,"崏",4,"崕崗崘崙崚崜崝崟",4,"崥崨崪崫崬崯",4,"崵",7,"崿",7,"嵈嵉嵍",10,"嵙嵚嵜嵞",10,"嵪嵭嵮嵰嵱嵲嵳嵵",12,"嶃",21,"嶚嶛嶜嶞嶟嶠"], +["8e40","嶡",21,"嶸",12,"巆",6,"巎",12,"巜巟巠巣巤巪巬巭"], +["8e80","巰巵巶巸",4,"巿帀帄帇帉帊帋帍帎帒帓帗帞",7,"帨",4,"帯帰帲",4,"帹帺帾帿幀幁幃幆",5,"幍",6,"幖",4,"幜幝幟幠幣",14,"幵幷幹幾庁庂広庅庈庉庌庍庎庒庘庛庝庡庢庣庤庨",4,"庮",4,"庴庺庻庼庽庿",6], +["8f40","廆廇廈廋",5,"廔廕廗廘廙廚廜",11,"廩廫",8,"廵廸廹廻廼廽弅弆弇弉弌弍弎弐弒弔弖弙弚弜弝弞弡弢弣弤"], +["8f80","弨弫弬弮弰弲",6,"弻弽弾弿彁",14,"彑彔彙彚彛彜彞彟彠彣彥彧彨彫彮彯彲彴彵彶彸彺彽彾彿徃徆徍徎徏徑従徔徖徚徛徝從徟徠徢",5,"復徫徬徯",5,"徶徸徹徺徻徾",4,"忇忈忊忋忎忓忔忕忚忛応忞忟忢忣忥忦忨忩忬忯忰忲忳忴忶忷忹忺忼怇"], +["9040","怈怉怋怌怐怑怓怗怘怚怞怟怢怣怤怬怭怮怰",4,"怶",4,"怽怾恀恄",6,"恌恎恏恑恓恔恖恗恘恛恜恞恟恠恡恥恦恮恱恲恴恵恷恾悀"], +["9080","悁悂悅悆悇悈悊悋悎悏悐悑悓悕悗悘悙悜悞悡悢悤悥悧悩悪悮悰悳悵悶悷悹悺悽",7,"惇惈惉惌",4,"惒惓惔惖惗惙惛惞惡",4,"惪惱惲惵惷惸惻",4,"愂愃愄愅愇愊愋愌愐",4,"愖愗愘愙愛愜愝愞愡愢愥愨愩愪愬",18,"慀",6], +["9140","慇慉態慍慏慐慒慓慔慖",6,"慞慟慠慡慣慤慥慦慩",6,"慱慲慳慴慶慸",18,"憌憍憏",4,"憕"], +["9180","憖",6,"憞",8,"憪憫憭",9,"憸",5,"憿懀懁懃",4,"應懌",4,"懓懕",16,"懧",13,"懶",8,"戀",5,"戇戉戓戔戙戜戝戞戠戣戦戧戨戩戫戭戯戰戱戲戵戶戸",4,"扂扄扅扆扊"], +["9240","扏扐払扖扗扙扚扜",6,"扤扥扨扱扲扴扵扷扸扺扻扽抁抂抃抅抆抇抈抋",5,"抔抙抜抝択抣抦抧抩抪抭抮抯抰抲抳抴抶抷抸抺抾拀拁"], +["9280","拃拋拏拑拕拝拞拠拡拤拪拫拰拲拵拸拹拺拻挀挃挄挅挆挊挋挌挍挏挐挒挓挔挕挗挘挙挜挦挧挩挬挭挮挰挱挳",5,"挻挼挾挿捀捁捄捇捈捊捑捒捓捔捖",7,"捠捤捥捦捨捪捫捬捯捰捲捳捴捵捸捹捼捽捾捿掁掃掄掅掆掋掍掑掓掔掕掗掙",6,"採掤掦掫掯掱掲掵掶掹掻掽掿揀"], +["9340","揁揂揃揅揇揈揊揋揌揑揓揔揕揗",6,"揟揢揤",4,"揫揬揮揯揰揱揳揵揷揹揺揻揼揾搃搄搆",4,"損搎搑搒搕",5,"搝搟搢搣搤"], +["9380","搥搧搨搩搫搮",5,"搵",4,"搻搼搾摀摂摃摉摋",6,"摓摕摖摗摙",4,"摟",7,"摨摪摫摬摮",9,"摻",6,"撃撆撈",8,"撓撔撗撘撚撛撜撝撟",4,"撥撦撧撨撪撫撯撱撲撳撴撶撹撻撽撾撿擁擃擄擆",6,"擏擑擓擔擕擖擙據"], +["9440","擛擜擝擟擠擡擣擥擧",24,"攁",7,"攊",7,"攓",4,"攙",8], +["9480","攢攣攤攦",4,"攬攭攰攱攲攳攷攺攼攽敀",4,"敆敇敊敋敍敎敐敒敓敔敗敘敚敜敟敠敡敤敥敧敨敩敪敭敮敯敱敳敵敶數",14,"斈斉斊斍斎斏斒斔斕斖斘斚斝斞斠斢斣斦斨斪斬斮斱",7,"斺斻斾斿旀旂旇旈旉旊旍旐旑旓旔旕旘",7,"旡旣旤旪旫"], +["9540","旲旳旴旵旸旹旻",4,"昁昄昅昇昈昉昋昍昐昑昒昖昗昘昚昛昜昞昡昢昣昤昦昩昪昫昬昮昰昲昳昷",4,"昽昿晀時晄",6,"晍晎晐晑晘"], +["9580","晙晛晜晝晞晠晢晣晥晧晩",4,"晱晲晳晵晸晹晻晼晽晿暀暁暃暅暆暈暉暊暋暍暎暏暐暒暓暔暕暘",4,"暞",8,"暩",4,"暯",4,"暵暶暷暸暺暻暼暽暿",25,"曚曞",7,"曧曨曪",5,"曱曵曶書曺曻曽朁朂會"], +["9640","朄朅朆朇朌朎朏朑朒朓朖朘朙朚朜朞朠",5,"朧朩朮朰朲朳朶朷朸朹朻朼朾朿杁杄杅杇杊杋杍杒杔杕杗",4,"杝杢杣杤杦杧杫杬杮東杴杶"], +["9680","杸杹杺杻杽枀枂枃枅枆枈枊枌枍枎枏枑枒枓枔枖枙枛枟枠枡枤枦枩枬枮枱枲枴枹",7,"柂柅",9,"柕柖柗柛柟柡柣柤柦柧柨柪柫柭柮柲柵",7,"柾栁栂栃栄栆栍栐栒栔栕栘",4,"栞栟栠栢",6,"栫",6,"栴栵栶栺栻栿桇桋桍桏桒桖",5], +["9740","桜桝桞桟桪桬",7,"桵桸",8,"梂梄梇",7,"梐梑梒梔梕梖梘",9,"梣梤梥梩梪梫梬梮梱梲梴梶梷梸"], +["9780","梹",6,"棁棃",5,"棊棌棎棏棐棑棓棔棖棗棙棛",4,"棡棢棤",9,"棯棲棳棴棶棷棸棻棽棾棿椀椂椃椄椆",4,"椌椏椑椓",11,"椡椢椣椥",7,"椮椯椱椲椳椵椶椷椸椺椻椼椾楀楁楃",16,"楕楖楘楙楛楜楟"], +["9840","楡楢楤楥楧楨楩楪楬業楯楰楲",4,"楺楻楽楾楿榁榃榅榊榋榌榎",5,"榖榗榙榚榝",9,"榩榪榬榮榯榰榲榳榵榶榸榹榺榼榽"], +["9880","榾榿槀槂",7,"構槍槏槑槒槓槕",5,"槜槝槞槡",11,"槮槯槰槱槳",9,"槾樀",9,"樋",11,"標",5,"樠樢",5,"権樫樬樭樮樰樲樳樴樶",6,"樿",4,"橅橆橈",7,"橑",6,"橚"], +["9940","橜",4,"橢橣橤橦",10,"橲",6,"橺橻橽橾橿檁檂檃檅",8,"檏檒",4,"檘",7,"檡",5], +["9980","檧檨檪檭",114,"欥欦欨",6], +["9a40","欯欰欱欳欴欵欶欸欻欼欽欿歀歁歂歄歅歈歊歋歍",11,"歚",7,"歨歩歫",13,"歺歽歾歿殀殅殈"], +["9a80","殌殎殏殐殑殔殕殗殘殙殜",4,"殢",7,"殫",7,"殶殸",6,"毀毃毄毆",4,"毌毎毐毑毘毚毜",4,"毢",7,"毬毭毮毰毱毲毴毶毷毸毺毻毼毾",6,"氈",4,"氎氒気氜氝氞氠氣氥氫氬氭氱氳氶氷氹氺氻氼氾氿汃汄汅汈汋",4,"汑汒汓汖汘"], +["9b40","汙汚汢汣汥汦汧汫",4,"汱汳汵汷汸決汻汼汿沀沄沇沊沋沍沎沑沒沕沖沗沘沚沜沝沞沠沢沨沬沯沰沴沵沶沷沺泀況泂泃泆泇泈泋泍泎泏泑泒泘"], +["9b80","泙泚泜泝泟泤泦泧泩泬泭泲泴泹泿洀洂洃洅洆洈洉洊洍洏洐洑洓洔洕洖洘洜洝洟",5,"洦洨洩洬洭洯洰洴洶洷洸洺洿浀浂浄浉浌浐浕浖浗浘浛浝浟浡浢浤浥浧浨浫浬浭浰浱浲浳浵浶浹浺浻浽",4,"涃涄涆涇涊涋涍涏涐涒涖",4,"涜涢涥涬涭涰涱涳涴涶涷涹",5,"淁淂淃淈淉淊"], +["9c40","淍淎淏淐淒淓淔淕淗淚淛淜淟淢淣淥淧淨淩淪淭淯淰淲淴淵淶淸淺淽",7,"渆渇済渉渋渏渒渓渕渘渙減渜渞渟渢渦渧渨渪測渮渰渱渳渵"], +["9c80","渶渷渹渻",7,"湅",7,"湏湐湑湒湕湗湙湚湜湝湞湠",10,"湬湭湯",14,"満溁溂溄溇溈溊",4,"溑",6,"溙溚溛溝溞溠溡溣溤溦溨溩溫溬溭溮溰溳溵溸溹溼溾溿滀滃滄滅滆滈滉滊滌滍滎滐滒滖滘滙滛滜滝滣滧滪",5], +["9d40","滰滱滲滳滵滶滷滸滺",7,"漃漄漅漇漈漊",4,"漐漑漒漖",9,"漡漢漣漥漦漧漨漬漮漰漲漴漵漷",6,"漿潀潁潂"], +["9d80","潃潄潅潈潉潊潌潎",9,"潙潚潛潝潟潠潡潣潤潥潧",5,"潯潰潱潳潵潶潷潹潻潽",6,"澅澆澇澊澋澏",12,"澝澞澟澠澢",4,"澨",10,"澴澵澷澸澺",5,"濁濃",5,"濊",6,"濓",10,"濟濢濣濤濥"], +["9e40","濦",7,"濰",32,"瀒",7,"瀜",6,"瀤",6], +["9e80","瀫",9,"瀶瀷瀸瀺",17,"灍灎灐",13,"灟",11,"灮灱灲灳灴灷灹灺灻災炁炂炃炄炆炇炈炋炌炍炏炐炑炓炗炘炚炛炞",12,"炰炲炴炵炶為炾炿烄烅烆烇烉烋",12,"烚"], +["9f40","烜烝烞烠烡烢烣烥烪烮烰",6,"烸烺烻烼烾",10,"焋",4,"焑焒焔焗焛",10,"焧",7,"焲焳焴"], +["9f80","焵焷",13,"煆煇煈煉煋煍煏",12,"煝煟",4,"煥煩",4,"煯煰煱煴煵煶煷煹煻煼煾",5,"熅",4,"熋熌熍熎熐熑熒熓熕熖熗熚",4,"熡",6,"熩熪熫熭",5,"熴熶熷熸熺",8,"燄",9,"燏",4], +["a040","燖",9,"燡燢燣燤燦燨",5,"燯",9,"燺",11,"爇",19], +["a080","爛爜爞",9,"爩爫爭爮爯爲爳爴爺爼爾牀",6,"牉牊牋牎牏牐牑牓牔牕牗牘牚牜牞牠牣牤牥牨牪牫牬牭牰牱牳牴牶牷牸牻牼牽犂犃犅",4,"犌犎犐犑犓",11,"犠",11,"犮犱犲犳犵犺",6,"狅狆狇狉狊狋狌狏狑狓狔狕狖狘狚狛"], +["a1a1"," 、。·ˉˇ¨〃々—~‖…‘’“”〔〕〈",7,"〖〗【】±×÷∶∧∨∑∏∪∩∈∷√⊥∥∠⌒⊙∫∮≡≌≈∽∝≠≮≯≤≥∞∵∴♂♀°′″℃$¤¢£‰§№☆★○●◎◇◆□■△▲※→←↑↓〓"], +["a2a1","ⅰ",9], +["a2b1","⒈",19,"⑴",19,"①",9], +["a2e5","㈠",9], +["a2f1","Ⅰ",11], +["a3a1","!"#¥%",88," ̄"], +["a4a1","ぁ",82], +["a5a1","ァ",85], +["a6a1","Α",16,"Σ",6], +["a6c1","α",16,"σ",6], +["a6e0","︵︶︹︺︿﹀︽︾﹁﹂﹃﹄"], +["a6ee","︻︼︷︸︱"], +["a6f4","︳︴"], +["a7a1","А",5,"ЁЖ",25], +["a7d1","а",5,"ёж",25], +["a840","ˊˋ˙–―‥‵℅℉↖↗↘↙∕∟∣≒≦≧⊿═",35,"▁",6], +["a880","█",7,"▓▔▕▼▽◢◣◤◥☉⊕〒〝〞"], +["a8a1","āáǎàēéěèīíǐìōóǒòūúǔùǖǘǚǜüêɑ"], +["a8bd","ńň"], +["a8c0","ɡ"], +["a8c5","ㄅ",36], +["a940","〡",8,"㊣㎎㎏㎜㎝㎞㎡㏄㏎㏑㏒㏕︰¬¦"], +["a959","℡㈱"], +["a95c","‐"], +["a960","ー゛゜ヽヾ〆ゝゞ﹉",9,"﹔﹕﹖﹗﹙",8], +["a980","﹢",4,"﹨﹩﹪﹫"], +["a996","〇"], +["a9a4","─",75], +["aa40","狜狝狟狢",5,"狪狫狵狶狹狽狾狿猀猂猄",5,"猋猌猍猏猐猑猒猔猘猙猚猟猠猣猤猦猧猨猭猯猰猲猳猵猶猺猻猼猽獀",8], +["aa80","獉獊獋獌獎獏獑獓獔獕獖獘",7,"獡",10,"獮獰獱"], +["ab40","獲",11,"獿",4,"玅玆玈玊玌玍玏玐玒玓玔玕玗玘玙玚玜玝玞玠玡玣",5,"玪玬玭玱玴玵玶玸玹玼玽玾玿珁珃",4], +["ab80","珋珌珎珒",6,"珚珛珜珝珟珡珢珣珤珦珨珪珫珬珮珯珰珱珳",4], +["ac40","珸",10,"琄琇琈琋琌琍琎琑",8,"琜",5,"琣琤琧琩琫琭琯琱琲琷",4,"琽琾琿瑀瑂",11], +["ac80","瑎",6,"瑖瑘瑝瑠",12,"瑮瑯瑱",4,"瑸瑹瑺"], +["ad40","瑻瑼瑽瑿璂璄璅璆璈璉璊璌璍璏璑",10,"璝璟",7,"璪",15,"璻",12], +["ad80","瓈",9,"瓓",8,"瓝瓟瓡瓥瓧",6,"瓰瓱瓲"], +["ae40","瓳瓵瓸",6,"甀甁甂甃甅",7,"甎甐甒甔甕甖甗甛甝甞甠",4,"甦甧甪甮甴甶甹甼甽甿畁畂畃畄畆畇畉畊畍畐畑畒畓畕畖畗畘"], +["ae80","畝",7,"畧畨畩畫",6,"畳畵當畷畺",4,"疀疁疂疄疅疇"], +["af40","疈疉疊疌疍疎疐疓疕疘疛疜疞疢疦",4,"疭疶疷疺疻疿痀痁痆痋痌痎痏痐痑痓痗痙痚痜痝痟痠痡痥痩痬痭痮痯痲痳痵痶痷痸痺痻痽痾瘂瘄瘆瘇"], +["af80","瘈瘉瘋瘍瘎瘏瘑瘒瘓瘔瘖瘚瘜瘝瘞瘡瘣瘧瘨瘬瘮瘯瘱瘲瘶瘷瘹瘺瘻瘽癁療癄"], +["b040","癅",6,"癎",5,"癕癗",4,"癝癟癠癡癢癤",6,"癬癭癮癰",7,"癹発發癿皀皁皃皅皉皊皌皍皏皐皒皔皕皗皘皚皛"], +["b080","皜",7,"皥",8,"皯皰皳皵",9,"盀盁盃啊阿埃挨哎唉哀皑癌蔼矮艾碍爱隘鞍氨安俺按暗岸胺案肮昂盎凹敖熬翱袄傲奥懊澳芭捌扒叭吧笆八疤巴拔跋靶把耙坝霸罢爸白柏百摆佰败拜稗斑班搬扳般颁板版扮拌伴瓣半办绊邦帮梆榜膀绑棒磅蚌镑傍谤苞胞包褒剥"], +["b140","盄盇盉盋盌盓盕盙盚盜盝盞盠",4,"盦",7,"盰盳盵盶盷盺盻盽盿眀眂眃眅眆眊県眎",10,"眛眜眝眞眡眣眤眥眧眪眫"], +["b180","眬眮眰",4,"眹眻眽眾眿睂睄睅睆睈",7,"睒",7,"睜薄雹保堡饱宝抱报暴豹鲍爆杯碑悲卑北辈背贝钡倍狈备惫焙被奔苯本笨崩绷甭泵蹦迸逼鼻比鄙笔彼碧蓖蔽毕毙毖币庇痹闭敝弊必辟壁臂避陛鞭边编贬扁便变卞辨辩辫遍标彪膘表鳖憋别瘪彬斌濒滨宾摈兵冰柄丙秉饼炳"], +["b240","睝睞睟睠睤睧睩睪睭",11,"睺睻睼瞁瞂瞃瞆",5,"瞏瞐瞓",11,"瞡瞣瞤瞦瞨瞫瞭瞮瞯瞱瞲瞴瞶",4], +["b280","瞼瞾矀",12,"矎",8,"矘矙矚矝",4,"矤病并玻菠播拨钵波博勃搏铂箔伯帛舶脖膊渤泊驳捕卜哺补埠不布步簿部怖擦猜裁材才财睬踩采彩菜蔡餐参蚕残惭惨灿苍舱仓沧藏操糙槽曹草厕策侧册测层蹭插叉茬茶查碴搽察岔差诧拆柴豺搀掺蝉馋谗缠铲产阐颤昌猖"], +["b340","矦矨矪矯矰矱矲矴矵矷矹矺矻矼砃",5,"砊砋砎砏砐砓砕砙砛砞砠砡砢砤砨砪砫砮砯砱砲砳砵砶砽砿硁硂硃硄硆硈硉硊硋硍硏硑硓硔硘硙硚"], +["b380","硛硜硞",11,"硯",7,"硸硹硺硻硽",6,"场尝常长偿肠厂敞畅唱倡超抄钞朝嘲潮巢吵炒车扯撤掣彻澈郴臣辰尘晨忱沉陈趁衬撑称城橙成呈乘程惩澄诚承逞骋秤吃痴持匙池迟弛驰耻齿侈尺赤翅斥炽充冲虫崇宠抽酬畴踌稠愁筹仇绸瞅丑臭初出橱厨躇锄雏滁除楚"], +["b440","碄碅碆碈碊碋碏碐碒碔碕碖碙碝碞碠碢碤碦碨",7,"碵碶碷碸確碻碼碽碿磀磂磃磄磆磇磈磌磍磎磏磑磒磓磖磗磘磚",9], +["b480","磤磥磦磧磩磪磫磭",4,"磳磵磶磸磹磻",5,"礂礃礄礆",6,"础储矗搐触处揣川穿椽传船喘串疮窗幢床闯创吹炊捶锤垂春椿醇唇淳纯蠢戳绰疵茨磁雌辞慈瓷词此刺赐次聪葱囱匆从丛凑粗醋簇促蹿篡窜摧崔催脆瘁粹淬翠村存寸磋撮搓措挫错搭达答瘩打大呆歹傣戴带殆代贷袋待逮"], +["b540","礍",5,"礔",9,"礟",4,"礥",14,"礵",4,"礽礿祂祃祄祅祇祊",8,"祔祕祘祙祡祣"], +["b580","祤祦祩祪祫祬祮祰",6,"祹祻",4,"禂禃禆禇禈禉禋禌禍禎禐禑禒怠耽担丹单郸掸胆旦氮但惮淡诞弹蛋当挡党荡档刀捣蹈倒岛祷导到稻悼道盗德得的蹬灯登等瞪凳邓堤低滴迪敌笛狄涤翟嫡抵底地蒂第帝弟递缔颠掂滇碘点典靛垫电佃甸店惦奠淀殿碉叼雕凋刁掉吊钓调跌爹碟蝶迭谍叠"], +["b640","禓",6,"禛",11,"禨",10,"禴",4,"禼禿秂秄秅秇秈秊秌秎秏秐秓秔秖秗秙",5,"秠秡秢秥秨秪"], +["b680","秬秮秱",6,"秹秺秼秾秿稁稄稅稇稈稉稊稌稏",4,"稕稖稘稙稛稜丁盯叮钉顶鼎锭定订丢东冬董懂动栋侗恫冻洞兜抖斗陡豆逗痘都督毒犊独读堵睹赌杜镀肚度渡妒端短锻段断缎堆兑队对墩吨蹲敦顿囤钝盾遁掇哆多夺垛躲朵跺舵剁惰堕蛾峨鹅俄额讹娥恶厄扼遏鄂饿恩而儿耳尔饵洱二"], +["b740","稝稟稡稢稤",14,"稴稵稶稸稺稾穀",5,"穇",9,"穒",4,"穘",16], +["b780","穩",6,"穱穲穳穵穻穼穽穾窂窅窇窉窊窋窌窎窏窐窓窔窙窚窛窞窡窢贰发罚筏伐乏阀法珐藩帆番翻樊矾钒繁凡烦反返范贩犯饭泛坊芳方肪房防妨仿访纺放菲非啡飞肥匪诽吠肺废沸费芬酚吩氛分纷坟焚汾粉奋份忿愤粪丰封枫蜂峰锋风疯烽逢冯缝讽奉凤佛否夫敷肤孵扶拂辐幅氟符伏俘服"], +["b840","窣窤窧窩窪窫窮",4,"窴",10,"竀",10,"竌",9,"竗竘竚竛竜竝竡竢竤竧",5,"竮竰竱竲竳"], +["b880","竴",4,"竻竼竾笀笁笂笅笇笉笌笍笎笐笒笓笖笗笘笚笜笝笟笡笢笣笧笩笭浮涪福袱弗甫抚辅俯釜斧脯腑府腐赴副覆赋复傅付阜父腹负富讣附妇缚咐噶嘎该改概钙盖溉干甘杆柑竿肝赶感秆敢赣冈刚钢缸肛纲岗港杠篙皋高膏羔糕搞镐稿告哥歌搁戈鸽胳疙割革葛格蛤阁隔铬个各给根跟耕更庚羹"], +["b940","笯笰笲笴笵笶笷笹笻笽笿",5,"筆筈筊筍筎筓筕筗筙筜筞筟筡筣",10,"筯筰筳筴筶筸筺筼筽筿箁箂箃箄箆",6,"箎箏"], +["b980","箑箒箓箖箘箙箚箛箞箟箠箣箤箥箮箯箰箲箳箵箶箷箹",7,"篂篃範埂耿梗工攻功恭龚供躬公宫弓巩汞拱贡共钩勾沟苟狗垢构购够辜菇咕箍估沽孤姑鼓古蛊骨谷股故顾固雇刮瓜剐寡挂褂乖拐怪棺关官冠观管馆罐惯灌贯光广逛瑰规圭硅归龟闺轨鬼诡癸桂柜跪贵刽辊滚棍锅郭国果裹过哈"], +["ba40","篅篈築篊篋篍篎篏篐篒篔",4,"篛篜篞篟篠篢篣篤篧篨篩篫篬篭篯篰篲",4,"篸篹篺篻篽篿",7,"簈簉簊簍簎簐",5,"簗簘簙"], +["ba80","簚",4,"簠",5,"簨簩簫",12,"簹",5,"籂骸孩海氦亥害骇酣憨邯韩含涵寒函喊罕翰撼捍旱憾悍焊汗汉夯杭航壕嚎豪毫郝好耗号浩呵喝荷菏核禾和何合盒貉阂河涸赫褐鹤贺嘿黑痕很狠恨哼亨横衡恒轰哄烘虹鸿洪宏弘红喉侯猴吼厚候后呼乎忽瑚壶葫胡蝴狐糊湖"], +["bb40","籃",9,"籎",36,"籵",5,"籾",9], +["bb80","粈粊",6,"粓粔粖粙粚粛粠粡粣粦粧粨粩粫粬粭粯粰粴",4,"粺粻弧虎唬护互沪户花哗华猾滑画划化话槐徊怀淮坏欢环桓还缓换患唤痪豢焕涣宦幻荒慌黄磺蝗簧皇凰惶煌晃幌恍谎灰挥辉徽恢蛔回毁悔慧卉惠晦贿秽会烩汇讳诲绘荤昏婚魂浑混豁活伙火获或惑霍货祸击圾基机畸稽积箕"], +["bc40","粿糀糂糃糄糆糉糋糎",6,"糘糚糛糝糞糡",6,"糩",5,"糰",7,"糹糺糼",13,"紋",5], +["bc80","紑",14,"紡紣紤紥紦紨紩紪紬紭紮細",6,"肌饥迹激讥鸡姬绩缉吉极棘辑籍集及急疾汲即嫉级挤几脊己蓟技冀季伎祭剂悸济寄寂计记既忌际妓继纪嘉枷夹佳家加荚颊贾甲钾假稼价架驾嫁歼监坚尖笺间煎兼肩艰奸缄茧检柬碱硷拣捡简俭剪减荐槛鉴践贱见键箭件"], +["bd40","紷",54,"絯",7], +["bd80","絸",32,"健舰剑饯渐溅涧建僵姜将浆江疆蒋桨奖讲匠酱降蕉椒礁焦胶交郊浇骄娇嚼搅铰矫侥脚狡角饺缴绞剿教酵轿较叫窖揭接皆秸街阶截劫节桔杰捷睫竭洁结解姐戒藉芥界借介疥诫届巾筋斤金今津襟紧锦仅谨进靳晋禁近烬浸"], +["be40","継",12,"綧",6,"綯",42], +["be80","線",32,"尽劲荆兢茎睛晶鲸京惊精粳经井警景颈静境敬镜径痉靖竟竞净炯窘揪究纠玖韭久灸九酒厩救旧臼舅咎就疚鞠拘狙疽居驹菊局咀矩举沮聚拒据巨具距踞锯俱句惧炬剧捐鹃娟倦眷卷绢撅攫抉掘倔爵觉决诀绝均菌钧军君峻"], +["bf40","緻",62], +["bf80","縺縼",4,"繂",4,"繈",21,"俊竣浚郡骏喀咖卡咯开揩楷凯慨刊堪勘坎砍看康慷糠扛抗亢炕考拷烤靠坷苛柯棵磕颗科壳咳可渴克刻客课肯啃垦恳坑吭空恐孔控抠口扣寇枯哭窟苦酷库裤夸垮挎跨胯块筷侩快宽款匡筐狂框矿眶旷况亏盔岿窥葵奎魁傀"], +["c040","繞",35,"纃",23,"纜纝纞"], +["c080","纮纴纻纼绖绤绬绹缊缐缞缷缹缻",6,"罃罆",9,"罒罓馈愧溃坤昆捆困括扩廓阔垃拉喇蜡腊辣啦莱来赖蓝婪栏拦篮阑兰澜谰揽览懒缆烂滥琅榔狼廊郎朗浪捞劳牢老佬姥酪烙涝勒乐雷镭蕾磊累儡垒擂肋类泪棱楞冷厘梨犁黎篱狸离漓理李里鲤礼莉荔吏栗丽厉励砾历利傈例俐"], +["c140","罖罙罛罜罝罞罠罣",4,"罫罬罭罯罰罳罵罶罷罸罺罻罼罽罿羀羂",7,"羋羍羏",4,"羕",4,"羛羜羠羢羣羥羦羨",6,"羱"], +["c180","羳",4,"羺羻羾翀翂翃翄翆翇翈翉翋翍翏",4,"翖翗翙",5,"翢翣痢立粒沥隶力璃哩俩联莲连镰廉怜涟帘敛脸链恋炼练粮凉梁粱良两辆量晾亮谅撩聊僚疗燎寥辽潦了撂镣廖料列裂烈劣猎琳林磷霖临邻鳞淋凛赁吝拎玲菱零龄铃伶羚凌灵陵岭领另令溜琉榴硫馏留刘瘤流柳六龙聋咙笼窿"], +["c240","翤翧翨翪翫翬翭翯翲翴",6,"翽翾翿耂耇耈耉耊耎耏耑耓耚耛耝耞耟耡耣耤耫",5,"耲耴耹耺耼耾聀聁聄聅聇聈聉聎聏聐聑聓聕聖聗"], +["c280","聙聛",13,"聫",5,"聲",11,"隆垄拢陇楼娄搂篓漏陋芦卢颅庐炉掳卤虏鲁麓碌露路赂鹿潞禄录陆戮驴吕铝侣旅履屡缕虑氯律率滤绿峦挛孪滦卵乱掠略抡轮伦仑沦纶论萝螺罗逻锣箩骡裸落洛骆络妈麻玛码蚂马骂嘛吗埋买麦卖迈脉瞒馒蛮满蔓曼慢漫"], +["c340","聾肁肂肅肈肊肍",5,"肔肕肗肙肞肣肦肧肨肬肰肳肵肶肸肹肻胅胇",4,"胏",6,"胘胟胠胢胣胦胮胵胷胹胻胾胿脀脁脃脄脅脇脈脋"], +["c380","脌脕脗脙脛脜脝脟",12,"脭脮脰脳脴脵脷脹",4,"脿谩芒茫盲氓忙莽猫茅锚毛矛铆卯茂冒帽貌贸么玫枚梅酶霉煤没眉媒镁每美昧寐妹媚门闷们萌蒙檬盟锰猛梦孟眯醚靡糜迷谜弥米秘觅泌蜜密幂棉眠绵冕免勉娩缅面苗描瞄藐秒渺庙妙蔑灭民抿皿敏悯闽明螟鸣铭名命谬摸"], +["c440","腀",5,"腇腉腍腎腏腒腖腗腘腛",4,"腡腢腣腤腦腨腪腫腬腯腲腳腵腶腷腸膁膃",4,"膉膋膌膍膎膐膒",5,"膙膚膞",4,"膤膥"], +["c480","膧膩膫",7,"膴",5,"膼膽膾膿臄臅臇臈臉臋臍",6,"摹蘑模膜磨摩魔抹末莫墨默沫漠寞陌谋牟某拇牡亩姆母墓暮幕募慕木目睦牧穆拿哪呐钠那娜纳氖乃奶耐奈南男难囊挠脑恼闹淖呢馁内嫩能妮霓倪泥尼拟你匿腻逆溺蔫拈年碾撵捻念娘酿鸟尿捏聂孽啮镊镍涅您柠狞凝宁"], +["c540","臔",14,"臤臥臦臨臩臫臮",4,"臵",5,"臽臿舃與",4,"舎舏舑舓舕",5,"舝舠舤舥舦舧舩舮舲舺舼舽舿"], +["c580","艀艁艂艃艅艆艈艊艌艍艎艐",7,"艙艛艜艝艞艠",7,"艩拧泞牛扭钮纽脓浓农弄奴努怒女暖虐疟挪懦糯诺哦欧鸥殴藕呕偶沤啪趴爬帕怕琶拍排牌徘湃派攀潘盘磐盼畔判叛乓庞旁耪胖抛咆刨炮袍跑泡呸胚培裴赔陪配佩沛喷盆砰抨烹澎彭蓬棚硼篷膨朋鹏捧碰坯砒霹批披劈琵毗"], +["c640","艪艫艬艭艱艵艶艷艸艻艼芀芁芃芅芆芇芉芌芐芓芔芕芖芚芛芞芠芢芣芧芲芵芶芺芻芼芿苀苂苃苅苆苉苐苖苙苚苝苢苧苨苩苪苬苭苮苰苲苳苵苶苸"], +["c680","苺苼",4,"茊茋茍茐茒茓茖茘茙茝",9,"茩茪茮茰茲茷茻茽啤脾疲皮匹痞僻屁譬篇偏片骗飘漂瓢票撇瞥拼频贫品聘乒坪苹萍平凭瓶评屏坡泼颇婆破魄迫粕剖扑铺仆莆葡菩蒲埔朴圃普浦谱曝瀑期欺栖戚妻七凄漆柒沏其棋奇歧畦崎脐齐旗祈祁骑起岂乞企启契砌器气迄弃汽泣讫掐"], +["c740","茾茿荁荂荄荅荈荊",4,"荓荕",4,"荝荢荰",6,"荹荺荾",6,"莇莈莊莋莌莍莏莐莑莔莕莖莗莙莚莝莟莡",6,"莬莭莮"], +["c780","莯莵莻莾莿菂菃菄菆菈菉菋菍菎菐菑菒菓菕菗菙菚菛菞菢菣菤菦菧菨菫菬菭恰洽牵扦钎铅千迁签仟谦乾黔钱钳前潜遣浅谴堑嵌欠歉枪呛腔羌墙蔷强抢橇锹敲悄桥瞧乔侨巧鞘撬翘峭俏窍切茄且怯窃钦侵亲秦琴勤芹擒禽寝沁青轻氢倾卿清擎晴氰情顷请庆琼穷秋丘邱球求囚酋泅趋区蛆曲躯屈驱渠"], +["c840","菮華菳",4,"菺菻菼菾菿萀萂萅萇萈萉萊萐萒",5,"萙萚萛萞",5,"萩",7,"萲",5,"萹萺萻萾",7,"葇葈葉"], +["c880","葊",6,"葒",4,"葘葝葞葟葠葢葤",4,"葪葮葯葰葲葴葷葹葻葼取娶龋趣去圈颧权醛泉全痊拳犬券劝缺炔瘸却鹊榷确雀裙群然燃冉染瓤壤攘嚷让饶扰绕惹热壬仁人忍韧任认刃妊纫扔仍日戎茸蓉荣融熔溶容绒冗揉柔肉茹蠕儒孺如辱乳汝入褥软阮蕊瑞锐闰润若弱撒洒萨腮鳃塞赛三叁"], +["c940","葽",4,"蒃蒄蒅蒆蒊蒍蒏",7,"蒘蒚蒛蒝蒞蒟蒠蒢",12,"蒰蒱蒳蒵蒶蒷蒻蒼蒾蓀蓂蓃蓅蓆蓇蓈蓋蓌蓎蓏蓒蓔蓕蓗"], +["c980","蓘",4,"蓞蓡蓢蓤蓧",4,"蓭蓮蓯蓱",10,"蓽蓾蔀蔁蔂伞散桑嗓丧搔骚扫嫂瑟色涩森僧莎砂杀刹沙纱傻啥煞筛晒珊苫杉山删煽衫闪陕擅赡膳善汕扇缮墒伤商赏晌上尚裳梢捎稍烧芍勺韶少哨邵绍奢赊蛇舌舍赦摄射慑涉社设砷申呻伸身深娠绅神沈审婶甚肾慎渗声生甥牲升绳"], +["ca40","蔃",8,"蔍蔎蔏蔐蔒蔔蔕蔖蔘蔙蔛蔜蔝蔞蔠蔢",8,"蔭",9,"蔾",4,"蕄蕅蕆蕇蕋",10], +["ca80","蕗蕘蕚蕛蕜蕝蕟",4,"蕥蕦蕧蕩",8,"蕳蕵蕶蕷蕸蕼蕽蕿薀薁省盛剩胜圣师失狮施湿诗尸虱十石拾时什食蚀实识史矢使屎驶始式示士世柿事拭誓逝势是嗜噬适仕侍释饰氏市恃室视试收手首守寿授售受瘦兽蔬枢梳殊抒输叔舒淑疏书赎孰熟薯暑曙署蜀黍鼠属术述树束戍竖墅庶数漱"], +["cb40","薂薃薆薈",6,"薐",10,"薝",6,"薥薦薧薩薫薬薭薱",5,"薸薺",6,"藂",6,"藊",4,"藑藒"], +["cb80","藔藖",5,"藝",6,"藥藦藧藨藪",14,"恕刷耍摔衰甩帅栓拴霜双爽谁水睡税吮瞬顺舜说硕朔烁斯撕嘶思私司丝死肆寺嗣四伺似饲巳松耸怂颂送宋讼诵搜艘擞嗽苏酥俗素速粟僳塑溯宿诉肃酸蒜算虽隋随绥髓碎岁穗遂隧祟孙损笋蓑梭唆缩琐索锁所塌他它她塔"], +["cc40","藹藺藼藽藾蘀",4,"蘆",10,"蘒蘓蘔蘕蘗",15,"蘨蘪",13,"蘹蘺蘻蘽蘾蘿虀"], +["cc80","虁",11,"虒虓處",4,"虛虜虝號虠虡虣",7,"獭挞蹋踏胎苔抬台泰酞太态汰坍摊贪瘫滩坛檀痰潭谭谈坦毯袒碳探叹炭汤塘搪堂棠膛唐糖倘躺淌趟烫掏涛滔绦萄桃逃淘陶讨套特藤腾疼誊梯剔踢锑提题蹄啼体替嚏惕涕剃屉天添填田甜恬舔腆挑条迢眺跳贴铁帖厅听烃"], +["cd40","虭虯虰虲",6,"蚃",6,"蚎",4,"蚔蚖",5,"蚞",4,"蚥蚦蚫蚭蚮蚲蚳蚷蚸蚹蚻",4,"蛁蛂蛃蛅蛈蛌蛍蛒蛓蛕蛖蛗蛚蛜"], +["cd80","蛝蛠蛡蛢蛣蛥蛦蛧蛨蛪蛫蛬蛯蛵蛶蛷蛺蛻蛼蛽蛿蜁蜄蜅蜆蜋蜌蜎蜏蜐蜑蜔蜖汀廷停亭庭挺艇通桐酮瞳同铜彤童桶捅筒统痛偷投头透凸秃突图徒途涂屠土吐兔湍团推颓腿蜕褪退吞屯臀拖托脱鸵陀驮驼椭妥拓唾挖哇蛙洼娃瓦袜歪外豌弯湾玩顽丸烷完碗挽晚皖惋宛婉万腕汪王亡枉网往旺望忘妄威"], +["ce40","蜙蜛蜝蜟蜠蜤蜦蜧蜨蜪蜫蜬蜭蜯蜰蜲蜳蜵蜶蜸蜹蜺蜼蜽蝀",6,"蝊蝋蝍蝏蝐蝑蝒蝔蝕蝖蝘蝚",5,"蝡蝢蝦",7,"蝯蝱蝲蝳蝵"], +["ce80","蝷蝸蝹蝺蝿螀螁螄螆螇螉螊螌螎",4,"螔螕螖螘",6,"螠",4,"巍微危韦违桅围唯惟为潍维苇萎委伟伪尾纬未蔚味畏胃喂魏位渭谓尉慰卫瘟温蚊文闻纹吻稳紊问嗡翁瓮挝蜗涡窝我斡卧握沃巫呜钨乌污诬屋无芜梧吾吴毋武五捂午舞伍侮坞戊雾晤物勿务悟误昔熙析西硒矽晰嘻吸锡牺"], +["cf40","螥螦螧螩螪螮螰螱螲螴螶螷螸螹螻螼螾螿蟁",4,"蟇蟈蟉蟌",4,"蟔",6,"蟜蟝蟞蟟蟡蟢蟣蟤蟦蟧蟨蟩蟫蟬蟭蟯",9], +["cf80","蟺蟻蟼蟽蟿蠀蠁蠂蠄",5,"蠋",7,"蠔蠗蠘蠙蠚蠜",4,"蠣稀息希悉膝夕惜熄烯溪汐犀檄袭席习媳喜铣洗系隙戏细瞎虾匣霞辖暇峡侠狭下厦夏吓掀锨先仙鲜纤咸贤衔舷闲涎弦嫌显险现献县腺馅羡宪陷限线相厢镶香箱襄湘乡翔祥详想响享项巷橡像向象萧硝霄削哮嚣销消宵淆晓"], +["d040","蠤",13,"蠳",5,"蠺蠻蠽蠾蠿衁衂衃衆",5,"衎",5,"衕衖衘衚",6,"衦衧衪衭衯衱衳衴衵衶衸衹衺"], +["d080","衻衼袀袃袆袇袉袊袌袎袏袐袑袓袔袕袗",4,"袝",4,"袣袥",5,"小孝校肖啸笑效楔些歇蝎鞋协挟携邪斜胁谐写械卸蟹懈泄泻谢屑薪芯锌欣辛新忻心信衅星腥猩惺兴刑型形邢行醒幸杏性姓兄凶胸匈汹雄熊休修羞朽嗅锈秀袖绣墟戌需虚嘘须徐许蓄酗叙旭序畜恤絮婿绪续轩喧宣悬旋玄"], +["d140","袬袮袯袰袲",4,"袸袹袺袻袽袾袿裀裃裄裇裈裊裋裌裍裏裐裑裓裖裗裚",4,"裠裡裦裧裩",6,"裲裵裶裷裺裻製裿褀褁褃",5], +["d180","褉褋",4,"褑褔",4,"褜",4,"褢褣褤褦褧褨褩褬褭褮褯褱褲褳褵褷选癣眩绚靴薛学穴雪血勋熏循旬询寻驯巡殉汛训讯逊迅压押鸦鸭呀丫芽牙蚜崖衙涯雅哑亚讶焉咽阉烟淹盐严研蜒岩延言颜阎炎沿奄掩眼衍演艳堰燕厌砚雁唁彦焰宴谚验殃央鸯秧杨扬佯疡羊洋阳氧仰痒养样漾邀腰妖瑶"], +["d240","褸",8,"襂襃襅",24,"襠",5,"襧",19,"襼"], +["d280","襽襾覀覂覄覅覇",26,"摇尧遥窑谣姚咬舀药要耀椰噎耶爷野冶也页掖业叶曳腋夜液一壹医揖铱依伊衣颐夷遗移仪胰疑沂宜姨彝椅蚁倚已乙矣以艺抑易邑屹亿役臆逸肄疫亦裔意毅忆义益溢诣议谊译异翼翌绎茵荫因殷音阴姻吟银淫寅饮尹引隐"], +["d340","覢",30,"觃觍觓觔觕觗觘觙觛觝觟觠觡觢觤觧觨觩觪觬觭觮觰觱觲觴",6], +["d380","觻",4,"訁",5,"計",21,"印英樱婴鹰应缨莹萤营荧蝇迎赢盈影颖硬映哟拥佣臃痈庸雍踊蛹咏泳涌永恿勇用幽优悠忧尤由邮铀犹油游酉有友右佑釉诱又幼迂淤于盂榆虞愚舆余俞逾鱼愉渝渔隅予娱雨与屿禹宇语羽玉域芋郁吁遇喻峪御愈欲狱育誉"], +["d440","訞",31,"訿",8,"詉",21], +["d480","詟",25,"詺",6,"浴寓裕预豫驭鸳渊冤元垣袁原援辕园员圆猿源缘远苑愿怨院曰约越跃钥岳粤月悦阅耘云郧匀陨允运蕴酝晕韵孕匝砸杂栽哉灾宰载再在咱攒暂赞赃脏葬遭糟凿藻枣早澡蚤躁噪造皂灶燥责择则泽贼怎增憎曾赠扎喳渣札轧"], +["d540","誁",7,"誋",7,"誔",46], +["d580","諃",32,"铡闸眨栅榨咋乍炸诈摘斋宅窄债寨瞻毡詹粘沾盏斩辗崭展蘸栈占战站湛绽樟章彰漳张掌涨杖丈帐账仗胀瘴障招昭找沼赵照罩兆肇召遮折哲蛰辙者锗蔗这浙珍斟真甄砧臻贞针侦枕疹诊震振镇阵蒸挣睁征狰争怔整拯正政"], +["d640","諤",34,"謈",27], +["d680","謤謥謧",30,"帧症郑证芝枝支吱蜘知肢脂汁之织职直植殖执值侄址指止趾只旨纸志挚掷至致置帜峙制智秩稚质炙痔滞治窒中盅忠钟衷终种肿重仲众舟周州洲诌粥轴肘帚咒皱宙昼骤珠株蛛朱猪诸诛逐竹烛煮拄瞩嘱主著柱助蛀贮铸筑"], +["d740","譆",31,"譧",4,"譭",25], +["d780","讇",24,"讬讱讻诇诐诪谉谞住注祝驻抓爪拽专砖转撰赚篆桩庄装妆撞壮状椎锥追赘坠缀谆准捉拙卓桌琢茁酌啄着灼浊兹咨资姿滋淄孜紫仔籽滓子自渍字鬃棕踪宗综总纵邹走奏揍租足卒族祖诅阻组钻纂嘴醉最罪尊遵昨左佐柞做作坐座"], +["d840","谸",8,"豂豃豄豅豈豊豋豍",7,"豖豗豘豙豛",5,"豣",6,"豬",6,"豴豵豶豷豻",6,"貃貄貆貇"], +["d880","貈貋貍",6,"貕貖貗貙",20,"亍丌兀丐廿卅丕亘丞鬲孬噩丨禺丿匕乇夭爻卮氐囟胤馗毓睾鼗丶亟鼐乜乩亓芈孛啬嘏仄厍厝厣厥厮靥赝匚叵匦匮匾赜卦卣刂刈刎刭刳刿剀剌剞剡剜蒯剽劂劁劐劓冂罔亻仃仉仂仨仡仫仞伛仳伢佤仵伥伧伉伫佞佧攸佚佝"], +["d940","貮",62], +["d980","賭",32,"佟佗伲伽佶佴侑侉侃侏佾佻侪佼侬侔俦俨俪俅俚俣俜俑俟俸倩偌俳倬倏倮倭俾倜倌倥倨偾偃偕偈偎偬偻傥傧傩傺僖儆僭僬僦僮儇儋仝氽佘佥俎龠汆籴兮巽黉馘冁夔勹匍訇匐凫夙兕亠兖亳衮袤亵脔裒禀嬴蠃羸冫冱冽冼"], +["da40","贎",14,"贠赑赒赗赟赥赨赩赪赬赮赯赱赲赸",8,"趂趃趆趇趈趉趌",4,"趒趓趕",9,"趠趡"], +["da80","趢趤",12,"趲趶趷趹趻趽跀跁跂跅跇跈跉跊跍跐跒跓跔凇冖冢冥讠讦讧讪讴讵讷诂诃诋诏诎诒诓诔诖诘诙诜诟诠诤诨诩诮诰诳诶诹诼诿谀谂谄谇谌谏谑谒谔谕谖谙谛谘谝谟谠谡谥谧谪谫谮谯谲谳谵谶卩卺阝阢阡阱阪阽阼陂陉陔陟陧陬陲陴隈隍隗隰邗邛邝邙邬邡邴邳邶邺"], +["db40","跕跘跙跜跠跡跢跥跦跧跩跭跮跰跱跲跴跶跼跾",6,"踆踇踈踋踍踎踐踑踒踓踕",7,"踠踡踤",4,"踫踭踰踲踳踴踶踷踸踻踼踾"], +["db80","踿蹃蹅蹆蹌",4,"蹓",5,"蹚",11,"蹧蹨蹪蹫蹮蹱邸邰郏郅邾郐郄郇郓郦郢郜郗郛郫郯郾鄄鄢鄞鄣鄱鄯鄹酃酆刍奂劢劬劭劾哿勐勖勰叟燮矍廴凵凼鬯厶弁畚巯坌垩垡塾墼壅壑圩圬圪圳圹圮圯坜圻坂坩垅坫垆坼坻坨坭坶坳垭垤垌垲埏垧垴垓垠埕埘埚埙埒垸埴埯埸埤埝"], +["dc40","蹳蹵蹷",4,"蹽蹾躀躂躃躄躆躈",6,"躑躒躓躕",6,"躝躟",11,"躭躮躰躱躳",6,"躻",7], +["dc80","軃",10,"軏",21,"堋堍埽埭堀堞堙塄堠塥塬墁墉墚墀馨鼙懿艹艽艿芏芊芨芄芎芑芗芙芫芸芾芰苈苊苣芘芷芮苋苌苁芩芴芡芪芟苄苎芤苡茉苷苤茏茇苜苴苒苘茌苻苓茑茚茆茔茕苠苕茜荑荛荜茈莒茼茴茱莛荞茯荏荇荃荟荀茗荠茭茺茳荦荥"], +["dd40","軥",62], +["dd80","輤",32,"荨茛荩荬荪荭荮莰荸莳莴莠莪莓莜莅荼莶莩荽莸荻莘莞莨莺莼菁萁菥菘堇萘萋菝菽菖萜萸萑萆菔菟萏萃菸菹菪菅菀萦菰菡葜葑葚葙葳蒇蒈葺蒉葸萼葆葩葶蒌蒎萱葭蓁蓍蓐蓦蒽蓓蓊蒿蒺蓠蒡蒹蒴蒗蓥蓣蔌甍蔸蓰蔹蔟蔺"], +["de40","轅",32,"轪辀辌辒辝辠辡辢辤辥辦辧辪辬辭辮辯農辳辴辵辷辸辺辻込辿迀迃迆"], +["de80","迉",4,"迏迒迖迗迚迠迡迣迧迬迯迱迲迴迵迶迺迻迼迾迿逇逈逌逎逓逕逘蕖蔻蓿蓼蕙蕈蕨蕤蕞蕺瞢蕃蕲蕻薤薨薇薏蕹薮薜薅薹薷薰藓藁藜藿蘧蘅蘩蘖蘼廾弈夼奁耷奕奚奘匏尢尥尬尴扌扪抟抻拊拚拗拮挢拶挹捋捃掭揶捱捺掎掴捭掬掊捩掮掼揲揸揠揿揄揞揎摒揆掾摅摁搋搛搠搌搦搡摞撄摭撖"], +["df40","這逜連逤逥逧",5,"逰",4,"逷逹逺逽逿遀遃遅遆遈",4,"過達違遖遙遚遜",5,"遤遦遧適遪遫遬遯",4,"遶",6,"遾邁"], +["df80","還邅邆邇邉邊邌",4,"邒邔邖邘邚邜邞邟邠邤邥邧邨邩邫邭邲邷邼邽邿郀摺撷撸撙撺擀擐擗擤擢攉攥攮弋忒甙弑卟叱叽叩叨叻吒吖吆呋呒呓呔呖呃吡呗呙吣吲咂咔呷呱呤咚咛咄呶呦咝哐咭哂咴哒咧咦哓哔呲咣哕咻咿哌哙哚哜咩咪咤哝哏哞唛哧唠哽唔哳唢唣唏唑唧唪啧喏喵啉啭啁啕唿啐唼"], +["e040","郂郃郆郈郉郋郌郍郒郔郕郖郘郙郚郞郟郠郣郤郥郩郪郬郮郰郱郲郳郵郶郷郹郺郻郼郿鄀鄁鄃鄅",19,"鄚鄛鄜"], +["e080","鄝鄟鄠鄡鄤",10,"鄰鄲",6,"鄺",8,"酄唷啖啵啶啷唳唰啜喋嗒喃喱喹喈喁喟啾嗖喑啻嗟喽喾喔喙嗪嗷嗉嘟嗑嗫嗬嗔嗦嗝嗄嗯嗥嗲嗳嗌嗍嗨嗵嗤辔嘞嘈嘌嘁嘤嘣嗾嘀嘧嘭噘嘹噗嘬噍噢噙噜噌噔嚆噤噱噫噻噼嚅嚓嚯囔囗囝囡囵囫囹囿圄圊圉圜帏帙帔帑帱帻帼"], +["e140","酅酇酈酑酓酔酕酖酘酙酛酜酟酠酦酧酨酫酭酳酺酻酼醀",4,"醆醈醊醎醏醓",6,"醜",5,"醤",5,"醫醬醰醱醲醳醶醷醸醹醻"], +["e180","醼",10,"釈釋釐釒",9,"針",8,"帷幄幔幛幞幡岌屺岍岐岖岈岘岙岑岚岜岵岢岽岬岫岱岣峁岷峄峒峤峋峥崂崃崧崦崮崤崞崆崛嵘崾崴崽嵬嵛嵯嵝嵫嵋嵊嵩嵴嶂嶙嶝豳嶷巅彳彷徂徇徉後徕徙徜徨徭徵徼衢彡犭犰犴犷犸狃狁狎狍狒狨狯狩狲狴狷猁狳猃狺"], +["e240","釦",62], +["e280","鈥",32,"狻猗猓猡猊猞猝猕猢猹猥猬猸猱獐獍獗獠獬獯獾舛夥飧夤夂饣饧",5,"饴饷饽馀馄馇馊馍馐馑馓馔馕庀庑庋庖庥庠庹庵庾庳赓廒廑廛廨廪膺忄忉忖忏怃忮怄忡忤忾怅怆忪忭忸怙怵怦怛怏怍怩怫怊怿怡恸恹恻恺恂"], +["e340","鉆",45,"鉵",16], +["e380","銆",7,"銏",24,"恪恽悖悚悭悝悃悒悌悛惬悻悱惝惘惆惚悴愠愦愕愣惴愀愎愫慊慵憬憔憧憷懔懵忝隳闩闫闱闳闵闶闼闾阃阄阆阈阊阋阌阍阏阒阕阖阗阙阚丬爿戕氵汔汜汊沣沅沐沔沌汨汩汴汶沆沩泐泔沭泷泸泱泗沲泠泖泺泫泮沱泓泯泾"], +["e440","銨",5,"銯",24,"鋉",31], +["e480","鋩",32,"洹洧洌浃浈洇洄洙洎洫浍洮洵洚浏浒浔洳涑浯涞涠浞涓涔浜浠浼浣渚淇淅淞渎涿淠渑淦淝淙渖涫渌涮渫湮湎湫溲湟溆湓湔渲渥湄滟溱溘滠漭滢溥溧溽溻溷滗溴滏溏滂溟潢潆潇漤漕滹漯漶潋潴漪漉漩澉澍澌潸潲潼潺濑"], +["e540","錊",51,"錿",10], +["e580","鍊",31,"鍫濉澧澹澶濂濡濮濞濠濯瀚瀣瀛瀹瀵灏灞宀宄宕宓宥宸甯骞搴寤寮褰寰蹇謇辶迓迕迥迮迤迩迦迳迨逅逄逋逦逑逍逖逡逵逶逭逯遄遑遒遐遨遘遢遛暹遴遽邂邈邃邋彐彗彖彘尻咫屐屙孱屣屦羼弪弩弭艴弼鬻屮妁妃妍妩妪妣"], +["e640","鍬",34,"鎐",27], +["e680","鎬",29,"鏋鏌鏍妗姊妫妞妤姒妲妯姗妾娅娆姝娈姣姘姹娌娉娲娴娑娣娓婀婧婊婕娼婢婵胬媪媛婷婺媾嫫媲嫒嫔媸嫠嫣嫱嫖嫦嫘嫜嬉嬗嬖嬲嬷孀尕尜孚孥孳孑孓孢驵驷驸驺驿驽骀骁骅骈骊骐骒骓骖骘骛骜骝骟骠骢骣骥骧纟纡纣纥纨纩"], +["e740","鏎",7,"鏗",54], +["e780","鐎",32,"纭纰纾绀绁绂绉绋绌绐绔绗绛绠绡绨绫绮绯绱绲缍绶绺绻绾缁缂缃缇缈缋缌缏缑缒缗缙缜缛缟缡",6,"缪缫缬缭缯",4,"缵幺畿巛甾邕玎玑玮玢玟珏珂珑玷玳珀珉珈珥珙顼琊珩珧珞玺珲琏琪瑛琦琥琨琰琮琬"], +["e840","鐯",14,"鐿",43,"鑬鑭鑮鑯"], +["e880","鑰",20,"钑钖钘铇铏铓铔铚铦铻锜锠琛琚瑁瑜瑗瑕瑙瑷瑭瑾璜璎璀璁璇璋璞璨璩璐璧瓒璺韪韫韬杌杓杞杈杩枥枇杪杳枘枧杵枨枞枭枋杷杼柰栉柘栊柩枰栌柙枵柚枳柝栀柃枸柢栎柁柽栲栳桠桡桎桢桄桤梃栝桕桦桁桧桀栾桊桉栩梵梏桴桷梓桫棂楮棼椟椠棹"], +["e940","锧锳锽镃镈镋镕镚镠镮镴镵長",7,"門",42], +["e980","閫",32,"椤棰椋椁楗棣椐楱椹楠楂楝榄楫榀榘楸椴槌榇榈槎榉楦楣楹榛榧榻榫榭槔榱槁槊槟榕槠榍槿樯槭樗樘橥槲橄樾檠橐橛樵檎橹樽樨橘橼檑檐檩檗檫猷獒殁殂殇殄殒殓殍殚殛殡殪轫轭轱轲轳轵轶轸轷轹轺轼轾辁辂辄辇辋"], +["ea40","闌",27,"闬闿阇阓阘阛阞阠阣",6,"阫阬阭阯阰阷阸阹阺阾陁陃陊陎陏陑陒陓陖陗"], +["ea80","陘陙陚陜陝陞陠陣陥陦陫陭",4,"陳陸",12,"隇隉隊辍辎辏辘辚軎戋戗戛戟戢戡戥戤戬臧瓯瓴瓿甏甑甓攴旮旯旰昊昙杲昃昕昀炅曷昝昴昱昶昵耆晟晔晁晏晖晡晗晷暄暌暧暝暾曛曜曦曩贲贳贶贻贽赀赅赆赈赉赇赍赕赙觇觊觋觌觎觏觐觑牮犟牝牦牯牾牿犄犋犍犏犒挈挲掰"], +["eb40","隌階隑隒隓隕隖隚際隝",9,"隨",7,"隱隲隴隵隷隸隺隻隿雂雃雈雊雋雐雑雓雔雖",9,"雡",6,"雫"], +["eb80","雬雭雮雰雱雲雴雵雸雺電雼雽雿霂霃霅霊霋霌霐霑霒霔霕霗",4,"霝霟霠搿擘耄毪毳毽毵毹氅氇氆氍氕氘氙氚氡氩氤氪氲攵敕敫牍牒牖爰虢刖肟肜肓肼朊肽肱肫肭肴肷胧胨胩胪胛胂胄胙胍胗朐胝胫胱胴胭脍脎胲胼朕脒豚脶脞脬脘脲腈腌腓腴腙腚腱腠腩腼腽腭腧塍媵膈膂膑滕膣膪臌朦臊膻"], +["ec40","霡",8,"霫霬霮霯霱霳",4,"霺霻霼霽霿",18,"靔靕靗靘靚靜靝靟靣靤靦靧靨靪",7], +["ec80","靲靵靷",4,"靽",7,"鞆",4,"鞌鞎鞏鞐鞓鞕鞖鞗鞙",4,"臁膦欤欷欹歃歆歙飑飒飓飕飙飚殳彀毂觳斐齑斓於旆旄旃旌旎旒旖炀炜炖炝炻烀炷炫炱烨烊焐焓焖焯焱煳煜煨煅煲煊煸煺熘熳熵熨熠燠燔燧燹爝爨灬焘煦熹戾戽扃扈扉礻祀祆祉祛祜祓祚祢祗祠祯祧祺禅禊禚禧禳忑忐"], +["ed40","鞞鞟鞡鞢鞤",6,"鞬鞮鞰鞱鞳鞵",46], +["ed80","韤韥韨韮",4,"韴韷",23,"怼恝恚恧恁恙恣悫愆愍慝憩憝懋懑戆肀聿沓泶淼矶矸砀砉砗砘砑斫砭砜砝砹砺砻砟砼砥砬砣砩硎硭硖硗砦硐硇硌硪碛碓碚碇碜碡碣碲碹碥磔磙磉磬磲礅磴礓礤礞礴龛黹黻黼盱眄眍盹眇眈眚眢眙眭眦眵眸睐睑睇睃睚睨"], +["ee40","頏",62], +["ee80","顎",32,"睢睥睿瞍睽瞀瞌瞑瞟瞠瞰瞵瞽町畀畎畋畈畛畲畹疃罘罡罟詈罨罴罱罹羁罾盍盥蠲钅钆钇钋钊钌钍钏钐钔钗钕钚钛钜钣钤钫钪钭钬钯钰钲钴钶",4,"钼钽钿铄铈",6,"铐铑铒铕铖铗铙铘铛铞铟铠铢铤铥铧铨铪"], +["ef40","顯",5,"颋颎颒颕颙颣風",37,"飏飐飔飖飗飛飜飝飠",4], +["ef80","飥飦飩",30,"铩铫铮铯铳铴铵铷铹铼铽铿锃锂锆锇锉锊锍锎锏锒",4,"锘锛锝锞锟锢锪锫锩锬锱锲锴锶锷锸锼锾锿镂锵镄镅镆镉镌镎镏镒镓镔镖镗镘镙镛镞镟镝镡镢镤",8,"镯镱镲镳锺矧矬雉秕秭秣秫稆嵇稃稂稞稔"], +["f040","餈",4,"餎餏餑",28,"餯",26], +["f080","饊",9,"饖",12,"饤饦饳饸饹饻饾馂馃馉稹稷穑黏馥穰皈皎皓皙皤瓞瓠甬鸠鸢鸨",4,"鸲鸱鸶鸸鸷鸹鸺鸾鹁鹂鹄鹆鹇鹈鹉鹋鹌鹎鹑鹕鹗鹚鹛鹜鹞鹣鹦",6,"鹱鹭鹳疒疔疖疠疝疬疣疳疴疸痄疱疰痃痂痖痍痣痨痦痤痫痧瘃痱痼痿瘐瘀瘅瘌瘗瘊瘥瘘瘕瘙"], +["f140","馌馎馚",10,"馦馧馩",47], +["f180","駙",32,"瘛瘼瘢瘠癀瘭瘰瘿瘵癃瘾瘳癍癞癔癜癖癫癯翊竦穸穹窀窆窈窕窦窠窬窨窭窳衤衩衲衽衿袂袢裆袷袼裉裢裎裣裥裱褚裼裨裾裰褡褙褓褛褊褴褫褶襁襦襻疋胥皲皴矜耒耔耖耜耠耢耥耦耧耩耨耱耋耵聃聆聍聒聩聱覃顸颀颃"], +["f240","駺",62], +["f280","騹",32,"颉颌颍颏颔颚颛颞颟颡颢颥颦虍虔虬虮虿虺虼虻蚨蚍蚋蚬蚝蚧蚣蚪蚓蚩蚶蛄蚵蛎蚰蚺蚱蚯蛉蛏蚴蛩蛱蛲蛭蛳蛐蜓蛞蛴蛟蛘蛑蜃蜇蛸蜈蜊蜍蜉蜣蜻蜞蜥蜮蜚蜾蝈蜴蜱蜩蜷蜿螂蜢蝽蝾蝻蝠蝰蝌蝮螋蝓蝣蝼蝤蝙蝥螓螯螨蟒"], +["f340","驚",17,"驲骃骉骍骎骔骕骙骦骩",6,"骲骳骴骵骹骻骽骾骿髃髄髆",4,"髍髎髏髐髒體髕髖髗髙髚髛髜"], +["f380","髝髞髠髢髣髤髥髧髨髩髪髬髮髰",8,"髺髼",6,"鬄鬅鬆蟆螈螅螭螗螃螫蟥螬螵螳蟋蟓螽蟑蟀蟊蟛蟪蟠蟮蠖蠓蟾蠊蠛蠡蠹蠼缶罂罄罅舐竺竽笈笃笄笕笊笫笏筇笸笪笙笮笱笠笥笤笳笾笞筘筚筅筵筌筝筠筮筻筢筲筱箐箦箧箸箬箝箨箅箪箜箢箫箴篑篁篌篝篚篥篦篪簌篾篼簏簖簋"], +["f440","鬇鬉",5,"鬐鬑鬒鬔",10,"鬠鬡鬢鬤",10,"鬰鬱鬳",7,"鬽鬾鬿魀魆魊魋魌魎魐魒魓魕",5], +["f480","魛",32,"簟簪簦簸籁籀臾舁舂舄臬衄舡舢舣舭舯舨舫舸舻舳舴舾艄艉艋艏艚艟艨衾袅袈裘裟襞羝羟羧羯羰羲籼敉粑粝粜粞粢粲粼粽糁糇糌糍糈糅糗糨艮暨羿翎翕翥翡翦翩翮翳糸絷綦綮繇纛麸麴赳趄趔趑趱赧赭豇豉酊酐酎酏酤"], +["f540","魼",62], +["f580","鮻",32,"酢酡酰酩酯酽酾酲酴酹醌醅醐醍醑醢醣醪醭醮醯醵醴醺豕鹾趸跫踅蹙蹩趵趿趼趺跄跖跗跚跞跎跏跛跆跬跷跸跣跹跻跤踉跽踔踝踟踬踮踣踯踺蹀踹踵踽踱蹉蹁蹂蹑蹒蹊蹰蹶蹼蹯蹴躅躏躔躐躜躞豸貂貊貅貘貔斛觖觞觚觜"], +["f640","鯜",62], +["f680","鰛",32,"觥觫觯訾謦靓雩雳雯霆霁霈霏霎霪霭霰霾龀龃龅",5,"龌黾鼋鼍隹隼隽雎雒瞿雠銎銮鋈錾鍪鏊鎏鐾鑫鱿鲂鲅鲆鲇鲈稣鲋鲎鲐鲑鲒鲔鲕鲚鲛鲞",5,"鲥",4,"鲫鲭鲮鲰",7,"鲺鲻鲼鲽鳄鳅鳆鳇鳊鳋"], +["f740","鰼",62], +["f780","鱻鱽鱾鲀鲃鲄鲉鲊鲌鲏鲓鲖鲗鲘鲙鲝鲪鲬鲯鲹鲾",4,"鳈鳉鳑鳒鳚鳛鳠鳡鳌",4,"鳓鳔鳕鳗鳘鳙鳜鳝鳟鳢靼鞅鞑鞒鞔鞯鞫鞣鞲鞴骱骰骷鹘骶骺骼髁髀髅髂髋髌髑魅魃魇魉魈魍魑飨餍餮饕饔髟髡髦髯髫髻髭髹鬈鬏鬓鬟鬣麽麾縻麂麇麈麋麒鏖麝麟黛黜黝黠黟黢黩黧黥黪黯鼢鼬鼯鼹鼷鼽鼾齄"], +["f840","鳣",62], +["f880","鴢",32], +["f940","鵃",62], +["f980","鶂",32], +["fa40","鶣",62], +["fa80","鷢",32], +["fb40","鸃",27,"鸤鸧鸮鸰鸴鸻鸼鹀鹍鹐鹒鹓鹔鹖鹙鹝鹟鹠鹡鹢鹥鹮鹯鹲鹴",9,"麀"], +["fb80","麁麃麄麅麆麉麊麌",5,"麔",8,"麞麠",5,"麧麨麩麪"], +["fc40","麫",8,"麵麶麷麹麺麼麿",4,"黅黆黇黈黊黋黌黐黒黓黕黖黗黙黚點黡黣黤黦黨黫黬黭黮黰",8,"黺黽黿",6], +["fc80","鼆",4,"鼌鼏鼑鼒鼔鼕鼖鼘鼚",5,"鼡鼣",8,"鼭鼮鼰鼱"], +["fd40","鼲",4,"鼸鼺鼼鼿",4,"齅",10,"齒",38], +["fd80","齹",5,"龁龂龍",11,"龜龝龞龡",4,"郎凉秊裏隣"], +["fe40","兀嗀﨎﨏﨑﨓﨔礼﨟蘒﨡﨣﨤﨧﨨﨩"] +] diff --git a/node_modules/body-parser/node_modules/iconv-lite/encodings/tables/cp949.json b/node_modules/body-parser/node_modules/iconv-lite/encodings/tables/cp949.json new file mode 100644 index 0000000..2022a00 --- /dev/null +++ b/node_modules/body-parser/node_modules/iconv-lite/encodings/tables/cp949.json @@ -0,0 +1,273 @@ +[ +["0","\u0000",127], +["8141","갂갃갅갆갋",4,"갘갞갟갡갢갣갥",6,"갮갲갳갴"], +["8161","갵갶갷갺갻갽갾갿걁",9,"걌걎",5,"걕"], +["8181","걖걗걙걚걛걝",18,"걲걳걵걶걹걻",4,"겂겇겈겍겎겏겑겒겓겕",6,"겞겢",5,"겫겭겮겱",6,"겺겾겿곀곂곃곅곆곇곉곊곋곍",7,"곖곘",7,"곢곣곥곦곩곫곭곮곲곴곷",4,"곾곿괁괂괃괅괇",4,"괎괐괒괓"], +["8241","괔괕괖괗괙괚괛괝괞괟괡",7,"괪괫괮",5], +["8261","괶괷괹괺괻괽",6,"굆굈굊",5,"굑굒굓굕굖굗"], +["8281","굙",7,"굢굤",7,"굮굯굱굲굷굸굹굺굾궀궃",4,"궊궋궍궎궏궑",10,"궞",5,"궥",17,"궸",7,"귂귃귅귆귇귉",6,"귒귔",7,"귝귞귟귡귢귣귥",18], +["8341","귺귻귽귾긂",5,"긊긌긎",5,"긕",7], +["8361","긝",18,"긲긳긵긶긹긻긼"], +["8381","긽긾긿깂깄깇깈깉깋깏깑깒깓깕깗",4,"깞깢깣깤깦깧깪깫깭깮깯깱",6,"깺깾",5,"꺆",5,"꺍",46,"꺿껁껂껃껅",6,"껎껒",5,"껚껛껝",8], +["8441","껦껧껩껪껬껮",5,"껵껶껷껹껺껻껽",8], +["8461","꼆꼉꼊꼋꼌꼎꼏꼑",18], +["8481","꼤",7,"꼮꼯꼱꼳꼵",6,"꼾꽀꽄꽅꽆꽇꽊",5,"꽑",10,"꽞",5,"꽦",18,"꽺",5,"꾁꾂꾃꾅꾆꾇꾉",6,"꾒꾓꾔꾖",5,"꾝",26,"꾺꾻꾽꾾"], +["8541","꾿꿁",5,"꿊꿌꿏",4,"꿕",6,"꿝",4], +["8561","꿢",5,"꿪",5,"꿲꿳꿵꿶꿷꿹",6,"뀂뀃"], +["8581","뀅",6,"뀍뀎뀏뀑뀒뀓뀕",6,"뀞",9,"뀩",26,"끆끇끉끋끍끏끐끑끒끖끘끚끛끜끞",29,"끾끿낁낂낃낅",6,"낎낐낒",5,"낛낝낞낣낤"], +["8641","낥낦낧낪낰낲낶낷낹낺낻낽",6,"냆냊",5,"냒"], +["8661","냓냕냖냗냙",6,"냡냢냣냤냦",10], +["8681","냱",22,"넊넍넎넏넑넔넕넖넗넚넞",4,"넦넧넩넪넫넭",6,"넶넺",5,"녂녃녅녆녇녉",6,"녒녓녖녗녙녚녛녝녞녟녡",22,"녺녻녽녾녿놁놃",4,"놊놌놎놏놐놑놕놖놗놙놚놛놝"], +["8741","놞",9,"놩",15], +["8761","놹",18,"뇍뇎뇏뇑뇒뇓뇕"], +["8781","뇖",5,"뇞뇠",7,"뇪뇫뇭뇮뇯뇱",7,"뇺뇼뇾",5,"눆눇눉눊눍",6,"눖눘눚",5,"눡",18,"눵",6,"눽",26,"뉙뉚뉛뉝뉞뉟뉡",6,"뉪",4], +["8841","뉯",4,"뉶",5,"뉽",6,"늆늇늈늊",4], +["8861","늏늒늓늕늖늗늛",4,"늢늤늧늨늩늫늭늮늯늱늲늳늵늶늷"], +["8881","늸",15,"닊닋닍닎닏닑닓",4,"닚닜닞닟닠닡닣닧닩닪닰닱닲닶닼닽닾댂댃댅댆댇댉",6,"댒댖",5,"댝",54,"덗덙덚덝덠덡덢덣"], +["8941","덦덨덪덬덭덯덲덳덵덶덷덹",6,"뎂뎆",5,"뎍"], +["8961","뎎뎏뎑뎒뎓뎕",10,"뎢",5,"뎩뎪뎫뎭"], +["8981","뎮",21,"돆돇돉돊돍돏돑돒돓돖돘돚돜돞돟돡돢돣돥돦돧돩",18,"돽",18,"됑",6,"됙됚됛됝됞됟됡",6,"됪됬",7,"됵",15], +["8a41","둅",10,"둒둓둕둖둗둙",6,"둢둤둦"], +["8a61","둧",4,"둭",18,"뒁뒂"], +["8a81","뒃",4,"뒉",19,"뒞",5,"뒥뒦뒧뒩뒪뒫뒭",7,"뒶뒸뒺",5,"듁듂듃듅듆듇듉",6,"듑듒듓듔듖",5,"듞듟듡듢듥듧",4,"듮듰듲",5,"듹",26,"딖딗딙딚딝"], +["8b41","딞",5,"딦딫",4,"딲딳딵딶딷딹",6,"땂땆"], +["8b61","땇땈땉땊땎땏땑땒땓땕",6,"땞땢",8], +["8b81","땫",52,"떢떣떥떦떧떩떬떭떮떯떲떶",4,"떾떿뗁뗂뗃뗅",6,"뗎뗒",5,"뗙",18,"뗭",18], +["8c41","똀",15,"똒똓똕똖똗똙",4], +["8c61","똞",6,"똦",5,"똭",6,"똵",5], +["8c81","똻",12,"뙉",26,"뙥뙦뙧뙩",50,"뚞뚟뚡뚢뚣뚥",5,"뚭뚮뚯뚰뚲",16], +["8d41","뛃",16,"뛕",8], +["8d61","뛞",17,"뛱뛲뛳뛵뛶뛷뛹뛺"], +["8d81","뛻",4,"뜂뜃뜄뜆",33,"뜪뜫뜭뜮뜱",6,"뜺뜼",7,"띅띆띇띉띊띋띍",6,"띖",9,"띡띢띣띥띦띧띩",6,"띲띴띶",5,"띾띿랁랂랃랅",6,"랎랓랔랕랚랛랝랞"], +["8e41","랟랡",6,"랪랮",5,"랶랷랹",8], +["8e61","럂",4,"럈럊",19], +["8e81","럞",13,"럮럯럱럲럳럵",6,"럾렂",4,"렊렋렍렎렏렑",6,"렚렜렞",5,"렦렧렩렪렫렭",6,"렶렺",5,"롁롂롃롅",11,"롒롔",7,"롞롟롡롢롣롥",6,"롮롰롲",5,"롹롺롻롽",7], +["8f41","뢅",7,"뢎",17], +["8f61","뢠",7,"뢩",6,"뢱뢲뢳뢵뢶뢷뢹",4], +["8f81","뢾뢿룂룄룆",5,"룍룎룏룑룒룓룕",7,"룞룠룢",5,"룪룫룭룮룯룱",6,"룺룼룾",5,"뤅",18,"뤙",6,"뤡",26,"뤾뤿륁륂륃륅",6,"륍륎륐륒",5], +["9041","륚륛륝륞륟륡",6,"륪륬륮",5,"륶륷륹륺륻륽"], +["9061","륾",5,"릆릈릋릌릏",15], +["9081","릟",12,"릮릯릱릲릳릵",6,"릾맀맂",5,"맊맋맍맓",4,"맚맜맟맠맢맦맧맩맪맫맭",6,"맶맻",4,"먂",5,"먉",11,"먖",33,"먺먻먽먾먿멁멃멄멅멆"], +["9141","멇멊멌멏멐멑멒멖멗멙멚멛멝",6,"멦멪",5], +["9161","멲멳멵멶멷멹",9,"몆몈몉몊몋몍",5], +["9181","몓",20,"몪몭몮몯몱몳",4,"몺몼몾",5,"뫅뫆뫇뫉",14,"뫚",33,"뫽뫾뫿묁묂묃묅",7,"묎묐묒",5,"묙묚묛묝묞묟묡",6], +["9241","묨묪묬",7,"묷묹묺묿",4,"뭆뭈뭊뭋뭌뭎뭑뭒"], +["9261","뭓뭕뭖뭗뭙",7,"뭢뭤",7,"뭭",4], +["9281","뭲",21,"뮉뮊뮋뮍뮎뮏뮑",18,"뮥뮦뮧뮩뮪뮫뮭",6,"뮵뮶뮸",7,"믁믂믃믅믆믇믉",6,"믑믒믔",35,"믺믻믽믾밁"], +["9341","밃",4,"밊밎밐밒밓밙밚밠밡밢밣밦밨밪밫밬밮밯밲밳밵"], +["9361","밶밷밹",6,"뱂뱆뱇뱈뱊뱋뱎뱏뱑",8], +["9381","뱚뱛뱜뱞",37,"벆벇벉벊벍벏",4,"벖벘벛",4,"벢벣벥벦벩",6,"벲벶",5,"벾벿볁볂볃볅",7,"볎볒볓볔볖볗볙볚볛볝",22,"볷볹볺볻볽"], +["9441","볾",5,"봆봈봊",5,"봑봒봓봕",8], +["9461","봞",5,"봥",6,"봭",12], +["9481","봺",5,"뵁",6,"뵊뵋뵍뵎뵏뵑",6,"뵚",9,"뵥뵦뵧뵩",22,"붂붃붅붆붋",4,"붒붔붖붗붘붛붝",6,"붥",10,"붱",6,"붹",24], +["9541","뷒뷓뷖뷗뷙뷚뷛뷝",11,"뷪",5,"뷱"], +["9561","뷲뷳뷵뷶뷷뷹",6,"븁븂븄븆",5,"븎븏븑븒븓"], +["9581","븕",6,"븞븠",35,"빆빇빉빊빋빍빏",4,"빖빘빜빝빞빟빢빣빥빦빧빩빫",4,"빲빶",4,"빾빿뺁뺂뺃뺅",6,"뺎뺒",5,"뺚",13,"뺩",14], +["9641","뺸",23,"뻒뻓"], +["9661","뻕뻖뻙",6,"뻡뻢뻦",5,"뻭",8], +["9681","뻶",10,"뼂",5,"뼊",13,"뼚뼞",33,"뽂뽃뽅뽆뽇뽉",6,"뽒뽓뽔뽖",44], +["9741","뾃",16,"뾕",8], +["9761","뾞",17,"뾱",7], +["9781","뾹",11,"뿆",5,"뿎뿏뿑뿒뿓뿕",6,"뿝뿞뿠뿢",89,"쀽쀾쀿"], +["9841","쁀",16,"쁒",5,"쁙쁚쁛"], +["9861","쁝쁞쁟쁡",6,"쁪",15], +["9881","쁺",21,"삒삓삕삖삗삙",6,"삢삤삦",5,"삮삱삲삷",4,"삾샂샃샄샆샇샊샋샍샎샏샑",6,"샚샞",5,"샦샧샩샪샫샭",6,"샶샸샺",5,"섁섂섃섅섆섇섉",6,"섑섒섓섔섖",5,"섡섢섥섨섩섪섫섮"], +["9941","섲섳섴섵섷섺섻섽섾섿셁",6,"셊셎",5,"셖셗"], +["9961","셙셚셛셝",6,"셦셪",5,"셱셲셳셵셶셷셹셺셻"], +["9981","셼",8,"솆",5,"솏솑솒솓솕솗",4,"솞솠솢솣솤솦솧솪솫솭솮솯솱",11,"솾",5,"쇅쇆쇇쇉쇊쇋쇍",6,"쇕쇖쇙",6,"쇡쇢쇣쇥쇦쇧쇩",6,"쇲쇴",7,"쇾쇿숁숂숃숅",6,"숎숐숒",5,"숚숛숝숞숡숢숣"], +["9a41","숤숥숦숧숪숬숮숰숳숵",16], +["9a61","쉆쉇쉉",6,"쉒쉓쉕쉖쉗쉙",6,"쉡쉢쉣쉤쉦"], +["9a81","쉧",4,"쉮쉯쉱쉲쉳쉵",6,"쉾슀슂",5,"슊",5,"슑",6,"슙슚슜슞",5,"슦슧슩슪슫슮",5,"슶슸슺",33,"싞싟싡싢싥",5,"싮싰싲싳싴싵싷싺싽싾싿쌁",6,"쌊쌋쌎쌏"], +["9b41","쌐쌑쌒쌖쌗쌙쌚쌛쌝",6,"쌦쌧쌪",8], +["9b61","쌳",17,"썆",7], +["9b81","썎",25,"썪썫썭썮썯썱썳",4,"썺썻썾",5,"쎅쎆쎇쎉쎊쎋쎍",50,"쏁",22,"쏚"], +["9c41","쏛쏝쏞쏡쏣",4,"쏪쏫쏬쏮",5,"쏶쏷쏹",5], +["9c61","쏿",8,"쐉",6,"쐑",9], +["9c81","쐛",8,"쐥",6,"쐭쐮쐯쐱쐲쐳쐵",6,"쐾",9,"쑉",26,"쑦쑧쑩쑪쑫쑭",6,"쑶쑷쑸쑺",5,"쒁",18,"쒕",6,"쒝",12], +["9d41","쒪",13,"쒹쒺쒻쒽",8], +["9d61","쓆",25], +["9d81","쓠",8,"쓪",5,"쓲쓳쓵쓶쓷쓹쓻쓼쓽쓾씂",9,"씍씎씏씑씒씓씕",6,"씝",10,"씪씫씭씮씯씱",6,"씺씼씾",5,"앆앇앋앏앐앑앒앖앚앛앜앟앢앣앥앦앧앩",6,"앲앶",5,"앾앿얁얂얃얅얆얈얉얊얋얎얐얒얓얔"], +["9e41","얖얙얚얛얝얞얟얡",7,"얪",9,"얶"], +["9e61","얷얺얿",4,"엋엍엏엒엓엕엖엗엙",6,"엢엤엦엧"], +["9e81","엨엩엪엫엯엱엲엳엵엸엹엺엻옂옃옄옉옊옋옍옎옏옑",6,"옚옝",6,"옦옧옩옪옫옯옱옲옶옸옺옼옽옾옿왂왃왅왆왇왉",6,"왒왖",5,"왞왟왡",10,"왭왮왰왲",5,"왺왻왽왾왿욁",6,"욊욌욎",5,"욖욗욙욚욛욝",6,"욦"], +["9f41","욨욪",5,"욲욳욵욶욷욻",4,"웂웄웆",5,"웎"], +["9f61","웏웑웒웓웕",6,"웞웟웢",5,"웪웫웭웮웯웱웲"], +["9f81","웳",4,"웺웻웼웾",5,"윆윇윉윊윋윍",6,"윖윘윚",5,"윢윣윥윦윧윩",6,"윲윴윶윸윹윺윻윾윿읁읂읃읅",4,"읋읎읐읙읚읛읝읞읟읡",6,"읩읪읬",7,"읶읷읹읺읻읿잀잁잂잆잋잌잍잏잒잓잕잙잛",4,"잢잧",4,"잮잯잱잲잳잵잶잷"], +["a041","잸잹잺잻잾쟂",5,"쟊쟋쟍쟏쟑",6,"쟙쟚쟛쟜"], +["a061","쟞",5,"쟥쟦쟧쟩쟪쟫쟭",13], +["a081","쟻",4,"젂젃젅젆젇젉젋",4,"젒젔젗",4,"젞젟젡젢젣젥",6,"젮젰젲",5,"젹젺젻젽젾젿졁",6,"졊졋졎",5,"졕",26,"졲졳졵졶졷졹졻",4,"좂좄좈좉좊좎",5,"좕",7,"좞좠좢좣좤"], +["a141","좥좦좧좩",18,"좾좿죀죁"], +["a161","죂죃죅죆죇죉죊죋죍",6,"죖죘죚",5,"죢죣죥"], +["a181","죦",14,"죶",5,"죾죿줁줂줃줇",4,"줎 、。·‥…¨〃­―∥\∼‘’“”〔〕〈",9,"±×÷≠≤≥∞∴°′″℃Å¢£¥♂♀∠⊥⌒∂∇≡≒§※☆★○●◎◇◆□■△▲▽▼→←↑↓↔〓≪≫√∽∝∵∫∬∈∋⊆⊇⊂⊃∪∩∧∨¬"], +["a241","줐줒",5,"줙",18], +["a261","줭",6,"줵",18], +["a281","쥈",7,"쥒쥓쥕쥖쥗쥙",6,"쥢쥤",7,"쥭쥮쥯⇒⇔∀∃´~ˇ˘˝˚˙¸˛¡¿ː∮∑∏¤℉‰◁◀▷▶♤♠♡♥♧♣⊙◈▣◐◑▒▤▥▨▧▦▩♨☏☎☜☞¶†‡↕↗↙↖↘♭♩♪♬㉿㈜№㏇™㏂㏘℡€®"], +["a341","쥱쥲쥳쥵",6,"쥽",10,"즊즋즍즎즏"], +["a361","즑",6,"즚즜즞",16], +["a381","즯",16,"짂짃짅짆짉짋",4,"짒짔짗짘짛!",58,"₩]",32," ̄"], +["a441","짞짟짡짣짥짦짨짩짪짫짮짲",5,"짺짻짽짾짿쨁쨂쨃쨄"], +["a461","쨅쨆쨇쨊쨎",5,"쨕쨖쨗쨙",12], +["a481","쨦쨧쨨쨪",28,"ㄱ",93], +["a541","쩇",4,"쩎쩏쩑쩒쩓쩕",6,"쩞쩢",5,"쩩쩪"], +["a561","쩫",17,"쩾",5,"쪅쪆"], +["a581","쪇",16,"쪙",14,"ⅰ",9], +["a5b0","Ⅰ",9], +["a5c1","Α",16,"Σ",6], +["a5e1","α",16,"σ",6], +["a641","쪨",19,"쪾쪿쫁쫂쫃쫅"], +["a661","쫆",5,"쫎쫐쫒쫔쫕쫖쫗쫚",5,"쫡",6], +["a681","쫨쫩쫪쫫쫭",6,"쫵",18,"쬉쬊─│┌┐┘└├┬┤┴┼━┃┏┓┛┗┣┳┫┻╋┠┯┨┷┿┝┰┥┸╂┒┑┚┙┖┕┎┍┞┟┡┢┦┧┩┪┭┮┱┲┵┶┹┺┽┾╀╁╃",7], +["a741","쬋",4,"쬑쬒쬓쬕쬖쬗쬙",6,"쬢",7], +["a761","쬪",22,"쭂쭃쭄"], +["a781","쭅쭆쭇쭊쭋쭍쭎쭏쭑",6,"쭚쭛쭜쭞",5,"쭥",7,"㎕㎖㎗ℓ㎘㏄㎣㎤㎥㎦㎙",9,"㏊㎍㎎㎏㏏㎈㎉㏈㎧㎨㎰",9,"㎀",4,"㎺",5,"㎐",4,"Ω㏀㏁㎊㎋㎌㏖㏅㎭㎮㎯㏛㎩㎪㎫㎬㏝㏐㏓㏃㏉㏜㏆"], +["a841","쭭",10,"쭺",14], +["a861","쮉",18,"쮝",6], +["a881","쮤",19,"쮹",11,"ÆÐªĦ"], +["a8a6","IJ"], +["a8a8","ĿŁØŒºÞŦŊ"], +["a8b1","㉠",27,"ⓐ",25,"①",14,"½⅓⅔¼¾⅛⅜⅝⅞"], +["a941","쯅",14,"쯕",10], +["a961","쯠쯡쯢쯣쯥쯦쯨쯪",18], +["a981","쯽",14,"찎찏찑찒찓찕",6,"찞찟찠찣찤æđðħıijĸŀłøœßþŧŋʼn㈀",27,"⒜",25,"⑴",14,"¹²³⁴ⁿ₁₂₃₄"], +["aa41","찥찦찪찫찭찯찱",6,"찺찿",4,"챆챇챉챊챋챍챎"], +["aa61","챏",4,"챖챚",5,"챡챢챣챥챧챩",6,"챱챲"], +["aa81","챳챴챶",29,"ぁ",82], +["ab41","첔첕첖첗첚첛첝첞첟첡",6,"첪첮",5,"첶첷첹"], +["ab61","첺첻첽",6,"쳆쳈쳊",5,"쳑쳒쳓쳕",5], +["ab81","쳛",8,"쳥",6,"쳭쳮쳯쳱",12,"ァ",85], +["ac41","쳾쳿촀촂",5,"촊촋촍촎촏촑",6,"촚촜촞촟촠"], +["ac61","촡촢촣촥촦촧촩촪촫촭",11,"촺",4], +["ac81","촿",28,"쵝쵞쵟А",5,"ЁЖ",25], +["acd1","а",5,"ёж",25], +["ad41","쵡쵢쵣쵥",6,"쵮쵰쵲",5,"쵹",7], +["ad61","춁",6,"춉",10,"춖춗춙춚춛춝춞춟"], +["ad81","춠춡춢춣춦춨춪",5,"춱",18,"췅"], +["ae41","췆",5,"췍췎췏췑",16], +["ae61","췢",5,"췩췪췫췭췮췯췱",6,"췺췼췾",4], +["ae81","츃츅츆츇츉츊츋츍",6,"츕츖츗츘츚",5,"츢츣츥츦츧츩츪츫"], +["af41","츬츭츮츯츲츴츶",19], +["af61","칊",13,"칚칛칝칞칢",5,"칪칬"], +["af81","칮",5,"칶칷칹칺칻칽",6,"캆캈캊",5,"캒캓캕캖캗캙"], +["b041","캚",5,"캢캦",5,"캮",12], +["b061","캻",5,"컂",19], +["b081","컖",13,"컦컧컩컪컭",6,"컶컺",5,"가각간갇갈갉갊감",7,"같",4,"갠갤갬갭갯갰갱갸갹갼걀걋걍걔걘걜거걱건걷걸걺검겁것겄겅겆겉겊겋게겐겔겜겝겟겠겡겨격겪견겯결겸겹겻겼경곁계곈곌곕곗고곡곤곧골곪곬곯곰곱곳공곶과곽관괄괆"], +["b141","켂켃켅켆켇켉",6,"켒켔켖",5,"켝켞켟켡켢켣"], +["b161","켥",6,"켮켲",5,"켹",11], +["b181","콅",14,"콖콗콙콚콛콝",6,"콦콨콪콫콬괌괍괏광괘괜괠괩괬괭괴괵괸괼굄굅굇굉교굔굘굡굣구국군굳굴굵굶굻굼굽굿궁궂궈궉권궐궜궝궤궷귀귁귄귈귐귑귓규균귤그극근귿글긁금급긋긍긔기긱긴긷길긺김깁깃깅깆깊까깍깎깐깔깖깜깝깟깠깡깥깨깩깬깰깸"], +["b241","콭콮콯콲콳콵콶콷콹",6,"쾁쾂쾃쾄쾆",5,"쾍"], +["b261","쾎",18,"쾢",5,"쾩"], +["b281","쾪",5,"쾱",18,"쿅",6,"깹깻깼깽꺄꺅꺌꺼꺽꺾껀껄껌껍껏껐껑께껙껜껨껫껭껴껸껼꼇꼈꼍꼐꼬꼭꼰꼲꼴꼼꼽꼿꽁꽂꽃꽈꽉꽐꽜꽝꽤꽥꽹꾀꾄꾈꾐꾑꾕꾜꾸꾹꾼꿀꿇꿈꿉꿋꿍꿎꿔꿜꿨꿩꿰꿱꿴꿸뀀뀁뀄뀌뀐뀔뀜뀝뀨끄끅끈끊끌끎끓끔끕끗끙"], +["b341","쿌",19,"쿢쿣쿥쿦쿧쿩"], +["b361","쿪",5,"쿲쿴쿶",5,"쿽쿾쿿퀁퀂퀃퀅",5], +["b381","퀋",5,"퀒",5,"퀙",19,"끝끼끽낀낄낌낍낏낑나낙낚난낟날낡낢남납낫",4,"낱낳내낵낸낼냄냅냇냈냉냐냑냔냘냠냥너넉넋넌널넒넓넘넙넛넜넝넣네넥넨넬넴넵넷넸넹녀녁년녈념녑녔녕녘녜녠노녹논놀놂놈놉놋농높놓놔놘놜놨뇌뇐뇔뇜뇝"], +["b441","퀮",5,"퀶퀷퀹퀺퀻퀽",6,"큆큈큊",5], +["b461","큑큒큓큕큖큗큙",6,"큡",10,"큮큯"], +["b481","큱큲큳큵",6,"큾큿킀킂",18,"뇟뇨뇩뇬뇰뇹뇻뇽누눅눈눋눌눔눕눗눙눠눴눼뉘뉜뉠뉨뉩뉴뉵뉼늄늅늉느늑는늘늙늚늠늡늣능늦늪늬늰늴니닉닌닐닒님닙닛닝닢다닥닦단닫",4,"닳담답닷",4,"닿대댁댄댈댐댑댓댔댕댜더덕덖던덛덜덞덟덤덥"], +["b541","킕",14,"킦킧킩킪킫킭",5], +["b561","킳킶킸킺",5,"탂탃탅탆탇탊",5,"탒탖",4], +["b581","탛탞탟탡탢탣탥",6,"탮탲",5,"탹",11,"덧덩덫덮데덱덴델뎀뎁뎃뎄뎅뎌뎐뎔뎠뎡뎨뎬도독돈돋돌돎돐돔돕돗동돛돝돠돤돨돼됐되된될됨됩됫됴두둑둔둘둠둡둣둥둬뒀뒈뒝뒤뒨뒬뒵뒷뒹듀듄듈듐듕드득든듣들듦듬듭듯등듸디딕딘딛딜딤딥딧딨딩딪따딱딴딸"], +["b641","턅",7,"턎",17], +["b661","턠",15,"턲턳턵턶턷턹턻턼턽턾"], +["b681","턿텂텆",5,"텎텏텑텒텓텕",6,"텞텠텢",5,"텩텪텫텭땀땁땃땄땅땋때땍땐땔땜땝땟땠땡떠떡떤떨떪떫떰떱떳떴떵떻떼떽뗀뗄뗌뗍뗏뗐뗑뗘뗬또똑똔똘똥똬똴뙈뙤뙨뚜뚝뚠뚤뚫뚬뚱뛔뛰뛴뛸뜀뜁뜅뜨뜩뜬뜯뜰뜸뜹뜻띄띈띌띔띕띠띤띨띰띱띳띵라락란랄람랍랏랐랑랒랖랗"], +["b741","텮",13,"텽",6,"톅톆톇톉톊"], +["b761","톋",20,"톢톣톥톦톧"], +["b781","톩",6,"톲톴톶톷톸톹톻톽톾톿퇁",14,"래랙랜랠램랩랫랬랭랴략랸럇량러럭런럴럼럽럿렀렁렇레렉렌렐렘렙렛렝려력련렬렴렵렷렸령례롄롑롓로록론롤롬롭롯롱롸롼뢍뢨뢰뢴뢸룀룁룃룅료룐룔룝룟룡루룩룬룰룸룹룻룽뤄뤘뤠뤼뤽륀륄륌륏륑류륙륜률륨륩"], +["b841","퇐",7,"퇙",17], +["b861","퇫",8,"퇵퇶퇷퇹",13], +["b881","툈툊",5,"툑",24,"륫륭르륵른를름릅릇릉릊릍릎리릭린릴림립릿링마막만많",4,"맘맙맛망맞맡맣매맥맨맬맴맵맷맸맹맺먀먁먈먕머먹먼멀멂멈멉멋멍멎멓메멕멘멜멤멥멧멨멩며멱면멸몃몄명몇몌모목몫몬몰몲몸몹못몽뫄뫈뫘뫙뫼"], +["b941","툪툫툮툯툱툲툳툵",6,"툾퉀퉂",5,"퉉퉊퉋퉌"], +["b961","퉍",14,"퉝",6,"퉥퉦퉧퉨"], +["b981","퉩",22,"튂튃튅튆튇튉튊튋튌묀묄묍묏묑묘묜묠묩묫무묵묶문묻물묽묾뭄뭅뭇뭉뭍뭏뭐뭔뭘뭡뭣뭬뮈뮌뮐뮤뮨뮬뮴뮷므믄믈믐믓미믹민믿밀밂밈밉밋밌밍및밑바",4,"받",4,"밤밥밧방밭배백밴밸뱀뱁뱃뱄뱅뱉뱌뱍뱐뱝버벅번벋벌벎범법벗"], +["ba41","튍튎튏튒튓튔튖",5,"튝튞튟튡튢튣튥",6,"튭"], +["ba61","튮튯튰튲",5,"튺튻튽튾틁틃",4,"틊틌",5], +["ba81","틒틓틕틖틗틙틚틛틝",6,"틦",9,"틲틳틵틶틷틹틺벙벚베벡벤벧벨벰벱벳벴벵벼벽변별볍볏볐병볕볘볜보복볶본볼봄봅봇봉봐봔봤봬뵀뵈뵉뵌뵐뵘뵙뵤뵨부북분붇불붉붊붐붑붓붕붙붚붜붤붰붸뷔뷕뷘뷜뷩뷰뷴뷸븀븃븅브븍븐블븜븝븟비빅빈빌빎빔빕빗빙빚빛빠빡빤"], +["bb41","틻",4,"팂팄팆",5,"팏팑팒팓팕팗",4,"팞팢팣"], +["bb61","팤팦팧팪팫팭팮팯팱",6,"팺팾",5,"퍆퍇퍈퍉"], +["bb81","퍊",31,"빨빪빰빱빳빴빵빻빼빽뺀뺄뺌뺍뺏뺐뺑뺘뺙뺨뻐뻑뻔뻗뻘뻠뻣뻤뻥뻬뼁뼈뼉뼘뼙뼛뼜뼝뽀뽁뽄뽈뽐뽑뽕뾔뾰뿅뿌뿍뿐뿔뿜뿟뿡쀼쁑쁘쁜쁠쁨쁩삐삑삔삘삠삡삣삥사삭삯산삳살삵삶삼삽삿샀상샅새색샌샐샘샙샛샜생샤"], +["bc41","퍪",17,"퍾퍿펁펂펃펅펆펇"], +["bc61","펈펉펊펋펎펒",5,"펚펛펝펞펟펡",6,"펪펬펮"], +["bc81","펯",4,"펵펶펷펹펺펻펽",6,"폆폇폊",5,"폑",5,"샥샨샬샴샵샷샹섀섄섈섐섕서",4,"섣설섦섧섬섭섯섰성섶세섹센셀셈셉셋셌셍셔셕션셜셤셥셧셨셩셰셴셸솅소속솎손솔솖솜솝솟송솥솨솩솬솰솽쇄쇈쇌쇔쇗쇘쇠쇤쇨쇰쇱쇳쇼쇽숀숄숌숍숏숑수숙순숟술숨숩숫숭"], +["bd41","폗폙",7,"폢폤",7,"폮폯폱폲폳폵폶폷"], +["bd61","폸폹폺폻폾퐀퐂",5,"퐉",13], +["bd81","퐗",5,"퐞",25,"숯숱숲숴쉈쉐쉑쉔쉘쉠쉥쉬쉭쉰쉴쉼쉽쉿슁슈슉슐슘슛슝스슥슨슬슭슴습슷승시식신싣실싫심십싯싱싶싸싹싻싼쌀쌈쌉쌌쌍쌓쌔쌕쌘쌜쌤쌥쌨쌩썅써썩썬썰썲썸썹썼썽쎄쎈쎌쏀쏘쏙쏜쏟쏠쏢쏨쏩쏭쏴쏵쏸쐈쐐쐤쐬쐰"], +["be41","퐸",7,"푁푂푃푅",14], +["be61","푔",7,"푝푞푟푡푢푣푥",7,"푮푰푱푲"], +["be81","푳",4,"푺푻푽푾풁풃",4,"풊풌풎",5,"풕",8,"쐴쐼쐽쑈쑤쑥쑨쑬쑴쑵쑹쒀쒔쒜쒸쒼쓩쓰쓱쓴쓸쓺쓿씀씁씌씐씔씜씨씩씬씰씸씹씻씽아악안앉않알앍앎앓암압앗았앙앝앞애액앤앨앰앱앳앴앵야약얀얄얇얌얍얏양얕얗얘얜얠얩어억언얹얻얼얽얾엄",6,"엌엎"], +["bf41","풞",10,"풪",14], +["bf61","풹",18,"퓍퓎퓏퓑퓒퓓퓕"], +["bf81","퓖",5,"퓝퓞퓠",7,"퓩퓪퓫퓭퓮퓯퓱",6,"퓹퓺퓼에엑엔엘엠엡엣엥여역엮연열엶엷염",5,"옅옆옇예옌옐옘옙옛옜오옥온올옭옮옰옳옴옵옷옹옻와왁완왈왐왑왓왔왕왜왝왠왬왯왱외왹왼욀욈욉욋욍요욕욘욜욤욥욧용우욱운울욹욺움웁웃웅워웍원월웜웝웠웡웨"], +["c041","퓾",5,"픅픆픇픉픊픋픍",6,"픖픘",5], +["c061","픞",25], +["c081","픸픹픺픻픾픿핁핂핃핅",6,"핎핐핒",5,"핚핛핝핞핟핡핢핣웩웬웰웸웹웽위윅윈윌윔윕윗윙유육윤율윰윱윳융윷으윽은을읊음읍읏응",7,"읜읠읨읫이익인일읽읾잃임입잇있잉잊잎자작잔잖잗잘잚잠잡잣잤장잦재잭잰잴잼잽잿쟀쟁쟈쟉쟌쟎쟐쟘쟝쟤쟨쟬저적전절젊"], +["c141","핤핦핧핪핬핮",5,"핶핷핹핺핻핽",6,"햆햊햋"], +["c161","햌햍햎햏햑",19,"햦햧"], +["c181","햨",31,"점접젓정젖제젝젠젤젬젭젯젱져젼졀졈졉졌졍졔조족존졸졺좀좁좃종좆좇좋좌좍좔좝좟좡좨좼좽죄죈죌죔죕죗죙죠죡죤죵주죽준줄줅줆줌줍줏중줘줬줴쥐쥑쥔쥘쥠쥡쥣쥬쥰쥴쥼즈즉즌즐즘즙즛증지직진짇질짊짐집짓"], +["c241","헊헋헍헎헏헑헓",4,"헚헜헞",5,"헦헧헩헪헫헭헮"], +["c261","헯",4,"헶헸헺",5,"혂혃혅혆혇혉",6,"혒"], +["c281","혖",5,"혝혞혟혡혢혣혥",7,"혮",9,"혺혻징짖짙짚짜짝짠짢짤짧짬짭짯짰짱째짹짼쨀쨈쨉쨋쨌쨍쨔쨘쨩쩌쩍쩐쩔쩜쩝쩟쩠쩡쩨쩽쪄쪘쪼쪽쫀쫄쫌쫍쫏쫑쫓쫘쫙쫠쫬쫴쬈쬐쬔쬘쬠쬡쭁쭈쭉쭌쭐쭘쭙쭝쭤쭸쭹쮜쮸쯔쯤쯧쯩찌찍찐찔찜찝찡찢찧차착찬찮찰참찹찻"], +["c341","혽혾혿홁홂홃홄홆홇홊홌홎홏홐홒홓홖홗홙홚홛홝",4], +["c361","홢",4,"홨홪",5,"홲홳홵",11], +["c381","횁횂횄횆",5,"횎횏횑횒횓횕",7,"횞횠횢",5,"횩횪찼창찾채책챈챌챔챕챗챘챙챠챤챦챨챰챵처척천철첨첩첫첬청체첵첸첼쳄쳅쳇쳉쳐쳔쳤쳬쳰촁초촉촌촐촘촙촛총촤촨촬촹최쵠쵤쵬쵭쵯쵱쵸춈추축춘출춤춥춧충춰췄췌췐취췬췰췸췹췻췽츄츈츌츔츙츠측츤츨츰츱츳층"], +["c441","횫횭횮횯횱",7,"횺횼",7,"훆훇훉훊훋"], +["c461","훍훎훏훐훒훓훕훖훘훚",5,"훡훢훣훥훦훧훩",4], +["c481","훮훯훱훲훳훴훶",5,"훾훿휁휂휃휅",11,"휒휓휔치칙친칟칠칡침칩칫칭카칵칸칼캄캅캇캉캐캑캔캘캠캡캣캤캥캬캭컁커컥컨컫컬컴컵컷컸컹케켁켄켈켐켑켓켕켜켠켤켬켭켯켰켱켸코콕콘콜콤콥콧콩콰콱콴콸쾀쾅쾌쾡쾨쾰쿄쿠쿡쿤쿨쿰쿱쿳쿵쿼퀀퀄퀑퀘퀭퀴퀵퀸퀼"], +["c541","휕휖휗휚휛휝휞휟휡",6,"휪휬휮",5,"휶휷휹"], +["c561","휺휻휽",6,"흅흆흈흊",5,"흒흓흕흚",4], +["c581","흟흢흤흦흧흨흪흫흭흮흯흱흲흳흵",6,"흾흿힀힂",5,"힊힋큄큅큇큉큐큔큘큠크큭큰클큼큽킁키킥킨킬킴킵킷킹타탁탄탈탉탐탑탓탔탕태택탠탤탬탭탯탰탱탸턍터턱턴털턺텀텁텃텄텅테텍텐텔템텝텟텡텨텬텼톄톈토톡톤톨톰톱톳통톺톼퇀퇘퇴퇸툇툉툐투툭툰툴툼툽툿퉁퉈퉜"], +["c641","힍힎힏힑",6,"힚힜힞",5], +["c6a1","퉤튀튁튄튈튐튑튕튜튠튤튬튱트특튼튿틀틂틈틉틋틔틘틜틤틥티틱틴틸팀팁팃팅파팍팎판팔팖팜팝팟팠팡팥패팩팬팰팸팹팻팼팽퍄퍅퍼퍽펀펄펌펍펏펐펑페펙펜펠펨펩펫펭펴편펼폄폅폈평폐폘폡폣포폭폰폴폼폽폿퐁"], +["c7a1","퐈퐝푀푄표푠푤푭푯푸푹푼푿풀풂품풉풋풍풔풩퓌퓐퓔퓜퓟퓨퓬퓰퓸퓻퓽프픈플픔픕픗피픽핀필핌핍핏핑하학한할핥함합핫항해핵핸핼햄햅햇했행햐향허헉헌헐헒험헙헛헝헤헥헨헬헴헵헷헹혀혁현혈혐협혓혔형혜혠"], +["c8a1","혤혭호혹혼홀홅홈홉홋홍홑화확환활홧황홰홱홴횃횅회획횐횔횝횟횡효횬횰횹횻후훅훈훌훑훔훗훙훠훤훨훰훵훼훽휀휄휑휘휙휜휠휨휩휫휭휴휵휸휼흄흇흉흐흑흔흖흗흘흙흠흡흣흥흩희흰흴흼흽힁히힉힌힐힘힙힛힝"], +["caa1","伽佳假價加可呵哥嘉嫁家暇架枷柯歌珂痂稼苛茄街袈訶賈跏軻迦駕刻却各恪慤殼珏脚覺角閣侃刊墾奸姦干幹懇揀杆柬桿澗癎看磵稈竿簡肝艮艱諫間乫喝曷渴碣竭葛褐蝎鞨勘坎堪嵌感憾戡敢柑橄減甘疳監瞰紺邯鑑鑒龕"], +["cba1","匣岬甲胛鉀閘剛堈姜岡崗康强彊慷江畺疆糠絳綱羌腔舡薑襁講鋼降鱇介价個凱塏愷愾慨改槪漑疥皆盖箇芥蓋豈鎧開喀客坑更粳羹醵倨去居巨拒据據擧渠炬祛距踞車遽鉅鋸乾件健巾建愆楗腱虔蹇鍵騫乞傑杰桀儉劍劒檢"], +["cca1","瞼鈐黔劫怯迲偈憩揭擊格檄激膈覡隔堅牽犬甄絹繭肩見譴遣鵑抉決潔結缺訣兼慊箝謙鉗鎌京俓倞傾儆勁勍卿坰境庚徑慶憬擎敬景暻更梗涇炅烱璟璥瓊痙硬磬竟競絅經耕耿脛莖警輕逕鏡頃頸驚鯨係啓堺契季屆悸戒桂械"], +["cda1","棨溪界癸磎稽系繫繼計誡谿階鷄古叩告呱固姑孤尻庫拷攷故敲暠枯槁沽痼皐睾稿羔考股膏苦苽菰藁蠱袴誥賈辜錮雇顧高鼓哭斛曲梏穀谷鵠困坤崑昆梱棍滾琨袞鯤汨滑骨供公共功孔工恐恭拱控攻珙空蚣貢鞏串寡戈果瓜"], +["cea1","科菓誇課跨過鍋顆廓槨藿郭串冠官寬慣棺款灌琯瓘管罐菅觀貫關館刮恝括适侊光匡壙廣曠洸炚狂珖筐胱鑛卦掛罫乖傀塊壞怪愧拐槐魁宏紘肱轟交僑咬喬嬌嶠巧攪敎校橋狡皎矯絞翹膠蕎蛟較轎郊餃驕鮫丘久九仇俱具勾"], +["cfa1","區口句咎嘔坵垢寇嶇廐懼拘救枸柩構歐毆毬求溝灸狗玖球瞿矩究絿耉臼舅舊苟衢謳購軀逑邱鉤銶駒驅鳩鷗龜國局菊鞠鞫麴君窘群裙軍郡堀屈掘窟宮弓穹窮芎躬倦券勸卷圈拳捲權淃眷厥獗蕨蹶闕机櫃潰詭軌饋句晷歸貴"], +["d0a1","鬼龜叫圭奎揆槻珪硅窺竅糾葵規赳逵閨勻均畇筠菌鈞龜橘克剋劇戟棘極隙僅劤勤懃斤根槿瑾筋芹菫覲謹近饉契今妗擒昑檎琴禁禽芩衾衿襟金錦伋及急扱汲級給亘兢矜肯企伎其冀嗜器圻基埼夔奇妓寄岐崎己幾忌技旗旣"], +["d1a1","朞期杞棋棄機欺氣汽沂淇玘琦琪璂璣畸畿碁磯祁祇祈祺箕紀綺羈耆耭肌記譏豈起錡錤飢饑騎騏驥麒緊佶吉拮桔金喫儺喇奈娜懦懶拏拿癩",5,"那樂",4,"諾酪駱亂卵暖欄煖爛蘭難鸞捏捺南嵐枏楠湳濫男藍襤拉"], +["d2a1","納臘蠟衲囊娘廊",4,"乃來內奈柰耐冷女年撚秊念恬拈捻寧寗努勞奴弩怒擄櫓爐瑙盧",5,"駑魯",10,"濃籠聾膿農惱牢磊腦賂雷尿壘",7,"嫩訥杻紐勒",5,"能菱陵尼泥匿溺多茶"], +["d3a1","丹亶但單團壇彖斷旦檀段湍短端簞緞蛋袒鄲鍛撻澾獺疸達啖坍憺擔曇淡湛潭澹痰聃膽蕁覃談譚錟沓畓答踏遝唐堂塘幢戇撞棠當糖螳黨代垈坮大對岱帶待戴擡玳臺袋貸隊黛宅德悳倒刀到圖堵塗導屠島嶋度徒悼挑掉搗桃"], +["d4a1","棹櫂淘渡滔濤燾盜睹禱稻萄覩賭跳蹈逃途道都鍍陶韜毒瀆牘犢獨督禿篤纛讀墩惇敦旽暾沌焞燉豚頓乭突仝冬凍動同憧東桐棟洞潼疼瞳童胴董銅兜斗杜枓痘竇荳讀豆逗頭屯臀芚遁遯鈍得嶝橙燈登等藤謄鄧騰喇懶拏癩羅"], +["d5a1","蘿螺裸邏樂洛烙珞絡落諾酪駱丹亂卵欄欒瀾爛蘭鸞剌辣嵐擥攬欖濫籃纜藍襤覽拉臘蠟廊朗浪狼琅瑯螂郞來崍徠萊冷掠略亮倆兩凉梁樑粮粱糧良諒輛量侶儷勵呂廬慮戾旅櫚濾礪藜蠣閭驢驪麗黎力曆歷瀝礫轢靂憐戀攣漣"], +["d6a1","煉璉練聯蓮輦連鍊冽列劣洌烈裂廉斂殮濂簾獵令伶囹寧岺嶺怜玲笭羚翎聆逞鈴零靈領齡例澧禮醴隷勞怒撈擄櫓潞瀘爐盧老蘆虜路輅露魯鷺鹵碌祿綠菉錄鹿麓論壟弄朧瀧瓏籠聾儡瀨牢磊賂賚賴雷了僚寮廖料燎療瞭聊蓼"], +["d7a1","遼鬧龍壘婁屢樓淚漏瘻累縷蔞褸鏤陋劉旒柳榴流溜瀏琉瑠留瘤硫謬類六戮陸侖倫崙淪綸輪律慄栗率隆勒肋凜凌楞稜綾菱陵俚利厘吏唎履悧李梨浬犁狸理璃異痢籬罹羸莉裏裡里釐離鯉吝潾燐璘藺躪隣鱗麟林淋琳臨霖砬"], +["d8a1","立笠粒摩瑪痲碼磨馬魔麻寞幕漠膜莫邈万卍娩巒彎慢挽晩曼滿漫灣瞞萬蔓蠻輓饅鰻唜抹末沫茉襪靺亡妄忘忙望網罔芒茫莽輞邙埋妹媒寐昧枚梅每煤罵買賣邁魅脈貊陌驀麥孟氓猛盲盟萌冪覓免冕勉棉沔眄眠綿緬面麵滅"], +["d9a1","蔑冥名命明暝椧溟皿瞑茗蓂螟酩銘鳴袂侮冒募姆帽慕摸摹暮某模母毛牟牡瑁眸矛耗芼茅謀謨貌木沐牧目睦穆鶩歿沒夢朦蒙卯墓妙廟描昴杳渺猫竗苗錨務巫憮懋戊拇撫无楙武毋無珷畝繆舞茂蕪誣貿霧鵡墨默們刎吻問文"], +["daa1","汶紊紋聞蚊門雯勿沕物味媚尾嵋彌微未梶楣渼湄眉米美薇謎迷靡黴岷悶愍憫敏旻旼民泯玟珉緡閔密蜜謐剝博拍搏撲朴樸泊珀璞箔粕縛膊舶薄迫雹駁伴半反叛拌搬攀斑槃泮潘班畔瘢盤盼磐磻礬絆般蟠返頒飯勃拔撥渤潑"], +["dba1","發跋醱鉢髮魃倣傍坊妨尨幇彷房放方旁昉枋榜滂磅紡肪膀舫芳蒡蚌訪謗邦防龐倍俳北培徘拜排杯湃焙盃背胚裴裵褙賠輩配陪伯佰帛柏栢白百魄幡樊煩燔番磻繁蕃藩飜伐筏罰閥凡帆梵氾汎泛犯範范法琺僻劈壁擘檗璧癖"], +["dca1","碧蘗闢霹便卞弁變辨辯邊別瞥鱉鼈丙倂兵屛幷昞昺柄棅炳甁病秉竝輧餠騈保堡報寶普步洑湺潽珤甫菩補褓譜輔伏僕匐卜宓復服福腹茯蔔複覆輹輻馥鰒本乶俸奉封峯峰捧棒烽熢琫縫蓬蜂逢鋒鳳不付俯傅剖副否咐埠夫婦"], +["dda1","孚孵富府復扶敷斧浮溥父符簿缶腐腑膚艀芙莩訃負賦賻赴趺部釜阜附駙鳧北分吩噴墳奔奮忿憤扮昐汾焚盆粉糞紛芬賁雰不佛弗彿拂崩朋棚硼繃鵬丕備匕匪卑妃婢庇悲憊扉批斐枇榧比毖毗毘沸泌琵痺砒碑秕秘粃緋翡肥"], +["dea1","脾臂菲蜚裨誹譬費鄙非飛鼻嚬嬪彬斌檳殯浜濱瀕牝玭貧賓頻憑氷聘騁乍事些仕伺似使俟僿史司唆嗣四士奢娑寫寺射巳師徙思捨斜斯柶査梭死沙泗渣瀉獅砂社祀祠私篩紗絲肆舍莎蓑蛇裟詐詞謝賜赦辭邪飼駟麝削數朔索"], +["dfa1","傘刪山散汕珊産疝算蒜酸霰乷撒殺煞薩三參杉森渗芟蔘衫揷澁鈒颯上傷像償商喪嘗孀尙峠常床庠廂想桑橡湘爽牀狀相祥箱翔裳觴詳象賞霜塞璽賽嗇塞穡索色牲生甥省笙墅壻嶼序庶徐恕抒捿敍暑曙書栖棲犀瑞筮絮緖署"], +["e0a1","胥舒薯西誓逝鋤黍鼠夕奭席惜昔晳析汐淅潟石碩蓆釋錫仙僊先善嬋宣扇敾旋渲煽琁瑄璇璿癬禪線繕羨腺膳船蘚蟬詵跣選銑鐥饍鮮卨屑楔泄洩渫舌薛褻設說雪齧剡暹殲纖蟾贍閃陝攝涉燮葉城姓宬性惺成星晟猩珹盛省筬"], +["e1a1","聖聲腥誠醒世勢歲洗稅笹細說貰召嘯塑宵小少巢所掃搔昭梳沼消溯瀟炤燒甦疏疎瘙笑篠簫素紹蔬蕭蘇訴逍遡邵銷韶騷俗屬束涑粟續謖贖速孫巽損蓀遜飡率宋悚松淞訟誦送頌刷殺灑碎鎖衰釗修受嗽囚垂壽嫂守岫峀帥愁"], +["e2a1","戍手授搜收數樹殊水洙漱燧狩獸琇璲瘦睡秀穗竪粹綏綬繡羞脩茱蒐蓚藪袖誰讐輸遂邃酬銖銹隋隧隨雖需須首髓鬚叔塾夙孰宿淑潚熟琡璹肅菽巡徇循恂旬栒楯橓殉洵淳珣盾瞬筍純脣舜荀蓴蕣詢諄醇錞順馴戌術述鉥崇崧"], +["e3a1","嵩瑟膝蝨濕拾習褶襲丞乘僧勝升承昇繩蠅陞侍匙嘶始媤尸屎屍市弑恃施是時枾柴猜矢示翅蒔蓍視試詩諡豕豺埴寔式息拭植殖湜熄篒蝕識軾食飾伸侁信呻娠宸愼新晨燼申神紳腎臣莘薪藎蜃訊身辛辰迅失室實悉審尋心沁"], +["e4a1","沈深瀋甚芯諶什十拾雙氏亞俄兒啞娥峨我牙芽莪蛾衙訝阿雅餓鴉鵝堊岳嶽幄惡愕握樂渥鄂鍔顎鰐齷安岸按晏案眼雁鞍顔鮟斡謁軋閼唵岩巖庵暗癌菴闇壓押狎鴨仰央怏昻殃秧鴦厓哀埃崖愛曖涯碍艾隘靄厄扼掖液縊腋額"], +["e5a1","櫻罌鶯鸚也倻冶夜惹揶椰爺耶若野弱掠略約若葯蒻藥躍亮佯兩凉壤孃恙揚攘敭暘梁楊樣洋瀁煬痒瘍禳穰糧羊良襄諒讓釀陽量養圄御於漁瘀禦語馭魚齬億憶抑檍臆偃堰彦焉言諺孼蘖俺儼嚴奄掩淹嶪業円予余勵呂女如廬"], +["e6a1","旅歟汝濾璵礖礪與艅茹輿轝閭餘驪麗黎亦力域役易曆歷疫繹譯轢逆驛嚥堧姸娟宴年延憐戀捐挻撚椽沇沿涎涓淵演漣烟然煙煉燃燕璉硏硯秊筵緣練縯聯衍軟輦蓮連鉛鍊鳶列劣咽悅涅烈熱裂說閱厭廉念捻染殮炎焰琰艶苒"], +["e7a1","簾閻髥鹽曄獵燁葉令囹塋寧嶺嶸影怜映暎楹榮永泳渶潁濚瀛瀯煐營獰玲瑛瑩瓔盈穎纓羚聆英詠迎鈴鍈零霙靈領乂倪例刈叡曳汭濊猊睿穢芮藝蘂禮裔詣譽豫醴銳隸霓預五伍俉傲午吾吳嗚塢墺奧娛寤悟惡懊敖旿晤梧汚澳"], +["e8a1","烏熬獒筽蜈誤鰲鼇屋沃獄玉鈺溫瑥瘟穩縕蘊兀壅擁瓮甕癰翁邕雍饔渦瓦窩窪臥蛙蝸訛婉完宛梡椀浣玩琓琬碗緩翫脘腕莞豌阮頑曰往旺枉汪王倭娃歪矮外嵬巍猥畏了僚僥凹堯夭妖姚寥寮尿嶢拗搖撓擾料曜樂橈燎燿瑤療"], +["e9a1","窈窯繇繞耀腰蓼蟯要謠遙遼邀饒慾欲浴縟褥辱俑傭冗勇埇墉容庸慂榕涌湧溶熔瑢用甬聳茸蓉踊鎔鏞龍于佑偶優又友右宇寓尤愚憂旴牛玗瑀盂祐禑禹紆羽芋藕虞迂遇郵釪隅雨雩勖彧旭昱栯煜稶郁頊云暈橒殞澐熉耘芸蕓"], +["eaa1","運隕雲韻蔚鬱亐熊雄元原員圓園垣媛嫄寃怨愿援沅洹湲源爰猿瑗苑袁轅遠阮院願鴛月越鉞位偉僞危圍委威尉慰暐渭爲瑋緯胃萎葦蔿蝟衛褘謂違韋魏乳侑儒兪劉唯喩孺宥幼幽庾悠惟愈愉揄攸有杻柔柚柳楡楢油洧流游溜"], +["eba1","濡猶猷琉瑜由留癒硫紐維臾萸裕誘諛諭踰蹂遊逾遺酉釉鍮類六堉戮毓肉育陸倫允奫尹崙淪潤玧胤贇輪鈗閏律慄栗率聿戎瀜絨融隆垠恩慇殷誾銀隱乙吟淫蔭陰音飮揖泣邑凝應膺鷹依倚儀宜意懿擬椅毅疑矣義艤薏蟻衣誼"], +["eca1","議醫二以伊利吏夷姨履已弛彛怡易李梨泥爾珥理異痍痢移罹而耳肄苡荑裏裡貽貳邇里離飴餌匿溺瀷益翊翌翼謚人仁刃印吝咽因姻寅引忍湮燐璘絪茵藺蚓認隣靭靷鱗麟一佚佾壹日溢逸鎰馹任壬妊姙恁林淋稔臨荏賃入卄"], +["eda1","立笠粒仍剩孕芿仔刺咨姉姿子字孜恣慈滋炙煮玆瓷疵磁紫者自茨蔗藉諮資雌作勺嚼斫昨灼炸爵綽芍酌雀鵲孱棧殘潺盞岑暫潛箴簪蠶雜丈仗匠場墻壯奬將帳庄張掌暲杖樟檣欌漿牆狀獐璋章粧腸臟臧莊葬蔣薔藏裝贓醬長"], +["eea1","障再哉在宰才材栽梓渽滓災縡裁財載齋齎爭箏諍錚佇低儲咀姐底抵杵楮樗沮渚狙猪疽箸紵苧菹著藷詛貯躇這邸雎齟勣吊嫡寂摘敵滴狄炙的積笛籍績翟荻謫賊赤跡蹟迪迹適鏑佃佺傳全典前剪塡塼奠專展廛悛戰栓殿氈澱"], +["efa1","煎琠田甸畑癲筌箋箭篆纏詮輾轉鈿銓錢鐫電顚顫餞切截折浙癤竊節絶占岾店漸点粘霑鮎點接摺蝶丁井亭停偵呈姃定幀庭廷征情挺政整旌晶晸柾楨檉正汀淀淨渟湞瀞炡玎珽町睛碇禎程穽精綎艇訂諪貞鄭酊釘鉦鋌錠霆靖"], +["f0a1","靜頂鼎制劑啼堤帝弟悌提梯濟祭第臍薺製諸蹄醍除際霽題齊俎兆凋助嘲弔彫措操早晁曺曹朝條棗槽漕潮照燥爪璪眺祖祚租稠窕粗糟組繰肇藻蚤詔調趙躁造遭釣阻雕鳥族簇足鏃存尊卒拙猝倧宗從悰慫棕淙琮種終綜縱腫"], +["f1a1","踪踵鍾鐘佐坐左座挫罪主住侏做姝胄呪周嗾奏宙州廚晝朱柱株注洲湊澍炷珠疇籌紂紬綢舟蛛註誅走躊輳週酎酒鑄駐竹粥俊儁准埈寯峻晙樽浚準濬焌畯竣蠢逡遵雋駿茁中仲衆重卽櫛楫汁葺增憎曾拯烝甑症繒蒸證贈之只"], +["f2a1","咫地址志持指摯支旨智枝枳止池沚漬知砥祉祗紙肢脂至芝芷蜘誌識贄趾遲直稙稷織職唇嗔塵振搢晉晋桭榛殄津溱珍瑨璡畛疹盡眞瞋秦縉縝臻蔯袗診賑軫辰進鎭陣陳震侄叱姪嫉帙桎瓆疾秩窒膣蛭質跌迭斟朕什執潗緝輯"], +["f3a1","鏶集徵懲澄且侘借叉嗟嵯差次此磋箚茶蹉車遮捉搾着窄錯鑿齪撰澯燦璨瓚竄簒纂粲纘讚贊鑽餐饌刹察擦札紮僭參塹慘慙懺斬站讒讖倉倡創唱娼廠彰愴敞昌昶暢槍滄漲猖瘡窓脹艙菖蒼債埰寀寨彩採砦綵菜蔡采釵冊柵策"], +["f4a1","責凄妻悽處倜刺剔尺慽戚拓擲斥滌瘠脊蹠陟隻仟千喘天川擅泉淺玔穿舛薦賤踐遷釧闡阡韆凸哲喆徹撤澈綴輟轍鐵僉尖沾添甛瞻簽籤詹諂堞妾帖捷牒疊睫諜貼輒廳晴淸聽菁請靑鯖切剃替涕滯締諦逮遞體初剿哨憔抄招梢"], +["f5a1","椒楚樵炒焦硝礁礎秒稍肖艸苕草蕉貂超酢醋醮促囑燭矗蜀觸寸忖村邨叢塚寵悤憁摠總聰蔥銃撮催崔最墜抽推椎楸樞湫皺秋芻萩諏趨追鄒酋醜錐錘鎚雛騶鰍丑畜祝竺筑築縮蓄蹙蹴軸逐春椿瑃出朮黜充忠沖蟲衝衷悴膵萃"], +["f6a1","贅取吹嘴娶就炊翠聚脆臭趣醉驟鷲側仄厠惻測層侈値嗤峙幟恥梔治淄熾痔痴癡稚穉緇緻置致蚩輜雉馳齒則勅飭親七柒漆侵寢枕沈浸琛砧針鍼蟄秤稱快他咤唾墮妥惰打拖朶楕舵陀馱駝倬卓啄坼度托拓擢晫柝濁濯琢琸託"], +["f7a1","鐸呑嘆坦彈憚歎灘炭綻誕奪脫探眈耽貪塔搭榻宕帑湯糖蕩兌台太怠態殆汰泰笞胎苔跆邰颱宅擇澤撑攄兎吐土討慟桶洞痛筒統通堆槌腿褪退頹偸套妬投透鬪慝特闖坡婆巴把播擺杷波派爬琶破罷芭跛頗判坂板版瓣販辦鈑"], +["f8a1","阪八叭捌佩唄悖敗沛浿牌狽稗覇貝彭澎烹膨愎便偏扁片篇編翩遍鞭騙貶坪平枰萍評吠嬖幣廢弊斃肺蔽閉陛佈包匍匏咆哺圃布怖抛抱捕暴泡浦疱砲胞脯苞葡蒲袍褒逋鋪飽鮑幅暴曝瀑爆輻俵剽彪慓杓標漂瓢票表豹飇飄驃"], +["f9a1","品稟楓諷豊風馮彼披疲皮被避陂匹弼必泌珌畢疋筆苾馝乏逼下何厦夏廈昰河瑕荷蝦賀遐霞鰕壑學虐謔鶴寒恨悍旱汗漢澣瀚罕翰閑閒限韓割轄函含咸啣喊檻涵緘艦銜陷鹹合哈盒蛤閤闔陜亢伉姮嫦巷恒抗杭桁沆港缸肛航"], +["faa1","行降項亥偕咳垓奚孩害懈楷海瀣蟹解該諧邂駭骸劾核倖幸杏荇行享向嚮珦鄕響餉饗香噓墟虛許憲櫶獻軒歇險驗奕爀赫革俔峴弦懸晛泫炫玄玹現眩睍絃絢縣舷衒見賢鉉顯孑穴血頁嫌俠協夾峽挾浹狹脅脇莢鋏頰亨兄刑型"], +["fba1","形泂滎瀅灐炯熒珩瑩荊螢衡逈邢鎣馨兮彗惠慧暳蕙蹊醯鞋乎互呼壕壺好岵弧戶扈昊晧毫浩淏湖滸澔濠濩灝狐琥瑚瓠皓祜糊縞胡芦葫蒿虎號蝴護豪鎬頀顥惑或酷婚昏混渾琿魂忽惚笏哄弘汞泓洪烘紅虹訌鴻化和嬅樺火畵"], +["fca1","禍禾花華話譁貨靴廓擴攫確碻穫丸喚奐宦幻患換歡晥桓渙煥環紈還驩鰥活滑猾豁闊凰幌徨恍惶愰慌晃晄榥況湟滉潢煌璜皇篁簧荒蝗遑隍黃匯回廻徊恢悔懷晦會檜淮澮灰獪繪膾茴蛔誨賄劃獲宖橫鐄哮嚆孝效斅曉梟涍淆"], +["fda1","爻肴酵驍侯候厚后吼喉嗅帿後朽煦珝逅勛勳塤壎焄熏燻薰訓暈薨喧暄煊萱卉喙毁彙徽揮暉煇諱輝麾休携烋畦虧恤譎鷸兇凶匈洶胸黑昕欣炘痕吃屹紇訖欠欽歆吸恰洽翕興僖凞喜噫囍姬嬉希憙憘戱晞曦熙熹熺犧禧稀羲詰"] +] diff --git a/node_modules/body-parser/node_modules/iconv-lite/encodings/tables/cp950.json b/node_modules/body-parser/node_modules/iconv-lite/encodings/tables/cp950.json new file mode 100644 index 0000000..d8bc871 --- /dev/null +++ b/node_modules/body-parser/node_modules/iconv-lite/encodings/tables/cp950.json @@ -0,0 +1,177 @@ +[ +["0","\u0000",127], +["a140"," ,、。.‧;:?!︰…‥﹐﹑﹒·﹔﹕﹖﹗|–︱—︳╴︴﹏()︵︶{}︷︸〔〕︹︺【】︻︼《》︽︾〈〉︿﹀「」﹁﹂『』﹃﹄﹙﹚"], +["a1a1","﹛﹜﹝﹞‘’“”〝〞‵′#&*※§〃○●△▲◎☆★◇◆□■▽▼㊣℅¯ ̄_ˍ﹉﹊﹍﹎﹋﹌﹟﹠﹡+-×÷±√<>=≦≧≠∞≒≡﹢",4,"~∩∪⊥∠∟⊿㏒㏑∫∮∵∴♀♂⊕⊙↑↓←→↖↗↙↘∥∣/"], +["a240","\∕﹨$¥〒¢£%@℃℉﹩﹪﹫㏕㎜㎝㎞㏎㎡㎎㎏㏄°兙兛兞兝兡兣嗧瓩糎▁",7,"▏▎▍▌▋▊▉┼┴┬┤├▔─│▕┌┐└┘╭"], +["a2a1","╮╰╯═╞╪╡◢◣◥◤╱╲╳0",9,"Ⅰ",9,"〡",8,"十卄卅A",25,"a",21], +["a340","wxyzΑ",16,"Σ",6,"α",16,"σ",6,"ㄅ",10], +["a3a1","ㄐ",25,"˙ˉˊˇˋ"], +["a3e1","€"], +["a440","一乙丁七乃九了二人儿入八几刀刁力匕十卜又三下丈上丫丸凡久么也乞于亡兀刃勺千叉口土士夕大女子孑孓寸小尢尸山川工己已巳巾干廾弋弓才"], +["a4a1","丑丐不中丰丹之尹予云井互五亢仁什仃仆仇仍今介仄元允內六兮公冗凶分切刈勻勾勿化匹午升卅卞厄友及反壬天夫太夭孔少尤尺屯巴幻廿弔引心戈戶手扎支文斗斤方日曰月木欠止歹毋比毛氏水火爪父爻片牙牛犬王丙"], +["a540","世丕且丘主乍乏乎以付仔仕他仗代令仙仞充兄冉冊冬凹出凸刊加功包匆北匝仟半卉卡占卯卮去可古右召叮叩叨叼司叵叫另只史叱台句叭叻四囚外"], +["a5a1","央失奴奶孕它尼巨巧左市布平幼弁弘弗必戊打扔扒扑斥旦朮本未末札正母民氐永汁汀氾犯玄玉瓜瓦甘生用甩田由甲申疋白皮皿目矛矢石示禾穴立丞丟乒乓乩亙交亦亥仿伉伙伊伕伍伐休伏仲件任仰仳份企伋光兇兆先全"], +["a640","共再冰列刑划刎刖劣匈匡匠印危吉吏同吊吐吁吋各向名合吃后吆吒因回囝圳地在圭圬圯圩夙多夷夸妄奸妃好她如妁字存宇守宅安寺尖屹州帆并年"], +["a6a1","式弛忙忖戎戌戍成扣扛托收早旨旬旭曲曳有朽朴朱朵次此死氖汝汗汙江池汐汕污汛汍汎灰牟牝百竹米糸缶羊羽老考而耒耳聿肉肋肌臣自至臼舌舛舟艮色艾虫血行衣西阡串亨位住佇佗佞伴佛何估佐佑伽伺伸佃佔似但佣"], +["a740","作你伯低伶余佝佈佚兌克免兵冶冷別判利刪刨劫助努劬匣即卵吝吭吞吾否呎吧呆呃吳呈呂君吩告吹吻吸吮吵吶吠吼呀吱含吟听囪困囤囫坊坑址坍"], +["a7a1","均坎圾坐坏圻壯夾妝妒妨妞妣妙妖妍妤妓妊妥孝孜孚孛完宋宏尬局屁尿尾岐岑岔岌巫希序庇床廷弄弟彤形彷役忘忌志忍忱快忸忪戒我抄抗抖技扶抉扭把扼找批扳抒扯折扮投抓抑抆改攻攸旱更束李杏材村杜杖杞杉杆杠"], +["a840","杓杗步每求汞沙沁沈沉沅沛汪決沐汰沌汨沖沒汽沃汲汾汴沆汶沍沔沘沂灶灼災灸牢牡牠狄狂玖甬甫男甸皂盯矣私秀禿究系罕肖肓肝肘肛肚育良芒"], +["a8a1","芋芍見角言谷豆豕貝赤走足身車辛辰迂迆迅迄巡邑邢邪邦那酉釆里防阮阱阪阬並乖乳事些亞享京佯依侍佳使佬供例來侃佰併侈佩佻侖佾侏侑佺兔兒兕兩具其典冽函刻券刷刺到刮制剁劾劻卒協卓卑卦卷卸卹取叔受味呵"], +["a940","咖呸咕咀呻呷咄咒咆呼咐呱呶和咚呢周咋命咎固垃坷坪坩坡坦坤坼夜奉奇奈奄奔妾妻委妹妮姑姆姐姍始姓姊妯妳姒姅孟孤季宗定官宜宙宛尚屈居"], +["a9a1","屆岷岡岸岩岫岱岳帘帚帖帕帛帑幸庚店府底庖延弦弧弩往征彿彼忝忠忽念忿怏怔怯怵怖怪怕怡性怩怫怛或戕房戾所承拉拌拄抿拂抹拒招披拓拔拋拈抨抽押拐拙拇拍抵拚抱拘拖拗拆抬拎放斧於旺昔易昌昆昂明昀昏昕昊"], +["aa40","昇服朋杭枋枕東果杳杷枇枝林杯杰板枉松析杵枚枓杼杪杲欣武歧歿氓氛泣注泳沱泌泥河沽沾沼波沫法泓沸泄油況沮泗泅泱沿治泡泛泊沬泯泜泖泠"], +["aaa1","炕炎炒炊炙爬爭爸版牧物狀狎狙狗狐玩玨玟玫玥甽疝疙疚的盂盲直知矽社祀祁秉秈空穹竺糾罔羌羋者肺肥肢肱股肫肩肴肪肯臥臾舍芳芝芙芭芽芟芹花芬芥芯芸芣芰芾芷虎虱初表軋迎返近邵邸邱邶采金長門阜陀阿阻附"], +["ab40","陂隹雨青非亟亭亮信侵侯便俠俑俏保促侶俘俟俊俗侮俐俄係俚俎俞侷兗冒冑冠剎剃削前剌剋則勇勉勃勁匍南卻厚叛咬哀咨哎哉咸咦咳哇哂咽咪品"], +["aba1","哄哈咯咫咱咻咩咧咿囿垂型垠垣垢城垮垓奕契奏奎奐姜姘姿姣姨娃姥姪姚姦威姻孩宣宦室客宥封屎屏屍屋峙峒巷帝帥帟幽庠度建弈弭彥很待徊律徇後徉怒思怠急怎怨恍恰恨恢恆恃恬恫恪恤扁拜挖按拼拭持拮拽指拱拷"], +["ac40","拯括拾拴挑挂政故斫施既春昭映昧是星昨昱昤曷柿染柱柔某柬架枯柵柩柯柄柑枴柚查枸柏柞柳枰柙柢柝柒歪殃殆段毒毗氟泉洋洲洪流津洌洱洞洗"], +["aca1","活洽派洶洛泵洹洧洸洩洮洵洎洫炫為炳炬炯炭炸炮炤爰牲牯牴狩狠狡玷珊玻玲珍珀玳甚甭畏界畎畋疫疤疥疢疣癸皆皇皈盈盆盃盅省盹相眉看盾盼眇矜砂研砌砍祆祉祈祇禹禺科秒秋穿突竿竽籽紂紅紀紉紇約紆缸美羿耄"], +["ad40","耐耍耑耶胖胥胚胃胄背胡胛胎胞胤胝致舢苧范茅苣苛苦茄若茂茉苒苗英茁苜苔苑苞苓苟苯茆虐虹虻虺衍衫要觔計訂訃貞負赴赳趴軍軌述迦迢迪迥"], +["ada1","迭迫迤迨郊郎郁郃酋酊重閂限陋陌降面革韋韭音頁風飛食首香乘亳倌倍倣俯倦倥俸倩倖倆值借倚倒們俺倀倔倨俱倡個候倘俳修倭倪俾倫倉兼冤冥冢凍凌准凋剖剜剔剛剝匪卿原厝叟哨唐唁唷哼哥哲唆哺唔哩哭員唉哮哪"], +["ae40","哦唧唇哽唏圃圄埂埔埋埃堉夏套奘奚娑娘娜娟娛娓姬娠娣娩娥娌娉孫屘宰害家宴宮宵容宸射屑展屐峭峽峻峪峨峰島崁峴差席師庫庭座弱徒徑徐恙"], +["aea1","恣恥恐恕恭恩息悄悟悚悍悔悌悅悖扇拳挈拿捎挾振捕捂捆捏捉挺捐挽挪挫挨捍捌效敉料旁旅時晉晏晃晒晌晅晁書朔朕朗校核案框桓根桂桔栩梳栗桌桑栽柴桐桀格桃株桅栓栘桁殊殉殷氣氧氨氦氤泰浪涕消涇浦浸海浙涓"], +["af40","浬涉浮浚浴浩涌涊浹涅浥涔烊烘烤烙烈烏爹特狼狹狽狸狷玆班琉珮珠珪珞畔畝畜畚留疾病症疲疳疽疼疹痂疸皋皰益盍盎眩真眠眨矩砰砧砸砝破砷"], +["afa1","砥砭砠砟砲祕祐祠祟祖神祝祗祚秤秣秧租秦秩秘窄窈站笆笑粉紡紗紋紊素索純紐紕級紜納紙紛缺罟羔翅翁耆耘耕耙耗耽耿胱脂胰脅胭胴脆胸胳脈能脊胼胯臭臬舀舐航舫舨般芻茫荒荔荊茸荐草茵茴荏茲茹茶茗荀茱茨荃"], +["b040","虔蚊蚪蚓蚤蚩蚌蚣蚜衰衷袁袂衽衹記訐討訌訕訊託訓訖訏訑豈豺豹財貢起躬軒軔軏辱送逆迷退迺迴逃追逅迸邕郡郝郢酒配酌釘針釗釜釙閃院陣陡"], +["b0a1","陛陝除陘陞隻飢馬骨高鬥鬲鬼乾偺偽停假偃偌做偉健偶偎偕偵側偷偏倏偯偭兜冕凰剪副勒務勘動匐匏匙匿區匾參曼商啪啦啄啞啡啃啊唱啖問啕唯啤唸售啜唬啣唳啁啗圈國圉域堅堊堆埠埤基堂堵執培夠奢娶婁婉婦婪婀"], +["b140","娼婢婚婆婊孰寇寅寄寂宿密尉專將屠屜屝崇崆崎崛崖崢崑崩崔崙崤崧崗巢常帶帳帷康庸庶庵庾張強彗彬彩彫得徙從徘御徠徜恿患悉悠您惋悴惦悽"], +["b1a1","情悻悵惜悼惘惕惆惟悸惚惇戚戛扈掠控捲掖探接捷捧掘措捱掩掉掃掛捫推掄授掙採掬排掏掀捻捩捨捺敝敖救教敗啟敏敘敕敔斜斛斬族旋旌旎晝晚晤晨晦晞曹勗望梁梯梢梓梵桿桶梱梧梗械梃棄梭梆梅梔條梨梟梡梂欲殺"], +["b240","毫毬氫涎涼淳淙液淡淌淤添淺清淇淋涯淑涮淞淹涸混淵淅淒渚涵淚淫淘淪深淮淨淆淄涪淬涿淦烹焉焊烽烯爽牽犁猜猛猖猓猙率琅琊球理現琍瓠瓶"], +["b2a1","瓷甜產略畦畢異疏痔痕疵痊痍皎盔盒盛眷眾眼眶眸眺硫硃硎祥票祭移窒窕笠笨笛第符笙笞笮粒粗粕絆絃統紮紹紼絀細紳組累終紲紱缽羞羚翌翎習耜聊聆脯脖脣脫脩脰脤舂舵舷舶船莎莞莘荸莢莖莽莫莒莊莓莉莠荷荻荼"], +["b340","莆莧處彪蛇蛀蚶蛄蚵蛆蛋蚱蚯蛉術袞袈被袒袖袍袋覓規訪訝訣訥許設訟訛訢豉豚販責貫貨貪貧赧赦趾趺軛軟這逍通逗連速逝逐逕逞造透逢逖逛途"], +["b3a1","部郭都酗野釵釦釣釧釭釩閉陪陵陳陸陰陴陶陷陬雀雪雩章竟頂頃魚鳥鹵鹿麥麻傢傍傅備傑傀傖傘傚最凱割剴創剩勞勝勛博厥啻喀喧啼喊喝喘喂喜喪喔喇喋喃喳單喟唾喲喚喻喬喱啾喉喫喙圍堯堪場堤堰報堡堝堠壹壺奠"], +["b440","婷媚婿媒媛媧孳孱寒富寓寐尊尋就嵌嵐崴嵇巽幅帽幀幃幾廊廁廂廄弼彭復循徨惑惡悲悶惠愜愣惺愕惰惻惴慨惱愎惶愉愀愒戟扉掣掌描揀揩揉揆揍"], +["b4a1","插揣提握揖揭揮捶援揪換摒揚揹敞敦敢散斑斐斯普晰晴晶景暑智晾晷曾替期朝棺棕棠棘棗椅棟棵森棧棹棒棲棣棋棍植椒椎棉棚楮棻款欺欽殘殖殼毯氮氯氬港游湔渡渲湧湊渠渥渣減湛湘渤湖湮渭渦湯渴湍渺測湃渝渾滋"], +["b540","溉渙湎湣湄湲湩湟焙焚焦焰無然煮焜牌犄犀猶猥猴猩琺琪琳琢琥琵琶琴琯琛琦琨甥甦畫番痢痛痣痙痘痞痠登發皖皓皴盜睏短硝硬硯稍稈程稅稀窘"], +["b5a1","窗窖童竣等策筆筐筒答筍筋筏筑粟粥絞結絨絕紫絮絲絡給絢絰絳善翔翕耋聒肅腕腔腋腑腎脹腆脾腌腓腴舒舜菩萃菸萍菠菅萋菁華菱菴著萊菰萌菌菽菲菊萸萎萄菜萇菔菟虛蛟蛙蛭蛔蛛蛤蛐蛞街裁裂袱覃視註詠評詞証詁"], +["b640","詔詛詐詆訴診訶詖象貂貯貼貳貽賁費賀貴買貶貿貸越超趁跎距跋跚跑跌跛跆軻軸軼辜逮逵週逸進逶鄂郵鄉郾酣酥量鈔鈕鈣鈉鈞鈍鈐鈇鈑閔閏開閑"], +["b6a1","間閒閎隊階隋陽隅隆隍陲隄雁雅雄集雇雯雲韌項順須飧飪飯飩飲飭馮馭黃黍黑亂傭債傲傳僅傾催傷傻傯僇剿剷剽募勦勤勢勣匯嗟嗨嗓嗦嗎嗜嗇嗑嗣嗤嗯嗚嗡嗅嗆嗥嗉園圓塞塑塘塗塚塔填塌塭塊塢塒塋奧嫁嫉嫌媾媽媼"], +["b740","媳嫂媲嵩嵯幌幹廉廈弒彙徬微愚意慈感想愛惹愁愈慎慌慄慍愾愴愧愍愆愷戡戢搓搾搞搪搭搽搬搏搜搔損搶搖搗搆敬斟新暗暉暇暈暖暄暘暍會榔業"], +["b7a1","楚楷楠楔極椰概楊楨楫楞楓楹榆楝楣楛歇歲毀殿毓毽溢溯滓溶滂源溝滇滅溥溘溼溺溫滑準溜滄滔溪溧溴煎煙煩煤煉照煜煬煦煌煥煞煆煨煖爺牒猷獅猿猾瑯瑚瑕瑟瑞瑁琿瑙瑛瑜當畸瘀痰瘁痲痱痺痿痴痳盞盟睛睫睦睞督"], +["b840","睹睪睬睜睥睨睢矮碎碰碗碘碌碉硼碑碓硿祺祿禁萬禽稜稚稠稔稟稞窟窠筷節筠筮筧粱粳粵經絹綑綁綏絛置罩罪署義羨群聖聘肆肄腱腰腸腥腮腳腫"], +["b8a1","腹腺腦舅艇蒂葷落萱葵葦葫葉葬葛萼萵葡董葩葭葆虞虜號蛹蜓蜈蜇蜀蛾蛻蜂蜃蜆蜊衙裟裔裙補裘裝裡裊裕裒覜解詫該詳試詩詰誇詼詣誠話誅詭詢詮詬詹詻訾詨豢貊貉賊資賈賄貲賃賂賅跡跟跨路跳跺跪跤跦躲較載軾輊"], +["b940","辟農運遊道遂達逼違遐遇遏過遍遑逾遁鄒鄗酬酪酩釉鈷鉗鈸鈽鉀鈾鉛鉋鉤鉑鈴鉉鉍鉅鈹鈿鉚閘隘隔隕雍雋雉雊雷電雹零靖靴靶預頑頓頊頒頌飼飴"], +["b9a1","飽飾馳馱馴髡鳩麂鼎鼓鼠僧僮僥僖僭僚僕像僑僱僎僩兢凳劃劂匱厭嗾嘀嘛嘗嗽嘔嘆嘉嘍嘎嗷嘖嘟嘈嘐嗶團圖塵塾境墓墊塹墅塽壽夥夢夤奪奩嫡嫦嫩嫗嫖嫘嫣孵寞寧寡寥實寨寢寤察對屢嶄嶇幛幣幕幗幔廓廖弊彆彰徹慇"], +["ba40","愿態慷慢慣慟慚慘慵截撇摘摔撤摸摟摺摑摧搴摭摻敲斡旗旖暢暨暝榜榨榕槁榮槓構榛榷榻榫榴槐槍榭槌榦槃榣歉歌氳漳演滾漓滴漩漾漠漬漏漂漢"], +["baa1","滿滯漆漱漸漲漣漕漫漯澈漪滬漁滲滌滷熔熙煽熊熄熒爾犒犖獄獐瑤瑣瑪瑰瑭甄疑瘧瘍瘋瘉瘓盡監瞄睽睿睡磁碟碧碳碩碣禎福禍種稱窪窩竭端管箕箋筵算箝箔箏箸箇箄粹粽精綻綰綜綽綾綠緊綴網綱綺綢綿綵綸維緒緇綬"], +["bb40","罰翠翡翟聞聚肇腐膀膏膈膊腿膂臧臺與舔舞艋蓉蒿蓆蓄蒙蒞蒲蒜蓋蒸蓀蓓蒐蒼蓑蓊蜿蜜蜻蜢蜥蜴蜘蝕蜷蜩裳褂裴裹裸製裨褚裯誦誌語誣認誡誓誤"], +["bba1","說誥誨誘誑誚誧豪貍貌賓賑賒赫趙趕跼輔輒輕輓辣遠遘遜遣遙遞遢遝遛鄙鄘鄞酵酸酷酴鉸銀銅銘銖鉻銓銜銨鉼銑閡閨閩閣閥閤隙障際雌雒需靼鞅韶頗領颯颱餃餅餌餉駁骯骰髦魁魂鳴鳶鳳麼鼻齊億儀僻僵價儂儈儉儅凜"], +["bc40","劇劈劉劍劊勰厲嘮嘻嘹嘲嘿嘴嘩噓噎噗噴嘶嘯嘰墀墟增墳墜墮墩墦奭嬉嫻嬋嫵嬌嬈寮寬審寫層履嶝嶔幢幟幡廢廚廟廝廣廠彈影德徵慶慧慮慝慕憂"], +["bca1","慼慰慫慾憧憐憫憎憬憚憤憔憮戮摩摯摹撞撲撈撐撰撥撓撕撩撒撮播撫撚撬撙撢撳敵敷數暮暫暴暱樣樟槨樁樞標槽模樓樊槳樂樅槭樑歐歎殤毅毆漿潼澄潑潦潔澆潭潛潸潮澎潺潰潤澗潘滕潯潠潟熟熬熱熨牖犛獎獗瑩璋璃"], +["bd40","瑾璀畿瘠瘩瘟瘤瘦瘡瘢皚皺盤瞎瞇瞌瞑瞋磋磅確磊碾磕碼磐稿稼穀稽稷稻窯窮箭箱範箴篆篇篁箠篌糊締練緯緻緘緬緝編緣線緞緩綞緙緲緹罵罷羯"], +["bda1","翩耦膛膜膝膠膚膘蔗蔽蔚蓮蔬蔭蔓蔑蔣蔡蔔蓬蔥蓿蔆螂蝴蝶蝠蝦蝸蝨蝙蝗蝌蝓衛衝褐複褒褓褕褊誼諒談諄誕請諸課諉諂調誰論諍誶誹諛豌豎豬賠賞賦賤賬賭賢賣賜質賡赭趟趣踫踐踝踢踏踩踟踡踞躺輝輛輟輩輦輪輜輞"], +["be40","輥適遮遨遭遷鄰鄭鄧鄱醇醉醋醃鋅銻銷鋪銬鋤鋁銳銼鋒鋇鋰銲閭閱霄霆震霉靠鞍鞋鞏頡頫頜颳養餓餒餘駝駐駟駛駑駕駒駙骷髮髯鬧魅魄魷魯鴆鴉"], +["bea1","鴃麩麾黎墨齒儒儘儔儐儕冀冪凝劑劓勳噙噫噹噩噤噸噪器噥噱噯噬噢噶壁墾壇壅奮嬝嬴學寰導彊憲憑憩憊懍憶憾懊懈戰擅擁擋撻撼據擄擇擂操撿擒擔撾整曆曉暹曄曇暸樽樸樺橙橫橘樹橄橢橡橋橇樵機橈歙歷氅濂澱澡"], +["bf40","濃澤濁澧澳激澹澶澦澠澴熾燉燐燒燈燕熹燎燙燜燃燄獨璜璣璘璟璞瓢甌甍瘴瘸瘺盧盥瞠瞞瞟瞥磨磚磬磧禦積穎穆穌穋窺篙簑築篤篛篡篩篦糕糖縊"], +["bfa1","縑縈縛縣縞縝縉縐罹羲翰翱翮耨膳膩膨臻興艘艙蕊蕙蕈蕨蕩蕃蕉蕭蕪蕞螃螟螞螢融衡褪褲褥褫褡親覦諦諺諫諱謀諜諧諮諾謁謂諷諭諳諶諼豫豭貓賴蹄踱踴蹂踹踵輻輯輸輳辨辦遵遴選遲遼遺鄴醒錠錶鋸錳錯錢鋼錫錄錚"], +["c040","錐錦錡錕錮錙閻隧隨險雕霎霑霖霍霓霏靛靜靦鞘頰頸頻頷頭頹頤餐館餞餛餡餚駭駢駱骸骼髻髭鬨鮑鴕鴣鴦鴨鴒鴛默黔龍龜優償儡儲勵嚎嚀嚐嚅嚇"], +["c0a1","嚏壕壓壑壎嬰嬪嬤孺尷屨嶼嶺嶽嶸幫彌徽應懂懇懦懋戲戴擎擊擘擠擰擦擬擱擢擭斂斃曙曖檀檔檄檢檜櫛檣橾檗檐檠歜殮毚氈濘濱濟濠濛濤濫濯澀濬濡濩濕濮濰燧營燮燦燥燭燬燴燠爵牆獰獲璩環璦璨癆療癌盪瞳瞪瞰瞬"], +["c140","瞧瞭矯磷磺磴磯礁禧禪穗窿簇簍篾篷簌篠糠糜糞糢糟糙糝縮績繆縷縲繃縫總縱繅繁縴縹繈縵縿縯罄翳翼聱聲聰聯聳臆臃膺臂臀膿膽臉膾臨舉艱薪"], +["c1a1","薄蕾薜薑薔薯薛薇薨薊虧蟀蟑螳蟒蟆螫螻螺蟈蟋褻褶襄褸褽覬謎謗謙講謊謠謝謄謐豁谿豳賺賽購賸賻趨蹉蹋蹈蹊轄輾轂轅輿避遽還邁邂邀鄹醣醞醜鍍鎂錨鍵鍊鍥鍋錘鍾鍬鍛鍰鍚鍔闊闋闌闈闆隱隸雖霜霞鞠韓顆颶餵騁"], +["c240","駿鮮鮫鮪鮭鴻鴿麋黏點黜黝黛鼾齋叢嚕嚮壙壘嬸彝懣戳擴擲擾攆擺擻擷斷曜朦檳檬櫃檻檸櫂檮檯歟歸殯瀉瀋濾瀆濺瀑瀏燻燼燾燸獷獵璧璿甕癖癘"], +["c2a1","癒瞽瞿瞻瞼礎禮穡穢穠竄竅簫簧簪簞簣簡糧織繕繞繚繡繒繙罈翹翻職聶臍臏舊藏薩藍藐藉薰薺薹薦蟯蟬蟲蟠覆覲觴謨謹謬謫豐贅蹙蹣蹦蹤蹟蹕軀轉轍邇邃邈醫醬釐鎔鎊鎖鎢鎳鎮鎬鎰鎘鎚鎗闔闖闐闕離雜雙雛雞霤鞣鞦"], +["c340","鞭韹額顏題顎顓颺餾餿餽餮馥騎髁鬃鬆魏魎魍鯊鯉鯽鯈鯀鵑鵝鵠黠鼕鼬儳嚥壞壟壢寵龐廬懲懷懶懵攀攏曠曝櫥櫝櫚櫓瀛瀟瀨瀚瀝瀕瀘爆爍牘犢獸"], +["c3a1","獺璽瓊瓣疇疆癟癡矇礙禱穫穩簾簿簸簽簷籀繫繭繹繩繪羅繳羶羹羸臘藩藝藪藕藤藥藷蟻蠅蠍蟹蟾襠襟襖襞譁譜識證譚譎譏譆譙贈贊蹼蹲躇蹶蹬蹺蹴轔轎辭邊邋醱醮鏡鏑鏟鏃鏈鏜鏝鏖鏢鏍鏘鏤鏗鏨關隴難霪霧靡韜韻類"], +["c440","願顛颼饅饉騖騙鬍鯨鯧鯖鯛鶉鵡鵲鵪鵬麒麗麓麴勸嚨嚷嚶嚴嚼壤孀孃孽寶巉懸懺攘攔攙曦朧櫬瀾瀰瀲爐獻瓏癢癥礦礪礬礫竇競籌籃籍糯糰辮繽繼"], +["c4a1","纂罌耀臚艦藻藹蘑藺蘆蘋蘇蘊蠔蠕襤覺觸議譬警譯譟譫贏贍躉躁躅躂醴釋鐘鐃鏽闡霰飄饒饑馨騫騰騷騵鰓鰍鹹麵黨鼯齟齣齡儷儸囁囀囂夔屬巍懼懾攝攜斕曩櫻欄櫺殲灌爛犧瓖瓔癩矓籐纏續羼蘗蘭蘚蠣蠢蠡蠟襪襬覽譴"], +["c540","護譽贓躊躍躋轟辯醺鐮鐳鐵鐺鐸鐲鐫闢霸霹露響顧顥饗驅驃驀騾髏魔魑鰭鰥鶯鶴鷂鶸麝黯鼙齜齦齧儼儻囈囊囉孿巔巒彎懿攤權歡灑灘玀瓤疊癮癬"], +["c5a1","禳籠籟聾聽臟襲襯觼讀贖贗躑躓轡酈鑄鑑鑒霽霾韃韁顫饕驕驍髒鬚鱉鰱鰾鰻鷓鷗鼴齬齪龔囌巖戀攣攫攪曬欐瓚竊籤籣籥纓纖纔臢蘸蘿蠱變邐邏鑣鑠鑤靨顯饜驚驛驗髓體髑鱔鱗鱖鷥麟黴囑壩攬灞癱癲矗罐羈蠶蠹衢讓讒"], +["c640","讖艷贛釀鑪靂靈靄韆顰驟鬢魘鱟鷹鷺鹼鹽鼇齷齲廳欖灣籬籮蠻觀躡釁鑲鑰顱饞髖鬣黌灤矚讚鑷韉驢驥纜讜躪釅鑽鑾鑼鱷鱸黷豔鑿鸚爨驪鬱鸛鸞籲"], +["c940","乂乜凵匚厂万丌乇亍囗兀屮彳丏冇与丮亓仂仉仈冘勼卬厹圠夃夬尐巿旡殳毌气爿丱丼仨仜仩仡仝仚刌匜卌圢圣夗夯宁宄尒尻屴屳帄庀庂忉戉扐氕"], +["c9a1","氶汃氿氻犮犰玊禸肊阞伎优伬仵伔仱伀价伈伝伂伅伢伓伄仴伒冱刓刉刐劦匢匟卍厊吇囡囟圮圪圴夼妀奼妅奻奾奷奿孖尕尥屼屺屻屾巟幵庄异弚彴忕忔忏扜扞扤扡扦扢扙扠扚扥旯旮朾朹朸朻机朿朼朳氘汆汒汜汏汊汔汋"], +["ca40","汌灱牞犴犵玎甪癿穵网艸艼芀艽艿虍襾邙邗邘邛邔阢阤阠阣佖伻佢佉体佤伾佧佒佟佁佘伭伳伿佡冏冹刜刞刡劭劮匉卣卲厎厏吰吷吪呔呅吙吜吥吘"], +["caa1","吽呏呁吨吤呇囮囧囥坁坅坌坉坋坒夆奀妦妘妠妗妎妢妐妏妧妡宎宒尨尪岍岏岈岋岉岒岊岆岓岕巠帊帎庋庉庌庈庍弅弝彸彶忒忑忐忭忨忮忳忡忤忣忺忯忷忻怀忴戺抃抌抎抏抔抇扱扻扺扰抁抈扷扽扲扴攷旰旴旳旲旵杅杇"], +["cb40","杙杕杌杈杝杍杚杋毐氙氚汸汧汫沄沋沏汱汯汩沚汭沇沕沜汦汳汥汻沎灴灺牣犿犽狃狆狁犺狅玕玗玓玔玒町甹疔疕皁礽耴肕肙肐肒肜芐芏芅芎芑芓"], +["cba1","芊芃芄豸迉辿邟邡邥邞邧邠阰阨阯阭丳侘佼侅佽侀侇佶佴侉侄佷佌侗佪侚佹侁佸侐侜侔侞侒侂侕佫佮冞冼冾刵刲刳剆刱劼匊匋匼厒厔咇呿咁咑咂咈呫呺呾呥呬呴呦咍呯呡呠咘呣呧呤囷囹坯坲坭坫坱坰坶垀坵坻坳坴坢"], +["cc40","坨坽夌奅妵妺姏姎妲姌姁妶妼姃姖妱妽姀姈妴姇孢孥宓宕屄屇岮岤岠岵岯岨岬岟岣岭岢岪岧岝岥岶岰岦帗帔帙弨弢弣弤彔徂彾彽忞忥怭怦怙怲怋"], +["cca1","怴怊怗怳怚怞怬怢怍怐怮怓怑怌怉怜戔戽抭抴拑抾抪抶拊抮抳抯抻抩抰抸攽斨斻昉旼昄昒昈旻昃昋昍昅旽昑昐曶朊枅杬枎枒杶杻枘枆构杴枍枌杺枟枑枙枃杽极杸杹枔欥殀歾毞氝沓泬泫泮泙沶泔沭泧沷泐泂沺泃泆泭泲"], +["cd40","泒泝沴沊沝沀泞泀洰泍泇沰泹泏泩泑炔炘炅炓炆炄炑炖炂炚炃牪狖狋狘狉狜狒狔狚狌狑玤玡玭玦玢玠玬玝瓝瓨甿畀甾疌疘皯盳盱盰盵矸矼矹矻矺"], +["cda1","矷祂礿秅穸穻竻籵糽耵肏肮肣肸肵肭舠芠苀芫芚芘芛芵芧芮芼芞芺芴芨芡芩苂芤苃芶芢虰虯虭虮豖迒迋迓迍迖迕迗邲邴邯邳邰阹阽阼阺陃俍俅俓侲俉俋俁俔俜俙侻侳俛俇俖侺俀侹俬剄剉勀勂匽卼厗厖厙厘咺咡咭咥哏"], +["ce40","哃茍咷咮哖咶哅哆咠呰咼咢咾呲哞咰垵垞垟垤垌垗垝垛垔垘垏垙垥垚垕壴复奓姡姞姮娀姱姝姺姽姼姶姤姲姷姛姩姳姵姠姾姴姭宨屌峐峘峌峗峋峛"], +["cea1","峞峚峉峇峊峖峓峔峏峈峆峎峟峸巹帡帢帣帠帤庰庤庢庛庣庥弇弮彖徆怷怹恔恲恞恅恓恇恉恛恌恀恂恟怤恄恘恦恮扂扃拏挍挋拵挎挃拫拹挏挌拸拶挀挓挔拺挕拻拰敁敃斪斿昶昡昲昵昜昦昢昳昫昺昝昴昹昮朏朐柁柲柈枺"], +["cf40","柜枻柸柘柀枷柅柫柤柟枵柍枳柷柶柮柣柂枹柎柧柰枲柼柆柭柌枮柦柛柺柉柊柃柪柋欨殂殄殶毖毘毠氠氡洨洴洭洟洼洿洒洊泚洳洄洙洺洚洑洀洝浂"], +["cfa1","洁洘洷洃洏浀洇洠洬洈洢洉洐炷炟炾炱炰炡炴炵炩牁牉牊牬牰牳牮狊狤狨狫狟狪狦狣玅珌珂珈珅玹玶玵玴珫玿珇玾珃珆玸珋瓬瓮甮畇畈疧疪癹盄眈眃眄眅眊盷盻盺矧矨砆砑砒砅砐砏砎砉砃砓祊祌祋祅祄秕种秏秖秎窀"], +["d040","穾竑笀笁籺籸籹籿粀粁紃紈紁罘羑羍羾耇耎耏耔耷胘胇胠胑胈胂胐胅胣胙胜胊胕胉胏胗胦胍臿舡芔苙苾苹茇苨茀苕茺苫苖苴苬苡苲苵茌苻苶苰苪"], +["d0a1","苤苠苺苳苭虷虴虼虳衁衎衧衪衩觓訄訇赲迣迡迮迠郱邽邿郕郅邾郇郋郈釔釓陔陏陑陓陊陎倞倅倇倓倢倰倛俵俴倳倷倬俶俷倗倜倠倧倵倯倱倎党冔冓凊凄凅凈凎剡剚剒剞剟剕剢勍匎厞唦哢唗唒哧哳哤唚哿唄唈哫唑唅哱"], +["d140","唊哻哷哸哠唎唃唋圁圂埌堲埕埒垺埆垽垼垸垶垿埇埐垹埁夎奊娙娖娭娮娕娏娗娊娞娳孬宧宭宬尃屖屔峬峿峮峱峷崀峹帩帨庨庮庪庬弳弰彧恝恚恧"], +["d1a1","恁悢悈悀悒悁悝悃悕悛悗悇悜悎戙扆拲挐捖挬捄捅挶捃揤挹捋捊挼挩捁挴捘捔捙挭捇挳捚捑挸捗捀捈敊敆旆旃旄旂晊晟晇晑朒朓栟栚桉栲栳栻桋桏栖栱栜栵栫栭栯桎桄栴栝栒栔栦栨栮桍栺栥栠欬欯欭欱欴歭肂殈毦毤"], +["d240","毨毣毢毧氥浺浣浤浶洍浡涒浘浢浭浯涑涍淯浿涆浞浧浠涗浰浼浟涂涘洯浨涋浾涀涄洖涃浻浽浵涐烜烓烑烝烋缹烢烗烒烞烠烔烍烅烆烇烚烎烡牂牸"], +["d2a1","牷牶猀狺狴狾狶狳狻猁珓珙珥珖玼珧珣珩珜珒珛珔珝珚珗珘珨瓞瓟瓴瓵甡畛畟疰痁疻痄痀疿疶疺皊盉眝眛眐眓眒眣眑眕眙眚眢眧砣砬砢砵砯砨砮砫砡砩砳砪砱祔祛祏祜祓祒祑秫秬秠秮秭秪秜秞秝窆窉窅窋窌窊窇竘笐"], +["d340","笄笓笅笏笈笊笎笉笒粄粑粊粌粈粍粅紞紝紑紎紘紖紓紟紒紏紌罜罡罞罠罝罛羖羒翃翂翀耖耾耹胺胲胹胵脁胻脀舁舯舥茳茭荄茙荑茥荖茿荁茦茜茢"], +["d3a1","荂荎茛茪茈茼荍茖茤茠茷茯茩荇荅荌荓茞茬荋茧荈虓虒蚢蚨蚖蚍蚑蚞蚇蚗蚆蚋蚚蚅蚥蚙蚡蚧蚕蚘蚎蚝蚐蚔衃衄衭衵衶衲袀衱衿衯袃衾衴衼訒豇豗豻貤貣赶赸趵趷趶軑軓迾迵适迿迻逄迼迶郖郠郙郚郣郟郥郘郛郗郜郤酐"], +["d440","酎酏釕釢釚陜陟隼飣髟鬯乿偰偪偡偞偠偓偋偝偲偈偍偁偛偊偢倕偅偟偩偫偣偤偆偀偮偳偗偑凐剫剭剬剮勖勓匭厜啵啶唼啍啐唴唪啑啢唶唵唰啒啅"], +["d4a1","唌唲啥啎唹啈唭唻啀啋圊圇埻堔埢埶埜埴堀埭埽堈埸堋埳埏堇埮埣埲埥埬埡堎埼堐埧堁堌埱埩埰堍堄奜婠婘婕婧婞娸娵婭婐婟婥婬婓婤婗婃婝婒婄婛婈媎娾婍娹婌婰婩婇婑婖婂婜孲孮寁寀屙崞崋崝崚崠崌崨崍崦崥崏"], +["d540","崰崒崣崟崮帾帴庱庴庹庲庳弶弸徛徖徟悊悐悆悾悰悺惓惔惏惤惙惝惈悱惛悷惊悿惃惍惀挲捥掊掂捽掽掞掭掝掗掫掎捯掇掐据掯捵掜捭掮捼掤挻掟"], +["d5a1","捸掅掁掑掍捰敓旍晥晡晛晙晜晢朘桹梇梐梜桭桮梮梫楖桯梣梬梩桵桴梲梏桷梒桼桫桲梪梀桱桾梛梖梋梠梉梤桸桻梑梌梊桽欶欳欷欸殑殏殍殎殌氪淀涫涴涳湴涬淩淢涷淶淔渀淈淠淟淖涾淥淜淝淛淴淊涽淭淰涺淕淂淏淉"], +["d640","淐淲淓淽淗淍淣涻烺焍烷焗烴焌烰焄烳焐烼烿焆焓焀烸烶焋焂焎牾牻牼牿猝猗猇猑猘猊猈狿猏猞玈珶珸珵琄琁珽琇琀珺珼珿琌琋珴琈畤畣痎痒痏"], +["d6a1","痋痌痑痐皏皉盓眹眯眭眱眲眴眳眽眥眻眵硈硒硉硍硊硌砦硅硐祤祧祩祪祣祫祡离秺秸秶秷窏窔窐笵筇笴笥笰笢笤笳笘笪笝笱笫笭笯笲笸笚笣粔粘粖粣紵紽紸紶紺絅紬紩絁絇紾紿絊紻紨罣羕羜羝羛翊翋翍翐翑翇翏翉耟"], +["d740","耞耛聇聃聈脘脥脙脛脭脟脬脞脡脕脧脝脢舑舸舳舺舴舲艴莐莣莨莍荺荳莤荴莏莁莕莙荵莔莩荽莃莌莝莛莪莋荾莥莯莈莗莰荿莦莇莮荶莚虙虖蚿蚷"], +["d7a1","蛂蛁蛅蚺蚰蛈蚹蚳蚸蛌蚴蚻蚼蛃蚽蚾衒袉袕袨袢袪袚袑袡袟袘袧袙袛袗袤袬袌袓袎覂觖觙觕訰訧訬訞谹谻豜豝豽貥赽赻赹趼跂趹趿跁軘軞軝軜軗軠軡逤逋逑逜逌逡郯郪郰郴郲郳郔郫郬郩酖酘酚酓酕釬釴釱釳釸釤釹釪"], +["d840","釫釷釨釮镺閆閈陼陭陫陱陯隿靪頄飥馗傛傕傔傞傋傣傃傌傎傝偨傜傒傂傇兟凔匒匑厤厧喑喨喥喭啷噅喢喓喈喏喵喁喣喒喤啽喌喦啿喕喡喎圌堩堷"], +["d8a1","堙堞堧堣堨埵塈堥堜堛堳堿堶堮堹堸堭堬堻奡媯媔媟婺媢媞婸媦婼媥媬媕媮娷媄媊媗媃媋媩婻婽媌媜媏媓媝寪寍寋寔寑寊寎尌尰崷嵃嵫嵁嵋崿崵嵑嵎嵕崳崺嵒崽崱嵙嵂崹嵉崸崼崲崶嵀嵅幄幁彘徦徥徫惉悹惌惢惎惄愔"], +["d940","惲愊愖愅惵愓惸惼惾惁愃愘愝愐惿愄愋扊掔掱掰揎揥揨揯揃撝揳揊揠揶揕揲揵摡揟掾揝揜揄揘揓揂揇揌揋揈揰揗揙攲敧敪敤敜敨敥斌斝斞斮旐旒"], +["d9a1","晼晬晻暀晱晹晪晲朁椌棓椄棜椪棬棪棱椏棖棷棫棤棶椓椐棳棡椇棌椈楰梴椑棯棆椔棸棐棽棼棨椋椊椗棎棈棝棞棦棴棑椆棔棩椕椥棇欹欻欿欼殔殗殙殕殽毰毲毳氰淼湆湇渟湉溈渼渽湅湢渫渿湁湝湳渜渳湋湀湑渻渃渮湞"], +["da40","湨湜湡渱渨湠湱湫渹渢渰湓湥渧湸湤湷湕湹湒湦渵渶湚焠焞焯烻焮焱焣焥焢焲焟焨焺焛牋牚犈犉犆犅犋猒猋猰猢猱猳猧猲猭猦猣猵猌琮琬琰琫琖"], +["daa1","琚琡琭琱琤琣琝琩琠琲瓻甯畯畬痧痚痡痦痝痟痤痗皕皒盚睆睇睄睍睅睊睎睋睌矞矬硠硤硥硜硭硱硪确硰硩硨硞硢祴祳祲祰稂稊稃稌稄窙竦竤筊笻筄筈筌筎筀筘筅粢粞粨粡絘絯絣絓絖絧絪絏絭絜絫絒絔絩絑絟絎缾缿罥"], +["db40","罦羢羠羡翗聑聏聐胾胔腃腊腒腏腇脽腍脺臦臮臷臸臹舄舼舽舿艵茻菏菹萣菀菨萒菧菤菼菶萐菆菈菫菣莿萁菝菥菘菿菡菋菎菖菵菉萉萏菞萑萆菂菳"], +["dba1","菕菺菇菑菪萓菃菬菮菄菻菗菢萛菛菾蛘蛢蛦蛓蛣蛚蛪蛝蛫蛜蛬蛩蛗蛨蛑衈衖衕袺裗袹袸裀袾袶袼袷袽袲褁裉覕覘覗觝觚觛詎詍訹詙詀詗詘詄詅詒詈詑詊詌詏豟貁貀貺貾貰貹貵趄趀趉跘跓跍跇跖跜跏跕跙跈跗跅軯軷軺"], +["dc40","軹軦軮軥軵軧軨軶軫軱軬軴軩逭逴逯鄆鄬鄄郿郼鄈郹郻鄁鄀鄇鄅鄃酡酤酟酢酠鈁鈊鈥鈃鈚鈦鈏鈌鈀鈒釿釽鈆鈄鈧鈂鈜鈤鈙鈗鈅鈖镻閍閌閐隇陾隈"], +["dca1","隉隃隀雂雈雃雱雰靬靰靮頇颩飫鳦黹亃亄亶傽傿僆傮僄僊傴僈僂傰僁傺傱僋僉傶傸凗剺剸剻剼嗃嗛嗌嗐嗋嗊嗝嗀嗔嗄嗩喿嗒喍嗏嗕嗢嗖嗈嗲嗍嗙嗂圔塓塨塤塏塍塉塯塕塎塝塙塥塛堽塣塱壼嫇嫄嫋媺媸媱媵媰媿嫈媻嫆"], +["dd40","媷嫀嫊媴媶嫍媹媐寖寘寙尟尳嵱嵣嵊嵥嵲嵬嵞嵨嵧嵢巰幏幎幊幍幋廅廌廆廋廇彀徯徭惷慉慊愫慅愶愲愮慆愯慏愩慀戠酨戣戥戤揅揱揫搐搒搉搠搤"], +["dda1","搳摃搟搕搘搹搷搢搣搌搦搰搨摁搵搯搊搚摀搥搧搋揧搛搮搡搎敯斒旓暆暌暕暐暋暊暙暔晸朠楦楟椸楎楢楱椿楅楪椹楂楗楙楺楈楉椵楬椳椽楥棰楸椴楩楀楯楄楶楘楁楴楌椻楋椷楜楏楑椲楒椯楻椼歆歅歃歂歈歁殛嗀毻毼"], +["de40","毹毷毸溛滖滈溏滀溟溓溔溠溱溹滆滒溽滁溞滉溷溰滍溦滏溲溾滃滜滘溙溒溎溍溤溡溿溳滐滊溗溮溣煇煔煒煣煠煁煝煢煲煸煪煡煂煘煃煋煰煟煐煓"], +["dea1","煄煍煚牏犍犌犑犐犎猼獂猻猺獀獊獉瑄瑊瑋瑒瑑瑗瑀瑏瑐瑎瑂瑆瑍瑔瓡瓿瓾瓽甝畹畷榃痯瘏瘃痷痾痼痹痸瘐痻痶痭痵痽皙皵盝睕睟睠睒睖睚睩睧睔睙睭矠碇碚碔碏碄碕碅碆碡碃硹碙碀碖硻祼禂祽祹稑稘稙稒稗稕稢稓"], +["df40","稛稐窣窢窞竫筦筤筭筴筩筲筥筳筱筰筡筸筶筣粲粴粯綈綆綀綍絿綅絺綎絻綃絼綌綔綄絽綒罭罫罧罨罬羦羥羧翛翜耡腤腠腷腜腩腛腢腲朡腞腶腧腯"], +["dfa1","腄腡舝艉艄艀艂艅蓱萿葖葶葹蒏蒍葥葑葀蒆葧萰葍葽葚葙葴葳葝蔇葞萷萺萴葺葃葸萲葅萩菙葋萯葂萭葟葰萹葎葌葒葯蓅蒎萻葇萶萳葨葾葄萫葠葔葮葐蜋蜄蛷蜌蛺蛖蛵蝍蛸蜎蜉蜁蛶蜍蜅裖裋裍裎裞裛裚裌裐覅覛觟觥觤"], +["e040","觡觠觢觜触詶誆詿詡訿詷誂誄詵誃誁詴詺谼豋豊豥豤豦貆貄貅賌赨赩趑趌趎趏趍趓趔趐趒跰跠跬跱跮跐跩跣跢跧跲跫跴輆軿輁輀輅輇輈輂輋遒逿"], +["e0a1","遄遉逽鄐鄍鄏鄑鄖鄔鄋鄎酮酯鉈鉒鈰鈺鉦鈳鉥鉞銃鈮鉊鉆鉭鉬鉏鉠鉧鉯鈶鉡鉰鈱鉔鉣鉐鉲鉎鉓鉌鉖鈲閟閜閞閛隒隓隑隗雎雺雽雸雵靳靷靸靲頏頍頎颬飶飹馯馲馰馵骭骫魛鳪鳭鳧麀黽僦僔僗僨僳僛僪僝僤僓僬僰僯僣僠"], +["e140","凘劀劁勩勫匰厬嘧嘕嘌嘒嗼嘏嘜嘁嘓嘂嗺嘝嘄嗿嗹墉塼墐墘墆墁塿塴墋塺墇墑墎塶墂墈塻墔墏壾奫嫜嫮嫥嫕嫪嫚嫭嫫嫳嫢嫠嫛嫬嫞嫝嫙嫨嫟孷寠"], +["e1a1","寣屣嶂嶀嵽嶆嵺嶁嵷嶊嶉嶈嵾嵼嶍嵹嵿幘幙幓廘廑廗廎廜廕廙廒廔彄彃彯徶愬愨慁慞慱慳慒慓慲慬憀慴慔慺慛慥愻慪慡慖戩戧戫搫摍摛摝摴摶摲摳摽摵摦撦摎撂摞摜摋摓摠摐摿搿摬摫摙摥摷敳斠暡暠暟朅朄朢榱榶槉"], +["e240","榠槎榖榰榬榼榑榙榎榧榍榩榾榯榿槄榽榤槔榹槊榚槏榳榓榪榡榞槙榗榐槂榵榥槆歊歍歋殞殟殠毃毄毾滎滵滱漃漥滸漷滻漮漉潎漙漚漧漘漻漒滭漊"], +["e2a1","漶潳滹滮漭潀漰漼漵滫漇漎潃漅滽滶漹漜滼漺漟漍漞漈漡熇熐熉熀熅熂熏煻熆熁熗牄牓犗犕犓獃獍獑獌瑢瑳瑱瑵瑲瑧瑮甀甂甃畽疐瘖瘈瘌瘕瘑瘊瘔皸瞁睼瞅瞂睮瞀睯睾瞃碲碪碴碭碨硾碫碞碥碠碬碢碤禘禊禋禖禕禔禓"], +["e340","禗禈禒禐稫穊稰稯稨稦窨窫窬竮箈箜箊箑箐箖箍箌箛箎箅箘劄箙箤箂粻粿粼粺綧綷緂綣綪緁緀緅綝緎緄緆緋緌綯綹綖綼綟綦綮綩綡緉罳翢翣翥翞"], +["e3a1","耤聝聜膉膆膃膇膍膌膋舕蒗蒤蒡蒟蒺蓎蓂蒬蒮蒫蒹蒴蓁蓍蒪蒚蒱蓐蒝蒧蒻蒢蒔蓇蓌蒛蒩蒯蒨蓖蒘蒶蓏蒠蓗蓔蓒蓛蒰蒑虡蜳蜣蜨蝫蝀蜮蜞蜡蜙蜛蝃蜬蝁蜾蝆蜠蜲蜪蜭蜼蜒蜺蜱蜵蝂蜦蜧蜸蜤蜚蜰蜑裷裧裱裲裺裾裮裼裶裻"], +["e440","裰裬裫覝覡覟覞觩觫觨誫誙誋誒誏誖谽豨豩賕賏賗趖踉踂跿踍跽踊踃踇踆踅跾踀踄輐輑輎輍鄣鄜鄠鄢鄟鄝鄚鄤鄡鄛酺酲酹酳銥銤鉶銛鉺銠銔銪銍"], +["e4a1","銦銚銫鉹銗鉿銣鋮銎銂銕銢鉽銈銡銊銆銌銙銧鉾銇銩銝銋鈭隞隡雿靘靽靺靾鞃鞀鞂靻鞄鞁靿韎韍頖颭颮餂餀餇馝馜駃馹馻馺駂馽駇骱髣髧鬾鬿魠魡魟鳱鳲鳵麧僿儃儰僸儆儇僶僾儋儌僽儊劋劌勱勯噈噂噌嘵噁噊噉噆噘"], +["e540","噚噀嘳嘽嘬嘾嘸嘪嘺圚墫墝墱墠墣墯墬墥墡壿嫿嫴嫽嫷嫶嬃嫸嬂嫹嬁嬇嬅嬏屧嶙嶗嶟嶒嶢嶓嶕嶠嶜嶡嶚嶞幩幝幠幜緳廛廞廡彉徲憋憃慹憱憰憢憉"], +["e5a1","憛憓憯憭憟憒憪憡憍慦憳戭摮摰撖撠撅撗撜撏撋撊撌撣撟摨撱撘敶敺敹敻斲斳暵暰暩暲暷暪暯樀樆樗槥槸樕槱槤樠槿槬槢樛樝槾樧槲槮樔槷槧橀樈槦槻樍槼槫樉樄樘樥樏槶樦樇槴樖歑殥殣殢殦氁氀毿氂潁漦潾澇濆澒"], +["e640","澍澉澌潢潏澅潚澖潶潬澂潕潲潒潐潗澔澓潝漀潡潫潽潧澐潓澋潩潿澕潣潷潪潻熲熯熛熰熠熚熩熵熝熥熞熤熡熪熜熧熳犘犚獘獒獞獟獠獝獛獡獚獙"], +["e6a1","獢璇璉璊璆璁瑽璅璈瑼瑹甈甇畾瘥瘞瘙瘝瘜瘣瘚瘨瘛皜皝皞皛瞍瞏瞉瞈磍碻磏磌磑磎磔磈磃磄磉禚禡禠禜禢禛歶稹窲窴窳箷篋箾箬篎箯箹篊箵糅糈糌糋緷緛緪緧緗緡縃緺緦緶緱緰緮緟罶羬羰羭翭翫翪翬翦翨聤聧膣膟"], +["e740","膞膕膢膙膗舖艏艓艒艐艎艑蔤蔻蔏蔀蔩蔎蔉蔍蔟蔊蔧蔜蓻蔫蓺蔈蔌蓴蔪蓲蔕蓷蓫蓳蓼蔒蓪蓩蔖蓾蔨蔝蔮蔂蓽蔞蓶蔱蔦蓧蓨蓰蓯蓹蔘蔠蔰蔋蔙蔯虢"], +["e7a1","蝖蝣蝤蝷蟡蝳蝘蝔蝛蝒蝡蝚蝑蝞蝭蝪蝐蝎蝟蝝蝯蝬蝺蝮蝜蝥蝏蝻蝵蝢蝧蝩衚褅褌褔褋褗褘褙褆褖褑褎褉覢覤覣觭觰觬諏諆誸諓諑諔諕誻諗誾諀諅諘諃誺誽諙谾豍貏賥賟賙賨賚賝賧趠趜趡趛踠踣踥踤踮踕踛踖踑踙踦踧"], +["e840","踔踒踘踓踜踗踚輬輤輘輚輠輣輖輗遳遰遯遧遫鄯鄫鄩鄪鄲鄦鄮醅醆醊醁醂醄醀鋐鋃鋄鋀鋙銶鋏鋱鋟鋘鋩鋗鋝鋌鋯鋂鋨鋊鋈鋎鋦鋍鋕鋉鋠鋞鋧鋑鋓"], +["e8a1","銵鋡鋆銴镼閬閫閮閰隤隢雓霅霈霂靚鞊鞎鞈韐韏頞頝頦頩頨頠頛頧颲餈飺餑餔餖餗餕駜駍駏駓駔駎駉駖駘駋駗駌骳髬髫髳髲髱魆魃魧魴魱魦魶魵魰魨魤魬鳼鳺鳽鳿鳷鴇鴀鳹鳻鴈鴅鴄麃黓鼏鼐儜儓儗儚儑凞匴叡噰噠噮"], +["e940","噳噦噣噭噲噞噷圜圛壈墽壉墿墺壂墼壆嬗嬙嬛嬡嬔嬓嬐嬖嬨嬚嬠嬞寯嶬嶱嶩嶧嶵嶰嶮嶪嶨嶲嶭嶯嶴幧幨幦幯廩廧廦廨廥彋徼憝憨憖懅憴懆懁懌憺"], +["e9a1","憿憸憌擗擖擐擏擉撽撉擃擛擳擙攳敿敼斢曈暾曀曊曋曏暽暻暺曌朣樴橦橉橧樲橨樾橝橭橶橛橑樨橚樻樿橁橪橤橐橏橔橯橩橠樼橞橖橕橍橎橆歕歔歖殧殪殫毈毇氄氃氆澭濋澣濇澼濎濈潞濄澽澞濊澨瀄澥澮澺澬澪濏澿澸"], +["ea40","澢濉澫濍澯澲澰燅燂熿熸燖燀燁燋燔燊燇燏熽燘熼燆燚燛犝犞獩獦獧獬獥獫獪瑿璚璠璔璒璕璡甋疀瘯瘭瘱瘽瘳瘼瘵瘲瘰皻盦瞚瞝瞡瞜瞛瞢瞣瞕瞙"], +["eaa1","瞗磝磩磥磪磞磣磛磡磢磭磟磠禤穄穈穇窶窸窵窱窷篞篣篧篝篕篥篚篨篹篔篪篢篜篫篘篟糒糔糗糐糑縒縡縗縌縟縠縓縎縜縕縚縢縋縏縖縍縔縥縤罃罻罼罺羱翯耪耩聬膱膦膮膹膵膫膰膬膴膲膷膧臲艕艖艗蕖蕅蕫蕍蕓蕡蕘"], +["eb40","蕀蕆蕤蕁蕢蕄蕑蕇蕣蔾蕛蕱蕎蕮蕵蕕蕧蕠薌蕦蕝蕔蕥蕬虣虥虤螛螏螗螓螒螈螁螖螘蝹螇螣螅螐螑螝螄螔螜螚螉褞褦褰褭褮褧褱褢褩褣褯褬褟觱諠"], +["eba1","諢諲諴諵諝謔諤諟諰諈諞諡諨諿諯諻貑貒貐賵賮賱賰賳赬赮趥趧踳踾踸蹀蹅踶踼踽蹁踰踿躽輶輮輵輲輹輷輴遶遹遻邆郺鄳鄵鄶醓醐醑醍醏錧錞錈錟錆錏鍺錸錼錛錣錒錁鍆錭錎錍鋋錝鋺錥錓鋹鋷錴錂錤鋿錩錹錵錪錔錌"], +["ec40","錋鋾錉錀鋻錖閼闍閾閹閺閶閿閵閽隩雔霋霒霐鞙鞗鞔韰韸頵頯頲餤餟餧餩馞駮駬駥駤駰駣駪駩駧骹骿骴骻髶髺髹髷鬳鮀鮅鮇魼魾魻鮂鮓鮒鮐魺鮕"], +["eca1","魽鮈鴥鴗鴠鴞鴔鴩鴝鴘鴢鴐鴙鴟麈麆麇麮麭黕黖黺鼒鼽儦儥儢儤儠儩勴嚓嚌嚍嚆嚄嚃噾嚂噿嚁壖壔壏壒嬭嬥嬲嬣嬬嬧嬦嬯嬮孻寱寲嶷幬幪徾徻懃憵憼懧懠懥懤懨懞擯擩擣擫擤擨斁斀斶旚曒檍檖檁檥檉檟檛檡檞檇檓檎"], +["ed40","檕檃檨檤檑橿檦檚檅檌檒歛殭氉濌澩濴濔濣濜濭濧濦濞濲濝濢濨燡燱燨燲燤燰燢獳獮獯璗璲璫璐璪璭璱璥璯甐甑甒甏疄癃癈癉癇皤盩瞵瞫瞲瞷瞶"], +["eda1","瞴瞱瞨矰磳磽礂磻磼磲礅磹磾礄禫禨穜穛穖穘穔穚窾竀竁簅簏篲簀篿篻簎篴簋篳簂簉簃簁篸篽簆篰篱簐簊糨縭縼繂縳顈縸縪繉繀繇縩繌縰縻縶繄縺罅罿罾罽翴翲耬膻臄臌臊臅臇膼臩艛艚艜薃薀薏薧薕薠薋薣蕻薤薚薞"], +["ee40","蕷蕼薉薡蕺蕸蕗薎薖薆薍薙薝薁薢薂薈薅蕹蕶薘薐薟虨螾螪螭蟅螰螬螹螵螼螮蟉蟃蟂蟌螷螯蟄蟊螴螶螿螸螽蟞螲褵褳褼褾襁襒褷襂覭覯覮觲觳謞"], +["eea1","謘謖謑謅謋謢謏謒謕謇謍謈謆謜謓謚豏豰豲豱豯貕貔賹赯蹎蹍蹓蹐蹌蹇轃轀邅遾鄸醚醢醛醙醟醡醝醠鎡鎃鎯鍤鍖鍇鍼鍘鍜鍶鍉鍐鍑鍠鍭鎏鍌鍪鍹鍗鍕鍒鍏鍱鍷鍻鍡鍞鍣鍧鎀鍎鍙闇闀闉闃闅閷隮隰隬霠霟霘霝霙鞚鞡鞜"], +["ef40","鞞鞝韕韔韱顁顄顊顉顅顃餥餫餬餪餳餲餯餭餱餰馘馣馡騂駺駴駷駹駸駶駻駽駾駼騃骾髾髽鬁髼魈鮚鮨鮞鮛鮦鮡鮥鮤鮆鮢鮠鮯鴳鵁鵧鴶鴮鴯鴱鴸鴰"], +["efa1","鵅鵂鵃鴾鴷鵀鴽翵鴭麊麉麍麰黈黚黻黿鼤鼣鼢齔龠儱儭儮嚘嚜嚗嚚嚝嚙奰嬼屩屪巀幭幮懘懟懭懮懱懪懰懫懖懩擿攄擽擸攁攃擼斔旛曚曛曘櫅檹檽櫡櫆檺檶檷櫇檴檭歞毉氋瀇瀌瀍瀁瀅瀔瀎濿瀀濻瀦濼濷瀊爁燿燹爃燽獶"], +["f040","璸瓀璵瓁璾璶璻瓂甔甓癜癤癙癐癓癗癚皦皽盬矂瞺磿礌礓礔礉礐礒礑禭禬穟簜簩簙簠簟簭簝簦簨簢簥簰繜繐繖繣繘繢繟繑繠繗繓羵羳翷翸聵臑臒"], +["f0a1","臐艟艞薴藆藀藃藂薳薵薽藇藄薿藋藎藈藅薱薶藒蘤薸薷薾虩蟧蟦蟢蟛蟫蟪蟥蟟蟳蟤蟔蟜蟓蟭蟘蟣螤蟗蟙蠁蟴蟨蟝襓襋襏襌襆襐襑襉謪謧謣謳謰謵譇謯謼謾謱謥謷謦謶謮謤謻謽謺豂豵貙貘貗賾贄贂贀蹜蹢蹠蹗蹖蹞蹥蹧"], +["f140","蹛蹚蹡蹝蹩蹔轆轇轈轋鄨鄺鄻鄾醨醥醧醯醪鎵鎌鎒鎷鎛鎝鎉鎧鎎鎪鎞鎦鎕鎈鎙鎟鎍鎱鎑鎲鎤鎨鎴鎣鎥闒闓闑隳雗雚巂雟雘雝霣霢霥鞬鞮鞨鞫鞤鞪"], +["f1a1","鞢鞥韗韙韖韘韺顐顑顒颸饁餼餺騏騋騉騍騄騑騊騅騇騆髀髜鬈鬄鬅鬩鬵魊魌魋鯇鯆鯃鮿鯁鮵鮸鯓鮶鯄鮹鮽鵜鵓鵏鵊鵛鵋鵙鵖鵌鵗鵒鵔鵟鵘鵚麎麌黟鼁鼀鼖鼥鼫鼪鼩鼨齌齕儴儵劖勷厴嚫嚭嚦嚧嚪嚬壚壝壛夒嬽嬾嬿巃幰"], +["f240","徿懻攇攐攍攉攌攎斄旞旝曞櫧櫠櫌櫑櫙櫋櫟櫜櫐櫫櫏櫍櫞歠殰氌瀙瀧瀠瀖瀫瀡瀢瀣瀩瀗瀤瀜瀪爌爊爇爂爅犥犦犤犣犡瓋瓅璷瓃甖癠矉矊矄矱礝礛"], +["f2a1","礡礜礗礞禰穧穨簳簼簹簬簻糬糪繶繵繸繰繷繯繺繲繴繨罋罊羃羆羷翽翾聸臗臕艤艡艣藫藱藭藙藡藨藚藗藬藲藸藘藟藣藜藑藰藦藯藞藢蠀蟺蠃蟶蟷蠉蠌蠋蠆蟼蠈蟿蠊蠂襢襚襛襗襡襜襘襝襙覈覷覶觶譐譈譊譀譓譖譔譋譕"], +["f340","譑譂譒譗豃豷豶貚贆贇贉趬趪趭趫蹭蹸蹳蹪蹯蹻軂轒轑轏轐轓辴酀鄿醰醭鏞鏇鏏鏂鏚鏐鏹鏬鏌鏙鎩鏦鏊鏔鏮鏣鏕鏄鏎鏀鏒鏧镽闚闛雡霩霫霬霨霦"], +["f3a1","鞳鞷鞶韝韞韟顜顙顝顗颿颽颻颾饈饇饃馦馧騚騕騥騝騤騛騢騠騧騣騞騜騔髂鬋鬊鬎鬌鬷鯪鯫鯠鯞鯤鯦鯢鯰鯔鯗鯬鯜鯙鯥鯕鯡鯚鵷鶁鶊鶄鶈鵱鶀鵸鶆鶋鶌鵽鵫鵴鵵鵰鵩鶅鵳鵻鶂鵯鵹鵿鶇鵨麔麑黀黼鼭齀齁齍齖齗齘匷嚲"], +["f440","嚵嚳壣孅巆巇廮廯忀忁懹攗攖攕攓旟曨曣曤櫳櫰櫪櫨櫹櫱櫮櫯瀼瀵瀯瀷瀴瀱灂瀸瀿瀺瀹灀瀻瀳灁爓爔犨獽獼璺皫皪皾盭矌矎矏矍矲礥礣礧礨礤礩"], +["f4a1","禲穮穬穭竷籉籈籊籇籅糮繻繾纁纀羺翿聹臛臙舋艨艩蘢藿蘁藾蘛蘀藶蘄蘉蘅蘌藽蠙蠐蠑蠗蠓蠖襣襦覹觷譠譪譝譨譣譥譧譭趮躆躈躄轙轖轗轕轘轚邍酃酁醷醵醲醳鐋鐓鏻鐠鐏鐔鏾鐕鐐鐨鐙鐍鏵鐀鏷鐇鐎鐖鐒鏺鐉鏸鐊鏿"], +["f540","鏼鐌鏶鐑鐆闞闠闟霮霯鞹鞻韽韾顠顢顣顟飁飂饐饎饙饌饋饓騲騴騱騬騪騶騩騮騸騭髇髊髆鬐鬒鬑鰋鰈鯷鰅鰒鯸鱀鰇鰎鰆鰗鰔鰉鶟鶙鶤鶝鶒鶘鶐鶛"], +["f5a1","鶠鶔鶜鶪鶗鶡鶚鶢鶨鶞鶣鶿鶩鶖鶦鶧麙麛麚黥黤黧黦鼰鼮齛齠齞齝齙龑儺儹劘劗囃嚽嚾孈孇巋巏廱懽攛欂櫼欃櫸欀灃灄灊灈灉灅灆爝爚爙獾甗癪矐礭礱礯籔籓糲纊纇纈纋纆纍罍羻耰臝蘘蘪蘦蘟蘣蘜蘙蘧蘮蘡蘠蘩蘞蘥"], +["f640","蠩蠝蠛蠠蠤蠜蠫衊襭襩襮襫觺譹譸譅譺譻贐贔趯躎躌轞轛轝酆酄酅醹鐿鐻鐶鐩鐽鐼鐰鐹鐪鐷鐬鑀鐱闥闤闣霵霺鞿韡顤飉飆飀饘饖騹騽驆驄驂驁騺"], +["f6a1","騿髍鬕鬗鬘鬖鬺魒鰫鰝鰜鰬鰣鰨鰩鰤鰡鶷鶶鶼鷁鷇鷊鷏鶾鷅鷃鶻鶵鷎鶹鶺鶬鷈鶱鶭鷌鶳鷍鶲鹺麜黫黮黭鼛鼘鼚鼱齎齥齤龒亹囆囅囋奱孋孌巕巑廲攡攠攦攢欋欈欉氍灕灖灗灒爞爟犩獿瓘瓕瓙瓗癭皭礵禴穰穱籗籜籙籛籚"], +["f740","糴糱纑罏羇臞艫蘴蘵蘳蘬蘲蘶蠬蠨蠦蠪蠥襱覿覾觻譾讄讂讆讅譿贕躕躔躚躒躐躖躗轠轢酇鑌鑐鑊鑋鑏鑇鑅鑈鑉鑆霿韣顪顩飋饔饛驎驓驔驌驏驈驊"], +["f7a1","驉驒驐髐鬙鬫鬻魖魕鱆鱈鰿鱄鰹鰳鱁鰼鰷鰴鰲鰽鰶鷛鷒鷞鷚鷋鷐鷜鷑鷟鷩鷙鷘鷖鷵鷕鷝麶黰鼵鼳鼲齂齫龕龢儽劙壨壧奲孍巘蠯彏戁戃戄攩攥斖曫欑欒欏毊灛灚爢玂玁玃癰矔籧籦纕艬蘺虀蘹蘼蘱蘻蘾蠰蠲蠮蠳襶襴襳觾"], +["f840","讌讎讋讈豅贙躘轤轣醼鑢鑕鑝鑗鑞韄韅頀驖驙鬞鬟鬠鱒鱘鱐鱊鱍鱋鱕鱙鱌鱎鷻鷷鷯鷣鷫鷸鷤鷶鷡鷮鷦鷲鷰鷢鷬鷴鷳鷨鷭黂黐黲黳鼆鼜鼸鼷鼶齃齏"], +["f8a1","齱齰齮齯囓囍孎屭攭曭曮欓灟灡灝灠爣瓛瓥矕礸禷禶籪纗羉艭虃蠸蠷蠵衋讔讕躞躟躠躝醾醽釂鑫鑨鑩雥靆靃靇韇韥驞髕魙鱣鱧鱦鱢鱞鱠鸂鷾鸇鸃鸆鸅鸀鸁鸉鷿鷽鸄麠鼞齆齴齵齶囔攮斸欘欙欗欚灢爦犪矘矙礹籩籫糶纚"], +["f940","纘纛纙臠臡虆虇虈襹襺襼襻觿讘讙躥躤躣鑮鑭鑯鑱鑳靉顲饟鱨鱮鱭鸋鸍鸐鸏鸒鸑麡黵鼉齇齸齻齺齹圞灦籯蠼趲躦釃鑴鑸鑶鑵驠鱴鱳鱱鱵鸔鸓黶鼊"], +["f9a1","龤灨灥糷虪蠾蠽蠿讞貜躩軉靋顳顴飌饡馫驤驦驧鬤鸕鸗齈戇欞爧虌躨钂钀钁驩驨鬮鸙爩虋讟钃鱹麷癵驫鱺鸝灩灪麤齾齉龘碁銹裏墻恒粧嫺╔╦╗╠╬╣╚╩╝╒╤╕╞╪╡╘╧╛╓╥╖╟╫╢╙╨╜║═╭╮╰╯▓"] +] diff --git a/node_modules/body-parser/node_modules/iconv-lite/encodings/tables/eucjp.json b/node_modules/body-parser/node_modules/iconv-lite/encodings/tables/eucjp.json new file mode 100644 index 0000000..4fa61ca --- /dev/null +++ b/node_modules/body-parser/node_modules/iconv-lite/encodings/tables/eucjp.json @@ -0,0 +1,182 @@ +[ +["0","\u0000",127], +["8ea1","。",62], +["a1a1"," 、。,.・:;?!゛゜´`¨^ ̄_ヽヾゝゞ〃仝々〆〇ー―‐/\~∥|…‥‘’“”()〔〕[]{}〈",9,"+-±×÷=≠<>≦≧∞∴♂♀°′″℃¥$¢£%#&*@§☆★○●◎◇"], +["a2a1","◆□■△▲▽▼※〒→←↑↓〓"], +["a2ba","∈∋⊆⊇⊂⊃∪∩"], +["a2ca","∧∨¬⇒⇔∀∃"], +["a2dc","∠⊥⌒∂∇≡≒≪≫√∽∝∵∫∬"], +["a2f2","ʼn♯♭♪†‡¶"], +["a2fe","◯"], +["a3b0","0",9], +["a3c1","A",25], +["a3e1","a",25], +["a4a1","ぁ",82], +["a5a1","ァ",85], +["a6a1","Α",16,"Σ",6], +["a6c1","α",16,"σ",6], +["a7a1","А",5,"ЁЖ",25], +["a7d1","а",5,"ёж",25], +["a8a1","─│┌┐┘└├┬┤┴┼━┃┏┓┛┗┣┳┫┻╋┠┯┨┷┿┝┰┥┸╂"], +["ada1","①",19,"Ⅰ",9], +["adc0","㍉㌔㌢㍍㌘㌧㌃㌶㍑㍗㌍㌦㌣㌫㍊㌻㎜㎝㎞㎎㎏㏄㎡"], +["addf","㍻〝〟№㏍℡㊤",4,"㈱㈲㈹㍾㍽㍼≒≡∫∮∑√⊥∠∟⊿∵∩∪"], +["b0a1","亜唖娃阿哀愛挨姶逢葵茜穐悪握渥旭葦芦鯵梓圧斡扱宛姐虻飴絢綾鮎或粟袷安庵按暗案闇鞍杏以伊位依偉囲夷委威尉惟意慰易椅為畏異移維緯胃萎衣謂違遺医井亥域育郁磯一壱溢逸稲茨芋鰯允印咽員因姻引飲淫胤蔭"], +["b1a1","院陰隠韻吋右宇烏羽迂雨卯鵜窺丑碓臼渦嘘唄欝蔚鰻姥厩浦瓜閏噂云運雲荏餌叡営嬰影映曳栄永泳洩瑛盈穎頴英衛詠鋭液疫益駅悦謁越閲榎厭円園堰奄宴延怨掩援沿演炎焔煙燕猿縁艶苑薗遠鉛鴛塩於汚甥凹央奥往応"], +["b2a1","押旺横欧殴王翁襖鴬鴎黄岡沖荻億屋憶臆桶牡乙俺卸恩温穏音下化仮何伽価佳加可嘉夏嫁家寡科暇果架歌河火珂禍禾稼箇花苛茄荷華菓蝦課嘩貨迦過霞蚊俄峨我牙画臥芽蛾賀雅餓駕介会解回塊壊廻快怪悔恢懐戒拐改"], +["b3a1","魁晦械海灰界皆絵芥蟹開階貝凱劾外咳害崖慨概涯碍蓋街該鎧骸浬馨蛙垣柿蛎鈎劃嚇各廓拡撹格核殻獲確穫覚角赫較郭閣隔革学岳楽額顎掛笠樫橿梶鰍潟割喝恰括活渇滑葛褐轄且鰹叶椛樺鞄株兜竃蒲釜鎌噛鴨栢茅萱"], +["b4a1","粥刈苅瓦乾侃冠寒刊勘勧巻喚堪姦完官寛干幹患感慣憾換敢柑桓棺款歓汗漢澗潅環甘監看竿管簡緩缶翰肝艦莞観諌貫還鑑間閑関陥韓館舘丸含岸巌玩癌眼岩翫贋雁頑顔願企伎危喜器基奇嬉寄岐希幾忌揮机旗既期棋棄"], +["b5a1","機帰毅気汽畿祈季稀紀徽規記貴起軌輝飢騎鬼亀偽儀妓宜戯技擬欺犠疑祇義蟻誼議掬菊鞠吉吃喫桔橘詰砧杵黍却客脚虐逆丘久仇休及吸宮弓急救朽求汲泣灸球究窮笈級糾給旧牛去居巨拒拠挙渠虚許距鋸漁禦魚亨享京"], +["b6a1","供侠僑兇競共凶協匡卿叫喬境峡強彊怯恐恭挟教橋況狂狭矯胸脅興蕎郷鏡響饗驚仰凝尭暁業局曲極玉桐粁僅勤均巾錦斤欣欽琴禁禽筋緊芹菌衿襟謹近金吟銀九倶句区狗玖矩苦躯駆駈駒具愚虞喰空偶寓遇隅串櫛釧屑屈"], +["b7a1","掘窟沓靴轡窪熊隈粂栗繰桑鍬勲君薫訓群軍郡卦袈祁係傾刑兄啓圭珪型契形径恵慶慧憩掲携敬景桂渓畦稽系経継繋罫茎荊蛍計詣警軽頚鶏芸迎鯨劇戟撃激隙桁傑欠決潔穴結血訣月件倹倦健兼券剣喧圏堅嫌建憲懸拳捲"], +["b8a1","検権牽犬献研硯絹県肩見謙賢軒遣鍵険顕験鹸元原厳幻弦減源玄現絃舷言諺限乎個古呼固姑孤己庫弧戸故枯湖狐糊袴股胡菰虎誇跨鈷雇顧鼓五互伍午呉吾娯後御悟梧檎瑚碁語誤護醐乞鯉交佼侯候倖光公功効勾厚口向"], +["b9a1","后喉坑垢好孔孝宏工巧巷幸広庚康弘恒慌抗拘控攻昂晃更杭校梗構江洪浩港溝甲皇硬稿糠紅紘絞綱耕考肯肱腔膏航荒行衡講貢購郊酵鉱砿鋼閤降項香高鴻剛劫号合壕拷濠豪轟麹克刻告国穀酷鵠黒獄漉腰甑忽惚骨狛込"], +["baa1","此頃今困坤墾婚恨懇昏昆根梱混痕紺艮魂些佐叉唆嵯左差査沙瑳砂詐鎖裟坐座挫債催再最哉塞妻宰彩才採栽歳済災采犀砕砦祭斎細菜裁載際剤在材罪財冴坂阪堺榊肴咲崎埼碕鷺作削咋搾昨朔柵窄策索錯桜鮭笹匙冊刷"], +["bba1","察拶撮擦札殺薩雑皐鯖捌錆鮫皿晒三傘参山惨撒散桟燦珊産算纂蚕讃賛酸餐斬暫残仕仔伺使刺司史嗣四士始姉姿子屍市師志思指支孜斯施旨枝止死氏獅祉私糸紙紫肢脂至視詞詩試誌諮資賜雌飼歯事似侍児字寺慈持時"], +["bca1","次滋治爾璽痔磁示而耳自蒔辞汐鹿式識鴫竺軸宍雫七叱執失嫉室悉湿漆疾質実蔀篠偲柴芝屡蕊縞舎写射捨赦斜煮社紗者謝車遮蛇邪借勺尺杓灼爵酌釈錫若寂弱惹主取守手朱殊狩珠種腫趣酒首儒受呪寿授樹綬需囚収周"], +["bda1","宗就州修愁拾洲秀秋終繍習臭舟蒐衆襲讐蹴輯週酋酬集醜什住充十従戎柔汁渋獣縦重銃叔夙宿淑祝縮粛塾熟出術述俊峻春瞬竣舜駿准循旬楯殉淳準潤盾純巡遵醇順処初所暑曙渚庶緒署書薯藷諸助叙女序徐恕鋤除傷償"], +["bea1","勝匠升召哨商唱嘗奨妾娼宵将小少尚庄床廠彰承抄招掌捷昇昌昭晶松梢樟樵沼消渉湘焼焦照症省硝礁祥称章笑粧紹肖菖蒋蕉衝裳訟証詔詳象賞醤鉦鍾鐘障鞘上丈丞乗冗剰城場壌嬢常情擾条杖浄状畳穣蒸譲醸錠嘱埴飾"], +["bfa1","拭植殖燭織職色触食蝕辱尻伸信侵唇娠寝審心慎振新晋森榛浸深申疹真神秦紳臣芯薪親診身辛進針震人仁刃塵壬尋甚尽腎訊迅陣靭笥諏須酢図厨逗吹垂帥推水炊睡粋翠衰遂酔錐錘随瑞髄崇嵩数枢趨雛据杉椙菅頗雀裾"], +["c0a1","澄摺寸世瀬畝是凄制勢姓征性成政整星晴棲栖正清牲生盛精聖声製西誠誓請逝醒青静斉税脆隻席惜戚斥昔析石積籍績脊責赤跡蹟碩切拙接摂折設窃節説雪絶舌蝉仙先千占宣専尖川戦扇撰栓栴泉浅洗染潜煎煽旋穿箭線"], +["c1a1","繊羨腺舛船薦詮賎践選遷銭銑閃鮮前善漸然全禅繕膳糎噌塑岨措曾曽楚狙疏疎礎祖租粗素組蘇訴阻遡鼠僧創双叢倉喪壮奏爽宋層匝惣想捜掃挿掻操早曹巣槍槽漕燥争痩相窓糟総綜聡草荘葬蒼藻装走送遭鎗霜騒像増憎"], +["c2a1","臓蔵贈造促側則即息捉束測足速俗属賊族続卒袖其揃存孫尊損村遜他多太汰詑唾堕妥惰打柁舵楕陀駄騨体堆対耐岱帯待怠態戴替泰滞胎腿苔袋貸退逮隊黛鯛代台大第醍題鷹滝瀧卓啄宅托択拓沢濯琢託鐸濁諾茸凧蛸只"], +["c3a1","叩但達辰奪脱巽竪辿棚谷狸鱈樽誰丹単嘆坦担探旦歎淡湛炭短端箪綻耽胆蛋誕鍛団壇弾断暖檀段男談値知地弛恥智池痴稚置致蜘遅馳築畜竹筑蓄逐秩窒茶嫡着中仲宙忠抽昼柱注虫衷註酎鋳駐樗瀦猪苧著貯丁兆凋喋寵"], +["c4a1","帖帳庁弔張彫徴懲挑暢朝潮牒町眺聴脹腸蝶調諜超跳銚長頂鳥勅捗直朕沈珍賃鎮陳津墜椎槌追鎚痛通塚栂掴槻佃漬柘辻蔦綴鍔椿潰坪壷嬬紬爪吊釣鶴亭低停偵剃貞呈堤定帝底庭廷弟悌抵挺提梯汀碇禎程締艇訂諦蹄逓"], +["c5a1","邸鄭釘鼎泥摘擢敵滴的笛適鏑溺哲徹撤轍迭鉄典填天展店添纏甜貼転顛点伝殿澱田電兎吐堵塗妬屠徒斗杜渡登菟賭途都鍍砥砺努度土奴怒倒党冬凍刀唐塔塘套宕島嶋悼投搭東桃梼棟盗淘湯涛灯燈当痘祷等答筒糖統到"], +["c6a1","董蕩藤討謄豆踏逃透鐙陶頭騰闘働動同堂導憧撞洞瞳童胴萄道銅峠鴇匿得徳涜特督禿篤毒独読栃橡凸突椴届鳶苫寅酉瀞噸屯惇敦沌豚遁頓呑曇鈍奈那内乍凪薙謎灘捺鍋楢馴縄畷南楠軟難汝二尼弐迩匂賑肉虹廿日乳入"], +["c7a1","如尿韮任妊忍認濡禰祢寧葱猫熱年念捻撚燃粘乃廼之埜嚢悩濃納能脳膿農覗蚤巴把播覇杷波派琶破婆罵芭馬俳廃拝排敗杯盃牌背肺輩配倍培媒梅楳煤狽買売賠陪這蝿秤矧萩伯剥博拍柏泊白箔粕舶薄迫曝漠爆縛莫駁麦"], +["c8a1","函箱硲箸肇筈櫨幡肌畑畠八鉢溌発醗髪伐罰抜筏閥鳩噺塙蛤隼伴判半反叛帆搬斑板氾汎版犯班畔繁般藩販範釆煩頒飯挽晩番盤磐蕃蛮匪卑否妃庇彼悲扉批披斐比泌疲皮碑秘緋罷肥被誹費避非飛樋簸備尾微枇毘琵眉美"], +["c9a1","鼻柊稗匹疋髭彦膝菱肘弼必畢筆逼桧姫媛紐百謬俵彪標氷漂瓢票表評豹廟描病秒苗錨鋲蒜蛭鰭品彬斌浜瀕貧賓頻敏瓶不付埠夫婦富冨布府怖扶敷斧普浮父符腐膚芙譜負賦赴阜附侮撫武舞葡蕪部封楓風葺蕗伏副復幅服"], +["caa1","福腹複覆淵弗払沸仏物鮒分吻噴墳憤扮焚奮粉糞紛雰文聞丙併兵塀幣平弊柄並蔽閉陛米頁僻壁癖碧別瞥蔑箆偏変片篇編辺返遍便勉娩弁鞭保舗鋪圃捕歩甫補輔穂募墓慕戊暮母簿菩倣俸包呆報奉宝峰峯崩庖抱捧放方朋"], +["cba1","法泡烹砲縫胞芳萌蓬蜂褒訪豊邦鋒飽鳳鵬乏亡傍剖坊妨帽忘忙房暴望某棒冒紡肪膨謀貌貿鉾防吠頬北僕卜墨撲朴牧睦穆釦勃没殆堀幌奔本翻凡盆摩磨魔麻埋妹昧枚毎哩槙幕膜枕鮪柾鱒桝亦俣又抹末沫迄侭繭麿万慢満"], +["cca1","漫蔓味未魅巳箕岬密蜜湊蓑稔脈妙粍民眠務夢無牟矛霧鵡椋婿娘冥名命明盟迷銘鳴姪牝滅免棉綿緬面麺摸模茂妄孟毛猛盲網耗蒙儲木黙目杢勿餅尤戻籾貰問悶紋門匁也冶夜爺耶野弥矢厄役約薬訳躍靖柳薮鑓愉愈油癒"], +["cda1","諭輸唯佑優勇友宥幽悠憂揖有柚湧涌猶猷由祐裕誘遊邑郵雄融夕予余与誉輿預傭幼妖容庸揚揺擁曜楊様洋溶熔用窯羊耀葉蓉要謡踊遥陽養慾抑欲沃浴翌翼淀羅螺裸来莱頼雷洛絡落酪乱卵嵐欄濫藍蘭覧利吏履李梨理璃"], +["cea1","痢裏裡里離陸律率立葎掠略劉流溜琉留硫粒隆竜龍侶慮旅虜了亮僚両凌寮料梁涼猟療瞭稜糧良諒遼量陵領力緑倫厘林淋燐琳臨輪隣鱗麟瑠塁涙累類令伶例冷励嶺怜玲礼苓鈴隷零霊麗齢暦歴列劣烈裂廉恋憐漣煉簾練聯"], +["cfa1","蓮連錬呂魯櫓炉賂路露労婁廊弄朗楼榔浪漏牢狼篭老聾蝋郎六麓禄肋録論倭和話歪賄脇惑枠鷲亙亘鰐詫藁蕨椀湾碗腕"], +["d0a1","弌丐丕个丱丶丼丿乂乖乘亂亅豫亊舒弍于亞亟亠亢亰亳亶从仍仄仆仂仗仞仭仟价伉佚估佛佝佗佇佶侈侏侘佻佩佰侑佯來侖儘俔俟俎俘俛俑俚俐俤俥倚倨倔倪倥倅伜俶倡倩倬俾俯們倆偃假會偕偐偈做偖偬偸傀傚傅傴傲"], +["d1a1","僉僊傳僂僖僞僥僭僣僮價僵儉儁儂儖儕儔儚儡儺儷儼儻儿兀兒兌兔兢竸兩兪兮冀冂囘册冉冏冑冓冕冖冤冦冢冩冪冫决冱冲冰况冽凅凉凛几處凩凭凰凵凾刄刋刔刎刧刪刮刳刹剏剄剋剌剞剔剪剴剩剳剿剽劍劔劒剱劈劑辨"], +["d2a1","辧劬劭劼劵勁勍勗勞勣勦飭勠勳勵勸勹匆匈甸匍匐匏匕匚匣匯匱匳匸區卆卅丗卉卍凖卞卩卮夘卻卷厂厖厠厦厥厮厰厶參簒雙叟曼燮叮叨叭叺吁吽呀听吭吼吮吶吩吝呎咏呵咎呟呱呷呰咒呻咀呶咄咐咆哇咢咸咥咬哄哈咨"], +["d3a1","咫哂咤咾咼哘哥哦唏唔哽哮哭哺哢唹啀啣啌售啜啅啖啗唸唳啝喙喀咯喊喟啻啾喘喞單啼喃喩喇喨嗚嗅嗟嗄嗜嗤嗔嘔嗷嘖嗾嗽嘛嗹噎噐營嘴嘶嘲嘸噫噤嘯噬噪嚆嚀嚊嚠嚔嚏嚥嚮嚶嚴囂嚼囁囃囀囈囎囑囓囗囮囹圀囿圄圉"], +["d4a1","圈國圍圓團圖嗇圜圦圷圸坎圻址坏坩埀垈坡坿垉垓垠垳垤垪垰埃埆埔埒埓堊埖埣堋堙堝塲堡塢塋塰毀塒堽塹墅墹墟墫墺壞墻墸墮壅壓壑壗壙壘壥壜壤壟壯壺壹壻壼壽夂夊夐夛梦夥夬夭夲夸夾竒奕奐奎奚奘奢奠奧奬奩"], +["d5a1","奸妁妝佞侫妣妲姆姨姜妍姙姚娥娟娑娜娉娚婀婬婉娵娶婢婪媚媼媾嫋嫂媽嫣嫗嫦嫩嫖嫺嫻嬌嬋嬖嬲嫐嬪嬶嬾孃孅孀孑孕孚孛孥孩孰孳孵學斈孺宀它宦宸寃寇寉寔寐寤實寢寞寥寫寰寶寳尅將專對尓尠尢尨尸尹屁屆屎屓"], +["d6a1","屐屏孱屬屮乢屶屹岌岑岔妛岫岻岶岼岷峅岾峇峙峩峽峺峭嶌峪崋崕崗嵜崟崛崑崔崢崚崙崘嵌嵒嵎嵋嵬嵳嵶嶇嶄嶂嶢嶝嶬嶮嶽嶐嶷嶼巉巍巓巒巖巛巫已巵帋帚帙帑帛帶帷幄幃幀幎幗幔幟幢幤幇幵并幺麼广庠廁廂廈廐廏"], +["d7a1","廖廣廝廚廛廢廡廨廩廬廱廳廰廴廸廾弃弉彝彜弋弑弖弩弭弸彁彈彌彎弯彑彖彗彙彡彭彳彷徃徂彿徊很徑徇從徙徘徠徨徭徼忖忻忤忸忱忝悳忿怡恠怙怐怩怎怱怛怕怫怦怏怺恚恁恪恷恟恊恆恍恣恃恤恂恬恫恙悁悍惧悃悚"], +["d8a1","悄悛悖悗悒悧悋惡悸惠惓悴忰悽惆悵惘慍愕愆惶惷愀惴惺愃愡惻惱愍愎慇愾愨愧慊愿愼愬愴愽慂慄慳慷慘慙慚慫慴慯慥慱慟慝慓慵憙憖憇憬憔憚憊憑憫憮懌懊應懷懈懃懆憺懋罹懍懦懣懶懺懴懿懽懼懾戀戈戉戍戌戔戛"], +["d9a1","戞戡截戮戰戲戳扁扎扞扣扛扠扨扼抂抉找抒抓抖拔抃抔拗拑抻拏拿拆擔拈拜拌拊拂拇抛拉挌拮拱挧挂挈拯拵捐挾捍搜捏掖掎掀掫捶掣掏掉掟掵捫捩掾揩揀揆揣揉插揶揄搖搴搆搓搦搶攝搗搨搏摧摯摶摎攪撕撓撥撩撈撼"], +["daa1","據擒擅擇撻擘擂擱擧舉擠擡抬擣擯攬擶擴擲擺攀擽攘攜攅攤攣攫攴攵攷收攸畋效敖敕敍敘敞敝敲數斂斃變斛斟斫斷旃旆旁旄旌旒旛旙无旡旱杲昊昃旻杳昵昶昴昜晏晄晉晁晞晝晤晧晨晟晢晰暃暈暎暉暄暘暝曁暹曉暾暼"], +["dba1","曄暸曖曚曠昿曦曩曰曵曷朏朖朞朦朧霸朮朿朶杁朸朷杆杞杠杙杣杤枉杰枩杼杪枌枋枦枡枅枷柯枴柬枳柩枸柤柞柝柢柮枹柎柆柧檜栞框栩桀桍栲桎梳栫桙档桷桿梟梏梭梔條梛梃檮梹桴梵梠梺椏梍桾椁棊椈棘椢椦棡椌棍"], +["dca1","棔棧棕椶椒椄棗棣椥棹棠棯椨椪椚椣椡棆楹楷楜楸楫楔楾楮椹楴椽楙椰楡楞楝榁楪榲榮槐榿槁槓榾槎寨槊槝榻槃榧樮榑榠榜榕榴槞槨樂樛槿權槹槲槧樅榱樞槭樔槫樊樒櫁樣樓橄樌橲樶橸橇橢橙橦橈樸樢檐檍檠檄檢檣"], +["dda1","檗蘗檻櫃櫂檸檳檬櫞櫑櫟檪櫚櫪櫻欅蘖櫺欒欖鬱欟欸欷盜欹飮歇歃歉歐歙歔歛歟歡歸歹歿殀殄殃殍殘殕殞殤殪殫殯殲殱殳殷殼毆毋毓毟毬毫毳毯麾氈氓气氛氤氣汞汕汢汪沂沍沚沁沛汾汨汳沒沐泄泱泓沽泗泅泝沮沱沾"], +["dea1","沺泛泯泙泪洟衍洶洫洽洸洙洵洳洒洌浣涓浤浚浹浙涎涕濤涅淹渕渊涵淇淦涸淆淬淞淌淨淒淅淺淙淤淕淪淮渭湮渮渙湲湟渾渣湫渫湶湍渟湃渺湎渤滿渝游溂溪溘滉溷滓溽溯滄溲滔滕溏溥滂溟潁漑灌滬滸滾漿滲漱滯漲滌"], +["dfa1","漾漓滷澆潺潸澁澀潯潛濳潭澂潼潘澎澑濂潦澳澣澡澤澹濆澪濟濕濬濔濘濱濮濛瀉瀋濺瀑瀁瀏濾瀛瀚潴瀝瀘瀟瀰瀾瀲灑灣炙炒炯烱炬炸炳炮烟烋烝烙焉烽焜焙煥煕熈煦煢煌煖煬熏燻熄熕熨熬燗熹熾燒燉燔燎燠燬燧燵燼"], +["e0a1","燹燿爍爐爛爨爭爬爰爲爻爼爿牀牆牋牘牴牾犂犁犇犒犖犢犧犹犲狃狆狄狎狒狢狠狡狹狷倏猗猊猜猖猝猴猯猩猥猾獎獏默獗獪獨獰獸獵獻獺珈玳珎玻珀珥珮珞璢琅瑯琥珸琲琺瑕琿瑟瑙瑁瑜瑩瑰瑣瑪瑶瑾璋璞璧瓊瓏瓔珱"], +["e1a1","瓠瓣瓧瓩瓮瓲瓰瓱瓸瓷甄甃甅甌甎甍甕甓甞甦甬甼畄畍畊畉畛畆畚畩畤畧畫畭畸當疆疇畴疊疉疂疔疚疝疥疣痂疳痃疵疽疸疼疱痍痊痒痙痣痞痾痿痼瘁痰痺痲痳瘋瘍瘉瘟瘧瘠瘡瘢瘤瘴瘰瘻癇癈癆癜癘癡癢癨癩癪癧癬癰"], +["e2a1","癲癶癸發皀皃皈皋皎皖皓皙皚皰皴皸皹皺盂盍盖盒盞盡盥盧盪蘯盻眈眇眄眩眤眞眥眦眛眷眸睇睚睨睫睛睥睿睾睹瞎瞋瞑瞠瞞瞰瞶瞹瞿瞼瞽瞻矇矍矗矚矜矣矮矼砌砒礦砠礪硅碎硴碆硼碚碌碣碵碪碯磑磆磋磔碾碼磅磊磬"], +["e3a1","磧磚磽磴礇礒礑礙礬礫祀祠祗祟祚祕祓祺祿禊禝禧齋禪禮禳禹禺秉秕秧秬秡秣稈稍稘稙稠稟禀稱稻稾稷穃穗穉穡穢穩龝穰穹穽窈窗窕窘窖窩竈窰窶竅竄窿邃竇竊竍竏竕竓站竚竝竡竢竦竭竰笂笏笊笆笳笘笙笞笵笨笶筐"], +["e4a1","筺笄筍笋筌筅筵筥筴筧筰筱筬筮箝箘箟箍箜箚箋箒箏筝箙篋篁篌篏箴篆篝篩簑簔篦篥籠簀簇簓篳篷簗簍篶簣簧簪簟簷簫簽籌籃籔籏籀籐籘籟籤籖籥籬籵粃粐粤粭粢粫粡粨粳粲粱粮粹粽糀糅糂糘糒糜糢鬻糯糲糴糶糺紆"], +["e5a1","紂紜紕紊絅絋紮紲紿紵絆絳絖絎絲絨絮絏絣經綉絛綏絽綛綺綮綣綵緇綽綫總綢綯緜綸綟綰緘緝緤緞緻緲緡縅縊縣縡縒縱縟縉縋縢繆繦縻縵縹繃縷縲縺繧繝繖繞繙繚繹繪繩繼繻纃緕繽辮繿纈纉續纒纐纓纔纖纎纛纜缸缺"], +["e6a1","罅罌罍罎罐网罕罔罘罟罠罨罩罧罸羂羆羃羈羇羌羔羞羝羚羣羯羲羹羮羶羸譱翅翆翊翕翔翡翦翩翳翹飜耆耄耋耒耘耙耜耡耨耿耻聊聆聒聘聚聟聢聨聳聲聰聶聹聽聿肄肆肅肛肓肚肭冐肬胛胥胙胝胄胚胖脉胯胱脛脩脣脯腋"], +["e7a1","隋腆脾腓腑胼腱腮腥腦腴膃膈膊膀膂膠膕膤膣腟膓膩膰膵膾膸膽臀臂膺臉臍臑臙臘臈臚臟臠臧臺臻臾舁舂舅與舊舍舐舖舩舫舸舳艀艙艘艝艚艟艤艢艨艪艫舮艱艷艸艾芍芒芫芟芻芬苡苣苟苒苴苳苺莓范苻苹苞茆苜茉苙"], +["e8a1","茵茴茖茲茱荀茹荐荅茯茫茗茘莅莚莪莟莢莖茣莎莇莊荼莵荳荵莠莉莨菴萓菫菎菽萃菘萋菁菷萇菠菲萍萢萠莽萸蔆菻葭萪萼蕚蒄葷葫蒭葮蒂葩葆萬葯葹萵蓊葢蒹蒿蒟蓙蓍蒻蓚蓐蓁蓆蓖蒡蔡蓿蓴蔗蔘蔬蔟蔕蔔蓼蕀蕣蕘蕈"], +["e9a1","蕁蘂蕋蕕薀薤薈薑薊薨蕭薔薛藪薇薜蕷蕾薐藉薺藏薹藐藕藝藥藜藹蘊蘓蘋藾藺蘆蘢蘚蘰蘿虍乕虔號虧虱蚓蚣蚩蚪蚋蚌蚶蚯蛄蛆蚰蛉蠣蚫蛔蛞蛩蛬蛟蛛蛯蜒蜆蜈蜀蜃蛻蜑蜉蜍蛹蜊蜴蜿蜷蜻蜥蜩蜚蝠蝟蝸蝌蝎蝴蝗蝨蝮蝙"], +["eaa1","蝓蝣蝪蠅螢螟螂螯蟋螽蟀蟐雖螫蟄螳蟇蟆螻蟯蟲蟠蠏蠍蟾蟶蟷蠎蟒蠑蠖蠕蠢蠡蠱蠶蠹蠧蠻衄衂衒衙衞衢衫袁衾袞衵衽袵衲袂袗袒袮袙袢袍袤袰袿袱裃裄裔裘裙裝裹褂裼裴裨裲褄褌褊褓襃褞褥褪褫襁襄褻褶褸襌褝襠襞"], +["eba1","襦襤襭襪襯襴襷襾覃覈覊覓覘覡覩覦覬覯覲覺覽覿觀觚觜觝觧觴觸訃訖訐訌訛訝訥訶詁詛詒詆詈詼詭詬詢誅誂誄誨誡誑誥誦誚誣諄諍諂諚諫諳諧諤諱謔諠諢諷諞諛謌謇謚諡謖謐謗謠謳鞫謦謫謾謨譁譌譏譎證譖譛譚譫"], +["eca1","譟譬譯譴譽讀讌讎讒讓讖讙讚谺豁谿豈豌豎豐豕豢豬豸豺貂貉貅貊貍貎貔豼貘戝貭貪貽貲貳貮貶賈賁賤賣賚賽賺賻贄贅贊贇贏贍贐齎贓賍贔贖赧赭赱赳趁趙跂趾趺跏跚跖跌跛跋跪跫跟跣跼踈踉跿踝踞踐踟蹂踵踰踴蹊"], +["eda1","蹇蹉蹌蹐蹈蹙蹤蹠踪蹣蹕蹶蹲蹼躁躇躅躄躋躊躓躑躔躙躪躡躬躰軆躱躾軅軈軋軛軣軼軻軫軾輊輅輕輒輙輓輜輟輛輌輦輳輻輹轅轂輾轌轉轆轎轗轜轢轣轤辜辟辣辭辯辷迚迥迢迪迯邇迴逅迹迺逑逕逡逍逞逖逋逧逶逵逹迸"], +["eea1","遏遐遑遒逎遉逾遖遘遞遨遯遶隨遲邂遽邁邀邊邉邏邨邯邱邵郢郤扈郛鄂鄒鄙鄲鄰酊酖酘酣酥酩酳酲醋醉醂醢醫醯醪醵醴醺釀釁釉釋釐釖釟釡釛釼釵釶鈞釿鈔鈬鈕鈑鉞鉗鉅鉉鉤鉈銕鈿鉋鉐銜銖銓銛鉚鋏銹銷鋩錏鋺鍄錮"], +["efa1","錙錢錚錣錺錵錻鍜鍠鍼鍮鍖鎰鎬鎭鎔鎹鏖鏗鏨鏥鏘鏃鏝鏐鏈鏤鐚鐔鐓鐃鐇鐐鐶鐫鐵鐡鐺鑁鑒鑄鑛鑠鑢鑞鑪鈩鑰鑵鑷鑽鑚鑼鑾钁鑿閂閇閊閔閖閘閙閠閨閧閭閼閻閹閾闊濶闃闍闌闕闔闖關闡闥闢阡阨阮阯陂陌陏陋陷陜陞"], +["f0a1","陝陟陦陲陬隍隘隕隗險隧隱隲隰隴隶隸隹雎雋雉雍襍雜霍雕雹霄霆霈霓霎霑霏霖霙霤霪霰霹霽霾靄靆靈靂靉靜靠靤靦靨勒靫靱靹鞅靼鞁靺鞆鞋鞏鞐鞜鞨鞦鞣鞳鞴韃韆韈韋韜韭齏韲竟韶韵頏頌頸頤頡頷頽顆顏顋顫顯顰"], +["f1a1","顱顴顳颪颯颱颶飄飃飆飩飫餃餉餒餔餘餡餝餞餤餠餬餮餽餾饂饉饅饐饋饑饒饌饕馗馘馥馭馮馼駟駛駝駘駑駭駮駱駲駻駸騁騏騅駢騙騫騷驅驂驀驃騾驕驍驛驗驟驢驥驤驩驫驪骭骰骼髀髏髑髓體髞髟髢髣髦髯髫髮髴髱髷"], +["f2a1","髻鬆鬘鬚鬟鬢鬣鬥鬧鬨鬩鬪鬮鬯鬲魄魃魏魍魎魑魘魴鮓鮃鮑鮖鮗鮟鮠鮨鮴鯀鯊鮹鯆鯏鯑鯒鯣鯢鯤鯔鯡鰺鯲鯱鯰鰕鰔鰉鰓鰌鰆鰈鰒鰊鰄鰮鰛鰥鰤鰡鰰鱇鰲鱆鰾鱚鱠鱧鱶鱸鳧鳬鳰鴉鴈鳫鴃鴆鴪鴦鶯鴣鴟鵄鴕鴒鵁鴿鴾鵆鵈"], +["f3a1","鵝鵞鵤鵑鵐鵙鵲鶉鶇鶫鵯鵺鶚鶤鶩鶲鷄鷁鶻鶸鶺鷆鷏鷂鷙鷓鷸鷦鷭鷯鷽鸚鸛鸞鹵鹹鹽麁麈麋麌麒麕麑麝麥麩麸麪麭靡黌黎黏黐黔黜點黝黠黥黨黯黴黶黷黹黻黼黽鼇鼈皷鼕鼡鼬鼾齊齒齔齣齟齠齡齦齧齬齪齷齲齶龕龜龠"], +["f4a1","堯槇遙瑤凜熙"], +["f9a1","纊褜鍈銈蓜俉炻昱棈鋹曻彅丨仡仼伀伃伹佖侒侊侚侔俍偀倢俿倞偆偰偂傔僴僘兊兤冝冾凬刕劜劦勀勛匀匇匤卲厓厲叝﨎咜咊咩哿喆坙坥垬埈埇﨏塚增墲夋奓奛奝奣妤妺孖寀甯寘寬尞岦岺峵崧嵓﨑嵂嵭嶸嶹巐弡弴彧德"], +["faa1","忞恝悅悊惞惕愠惲愑愷愰憘戓抦揵摠撝擎敎昀昕昻昉昮昞昤晥晗晙晴晳暙暠暲暿曺朎朗杦枻桒柀栁桄棏﨓楨﨔榘槢樰橫橆橳橾櫢櫤毖氿汜沆汯泚洄涇浯涖涬淏淸淲淼渹湜渧渼溿澈澵濵瀅瀇瀨炅炫焏焄煜煆煇凞燁燾犱"], +["fba1","犾猤猪獷玽珉珖珣珒琇珵琦琪琩琮瑢璉璟甁畯皂皜皞皛皦益睆劯砡硎硤硺礰礼神祥禔福禛竑竧靖竫箞精絈絜綷綠緖繒罇羡羽茁荢荿菇菶葈蒴蕓蕙蕫﨟薰蘒﨡蠇裵訒訷詹誧誾諟諸諶譓譿賰賴贒赶﨣軏﨤逸遧郞都鄕鄧釚"], +["fca1","釗釞釭釮釤釥鈆鈐鈊鈺鉀鈼鉎鉙鉑鈹鉧銧鉷鉸鋧鋗鋙鋐﨧鋕鋠鋓錥錡鋻﨨錞鋿錝錂鍰鍗鎤鏆鏞鏸鐱鑅鑈閒隆﨩隝隯霳霻靃靍靏靑靕顗顥飯飼餧館馞驎髙髜魵魲鮏鮱鮻鰀鵰鵫鶴鸙黑"], +["fcf1","ⅰ",9,"¬¦'""], +["8fa2af","˘ˇ¸˙˝¯˛˚~΄΅"], +["8fa2c2","¡¦¿"], +["8fa2eb","ºª©®™¤№"], +["8fa6e1","ΆΈΉΊΪ"], +["8fa6e7","Ό"], +["8fa6e9","ΎΫ"], +["8fa6ec","Ώ"], +["8fa6f1","άέήίϊΐόςύϋΰώ"], +["8fa7c2","Ђ",10,"ЎЏ"], +["8fa7f2","ђ",10,"ўџ"], +["8fa9a1","ÆĐ"], +["8fa9a4","Ħ"], +["8fa9a6","IJ"], +["8fa9a8","ŁĿ"], +["8fa9ab","ŊØŒ"], +["8fa9af","ŦÞ"], +["8fa9c1","æđðħıijĸłŀʼnŋøœßŧþ"], +["8faaa1","ÁÀÄÂĂǍĀĄÅÃĆĈČÇĊĎÉÈËÊĚĖĒĘ"], +["8faaba","ĜĞĢĠĤÍÌÏÎǏİĪĮĨĴĶĹĽĻŃŇŅÑÓÒÖÔǑŐŌÕŔŘŖŚŜŠŞŤŢÚÙÜÛŬǓŰŪŲŮŨǗǛǙǕŴÝŸŶŹŽŻ"], +["8faba1","áàäâăǎāąåãćĉčçċďéèëêěėēęǵĝğ"], +["8fabbd","ġĥíìïîǐ"], +["8fabc5","īįĩĵķĺľļńňņñóòöôǒőōõŕřŗśŝšşťţúùüûŭǔűūųůũǘǜǚǖŵýÿŷźžż"], +["8fb0a1","丂丄丅丌丒丟丣两丨丫丮丯丰丵乀乁乄乇乑乚乜乣乨乩乴乵乹乿亍亖亗亝亯亹仃仐仚仛仠仡仢仨仯仱仳仵份仾仿伀伂伃伈伋伌伒伕伖众伙伮伱你伳伵伷伹伻伾佀佂佈佉佋佌佒佔佖佘佟佣佪佬佮佱佷佸佹佺佽佾侁侂侄"], +["8fb1a1","侅侉侊侌侎侐侒侓侔侗侙侚侞侟侲侷侹侻侼侽侾俀俁俅俆俈俉俋俌俍俏俒俜俠俢俰俲俼俽俿倀倁倄倇倊倌倎倐倓倗倘倛倜倝倞倢倧倮倰倲倳倵偀偁偂偅偆偊偌偎偑偒偓偗偙偟偠偢偣偦偧偪偭偰偱倻傁傃傄傆傊傎傏傐"], +["8fb2a1","傒傓傔傖傛傜傞",4,"傪傯傰傹傺傽僀僃僄僇僌僎僐僓僔僘僜僝僟僢僤僦僨僩僯僱僶僺僾儃儆儇儈儋儌儍儎僲儐儗儙儛儜儝儞儣儧儨儬儭儯儱儳儴儵儸儹兂兊兏兓兕兗兘兟兤兦兾冃冄冋冎冘冝冡冣冭冸冺冼冾冿凂"], +["8fb3a1","凈减凑凒凓凕凘凞凢凥凮凲凳凴凷刁刂刅划刓刕刖刘刢刨刱刲刵刼剅剉剕剗剘剚剜剟剠剡剦剮剷剸剹劀劂劅劊劌劓劕劖劗劘劚劜劤劥劦劧劯劰劶劷劸劺劻劽勀勄勆勈勌勏勑勔勖勛勜勡勥勨勩勪勬勰勱勴勶勷匀匃匊匋"], +["8fb4a1","匌匑匓匘匛匜匞匟匥匧匨匩匫匬匭匰匲匵匼匽匾卂卌卋卙卛卡卣卥卬卭卲卹卾厃厇厈厎厓厔厙厝厡厤厪厫厯厲厴厵厷厸厺厽叀叅叏叒叓叕叚叝叞叠另叧叵吂吓吚吡吧吨吪启吱吴吵呃呄呇呍呏呞呢呤呦呧呩呫呭呮呴呿"], +["8fb5a1","咁咃咅咈咉咍咑咕咖咜咟咡咦咧咩咪咭咮咱咷咹咺咻咿哆哊响哎哠哪哬哯哶哼哾哿唀唁唅唈唉唌唍唎唕唪唫唲唵唶唻唼唽啁啇啉啊啍啐啑啘啚啛啞啠啡啤啦啿喁喂喆喈喎喏喑喒喓喔喗喣喤喭喲喿嗁嗃嗆嗉嗋嗌嗎嗑嗒"], +["8fb6a1","嗓嗗嗘嗛嗞嗢嗩嗶嗿嘅嘈嘊嘍",5,"嘙嘬嘰嘳嘵嘷嘹嘻嘼嘽嘿噀噁噃噄噆噉噋噍噏噔噞噠噡噢噣噦噩噭噯噱噲噵嚄嚅嚈嚋嚌嚕嚙嚚嚝嚞嚟嚦嚧嚨嚩嚫嚬嚭嚱嚳嚷嚾囅囉囊囋囏囐囌囍囙囜囝囟囡囤",4,"囱囫园"], +["8fb7a1","囶囷圁圂圇圊圌圑圕圚圛圝圠圢圣圤圥圩圪圬圮圯圳圴圽圾圿坅坆坌坍坒坢坥坧坨坫坭",4,"坳坴坵坷坹坺坻坼坾垁垃垌垔垗垙垚垜垝垞垟垡垕垧垨垩垬垸垽埇埈埌埏埕埝埞埤埦埧埩埭埰埵埶埸埽埾埿堃堄堈堉埡"], +["8fb8a1","堌堍堛堞堟堠堦堧堭堲堹堿塉塌塍塏塐塕塟塡塤塧塨塸塼塿墀墁墇墈墉墊墌墍墏墐墔墖墝墠墡墢墦墩墱墲壄墼壂壈壍壎壐壒壔壖壚壝壡壢壩壳夅夆夋夌夒夓夔虁夝夡夣夤夨夯夰夳夵夶夿奃奆奒奓奙奛奝奞奟奡奣奫奭"], +["8fb9a1","奯奲奵奶她奻奼妋妌妎妒妕妗妟妤妧妭妮妯妰妳妷妺妼姁姃姄姈姊姍姒姝姞姟姣姤姧姮姯姱姲姴姷娀娄娌娍娎娒娓娞娣娤娧娨娪娭娰婄婅婇婈婌婐婕婞婣婥婧婭婷婺婻婾媋媐媓媖媙媜媞媟媠媢媧媬媱媲媳媵媸媺媻媿"], +["8fbaa1","嫄嫆嫈嫏嫚嫜嫠嫥嫪嫮嫵嫶嫽嬀嬁嬈嬗嬴嬙嬛嬝嬡嬥嬭嬸孁孋孌孒孖孞孨孮孯孼孽孾孿宁宄宆宊宎宐宑宓宔宖宨宩宬宭宯宱宲宷宺宼寀寁寍寏寖",4,"寠寯寱寴寽尌尗尞尟尣尦尩尫尬尮尰尲尵尶屙屚屜屢屣屧屨屩"], +["8fbba1","屭屰屴屵屺屻屼屽岇岈岊岏岒岝岟岠岢岣岦岪岲岴岵岺峉峋峒峝峗峮峱峲峴崁崆崍崒崫崣崤崦崧崱崴崹崽崿嵂嵃嵆嵈嵕嵑嵙嵊嵟嵠嵡嵢嵤嵪嵭嵰嵹嵺嵾嵿嶁嶃嶈嶊嶒嶓嶔嶕嶙嶛嶟嶠嶧嶫嶰嶴嶸嶹巃巇巋巐巎巘巙巠巤"], +["8fbca1","巩巸巹帀帇帍帒帔帕帘帟帠帮帨帲帵帾幋幐幉幑幖幘幛幜幞幨幪",4,"幰庀庋庎庢庤庥庨庪庬庱庳庽庾庿廆廌廋廎廑廒廔廕廜廞廥廫异弆弇弈弎弙弜弝弡弢弣弤弨弫弬弮弰弴弶弻弽弿彀彄彅彇彍彐彔彘彛彠彣彤彧"], +["8fbda1","彯彲彴彵彸彺彽彾徉徍徏徖徜徝徢徧徫徤徬徯徰徱徸忄忇忈忉忋忐",4,"忞忡忢忨忩忪忬忭忮忯忲忳忶忺忼怇怊怍怓怔怗怘怚怟怤怭怳怵恀恇恈恉恌恑恔恖恗恝恡恧恱恾恿悂悆悈悊悎悑悓悕悘悝悞悢悤悥您悰悱悷"], +["8fbea1","悻悾惂惄惈惉惊惋惎惏惔惕惙惛惝惞惢惥惲惵惸惼惽愂愇愊愌愐",4,"愖愗愙愜愞愢愪愫愰愱愵愶愷愹慁慅慆慉慞慠慬慲慸慻慼慿憀憁憃憄憋憍憒憓憗憘憜憝憟憠憥憨憪憭憸憹憼懀懁懂懎懏懕懜懝懞懟懡懢懧懩懥"], +["8fbfa1","懬懭懯戁戃戄戇戓戕戜戠戢戣戧戩戫戹戽扂扃扄扆扌扐扑扒扔扖扚扜扤扭扯扳扺扽抍抎抏抐抦抨抳抶抷抺抾抿拄拎拕拖拚拪拲拴拼拽挃挄挊挋挍挐挓挖挘挩挪挭挵挶挹挼捁捂捃捄捆捊捋捎捒捓捔捘捛捥捦捬捭捱捴捵"], +["8fc0a1","捸捼捽捿掂掄掇掊掐掔掕掙掚掞掤掦掭掮掯掽揁揅揈揎揑揓揔揕揜揠揥揪揬揲揳揵揸揹搉搊搐搒搔搘搞搠搢搤搥搩搪搯搰搵搽搿摋摏摑摒摓摔摚摛摜摝摟摠摡摣摭摳摴摻摽撅撇撏撐撑撘撙撛撝撟撡撣撦撨撬撳撽撾撿"], +["8fc1a1","擄擉擊擋擌擎擐擑擕擗擤擥擩擪擭擰擵擷擻擿攁攄攈攉攊攏攓攔攖攙攛攞攟攢攦攩攮攱攺攼攽敃敇敉敐敒敔敟敠敧敫敺敽斁斅斊斒斕斘斝斠斣斦斮斲斳斴斿旂旈旉旎旐旔旖旘旟旰旲旴旵旹旾旿昀昄昈昉昍昑昒昕昖昝"], +["8fc2a1","昞昡昢昣昤昦昩昪昫昬昮昰昱昳昹昷晀晅晆晊晌晑晎晗晘晙晛晜晠晡曻晪晫晬晾晳晵晿晷晸晹晻暀晼暋暌暍暐暒暙暚暛暜暟暠暤暭暱暲暵暻暿曀曂曃曈曌曎曏曔曛曟曨曫曬曮曺朅朇朎朓朙朜朠朢朳朾杅杇杈杌杔杕杝"], +["8fc3a1","杦杬杮杴杶杻极构枎枏枑枓枖枘枙枛枰枱枲枵枻枼枽柹柀柂柃柅柈柉柒柗柙柜柡柦柰柲柶柷桒栔栙栝栟栨栧栬栭栯栰栱栳栻栿桄桅桊桌桕桗桘桛桫桮",4,"桵桹桺桻桼梂梄梆梈梖梘梚梜梡梣梥梩梪梮梲梻棅棈棌棏"], +["8fc4a1","棐棑棓棖棙棜棝棥棨棪棫棬棭棰棱棵棶棻棼棽椆椉椊椐椑椓椖椗椱椳椵椸椻楂楅楉楎楗楛楣楤楥楦楨楩楬楰楱楲楺楻楿榀榍榒榖榘榡榥榦榨榫榭榯榷榸榺榼槅槈槑槖槗槢槥槮槯槱槳槵槾樀樁樃樏樑樕樚樝樠樤樨樰樲"], +["8fc5a1","樴樷樻樾樿橅橆橉橊橎橐橑橒橕橖橛橤橧橪橱橳橾檁檃檆檇檉檋檑檛檝檞檟檥檫檯檰檱檴檽檾檿櫆櫉櫈櫌櫐櫔櫕櫖櫜櫝櫤櫧櫬櫰櫱櫲櫼櫽欂欃欆欇欉欏欐欑欗欛欞欤欨欫欬欯欵欶欻欿歆歊歍歒歖歘歝歠歧歫歮歰歵歽"], +["8fc6a1","歾殂殅殗殛殟殠殢殣殨殩殬殭殮殰殸殹殽殾毃毄毉毌毖毚毡毣毦毧毮毱毷毹毿氂氄氅氉氍氎氐氒氙氟氦氧氨氬氮氳氵氶氺氻氿汊汋汍汏汒汔汙汛汜汫汭汯汴汶汸汹汻沅沆沇沉沔沕沗沘沜沟沰沲沴泂泆泍泏泐泑泒泔泖"], +["8fc7a1","泚泜泠泧泩泫泬泮泲泴洄洇洊洎洏洑洓洚洦洧洨汧洮洯洱洹洼洿浗浞浟浡浥浧浯浰浼涂涇涑涒涔涖涗涘涪涬涴涷涹涽涿淄淈淊淎淏淖淛淝淟淠淢淥淩淯淰淴淶淼渀渄渞渢渧渲渶渹渻渼湄湅湈湉湋湏湑湒湓湔湗湜湝湞"], +["8fc8a1","湢湣湨湳湻湽溍溓溙溠溧溭溮溱溳溻溿滀滁滃滇滈滊滍滎滏滫滭滮滹滻滽漄漈漊漌漍漖漘漚漛漦漩漪漯漰漳漶漻漼漭潏潑潒潓潗潙潚潝潞潡潢潨潬潽潾澃澇澈澋澌澍澐澒澓澔澖澚澟澠澥澦澧澨澮澯澰澵澶澼濅濇濈濊"], +["8fc9a1","濚濞濨濩濰濵濹濼濽瀀瀅瀆瀇瀍瀗瀠瀣瀯瀴瀷瀹瀼灃灄灈灉灊灋灔灕灝灞灎灤灥灬灮灵灶灾炁炅炆炔",4,"炛炤炫炰炱炴炷烊烑烓烔烕烖烘烜烤烺焃",4,"焋焌焏焞焠焫焭焯焰焱焸煁煅煆煇煊煋煐煒煗煚煜煞煠"], +["8fcaa1","煨煹熀熅熇熌熒熚熛熠熢熯熰熲熳熺熿燀燁燄燋燌燓燖燙燚燜燸燾爀爇爈爉爓爗爚爝爟爤爫爯爴爸爹牁牂牃牅牎牏牐牓牕牖牚牜牞牠牣牨牫牮牯牱牷牸牻牼牿犄犉犍犎犓犛犨犭犮犱犴犾狁狇狉狌狕狖狘狟狥狳狴狺狻"], +["8fcba1","狾猂猄猅猇猋猍猒猓猘猙猞猢猤猧猨猬猱猲猵猺猻猽獃獍獐獒獖獘獝獞獟獠獦獧獩獫獬獮獯獱獷獹獼玀玁玃玅玆玎玐玓玕玗玘玜玞玟玠玢玥玦玪玫玭玵玷玹玼玽玿珅珆珉珋珌珏珒珓珖珙珝珡珣珦珧珩珴珵珷珹珺珻珽"], +["8fcca1","珿琀琁琄琇琊琑琚琛琤琦琨",9,"琹瑀瑃瑄瑆瑇瑋瑍瑑瑒瑗瑝瑢瑦瑧瑨瑫瑭瑮瑱瑲璀璁璅璆璇璉璏璐璑璒璘璙璚璜璟璠璡璣璦璨璩璪璫璮璯璱璲璵璹璻璿瓈瓉瓌瓐瓓瓘瓚瓛瓞瓟瓤瓨瓪瓫瓯瓴瓺瓻瓼瓿甆"], +["8fcda1","甒甖甗甠甡甤甧甩甪甯甶甹甽甾甿畀畃畇畈畎畐畒畗畞畟畡畯畱畹",5,"疁疅疐疒疓疕疙疜疢疤疴疺疿痀痁痄痆痌痎痏痗痜痟痠痡痤痧痬痮痯痱痹瘀瘂瘃瘄瘇瘈瘊瘌瘏瘒瘓瘕瘖瘙瘛瘜瘝瘞瘣瘥瘦瘩瘭瘲瘳瘵瘸瘹"], +["8fcea1","瘺瘼癊癀癁癃癄癅癉癋癕癙癟癤癥癭癮癯癱癴皁皅皌皍皕皛皜皝皟皠皢",6,"皪皭皽盁盅盉盋盌盎盔盙盠盦盨盬盰盱盶盹盼眀眆眊眎眒眔眕眗眙眚眜眢眨眭眮眯眴眵眶眹眽眾睂睅睆睊睍睎睏睒睖睗睜睞睟睠睢"], +["8fcfa1","睤睧睪睬睰睲睳睴睺睽瞀瞄瞌瞍瞔瞕瞖瞚瞟瞢瞧瞪瞮瞯瞱瞵瞾矃矉矑矒矕矙矞矟矠矤矦矪矬矰矱矴矸矻砅砆砉砍砎砑砝砡砢砣砭砮砰砵砷硃硄硇硈硌硎硒硜硞硠硡硣硤硨硪确硺硾碊碏碔碘碡碝碞碟碤碨碬碭碰碱碲碳"], +["8fd0a1","碻碽碿磇磈磉磌磎磒磓磕磖磤磛磟磠磡磦磪磲磳礀磶磷磺磻磿礆礌礐礚礜礞礟礠礥礧礩礭礱礴礵礻礽礿祄祅祆祊祋祏祑祔祘祛祜祧祩祫祲祹祻祼祾禋禌禑禓禔禕禖禘禛禜禡禨禩禫禯禱禴禸离秂秄秇秈秊秏秔秖秚秝秞"], +["8fd1a1","秠秢秥秪秫秭秱秸秼稂稃稇稉稊稌稑稕稛稞稡稧稫稭稯稰稴稵稸稹稺穄穅穇穈穌穕穖穙穜穝穟穠穥穧穪穭穵穸穾窀窂窅窆窊窋窐窑窔窞窠窣窬窳窵窹窻窼竆竉竌竎竑竛竨竩竫竬竱竴竻竽竾笇笔笟笣笧笩笪笫笭笮笯笰"], +["8fd2a1","笱笴笽笿筀筁筇筎筕筠筤筦筩筪筭筯筲筳筷箄箉箎箐箑箖箛箞箠箥箬箯箰箲箵箶箺箻箼箽篂篅篈篊篔篖篗篙篚篛篨篪篲篴篵篸篹篺篼篾簁簂簃簄簆簉簋簌簎簏簙簛簠簥簦簨簬簱簳簴簶簹簺籆籊籕籑籒籓籙",5], +["8fd3a1","籡籣籧籩籭籮籰籲籹籼籽粆粇粏粔粞粠粦粰粶粷粺粻粼粿糄糇糈糉糍糏糓糔糕糗糙糚糝糦糩糫糵紃紇紈紉紏紑紒紓紖紝紞紣紦紪紭紱紼紽紾絀絁絇絈絍絑絓絗絙絚絜絝絥絧絪絰絸絺絻絿綁綂綃綅綆綈綋綌綍綑綖綗綝"], +["8fd4a1","綞綦綧綪綳綶綷綹緂",4,"緌緍緎緗緙縀緢緥緦緪緫緭緱緵緶緹緺縈縐縑縕縗縜縝縠縧縨縬縭縯縳縶縿繄繅繇繎繐繒繘繟繡繢繥繫繮繯繳繸繾纁纆纇纊纍纑纕纘纚纝纞缼缻缽缾缿罃罄罇罏罒罓罛罜罝罡罣罤罥罦罭"], +["8fd5a1","罱罽罾罿羀羋羍羏羐羑羖羗羜羡羢羦羪羭羴羼羿翀翃翈翎翏翛翟翣翥翨翬翮翯翲翺翽翾翿耇耈耊耍耎耏耑耓耔耖耝耞耟耠耤耦耬耮耰耴耵耷耹耺耼耾聀聄聠聤聦聭聱聵肁肈肎肜肞肦肧肫肸肹胈胍胏胒胔胕胗胘胠胭胮"], +["8fd6a1","胰胲胳胶胹胺胾脃脋脖脗脘脜脞脠脤脧脬脰脵脺脼腅腇腊腌腒腗腠腡腧腨腩腭腯腷膁膐膄膅膆膋膎膖膘膛膞膢膮膲膴膻臋臃臅臊臎臏臕臗臛臝臞臡臤臫臬臰臱臲臵臶臸臹臽臿舀舃舏舓舔舙舚舝舡舢舨舲舴舺艃艄艅艆"], +["8fd7a1","艋艎艏艑艖艜艠艣艧艭艴艻艽艿芀芁芃芄芇芉芊芎芑芔芖芘芚芛芠芡芣芤芧芨芩芪芮芰芲芴芷芺芼芾芿苆苐苕苚苠苢苤苨苪苭苯苶苷苽苾茀茁茇茈茊茋荔茛茝茞茟茡茢茬茭茮茰茳茷茺茼茽荂荃荄荇荍荎荑荕荖荗荰荸"], +["8fd8a1","荽荿莀莂莄莆莍莒莔莕莘莙莛莜莝莦莧莩莬莾莿菀菇菉菏菐菑菔菝荓菨菪菶菸菹菼萁萆萊萏萑萕萙莭萯萹葅葇葈葊葍葏葑葒葖葘葙葚葜葠葤葥葧葪葰葳葴葶葸葼葽蒁蒅蒒蒓蒕蒞蒦蒨蒩蒪蒯蒱蒴蒺蒽蒾蓀蓂蓇蓈蓌蓏蓓"], +["8fd9a1","蓜蓧蓪蓯蓰蓱蓲蓷蔲蓺蓻蓽蔂蔃蔇蔌蔎蔐蔜蔞蔢蔣蔤蔥蔧蔪蔫蔯蔳蔴蔶蔿蕆蕏",4,"蕖蕙蕜",6,"蕤蕫蕯蕹蕺蕻蕽蕿薁薅薆薉薋薌薏薓薘薝薟薠薢薥薧薴薶薷薸薼薽薾薿藂藇藊藋藎薭藘藚藟藠藦藨藭藳藶藼"], +["8fdaa1","藿蘀蘄蘅蘍蘎蘐蘑蘒蘘蘙蘛蘞蘡蘧蘩蘶蘸蘺蘼蘽虀虂虆虒虓虖虗虘虙虝虠",4,"虩虬虯虵虶虷虺蚍蚑蚖蚘蚚蚜蚡蚦蚧蚨蚭蚱蚳蚴蚵蚷蚸蚹蚿蛀蛁蛃蛅蛑蛒蛕蛗蛚蛜蛠蛣蛥蛧蚈蛺蛼蛽蜄蜅蜇蜋蜎蜏蜐蜓蜔蜙蜞蜟蜡蜣"], +["8fdba1","蜨蜮蜯蜱蜲蜹蜺蜼蜽蜾蝀蝃蝅蝍蝘蝝蝡蝤蝥蝯蝱蝲蝻螃",6,"螋螌螐螓螕螗螘螙螞螠螣螧螬螭螮螱螵螾螿蟁蟈蟉蟊蟎蟕蟖蟙蟚蟜蟟蟢蟣蟤蟪蟫蟭蟱蟳蟸蟺蟿蠁蠃蠆蠉蠊蠋蠐蠙蠒蠓蠔蠘蠚蠛蠜蠞蠟蠨蠭蠮蠰蠲蠵"], +["8fdca1","蠺蠼衁衃衅衈衉衊衋衎衑衕衖衘衚衜衟衠衤衩衱衹衻袀袘袚袛袜袟袠袨袪袺袽袾裀裊",4,"裑裒裓裛裞裧裯裰裱裵裷褁褆褍褎褏褕褖褘褙褚褜褠褦褧褨褰褱褲褵褹褺褾襀襂襅襆襉襏襒襗襚襛襜襡襢襣襫襮襰襳襵襺"], +["8fdda1","襻襼襽覉覍覐覔覕覛覜覟覠覥覰覴覵覶覷覼觔",4,"觥觩觫觭觱觳觶觹觽觿訄訅訇訏訑訒訔訕訞訠訢訤訦訫訬訯訵訷訽訾詀詃詅詇詉詍詎詓詖詗詘詜詝詡詥詧詵詶詷詹詺詻詾詿誀誃誆誋誏誐誒誖誗誙誟誧誩誮誯誳"], +["8fdea1","誶誷誻誾諃諆諈諉諊諑諓諔諕諗諝諟諬諰諴諵諶諼諿謅謆謋謑謜謞謟謊謭謰謷謼譂",4,"譈譒譓譔譙譍譞譣譭譶譸譹譼譾讁讄讅讋讍讏讔讕讜讞讟谸谹谽谾豅豇豉豋豏豑豓豔豗豘豛豝豙豣豤豦豨豩豭豳豵豶豻豾貆"], +["8fdfa1","貇貋貐貒貓貙貛貜貤貹貺賅賆賉賋賏賖賕賙賝賡賨賬賯賰賲賵賷賸賾賿贁贃贉贒贗贛赥赩赬赮赿趂趄趈趍趐趑趕趞趟趠趦趫趬趯趲趵趷趹趻跀跅跆跇跈跊跎跑跔跕跗跙跤跥跧跬跰趼跱跲跴跽踁踄踅踆踋踑踔踖踠踡踢"], +["8fe0a1","踣踦踧踱踳踶踷踸踹踽蹀蹁蹋蹍蹎蹏蹔蹛蹜蹝蹞蹡蹢蹩蹬蹭蹯蹰蹱蹹蹺蹻躂躃躉躐躒躕躚躛躝躞躢躧躩躭躮躳躵躺躻軀軁軃軄軇軏軑軔軜軨軮軰軱軷軹軺軭輀輂輇輈輏輐輖輗輘輞輠輡輣輥輧輨輬輭輮輴輵輶輷輺轀轁"], +["8fe1a1","轃轇轏轑",4,"轘轝轞轥辝辠辡辤辥辦辵辶辸达迀迁迆迊迋迍运迒迓迕迠迣迤迨迮迱迵迶迻迾适逄逈逌逘逛逨逩逯逪逬逭逳逴逷逿遃遄遌遛遝遢遦遧遬遰遴遹邅邈邋邌邎邐邕邗邘邙邛邠邡邢邥邰邲邳邴邶邽郌邾郃"], +["8fe2a1","郄郅郇郈郕郗郘郙郜郝郟郥郒郶郫郯郰郴郾郿鄀鄄鄅鄆鄈鄍鄐鄔鄖鄗鄘鄚鄜鄞鄠鄥鄢鄣鄧鄩鄮鄯鄱鄴鄶鄷鄹鄺鄼鄽酃酇酈酏酓酗酙酚酛酡酤酧酭酴酹酺酻醁醃醅醆醊醎醑醓醔醕醘醞醡醦醨醬醭醮醰醱醲醳醶醻醼醽醿"], +["8fe3a1","釂釃釅釓釔釗釙釚釞釤釥釩釪釬",5,"釷釹釻釽鈀鈁鈄鈅鈆鈇鈉鈊鈌鈐鈒鈓鈖鈘鈜鈝鈣鈤鈥鈦鈨鈮鈯鈰鈳鈵鈶鈸鈹鈺鈼鈾鉀鉂鉃鉆鉇鉊鉍鉎鉏鉑鉘鉙鉜鉝鉠鉡鉥鉧鉨鉩鉮鉯鉰鉵",4,"鉻鉼鉽鉿銈銉銊銍銎銒銗"], +["8fe4a1","銙銟銠銤銥銧銨銫銯銲銶銸銺銻銼銽銿",4,"鋅鋆鋇鋈鋋鋌鋍鋎鋐鋓鋕鋗鋘鋙鋜鋝鋟鋠鋡鋣鋥鋧鋨鋬鋮鋰鋹鋻鋿錀錂錈錍錑錔錕錜錝錞錟錡錤錥錧錩錪錳錴錶錷鍇鍈鍉鍐鍑鍒鍕鍗鍘鍚鍞鍤鍥鍧鍩鍪鍭鍯鍰鍱鍳鍴鍶"], +["8fe5a1","鍺鍽鍿鎀鎁鎂鎈鎊鎋鎍鎏鎒鎕鎘鎛鎞鎡鎣鎤鎦鎨鎫鎴鎵鎶鎺鎩鏁鏄鏅鏆鏇鏉",4,"鏓鏙鏜鏞鏟鏢鏦鏧鏹鏷鏸鏺鏻鏽鐁鐂鐄鐈鐉鐍鐎鐏鐕鐖鐗鐟鐮鐯鐱鐲鐳鐴鐻鐿鐽鑃鑅鑈鑊鑌鑕鑙鑜鑟鑡鑣鑨鑫鑭鑮鑯鑱鑲钄钃镸镹"], +["8fe6a1","镾閄閈閌閍閎閝閞閟閡閦閩閫閬閴閶閺閽閿闆闈闉闋闐闑闒闓闙闚闝闞闟闠闤闦阝阞阢阤阥阦阬阱阳阷阸阹阺阼阽陁陒陔陖陗陘陡陮陴陻陼陾陿隁隂隃隄隉隑隖隚隝隟隤隥隦隩隮隯隳隺雊雒嶲雘雚雝雞雟雩雯雱雺霂"], +["8fe7a1","霃霅霉霚霛霝霡霢霣霨霱霳靁靃靊靎靏靕靗靘靚靛靣靧靪靮靳靶靷靸靻靽靿鞀鞉鞕鞖鞗鞙鞚鞞鞟鞢鞬鞮鞱鞲鞵鞶鞸鞹鞺鞼鞾鞿韁韄韅韇韉韊韌韍韎韐韑韔韗韘韙韝韞韠韛韡韤韯韱韴韷韸韺頇頊頙頍頎頔頖頜頞頠頣頦"], +["8fe8a1","頫頮頯頰頲頳頵頥頾顄顇顊顑顒顓顖顗顙顚顢顣顥顦顪顬颫颭颮颰颴颷颸颺颻颿飂飅飈飌飡飣飥飦飧飪飳飶餂餇餈餑餕餖餗餚餛餜餟餢餦餧餫餱",4,"餹餺餻餼饀饁饆饇饈饍饎饔饘饙饛饜饞饟饠馛馝馟馦馰馱馲馵"], +["8fe9a1","馹馺馽馿駃駉駓駔駙駚駜駞駧駪駫駬駰駴駵駹駽駾騂騃騄騋騌騐騑騖騞騠騢騣騤騧騭騮騳騵騶騸驇驁驄驊驋驌驎驑驔驖驝骪骬骮骯骲骴骵骶骹骻骾骿髁髃髆髈髎髐髒髕髖髗髛髜髠髤髥髧髩髬髲髳髵髹髺髽髿",4], +["8feaa1","鬄鬅鬈鬉鬋鬌鬍鬎鬐鬒鬖鬙鬛鬜鬠鬦鬫鬭鬳鬴鬵鬷鬹鬺鬽魈魋魌魕魖魗魛魞魡魣魥魦魨魪",4,"魳魵魷魸魹魿鮀鮄鮅鮆鮇鮉鮊鮋鮍鮏鮐鮔鮚鮝鮞鮦鮧鮩鮬鮰鮱鮲鮷鮸鮻鮼鮾鮿鯁鯇鯈鯎鯐鯗鯘鯝鯟鯥鯧鯪鯫鯯鯳鯷鯸"], +["8feba1","鯹鯺鯽鯿鰀鰂鰋鰏鰑鰖鰘鰙鰚鰜鰞鰢鰣鰦",4,"鰱鰵鰶鰷鰽鱁鱃鱄鱅鱉鱊鱎鱏鱐鱓鱔鱖鱘鱛鱝鱞鱟鱣鱩鱪鱜鱫鱨鱮鱰鱲鱵鱷鱻鳦鳲鳷鳹鴋鴂鴑鴗鴘鴜鴝鴞鴯鴰鴲鴳鴴鴺鴼鵅鴽鵂鵃鵇鵊鵓鵔鵟鵣鵢鵥鵩鵪鵫鵰鵶鵷鵻"], +["8feca1","鵼鵾鶃鶄鶆鶊鶍鶎鶒鶓鶕鶖鶗鶘鶡鶪鶬鶮鶱鶵鶹鶼鶿鷃鷇鷉鷊鷔鷕鷖鷗鷚鷞鷟鷠鷥鷧鷩鷫鷮鷰鷳鷴鷾鸊鸂鸇鸎鸐鸑鸒鸕鸖鸙鸜鸝鹺鹻鹼麀麂麃麄麅麇麎麏麖麘麛麞麤麨麬麮麯麰麳麴麵黆黈黋黕黟黤黧黬黭黮黰黱黲黵"], +["8feda1","黸黿鼂鼃鼉鼏鼐鼑鼒鼔鼖鼗鼙鼚鼛鼟鼢鼦鼪鼫鼯鼱鼲鼴鼷鼹鼺鼼鼽鼿齁齃",4,"齓齕齖齗齘齚齝齞齨齩齭",4,"齳齵齺齽龏龐龑龒龔龖龗龞龡龢龣龥"] +] diff --git a/node_modules/body-parser/node_modules/iconv-lite/encodings/tables/gb18030-ranges.json b/node_modules/body-parser/node_modules/iconv-lite/encodings/tables/gb18030-ranges.json new file mode 100644 index 0000000..85c6934 --- /dev/null +++ b/node_modules/body-parser/node_modules/iconv-lite/encodings/tables/gb18030-ranges.json @@ -0,0 +1 @@ +{"uChars":[128,165,169,178,184,216,226,235,238,244,248,251,253,258,276,284,300,325,329,334,364,463,465,467,469,471,473,475,477,506,594,610,712,716,730,930,938,962,970,1026,1104,1106,8209,8215,8218,8222,8231,8241,8244,8246,8252,8365,8452,8454,8458,8471,8482,8556,8570,8596,8602,8713,8720,8722,8726,8731,8737,8740,8742,8748,8751,8760,8766,8777,8781,8787,8802,8808,8816,8854,8858,8870,8896,8979,9322,9372,9548,9588,9616,9622,9634,9652,9662,9672,9676,9680,9702,9735,9738,9793,9795,11906,11909,11913,11917,11928,11944,11947,11951,11956,11960,11964,11979,12284,12292,12312,12319,12330,12351,12436,12447,12535,12543,12586,12842,12850,12964,13200,13215,13218,13253,13263,13267,13270,13384,13428,13727,13839,13851,14617,14703,14801,14816,14964,15183,15471,15585,16471,16736,17208,17325,17330,17374,17623,17997,18018,18212,18218,18301,18318,18760,18811,18814,18820,18823,18844,18848,18872,19576,19620,19738,19887,40870,59244,59336,59367,59413,59417,59423,59431,59437,59443,59452,59460,59478,59493,63789,63866,63894,63976,63986,64016,64018,64021,64025,64034,64037,64042,65074,65093,65107,65112,65127,65132,65375,65510,65536],"gbChars":[0,36,38,45,50,81,89,95,96,100,103,104,105,109,126,133,148,172,175,179,208,306,307,308,309,310,311,312,313,341,428,443,544,545,558,741,742,749,750,805,819,820,7922,7924,7925,7927,7934,7943,7944,7945,7950,8062,8148,8149,8152,8164,8174,8236,8240,8262,8264,8374,8380,8381,8384,8388,8390,8392,8393,8394,8396,8401,8406,8416,8419,8424,8437,8439,8445,8482,8485,8496,8521,8603,8936,8946,9046,9050,9063,9066,9076,9092,9100,9108,9111,9113,9131,9162,9164,9218,9219,11329,11331,11334,11336,11346,11361,11363,11366,11370,11372,11375,11389,11682,11686,11687,11692,11694,11714,11716,11723,11725,11730,11736,11982,11989,12102,12336,12348,12350,12384,12393,12395,12397,12510,12553,12851,12962,12973,13738,13823,13919,13933,14080,14298,14585,14698,15583,15847,16318,16434,16438,16481,16729,17102,17122,17315,17320,17402,17418,17859,17909,17911,17915,17916,17936,17939,17961,18664,18703,18814,18962,19043,33469,33470,33471,33484,33485,33490,33497,33501,33505,33513,33520,33536,33550,37845,37921,37948,38029,38038,38064,38065,38066,38069,38075,38076,38078,39108,39109,39113,39114,39115,39116,39265,39394,189000]} \ No newline at end of file diff --git a/node_modules/body-parser/node_modules/iconv-lite/encodings/tables/gbk-added.json b/node_modules/body-parser/node_modules/iconv-lite/encodings/tables/gbk-added.json new file mode 100644 index 0000000..8abfa9f --- /dev/null +++ b/node_modules/body-parser/node_modules/iconv-lite/encodings/tables/gbk-added.json @@ -0,0 +1,55 @@ +[ +["a140","",62], +["a180","",32], +["a240","",62], +["a280","",32], +["a2ab","",5], +["a2e3","€"], +["a2ef",""], +["a2fd",""], +["a340","",62], +["a380","",31," "], +["a440","",62], +["a480","",32], +["a4f4","",10], +["a540","",62], +["a580","",32], +["a5f7","",7], +["a640","",62], +["a680","",32], +["a6b9","",7], +["a6d9","",6], +["a6ec",""], +["a6f3",""], +["a6f6","",8], +["a740","",62], +["a780","",32], +["a7c2","",14], +["a7f2","",12], +["a896","",10], +["a8bc",""], +["a8bf","ǹ"], +["a8c1",""], +["a8ea","",20], +["a958",""], +["a95b",""], +["a95d",""], +["a989","〾⿰",11], +["a997","",12], +["a9f0","",14], +["aaa1","",93], +["aba1","",93], +["aca1","",93], +["ada1","",93], +["aea1","",93], +["afa1","",93], +["d7fa","",4], +["f8a1","",93], +["f9a1","",93], +["faa1","",93], +["fba1","",93], +["fca1","",93], +["fda1","",93], +["fe50","⺁⺄㑳㑇⺈⺋㖞㘚㘎⺌⺗㥮㤘㧏㧟㩳㧐㭎㱮㳠⺧⺪䁖䅟⺮䌷⺳⺶⺷䎱䎬⺻䏝䓖䙡䙌"], +["fe80","䜣䜩䝼䞍⻊䥇䥺䥽䦂䦃䦅䦆䦟䦛䦷䦶䲣䲟䲠䲡䱷䲢䴓",6,"䶮",93] +] diff --git a/node_modules/body-parser/node_modules/iconv-lite/encodings/tables/shiftjis.json b/node_modules/body-parser/node_modules/iconv-lite/encodings/tables/shiftjis.json new file mode 100644 index 0000000..5a3a43c --- /dev/null +++ b/node_modules/body-parser/node_modules/iconv-lite/encodings/tables/shiftjis.json @@ -0,0 +1,125 @@ +[ +["0","\u0000",128], +["a1","。",62], +["8140"," 、。,.・:;?!゛゜´`¨^ ̄_ヽヾゝゞ〃仝々〆〇ー―‐/\~∥|…‥‘’“”()〔〕[]{}〈",9,"+-±×"], +["8180","÷=≠<>≦≧∞∴♂♀°′″℃¥$¢£%#&*@§☆★○●◎◇◆□■△▲▽▼※〒→←↑↓〓"], +["81b8","∈∋⊆⊇⊂⊃∪∩"], +["81c8","∧∨¬⇒⇔∀∃"], +["81da","∠⊥⌒∂∇≡≒≪≫√∽∝∵∫∬"], +["81f0","ʼn♯♭♪†‡¶"], +["81fc","◯"], +["824f","0",9], +["8260","A",25], +["8281","a",25], +["829f","ぁ",82], +["8340","ァ",62], +["8380","ム",22], +["839f","Α",16,"Σ",6], +["83bf","α",16,"σ",6], +["8440","А",5,"ЁЖ",25], +["8470","а",5,"ёж",7], +["8480","о",17], +["849f","─│┌┐┘└├┬┤┴┼━┃┏┓┛┗┣┳┫┻╋┠┯┨┷┿┝┰┥┸╂"], +["8740","①",19,"Ⅰ",9], +["875f","㍉㌔㌢㍍㌘㌧㌃㌶㍑㍗㌍㌦㌣㌫㍊㌻㎜㎝㎞㎎㎏㏄㎡"], +["877e","㍻"], +["8780","〝〟№㏍℡㊤",4,"㈱㈲㈹㍾㍽㍼≒≡∫∮∑√⊥∠∟⊿∵∩∪"], +["889f","亜唖娃阿哀愛挨姶逢葵茜穐悪握渥旭葦芦鯵梓圧斡扱宛姐虻飴絢綾鮎或粟袷安庵按暗案闇鞍杏以伊位依偉囲夷委威尉惟意慰易椅為畏異移維緯胃萎衣謂違遺医井亥域育郁磯一壱溢逸稲茨芋鰯允印咽員因姻引飲淫胤蔭"], +["8940","院陰隠韻吋右宇烏羽迂雨卯鵜窺丑碓臼渦嘘唄欝蔚鰻姥厩浦瓜閏噂云運雲荏餌叡営嬰影映曳栄永泳洩瑛盈穎頴英衛詠鋭液疫益駅悦謁越閲榎厭円"], +["8980","園堰奄宴延怨掩援沿演炎焔煙燕猿縁艶苑薗遠鉛鴛塩於汚甥凹央奥往応押旺横欧殴王翁襖鴬鴎黄岡沖荻億屋憶臆桶牡乙俺卸恩温穏音下化仮何伽価佳加可嘉夏嫁家寡科暇果架歌河火珂禍禾稼箇花苛茄荷華菓蝦課嘩貨迦過霞蚊俄峨我牙画臥芽蛾賀雅餓駕介会解回塊壊廻快怪悔恢懐戒拐改"], +["8a40","魁晦械海灰界皆絵芥蟹開階貝凱劾外咳害崖慨概涯碍蓋街該鎧骸浬馨蛙垣柿蛎鈎劃嚇各廓拡撹格核殻獲確穫覚角赫較郭閣隔革学岳楽額顎掛笠樫"], +["8a80","橿梶鰍潟割喝恰括活渇滑葛褐轄且鰹叶椛樺鞄株兜竃蒲釜鎌噛鴨栢茅萱粥刈苅瓦乾侃冠寒刊勘勧巻喚堪姦完官寛干幹患感慣憾換敢柑桓棺款歓汗漢澗潅環甘監看竿管簡緩缶翰肝艦莞観諌貫還鑑間閑関陥韓館舘丸含岸巌玩癌眼岩翫贋雁頑顔願企伎危喜器基奇嬉寄岐希幾忌揮机旗既期棋棄"], +["8b40","機帰毅気汽畿祈季稀紀徽規記貴起軌輝飢騎鬼亀偽儀妓宜戯技擬欺犠疑祇義蟻誼議掬菊鞠吉吃喫桔橘詰砧杵黍却客脚虐逆丘久仇休及吸宮弓急救"], +["8b80","朽求汲泣灸球究窮笈級糾給旧牛去居巨拒拠挙渠虚許距鋸漁禦魚亨享京供侠僑兇競共凶協匡卿叫喬境峡強彊怯恐恭挟教橋況狂狭矯胸脅興蕎郷鏡響饗驚仰凝尭暁業局曲極玉桐粁僅勤均巾錦斤欣欽琴禁禽筋緊芹菌衿襟謹近金吟銀九倶句区狗玖矩苦躯駆駈駒具愚虞喰空偶寓遇隅串櫛釧屑屈"], +["8c40","掘窟沓靴轡窪熊隈粂栗繰桑鍬勲君薫訓群軍郡卦袈祁係傾刑兄啓圭珪型契形径恵慶慧憩掲携敬景桂渓畦稽系経継繋罫茎荊蛍計詣警軽頚鶏芸迎鯨"], +["8c80","劇戟撃激隙桁傑欠決潔穴結血訣月件倹倦健兼券剣喧圏堅嫌建憲懸拳捲検権牽犬献研硯絹県肩見謙賢軒遣鍵険顕験鹸元原厳幻弦減源玄現絃舷言諺限乎個古呼固姑孤己庫弧戸故枯湖狐糊袴股胡菰虎誇跨鈷雇顧鼓五互伍午呉吾娯後御悟梧檎瑚碁語誤護醐乞鯉交佼侯候倖光公功効勾厚口向"], +["8d40","后喉坑垢好孔孝宏工巧巷幸広庚康弘恒慌抗拘控攻昂晃更杭校梗構江洪浩港溝甲皇硬稿糠紅紘絞綱耕考肯肱腔膏航荒行衡講貢購郊酵鉱砿鋼閤降"], +["8d80","項香高鴻剛劫号合壕拷濠豪轟麹克刻告国穀酷鵠黒獄漉腰甑忽惚骨狛込此頃今困坤墾婚恨懇昏昆根梱混痕紺艮魂些佐叉唆嵯左差査沙瑳砂詐鎖裟坐座挫債催再最哉塞妻宰彩才採栽歳済災采犀砕砦祭斎細菜裁載際剤在材罪財冴坂阪堺榊肴咲崎埼碕鷺作削咋搾昨朔柵窄策索錯桜鮭笹匙冊刷"], +["8e40","察拶撮擦札殺薩雑皐鯖捌錆鮫皿晒三傘参山惨撒散桟燦珊産算纂蚕讃賛酸餐斬暫残仕仔伺使刺司史嗣四士始姉姿子屍市師志思指支孜斯施旨枝止"], +["8e80","死氏獅祉私糸紙紫肢脂至視詞詩試誌諮資賜雌飼歯事似侍児字寺慈持時次滋治爾璽痔磁示而耳自蒔辞汐鹿式識鴫竺軸宍雫七叱執失嫉室悉湿漆疾質実蔀篠偲柴芝屡蕊縞舎写射捨赦斜煮社紗者謝車遮蛇邪借勺尺杓灼爵酌釈錫若寂弱惹主取守手朱殊狩珠種腫趣酒首儒受呪寿授樹綬需囚収周"], +["8f40","宗就州修愁拾洲秀秋終繍習臭舟蒐衆襲讐蹴輯週酋酬集醜什住充十従戎柔汁渋獣縦重銃叔夙宿淑祝縮粛塾熟出術述俊峻春瞬竣舜駿准循旬楯殉淳"], +["8f80","準潤盾純巡遵醇順処初所暑曙渚庶緒署書薯藷諸助叙女序徐恕鋤除傷償勝匠升召哨商唱嘗奨妾娼宵将小少尚庄床廠彰承抄招掌捷昇昌昭晶松梢樟樵沼消渉湘焼焦照症省硝礁祥称章笑粧紹肖菖蒋蕉衝裳訟証詔詳象賞醤鉦鍾鐘障鞘上丈丞乗冗剰城場壌嬢常情擾条杖浄状畳穣蒸譲醸錠嘱埴飾"], +["9040","拭植殖燭織職色触食蝕辱尻伸信侵唇娠寝審心慎振新晋森榛浸深申疹真神秦紳臣芯薪親診身辛進針震人仁刃塵壬尋甚尽腎訊迅陣靭笥諏須酢図厨"], +["9080","逗吹垂帥推水炊睡粋翠衰遂酔錐錘随瑞髄崇嵩数枢趨雛据杉椙菅頗雀裾澄摺寸世瀬畝是凄制勢姓征性成政整星晴棲栖正清牲生盛精聖声製西誠誓請逝醒青静斉税脆隻席惜戚斥昔析石積籍績脊責赤跡蹟碩切拙接摂折設窃節説雪絶舌蝉仙先千占宣専尖川戦扇撰栓栴泉浅洗染潜煎煽旋穿箭線"], +["9140","繊羨腺舛船薦詮賎践選遷銭銑閃鮮前善漸然全禅繕膳糎噌塑岨措曾曽楚狙疏疎礎祖租粗素組蘇訴阻遡鼠僧創双叢倉喪壮奏爽宋層匝惣想捜掃挿掻"], +["9180","操早曹巣槍槽漕燥争痩相窓糟総綜聡草荘葬蒼藻装走送遭鎗霜騒像増憎臓蔵贈造促側則即息捉束測足速俗属賊族続卒袖其揃存孫尊損村遜他多太汰詑唾堕妥惰打柁舵楕陀駄騨体堆対耐岱帯待怠態戴替泰滞胎腿苔袋貸退逮隊黛鯛代台大第醍題鷹滝瀧卓啄宅托択拓沢濯琢託鐸濁諾茸凧蛸只"], +["9240","叩但達辰奪脱巽竪辿棚谷狸鱈樽誰丹単嘆坦担探旦歎淡湛炭短端箪綻耽胆蛋誕鍛団壇弾断暖檀段男談値知地弛恥智池痴稚置致蜘遅馳築畜竹筑蓄"], +["9280","逐秩窒茶嫡着中仲宙忠抽昼柱注虫衷註酎鋳駐樗瀦猪苧著貯丁兆凋喋寵帖帳庁弔張彫徴懲挑暢朝潮牒町眺聴脹腸蝶調諜超跳銚長頂鳥勅捗直朕沈珍賃鎮陳津墜椎槌追鎚痛通塚栂掴槻佃漬柘辻蔦綴鍔椿潰坪壷嬬紬爪吊釣鶴亭低停偵剃貞呈堤定帝底庭廷弟悌抵挺提梯汀碇禎程締艇訂諦蹄逓"], +["9340","邸鄭釘鼎泥摘擢敵滴的笛適鏑溺哲徹撤轍迭鉄典填天展店添纏甜貼転顛点伝殿澱田電兎吐堵塗妬屠徒斗杜渡登菟賭途都鍍砥砺努度土奴怒倒党冬"], +["9380","凍刀唐塔塘套宕島嶋悼投搭東桃梼棟盗淘湯涛灯燈当痘祷等答筒糖統到董蕩藤討謄豆踏逃透鐙陶頭騰闘働動同堂導憧撞洞瞳童胴萄道銅峠鴇匿得徳涜特督禿篤毒独読栃橡凸突椴届鳶苫寅酉瀞噸屯惇敦沌豚遁頓呑曇鈍奈那内乍凪薙謎灘捺鍋楢馴縄畷南楠軟難汝二尼弐迩匂賑肉虹廿日乳入"], +["9440","如尿韮任妊忍認濡禰祢寧葱猫熱年念捻撚燃粘乃廼之埜嚢悩濃納能脳膿農覗蚤巴把播覇杷波派琶破婆罵芭馬俳廃拝排敗杯盃牌背肺輩配倍培媒梅"], +["9480","楳煤狽買売賠陪這蝿秤矧萩伯剥博拍柏泊白箔粕舶薄迫曝漠爆縛莫駁麦函箱硲箸肇筈櫨幡肌畑畠八鉢溌発醗髪伐罰抜筏閥鳩噺塙蛤隼伴判半反叛帆搬斑板氾汎版犯班畔繁般藩販範釆煩頒飯挽晩番盤磐蕃蛮匪卑否妃庇彼悲扉批披斐比泌疲皮碑秘緋罷肥被誹費避非飛樋簸備尾微枇毘琵眉美"], +["9540","鼻柊稗匹疋髭彦膝菱肘弼必畢筆逼桧姫媛紐百謬俵彪標氷漂瓢票表評豹廟描病秒苗錨鋲蒜蛭鰭品彬斌浜瀕貧賓頻敏瓶不付埠夫婦富冨布府怖扶敷"], +["9580","斧普浮父符腐膚芙譜負賦赴阜附侮撫武舞葡蕪部封楓風葺蕗伏副復幅服福腹複覆淵弗払沸仏物鮒分吻噴墳憤扮焚奮粉糞紛雰文聞丙併兵塀幣平弊柄並蔽閉陛米頁僻壁癖碧別瞥蔑箆偏変片篇編辺返遍便勉娩弁鞭保舗鋪圃捕歩甫補輔穂募墓慕戊暮母簿菩倣俸包呆報奉宝峰峯崩庖抱捧放方朋"], +["9640","法泡烹砲縫胞芳萌蓬蜂褒訪豊邦鋒飽鳳鵬乏亡傍剖坊妨帽忘忙房暴望某棒冒紡肪膨謀貌貿鉾防吠頬北僕卜墨撲朴牧睦穆釦勃没殆堀幌奔本翻凡盆"], +["9680","摩磨魔麻埋妹昧枚毎哩槙幕膜枕鮪柾鱒桝亦俣又抹末沫迄侭繭麿万慢満漫蔓味未魅巳箕岬密蜜湊蓑稔脈妙粍民眠務夢無牟矛霧鵡椋婿娘冥名命明盟迷銘鳴姪牝滅免棉綿緬面麺摸模茂妄孟毛猛盲網耗蒙儲木黙目杢勿餅尤戻籾貰問悶紋門匁也冶夜爺耶野弥矢厄役約薬訳躍靖柳薮鑓愉愈油癒"], +["9740","諭輸唯佑優勇友宥幽悠憂揖有柚湧涌猶猷由祐裕誘遊邑郵雄融夕予余与誉輿預傭幼妖容庸揚揺擁曜楊様洋溶熔用窯羊耀葉蓉要謡踊遥陽養慾抑欲"], +["9780","沃浴翌翼淀羅螺裸来莱頼雷洛絡落酪乱卵嵐欄濫藍蘭覧利吏履李梨理璃痢裏裡里離陸律率立葎掠略劉流溜琉留硫粒隆竜龍侶慮旅虜了亮僚両凌寮料梁涼猟療瞭稜糧良諒遼量陵領力緑倫厘林淋燐琳臨輪隣鱗麟瑠塁涙累類令伶例冷励嶺怜玲礼苓鈴隷零霊麗齢暦歴列劣烈裂廉恋憐漣煉簾練聯"], +["9840","蓮連錬呂魯櫓炉賂路露労婁廊弄朗楼榔浪漏牢狼篭老聾蝋郎六麓禄肋録論倭和話歪賄脇惑枠鷲亙亘鰐詫藁蕨椀湾碗腕"], +["989f","弌丐丕个丱丶丼丿乂乖乘亂亅豫亊舒弍于亞亟亠亢亰亳亶从仍仄仆仂仗仞仭仟价伉佚估佛佝佗佇佶侈侏侘佻佩佰侑佯來侖儘俔俟俎俘俛俑俚俐俤俥倚倨倔倪倥倅伜俶倡倩倬俾俯們倆偃假會偕偐偈做偖偬偸傀傚傅傴傲"], +["9940","僉僊傳僂僖僞僥僭僣僮價僵儉儁儂儖儕儔儚儡儺儷儼儻儿兀兒兌兔兢竸兩兪兮冀冂囘册冉冏冑冓冕冖冤冦冢冩冪冫决冱冲冰况冽凅凉凛几處凩凭"], +["9980","凰凵凾刄刋刔刎刧刪刮刳刹剏剄剋剌剞剔剪剴剩剳剿剽劍劔劒剱劈劑辨辧劬劭劼劵勁勍勗勞勣勦飭勠勳勵勸勹匆匈甸匍匐匏匕匚匣匯匱匳匸區卆卅丗卉卍凖卞卩卮夘卻卷厂厖厠厦厥厮厰厶參簒雙叟曼燮叮叨叭叺吁吽呀听吭吼吮吶吩吝呎咏呵咎呟呱呷呰咒呻咀呶咄咐咆哇咢咸咥咬哄哈咨"], +["9a40","咫哂咤咾咼哘哥哦唏唔哽哮哭哺哢唹啀啣啌售啜啅啖啗唸唳啝喙喀咯喊喟啻啾喘喞單啼喃喩喇喨嗚嗅嗟嗄嗜嗤嗔嘔嗷嘖嗾嗽嘛嗹噎噐營嘴嘶嘲嘸"], +["9a80","噫噤嘯噬噪嚆嚀嚊嚠嚔嚏嚥嚮嚶嚴囂嚼囁囃囀囈囎囑囓囗囮囹圀囿圄圉圈國圍圓團圖嗇圜圦圷圸坎圻址坏坩埀垈坡坿垉垓垠垳垤垪垰埃埆埔埒埓堊埖埣堋堙堝塲堡塢塋塰毀塒堽塹墅墹墟墫墺壞墻墸墮壅壓壑壗壙壘壥壜壤壟壯壺壹壻壼壽夂夊夐夛梦夥夬夭夲夸夾竒奕奐奎奚奘奢奠奧奬奩"], +["9b40","奸妁妝佞侫妣妲姆姨姜妍姙姚娥娟娑娜娉娚婀婬婉娵娶婢婪媚媼媾嫋嫂媽嫣嫗嫦嫩嫖嫺嫻嬌嬋嬖嬲嫐嬪嬶嬾孃孅孀孑孕孚孛孥孩孰孳孵學斈孺宀"], +["9b80","它宦宸寃寇寉寔寐寤實寢寞寥寫寰寶寳尅將專對尓尠尢尨尸尹屁屆屎屓屐屏孱屬屮乢屶屹岌岑岔妛岫岻岶岼岷峅岾峇峙峩峽峺峭嶌峪崋崕崗嵜崟崛崑崔崢崚崙崘嵌嵒嵎嵋嵬嵳嵶嶇嶄嶂嶢嶝嶬嶮嶽嶐嶷嶼巉巍巓巒巖巛巫已巵帋帚帙帑帛帶帷幄幃幀幎幗幔幟幢幤幇幵并幺麼广庠廁廂廈廐廏"], +["9c40","廖廣廝廚廛廢廡廨廩廬廱廳廰廴廸廾弃弉彝彜弋弑弖弩弭弸彁彈彌彎弯彑彖彗彙彡彭彳彷徃徂彿徊很徑徇從徙徘徠徨徭徼忖忻忤忸忱忝悳忿怡恠"], +["9c80","怙怐怩怎怱怛怕怫怦怏怺恚恁恪恷恟恊恆恍恣恃恤恂恬恫恙悁悍惧悃悚悄悛悖悗悒悧悋惡悸惠惓悴忰悽惆悵惘慍愕愆惶惷愀惴惺愃愡惻惱愍愎慇愾愨愧慊愿愼愬愴愽慂慄慳慷慘慙慚慫慴慯慥慱慟慝慓慵憙憖憇憬憔憚憊憑憫憮懌懊應懷懈懃懆憺懋罹懍懦懣懶懺懴懿懽懼懾戀戈戉戍戌戔戛"], +["9d40","戞戡截戮戰戲戳扁扎扞扣扛扠扨扼抂抉找抒抓抖拔抃抔拗拑抻拏拿拆擔拈拜拌拊拂拇抛拉挌拮拱挧挂挈拯拵捐挾捍搜捏掖掎掀掫捶掣掏掉掟掵捫"], +["9d80","捩掾揩揀揆揣揉插揶揄搖搴搆搓搦搶攝搗搨搏摧摯摶摎攪撕撓撥撩撈撼據擒擅擇撻擘擂擱擧舉擠擡抬擣擯攬擶擴擲擺攀擽攘攜攅攤攣攫攴攵攷收攸畋效敖敕敍敘敞敝敲數斂斃變斛斟斫斷旃旆旁旄旌旒旛旙无旡旱杲昊昃旻杳昵昶昴昜晏晄晉晁晞晝晤晧晨晟晢晰暃暈暎暉暄暘暝曁暹曉暾暼"], +["9e40","曄暸曖曚曠昿曦曩曰曵曷朏朖朞朦朧霸朮朿朶杁朸朷杆杞杠杙杣杤枉杰枩杼杪枌枋枦枡枅枷柯枴柬枳柩枸柤柞柝柢柮枹柎柆柧檜栞框栩桀桍栲桎"], +["9e80","梳栫桙档桷桿梟梏梭梔條梛梃檮梹桴梵梠梺椏梍桾椁棊椈棘椢椦棡椌棍棔棧棕椶椒椄棗棣椥棹棠棯椨椪椚椣椡棆楹楷楜楸楫楔楾楮椹楴椽楙椰楡楞楝榁楪榲榮槐榿槁槓榾槎寨槊槝榻槃榧樮榑榠榜榕榴槞槨樂樛槿權槹槲槧樅榱樞槭樔槫樊樒櫁樣樓橄樌橲樶橸橇橢橙橦橈樸樢檐檍檠檄檢檣"], +["9f40","檗蘗檻櫃櫂檸檳檬櫞櫑櫟檪櫚櫪櫻欅蘖櫺欒欖鬱欟欸欷盜欹飮歇歃歉歐歙歔歛歟歡歸歹歿殀殄殃殍殘殕殞殤殪殫殯殲殱殳殷殼毆毋毓毟毬毫毳毯"], +["9f80","麾氈氓气氛氤氣汞汕汢汪沂沍沚沁沛汾汨汳沒沐泄泱泓沽泗泅泝沮沱沾沺泛泯泙泪洟衍洶洫洽洸洙洵洳洒洌浣涓浤浚浹浙涎涕濤涅淹渕渊涵淇淦涸淆淬淞淌淨淒淅淺淙淤淕淪淮渭湮渮渙湲湟渾渣湫渫湶湍渟湃渺湎渤滿渝游溂溪溘滉溷滓溽溯滄溲滔滕溏溥滂溟潁漑灌滬滸滾漿滲漱滯漲滌"], +["e040","漾漓滷澆潺潸澁澀潯潛濳潭澂潼潘澎澑濂潦澳澣澡澤澹濆澪濟濕濬濔濘濱濮濛瀉瀋濺瀑瀁瀏濾瀛瀚潴瀝瀘瀟瀰瀾瀲灑灣炙炒炯烱炬炸炳炮烟烋烝"], +["e080","烙焉烽焜焙煥煕熈煦煢煌煖煬熏燻熄熕熨熬燗熹熾燒燉燔燎燠燬燧燵燼燹燿爍爐爛爨爭爬爰爲爻爼爿牀牆牋牘牴牾犂犁犇犒犖犢犧犹犲狃狆狄狎狒狢狠狡狹狷倏猗猊猜猖猝猴猯猩猥猾獎獏默獗獪獨獰獸獵獻獺珈玳珎玻珀珥珮珞璢琅瑯琥珸琲琺瑕琿瑟瑙瑁瑜瑩瑰瑣瑪瑶瑾璋璞璧瓊瓏瓔珱"], +["e140","瓠瓣瓧瓩瓮瓲瓰瓱瓸瓷甄甃甅甌甎甍甕甓甞甦甬甼畄畍畊畉畛畆畚畩畤畧畫畭畸當疆疇畴疊疉疂疔疚疝疥疣痂疳痃疵疽疸疼疱痍痊痒痙痣痞痾痿"], +["e180","痼瘁痰痺痲痳瘋瘍瘉瘟瘧瘠瘡瘢瘤瘴瘰瘻癇癈癆癜癘癡癢癨癩癪癧癬癰癲癶癸發皀皃皈皋皎皖皓皙皚皰皴皸皹皺盂盍盖盒盞盡盥盧盪蘯盻眈眇眄眩眤眞眥眦眛眷眸睇睚睨睫睛睥睿睾睹瞎瞋瞑瞠瞞瞰瞶瞹瞿瞼瞽瞻矇矍矗矚矜矣矮矼砌砒礦砠礪硅碎硴碆硼碚碌碣碵碪碯磑磆磋磔碾碼磅磊磬"], +["e240","磧磚磽磴礇礒礑礙礬礫祀祠祗祟祚祕祓祺祿禊禝禧齋禪禮禳禹禺秉秕秧秬秡秣稈稍稘稙稠稟禀稱稻稾稷穃穗穉穡穢穩龝穰穹穽窈窗窕窘窖窩竈窰"], +["e280","窶竅竄窿邃竇竊竍竏竕竓站竚竝竡竢竦竭竰笂笏笊笆笳笘笙笞笵笨笶筐筺笄筍笋筌筅筵筥筴筧筰筱筬筮箝箘箟箍箜箚箋箒箏筝箙篋篁篌篏箴篆篝篩簑簔篦篥籠簀簇簓篳篷簗簍篶簣簧簪簟簷簫簽籌籃籔籏籀籐籘籟籤籖籥籬籵粃粐粤粭粢粫粡粨粳粲粱粮粹粽糀糅糂糘糒糜糢鬻糯糲糴糶糺紆"], +["e340","紂紜紕紊絅絋紮紲紿紵絆絳絖絎絲絨絮絏絣經綉絛綏絽綛綺綮綣綵緇綽綫總綢綯緜綸綟綰緘緝緤緞緻緲緡縅縊縣縡縒縱縟縉縋縢繆繦縻縵縹繃縷"], +["e380","縲縺繧繝繖繞繙繚繹繪繩繼繻纃緕繽辮繿纈纉續纒纐纓纔纖纎纛纜缸缺罅罌罍罎罐网罕罔罘罟罠罨罩罧罸羂羆羃羈羇羌羔羞羝羚羣羯羲羹羮羶羸譱翅翆翊翕翔翡翦翩翳翹飜耆耄耋耒耘耙耜耡耨耿耻聊聆聒聘聚聟聢聨聳聲聰聶聹聽聿肄肆肅肛肓肚肭冐肬胛胥胙胝胄胚胖脉胯胱脛脩脣脯腋"], +["e440","隋腆脾腓腑胼腱腮腥腦腴膃膈膊膀膂膠膕膤膣腟膓膩膰膵膾膸膽臀臂膺臉臍臑臙臘臈臚臟臠臧臺臻臾舁舂舅與舊舍舐舖舩舫舸舳艀艙艘艝艚艟艤"], +["e480","艢艨艪艫舮艱艷艸艾芍芒芫芟芻芬苡苣苟苒苴苳苺莓范苻苹苞茆苜茉苙茵茴茖茲茱荀茹荐荅茯茫茗茘莅莚莪莟莢莖茣莎莇莊荼莵荳荵莠莉莨菴萓菫菎菽萃菘萋菁菷萇菠菲萍萢萠莽萸蔆菻葭萪萼蕚蒄葷葫蒭葮蒂葩葆萬葯葹萵蓊葢蒹蒿蒟蓙蓍蒻蓚蓐蓁蓆蓖蒡蔡蓿蓴蔗蔘蔬蔟蔕蔔蓼蕀蕣蕘蕈"], +["e540","蕁蘂蕋蕕薀薤薈薑薊薨蕭薔薛藪薇薜蕷蕾薐藉薺藏薹藐藕藝藥藜藹蘊蘓蘋藾藺蘆蘢蘚蘰蘿虍乕虔號虧虱蚓蚣蚩蚪蚋蚌蚶蚯蛄蛆蚰蛉蠣蚫蛔蛞蛩蛬"], +["e580","蛟蛛蛯蜒蜆蜈蜀蜃蛻蜑蜉蜍蛹蜊蜴蜿蜷蜻蜥蜩蜚蝠蝟蝸蝌蝎蝴蝗蝨蝮蝙蝓蝣蝪蠅螢螟螂螯蟋螽蟀蟐雖螫蟄螳蟇蟆螻蟯蟲蟠蠏蠍蟾蟶蟷蠎蟒蠑蠖蠕蠢蠡蠱蠶蠹蠧蠻衄衂衒衙衞衢衫袁衾袞衵衽袵衲袂袗袒袮袙袢袍袤袰袿袱裃裄裔裘裙裝裹褂裼裴裨裲褄褌褊褓襃褞褥褪褫襁襄褻褶褸襌褝襠襞"], +["e640","襦襤襭襪襯襴襷襾覃覈覊覓覘覡覩覦覬覯覲覺覽覿觀觚觜觝觧觴觸訃訖訐訌訛訝訥訶詁詛詒詆詈詼詭詬詢誅誂誄誨誡誑誥誦誚誣諄諍諂諚諫諳諧"], +["e680","諤諱謔諠諢諷諞諛謌謇謚諡謖謐謗謠謳鞫謦謫謾謨譁譌譏譎證譖譛譚譫譟譬譯譴譽讀讌讎讒讓讖讙讚谺豁谿豈豌豎豐豕豢豬豸豺貂貉貅貊貍貎貔豼貘戝貭貪貽貲貳貮貶賈賁賤賣賚賽賺賻贄贅贊贇贏贍贐齎贓賍贔贖赧赭赱赳趁趙跂趾趺跏跚跖跌跛跋跪跫跟跣跼踈踉跿踝踞踐踟蹂踵踰踴蹊"], +["e740","蹇蹉蹌蹐蹈蹙蹤蹠踪蹣蹕蹶蹲蹼躁躇躅躄躋躊躓躑躔躙躪躡躬躰軆躱躾軅軈軋軛軣軼軻軫軾輊輅輕輒輙輓輜輟輛輌輦輳輻輹轅轂輾轌轉轆轎轗轜"], +["e780","轢轣轤辜辟辣辭辯辷迚迥迢迪迯邇迴逅迹迺逑逕逡逍逞逖逋逧逶逵逹迸遏遐遑遒逎遉逾遖遘遞遨遯遶隨遲邂遽邁邀邊邉邏邨邯邱邵郢郤扈郛鄂鄒鄙鄲鄰酊酖酘酣酥酩酳酲醋醉醂醢醫醯醪醵醴醺釀釁釉釋釐釖釟釡釛釼釵釶鈞釿鈔鈬鈕鈑鉞鉗鉅鉉鉤鉈銕鈿鉋鉐銜銖銓銛鉚鋏銹銷鋩錏鋺鍄錮"], +["e840","錙錢錚錣錺錵錻鍜鍠鍼鍮鍖鎰鎬鎭鎔鎹鏖鏗鏨鏥鏘鏃鏝鏐鏈鏤鐚鐔鐓鐃鐇鐐鐶鐫鐵鐡鐺鑁鑒鑄鑛鑠鑢鑞鑪鈩鑰鑵鑷鑽鑚鑼鑾钁鑿閂閇閊閔閖閘閙"], +["e880","閠閨閧閭閼閻閹閾闊濶闃闍闌闕闔闖關闡闥闢阡阨阮阯陂陌陏陋陷陜陞陝陟陦陲陬隍隘隕隗險隧隱隲隰隴隶隸隹雎雋雉雍襍雜霍雕雹霄霆霈霓霎霑霏霖霙霤霪霰霹霽霾靄靆靈靂靉靜靠靤靦靨勒靫靱靹鞅靼鞁靺鞆鞋鞏鞐鞜鞨鞦鞣鞳鞴韃韆韈韋韜韭齏韲竟韶韵頏頌頸頤頡頷頽顆顏顋顫顯顰"], +["e940","顱顴顳颪颯颱颶飄飃飆飩飫餃餉餒餔餘餡餝餞餤餠餬餮餽餾饂饉饅饐饋饑饒饌饕馗馘馥馭馮馼駟駛駝駘駑駭駮駱駲駻駸騁騏騅駢騙騫騷驅驂驀驃"], +["e980","騾驕驍驛驗驟驢驥驤驩驫驪骭骰骼髀髏髑髓體髞髟髢髣髦髯髫髮髴髱髷髻鬆鬘鬚鬟鬢鬣鬥鬧鬨鬩鬪鬮鬯鬲魄魃魏魍魎魑魘魴鮓鮃鮑鮖鮗鮟鮠鮨鮴鯀鯊鮹鯆鯏鯑鯒鯣鯢鯤鯔鯡鰺鯲鯱鯰鰕鰔鰉鰓鰌鰆鰈鰒鰊鰄鰮鰛鰥鰤鰡鰰鱇鰲鱆鰾鱚鱠鱧鱶鱸鳧鳬鳰鴉鴈鳫鴃鴆鴪鴦鶯鴣鴟鵄鴕鴒鵁鴿鴾鵆鵈"], +["ea40","鵝鵞鵤鵑鵐鵙鵲鶉鶇鶫鵯鵺鶚鶤鶩鶲鷄鷁鶻鶸鶺鷆鷏鷂鷙鷓鷸鷦鷭鷯鷽鸚鸛鸞鹵鹹鹽麁麈麋麌麒麕麑麝麥麩麸麪麭靡黌黎黏黐黔黜點黝黠黥黨黯"], +["ea80","黴黶黷黹黻黼黽鼇鼈皷鼕鼡鼬鼾齊齒齔齣齟齠齡齦齧齬齪齷齲齶龕龜龠堯槇遙瑤凜熙"], +["ed40","纊褜鍈銈蓜俉炻昱棈鋹曻彅丨仡仼伀伃伹佖侒侊侚侔俍偀倢俿倞偆偰偂傔僴僘兊兤冝冾凬刕劜劦勀勛匀匇匤卲厓厲叝﨎咜咊咩哿喆坙坥垬埈埇﨏"], +["ed80","塚增墲夋奓奛奝奣妤妺孖寀甯寘寬尞岦岺峵崧嵓﨑嵂嵭嶸嶹巐弡弴彧德忞恝悅悊惞惕愠惲愑愷愰憘戓抦揵摠撝擎敎昀昕昻昉昮昞昤晥晗晙晴晳暙暠暲暿曺朎朗杦枻桒柀栁桄棏﨓楨﨔榘槢樰橫橆橳橾櫢櫤毖氿汜沆汯泚洄涇浯涖涬淏淸淲淼渹湜渧渼溿澈澵濵瀅瀇瀨炅炫焏焄煜煆煇凞燁燾犱"], +["ee40","犾猤猪獷玽珉珖珣珒琇珵琦琪琩琮瑢璉璟甁畯皂皜皞皛皦益睆劯砡硎硤硺礰礼神祥禔福禛竑竧靖竫箞精絈絜綷綠緖繒罇羡羽茁荢荿菇菶葈蒴蕓蕙"], +["ee80","蕫﨟薰蘒﨡蠇裵訒訷詹誧誾諟諸諶譓譿賰賴贒赶﨣軏﨤逸遧郞都鄕鄧釚釗釞釭釮釤釥鈆鈐鈊鈺鉀鈼鉎鉙鉑鈹鉧銧鉷鉸鋧鋗鋙鋐﨧鋕鋠鋓錥錡鋻﨨錞鋿錝錂鍰鍗鎤鏆鏞鏸鐱鑅鑈閒隆﨩隝隯霳霻靃靍靏靑靕顗顥飯飼餧館馞驎髙髜魵魲鮏鮱鮻鰀鵰鵫鶴鸙黑"], +["eeef","ⅰ",9,"¬¦'""], +["f040","",62], +["f080","",124], +["f140","",62], +["f180","",124], +["f240","",62], +["f280","",124], +["f340","",62], +["f380","",124], +["f440","",62], +["f480","",124], +["f540","",62], +["f580","",124], +["f640","",62], +["f680","",124], +["f740","",62], +["f780","",124], +["f840","",62], +["f880","",124], +["f940",""], +["fa40","ⅰ",9,"Ⅰ",9,"¬¦'"㈱№℡∵纊褜鍈銈蓜俉炻昱棈鋹曻彅丨仡仼伀伃伹佖侒侊侚侔俍偀倢俿倞偆偰偂傔僴僘兊"], +["fa80","兤冝冾凬刕劜劦勀勛匀匇匤卲厓厲叝﨎咜咊咩哿喆坙坥垬埈埇﨏塚增墲夋奓奛奝奣妤妺孖寀甯寘寬尞岦岺峵崧嵓﨑嵂嵭嶸嶹巐弡弴彧德忞恝悅悊惞惕愠惲愑愷愰憘戓抦揵摠撝擎敎昀昕昻昉昮昞昤晥晗晙晴晳暙暠暲暿曺朎朗杦枻桒柀栁桄棏﨓楨﨔榘槢樰橫橆橳橾櫢櫤毖氿汜沆汯泚洄涇浯"], +["fb40","涖涬淏淸淲淼渹湜渧渼溿澈澵濵瀅瀇瀨炅炫焏焄煜煆煇凞燁燾犱犾猤猪獷玽珉珖珣珒琇珵琦琪琩琮瑢璉璟甁畯皂皜皞皛皦益睆劯砡硎硤硺礰礼神"], +["fb80","祥禔福禛竑竧靖竫箞精絈絜綷綠緖繒罇羡羽茁荢荿菇菶葈蒴蕓蕙蕫﨟薰蘒﨡蠇裵訒訷詹誧誾諟諸諶譓譿賰賴贒赶﨣軏﨤逸遧郞都鄕鄧釚釗釞釭釮釤釥鈆鈐鈊鈺鉀鈼鉎鉙鉑鈹鉧銧鉷鉸鋧鋗鋙鋐﨧鋕鋠鋓錥錡鋻﨨錞鋿錝錂鍰鍗鎤鏆鏞鏸鐱鑅鑈閒隆﨩隝隯霳霻靃靍靏靑靕顗顥飯飼餧館馞驎髙"], +["fc40","髜魵魲鮏鮱鮻鰀鵰鵫鶴鸙黑"] +] diff --git a/node_modules/body-parser/node_modules/iconv-lite/encodings/utf16.js b/node_modules/body-parser/node_modules/iconv-lite/encodings/utf16.js new file mode 100644 index 0000000..399f551 --- /dev/null +++ b/node_modules/body-parser/node_modules/iconv-lite/encodings/utf16.js @@ -0,0 +1,174 @@ +"use strict" + +// == UTF16-BE codec. ========================================================== + +exports.utf16be = Utf16BECodec; +function Utf16BECodec() { +} + +Utf16BECodec.prototype.encoder = Utf16BEEncoder; +Utf16BECodec.prototype.decoder = Utf16BEDecoder; +Utf16BECodec.prototype.bomAware = true; + + +// -- Encoding + +function Utf16BEEncoder() { +} + +Utf16BEEncoder.prototype.write = function(str) { + var buf = new Buffer(str, 'ucs2'); + for (var i = 0; i < buf.length; i += 2) { + var tmp = buf[i]; buf[i] = buf[i+1]; buf[i+1] = tmp; + } + return buf; +} + +Utf16BEEncoder.prototype.end = function() { +} + + +// -- Decoding + +function Utf16BEDecoder() { + this.overflowByte = -1; +} + +Utf16BEDecoder.prototype.write = function(buf) { + if (buf.length == 0) + return ''; + + var buf2 = new Buffer(buf.length + 1), + i = 0, j = 0; + + if (this.overflowByte !== -1) { + buf2[0] = buf[0]; + buf2[1] = this.overflowByte; + i = 1; j = 2; + } + + for (; i < buf.length-1; i += 2, j+= 2) { + buf2[j] = buf[i+1]; + buf2[j+1] = buf[i]; + } + + this.overflowByte = (i == buf.length-1) ? buf[buf.length-1] : -1; + + return buf2.slice(0, j).toString('ucs2'); +} + +Utf16BEDecoder.prototype.end = function() { +} + + +// == UTF-16 codec ============================================================= +// Decoder chooses automatically from UTF-16LE and UTF-16BE using BOM and space-based heuristic. +// Defaults to UTF-16LE, as it's prevalent and default in Node. +// http://en.wikipedia.org/wiki/UTF-16 and http://encoding.spec.whatwg.org/#utf-16le +// Decoder default can be changed: iconv.decode(buf, 'utf16', {defaultEncoding: 'utf-16be'}); + +// Encoder uses UTF-16LE and prepends BOM (which can be overridden with addBOM: false). + +exports.utf16 = Utf16Codec; +function Utf16Codec(codecOptions, iconv) { + this.iconv = iconv; +} + +Utf16Codec.prototype.encoder = Utf16Encoder; +Utf16Codec.prototype.decoder = Utf16Decoder; + + +// -- Encoding (pass-through) + +function Utf16Encoder(options, codec) { + options = options || {}; + if (options.addBOM === undefined) + options.addBOM = true; + this.encoder = codec.iconv.getEncoder('utf-16le', options); +} + +Utf16Encoder.prototype.write = function(str) { + return this.encoder.write(str); +} + +Utf16Encoder.prototype.end = function() { + return this.encoder.end(); +} + + +// -- Decoding + +function Utf16Decoder(options, codec) { + this.decoder = null; + this.initialBytes = []; + this.initialBytesLen = 0; + + this.options = options || {}; + this.iconv = codec.iconv; +} + +Utf16Decoder.prototype.write = function(buf) { + if (!this.decoder) { + // Codec is not chosen yet. Accumulate initial bytes. + this.initialBytes.push(buf); + this.initialBytesLen += buf.length; + + if (this.initialBytesLen < 16) // We need more bytes to use space heuristic (see below) + return ''; + + // We have enough bytes -> detect endianness. + var buf = Buffer.concat(this.initialBytes), + encoding = detectEncoding(buf, this.options.defaultEncoding); + this.decoder = this.iconv.getDecoder(encoding, this.options); + this.initialBytes.length = this.initialBytesLen = 0; + } + + return this.decoder.write(buf); +} + +Utf16Decoder.prototype.end = function() { + if (!this.decoder) { + var buf = Buffer.concat(this.initialBytes), + encoding = detectEncoding(buf, this.options.defaultEncoding); + this.decoder = this.iconv.getDecoder(encoding, this.options); + + var res = this.decoder.write(buf), + trail = this.decoder.end(); + + return trail ? (res + trail) : res; + } + return this.decoder.end(); +} + +function detectEncoding(buf, defaultEncoding) { + var enc = defaultEncoding || 'utf-16le'; + + if (buf.length >= 2) { + // Check BOM. + if (buf[0] == 0xFE && buf[1] == 0xFF) // UTF-16BE BOM + enc = 'utf-16be'; + else if (buf[0] == 0xFF && buf[1] == 0xFE) // UTF-16LE BOM + enc = 'utf-16le'; + else { + // No BOM found. Try to deduce encoding from initial content. + // Most of the time, the content has ASCII chars (U+00**), but the opposite (U+**00) is uncommon. + // So, we count ASCII as if it was LE or BE, and decide from that. + var asciiCharsLE = 0, asciiCharsBE = 0, // Counts of chars in both positions + _len = Math.min(buf.length - (buf.length % 2), 64); // Len is always even. + + for (var i = 0; i < _len; i += 2) { + if (buf[i] === 0 && buf[i+1] !== 0) asciiCharsBE++; + if (buf[i] !== 0 && buf[i+1] === 0) asciiCharsLE++; + } + + if (asciiCharsBE > asciiCharsLE) + enc = 'utf-16be'; + else if (asciiCharsBE < asciiCharsLE) + enc = 'utf-16le'; + } + } + + return enc; +} + + diff --git a/node_modules/body-parser/node_modules/iconv-lite/encodings/utf7.js b/node_modules/body-parser/node_modules/iconv-lite/encodings/utf7.js new file mode 100644 index 0000000..bab5099 --- /dev/null +++ b/node_modules/body-parser/node_modules/iconv-lite/encodings/utf7.js @@ -0,0 +1,289 @@ +"use strict" + +// UTF-7 codec, according to https://tools.ietf.org/html/rfc2152 +// See also below a UTF-7-IMAP codec, according to http://tools.ietf.org/html/rfc3501#section-5.1.3 + +exports.utf7 = Utf7Codec; +exports.unicode11utf7 = 'utf7'; // Alias UNICODE-1-1-UTF-7 +function Utf7Codec(codecOptions, iconv) { + this.iconv = iconv; +}; + +Utf7Codec.prototype.encoder = Utf7Encoder; +Utf7Codec.prototype.decoder = Utf7Decoder; +Utf7Codec.prototype.bomAware = true; + + +// -- Encoding + +var nonDirectChars = /[^A-Za-z0-9'\(\),-\.\/:\? \n\r\t]+/g; + +function Utf7Encoder(options, codec) { + this.iconv = codec.iconv; +} + +Utf7Encoder.prototype.write = function(str) { + // Naive implementation. + // Non-direct chars are encoded as "+-"; single "+" char is encoded as "+-". + return new Buffer(str.replace(nonDirectChars, function(chunk) { + return "+" + (chunk === '+' ? '' : + this.iconv.encode(chunk, 'utf16-be').toString('base64').replace(/=+$/, '')) + + "-"; + }.bind(this))); +} + +Utf7Encoder.prototype.end = function() { +} + + +// -- Decoding + +function Utf7Decoder(options, codec) { + this.iconv = codec.iconv; + this.inBase64 = false; + this.base64Accum = ''; +} + +var base64Regex = /[A-Za-z0-9\/+]/; +var base64Chars = []; +for (var i = 0; i < 256; i++) + base64Chars[i] = base64Regex.test(String.fromCharCode(i)); + +var plusChar = '+'.charCodeAt(0), + minusChar = '-'.charCodeAt(0), + andChar = '&'.charCodeAt(0); + +Utf7Decoder.prototype.write = function(buf) { + var res = "", lastI = 0, + inBase64 = this.inBase64, + base64Accum = this.base64Accum; + + // The decoder is more involved as we must handle chunks in stream. + + for (var i = 0; i < buf.length; i++) { + if (!inBase64) { // We're in direct mode. + // Write direct chars until '+' + if (buf[i] == plusChar) { + res += this.iconv.decode(buf.slice(lastI, i), "ascii"); // Write direct chars. + lastI = i+1; + inBase64 = true; + } + } else { // We decode base64. + if (!base64Chars[buf[i]]) { // Base64 ended. + if (i == lastI && buf[i] == minusChar) {// "+-" -> "+" + res += "+"; + } else { + var b64str = base64Accum + buf.slice(lastI, i).toString(); + res += this.iconv.decode(new Buffer(b64str, 'base64'), "utf16-be"); + } + + if (buf[i] != minusChar) // Minus is absorbed after base64. + i--; + + lastI = i+1; + inBase64 = false; + base64Accum = ''; + } + } + } + + if (!inBase64) { + res += this.iconv.decode(buf.slice(lastI), "ascii"); // Write direct chars. + } else { + var b64str = base64Accum + buf.slice(lastI).toString(); + + var canBeDecoded = b64str.length - (b64str.length % 8); // Minimal chunk: 2 quads -> 2x3 bytes -> 3 chars. + base64Accum = b64str.slice(canBeDecoded); // The rest will be decoded in future. + b64str = b64str.slice(0, canBeDecoded); + + res += this.iconv.decode(new Buffer(b64str, 'base64'), "utf16-be"); + } + + this.inBase64 = inBase64; + this.base64Accum = base64Accum; + + return res; +} + +Utf7Decoder.prototype.end = function() { + var res = ""; + if (this.inBase64 && this.base64Accum.length > 0) + res = this.iconv.decode(new Buffer(this.base64Accum, 'base64'), "utf16-be"); + + this.inBase64 = false; + this.base64Accum = ''; + return res; +} + + +// UTF-7-IMAP codec. +// RFC3501 Sec. 5.1.3 Modified UTF-7 (http://tools.ietf.org/html/rfc3501#section-5.1.3) +// Differences: +// * Base64 part is started by "&" instead of "+" +// * Direct characters are 0x20-0x7E, except "&" (0x26) +// * In Base64, "," is used instead of "/" +// * Base64 must not be used to represent direct characters. +// * No implicit shift back from Base64 (should always end with '-') +// * String must end in non-shifted position. +// * "-&" while in base64 is not allowed. + + +exports.utf7imap = Utf7IMAPCodec; +function Utf7IMAPCodec(codecOptions, iconv) { + this.iconv = iconv; +}; + +Utf7IMAPCodec.prototype.encoder = Utf7IMAPEncoder; +Utf7IMAPCodec.prototype.decoder = Utf7IMAPDecoder; +Utf7IMAPCodec.prototype.bomAware = true; + + +// -- Encoding + +function Utf7IMAPEncoder(options, codec) { + this.iconv = codec.iconv; + this.inBase64 = false; + this.base64Accum = new Buffer(6); + this.base64AccumIdx = 0; +} + +Utf7IMAPEncoder.prototype.write = function(str) { + var inBase64 = this.inBase64, + base64Accum = this.base64Accum, + base64AccumIdx = this.base64AccumIdx, + buf = new Buffer(str.length*5 + 10), bufIdx = 0; + + for (var i = 0; i < str.length; i++) { + var uChar = str.charCodeAt(i); + if (0x20 <= uChar && uChar <= 0x7E) { // Direct character or '&'. + if (inBase64) { + if (base64AccumIdx > 0) { + bufIdx += buf.write(base64Accum.slice(0, base64AccumIdx).toString('base64').replace(/\//g, ',').replace(/=+$/, ''), bufIdx); + base64AccumIdx = 0; + } + + buf[bufIdx++] = minusChar; // Write '-', then go to direct mode. + inBase64 = false; + } + + if (!inBase64) { + buf[bufIdx++] = uChar; // Write direct character + + if (uChar === andChar) // Ampersand -> '&-' + buf[bufIdx++] = minusChar; + } + + } else { // Non-direct character + if (!inBase64) { + buf[bufIdx++] = andChar; // Write '&', then go to base64 mode. + inBase64 = true; + } + if (inBase64) { + base64Accum[base64AccumIdx++] = uChar >> 8; + base64Accum[base64AccumIdx++] = uChar & 0xFF; + + if (base64AccumIdx == base64Accum.length) { + bufIdx += buf.write(base64Accum.toString('base64').replace(/\//g, ','), bufIdx); + base64AccumIdx = 0; + } + } + } + } + + this.inBase64 = inBase64; + this.base64AccumIdx = base64AccumIdx; + + return buf.slice(0, bufIdx); +} + +Utf7IMAPEncoder.prototype.end = function() { + var buf = new Buffer(10), bufIdx = 0; + if (this.inBase64) { + if (this.base64AccumIdx > 0) { + bufIdx += buf.write(this.base64Accum.slice(0, this.base64AccumIdx).toString('base64').replace(/\//g, ',').replace(/=+$/, ''), bufIdx); + this.base64AccumIdx = 0; + } + + buf[bufIdx++] = minusChar; // Write '-', then go to direct mode. + this.inBase64 = false; + } + + return buf.slice(0, bufIdx); +} + + +// -- Decoding + +function Utf7IMAPDecoder(options, codec) { + this.iconv = codec.iconv; + this.inBase64 = false; + this.base64Accum = ''; +} + +var base64IMAPChars = base64Chars.slice(); +base64IMAPChars[','.charCodeAt(0)] = true; + +Utf7IMAPDecoder.prototype.write = function(buf) { + var res = "", lastI = 0, + inBase64 = this.inBase64, + base64Accum = this.base64Accum; + + // The decoder is more involved as we must handle chunks in stream. + // It is forgiving, closer to standard UTF-7 (for example, '-' is optional at the end). + + for (var i = 0; i < buf.length; i++) { + if (!inBase64) { // We're in direct mode. + // Write direct chars until '&' + if (buf[i] == andChar) { + res += this.iconv.decode(buf.slice(lastI, i), "ascii"); // Write direct chars. + lastI = i+1; + inBase64 = true; + } + } else { // We decode base64. + if (!base64IMAPChars[buf[i]]) { // Base64 ended. + if (i == lastI && buf[i] == minusChar) { // "&-" -> "&" + res += "&"; + } else { + var b64str = base64Accum + buf.slice(lastI, i).toString().replace(/,/g, '/'); + res += this.iconv.decode(new Buffer(b64str, 'base64'), "utf16-be"); + } + + if (buf[i] != minusChar) // Minus may be absorbed after base64. + i--; + + lastI = i+1; + inBase64 = false; + base64Accum = ''; + } + } + } + + if (!inBase64) { + res += this.iconv.decode(buf.slice(lastI), "ascii"); // Write direct chars. + } else { + var b64str = base64Accum + buf.slice(lastI).toString().replace(/,/g, '/'); + + var canBeDecoded = b64str.length - (b64str.length % 8); // Minimal chunk: 2 quads -> 2x3 bytes -> 3 chars. + base64Accum = b64str.slice(canBeDecoded); // The rest will be decoded in future. + b64str = b64str.slice(0, canBeDecoded); + + res += this.iconv.decode(new Buffer(b64str, 'base64'), "utf16-be"); + } + + this.inBase64 = inBase64; + this.base64Accum = base64Accum; + + return res; +} + +Utf7IMAPDecoder.prototype.end = function() { + var res = ""; + if (this.inBase64 && this.base64Accum.length > 0) + res = this.iconv.decode(new Buffer(this.base64Accum, 'base64'), "utf16-be"); + + this.inBase64 = false; + this.base64Accum = ''; + return res; +} + + diff --git a/node_modules/body-parser/node_modules/iconv-lite/lib/bom-handling.js b/node_modules/body-parser/node_modules/iconv-lite/lib/bom-handling.js new file mode 100644 index 0000000..3f0ed93 --- /dev/null +++ b/node_modules/body-parser/node_modules/iconv-lite/lib/bom-handling.js @@ -0,0 +1,52 @@ +"use strict" + +var BOMChar = '\uFEFF'; + +exports.PrependBOM = PrependBOMWrapper +function PrependBOMWrapper(encoder, options) { + this.encoder = encoder; + this.addBOM = true; +} + +PrependBOMWrapper.prototype.write = function(str) { + if (this.addBOM) { + str = BOMChar + str; + this.addBOM = false; + } + + return this.encoder.write(str); +} + +PrependBOMWrapper.prototype.end = function() { + return this.encoder.end(); +} + + +//------------------------------------------------------------------------------ + +exports.StripBOM = StripBOMWrapper; +function StripBOMWrapper(decoder, options) { + this.decoder = decoder; + this.pass = false; + this.options = options || {}; +} + +StripBOMWrapper.prototype.write = function(buf) { + var res = this.decoder.write(buf); + if (this.pass || !res) + return res; + + if (res[0] === BOMChar) { + res = res.slice(1); + if (typeof this.options.stripBOM === 'function') + this.options.stripBOM(); + } + + this.pass = true; + return res; +} + +StripBOMWrapper.prototype.end = function() { + return this.decoder.end(); +} + diff --git a/node_modules/body-parser/node_modules/iconv-lite/lib/extend-node.js b/node_modules/body-parser/node_modules/iconv-lite/lib/extend-node.js new file mode 100644 index 0000000..1d8c953 --- /dev/null +++ b/node_modules/body-parser/node_modules/iconv-lite/lib/extend-node.js @@ -0,0 +1,214 @@ +"use strict" + +// == Extend Node primitives to use iconv-lite ================================= + +module.exports = function (iconv) { + var original = undefined; // Place to keep original methods. + + // Node authors rewrote Buffer internals to make it compatible with + // Uint8Array and we cannot patch key functions since then. + iconv.supportsNodeEncodingsExtension = !(new Buffer(0) instanceof Uint8Array); + + iconv.extendNodeEncodings = function extendNodeEncodings() { + if (original) return; + original = {}; + + if (!iconv.supportsNodeEncodingsExtension) { + console.error("ACTION NEEDED: require('iconv-lite').extendNodeEncodings() is not supported in your version of Node"); + console.error("See more info at https://github.com/ashtuchkin/iconv-lite/wiki/Node-v4-compatibility"); + return; + } + + var nodeNativeEncodings = { + 'hex': true, 'utf8': true, 'utf-8': true, 'ascii': true, 'binary': true, + 'base64': true, 'ucs2': true, 'ucs-2': true, 'utf16le': true, 'utf-16le': true, + }; + + Buffer.isNativeEncoding = function(enc) { + return enc && nodeNativeEncodings[enc.toLowerCase()]; + } + + // -- SlowBuffer ----------------------------------------------------------- + var SlowBuffer = require('buffer').SlowBuffer; + + original.SlowBufferToString = SlowBuffer.prototype.toString; + SlowBuffer.prototype.toString = function(encoding, start, end) { + encoding = String(encoding || 'utf8').toLowerCase(); + + // Use native conversion when possible + if (Buffer.isNativeEncoding(encoding)) + return original.SlowBufferToString.call(this, encoding, start, end); + + // Otherwise, use our decoding method. + if (typeof start == 'undefined') start = 0; + if (typeof end == 'undefined') end = this.length; + return iconv.decode(this.slice(start, end), encoding); + } + + original.SlowBufferWrite = SlowBuffer.prototype.write; + SlowBuffer.prototype.write = function(string, offset, length, encoding) { + // Support both (string, offset, length, encoding) + // and the legacy (string, encoding, offset, length) + if (isFinite(offset)) { + if (!isFinite(length)) { + encoding = length; + length = undefined; + } + } else { // legacy + var swap = encoding; + encoding = offset; + offset = length; + length = swap; + } + + offset = +offset || 0; + var remaining = this.length - offset; + if (!length) { + length = remaining; + } else { + length = +length; + if (length > remaining) { + length = remaining; + } + } + encoding = String(encoding || 'utf8').toLowerCase(); + + // Use native conversion when possible + if (Buffer.isNativeEncoding(encoding)) + return original.SlowBufferWrite.call(this, string, offset, length, encoding); + + if (string.length > 0 && (length < 0 || offset < 0)) + throw new RangeError('attempt to write beyond buffer bounds'); + + // Otherwise, use our encoding method. + var buf = iconv.encode(string, encoding); + if (buf.length < length) length = buf.length; + buf.copy(this, offset, 0, length); + return length; + } + + // -- Buffer --------------------------------------------------------------- + + original.BufferIsEncoding = Buffer.isEncoding; + Buffer.isEncoding = function(encoding) { + return Buffer.isNativeEncoding(encoding) || iconv.encodingExists(encoding); + } + + original.BufferByteLength = Buffer.byteLength; + Buffer.byteLength = SlowBuffer.byteLength = function(str, encoding) { + encoding = String(encoding || 'utf8').toLowerCase(); + + // Use native conversion when possible + if (Buffer.isNativeEncoding(encoding)) + return original.BufferByteLength.call(this, str, encoding); + + // Slow, I know, but we don't have a better way yet. + return iconv.encode(str, encoding).length; + } + + original.BufferToString = Buffer.prototype.toString; + Buffer.prototype.toString = function(encoding, start, end) { + encoding = String(encoding || 'utf8').toLowerCase(); + + // Use native conversion when possible + if (Buffer.isNativeEncoding(encoding)) + return original.BufferToString.call(this, encoding, start, end); + + // Otherwise, use our decoding method. + if (typeof start == 'undefined') start = 0; + if (typeof end == 'undefined') end = this.length; + return iconv.decode(this.slice(start, end), encoding); + } + + original.BufferWrite = Buffer.prototype.write; + Buffer.prototype.write = function(string, offset, length, encoding) { + var _offset = offset, _length = length, _encoding = encoding; + // Support both (string, offset, length, encoding) + // and the legacy (string, encoding, offset, length) + if (isFinite(offset)) { + if (!isFinite(length)) { + encoding = length; + length = undefined; + } + } else { // legacy + var swap = encoding; + encoding = offset; + offset = length; + length = swap; + } + + encoding = String(encoding || 'utf8').toLowerCase(); + + // Use native conversion when possible + if (Buffer.isNativeEncoding(encoding)) + return original.BufferWrite.call(this, string, _offset, _length, _encoding); + + offset = +offset || 0; + var remaining = this.length - offset; + if (!length) { + length = remaining; + } else { + length = +length; + if (length > remaining) { + length = remaining; + } + } + + if (string.length > 0 && (length < 0 || offset < 0)) + throw new RangeError('attempt to write beyond buffer bounds'); + + // Otherwise, use our encoding method. + var buf = iconv.encode(string, encoding); + if (buf.length < length) length = buf.length; + buf.copy(this, offset, 0, length); + return length; + + // TODO: Set _charsWritten. + } + + + // -- Readable ------------------------------------------------------------- + if (iconv.supportsStreams) { + var Readable = require('stream').Readable; + + original.ReadableSetEncoding = Readable.prototype.setEncoding; + Readable.prototype.setEncoding = function setEncoding(enc, options) { + // Use our own decoder, it has the same interface. + // We cannot use original function as it doesn't handle BOM-s. + this._readableState.decoder = iconv.getDecoder(enc, options); + this._readableState.encoding = enc; + } + + Readable.prototype.collect = iconv._collect; + } + } + + // Remove iconv-lite Node primitive extensions. + iconv.undoExtendNodeEncodings = function undoExtendNodeEncodings() { + if (!iconv.supportsNodeEncodingsExtension) + return; + if (!original) + throw new Error("require('iconv-lite').undoExtendNodeEncodings(): Nothing to undo; extendNodeEncodings() is not called.") + + delete Buffer.isNativeEncoding; + + var SlowBuffer = require('buffer').SlowBuffer; + + SlowBuffer.prototype.toString = original.SlowBufferToString; + SlowBuffer.prototype.write = original.SlowBufferWrite; + + Buffer.isEncoding = original.BufferIsEncoding; + Buffer.byteLength = original.BufferByteLength; + Buffer.prototype.toString = original.BufferToString; + Buffer.prototype.write = original.BufferWrite; + + if (iconv.supportsStreams) { + var Readable = require('stream').Readable; + + Readable.prototype.setEncoding = original.ReadableSetEncoding; + delete Readable.prototype.collect; + } + + original = undefined; + } +} diff --git a/node_modules/body-parser/node_modules/iconv-lite/lib/index.js b/node_modules/body-parser/node_modules/iconv-lite/lib/index.js new file mode 100644 index 0000000..ac1403c --- /dev/null +++ b/node_modules/body-parser/node_modules/iconv-lite/lib/index.js @@ -0,0 +1,141 @@ +"use strict" + +var bomHandling = require('./bom-handling'), + iconv = module.exports; + +// All codecs and aliases are kept here, keyed by encoding name/alias. +// They are lazy loaded in `iconv.getCodec` from `encodings/index.js`. +iconv.encodings = null; + +// Characters emitted in case of error. +iconv.defaultCharUnicode = '�'; +iconv.defaultCharSingleByte = '?'; + +// Public API. +iconv.encode = function encode(str, encoding, options) { + str = "" + (str || ""); // Ensure string. + + var encoder = iconv.getEncoder(encoding, options); + + var res = encoder.write(str); + var trail = encoder.end(); + + return (trail && trail.length > 0) ? Buffer.concat([res, trail]) : res; +} + +iconv.decode = function decode(buf, encoding, options) { + if (typeof buf === 'string') { + if (!iconv.skipDecodeWarning) { + console.error('Iconv-lite warning: decode()-ing strings is deprecated. Refer to https://github.com/ashtuchkin/iconv-lite/wiki/Use-Buffers-when-decoding'); + iconv.skipDecodeWarning = true; + } + + buf = new Buffer("" + (buf || ""), "binary"); // Ensure buffer. + } + + var decoder = iconv.getDecoder(encoding, options); + + var res = decoder.write(buf); + var trail = decoder.end(); + + return trail ? (res + trail) : res; +} + +iconv.encodingExists = function encodingExists(enc) { + try { + iconv.getCodec(enc); + return true; + } catch (e) { + return false; + } +} + +// Legacy aliases to convert functions +iconv.toEncoding = iconv.encode; +iconv.fromEncoding = iconv.decode; + +// Search for a codec in iconv.encodings. Cache codec data in iconv._codecDataCache. +iconv._codecDataCache = {}; +iconv.getCodec = function getCodec(encoding) { + if (!iconv.encodings) + iconv.encodings = require("../encodings"); // Lazy load all encoding definitions. + + // Canonicalize encoding name: strip all non-alphanumeric chars and appended year. + var enc = (''+encoding).toLowerCase().replace(/[^0-9a-z]|:\d{4}$/g, ""); + + // Traverse iconv.encodings to find actual codec. + var codecOptions = {}; + while (true) { + var codec = iconv._codecDataCache[enc]; + if (codec) + return codec; + + var codecDef = iconv.encodings[enc]; + + switch (typeof codecDef) { + case "string": // Direct alias to other encoding. + enc = codecDef; + break; + + case "object": // Alias with options. Can be layered. + for (var key in codecDef) + codecOptions[key] = codecDef[key]; + + if (!codecOptions.encodingName) + codecOptions.encodingName = enc; + + enc = codecDef.type; + break; + + case "function": // Codec itself. + if (!codecOptions.encodingName) + codecOptions.encodingName = enc; + + // The codec function must load all tables and return object with .encoder and .decoder methods. + // It'll be called only once (for each different options object). + codec = new codecDef(codecOptions, iconv); + + iconv._codecDataCache[codecOptions.encodingName] = codec; // Save it to be reused later. + return codec; + + default: + throw new Error("Encoding not recognized: '" + encoding + "' (searched as: '"+enc+"')"); + } + } +} + +iconv.getEncoder = function getEncoder(encoding, options) { + var codec = iconv.getCodec(encoding), + encoder = new codec.encoder(options, codec); + + if (codec.bomAware && options && options.addBOM) + encoder = new bomHandling.PrependBOM(encoder, options); + + return encoder; +} + +iconv.getDecoder = function getDecoder(encoding, options) { + var codec = iconv.getCodec(encoding), + decoder = new codec.decoder(options, codec); + + if (codec.bomAware && !(options && options.stripBOM === false)) + decoder = new bomHandling.StripBOM(decoder, options); + + return decoder; +} + + +// Load extensions in Node. All of them are omitted in Browserify build via 'browser' field in package.json. +var nodeVer = typeof process !== 'undefined' && process.versions && process.versions.node; +if (nodeVer) { + + // Load streaming support in Node v0.10+ + var nodeVerArr = nodeVer.split(".").map(Number); + if (nodeVerArr[0] > 0 || nodeVerArr[1] >= 10) { + require("./streams")(iconv); + } + + // Load Node primitive extensions. + require("./extend-node")(iconv); +} + diff --git a/node_modules/body-parser/node_modules/iconv-lite/lib/streams.js b/node_modules/body-parser/node_modules/iconv-lite/lib/streams.js new file mode 100644 index 0000000..c95b26c --- /dev/null +++ b/node_modules/body-parser/node_modules/iconv-lite/lib/streams.js @@ -0,0 +1,120 @@ +"use strict" + +var Transform = require("stream").Transform; + + +// == Exports ================================================================== +module.exports = function(iconv) { + + // Additional Public API. + iconv.encodeStream = function encodeStream(encoding, options) { + return new IconvLiteEncoderStream(iconv.getEncoder(encoding, options), options); + } + + iconv.decodeStream = function decodeStream(encoding, options) { + return new IconvLiteDecoderStream(iconv.getDecoder(encoding, options), options); + } + + iconv.supportsStreams = true; + + + // Not published yet. + iconv.IconvLiteEncoderStream = IconvLiteEncoderStream; + iconv.IconvLiteDecoderStream = IconvLiteDecoderStream; + iconv._collect = IconvLiteDecoderStream.prototype.collect; +}; + + +// == Encoder stream ======================================================= +function IconvLiteEncoderStream(conv, options) { + this.conv = conv; + options = options || {}; + options.decodeStrings = false; // We accept only strings, so we don't need to decode them. + Transform.call(this, options); +} + +IconvLiteEncoderStream.prototype = Object.create(Transform.prototype, { + constructor: { value: IconvLiteEncoderStream } +}); + +IconvLiteEncoderStream.prototype._transform = function(chunk, encoding, done) { + if (typeof chunk != 'string') + return done(new Error("Iconv encoding stream needs strings as its input.")); + try { + var res = this.conv.write(chunk); + if (res && res.length) this.push(res); + done(); + } + catch (e) { + done(e); + } +} + +IconvLiteEncoderStream.prototype._flush = function(done) { + try { + var res = this.conv.end(); + if (res && res.length) this.push(res); + done(); + } + catch (e) { + done(e); + } +} + +IconvLiteEncoderStream.prototype.collect = function(cb) { + var chunks = []; + this.on('error', cb); + this.on('data', function(chunk) { chunks.push(chunk); }); + this.on('end', function() { + cb(null, Buffer.concat(chunks)); + }); + return this; +} + + +// == Decoder stream ======================================================= +function IconvLiteDecoderStream(conv, options) { + this.conv = conv; + options = options || {}; + options.encoding = this.encoding = 'utf8'; // We output strings. + Transform.call(this, options); +} + +IconvLiteDecoderStream.prototype = Object.create(Transform.prototype, { + constructor: { value: IconvLiteDecoderStream } +}); + +IconvLiteDecoderStream.prototype._transform = function(chunk, encoding, done) { + if (!Buffer.isBuffer(chunk)) + return done(new Error("Iconv decoding stream needs buffers as its input.")); + try { + var res = this.conv.write(chunk); + if (res && res.length) this.push(res, this.encoding); + done(); + } + catch (e) { + done(e); + } +} + +IconvLiteDecoderStream.prototype._flush = function(done) { + try { + var res = this.conv.end(); + if (res && res.length) this.push(res, this.encoding); + done(); + } + catch (e) { + done(e); + } +} + +IconvLiteDecoderStream.prototype.collect = function(cb) { + var res = ''; + this.on('error', cb); + this.on('data', function(chunk) { res += chunk; }); + this.on('end', function() { + cb(null, res); + }); + return this; +} + diff --git a/node_modules/body-parser/node_modules/iconv-lite/package.json b/node_modules/body-parser/node_modules/iconv-lite/package.json new file mode 100644 index 0000000..01d9203 --- /dev/null +++ b/node_modules/body-parser/node_modules/iconv-lite/package.json @@ -0,0 +1,119 @@ +{ + "name": "iconv-lite", + "description": "Convert character encodings in pure javascript.", + "version": "0.4.13", + "license": "MIT", + "keywords": [ + "iconv", + "convert", + "charset", + "icu" + ], + "author": { + "name": "Alexander Shtuchkin", + "email": "ashtuchkin@gmail.com" + }, + "contributors": [ + { + "name": "Jinwu Zhan", + "url": "https://github.com/jenkinv" + }, + { + "name": "Adamansky Anton", + "url": "https://github.com/adamansky" + }, + { + "name": "George Stagas", + "url": "https://github.com/stagas" + }, + { + "name": "Mike D Pilsbury", + "url": "https://github.com/pekim" + }, + { + "name": "Niggler", + "url": "https://github.com/Niggler" + }, + { + "name": "wychi", + "url": "https://github.com/wychi" + }, + { + "name": "David Kuo", + "url": "https://github.com/david50407" + }, + { + "name": "ChangZhuo Chen", + "url": "https://github.com/czchen" + }, + { + "name": "Lee Treveil", + "url": "https://github.com/leetreveil" + }, + { + "name": "Brian White", + "url": "https://github.com/mscdex" + }, + { + "name": "Mithgol", + "url": "https://github.com/Mithgol" + }, + { + "name": "Nazar Leush", + "url": "https://github.com/nleush" + } + ], + "main": "./lib/index.js", + "homepage": "https://github.com/ashtuchkin/iconv-lite", + "bugs": { + "url": "https://github.com/ashtuchkin/iconv-lite/issues" + }, + "repository": { + "type": "git", + "url": "git://github.com/ashtuchkin/iconv-lite.git" + }, + "engines": { + "node": ">=0.8.0" + }, + "scripts": { + "coverage": "istanbul cover _mocha -- --grep .", + "coverage-open": "open coverage/lcov-report/index.html", + "test": "mocha --reporter spec --grep ." + }, + "browser": { + "./extend-node": false, + "./streams": false + }, + "devDependencies": { + "mocha": "*", + "request": "2.47", + "unorm": "*", + "errto": "*", + "async": "*", + "istanbul": "*", + "iconv": "2.1" + }, + "gitHead": "f5ec51b1e7dd1477a3570824960641eebdc5fbc6", + "_id": "iconv-lite@0.4.13", + "_shasum": "1f88aba4ab0b1508e8312acc39345f36e992e2f2", + "_from": "iconv-lite@0.4.13", + "_npmVersion": "2.14.4", + "_nodeVersion": "4.1.1", + "_npmUser": { + "name": "ashtuchkin", + "email": "ashtuchkin@gmail.com" + }, + "maintainers": [ + { + "name": "ashtuchkin", + "email": "ashtuchkin@gmail.com" + } + ], + "dist": { + "shasum": "1f88aba4ab0b1508e8312acc39345f36e992e2f2", + "tarball": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.13.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.13.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/body-parser/node_modules/on-finished/HISTORY.md b/node_modules/body-parser/node_modules/on-finished/HISTORY.md new file mode 100644 index 0000000..98ff0e9 --- /dev/null +++ b/node_modules/body-parser/node_modules/on-finished/HISTORY.md @@ -0,0 +1,88 @@ +2.3.0 / 2015-05-26 +================== + + * Add defined behavior for HTTP `CONNECT` requests + * Add defined behavior for HTTP `Upgrade` requests + * deps: ee-first@1.1.1 + +2.2.1 / 2015-04-22 +================== + + * Fix `isFinished(req)` when data buffered + +2.2.0 / 2014-12-22 +================== + + * Add message object to callback arguments + +2.1.1 / 2014-10-22 +================== + + * Fix handling of pipelined requests + +2.1.0 / 2014-08-16 +================== + + * Check if `socket` is detached + * Return `undefined` for `isFinished` if state unknown + +2.0.0 / 2014-08-16 +================== + + * Add `isFinished` function + * Move to `jshttp` organization + * Remove support for plain socket argument + * Rename to `on-finished` + * Support both `req` and `res` as arguments + * deps: ee-first@1.0.5 + +1.2.2 / 2014-06-10 +================== + + * Reduce listeners added to emitters + - avoids "event emitter leak" warnings when used multiple times on same request + +1.2.1 / 2014-06-08 +================== + + * Fix returned value when already finished + +1.2.0 / 2014-06-05 +================== + + * Call callback when called on already-finished socket + +1.1.4 / 2014-05-27 +================== + + * Support node.js 0.8 + +1.1.3 / 2014-04-30 +================== + + * Make sure errors passed as instanceof `Error` + +1.1.2 / 2014-04-18 +================== + + * Default the `socket` to passed-in object + +1.1.1 / 2014-01-16 +================== + + * Rename module to `finished` + +1.1.0 / 2013-12-25 +================== + + * Call callback when called on already-errored socket + +1.0.1 / 2013-12-20 +================== + + * Actually pass the error to the callback + +1.0.0 / 2013-12-20 +================== + + * Initial release diff --git a/node_modules/body-parser/node_modules/on-finished/LICENSE b/node_modules/body-parser/node_modules/on-finished/LICENSE new file mode 100644 index 0000000..5931fd2 --- /dev/null +++ b/node_modules/body-parser/node_modules/on-finished/LICENSE @@ -0,0 +1,23 @@ +(The MIT License) + +Copyright (c) 2013 Jonathan Ong +Copyright (c) 2014 Douglas Christopher Wilson + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/body-parser/node_modules/on-finished/README.md b/node_modules/body-parser/node_modules/on-finished/README.md new file mode 100644 index 0000000..a0e1157 --- /dev/null +++ b/node_modules/body-parser/node_modules/on-finished/README.md @@ -0,0 +1,154 @@ +# on-finished + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Node.js Version][node-version-image]][node-version-url] +[![Build Status][travis-image]][travis-url] +[![Test Coverage][coveralls-image]][coveralls-url] + +Execute a callback when a HTTP request closes, finishes, or errors. + +## Install + +```sh +$ npm install on-finished +``` + +## API + +```js +var onFinished = require('on-finished') +``` + +### onFinished(res, listener) + +Attach a listener to listen for the response to finish. The listener will +be invoked only once when the response finished. If the response finished +to an error, the first argument will contain the error. If the response +has already finished, the listener will be invoked. + +Listening to the end of a response would be used to close things associated +with the response, like open files. + +Listener is invoked as `listener(err, res)`. + +```js +onFinished(res, function (err, res) { + // clean up open fds, etc. + // err contains the error is request error'd +}) +``` + +### onFinished(req, listener) + +Attach a listener to listen for the request to finish. The listener will +be invoked only once when the request finished. If the request finished +to an error, the first argument will contain the error. If the request +has already finished, the listener will be invoked. + +Listening to the end of a request would be used to know when to continue +after reading the data. + +Listener is invoked as `listener(err, req)`. + +```js +var data = '' + +req.setEncoding('utf8') +res.on('data', function (str) { + data += str +}) + +onFinished(req, function (err, req) { + // data is read unless there is err +}) +``` + +### onFinished.isFinished(res) + +Determine if `res` is already finished. This would be useful to check and +not even start certain operations if the response has already finished. + +### onFinished.isFinished(req) + +Determine if `req` is already finished. This would be useful to check and +not even start certain operations if the request has already finished. + +## Special Node.js requests + +### HTTP CONNECT method + +The meaning of the `CONNECT` method from RFC 7231, section 4.3.6: + +> The CONNECT method requests that the recipient establish a tunnel to +> the destination origin server identified by the request-target and, +> if successful, thereafter restrict its behavior to blind forwarding +> of packets, in both directions, until the tunnel is closed. Tunnels +> are commonly used to create an end-to-end virtual connection, through +> one or more proxies, which can then be secured using TLS (Transport +> Layer Security, [RFC5246]). + +In Node.js, these request objects come from the `'connect'` event on +the HTTP server. + +When this module is used on a HTTP `CONNECT` request, the request is +considered "finished" immediately, **due to limitations in the Node.js +interface**. This means if the `CONNECT` request contains a request entity, +the request will be considered "finished" even before it has been read. + +There is no such thing as a response object to a `CONNECT` request in +Node.js, so there is no support for for one. + +### HTTP Upgrade request + +The meaning of the `Upgrade` header from RFC 7230, section 6.1: + +> The "Upgrade" header field is intended to provide a simple mechanism +> for transitioning from HTTP/1.1 to some other protocol on the same +> connection. + +In Node.js, these request objects come from the `'upgrade'` event on +the HTTP server. + +When this module is used on a HTTP request with an `Upgrade` header, the +request is considered "finished" immediately, **due to limitations in the +Node.js interface**. This means if the `Upgrade` request contains a request +entity, the request will be considered "finished" even before it has been +read. + +There is no such thing as a response object to a `Upgrade` request in +Node.js, so there is no support for for one. + +## Example + +The following code ensures that file descriptors are always closed +once the response finishes. + +```js +var destroy = require('destroy') +var http = require('http') +var onFinished = require('on-finished') + +http.createServer(function onRequest(req, res) { + var stream = fs.createReadStream('package.json') + stream.pipe(res) + onFinished(res, function (err) { + destroy(stream) + }) +}) +``` + +## License + +[MIT](LICENSE) + +[npm-image]: https://img.shields.io/npm/v/on-finished.svg +[npm-url]: https://npmjs.org/package/on-finished +[node-version-image]: https://img.shields.io/node/v/on-finished.svg +[node-version-url]: http://nodejs.org/download/ +[travis-image]: https://img.shields.io/travis/jshttp/on-finished/master.svg +[travis-url]: https://travis-ci.org/jshttp/on-finished +[coveralls-image]: https://img.shields.io/coveralls/jshttp/on-finished/master.svg +[coveralls-url]: https://coveralls.io/r/jshttp/on-finished?branch=master +[downloads-image]: https://img.shields.io/npm/dm/on-finished.svg +[downloads-url]: https://npmjs.org/package/on-finished diff --git a/node_modules/body-parser/node_modules/on-finished/index.js b/node_modules/body-parser/node_modules/on-finished/index.js new file mode 100644 index 0000000..9abd98f --- /dev/null +++ b/node_modules/body-parser/node_modules/on-finished/index.js @@ -0,0 +1,196 @@ +/*! + * on-finished + * Copyright(c) 2013 Jonathan Ong + * Copyright(c) 2014 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module exports. + * @public + */ + +module.exports = onFinished +module.exports.isFinished = isFinished + +/** + * Module dependencies. + * @private + */ + +var first = require('ee-first') + +/** + * Variables. + * @private + */ + +/* istanbul ignore next */ +var defer = typeof setImmediate === 'function' + ? setImmediate + : function(fn){ process.nextTick(fn.bind.apply(fn, arguments)) } + +/** + * Invoke callback when the response has finished, useful for + * cleaning up resources afterwards. + * + * @param {object} msg + * @param {function} listener + * @return {object} + * @public + */ + +function onFinished(msg, listener) { + if (isFinished(msg) !== false) { + defer(listener, null, msg) + return msg + } + + // attach the listener to the message + attachListener(msg, listener) + + return msg +} + +/** + * Determine if message is already finished. + * + * @param {object} msg + * @return {boolean} + * @public + */ + +function isFinished(msg) { + var socket = msg.socket + + if (typeof msg.finished === 'boolean') { + // OutgoingMessage + return Boolean(msg.finished || (socket && !socket.writable)) + } + + if (typeof msg.complete === 'boolean') { + // IncomingMessage + return Boolean(msg.upgrade || !socket || !socket.readable || (msg.complete && !msg.readable)) + } + + // don't know + return undefined +} + +/** + * Attach a finished listener to the message. + * + * @param {object} msg + * @param {function} callback + * @private + */ + +function attachFinishedListener(msg, callback) { + var eeMsg + var eeSocket + var finished = false + + function onFinish(error) { + eeMsg.cancel() + eeSocket.cancel() + + finished = true + callback(error) + } + + // finished on first message event + eeMsg = eeSocket = first([[msg, 'end', 'finish']], onFinish) + + function onSocket(socket) { + // remove listener + msg.removeListener('socket', onSocket) + + if (finished) return + if (eeMsg !== eeSocket) return + + // finished on first socket event + eeSocket = first([[socket, 'error', 'close']], onFinish) + } + + if (msg.socket) { + // socket already assigned + onSocket(msg.socket) + return + } + + // wait for socket to be assigned + msg.on('socket', onSocket) + + if (msg.socket === undefined) { + // node.js 0.8 patch + patchAssignSocket(msg, onSocket) + } +} + +/** + * Attach the listener to the message. + * + * @param {object} msg + * @return {function} + * @private + */ + +function attachListener(msg, listener) { + var attached = msg.__onFinished + + // create a private single listener with queue + if (!attached || !attached.queue) { + attached = msg.__onFinished = createListener(msg) + attachFinishedListener(msg, attached) + } + + attached.queue.push(listener) +} + +/** + * Create listener on message. + * + * @param {object} msg + * @return {function} + * @private + */ + +function createListener(msg) { + function listener(err) { + if (msg.__onFinished === listener) msg.__onFinished = null + if (!listener.queue) return + + var queue = listener.queue + listener.queue = null + + for (var i = 0; i < queue.length; i++) { + queue[i](err, msg) + } + } + + listener.queue = [] + + return listener +} + +/** + * Patch ServerResponse.prototype.assignSocket for node.js 0.8. + * + * @param {ServerResponse} res + * @param {function} callback + * @private + */ + +function patchAssignSocket(res, callback) { + var assignSocket = res.assignSocket + + if (typeof assignSocket !== 'function') return + + // res.on('socket', callback) is broken in 0.8 + res.assignSocket = function _assignSocket(socket) { + assignSocket.call(this, socket) + callback(socket) + } +} diff --git a/node_modules/body-parser/node_modules/on-finished/node_modules/ee-first/LICENSE b/node_modules/body-parser/node_modules/on-finished/node_modules/ee-first/LICENSE new file mode 100644 index 0000000..a7ae8ee --- /dev/null +++ b/node_modules/body-parser/node_modules/on-finished/node_modules/ee-first/LICENSE @@ -0,0 +1,22 @@ + +The MIT License (MIT) + +Copyright (c) 2014 Jonathan Ong me@jongleberry.com + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. diff --git a/node_modules/body-parser/node_modules/on-finished/node_modules/ee-first/README.md b/node_modules/body-parser/node_modules/on-finished/node_modules/ee-first/README.md new file mode 100644 index 0000000..cbd2478 --- /dev/null +++ b/node_modules/body-parser/node_modules/on-finished/node_modules/ee-first/README.md @@ -0,0 +1,80 @@ +# EE First + +[![NPM version][npm-image]][npm-url] +[![Build status][travis-image]][travis-url] +[![Test coverage][coveralls-image]][coveralls-url] +[![License][license-image]][license-url] +[![Downloads][downloads-image]][downloads-url] +[![Gittip][gittip-image]][gittip-url] + +Get the first event in a set of event emitters and event pairs, +then clean up after itself. + +## Install + +```sh +$ npm install ee-first +``` + +## API + +```js +var first = require('ee-first') +``` + +### first(arr, listener) + +Invoke `listener` on the first event from the list specified in `arr`. `arr` is +an array of arrays, with each array in the format `[ee, ...event]`. `listener` +will be called only once, the first time any of the given events are emitted. If +`error` is one of the listened events, then if that fires first, the `listener` +will be given the `err` argument. + +The `listener` is invoked as `listener(err, ee, event, args)`, where `err` is the +first argument emitted from an `error` event, if applicable; `ee` is the event +emitter that fired; `event` is the string event name that fired; and `args` is an +array of the arguments that were emitted on the event. + +```js +var ee1 = new EventEmitter() +var ee2 = new EventEmitter() + +first([ + [ee1, 'close', 'end', 'error'], + [ee2, 'error'] +], function (err, ee, event, args) { + // listener invoked +}) +``` + +#### .cancel() + +The group of listeners can be cancelled before being invoked and have all the event +listeners removed from the underlying event emitters. + +```js +var thunk = first([ + [ee1, 'close', 'end', 'error'], + [ee2, 'error'] +], function (err, ee, event, args) { + // listener invoked +}) + +// cancel and clean up +thunk.cancel() +``` + +[npm-image]: https://img.shields.io/npm/v/ee-first.svg?style=flat-square +[npm-url]: https://npmjs.org/package/ee-first +[github-tag]: http://img.shields.io/github/tag/jonathanong/ee-first.svg?style=flat-square +[github-url]: https://github.com/jonathanong/ee-first/tags +[travis-image]: https://img.shields.io/travis/jonathanong/ee-first.svg?style=flat-square +[travis-url]: https://travis-ci.org/jonathanong/ee-first +[coveralls-image]: https://img.shields.io/coveralls/jonathanong/ee-first.svg?style=flat-square +[coveralls-url]: https://coveralls.io/r/jonathanong/ee-first?branch=master +[license-image]: http://img.shields.io/npm/l/ee-first.svg?style=flat-square +[license-url]: LICENSE.md +[downloads-image]: http://img.shields.io/npm/dm/ee-first.svg?style=flat-square +[downloads-url]: https://npmjs.org/package/ee-first +[gittip-image]: https://img.shields.io/gittip/jonathanong.svg?style=flat-square +[gittip-url]: https://www.gittip.com/jonathanong/ diff --git a/node_modules/body-parser/node_modules/on-finished/node_modules/ee-first/index.js b/node_modules/body-parser/node_modules/on-finished/node_modules/ee-first/index.js new file mode 100644 index 0000000..501287c --- /dev/null +++ b/node_modules/body-parser/node_modules/on-finished/node_modules/ee-first/index.js @@ -0,0 +1,95 @@ +/*! + * ee-first + * Copyright(c) 2014 Jonathan Ong + * MIT Licensed + */ + +'use strict' + +/** + * Module exports. + * @public + */ + +module.exports = first + +/** + * Get the first event in a set of event emitters and event pairs. + * + * @param {array} stuff + * @param {function} done + * @public + */ + +function first(stuff, done) { + if (!Array.isArray(stuff)) + throw new TypeError('arg must be an array of [ee, events...] arrays') + + var cleanups = [] + + for (var i = 0; i < stuff.length; i++) { + var arr = stuff[i] + + if (!Array.isArray(arr) || arr.length < 2) + throw new TypeError('each array member must be [ee, events...]') + + var ee = arr[0] + + for (var j = 1; j < arr.length; j++) { + var event = arr[j] + var fn = listener(event, callback) + + // listen to the event + ee.on(event, fn) + // push this listener to the list of cleanups + cleanups.push({ + ee: ee, + event: event, + fn: fn, + }) + } + } + + function callback() { + cleanup() + done.apply(null, arguments) + } + + function cleanup() { + var x + for (var i = 0; i < cleanups.length; i++) { + x = cleanups[i] + x.ee.removeListener(x.event, x.fn) + } + } + + function thunk(fn) { + done = fn + } + + thunk.cancel = cleanup + + return thunk +} + +/** + * Create the event listener. + * @private + */ + +function listener(event, done) { + return function onevent(arg1) { + var args = new Array(arguments.length) + var ee = this + var err = event === 'error' + ? arg1 + : null + + // copy args to prevent arguments escaping scope + for (var i = 0; i < args.length; i++) { + args[i] = arguments[i] + } + + done(err, ee, event, args) + } +} diff --git a/node_modules/body-parser/node_modules/on-finished/node_modules/ee-first/package.json b/node_modules/body-parser/node_modules/on-finished/node_modules/ee-first/package.json new file mode 100644 index 0000000..1320c1c --- /dev/null +++ b/node_modules/body-parser/node_modules/on-finished/node_modules/ee-first/package.json @@ -0,0 +1,64 @@ +{ + "name": "ee-first", + "description": "return the first event in a set of ee/event pairs", + "version": "1.1.1", + "author": { + "name": "Jonathan Ong", + "email": "me@jongleberry.com", + "url": "http://jongleberry.com" + }, + "contributors": [ + { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + } + ], + "license": "MIT", + "repository": { + "type": "git", + "url": "git+https://github.com/jonathanong/ee-first.git" + }, + "devDependencies": { + "istanbul": "0.3.9", + "mocha": "2.2.5" + }, + "files": [ + "index.js", + "LICENSE" + ], + "scripts": { + "test": "mocha --reporter spec --bail --check-leaks test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot --check-leaks test/", + "test-travis": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter spec --check-leaks test/" + }, + "gitHead": "512e0ce4cc3643f603708f965a97b61b1a9c0441", + "bugs": { + "url": "https://github.com/jonathanong/ee-first/issues" + }, + "homepage": "https://github.com/jonathanong/ee-first", + "_id": "ee-first@1.1.1", + "_shasum": "590c61156b0ae2f4f0255732a158b266bc56b21d", + "_from": "ee-first@1.1.1", + "_npmVersion": "1.4.28", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "maintainers": [ + { + "name": "jongleberry", + "email": "jonathanrichardong@gmail.com" + }, + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + } + ], + "dist": { + "shasum": "590c61156b0ae2f4f0255732a158b266bc56b21d", + "tarball": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/body-parser/node_modules/on-finished/package.json b/node_modules/body-parser/node_modules/on-finished/package.json new file mode 100644 index 0000000..39e63f6 --- /dev/null +++ b/node_modules/body-parser/node_modules/on-finished/package.json @@ -0,0 +1,71 @@ +{ + "name": "on-finished", + "description": "Execute a callback when a request closes, finishes, or errors", + "version": "2.3.0", + "contributors": [ + { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "Jonathan Ong", + "email": "me@jongleberry.com", + "url": "http://jongleberry.com" + } + ], + "license": "MIT", + "repository": { + "type": "git", + "url": "git+https://github.com/jshttp/on-finished.git" + }, + "dependencies": { + "ee-first": "1.1.1" + }, + "devDependencies": { + "istanbul": "0.3.9", + "mocha": "2.2.5" + }, + "engines": { + "node": ">= 0.8" + }, + "files": [ + "HISTORY.md", + "LICENSE", + "index.js" + ], + "scripts": { + "test": "mocha --reporter spec --bail --check-leaks test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot --check-leaks test/", + "test-travis": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter spec --check-leaks test/" + }, + "gitHead": "34babcb58126a416fcf5205768204f2e12699dda", + "bugs": { + "url": "https://github.com/jshttp/on-finished/issues" + }, + "homepage": "https://github.com/jshttp/on-finished", + "_id": "on-finished@2.3.0", + "_shasum": "20f1336481b083cd75337992a16971aa2d906947", + "_from": "on-finished@>=2.3.0 <2.4.0", + "_npmVersion": "1.4.28", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "maintainers": [ + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "jongleberry", + "email": "jonathanrichardong@gmail.com" + } + ], + "dist": { + "shasum": "20f1336481b083cd75337992a16971aa2d906947", + "tarball": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/body-parser/node_modules/qs/.eslintignore b/node_modules/body-parser/node_modules/qs/.eslintignore new file mode 100644 index 0000000..1521c8b --- /dev/null +++ b/node_modules/body-parser/node_modules/qs/.eslintignore @@ -0,0 +1 @@ +dist diff --git a/node_modules/body-parser/node_modules/qs/.eslintrc b/node_modules/body-parser/node_modules/qs/.eslintrc new file mode 100644 index 0000000..1faac27 --- /dev/null +++ b/node_modules/body-parser/node_modules/qs/.eslintrc @@ -0,0 +1,19 @@ +{ + "root": true, + + "extends": "@ljharb", + + "rules": { + "complexity": [2, 22], + "consistent-return": [1], + "id-length": [2, { "min": 1, "max": 25, "properties": "never" }], + "indent": [2, 4], + "max-params": [2, 9], + "max-statements": [2, 36], + "no-extra-parens": [1], + "no-continue": [1], + "no-magic-numbers": 0, + "no-restricted-syntax": [2, "BreakStatement", "DebuggerStatement", "ForInStatement", "LabeledStatement", "WithStatement"], + "operator-linebreak": 1 + } +} diff --git a/node_modules/body-parser/node_modules/qs/.jscs.json b/node_modules/body-parser/node_modules/qs/.jscs.json new file mode 100644 index 0000000..3d099c4 --- /dev/null +++ b/node_modules/body-parser/node_modules/qs/.jscs.json @@ -0,0 +1,176 @@ +{ + "es3": true, + + "additionalRules": [], + + "requireSemicolons": true, + + "disallowMultipleSpaces": true, + + "disallowIdentifierNames": [], + + "requireCurlyBraces": { + "allExcept": [], + "keywords": ["if", "else", "for", "while", "do", "try", "catch"] + }, + + "requireSpaceAfterKeywords": ["if", "else", "for", "while", "do", "switch", "return", "try", "catch", "function"], + + "disallowSpaceAfterKeywords": [], + + "disallowSpaceBeforeComma": true, + "disallowSpaceAfterComma": false, + "disallowSpaceBeforeSemicolon": true, + + "disallowNodeTypes": [ + "DebuggerStatement", + "ForInStatement", + "LabeledStatement", + "SwitchCase", + "SwitchStatement", + "WithStatement" + ], + + "requireObjectKeysOnNewLine": { "allExcept": ["sameLine"] }, + + "requireSpacesInAnonymousFunctionExpression": { "beforeOpeningRoundBrace": true, "beforeOpeningCurlyBrace": true }, + "requireSpacesInNamedFunctionExpression": { "beforeOpeningCurlyBrace": true }, + "disallowSpacesInNamedFunctionExpression": { "beforeOpeningRoundBrace": true }, + "requireSpacesInFunctionDeclaration": { "beforeOpeningCurlyBrace": true }, + "disallowSpacesInFunctionDeclaration": { "beforeOpeningRoundBrace": true }, + + "requireSpaceBetweenArguments": true, + + "disallowSpacesInsideParentheses": true, + + "disallowSpacesInsideArrayBrackets": true, + + "disallowQuotedKeysInObjects": { "allExcept": ["reserved"] }, + + "disallowSpaceAfterObjectKeys": true, + + "requireCommaBeforeLineBreak": true, + + "disallowSpaceAfterPrefixUnaryOperators": ["++", "--", "+", "-", "~", "!"], + "requireSpaceAfterPrefixUnaryOperators": [], + + "disallowSpaceBeforePostfixUnaryOperators": ["++", "--"], + "requireSpaceBeforePostfixUnaryOperators": [], + + "disallowSpaceBeforeBinaryOperators": [], + "requireSpaceBeforeBinaryOperators": ["+", "-", "/", "*", "=", "==", "===", "!=", "!=="], + + "requireSpaceAfterBinaryOperators": ["+", "-", "/", "*", "=", "==", "===", "!=", "!=="], + "disallowSpaceAfterBinaryOperators": [], + + "disallowImplicitTypeConversion": ["binary", "string"], + + "disallowKeywords": ["with", "eval"], + + "requireKeywordsOnNewLine": [], + "disallowKeywordsOnNewLine": ["else"], + + "requireLineFeedAtFileEnd": true, + + "disallowTrailingWhitespace": true, + + "disallowTrailingComma": true, + + "excludeFiles": ["node_modules/**", "vendor/**"], + + "disallowMultipleLineStrings": true, + + "requireDotNotation": { "allExcept": ["keywords"] }, + + "requireParenthesesAroundIIFE": true, + + "validateLineBreaks": "LF", + + "validateQuoteMarks": { + "escape": true, + "mark": "'" + }, + + "disallowOperatorBeforeLineBreak": [], + + "requireSpaceBeforeKeywords": [ + "do", + "for", + "if", + "else", + "switch", + "case", + "try", + "catch", + "finally", + "while", + "with", + "return" + ], + + "validateAlignedFunctionParameters": { + "lineBreakAfterOpeningBraces": true, + "lineBreakBeforeClosingBraces": true + }, + + "requirePaddingNewLinesBeforeExport": true, + + "validateNewlineAfterArrayElements": { + "maximum": 1 + }, + + "requirePaddingNewLinesAfterUseStrict": true, + + "disallowArrowFunctions": true, + + "disallowMultiLineTernary": true, + + "validateOrderInObjectKeys": "asc-insensitive", + + "disallowIdenticalDestructuringNames": true, + + "disallowNestedTernaries": { "maxLevel": 1 }, + + "requireSpaceAfterComma": { "allExcept": ["trailing"] }, + "requireAlignedMultilineParams": false, + + "requireSpacesInGenerator": { + "afterStar": true + }, + + "disallowSpacesInGenerator": { + "beforeStar": true + }, + + "disallowVar": false, + + "requireArrayDestructuring": false, + + "requireEnhancedObjectLiterals": false, + + "requireObjectDestructuring": false, + + "requireEarlyReturn": false, + + "requireCapitalizedConstructorsNew": { + "allExcept": ["Function", "String", "Object", "Symbol", "Number", "Date", "RegExp", "Error", "Boolean", "Array"] + }, + + "requireImportAlphabetized": false, + + "requireSpaceBeforeObjectValues": true, + "requireSpaceBeforeDestructuredValues": true, + + "disallowSpacesInsideTemplateStringPlaceholders": true, + + "disallowArrayDestructuringReturn": false, + + "requireNewlineBeforeSingleStatementsInIf": false, + + "disallowUnusedVariables": true, + + "requireSpacesInsideImportedObjectBraces": true, + + "requireUseStrict": true +} + diff --git a/node_modules/body-parser/node_modules/qs/CHANGELOG.md b/node_modules/body-parser/node_modules/qs/CHANGELOG.md new file mode 100644 index 0000000..e318a05 --- /dev/null +++ b/node_modules/body-parser/node_modules/qs/CHANGELOG.md @@ -0,0 +1,120 @@ +## [**6.2.0**](https://github.com/ljharb/qs/issues?milestone=36&state=closed) +- [New] pass Buffers to the encoder/decoder directly (#161) +- [New] add "encoder" and "decoder" options, for custom param encoding/decoding (#160) +- [Fix] fix compacting of nested sparse arrays (#150) + +## [**6.1.0**](https://github.com/ljharb/qs/issues?milestone=35&state=closed) +- [New] allowDots option for `stringify` (#151) +- [Fix] "sort" option should work at a depth of 3 or more (#151) +- [Fix] Restore `dist` directory; will be removed in v7 (#148) + +## [**6.0.2**](https://github.com/ljharb/qs/issues?milestone=33&state=closed) +- Revert ES6 requirement and restore support for node down to v0.8. + +## [**6.0.1**](https://github.com/ljharb/qs/issues?milestone=32&state=closed) +- [**#127**](https://github.com/ljharb/qs/pull/127) Fix engines definition in package.json + +## [**6.0.0**](https://github.com/ljharb/qs/issues?milestone=31&state=closed) +- [**#124**](https://github.com/ljharb/qs/issues/124) Use ES6 and drop support for node < v4 + +## [**5.2.0**](https://github.com/ljharb/qs/issues?milestone=30&state=closed) +- [**#64**](https://github.com/ljharb/qs/issues/64) Add option to sort object keys in the query string + +## [**5.1.0**](https://github.com/ljharb/qs/issues?milestone=29&state=closed) +- [**#117**](https://github.com/ljharb/qs/issues/117) make URI encoding stringified results optional +- [**#106**](https://github.com/ljharb/qs/issues/106) Add flag `skipNulls` to optionally skip null values in stringify + +## [**5.0.0**](https://github.com/ljharb/qs/issues?milestone=28&state=closed) +- [**#114**](https://github.com/ljharb/qs/issues/114) default allowDots to false +- [**#100**](https://github.com/ljharb/qs/issues/100) include dist to npm + +## [**4.0.0**](https://github.com/ljharb/qs/issues?milestone=26&state=closed) +- [**#98**](https://github.com/ljharb/qs/issues/98) make returning plain objects and allowing prototype overwriting properties optional + +## [**3.1.0**](https://github.com/ljharb/qs/issues?milestone=24&state=closed) +- [**#89**](https://github.com/ljharb/qs/issues/89) Add option to disable "Transform dot notation to bracket notation" + +## [**3.0.0**](https://github.com/ljharb/qs/issues?milestone=23&state=closed) +- [**#80**](https://github.com/ljharb/qs/issues/80) qs.parse silently drops properties +- [**#77**](https://github.com/ljharb/qs/issues/77) Perf boost +- [**#60**](https://github.com/ljharb/qs/issues/60) Add explicit option to disable array parsing +- [**#74**](https://github.com/ljharb/qs/issues/74) Bad parse when turning array into object +- [**#81**](https://github.com/ljharb/qs/issues/81) Add a `filter` option +- [**#68**](https://github.com/ljharb/qs/issues/68) Fixed issue with recursion and passing strings into objects. +- [**#66**](https://github.com/ljharb/qs/issues/66) Add mixed array and object dot notation support Closes: #47 +- [**#76**](https://github.com/ljharb/qs/issues/76) RFC 3986 +- [**#85**](https://github.com/ljharb/qs/issues/85) No equal sign +- [**#84**](https://github.com/ljharb/qs/issues/84) update license attribute + +## [**2.4.1**](https://github.com/ljharb/qs/issues?milestone=20&state=closed) +- [**#73**](https://github.com/ljharb/qs/issues/73) Property 'hasOwnProperty' of object # is not a function + +## [**2.4.0**](https://github.com/ljharb/qs/issues?milestone=19&state=closed) +- [**#70**](https://github.com/ljharb/qs/issues/70) Add arrayFormat option + +## [**2.3.3**](https://github.com/ljharb/qs/issues?milestone=18&state=closed) +- [**#59**](https://github.com/ljharb/qs/issues/59) make sure array indexes are >= 0, closes #57 +- [**#58**](https://github.com/ljharb/qs/issues/58) make qs usable for browser loader + +## [**2.3.2**](https://github.com/ljharb/qs/issues?milestone=17&state=closed) +- [**#55**](https://github.com/ljharb/qs/issues/55) allow merging a string into an object + +## [**2.3.1**](https://github.com/ljharb/qs/issues?milestone=16&state=closed) +- [**#52**](https://github.com/ljharb/qs/issues/52) Return "undefined" and "false" instead of throwing "TypeError". + +## [**2.3.0**](https://github.com/ljharb/qs/issues?milestone=15&state=closed) +- [**#50**](https://github.com/ljharb/qs/issues/50) add option to omit array indices, closes #46 + +## [**2.2.5**](https://github.com/ljharb/qs/issues?milestone=14&state=closed) +- [**#39**](https://github.com/ljharb/qs/issues/39) Is there an alternative to Buffer.isBuffer? +- [**#49**](https://github.com/ljharb/qs/issues/49) refactor utils.merge, fixes #45 +- [**#41**](https://github.com/ljharb/qs/issues/41) avoid browserifying Buffer, for #39 + +## [**2.2.4**](https://github.com/ljharb/qs/issues?milestone=13&state=closed) +- [**#38**](https://github.com/ljharb/qs/issues/38) how to handle object keys beginning with a number + +## [**2.2.3**](https://github.com/ljharb/qs/issues?milestone=12&state=closed) +- [**#37**](https://github.com/ljharb/qs/issues/37) parser discards first empty value in array +- [**#36**](https://github.com/ljharb/qs/issues/36) Update to lab 4.x + +## [**2.2.2**](https://github.com/ljharb/qs/issues?milestone=11&state=closed) +- [**#33**](https://github.com/ljharb/qs/issues/33) Error when plain object in a value +- [**#34**](https://github.com/ljharb/qs/issues/34) use Object.prototype.hasOwnProperty.call instead of obj.hasOwnProperty +- [**#24**](https://github.com/ljharb/qs/issues/24) Changelog? Semver? + +## [**2.2.1**](https://github.com/ljharb/qs/issues?milestone=10&state=closed) +- [**#32**](https://github.com/ljharb/qs/issues/32) account for circular references properly, closes #31 +- [**#31**](https://github.com/ljharb/qs/issues/31) qs.parse stackoverflow on circular objects + +## [**2.2.0**](https://github.com/ljharb/qs/issues?milestone=9&state=closed) +- [**#26**](https://github.com/ljharb/qs/issues/26) Don't use Buffer global if it's not present +- [**#30**](https://github.com/ljharb/qs/issues/30) Bug when merging non-object values into arrays +- [**#29**](https://github.com/ljharb/qs/issues/29) Don't call Utils.clone at the top of Utils.merge +- [**#23**](https://github.com/ljharb/qs/issues/23) Ability to not limit parameters? + +## [**2.1.0**](https://github.com/ljharb/qs/issues?milestone=8&state=closed) +- [**#22**](https://github.com/ljharb/qs/issues/22) Enable using a RegExp as delimiter + +## [**2.0.0**](https://github.com/ljharb/qs/issues?milestone=7&state=closed) +- [**#18**](https://github.com/ljharb/qs/issues/18) Why is there arrayLimit? +- [**#20**](https://github.com/ljharb/qs/issues/20) Configurable parametersLimit +- [**#21**](https://github.com/ljharb/qs/issues/21) make all limits optional, for #18, for #20 + +## [**1.2.2**](https://github.com/ljharb/qs/issues?milestone=6&state=closed) +- [**#19**](https://github.com/ljharb/qs/issues/19) Don't overwrite null values + +## [**1.2.1**](https://github.com/ljharb/qs/issues?milestone=5&state=closed) +- [**#16**](https://github.com/ljharb/qs/issues/16) ignore non-string delimiters +- [**#15**](https://github.com/ljharb/qs/issues/15) Close code block + +## [**1.2.0**](https://github.com/ljharb/qs/issues?milestone=4&state=closed) +- [**#12**](https://github.com/ljharb/qs/issues/12) Add optional delim argument +- [**#13**](https://github.com/ljharb/qs/issues/13) fix #11: flattened keys in array are now correctly parsed + +## [**1.1.0**](https://github.com/ljharb/qs/issues?milestone=3&state=closed) +- [**#7**](https://github.com/ljharb/qs/issues/7) Empty values of a POST array disappear after being submitted +- [**#9**](https://github.com/ljharb/qs/issues/9) Should not omit equals signs (=) when value is null +- [**#6**](https://github.com/ljharb/qs/issues/6) Minor grammar fix in README + +## [**1.0.2**](https://github.com/ljharb/qs/issues?milestone=2&state=closed) +- [**#5**](https://github.com/ljharb/qs/issues/5) array holes incorrectly copied into object on large index diff --git a/node_modules/body-parser/node_modules/qs/CONTRIBUTING.md b/node_modules/body-parser/node_modules/qs/CONTRIBUTING.md new file mode 100644 index 0000000..8928361 --- /dev/null +++ b/node_modules/body-parser/node_modules/qs/CONTRIBUTING.md @@ -0,0 +1 @@ +Please view our [hapijs contributing guide](https://github.com/hapijs/hapi/blob/master/CONTRIBUTING.md). diff --git a/node_modules/body-parser/node_modules/qs/LICENSE b/node_modules/body-parser/node_modules/qs/LICENSE new file mode 100644 index 0000000..d456948 --- /dev/null +++ b/node_modules/body-parser/node_modules/qs/LICENSE @@ -0,0 +1,28 @@ +Copyright (c) 2014 Nathan LaFreniere and other contributors. +All rights reserved. + +Redistribution and use in source and binary forms, with or without +modification, are permitted provided that the following conditions are met: + * Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. + * Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. + * The names of any contributors may not be used to endorse or promote + products derived from this software without specific prior written + permission. + +THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND +ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED +WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE +DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDERS AND CONTRIBUTORS BE LIABLE FOR ANY +DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES +(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; +LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND +ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT +(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS +SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + + * * * + +The complete list of contributors can be found at: https://github.com/hapijs/qs/graphs/contributors diff --git a/node_modules/body-parser/node_modules/qs/dist/qs.js b/node_modules/body-parser/node_modules/qs/dist/qs.js new file mode 100644 index 0000000..4cc6f30 --- /dev/null +++ b/node_modules/body-parser/node_modules/qs/dist/qs.js @@ -0,0 +1,487 @@ +(function(f){if(typeof exports==="object"&&typeof module!=="undefined"){module.exports=f()}else if(typeof define==="function"&&define.amd){define([],f)}else{var g;if(typeof window!=="undefined"){g=window}else if(typeof global!=="undefined"){g=global}else if(typeof self!=="undefined"){g=self}else{g=this}g.Qs = f()}})(function(){var define,module,exports;return (function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o= 0 && + (options.parseArrays && index <= options.arrayLimit) + ) { + obj = []; + obj[index] = parseObject(chain, val, options); + } else { + obj[cleanRoot] = parseObject(chain, val, options); + } + } + + return obj; +}; + +var parseKeys = function parseKeys(givenKey, val, options) { + if (!givenKey) { + return; + } + + // Transform dot notation to bracket notation + var key = options.allowDots ? givenKey.replace(/\.([^\.\[]+)/g, '[$1]') : givenKey; + + // The regex chunks + + var parent = /^([^\[\]]*)/; + var child = /(\[[^\[\]]*\])/g; + + // Get the parent + + var segment = parent.exec(key); + + // Stash the parent if it exists + + var keys = []; + if (segment[1]) { + // If we aren't using plain objects, optionally prefix keys + // that would overwrite object prototype properties + if (!options.plainObjects && Object.prototype.hasOwnProperty(segment[1])) { + if (!options.allowPrototypes) { + return; + } + } + + keys.push(segment[1]); + } + + // Loop through children appending to the array until we hit depth + + var i = 0; + while ((segment = child.exec(key)) !== null && i < options.depth) { + i += 1; + if (!options.plainObjects && Object.prototype.hasOwnProperty(segment[1].replace(/\[|\]/g, ''))) { + if (!options.allowPrototypes) { + continue; + } + } + keys.push(segment[1]); + } + + // If there's a remainder, just add whatever is left + + if (segment) { + keys.push('[' + key.slice(segment.index) + ']'); + } + + return parseObject(keys, val, options); +}; + +module.exports = function (str, opts) { + var options = opts || {}; + + if (options.decoder !== null && options.decoder !== undefined && typeof options.decoder !== 'function') { + throw new TypeError('Decoder has to be a function.'); + } + + options.delimiter = typeof options.delimiter === 'string' || Utils.isRegExp(options.delimiter) ? options.delimiter : defaults.delimiter; + options.depth = typeof options.depth === 'number' ? options.depth : defaults.depth; + options.arrayLimit = typeof options.arrayLimit === 'number' ? options.arrayLimit : defaults.arrayLimit; + options.parseArrays = options.parseArrays !== false; + options.decoder = typeof options.decoder === 'function' ? options.decoder : defaults.decoder; + options.allowDots = typeof options.allowDots === 'boolean' ? options.allowDots : defaults.allowDots; + options.plainObjects = typeof options.plainObjects === 'boolean' ? options.plainObjects : defaults.plainObjects; + options.allowPrototypes = typeof options.allowPrototypes === 'boolean' ? options.allowPrototypes : defaults.allowPrototypes; + options.parameterLimit = typeof options.parameterLimit === 'number' ? options.parameterLimit : defaults.parameterLimit; + options.strictNullHandling = typeof options.strictNullHandling === 'boolean' ? options.strictNullHandling : defaults.strictNullHandling; + + if (str === '' || str === null || typeof str === 'undefined') { + return options.plainObjects ? Object.create(null) : {}; + } + + var tempObj = typeof str === 'string' ? parseValues(str, options) : str; + var obj = options.plainObjects ? Object.create(null) : {}; + + // Iterate over the keys and setup the new object + + var keys = Object.keys(tempObj); + for (var i = 0; i < keys.length; ++i) { + var key = keys[i]; + var newObj = parseKeys(key, tempObj[key], options); + obj = Utils.merge(obj, newObj, options); + } + + return Utils.compact(obj); +}; + +},{"./utils":4}],3:[function(require,module,exports){ +'use strict'; + +var Utils = require('./utils'); + +var arrayPrefixGenerators = { + brackets: function brackets(prefix) { + return prefix + '[]'; + }, + indices: function indices(prefix, key) { + return prefix + '[' + key + ']'; + }, + repeat: function repeat(prefix) { + return prefix; + } +}; + +var defaults = { + delimiter: '&', + strictNullHandling: false, + skipNulls: false, + encode: true, + encoder: Utils.encode +}; + +var stringify = function stringify(object, prefix, generateArrayPrefix, strictNullHandling, skipNulls, encoder, filter, sort, allowDots) { + var obj = object; + if (typeof filter === 'function') { + obj = filter(prefix, obj); + } else if (obj instanceof Date) { + obj = obj.toISOString(); + } else if (obj === null) { + if (strictNullHandling) { + return encoder ? encoder(prefix) : prefix; + } + + obj = ''; + } + + if (typeof obj === 'string' || typeof obj === 'number' || typeof obj === 'boolean' || Utils.isBuffer(obj)) { + if (encoder) { + return [encoder(prefix) + '=' + encoder(obj)]; + } + return [prefix + '=' + String(obj)]; + } + + var values = []; + + if (typeof obj === 'undefined') { + return values; + } + + var objKeys; + if (Array.isArray(filter)) { + objKeys = filter; + } else { + var keys = Object.keys(obj); + objKeys = sort ? keys.sort(sort) : keys; + } + + for (var i = 0; i < objKeys.length; ++i) { + var key = objKeys[i]; + + if (skipNulls && obj[key] === null) { + continue; + } + + if (Array.isArray(obj)) { + values = values.concat(stringify(obj[key], generateArrayPrefix(prefix, key), generateArrayPrefix, strictNullHandling, skipNulls, encoder, filter, sort, allowDots)); + } else { + values = values.concat(stringify(obj[key], prefix + (allowDots ? '.' + key : '[' + key + ']'), generateArrayPrefix, strictNullHandling, skipNulls, encoder, filter, sort, allowDots)); + } + } + + return values; +}; + +module.exports = function (object, opts) { + var obj = object; + var options = opts || {}; + var delimiter = typeof options.delimiter === 'undefined' ? defaults.delimiter : options.delimiter; + var strictNullHandling = typeof options.strictNullHandling === 'boolean' ? options.strictNullHandling : defaults.strictNullHandling; + var skipNulls = typeof options.skipNulls === 'boolean' ? options.skipNulls : defaults.skipNulls; + var encode = typeof options.encode === 'boolean' ? options.encode : defaults.encode; + var encoder = encode ? (typeof options.encoder === 'function' ? options.encoder : defaults.encoder) : null; + var sort = typeof options.sort === 'function' ? options.sort : null; + var allowDots = typeof options.allowDots === 'undefined' ? false : options.allowDots; + var objKeys; + var filter; + + if (options.encoder !== null && options.encoder !== undefined && typeof options.encoder !== 'function') { + throw new TypeError('Encoder has to be a function.'); + } + + if (typeof options.filter === 'function') { + filter = options.filter; + obj = filter('', obj); + } else if (Array.isArray(options.filter)) { + objKeys = filter = options.filter; + } + + var keys = []; + + if (typeof obj !== 'object' || obj === null) { + return ''; + } + + var arrayFormat; + if (options.arrayFormat in arrayPrefixGenerators) { + arrayFormat = options.arrayFormat; + } else if ('indices' in options) { + arrayFormat = options.indices ? 'indices' : 'repeat'; + } else { + arrayFormat = 'indices'; + } + + var generateArrayPrefix = arrayPrefixGenerators[arrayFormat]; + + if (!objKeys) { + objKeys = Object.keys(obj); + } + + if (sort) { + objKeys.sort(sort); + } + + for (var i = 0; i < objKeys.length; ++i) { + var key = objKeys[i]; + + if (skipNulls && obj[key] === null) { + continue; + } + + keys = keys.concat(stringify(obj[key], key, generateArrayPrefix, strictNullHandling, skipNulls, encoder, filter, sort, allowDots)); + } + + return keys.join(delimiter); +}; + +},{"./utils":4}],4:[function(require,module,exports){ +'use strict'; + +var hexTable = (function () { + var array = new Array(256); + for (var i = 0; i < 256; ++i) { + array[i] = '%' + ((i < 16 ? '0' : '') + i.toString(16)).toUpperCase(); + } + + return array; +}()); + +exports.arrayToObject = function (source, options) { + var obj = options.plainObjects ? Object.create(null) : {}; + for (var i = 0; i < source.length; ++i) { + if (typeof source[i] !== 'undefined') { + obj[i] = source[i]; + } + } + + return obj; +}; + +exports.merge = function (target, source, options) { + if (!source) { + return target; + } + + if (typeof source !== 'object') { + if (Array.isArray(target)) { + target.push(source); + } else if (typeof target === 'object') { + target[source] = true; + } else { + return [target, source]; + } + + return target; + } + + if (typeof target !== 'object') { + return [target].concat(source); + } + + var mergeTarget = target; + if (Array.isArray(target) && !Array.isArray(source)) { + mergeTarget = exports.arrayToObject(target, options); + } + + return Object.keys(source).reduce(function (acc, key) { + var value = source[key]; + + if (Object.prototype.hasOwnProperty.call(acc, key)) { + acc[key] = exports.merge(acc[key], value, options); + } else { + acc[key] = value; + } + return acc; + }, mergeTarget); +}; + +exports.decode = function (str) { + try { + return decodeURIComponent(str.replace(/\+/g, ' ')); + } catch (e) { + return str; + } +}; + +exports.encode = function (str) { + // This code was originally written by Brian White (mscdex) for the io.js core querystring library. + // It has been adapted here for stricter adherence to RFC 3986 + if (str.length === 0) { + return str; + } + + var string = typeof str === 'string' ? str : String(str); + + var out = ''; + for (var i = 0; i < string.length; ++i) { + var c = string.charCodeAt(i); + + if ( + c === 0x2D || // - + c === 0x2E || // . + c === 0x5F || // _ + c === 0x7E || // ~ + (c >= 0x30 && c <= 0x39) || // 0-9 + (c >= 0x41 && c <= 0x5A) || // a-z + (c >= 0x61 && c <= 0x7A) // A-Z + ) { + out += string.charAt(i); + continue; + } + + if (c < 0x80) { + out = out + hexTable[c]; + continue; + } + + if (c < 0x800) { + out = out + (hexTable[0xC0 | (c >> 6)] + hexTable[0x80 | (c & 0x3F)]); + continue; + } + + if (c < 0xD800 || c >= 0xE000) { + out = out + (hexTable[0xE0 | (c >> 12)] + hexTable[0x80 | ((c >> 6) & 0x3F)] + hexTable[0x80 | (c & 0x3F)]); + continue; + } + + i += 1; + c = 0x10000 + (((c & 0x3FF) << 10) | (string.charCodeAt(i) & 0x3FF)); + out += hexTable[0xF0 | (c >> 18)] + hexTable[0x80 | ((c >> 12) & 0x3F)] + hexTable[0x80 | ((c >> 6) & 0x3F)] + hexTable[0x80 | (c & 0x3F)]; + } + + return out; +}; + +exports.compact = function (obj, references) { + if (typeof obj !== 'object' || obj === null) { + return obj; + } + + var refs = references || []; + var lookup = refs.indexOf(obj); + if (lookup !== -1) { + return refs[lookup]; + } + + refs.push(obj); + + if (Array.isArray(obj)) { + var compacted = []; + + for (var i = 0; i < obj.length; ++i) { + if (obj[i] && typeof obj[i] === 'object') { + compacted.push(exports.compact(obj[i], refs)); + } else if (typeof obj[i] !== 'undefined') { + compacted.push(obj[i]); + } + } + + return compacted; + } + + var keys = Object.keys(obj); + for (var j = 0; j < keys.length; ++j) { + var key = keys[j]; + obj[key] = exports.compact(obj[key], refs); + } + + return obj; +}; + +exports.isRegExp = function (obj) { + return Object.prototype.toString.call(obj) === '[object RegExp]'; +}; + +exports.isBuffer = function (obj) { + if (obj === null || typeof obj === 'undefined') { + return false; + } + + return !!(obj.constructor && obj.constructor.isBuffer && obj.constructor.isBuffer(obj)); +}; + +},{}]},{},[1])(1) +}); \ No newline at end of file diff --git a/node_modules/body-parser/node_modules/qs/lib/index.js b/node_modules/body-parser/node_modules/qs/lib/index.js new file mode 100644 index 0000000..1901959 --- /dev/null +++ b/node_modules/body-parser/node_modules/qs/lib/index.js @@ -0,0 +1,9 @@ +'use strict'; + +var Stringify = require('./stringify'); +var Parse = require('./parse'); + +module.exports = { + stringify: Stringify, + parse: Parse +}; diff --git a/node_modules/body-parser/node_modules/qs/lib/parse.js b/node_modules/body-parser/node_modules/qs/lib/parse.js new file mode 100644 index 0000000..bf70fd8 --- /dev/null +++ b/node_modules/body-parser/node_modules/qs/lib/parse.js @@ -0,0 +1,167 @@ +'use strict'; + +var Utils = require('./utils'); + +var defaults = { + delimiter: '&', + depth: 5, + arrayLimit: 20, + parameterLimit: 1000, + strictNullHandling: false, + plainObjects: false, + allowPrototypes: false, + allowDots: false, + decoder: Utils.decode +}; + +var parseValues = function parseValues(str, options) { + var obj = {}; + var parts = str.split(options.delimiter, options.parameterLimit === Infinity ? undefined : options.parameterLimit); + + for (var i = 0; i < parts.length; ++i) { + var part = parts[i]; + var pos = part.indexOf(']=') === -1 ? part.indexOf('=') : part.indexOf(']=') + 1; + + if (pos === -1) { + obj[options.decoder(part)] = ''; + + if (options.strictNullHandling) { + obj[options.decoder(part)] = null; + } + } else { + var key = options.decoder(part.slice(0, pos)); + var val = options.decoder(part.slice(pos + 1)); + + if (Object.prototype.hasOwnProperty.call(obj, key)) { + obj[key] = [].concat(obj[key]).concat(val); + } else { + obj[key] = val; + } + } + } + + return obj; +}; + +var parseObject = function parseObject(chain, val, options) { + if (!chain.length) { + return val; + } + + var root = chain.shift(); + + var obj; + if (root === '[]') { + obj = []; + obj = obj.concat(parseObject(chain, val, options)); + } else { + obj = options.plainObjects ? Object.create(null) : {}; + var cleanRoot = root[0] === '[' && root[root.length - 1] === ']' ? root.slice(1, root.length - 1) : root; + var index = parseInt(cleanRoot, 10); + if ( + !isNaN(index) && + root !== cleanRoot && + String(index) === cleanRoot && + index >= 0 && + (options.parseArrays && index <= options.arrayLimit) + ) { + obj = []; + obj[index] = parseObject(chain, val, options); + } else { + obj[cleanRoot] = parseObject(chain, val, options); + } + } + + return obj; +}; + +var parseKeys = function parseKeys(givenKey, val, options) { + if (!givenKey) { + return; + } + + // Transform dot notation to bracket notation + var key = options.allowDots ? givenKey.replace(/\.([^\.\[]+)/g, '[$1]') : givenKey; + + // The regex chunks + + var parent = /^([^\[\]]*)/; + var child = /(\[[^\[\]]*\])/g; + + // Get the parent + + var segment = parent.exec(key); + + // Stash the parent if it exists + + var keys = []; + if (segment[1]) { + // If we aren't using plain objects, optionally prefix keys + // that would overwrite object prototype properties + if (!options.plainObjects && Object.prototype.hasOwnProperty(segment[1])) { + if (!options.allowPrototypes) { + return; + } + } + + keys.push(segment[1]); + } + + // Loop through children appending to the array until we hit depth + + var i = 0; + while ((segment = child.exec(key)) !== null && i < options.depth) { + i += 1; + if (!options.plainObjects && Object.prototype.hasOwnProperty(segment[1].replace(/\[|\]/g, ''))) { + if (!options.allowPrototypes) { + continue; + } + } + keys.push(segment[1]); + } + + // If there's a remainder, just add whatever is left + + if (segment) { + keys.push('[' + key.slice(segment.index) + ']'); + } + + return parseObject(keys, val, options); +}; + +module.exports = function (str, opts) { + var options = opts || {}; + + if (options.decoder !== null && options.decoder !== undefined && typeof options.decoder !== 'function') { + throw new TypeError('Decoder has to be a function.'); + } + + options.delimiter = typeof options.delimiter === 'string' || Utils.isRegExp(options.delimiter) ? options.delimiter : defaults.delimiter; + options.depth = typeof options.depth === 'number' ? options.depth : defaults.depth; + options.arrayLimit = typeof options.arrayLimit === 'number' ? options.arrayLimit : defaults.arrayLimit; + options.parseArrays = options.parseArrays !== false; + options.decoder = typeof options.decoder === 'function' ? options.decoder : defaults.decoder; + options.allowDots = typeof options.allowDots === 'boolean' ? options.allowDots : defaults.allowDots; + options.plainObjects = typeof options.plainObjects === 'boolean' ? options.plainObjects : defaults.plainObjects; + options.allowPrototypes = typeof options.allowPrototypes === 'boolean' ? options.allowPrototypes : defaults.allowPrototypes; + options.parameterLimit = typeof options.parameterLimit === 'number' ? options.parameterLimit : defaults.parameterLimit; + options.strictNullHandling = typeof options.strictNullHandling === 'boolean' ? options.strictNullHandling : defaults.strictNullHandling; + + if (str === '' || str === null || typeof str === 'undefined') { + return options.plainObjects ? Object.create(null) : {}; + } + + var tempObj = typeof str === 'string' ? parseValues(str, options) : str; + var obj = options.plainObjects ? Object.create(null) : {}; + + // Iterate over the keys and setup the new object + + var keys = Object.keys(tempObj); + for (var i = 0; i < keys.length; ++i) { + var key = keys[i]; + var newObj = parseKeys(key, tempObj[key], options); + obj = Utils.merge(obj, newObj, options); + } + + return Utils.compact(obj); +}; diff --git a/node_modules/body-parser/node_modules/qs/lib/stringify.js b/node_modules/body-parser/node_modules/qs/lib/stringify.js new file mode 100644 index 0000000..6e1c9a2 --- /dev/null +++ b/node_modules/body-parser/node_modules/qs/lib/stringify.js @@ -0,0 +1,137 @@ +'use strict'; + +var Utils = require('./utils'); + +var arrayPrefixGenerators = { + brackets: function brackets(prefix) { + return prefix + '[]'; + }, + indices: function indices(prefix, key) { + return prefix + '[' + key + ']'; + }, + repeat: function repeat(prefix) { + return prefix; + } +}; + +var defaults = { + delimiter: '&', + strictNullHandling: false, + skipNulls: false, + encode: true, + encoder: Utils.encode +}; + +var stringify = function stringify(object, prefix, generateArrayPrefix, strictNullHandling, skipNulls, encoder, filter, sort, allowDots) { + var obj = object; + if (typeof filter === 'function') { + obj = filter(prefix, obj); + } else if (obj instanceof Date) { + obj = obj.toISOString(); + } else if (obj === null) { + if (strictNullHandling) { + return encoder ? encoder(prefix) : prefix; + } + + obj = ''; + } + + if (typeof obj === 'string' || typeof obj === 'number' || typeof obj === 'boolean' || Utils.isBuffer(obj)) { + if (encoder) { + return [encoder(prefix) + '=' + encoder(obj)]; + } + return [prefix + '=' + String(obj)]; + } + + var values = []; + + if (typeof obj === 'undefined') { + return values; + } + + var objKeys; + if (Array.isArray(filter)) { + objKeys = filter; + } else { + var keys = Object.keys(obj); + objKeys = sort ? keys.sort(sort) : keys; + } + + for (var i = 0; i < objKeys.length; ++i) { + var key = objKeys[i]; + + if (skipNulls && obj[key] === null) { + continue; + } + + if (Array.isArray(obj)) { + values = values.concat(stringify(obj[key], generateArrayPrefix(prefix, key), generateArrayPrefix, strictNullHandling, skipNulls, encoder, filter, sort, allowDots)); + } else { + values = values.concat(stringify(obj[key], prefix + (allowDots ? '.' + key : '[' + key + ']'), generateArrayPrefix, strictNullHandling, skipNulls, encoder, filter, sort, allowDots)); + } + } + + return values; +}; + +module.exports = function (object, opts) { + var obj = object; + var options = opts || {}; + var delimiter = typeof options.delimiter === 'undefined' ? defaults.delimiter : options.delimiter; + var strictNullHandling = typeof options.strictNullHandling === 'boolean' ? options.strictNullHandling : defaults.strictNullHandling; + var skipNulls = typeof options.skipNulls === 'boolean' ? options.skipNulls : defaults.skipNulls; + var encode = typeof options.encode === 'boolean' ? options.encode : defaults.encode; + var encoder = encode ? (typeof options.encoder === 'function' ? options.encoder : defaults.encoder) : null; + var sort = typeof options.sort === 'function' ? options.sort : null; + var allowDots = typeof options.allowDots === 'undefined' ? false : options.allowDots; + var objKeys; + var filter; + + if (options.encoder !== null && options.encoder !== undefined && typeof options.encoder !== 'function') { + throw new TypeError('Encoder has to be a function.'); + } + + if (typeof options.filter === 'function') { + filter = options.filter; + obj = filter('', obj); + } else if (Array.isArray(options.filter)) { + objKeys = filter = options.filter; + } + + var keys = []; + + if (typeof obj !== 'object' || obj === null) { + return ''; + } + + var arrayFormat; + if (options.arrayFormat in arrayPrefixGenerators) { + arrayFormat = options.arrayFormat; + } else if ('indices' in options) { + arrayFormat = options.indices ? 'indices' : 'repeat'; + } else { + arrayFormat = 'indices'; + } + + var generateArrayPrefix = arrayPrefixGenerators[arrayFormat]; + + if (!objKeys) { + objKeys = Object.keys(obj); + } + + if (sort) { + objKeys.sort(sort); + } + + for (var i = 0; i < objKeys.length; ++i) { + var key = objKeys[i]; + + if (skipNulls && obj[key] === null) { + continue; + } + + keys = keys.concat(stringify(obj[key], key, generateArrayPrefix, strictNullHandling, skipNulls, encoder, filter, sort, allowDots)); + } + + return keys.join(delimiter); +}; diff --git a/node_modules/body-parser/node_modules/qs/lib/utils.js b/node_modules/body-parser/node_modules/qs/lib/utils.js new file mode 100644 index 0000000..2c5c8ee --- /dev/null +++ b/node_modules/body-parser/node_modules/qs/lib/utils.js @@ -0,0 +1,164 @@ +'use strict'; + +var hexTable = (function () { + var array = new Array(256); + for (var i = 0; i < 256; ++i) { + array[i] = '%' + ((i < 16 ? '0' : '') + i.toString(16)).toUpperCase(); + } + + return array; +}()); + +exports.arrayToObject = function (source, options) { + var obj = options.plainObjects ? Object.create(null) : {}; + for (var i = 0; i < source.length; ++i) { + if (typeof source[i] !== 'undefined') { + obj[i] = source[i]; + } + } + + return obj; +}; + +exports.merge = function (target, source, options) { + if (!source) { + return target; + } + + if (typeof source !== 'object') { + if (Array.isArray(target)) { + target.push(source); + } else if (typeof target === 'object') { + target[source] = true; + } else { + return [target, source]; + } + + return target; + } + + if (typeof target !== 'object') { + return [target].concat(source); + } + + var mergeTarget = target; + if (Array.isArray(target) && !Array.isArray(source)) { + mergeTarget = exports.arrayToObject(target, options); + } + + return Object.keys(source).reduce(function (acc, key) { + var value = source[key]; + + if (Object.prototype.hasOwnProperty.call(acc, key)) { + acc[key] = exports.merge(acc[key], value, options); + } else { + acc[key] = value; + } + return acc; + }, mergeTarget); +}; + +exports.decode = function (str) { + try { + return decodeURIComponent(str.replace(/\+/g, ' ')); + } catch (e) { + return str; + } +}; + +exports.encode = function (str) { + // This code was originally written by Brian White (mscdex) for the io.js core querystring library. + // It has been adapted here for stricter adherence to RFC 3986 + if (str.length === 0) { + return str; + } + + var string = typeof str === 'string' ? str : String(str); + + var out = ''; + for (var i = 0; i < string.length; ++i) { + var c = string.charCodeAt(i); + + if ( + c === 0x2D || // - + c === 0x2E || // . + c === 0x5F || // _ + c === 0x7E || // ~ + (c >= 0x30 && c <= 0x39) || // 0-9 + (c >= 0x41 && c <= 0x5A) || // a-z + (c >= 0x61 && c <= 0x7A) // A-Z + ) { + out += string.charAt(i); + continue; + } + + if (c < 0x80) { + out = out + hexTable[c]; + continue; + } + + if (c < 0x800) { + out = out + (hexTable[0xC0 | (c >> 6)] + hexTable[0x80 | (c & 0x3F)]); + continue; + } + + if (c < 0xD800 || c >= 0xE000) { + out = out + (hexTable[0xE0 | (c >> 12)] + hexTable[0x80 | ((c >> 6) & 0x3F)] + hexTable[0x80 | (c & 0x3F)]); + continue; + } + + i += 1; + c = 0x10000 + (((c & 0x3FF) << 10) | (string.charCodeAt(i) & 0x3FF)); + out += hexTable[0xF0 | (c >> 18)] + hexTable[0x80 | ((c >> 12) & 0x3F)] + hexTable[0x80 | ((c >> 6) & 0x3F)] + hexTable[0x80 | (c & 0x3F)]; + } + + return out; +}; + +exports.compact = function (obj, references) { + if (typeof obj !== 'object' || obj === null) { + return obj; + } + + var refs = references || []; + var lookup = refs.indexOf(obj); + if (lookup !== -1) { + return refs[lookup]; + } + + refs.push(obj); + + if (Array.isArray(obj)) { + var compacted = []; + + for (var i = 0; i < obj.length; ++i) { + if (obj[i] && typeof obj[i] === 'object') { + compacted.push(exports.compact(obj[i], refs)); + } else if (typeof obj[i] !== 'undefined') { + compacted.push(obj[i]); + } + } + + return compacted; + } + + var keys = Object.keys(obj); + for (var j = 0; j < keys.length; ++j) { + var key = keys[j]; + obj[key] = exports.compact(obj[key], refs); + } + + return obj; +}; + +exports.isRegExp = function (obj) { + return Object.prototype.toString.call(obj) === '[object RegExp]'; +}; + +exports.isBuffer = function (obj) { + if (obj === null || typeof obj === 'undefined') { + return false; + } + + return !!(obj.constructor && obj.constructor.isBuffer && obj.constructor.isBuffer(obj)); +}; diff --git a/node_modules/body-parser/node_modules/qs/package.json b/node_modules/body-parser/node_modules/qs/package.json new file mode 100644 index 0000000..debabac --- /dev/null +++ b/node_modules/body-parser/node_modules/qs/package.json @@ -0,0 +1,86 @@ +{ + "name": "qs", + "description": "A querystring parser that supports nesting and arrays, with a depth limit", + "homepage": "https://github.com/ljharb/qs", + "version": "6.2.0", + "repository": { + "type": "git", + "url": "git+https://github.com/ljharb/qs.git" + }, + "main": "lib/index.js", + "contributors": [ + { + "name": "Jordan Harband", + "email": "ljharb@gmail.com", + "url": "http://ljharb.codes" + } + ], + "keywords": [ + "querystring", + "qs" + ], + "engines": { + "node": ">=0.6" + }, + "dependencies": {}, + "devDependencies": { + "browserify": "^13.0.1", + "tape": "^4.5.1", + "covert": "^1.1.0", + "mkdirp": "^0.5.1", + "eslint": "^2.9.0", + "@ljharb/eslint-config": "^4.0.0", + "parallelshell": "^2.0.0", + "iconv-lite": "^0.4.13", + "evalmd": "^0.0.17" + }, + "scripts": { + "pretest": "parallelshell 'npm run --silent readme' 'npm run --silent lint'", + "test": "npm run --silent coverage", + "tests-only": "node test", + "readme": "evalmd README.md", + "lint": "eslint lib/*.js text/*.js", + "coverage": "covert test", + "dist": "mkdirp dist && browserify --standalone Qs lib/index.js > dist/qs.js", + "prepublish": "npm run dist" + }, + "license": "BSD-3-Clause", + "gitHead": "d67d315b606c6bb809fedcbeebbbdb7f863852aa", + "bugs": { + "url": "https://github.com/ljharb/qs/issues" + }, + "_id": "qs@6.2.0", + "_shasum": "3b7848c03c2dece69a9522b0fae8c4126d745f3b", + "_from": "qs@6.2.0", + "_npmVersion": "3.8.6", + "_nodeVersion": "6.1.0", + "_npmUser": { + "name": "ljharb", + "email": "ljharb@gmail.com" + }, + "dist": { + "shasum": "3b7848c03c2dece69a9522b0fae8c4126d745f3b", + "tarball": "https://registry.npmjs.org/qs/-/qs-6.2.0.tgz" + }, + "maintainers": [ + { + "name": "hueniverse", + "email": "eran@hammer.io" + }, + { + "name": "ljharb", + "email": "ljharb@gmail.com" + }, + { + "name": "nlf", + "email": "quitlahok@gmail.com" + } + ], + "_npmOperationalInternal": { + "host": "packages-12-west.internal.npmjs.com", + "tmp": "tmp/qs-6.2.0.tgz_1462749349998_0.03372702235355973" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/qs/-/qs-6.2.0.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/body-parser/node_modules/qs/test/index.js b/node_modules/body-parser/node_modules/qs/test/index.js new file mode 100644 index 0000000..b6a7d95 --- /dev/null +++ b/node_modules/body-parser/node_modules/qs/test/index.js @@ -0,0 +1,5 @@ +require('./parse'); + +require('./stringify'); + +require('./utils'); diff --git a/node_modules/body-parser/node_modules/qs/test/parse.js b/node_modules/body-parser/node_modules/qs/test/parse.js new file mode 100644 index 0000000..1b79daf --- /dev/null +++ b/node_modules/body-parser/node_modules/qs/test/parse.js @@ -0,0 +1,423 @@ +'use strict'; + +var test = require('tape'); +var qs = require('../'); +var iconv = require('iconv-lite'); + +test('parse()', function (t) { + t.test('parses a simple string', function (st) { + st.deepEqual(qs.parse('0=foo'), { '0': 'foo' }); + st.deepEqual(qs.parse('foo=c++'), { foo: 'c ' }); + st.deepEqual(qs.parse('a[>=]=23'), { a: { '>=': '23' } }); + st.deepEqual(qs.parse('a[<=>]==23'), { a: { '<=>': '=23' } }); + st.deepEqual(qs.parse('a[==]=23'), { a: { '==': '23' } }); + st.deepEqual(qs.parse('foo', { strictNullHandling: true }), { foo: null }); + st.deepEqual(qs.parse('foo'), { foo: '' }); + st.deepEqual(qs.parse('foo='), { foo: '' }); + st.deepEqual(qs.parse('foo=bar'), { foo: 'bar' }); + st.deepEqual(qs.parse(' foo = bar = baz '), { ' foo ': ' bar = baz ' }); + st.deepEqual(qs.parse('foo=bar=baz'), { foo: 'bar=baz' }); + st.deepEqual(qs.parse('foo=bar&bar=baz'), { foo: 'bar', bar: 'baz' }); + st.deepEqual(qs.parse('foo2=bar2&baz2='), { foo2: 'bar2', baz2: '' }); + st.deepEqual(qs.parse('foo=bar&baz', { strictNullHandling: true }), { foo: 'bar', baz: null }); + st.deepEqual(qs.parse('foo=bar&baz'), { foo: 'bar', baz: '' }); + st.deepEqual(qs.parse('cht=p3&chd=t:60,40&chs=250x100&chl=Hello|World'), { + cht: 'p3', + chd: 't:60,40', + chs: '250x100', + chl: 'Hello|World' + }); + st.end(); + }); + + t.test('allows enabling dot notation', function (st) { + st.deepEqual(qs.parse('a.b=c'), { 'a.b': 'c' }); + st.deepEqual(qs.parse('a.b=c', { allowDots: true }), { a: { b: 'c' } }); + st.end(); + }); + + t.deepEqual(qs.parse('a[b]=c'), { a: { b: 'c' } }, 'parses a single nested string'); + t.deepEqual(qs.parse('a[b][c]=d'), { a: { b: { c: 'd' } } }, 'parses a double nested string'); + t.deepEqual( + qs.parse('a[b][c][d][e][f][g][h]=i'), + { a: { b: { c: { d: { e: { f: { '[g][h]': 'i' } } } } } } }, + 'defaults to a depth of 5' + ); + + t.test('only parses one level when depth = 1', function (st) { + st.deepEqual(qs.parse('a[b][c]=d', { depth: 1 }), { a: { b: { '[c]': 'd' } } }); + st.deepEqual(qs.parse('a[b][c][d]=e', { depth: 1 }), { a: { b: { '[c][d]': 'e' } } }); + st.end(); + }); + + t.deepEqual(qs.parse('a=b&a=c'), { a: ['b', 'c'] }, 'parses a simple array'); + + t.test('parses an explicit array', function (st) { + st.deepEqual(qs.parse('a[]=b'), { a: ['b'] }); + st.deepEqual(qs.parse('a[]=b&a[]=c'), { a: ['b', 'c'] }); + st.deepEqual(qs.parse('a[]=b&a[]=c&a[]=d'), { a: ['b', 'c', 'd'] }); + st.end(); + }); + + t.test('parses a mix of simple and explicit arrays', function (st) { + st.deepEqual(qs.parse('a=b&a[]=c'), { a: ['b', 'c'] }); + st.deepEqual(qs.parse('a[]=b&a=c'), { a: ['b', 'c'] }); + st.deepEqual(qs.parse('a[0]=b&a=c'), { a: ['b', 'c'] }); + st.deepEqual(qs.parse('a=b&a[0]=c'), { a: ['b', 'c'] }); + st.deepEqual(qs.parse('a[1]=b&a=c'), { a: ['b', 'c'] }); + st.deepEqual(qs.parse('a=b&a[1]=c'), { a: ['b', 'c'] }); + st.end(); + }); + + t.test('parses a nested array', function (st) { + st.deepEqual(qs.parse('a[b][]=c&a[b][]=d'), { a: { b: ['c', 'd'] } }); + st.deepEqual(qs.parse('a[>=]=25'), { a: { '>=': '25' } }); + st.end(); + }); + + t.test('allows to specify array indices', function (st) { + st.deepEqual(qs.parse('a[1]=c&a[0]=b&a[2]=d'), { a: ['b', 'c', 'd'] }); + st.deepEqual(qs.parse('a[1]=c&a[0]=b'), { a: ['b', 'c'] }); + st.deepEqual(qs.parse('a[1]=c'), { a: ['c'] }); + st.end(); + }); + + t.test('limits specific array indices to 20', function (st) { + st.deepEqual(qs.parse('a[20]=a'), { a: ['a'] }); + st.deepEqual(qs.parse('a[21]=a'), { a: { '21': 'a' } }); + st.end(); + }); + + t.deepEqual(qs.parse('a[12b]=c'), { a: { '12b': 'c' } }, 'supports keys that begin with a number'); + + t.test('supports encoded = signs', function (st) { + st.deepEqual(qs.parse('he%3Dllo=th%3Dere'), { 'he=llo': 'th=ere' }); + st.end(); + }); + + t.test('is ok with url encoded strings', function (st) { + st.deepEqual(qs.parse('a[b%20c]=d'), { a: { 'b c': 'd' } }); + st.deepEqual(qs.parse('a[b]=c%20d'), { a: { b: 'c d' } }); + st.end(); + }); + + t.test('allows brackets in the value', function (st) { + st.deepEqual(qs.parse('pets=["tobi"]'), { pets: '["tobi"]' }); + st.deepEqual(qs.parse('operators=[">=", "<="]'), { operators: '[">=", "<="]' }); + st.end(); + }); + + t.test('allows empty values', function (st) { + st.deepEqual(qs.parse(''), {}); + st.deepEqual(qs.parse(null), {}); + st.deepEqual(qs.parse(undefined), {}); + st.end(); + }); + + t.test('transforms arrays to objects', function (st) { + st.deepEqual(qs.parse('foo[0]=bar&foo[bad]=baz'), { foo: { '0': 'bar', bad: 'baz' } }); + st.deepEqual(qs.parse('foo[bad]=baz&foo[0]=bar'), { foo: { bad: 'baz', '0': 'bar' } }); + st.deepEqual(qs.parse('foo[bad]=baz&foo[]=bar'), { foo: { bad: 'baz', '0': 'bar' } }); + st.deepEqual(qs.parse('foo[]=bar&foo[bad]=baz'), { foo: { '0': 'bar', bad: 'baz' } }); + st.deepEqual(qs.parse('foo[bad]=baz&foo[]=bar&foo[]=foo'), { foo: { bad: 'baz', '0': 'bar', '1': 'foo' } }); + st.deepEqual(qs.parse('foo[0][a]=a&foo[0][b]=b&foo[1][a]=aa&foo[1][b]=bb'), { foo: [{ a: 'a', b: 'b' }, { a: 'aa', b: 'bb' }] }); + st.deepEqual(qs.parse('a[]=b&a[t]=u&a[hasOwnProperty]=c'), { a: { '0': 'b', t: 'u', c: true } }); + st.deepEqual(qs.parse('a[]=b&a[hasOwnProperty]=c&a[x]=y'), { a: { '0': 'b', '1': 'c', x: 'y' } }); + st.end(); + }); + + t.test('transforms arrays to objects (dot notation)', function (st) { + st.deepEqual(qs.parse('foo[0].baz=bar&fool.bad=baz', { allowDots: true }), { foo: [{ baz: 'bar' }], fool: { bad: 'baz' } }); + st.deepEqual(qs.parse('foo[0].baz=bar&fool.bad.boo=baz', { allowDots: true }), { foo: [{ baz: 'bar' }], fool: { bad: { boo: 'baz' } } }); + st.deepEqual(qs.parse('foo[0][0].baz=bar&fool.bad=baz', { allowDots: true }), { foo: [[{ baz: 'bar' }]], fool: { bad: 'baz' } }); + st.deepEqual(qs.parse('foo[0].baz[0]=15&foo[0].bar=2', { allowDots: true }), { foo: [{ baz: ['15'], bar: '2' }] }); + st.deepEqual(qs.parse('foo[0].baz[0]=15&foo[0].baz[1]=16&foo[0].bar=2', { allowDots: true }), { foo: [{ baz: ['15', '16'], bar: '2' }] }); + st.deepEqual(qs.parse('foo.bad=baz&foo[0]=bar', { allowDots: true }), { foo: { bad: 'baz', '0': 'bar' } }); + st.deepEqual(qs.parse('foo.bad=baz&foo[]=bar', { allowDots: true }), { foo: { bad: 'baz', '0': 'bar' } }); + st.deepEqual(qs.parse('foo[]=bar&foo.bad=baz', { allowDots: true }), { foo: { '0': 'bar', bad: 'baz' } }); + st.deepEqual(qs.parse('foo.bad=baz&foo[]=bar&foo[]=foo', { allowDots: true }), { foo: { bad: 'baz', '0': 'bar', '1': 'foo' } }); + st.deepEqual(qs.parse('foo[0].a=a&foo[0].b=b&foo[1].a=aa&foo[1].b=bb', { allowDots: true }), { foo: [{ a: 'a', b: 'b' }, { a: 'aa', b: 'bb' }] }); + st.end(); + }); + + t.deepEqual(qs.parse('a[b]=c&a=d'), { a: { b: 'c', d: true } }, 'can add keys to objects'); + + t.test('correctly prunes undefined values when converting an array to an object', function (st) { + st.deepEqual(qs.parse('a[2]=b&a[99999999]=c'), { a: { '2': 'b', '99999999': 'c' } }); + st.end(); + }); + + t.test('supports malformed uri characters', function (st) { + st.deepEqual(qs.parse('{%:%}', { strictNullHandling: true }), { '{%:%}': null }); + st.deepEqual(qs.parse('{%:%}='), { '{%:%}': '' }); + st.deepEqual(qs.parse('foo=%:%}'), { foo: '%:%}' }); + st.end(); + }); + + t.test('doesn\'t produce empty keys', function (st) { + st.deepEqual(qs.parse('_r=1&'), { '_r': '1' }); + st.end(); + }); + + t.test('cannot access Object prototype', function (st) { + qs.parse('constructor[prototype][bad]=bad'); + qs.parse('bad[constructor][prototype][bad]=bad'); + st.equal(typeof Object.prototype.bad, 'undefined'); + st.end(); + }); + + t.test('parses arrays of objects', function (st) { + st.deepEqual(qs.parse('a[][b]=c'), { a: [{ b: 'c' }] }); + st.deepEqual(qs.parse('a[0][b]=c'), { a: [{ b: 'c' }] }); + st.end(); + }); + + t.test('allows for empty strings in arrays', function (st) { + st.deepEqual(qs.parse('a[]=b&a[]=&a[]=c'), { a: ['b', '', 'c'] }); + st.deepEqual(qs.parse('a[0]=b&a[1]&a[2]=c&a[19]=', { strictNullHandling: true }), { a: ['b', null, 'c', ''] }); + st.deepEqual(qs.parse('a[0]=b&a[1]=&a[2]=c&a[19]', { strictNullHandling: true }), { a: ['b', '', 'c', null] }); + st.deepEqual(qs.parse('a[]=&a[]=b&a[]=c'), { a: ['', 'b', 'c'] }); + st.end(); + }); + + t.test('compacts sparse arrays', function (st) { + st.deepEqual(qs.parse('a[10]=1&a[2]=2'), { a: ['2', '1'] }); + st.deepEqual(qs.parse('a[1][b][2][c]=1'), { a: [{ b: [{ c: '1' }] }] }); + st.deepEqual(qs.parse('a[1][2][3][c]=1'), { a: [[[{ c: '1' }]]] }); + st.deepEqual(qs.parse('a[1][2][3][c][1]=1'), { a: [[[{ c: ['1'] }]]] }); + st.end(); + }); + + t.test('parses semi-parsed strings', function (st) { + st.deepEqual(qs.parse({ 'a[b]': 'c' }), { a: { b: 'c' } }); + st.deepEqual(qs.parse({ 'a[b]': 'c', 'a[d]': 'e' }), { a: { b: 'c', d: 'e' } }); + st.end(); + }); + + t.test('parses buffers correctly', function (st) { + var b = new Buffer('test'); + st.deepEqual(qs.parse({ a: b }), { a: b }); + st.end(); + }); + + t.test('continues parsing when no parent is found', function (st) { + st.deepEqual(qs.parse('[]=&a=b'), { '0': '', a: 'b' }); + st.deepEqual(qs.parse('[]&a=b', { strictNullHandling: true }), { '0': null, a: 'b' }); + st.deepEqual(qs.parse('[foo]=bar'), { foo: 'bar' }); + st.end(); + }); + + t.test('does not error when parsing a very long array', function (st) { + var str = 'a[]=a'; + while (Buffer.byteLength(str) < 128 * 1024) { + str = str + '&' + str; + } + + st.doesNotThrow(function () { qs.parse(str); }); + + st.end(); + }); + + t.test('should not throw when a native prototype has an enumerable property', { parallel: false }, function (st) { + Object.prototype.crash = ''; + Array.prototype.crash = ''; + st.doesNotThrow(qs.parse.bind(null, 'a=b')); + st.deepEqual(qs.parse('a=b'), { a: 'b' }); + st.doesNotThrow(qs.parse.bind(null, 'a[][b]=c')); + st.deepEqual(qs.parse('a[][b]=c'), { a: [{ b: 'c' }] }); + delete Object.prototype.crash; + delete Array.prototype.crash; + st.end(); + }); + + t.test('parses a string with an alternative string delimiter', function (st) { + st.deepEqual(qs.parse('a=b;c=d', { delimiter: ';' }), { a: 'b', c: 'd' }); + st.end(); + }); + + t.test('parses a string with an alternative RegExp delimiter', function (st) { + st.deepEqual(qs.parse('a=b; c=d', { delimiter: /[;,] */ }), { a: 'b', c: 'd' }); + st.end(); + }); + + t.test('does not use non-splittable objects as delimiters', function (st) { + st.deepEqual(qs.parse('a=b&c=d', { delimiter: true }), { a: 'b', c: 'd' }); + st.end(); + }); + + t.test('allows overriding parameter limit', function (st) { + st.deepEqual(qs.parse('a=b&c=d', { parameterLimit: 1 }), { a: 'b' }); + st.end(); + }); + + t.test('allows setting the parameter limit to Infinity', function (st) { + st.deepEqual(qs.parse('a=b&c=d', { parameterLimit: Infinity }), { a: 'b', c: 'd' }); + st.end(); + }); + + t.test('allows overriding array limit', function (st) { + st.deepEqual(qs.parse('a[0]=b', { arrayLimit: -1 }), { a: { '0': 'b' } }); + st.deepEqual(qs.parse('a[-1]=b', { arrayLimit: -1 }), { a: { '-1': 'b' } }); + st.deepEqual(qs.parse('a[0]=b&a[1]=c', { arrayLimit: 0 }), { a: { '0': 'b', '1': 'c' } }); + st.end(); + }); + + t.test('allows disabling array parsing', function (st) { + st.deepEqual(qs.parse('a[0]=b&a[1]=c', { parseArrays: false }), { a: { '0': 'b', '1': 'c' } }); + st.end(); + }); + + t.test('parses an object', function (st) { + var input = { + 'user[name]': { 'pop[bob]': 3 }, + 'user[email]': null + }; + + var expected = { + user: { + name: { 'pop[bob]': 3 }, + email: null + } + }; + + var result = qs.parse(input); + + st.deepEqual(result, expected); + st.end(); + }); + + t.test('parses an object in dot notation', function (st) { + var input = { + 'user.name': { 'pop[bob]': 3 }, + 'user.email.': null + }; + + var expected = { + user: { + name: { 'pop[bob]': 3 }, + email: null + } + }; + + var result = qs.parse(input, { allowDots: true }); + + st.deepEqual(result, expected); + st.end(); + }); + + t.test('parses an object and not child values', function (st) { + var input = { + 'user[name]': { 'pop[bob]': { 'test': 3 } }, + 'user[email]': null + }; + + var expected = { + user: { + name: { 'pop[bob]': { 'test': 3 } }, + email: null + } + }; + + var result = qs.parse(input); + + st.deepEqual(result, expected); + st.end(); + }); + + t.test('does not blow up when Buffer global is missing', function (st) { + var tempBuffer = global.Buffer; + delete global.Buffer; + var result = qs.parse('a=b&c=d'); + global.Buffer = tempBuffer; + st.deepEqual(result, { a: 'b', c: 'd' }); + st.end(); + }); + + t.test('does not crash when parsing circular references', function (st) { + var a = {}; + a.b = a; + + var parsed; + + st.doesNotThrow(function () { + parsed = qs.parse({ 'foo[bar]': 'baz', 'foo[baz]': a }); + }); + + st.equal('foo' in parsed, true, 'parsed has "foo" property'); + st.equal('bar' in parsed.foo, true); + st.equal('baz' in parsed.foo, true); + st.equal(parsed.foo.bar, 'baz'); + st.deepEqual(parsed.foo.baz, a); + st.end(); + }); + + t.test('parses plain objects correctly', function (st) { + var a = Object.create(null); + a.b = 'c'; + + st.deepEqual(qs.parse(a), { b: 'c' }); + var result = qs.parse({ a: a }); + st.equal('a' in result, true, 'result has "a" property'); + st.deepEqual(result.a, a); + st.end(); + }); + + t.test('parses dates correctly', function (st) { + var now = new Date(); + st.deepEqual(qs.parse({ a: now }), { a: now }); + st.end(); + }); + + t.test('parses regular expressions correctly', function (st) { + var re = /^test$/; + st.deepEqual(qs.parse({ a: re }), { a: re }); + st.end(); + }); + + t.test('can allow overwriting prototype properties', function (st) { + st.deepEqual(qs.parse('a[hasOwnProperty]=b', { allowPrototypes: true }), { a: { hasOwnProperty: 'b' } }, { prototype: false }); + st.deepEqual(qs.parse('hasOwnProperty=b', { allowPrototypes: true }), { hasOwnProperty: 'b' }, { prototype: false }); + st.end(); + }); + + t.test('can return plain objects', function (st) { + var expected = Object.create(null); + expected.a = Object.create(null); + expected.a.b = 'c'; + expected.a.hasOwnProperty = 'd'; + st.deepEqual(qs.parse('a[b]=c&a[hasOwnProperty]=d', { plainObjects: true }), expected); + st.deepEqual(qs.parse(null, { plainObjects: true }), Object.create(null)); + var expectedArray = Object.create(null); + expectedArray.a = Object.create(null); + expectedArray.a['0'] = 'b'; + expectedArray.a.c = 'd'; + st.deepEqual(qs.parse('a[]=b&a[c]=d', { plainObjects: true }), expectedArray); + st.end(); + }); + + t.test('can parse with custom encoding', function (st) { + st.deepEqual(qs.parse('%8c%a7=%91%e5%8d%e3%95%7b', { + decoder: function (str) { + var reg = /\%([0-9A-F]{2})/ig; + var result = []; + var parts; + var last = 0; + while (parts = reg.exec(str)) { + result.push(parseInt(parts[1], 16)); + last = parts.index + parts[0].length; + } + return iconv.decode(new Buffer(result), 'shift_jis').toString(); + } + }), { 県: '大阪府' }); + st.end(); + }); + + t.test('throws error with wrong decoder', function (st) { + st.throws(function () { + qs.parse({}, { + decoder: 'string' + }); + }, new TypeError('Decoder has to be a function.')); + st.end(); + }); +}); diff --git a/node_modules/body-parser/node_modules/qs/test/stringify.js b/node_modules/body-parser/node_modules/qs/test/stringify.js new file mode 100644 index 0000000..699397e --- /dev/null +++ b/node_modules/body-parser/node_modules/qs/test/stringify.js @@ -0,0 +1,305 @@ +'use strict'; + +var test = require('tape'); +var qs = require('../'); +var iconv = require('iconv-lite'); + +test('stringify()', function (t) { + t.test('stringifies a querystring object', function (st) { + st.equal(qs.stringify({ a: 'b' }), 'a=b'); + st.equal(qs.stringify({ a: 1 }), 'a=1'); + st.equal(qs.stringify({ a: 1, b: 2 }), 'a=1&b=2'); + st.equal(qs.stringify({ a: 'A_Z' }), 'a=A_Z'); + st.equal(qs.stringify({ a: '€' }), 'a=%E2%82%AC'); + st.equal(qs.stringify({ a: '' }), 'a=%EE%80%80'); + st.equal(qs.stringify({ a: 'א' }), 'a=%D7%90'); + st.equal(qs.stringify({ a: '𐐷' }), 'a=%F0%90%90%B7'); + st.end(); + }); + + t.test('stringifies a nested object', function (st) { + st.equal(qs.stringify({ a: { b: 'c' } }), 'a%5Bb%5D=c'); + st.equal(qs.stringify({ a: { b: { c: { d: 'e' } } } }), 'a%5Bb%5D%5Bc%5D%5Bd%5D=e'); + st.end(); + }); + + t.test('stringifies a nested object with dots notation', function (st) { + st.equal(qs.stringify({ a: { b: 'c' } }, { allowDots: true }), 'a.b=c'); + st.equal(qs.stringify({ a: { b: { c: { d: 'e' } } } }, { allowDots: true }), 'a.b.c.d=e'); + st.end(); + }); + + t.test('stringifies an array value', function (st) { + st.equal(qs.stringify({ a: ['b', 'c', 'd'] }), 'a%5B0%5D=b&a%5B1%5D=c&a%5B2%5D=d'); + st.end(); + }); + + t.test('omits nulls when asked', function (st) { + st.equal(qs.stringify({ a: 'b', c: null }, { skipNulls: true }), 'a=b'); + st.end(); + }); + + + t.test('omits nested nulls when asked', function (st) { + st.equal(qs.stringify({ a: { b: 'c', d: null } }, { skipNulls: true }), 'a%5Bb%5D=c'); + st.end(); + }); + + t.test('omits array indices when asked', function (st) { + st.equal(qs.stringify({ a: ['b', 'c', 'd'] }, { indices: false }), 'a=b&a=c&a=d'); + st.end(); + }); + + t.test('stringifies a nested array value', function (st) { + st.equal(qs.stringify({ a: { b: ['c', 'd'] } }), 'a%5Bb%5D%5B0%5D=c&a%5Bb%5D%5B1%5D=d'); + st.end(); + }); + + t.test('stringifies a nested array value with dots notation', function (st) { + st.equal(qs.stringify({ a: { b: ['c', 'd'] } }, { allowDots: true, encode: false }), 'a.b[0]=c&a.b[1]=d'); + st.end(); + }); + + t.test('stringifies an object inside an array', function (st) { + st.equal(qs.stringify({ a: [{ b: 'c' }] }), 'a%5B0%5D%5Bb%5D=c'); + st.equal(qs.stringify({ a: [{ b: { c: [1] } }] }), 'a%5B0%5D%5Bb%5D%5Bc%5D%5B0%5D=1'); + st.end(); + }); + + t.test('stringifies an array with mixed objects and primitives', function (st) { + st.equal(qs.stringify({ a: [{ b: 1 }, 2, 3] }, { encode: false }), 'a[0][b]=1&a[1]=2&a[2]=3'); + st.end(); + }); + + t.test('stringifies an object inside an array with dots notation', function (st) { + st.equal(qs.stringify({ a: [{ b: 'c' }] }, { allowDots: true, encode: false }), 'a[0].b=c'); + st.equal(qs.stringify({ a: [{ b: { c: [1] } }] }, { allowDots: true, encode: false }), 'a[0].b.c[0]=1'); + st.end(); + }); + + t.test('does not omit object keys when indices = false', function (st) { + st.equal(qs.stringify({ a: [{ b: 'c' }] }, { indices: false }), 'a%5Bb%5D=c'); + st.end(); + }); + + t.test('uses indices notation for arrays when indices=true', function (st) { + st.equal(qs.stringify({ a: ['b', 'c'] }, { indices: true }), 'a%5B0%5D=b&a%5B1%5D=c'); + st.end(); + }); + + t.test('uses indices notation for arrays when no arrayFormat is specified', function (st) { + st.equal(qs.stringify({ a: ['b', 'c'] }), 'a%5B0%5D=b&a%5B1%5D=c'); + st.end(); + }); + + t.test('uses indices notation for arrays when no arrayFormat=indices', function (st) { + st.equal(qs.stringify({ a: ['b', 'c'] }, { arrayFormat: 'indices' }), 'a%5B0%5D=b&a%5B1%5D=c'); + st.end(); + }); + + t.test('uses repeat notation for arrays when no arrayFormat=repeat', function (st) { + st.equal(qs.stringify({ a: ['b', 'c'] }, { arrayFormat: 'repeat' }), 'a=b&a=c'); + st.end(); + }); + + t.test('uses brackets notation for arrays when no arrayFormat=brackets', function (st) { + st.equal(qs.stringify({ a: ['b', 'c'] }, { arrayFormat: 'brackets' }), 'a%5B%5D=b&a%5B%5D=c'); + st.end(); + }); + + t.test('stringifies a complicated object', function (st) { + st.equal(qs.stringify({ a: { b: 'c', d: 'e' } }), 'a%5Bb%5D=c&a%5Bd%5D=e'); + st.end(); + }); + + t.test('stringifies an empty value', function (st) { + st.equal(qs.stringify({ a: '' }), 'a='); + st.equal(qs.stringify({ a: null }, { strictNullHandling: true }), 'a'); + + st.equal(qs.stringify({ a: '', b: '' }), 'a=&b='); + st.equal(qs.stringify({ a: null, b: '' }, { strictNullHandling: true }), 'a&b='); + + st.equal(qs.stringify({ a: { b: '' } }), 'a%5Bb%5D='); + st.equal(qs.stringify({ a: { b: null } }, { strictNullHandling: true }), 'a%5Bb%5D'); + st.equal(qs.stringify({ a: { b: null } }, { strictNullHandling: false }), 'a%5Bb%5D='); + + st.end(); + }); + + t.test('stringifies an empty object', function (st) { + var obj = Object.create(null); + obj.a = 'b'; + st.equal(qs.stringify(obj), 'a=b'); + st.end(); + }); + + t.test('returns an empty string for invalid input', function (st) { + st.equal(qs.stringify(undefined), ''); + st.equal(qs.stringify(false), ''); + st.equal(qs.stringify(null), ''); + st.equal(qs.stringify(''), ''); + st.end(); + }); + + t.test('stringifies an object with an empty object as a child', function (st) { + var obj = { + a: Object.create(null) + }; + + obj.a.b = 'c'; + st.equal(qs.stringify(obj), 'a%5Bb%5D=c'); + st.end(); + }); + + t.test('drops keys with a value of undefined', function (st) { + st.equal(qs.stringify({ a: undefined }), ''); + + st.equal(qs.stringify({ a: { b: undefined, c: null } }, { strictNullHandling: true }), 'a%5Bc%5D'); + st.equal(qs.stringify({ a: { b: undefined, c: null } }, { strictNullHandling: false }), 'a%5Bc%5D='); + st.equal(qs.stringify({ a: { b: undefined, c: '' } }), 'a%5Bc%5D='); + st.end(); + }); + + t.test('url encodes values', function (st) { + st.equal(qs.stringify({ a: 'b c' }), 'a=b%20c'); + st.end(); + }); + + t.test('stringifies a date', function (st) { + var now = new Date(); + var str = 'a=' + encodeURIComponent(now.toISOString()); + st.equal(qs.stringify({ a: now }), str); + st.end(); + }); + + t.test('stringifies the weird object from qs', function (st) { + st.equal(qs.stringify({ 'my weird field': '~q1!2"\'w$5&7/z8)?' }), 'my%20weird%20field=~q1%212%22%27w%245%267%2Fz8%29%3F'); + st.end(); + }); + + t.test('skips properties that are part of the object prototype', function (st) { + Object.prototype.crash = 'test'; + st.equal(qs.stringify({ a: 'b' }), 'a=b'); + st.equal(qs.stringify({ a: { b: 'c' } }), 'a%5Bb%5D=c'); + delete Object.prototype.crash; + st.end(); + }); + + t.test('stringifies boolean values', function (st) { + st.equal(qs.stringify({ a: true }), 'a=true'); + st.equal(qs.stringify({ a: { b: true } }), 'a%5Bb%5D=true'); + st.equal(qs.stringify({ b: false }), 'b=false'); + st.equal(qs.stringify({ b: { c: false } }), 'b%5Bc%5D=false'); + st.end(); + }); + + t.test('stringifies buffer values', function (st) { + st.equal(qs.stringify({ a: new Buffer('test') }), 'a=test'); + st.equal(qs.stringify({ a: { b: new Buffer('test') } }), 'a%5Bb%5D=test'); + st.end(); + }); + + t.test('stringifies an object using an alternative delimiter', function (st) { + st.equal(qs.stringify({ a: 'b', c: 'd' }, { delimiter: ';' }), 'a=b;c=d'); + st.end(); + }); + + t.test('doesn\'t blow up when Buffer global is missing', function (st) { + var tempBuffer = global.Buffer; + delete global.Buffer; + var result = qs.stringify({ a: 'b', c: 'd' }); + global.Buffer = tempBuffer; + st.equal(result, 'a=b&c=d'); + st.end(); + }); + + t.test('selects properties when filter=array', function (st) { + st.equal(qs.stringify({ a: 'b' }, { filter: ['a'] }), 'a=b'); + st.equal(qs.stringify({ a: 1 }, { filter: [] }), ''); + st.equal(qs.stringify({ a: { b: [1, 2, 3, 4], c: 'd' }, c: 'f' }, { filter: ['a', 'b', 0, 2] }), 'a%5Bb%5D%5B0%5D=1&a%5Bb%5D%5B2%5D=3'); + st.end(); + }); + + t.test('supports custom representations when filter=function', function (st) { + var calls = 0; + var obj = { a: 'b', c: 'd', e: { f: new Date(1257894000000) } }; + var filterFunc = function (prefix, value) { + calls++; + if (calls === 1) { + st.equal(prefix, '', 'prefix is empty'); + st.equal(value, obj); + } else if (prefix === 'c') { + return; + } else if (value instanceof Date) { + st.equal(prefix, 'e[f]'); + return value.getTime(); + } + return value; + }; + + st.equal(qs.stringify(obj, { filter: filterFunc }), 'a=b&e%5Bf%5D=1257894000000'); + st.equal(calls, 5); + st.end(); + }); + + t.test('can disable uri encoding', function (st) { + st.equal(qs.stringify({ a: 'b' }, { encode: false }), 'a=b'); + st.equal(qs.stringify({ a: { b: 'c' } }, { encode: false }), 'a[b]=c'); + st.equal(qs.stringify({ a: 'b', c: null }, { strictNullHandling: true, encode: false }), 'a=b&c'); + st.end(); + }); + + t.test('can sort the keys', function (st) { + var sort = function (a, b) { return a.localeCompare(b); }; + st.equal(qs.stringify({ a: 'c', z: 'y', b: 'f' }, { sort: sort }), 'a=c&b=f&z=y'); + st.equal(qs.stringify({ a: 'c', z: { j: 'a', i: 'b' }, b: 'f' }, { sort: sort }), 'a=c&b=f&z%5Bi%5D=b&z%5Bj%5D=a'); + st.end(); + }); + + t.test('can sort the keys at depth 3 or more too', function (st) { + var sort = function (a, b) { return a.localeCompare(b); }; + st.equal(qs.stringify({ a: 'a', z: { zj: {zjb: 'zjb', zja: 'zja'}, zi: {zib: 'zib', zia: 'zia'} }, b: 'b' }, { sort: sort, encode: false }), 'a=a&b=b&z[zi][zia]=zia&z[zi][zib]=zib&z[zj][zja]=zja&z[zj][zjb]=zjb'); + st.equal(qs.stringify({ a: 'a', z: { zj: {zjb: 'zjb', zja: 'zja'}, zi: {zib: 'zib', zia: 'zia'} }, b: 'b' }, { sort: null, encode: false }), 'a=a&z[zj][zjb]=zjb&z[zj][zja]=zja&z[zi][zib]=zib&z[zi][zia]=zia&b=b'); + st.end(); + }); + + t.test('can stringify with custom encoding', function (st) { + st.equal(qs.stringify({ 県: '大阪府', '': ''}, { + encoder: function (str) { + if (str.length === 0) { + return ''; + } + var buf = iconv.encode(str, 'shiftjis'); + var result = []; + for (var i=0; i < buf.length; ++i) { + result.push(buf.readUInt8(i).toString(16)); + } + return '%' + result.join('%'); + } + }), '%8c%a7=%91%e5%8d%e3%95%7b&='); + st.end(); + }); + + t.test('throws error with wrong encoder', function (st) { + st.throws(function () { + qs.stringify({}, { + encoder: 'string' + }); + }, new TypeError('Encoder has to be a function.')); + st.end(); + }); + + t.test('can use custom encoder for a buffer object', { + skip: typeof Buffer === 'undefined' + }, function (st) { + st.equal(qs.stringify({ a: new Buffer([1]) }, { + encoder: function (buffer) { + if (typeof buffer === 'string') { + return buffer; + } + return String.fromCharCode(buffer.readUInt8(0) + 97); + } + }), 'a=b'); + st.end(); + }); +}); diff --git a/node_modules/body-parser/node_modules/qs/test/utils.js b/node_modules/body-parser/node_modules/qs/test/utils.js new file mode 100644 index 0000000..4a8d824 --- /dev/null +++ b/node_modules/body-parser/node_modules/qs/test/utils.js @@ -0,0 +1,9 @@ +'use strict'; + +var test = require('tape'); +var utils = require('../lib/utils'); + +test('merge()', function (t) { + t.deepEqual(utils.merge({ a: 'b' }, { a: 'c' }), { a: ['b', 'c'] }, 'merges two objects with the same key'); + t.end(); +}); diff --git a/node_modules/body-parser/node_modules/raw-body/HISTORY.md b/node_modules/body-parser/node_modules/raw-body/HISTORY.md new file mode 100644 index 0000000..720c860 --- /dev/null +++ b/node_modules/body-parser/node_modules/raw-body/HISTORY.md @@ -0,0 +1,209 @@ +2.1.7 / 2016-06-19 +================== + + * deps: bytes@2.4.0 + * perf: remove double-cleanup on happy path + +2.1.6 / 2016-03-07 +================== + + * deps: bytes@2.3.0 + - Drop partial bytes on all parsed units + - Fix parsing byte string that looks like hex + +2.1.5 / 2015-11-30 +================== + + * deps: bytes@2.2.0 + * deps: iconv-lite@0.4.13 + +2.1.4 / 2015-09-27 +================== + + * Fix masking critical errors from `iconv-lite` + * deps: iconv-lite@0.4.12 + - Fix CESU-8 decoding in Node.js 4.x + +2.1.3 / 2015-09-12 +================== + + * Fix sync callback when attaching data listener causes sync read + - Node.js 0.10 compatibility issue + +2.1.2 / 2015-07-05 +================== + + * Fix error stack traces to skip `makeError` + * deps: iconv-lite@0.4.11 + - Add encoding CESU-8 + +2.1.1 / 2015-06-14 +================== + + * Use `unpipe` module for unpiping requests + +2.1.0 / 2015-05-28 +================== + + * deps: iconv-lite@0.4.10 + - Improved UTF-16 endianness detection + - Leading BOM is now removed when decoding + - The encoding UTF-16 without BOM now defaults to UTF-16LE when detection fails + +2.0.2 / 2015-05-21 +================== + + * deps: bytes@2.1.0 + - Slight optimizations + +2.0.1 / 2015-05-10 +================== + + * Fix a false-positive when unpiping in Node.js 0.8 + +2.0.0 / 2015-05-08 +================== + + * Return a promise without callback instead of thunk + * deps: bytes@2.0.1 + - units no longer case sensitive when parsing + +1.3.4 / 2015-04-15 +================== + + * Fix hanging callback if request aborts during read + * deps: iconv-lite@0.4.8 + - Add encoding alias UNICODE-1-1-UTF-7 + +1.3.3 / 2015-02-08 +================== + + * deps: iconv-lite@0.4.7 + - Gracefully support enumerables on `Object.prototype` + +1.3.2 / 2015-01-20 +================== + + * deps: iconv-lite@0.4.6 + - Fix rare aliases of single-byte encodings + +1.3.1 / 2014-11-21 +================== + + * deps: iconv-lite@0.4.5 + - Fix Windows-31J and X-SJIS encoding support + +1.3.0 / 2014-07-20 +================== + + * Fully unpipe the stream on error + - Fixes `Cannot switch to old mode now` error on Node.js 0.10+ + +1.2.3 / 2014-07-20 +================== + + * deps: iconv-lite@0.4.4 + - Added encoding UTF-7 + +1.2.2 / 2014-06-19 +================== + + * Send invalid encoding error to callback + +1.2.1 / 2014-06-15 +================== + + * deps: iconv-lite@0.4.3 + - Added encodings UTF-16BE and UTF-16 with BOM + +1.2.0 / 2014-06-13 +================== + + * Passing string as `options` interpreted as encoding + * Support all encodings from `iconv-lite` + +1.1.7 / 2014-06-12 +================== + + * use `string_decoder` module from npm + +1.1.6 / 2014-05-27 +================== + + * check encoding for old streams1 + * support node.js < 0.10.6 + +1.1.5 / 2014-05-14 +================== + + * bump bytes + +1.1.4 / 2014-04-19 +================== + + * allow true as an option + * bump bytes + +1.1.3 / 2014-03-02 +================== + + * fix case when length=null + +1.1.2 / 2013-12-01 +================== + + * be less strict on state.encoding check + +1.1.1 / 2013-11-27 +================== + + * add engines + +1.1.0 / 2013-11-27 +================== + + * add err.statusCode and err.type + * allow for encoding option to be true + * pause the stream instead of dumping on error + * throw if the stream's encoding is set + +1.0.1 / 2013-11-19 +================== + + * dont support streams1, throw if dev set encoding + +1.0.0 / 2013-11-17 +================== + + * rename `expected` option to `length` + +0.2.0 / 2013-11-15 +================== + + * republish + +0.1.1 / 2013-11-15 +================== + + * use bytes + +0.1.0 / 2013-11-11 +================== + + * generator support + +0.0.3 / 2013-10-10 +================== + + * update repo + +0.0.2 / 2013-09-14 +================== + + * dump stream on bad headers + * listen to events after defining received and buffers + +0.0.1 / 2013-09-14 +================== + + * Initial release diff --git a/node_modules/body-parser/node_modules/raw-body/LICENSE b/node_modules/body-parser/node_modules/raw-body/LICENSE new file mode 100644 index 0000000..d695c8f --- /dev/null +++ b/node_modules/body-parser/node_modules/raw-body/LICENSE @@ -0,0 +1,22 @@ +The MIT License (MIT) + +Copyright (c) 2013-2014 Jonathan Ong +Copyright (c) 2014-2015 Douglas Christopher Wilson + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. diff --git a/node_modules/body-parser/node_modules/raw-body/README.md b/node_modules/body-parser/node_modules/raw-body/README.md new file mode 100644 index 0000000..5799c82 --- /dev/null +++ b/node_modules/body-parser/node_modules/raw-body/README.md @@ -0,0 +1,126 @@ +# raw-body + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Node.js Version][node-version-image]][node-version-url] +[![Build status][travis-image]][travis-url] +[![Test coverage][coveralls-image]][coveralls-url] + +Gets the entire buffer of a stream either as a `Buffer` or a string. +Validates the stream's length against an expected length and maximum limit. +Ideal for parsing request bodies. + +## API + +```js +var getRawBody = require('raw-body') +``` + +### getRawBody(stream, [options], [callback]) + +**Returns a promise if no callback specified and global `Promise` exists.** + +Options: + +- `length` - The length of the stream. + If the contents of the stream do not add up to this length, + an `400` error code is returned. +- `limit` - The byte limit of the body. + If the body ends up being larger than this limit, + a `413` error code is returned. +- `encoding` - The requested encoding. + By default, a `Buffer` instance will be returned. + Most likely, you want `utf8`. + You can use any type of encoding supported by [iconv-lite](https://www.npmjs.org/package/iconv-lite#readme). + +You can also pass a string in place of options to just specify the encoding. + +`callback(err, res)`: + +- `err` - the following attributes will be defined if applicable: + + - `limit` - the limit in bytes + - `length` and `expected` - the expected length of the stream + - `received` - the received bytes + - `encoding` - the invalid encoding + - `status` and `statusCode` - the corresponding status code for the error + - `type` - either `entity.too.large`, `request.aborted`, `request.size.invalid`, `stream.encoding.set`, or `encoding.unsupported` + +- `res` - the result, either as a `String` if an encoding was set or a `Buffer` otherwise. + +If an error occurs, the stream will be paused, everything unpiped, +and you are responsible for correctly disposing the stream. +For HTTP requests, no handling is required if you send a response. +For streams that use file descriptors, you should `stream.destroy()` or `stream.close()` to prevent leaks. + +## Examples + +### Simple Express example + +```js +var getRawBody = require('raw-body') +var typer = require('media-typer') + +app.use(function (req, res, next) { + getRawBody(req, { + length: req.headers['content-length'], + limit: '1mb', + encoding: typer.parse(req.headers['content-type']).parameters.charset + }, function (err, string) { + if (err) return next(err) + req.text = string + next() + }) +}) +``` + +### Simple Koa example + +```js +app.use(function* (next) { + var string = yield getRawBody(this.req, { + length: this.length, + limit: '1mb', + encoding: this.charset + }) +}) +``` + +### Using as a promise + +To use this library as a promise, simply omit the `callback` and a promise is +returned, provided that a global `Promise` is defined. + +```js +var getRawBody = require('raw-body') +var http = require('http') + +var server = http.createServer(function (req, res) { + getRawBody(req) + .then(function (buf) { + res.statusCode = 200 + res.end(buf.length + ' bytes submitted') + }) + .catch(function (err) { + res.statusCode = 500 + res.end(err.message) + }) +}) + +server.listen(3000) +``` + +## License + +[MIT](LICENSE) + +[npm-image]: https://img.shields.io/npm/v/raw-body.svg +[npm-url]: https://npmjs.org/package/raw-body +[node-version-image]: https://img.shields.io/node/v/raw-body.svg +[node-version-url]: http://nodejs.org/download/ +[travis-image]: https://img.shields.io/travis/stream-utils/raw-body/master.svg +[travis-url]: https://travis-ci.org/stream-utils/raw-body +[coveralls-image]: https://img.shields.io/coveralls/stream-utils/raw-body/master.svg +[coveralls-url]: https://coveralls.io/r/stream-utils/raw-body?branch=master +[downloads-image]: https://img.shields.io/npm/dm/raw-body.svg +[downloads-url]: https://npmjs.org/package/raw-body diff --git a/node_modules/body-parser/node_modules/raw-body/index.js b/node_modules/body-parser/node_modules/raw-body/index.js new file mode 100644 index 0000000..57b9c11 --- /dev/null +++ b/node_modules/body-parser/node_modules/raw-body/index.js @@ -0,0 +1,320 @@ +/*! + * raw-body + * Copyright(c) 2013-2014 Jonathan Ong + * Copyright(c) 2014-2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module dependencies. + * @private + */ + +var bytes = require('bytes') +var iconv = require('iconv-lite') +var unpipe = require('unpipe') + +/** + * Module exports. + * @public + */ + +module.exports = getRawBody + +/** + * Module variables. + * @private + */ + +var iconvEncodingMessageRegExp = /^Encoding not recognized: / + +/** + * Get the decoder for a given encoding. + * + * @param {string} encoding + * @private + */ + +function getDecoder (encoding) { + if (!encoding) return null + + try { + return iconv.getDecoder(encoding) + } catch (e) { + // error getting decoder + if (!iconvEncodingMessageRegExp.test(e.message)) throw e + + // the encoding was not found + throw createError(415, 'specified encoding unsupported', 'encoding.unsupported', { + encoding: encoding + }) + } +} + +/** + * Get the raw body of a stream (typically HTTP). + * + * @param {object} stream + * @param {object|string|function} [options] + * @param {function} [callback] + * @public + */ + +function getRawBody (stream, options, callback) { + var done = callback + var opts = options || {} + + if (options === true || typeof options === 'string') { + // short cut for encoding + opts = { + encoding: options + } + } + + if (typeof options === 'function') { + done = options + opts = {} + } + + // validate callback is a function, if provided + if (done !== undefined && typeof done !== 'function') { + throw new TypeError('argument callback must be a function') + } + + // require the callback without promises + if (!done && !global.Promise) { + throw new TypeError('argument callback is required') + } + + // get encoding + var encoding = opts.encoding !== true + ? opts.encoding + : 'utf-8' + + // convert the limit to an integer + var limit = bytes.parse(opts.limit) + + // convert the expected length to an integer + var length = opts.length != null && !isNaN(opts.length) + ? parseInt(opts.length, 10) + : null + + if (done) { + // classic callback style + return readStream(stream, encoding, length, limit, done) + } + + return new Promise(function executor (resolve, reject) { + readStream(stream, encoding, length, limit, function onRead (err, buf) { + if (err) return reject(err) + resolve(buf) + }) + }) +} + +/** + * Halt a stream. + * + * @param {Object} stream + * @private + */ + +function halt (stream) { + // unpipe everything from the stream + unpipe(stream) + + // pause stream + if (typeof stream.pause === 'function') { + stream.pause() + } +} + +/** + * Make a serializable error object. + * + * To create serializable errors you must re-set message so + * that it is enumerable and you must re configure the type + * property so that is writable and enumerable. + * + * @param {number} status + * @param {string} message + * @param {string} type + * @param {object} props + * @private + */ + +function createError (status, message, type, props) { + var error = new Error() + + // capture stack trace + Error.captureStackTrace(error, createError) + + // set free-form properties + for (var prop in props) { + error[prop] = props[prop] + } + + // set message + error.message = message + + // set status + error.status = status + error.statusCode = status + + // set type + Object.defineProperty(error, 'type', { + value: type, + enumerable: true, + writable: true, + configurable: true + }) + + return error +} + +/** + * Read the data from the stream. + * + * @param {object} stream + * @param {string} encoding + * @param {number} length + * @param {number} limit + * @param {function} callback + * @public + */ + +function readStream (stream, encoding, length, limit, callback) { + var complete = false + var sync = true + + // check the length and limit options. + // note: we intentionally leave the stream paused, + // so users should handle the stream themselves. + if (limit !== null && length !== null && length > limit) { + return done(createError(413, 'request entity too large', 'entity.too.large', { + expected: length, + length: length, + limit: limit + })) + } + + // streams1: assert request encoding is buffer. + // streams2+: assert the stream encoding is buffer. + // stream._decoder: streams1 + // state.encoding: streams2 + // state.decoder: streams2, specifically < 0.10.6 + var state = stream._readableState + if (stream._decoder || (state && (state.encoding || state.decoder))) { + // developer error + return done(createError(500, 'stream encoding should not be set', 'stream.encoding.set')) + } + + var received = 0 + var decoder + + try { + decoder = getDecoder(encoding) + } catch (err) { + return done(err) + } + + var buffer = decoder + ? '' + : [] + + // attach listeners + stream.on('aborted', onAborted) + stream.on('close', cleanup) + stream.on('data', onData) + stream.on('end', onEnd) + stream.on('error', onEnd) + + // mark sync section complete + sync = false + + function done () { + var args = new Array(arguments.length) + + // copy arguments + for (var i = 0; i < args.length; i++) { + args[i] = arguments[i] + } + + // mark complete + complete = true + + if (sync) { + process.nextTick(invokeCallback) + } else { + invokeCallback() + } + + function invokeCallback () { + cleanup() + + if (args[0]) { + // halt the stream on error + halt(stream) + } + + callback.apply(null, args) + } + } + + function onAborted () { + if (complete) return + + done(createError(400, 'request aborted', 'request.aborted', { + code: 'ECONNABORTED', + expected: length, + length: length, + received: received + })) + } + + function onData (chunk) { + if (complete) return + + received += chunk.length + decoder + ? buffer += decoder.write(chunk) + : buffer.push(chunk) + + if (limit !== null && received > limit) { + done(createError(413, 'request entity too large', 'entity.too.large', { + limit: limit, + received: received + })) + } + } + + function onEnd (err) { + if (complete) return + if (err) return done(err) + + if (length !== null && received !== length) { + done(createError(400, 'request size did not match content length', 'request.size.invalid', { + expected: length, + length: length, + received: received + })) + } else { + var string = decoder + ? buffer + (decoder.end() || '') + : Buffer.concat(buffer) + done(null, string) + } + } + + function cleanup () { + buffer = null + + stream.removeListener('aborted', onAborted) + stream.removeListener('data', onData) + stream.removeListener('end', onEnd) + stream.removeListener('error', onEnd) + stream.removeListener('close', cleanup) + } +} diff --git a/node_modules/body-parser/node_modules/raw-body/node_modules/unpipe/HISTORY.md b/node_modules/body-parser/node_modules/raw-body/node_modules/unpipe/HISTORY.md new file mode 100644 index 0000000..85e0f8d --- /dev/null +++ b/node_modules/body-parser/node_modules/raw-body/node_modules/unpipe/HISTORY.md @@ -0,0 +1,4 @@ +1.0.0 / 2015-06-14 +================== + + * Initial release diff --git a/node_modules/body-parser/node_modules/raw-body/node_modules/unpipe/LICENSE b/node_modules/body-parser/node_modules/raw-body/node_modules/unpipe/LICENSE new file mode 100644 index 0000000..aed0138 --- /dev/null +++ b/node_modules/body-parser/node_modules/raw-body/node_modules/unpipe/LICENSE @@ -0,0 +1,22 @@ +(The MIT License) + +Copyright (c) 2015 Douglas Christopher Wilson + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/body-parser/node_modules/raw-body/node_modules/unpipe/README.md b/node_modules/body-parser/node_modules/raw-body/node_modules/unpipe/README.md new file mode 100644 index 0000000..e536ad2 --- /dev/null +++ b/node_modules/body-parser/node_modules/raw-body/node_modules/unpipe/README.md @@ -0,0 +1,43 @@ +# unpipe + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Node.js Version][node-image]][node-url] +[![Build Status][travis-image]][travis-url] +[![Test Coverage][coveralls-image]][coveralls-url] + +Unpipe a stream from all destinations. + +## Installation + +```sh +$ npm install unpipe +``` + +## API + +```js +var unpipe = require('unpipe') +``` + +### unpipe(stream) + +Unpipes all destinations from a given stream. With stream 2+, this is +equivalent to `stream.unpipe()`. When used with streams 1 style streams +(typically Node.js 0.8 and below), this module attempts to undo the +actions done in `stream.pipe(dest)`. + +## License + +[MIT](LICENSE) + +[npm-image]: https://img.shields.io/npm/v/unpipe.svg +[npm-url]: https://npmjs.org/package/unpipe +[node-image]: https://img.shields.io/node/v/unpipe.svg +[node-url]: http://nodejs.org/download/ +[travis-image]: https://img.shields.io/travis/stream-utils/unpipe.svg +[travis-url]: https://travis-ci.org/stream-utils/unpipe +[coveralls-image]: https://img.shields.io/coveralls/stream-utils/unpipe.svg +[coveralls-url]: https://coveralls.io/r/stream-utils/unpipe?branch=master +[downloads-image]: https://img.shields.io/npm/dm/unpipe.svg +[downloads-url]: https://npmjs.org/package/unpipe diff --git a/node_modules/body-parser/node_modules/raw-body/node_modules/unpipe/index.js b/node_modules/body-parser/node_modules/raw-body/node_modules/unpipe/index.js new file mode 100644 index 0000000..15c3d97 --- /dev/null +++ b/node_modules/body-parser/node_modules/raw-body/node_modules/unpipe/index.js @@ -0,0 +1,69 @@ +/*! + * unpipe + * Copyright(c) 2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module exports. + * @public + */ + +module.exports = unpipe + +/** + * Determine if there are Node.js pipe-like data listeners. + * @private + */ + +function hasPipeDataListeners(stream) { + var listeners = stream.listeners('data') + + for (var i = 0; i < listeners.length; i++) { + if (listeners[i].name === 'ondata') { + return true + } + } + + return false +} + +/** + * Unpipe a stream from all destinations. + * + * @param {object} stream + * @public + */ + +function unpipe(stream) { + if (!stream) { + throw new TypeError('argument stream is required') + } + + if (typeof stream.unpipe === 'function') { + // new-style + stream.unpipe() + return + } + + // Node.js 0.8 hack + if (!hasPipeDataListeners(stream)) { + return + } + + var listener + var listeners = stream.listeners('close') + + for (var i = 0; i < listeners.length; i++) { + listener = listeners[i] + + if (listener.name !== 'cleanup' && listener.name !== 'onclose') { + continue + } + + // invoke the listener + listener.call(stream) + } +} diff --git a/node_modules/body-parser/node_modules/raw-body/node_modules/unpipe/package.json b/node_modules/body-parser/node_modules/raw-body/node_modules/unpipe/package.json new file mode 100644 index 0000000..d4235b5 --- /dev/null +++ b/node_modules/body-parser/node_modules/raw-body/node_modules/unpipe/package.json @@ -0,0 +1,59 @@ +{ + "name": "unpipe", + "description": "Unpipe a stream from all destinations", + "version": "1.0.0", + "author": { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + }, + "license": "MIT", + "repository": { + "type": "git", + "url": "git+https://github.com/stream-utils/unpipe.git" + }, + "devDependencies": { + "istanbul": "0.3.15", + "mocha": "2.2.5", + "readable-stream": "1.1.13" + }, + "files": [ + "HISTORY.md", + "LICENSE", + "README.md", + "index.js" + ], + "engines": { + "node": ">= 0.8" + }, + "scripts": { + "test": "mocha --reporter spec --bail --check-leaks test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot --check-leaks test/", + "test-travis": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter spec --check-leaks test/" + }, + "gitHead": "d2df901c06487430e78dca62b6edb8bb2fc5e99d", + "bugs": { + "url": "https://github.com/stream-utils/unpipe/issues" + }, + "homepage": "https://github.com/stream-utils/unpipe", + "_id": "unpipe@1.0.0", + "_shasum": "b2bf4ee8514aae6165b4817829d21b2ef49904ec", + "_from": "unpipe@1.0.0", + "_npmVersion": "1.4.28", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "maintainers": [ + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + } + ], + "dist": { + "shasum": "b2bf4ee8514aae6165b4817829d21b2ef49904ec", + "tarball": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/body-parser/node_modules/raw-body/package.json b/node_modules/body-parser/node_modules/raw-body/package.json new file mode 100644 index 0000000..9644668 --- /dev/null +++ b/node_modules/body-parser/node_modules/raw-body/package.json @@ -0,0 +1,90 @@ +{ + "name": "raw-body", + "description": "Get and validate the raw body of a readable stream.", + "version": "2.1.7", + "author": { + "name": "Jonathan Ong", + "email": "me@jongleberry.com", + "url": "http://jongleberry.com" + }, + "contributors": [ + { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "Raynos", + "email": "raynos2@gmail.com" + } + ], + "license": "MIT", + "repository": { + "type": "git", + "url": "git+https://github.com/stream-utils/raw-body.git" + }, + "dependencies": { + "bytes": "2.4.0", + "iconv-lite": "0.4.13", + "unpipe": "1.0.0" + }, + "devDependencies": { + "bluebird": "3.4.1", + "eslint": "2.13.0", + "eslint-config-standard": "5.3.1", + "eslint-plugin-promise": "1.3.2", + "eslint-plugin-standard": "1.3.2", + "istanbul": "0.4.3", + "mocha": "2.5.3", + "readable-stream": "2.1.2", + "through2": "2.0.1" + }, + "engines": { + "node": ">= 0.8" + }, + "files": [ + "HISTORY.md", + "LICENSE", + "README.md", + "index.js" + ], + "scripts": { + "lint": "eslint **/*.js", + "test": "mocha --trace-deprecation --reporter spec --bail --check-leaks test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --trace-deprecation --reporter dot --check-leaks test/", + "test-travis": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --trace-deprecation --reporter spec --check-leaks test/" + }, + "gitHead": "9d13a27048cc97958fc14fc12418c6aa76f0b1f9", + "bugs": { + "url": "https://github.com/stream-utils/raw-body/issues" + }, + "homepage": "https://github.com/stream-utils/raw-body#readme", + "_id": "raw-body@2.1.7", + "_shasum": "adfeace2e4fb3098058014d08c072dcc59758774", + "_from": "raw-body@>=2.1.7 <2.2.0", + "_npmVersion": "2.15.1", + "_nodeVersion": "4.4.3", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "dist": { + "shasum": "adfeace2e4fb3098058014d08c072dcc59758774", + "tarball": "https://registry.npmjs.org/raw-body/-/raw-body-2.1.7.tgz" + }, + "maintainers": [ + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "jongleberry", + "email": "jonathanrichardong@gmail.com" + } + ], + "_npmOperationalInternal": { + "host": "packages-12-west.internal.npmjs.com", + "tmp": "tmp/raw-body-2.1.7.tgz_1466363663010_0.38383363327011466" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/raw-body/-/raw-body-2.1.7.tgz" +} diff --git a/node_modules/body-parser/node_modules/type-is/HISTORY.md b/node_modules/body-parser/node_modules/type-is/HISTORY.md new file mode 100644 index 0000000..5ec118c --- /dev/null +++ b/node_modules/body-parser/node_modules/type-is/HISTORY.md @@ -0,0 +1,206 @@ +1.6.13 / 2016-05-18 +=================== + + * deps: mime-types@~2.1.11 + - Add new mime types + +1.6.12 / 2016-02-28 +=================== + + * deps: mime-types@~2.1.10 + - Add new mime types + - Fix extension of `application/dash+xml` + - Update primary extension for `audio/mp4` + +1.6.11 / 2016-01-29 +=================== + + * deps: mime-types@~2.1.9 + - Add new mime types + +1.6.10 / 2015-12-01 +=================== + + * deps: mime-types@~2.1.8 + - Add new mime types + +1.6.9 / 2015-09-27 +================== + + * deps: mime-types@~2.1.7 + - Add new mime types + +1.6.8 / 2015-09-04 +================== + + * deps: mime-types@~2.1.6 + - Add new mime types + +1.6.7 / 2015-08-20 +================== + + * Fix type error when given invalid type to match against + * deps: mime-types@~2.1.5 + - Add new mime types + +1.6.6 / 2015-07-31 +================== + + * deps: mime-types@~2.1.4 + - Add new mime types + +1.6.5 / 2015-07-16 +================== + + * deps: mime-types@~2.1.3 + - Add new mime types + +1.6.4 / 2015-07-01 +================== + + * deps: mime-types@~2.1.2 + - Add new mime types + * perf: enable strict mode + * perf: remove argument reassignment + +1.6.3 / 2015-06-08 +================== + + * deps: mime-types@~2.1.1 + - Add new mime types + * perf: reduce try block size + * perf: remove bitwise operations + +1.6.2 / 2015-05-10 +================== + + * deps: mime-types@~2.0.11 + - Add new mime types + +1.6.1 / 2015-03-13 +================== + + * deps: mime-types@~2.0.10 + - Add new mime types + +1.6.0 / 2015-02-12 +================== + + * fix false-positives in `hasBody` `Transfer-Encoding` check + * support wildcard for both type and subtype (`*/*`) + +1.5.7 / 2015-02-09 +================== + + * fix argument reassignment + * deps: mime-types@~2.0.9 + - Add new mime types + +1.5.6 / 2015-01-29 +================== + + * deps: mime-types@~2.0.8 + - Add new mime types + +1.5.5 / 2014-12-30 +================== + + * deps: mime-types@~2.0.7 + - Add new mime types + - Fix missing extensions + - Fix various invalid MIME type entries + - Remove example template MIME types + - deps: mime-db@~1.5.0 + +1.5.4 / 2014-12-10 +================== + + * deps: mime-types@~2.0.4 + - Add new mime types + - deps: mime-db@~1.3.0 + +1.5.3 / 2014-11-09 +================== + + * deps: mime-types@~2.0.3 + - Add new mime types + - deps: mime-db@~1.2.0 + +1.5.2 / 2014-09-28 +================== + + * deps: mime-types@~2.0.2 + - Add new mime types + - deps: mime-db@~1.1.0 + +1.5.1 / 2014-09-07 +================== + + * Support Node.js 0.6 + * deps: media-typer@0.3.0 + * deps: mime-types@~2.0.1 + - Support Node.js 0.6 + +1.5.0 / 2014-09-05 +================== + + * fix `hasbody` to be true for `content-length: 0` + +1.4.0 / 2014-09-02 +================== + + * update mime-types + +1.3.2 / 2014-06-24 +================== + + * use `~` range on mime-types + +1.3.1 / 2014-06-19 +================== + + * fix global variable leak + +1.3.0 / 2014-06-19 +================== + + * improve type parsing + + - invalid media type never matches + - media type not case-sensitive + - extra LWS does not affect results + +1.2.2 / 2014-06-19 +================== + + * fix behavior on unknown type argument + +1.2.1 / 2014-06-03 +================== + + * switch dependency from `mime` to `mime-types@1.0.0` + +1.2.0 / 2014-05-11 +================== + + * support suffix matching: + + - `+json` matches `application/vnd+json` + - `*/vnd+json` matches `application/vnd+json` + - `application/*+json` matches `application/vnd+json` + +1.1.0 / 2014-04-12 +================== + + * add non-array values support + * expose internal utilities: + + - `.is()` + - `.hasBody()` + - `.normalize()` + - `.match()` + +1.0.1 / 2014-03-30 +================== + + * add `multipart` as a shorthand diff --git a/node_modules/body-parser/node_modules/type-is/LICENSE b/node_modules/body-parser/node_modules/type-is/LICENSE new file mode 100644 index 0000000..386b7b6 --- /dev/null +++ b/node_modules/body-parser/node_modules/type-is/LICENSE @@ -0,0 +1,23 @@ +(The MIT License) + +Copyright (c) 2014 Jonathan Ong +Copyright (c) 2014-2015 Douglas Christopher Wilson + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/body-parser/node_modules/type-is/README.md b/node_modules/body-parser/node_modules/type-is/README.md new file mode 100644 index 0000000..008a7af --- /dev/null +++ b/node_modules/body-parser/node_modules/type-is/README.md @@ -0,0 +1,136 @@ +# type-is + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Node.js Version][node-version-image]][node-version-url] +[![Build Status][travis-image]][travis-url] +[![Test Coverage][coveralls-image]][coveralls-url] + +Infer the content-type of a request. + +### Install + +```sh +$ npm install type-is +``` + +## API + +```js +var http = require('http') +var is = require('type-is') + +http.createServer(function (req, res) { + var istext = is(req, ['text/*']) + res.end('you ' + (istext ? 'sent' : 'did not send') + ' me text') +}) +``` + +### type = is(request, types) + +`request` is the node HTTP request. `types` is an array of types. + +```js +// req.headers.content-type = 'application/json' + +is(req, ['json']) // 'json' +is(req, ['html', 'json']) // 'json' +is(req, ['application/*']) // 'application/json' +is(req, ['application/json']) // 'application/json' + +is(req, ['html']) // false +``` + +### is.hasBody(request) + +Returns a Boolean if the given `request` has a body, regardless of the +`Content-Type` header. + +Having a body has no relation to how large the body is (it may be 0 bytes). +This is similar to how file existence works. If a body does exist, then this +indicates that there is data to read from the Node.js request stream. + +```js +if (is.hasBody(req)) { + // read the body, since there is one + + req.on('data', function (chunk) { + // ... + }) +} +``` + +### type = is.is(mediaType, types) + +`mediaType` is the [media type](https://tools.ietf.org/html/rfc6838) string. `types` is an array of types. + +```js +var mediaType = 'application/json' + +is.is(mediaType, ['json']) // 'json' +is.is(mediaType, ['html', 'json']) // 'json' +is.is(mediaType, ['application/*']) // 'application/json' +is.is(mediaType, ['application/json']) // 'application/json' + +is.is(mediaType, ['html']) // false +``` + +### Each type can be: + +- An extension name such as `json`. This name will be returned if matched. +- A mime type such as `application/json`. +- A mime type with a wildcard such as `*/*` or `*/json` or `application/*`. The full mime type will be returned if matched. +- A suffix such as `+json`. This can be combined with a wildcard such as `*/vnd+json` or `application/*+json`. The full mime type will be returned if matched. + +`false` will be returned if no type matches or the content type is invalid. + +`null` will be returned if the request does not have a body. + +## Examples + +#### Example body parser + +```js +var is = require('type-is'); + +function bodyParser(req, res, next) { + if (!is.hasBody(req)) { + return next() + } + + switch (is(req, ['urlencoded', 'json', 'multipart'])) { + case 'urlencoded': + // parse urlencoded body + throw new Error('implement urlencoded body parsing') + break + case 'json': + // parse json body + throw new Error('implement json body parsing') + break + case 'multipart': + // parse multipart body + throw new Error('implement multipart body parsing') + break + default: + // 415 error code + res.statusCode = 415 + res.end() + return + } +} +``` + +## License + +[MIT](LICENSE) + +[npm-image]: https://img.shields.io/npm/v/type-is.svg +[npm-url]: https://npmjs.org/package/type-is +[node-version-image]: https://img.shields.io/node/v/type-is.svg +[node-version-url]: https://nodejs.org/en/download/ +[travis-image]: https://img.shields.io/travis/jshttp/type-is/master.svg +[travis-url]: https://travis-ci.org/jshttp/type-is +[coveralls-image]: https://img.shields.io/coveralls/jshttp/type-is/master.svg +[coveralls-url]: https://coveralls.io/r/jshttp/type-is?branch=master +[downloads-image]: https://img.shields.io/npm/dm/type-is.svg +[downloads-url]: https://npmjs.org/package/type-is diff --git a/node_modules/body-parser/node_modules/type-is/index.js b/node_modules/body-parser/node_modules/type-is/index.js new file mode 100644 index 0000000..4da7301 --- /dev/null +++ b/node_modules/body-parser/node_modules/type-is/index.js @@ -0,0 +1,262 @@ +/*! + * type-is + * Copyright(c) 2014 Jonathan Ong + * Copyright(c) 2014-2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module dependencies. + * @private + */ + +var typer = require('media-typer') +var mime = require('mime-types') + +/** + * Module exports. + * @public + */ + +module.exports = typeofrequest +module.exports.is = typeis +module.exports.hasBody = hasbody +module.exports.normalize = normalize +module.exports.match = mimeMatch + +/** + * Compare a `value` content-type with `types`. + * Each `type` can be an extension like `html`, + * a special shortcut like `multipart` or `urlencoded`, + * or a mime type. + * + * If no types match, `false` is returned. + * Otherwise, the first `type` that matches is returned. + * + * @param {String} value + * @param {Array} types + * @public + */ + +function typeis (value, types_) { + var i + var types = types_ + + // remove parameters and normalize + var val = tryNormalizeType(value) + + // no type or invalid + if (!val) { + return false + } + + // support flattened arguments + if (types && !Array.isArray(types)) { + types = new Array(arguments.length - 1) + for (i = 0; i < types.length; i++) { + types[i] = arguments[i + 1] + } + } + + // no types, return the content type + if (!types || !types.length) { + return val + } + + var type + for (i = 0; i < types.length; i++) { + if (mimeMatch(normalize(type = types[i]), val)) { + return type[0] === '+' || type.indexOf('*') !== -1 + ? val + : type + } + } + + // no matches + return false +} + +/** + * Check if a request has a request body. + * A request with a body __must__ either have `transfer-encoding` + * or `content-length` headers set. + * http://www.w3.org/Protocols/rfc2616/rfc2616-sec4.html#sec4.3 + * + * @param {Object} request + * @return {Boolean} + * @public + */ + +function hasbody (req) { + return req.headers['transfer-encoding'] !== undefined || + !isNaN(req.headers['content-length']) +} + +/** + * Check if the incoming request contains the "Content-Type" + * header field, and it contains any of the give mime `type`s. + * If there is no request body, `null` is returned. + * If there is no content type, `false` is returned. + * Otherwise, it returns the first `type` that matches. + * + * Examples: + * + * // With Content-Type: text/html; charset=utf-8 + * this.is('html'); // => 'html' + * this.is('text/html'); // => 'text/html' + * this.is('text/*', 'application/json'); // => 'text/html' + * + * // When Content-Type is application/json + * this.is('json', 'urlencoded'); // => 'json' + * this.is('application/json'); // => 'application/json' + * this.is('html', 'application/*'); // => 'application/json' + * + * this.is('html'); // => false + * + * @param {String|Array} types... + * @return {String|false|null} + * @public + */ + +function typeofrequest (req, types_) { + var types = types_ + + // no body + if (!hasbody(req)) { + return null + } + + // support flattened arguments + if (arguments.length > 2) { + types = new Array(arguments.length - 1) + for (var i = 0; i < types.length; i++) { + types[i] = arguments[i + 1] + } + } + + // request content type + var value = req.headers['content-type'] + + return typeis(value, types) +} + +/** + * Normalize a mime type. + * If it's a shorthand, expand it to a valid mime type. + * + * In general, you probably want: + * + * var type = is(req, ['urlencoded', 'json', 'multipart']); + * + * Then use the appropriate body parsers. + * These three are the most common request body types + * and are thus ensured to work. + * + * @param {String} type + * @private + */ + +function normalize (type) { + if (typeof type !== 'string') { + // invalid type + return false + } + + switch (type) { + case 'urlencoded': + return 'application/x-www-form-urlencoded' + case 'multipart': + return 'multipart/*' + } + + if (type[0] === '+') { + // "+json" -> "*/*+json" expando + return '*/*' + type + } + + return type.indexOf('/') === -1 + ? mime.lookup(type) + : type +} + +/** + * Check if `expected` mime type + * matches `actual` mime type with + * wildcard and +suffix support. + * + * @param {String} expected + * @param {String} actual + * @return {Boolean} + * @private + */ + +function mimeMatch (expected, actual) { + // invalid type + if (expected === false) { + return false + } + + // split types + var actualParts = actual.split('/') + var expectedParts = expected.split('/') + + // invalid format + if (actualParts.length !== 2 || expectedParts.length !== 2) { + return false + } + + // validate type + if (expectedParts[0] !== '*' && expectedParts[0] !== actualParts[0]) { + return false + } + + // validate suffix wildcard + if (expectedParts[1].substr(0, 2) === '*+') { + return expectedParts[1].length <= actualParts[1].length + 1 && + expectedParts[1].substr(1) === actualParts[1].substr(1 - expectedParts[1].length) + } + + // validate subtype + if (expectedParts[1] !== '*' && expectedParts[1] !== actualParts[1]) { + return false + } + + return true +} + +/** + * Normalize a type and remove parameters. + * + * @param {string} value + * @return {string} + * @private + */ + +function normalizeType (value) { + // parse the type + var type = typer.parse(value) + + // remove the parameters + type.parameters = undefined + + // reformat it + return typer.format(type) +} + +/** + * Try to normalize a type and remove parameters. + * + * @param {string} value + * @return {string} + * @private + */ + +function tryNormalizeType (value) { + try { + return normalizeType(value) + } catch (err) { + return null + } +} diff --git a/node_modules/body-parser/node_modules/type-is/node_modules/media-typer/HISTORY.md b/node_modules/body-parser/node_modules/type-is/node_modules/media-typer/HISTORY.md new file mode 100644 index 0000000..62c2003 --- /dev/null +++ b/node_modules/body-parser/node_modules/type-is/node_modules/media-typer/HISTORY.md @@ -0,0 +1,22 @@ +0.3.0 / 2014-09-07 +================== + + * Support Node.js 0.6 + * Throw error when parameter format invalid on parse + +0.2.0 / 2014-06-18 +================== + + * Add `typer.format()` to format media types + +0.1.0 / 2014-06-17 +================== + + * Accept `req` as argument to `parse` + * Accept `res` as argument to `parse` + * Parse media type with extra LWS between type and first parameter + +0.0.0 / 2014-06-13 +================== + + * Initial implementation diff --git a/node_modules/body-parser/node_modules/type-is/node_modules/media-typer/LICENSE b/node_modules/body-parser/node_modules/type-is/node_modules/media-typer/LICENSE new file mode 100644 index 0000000..b7dce6c --- /dev/null +++ b/node_modules/body-parser/node_modules/type-is/node_modules/media-typer/LICENSE @@ -0,0 +1,22 @@ +(The MIT License) + +Copyright (c) 2014 Douglas Christopher Wilson + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/body-parser/node_modules/type-is/node_modules/media-typer/README.md b/node_modules/body-parser/node_modules/type-is/node_modules/media-typer/README.md new file mode 100644 index 0000000..d8df623 --- /dev/null +++ b/node_modules/body-parser/node_modules/type-is/node_modules/media-typer/README.md @@ -0,0 +1,81 @@ +# media-typer + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Node.js Version][node-version-image]][node-version-url] +[![Build Status][travis-image]][travis-url] +[![Test Coverage][coveralls-image]][coveralls-url] + +Simple RFC 6838 media type parser + +## Installation + +```sh +$ npm install media-typer +``` + +## API + +```js +var typer = require('media-typer') +``` + +### typer.parse(string) + +```js +var obj = typer.parse('image/svg+xml; charset=utf-8') +``` + +Parse a media type string. This will return an object with the following +properties (examples are shown for the string `'image/svg+xml; charset=utf-8'`): + + - `type`: The type of the media type (always lower case). Example: `'image'` + + - `subtype`: The subtype of the media type (always lower case). Example: `'svg'` + + - `suffix`: The suffix of the media type (always lower case). Example: `'xml'` + + - `parameters`: An object of the parameters in the media type (name of parameter always lower case). Example: `{charset: 'utf-8'}` + +### typer.parse(req) + +```js +var obj = typer.parse(req) +``` + +Parse the `content-type` header from the given `req`. Short-cut for +`typer.parse(req.headers['content-type'])`. + +### typer.parse(res) + +```js +var obj = typer.parse(res) +``` + +Parse the `content-type` header set on the given `res`. Short-cut for +`typer.parse(res.getHeader('content-type'))`. + +### typer.format(obj) + +```js +var obj = typer.format({type: 'image', subtype: 'svg', suffix: 'xml'}) +``` + +Format an object into a media type string. This will return a string of the +mime type for the given object. For the properties of the object, see the +documentation for `typer.parse(string)`. + +## License + +[MIT](LICENSE) + +[npm-image]: https://img.shields.io/npm/v/media-typer.svg?style=flat +[npm-url]: https://npmjs.org/package/media-typer +[node-version-image]: https://img.shields.io/badge/node.js-%3E%3D_0.6-brightgreen.svg?style=flat +[node-version-url]: http://nodejs.org/download/ +[travis-image]: https://img.shields.io/travis/jshttp/media-typer.svg?style=flat +[travis-url]: https://travis-ci.org/jshttp/media-typer +[coveralls-image]: https://img.shields.io/coveralls/jshttp/media-typer.svg?style=flat +[coveralls-url]: https://coveralls.io/r/jshttp/media-typer +[downloads-image]: https://img.shields.io/npm/dm/media-typer.svg?style=flat +[downloads-url]: https://npmjs.org/package/media-typer diff --git a/node_modules/body-parser/node_modules/type-is/node_modules/media-typer/index.js b/node_modules/body-parser/node_modules/type-is/node_modules/media-typer/index.js new file mode 100644 index 0000000..07f7295 --- /dev/null +++ b/node_modules/body-parser/node_modules/type-is/node_modules/media-typer/index.js @@ -0,0 +1,270 @@ +/*! + * media-typer + * Copyright(c) 2014 Douglas Christopher Wilson + * MIT Licensed + */ + +/** + * RegExp to match *( ";" parameter ) in RFC 2616 sec 3.7 + * + * parameter = token "=" ( token | quoted-string ) + * token = 1* + * separators = "(" | ")" | "<" | ">" | "@" + * | "," | ";" | ":" | "\" | <"> + * | "/" | "[" | "]" | "?" | "=" + * | "{" | "}" | SP | HT + * quoted-string = ( <"> *(qdtext | quoted-pair ) <"> ) + * qdtext = > + * quoted-pair = "\" CHAR + * CHAR = + * TEXT = + * LWS = [CRLF] 1*( SP | HT ) + * CRLF = CR LF + * CR = + * LF = + * SP = + * SHT = + * CTL = + * OCTET = + */ +var paramRegExp = /; *([!#$%&'\*\+\-\.0-9A-Z\^_`a-z\|~]+) *= *("(?:[ !\u0023-\u005b\u005d-\u007e\u0080-\u00ff]|\\[\u0020-\u007e])*"|[!#$%&'\*\+\-\.0-9A-Z\^_`a-z\|~]+) */g; +var textRegExp = /^[\u0020-\u007e\u0080-\u00ff]+$/ +var tokenRegExp = /^[!#$%&'\*\+\-\.0-9A-Z\^_`a-z\|~]+$/ + +/** + * RegExp to match quoted-pair in RFC 2616 + * + * quoted-pair = "\" CHAR + * CHAR = + */ +var qescRegExp = /\\([\u0000-\u007f])/g; + +/** + * RegExp to match chars that must be quoted-pair in RFC 2616 + */ +var quoteRegExp = /([\\"])/g; + +/** + * RegExp to match type in RFC 6838 + * + * type-name = restricted-name + * subtype-name = restricted-name + * restricted-name = restricted-name-first *126restricted-name-chars + * restricted-name-first = ALPHA / DIGIT + * restricted-name-chars = ALPHA / DIGIT / "!" / "#" / + * "$" / "&" / "-" / "^" / "_" + * restricted-name-chars =/ "." ; Characters before first dot always + * ; specify a facet name + * restricted-name-chars =/ "+" ; Characters after last plus always + * ; specify a structured syntax suffix + * ALPHA = %x41-5A / %x61-7A ; A-Z / a-z + * DIGIT = %x30-39 ; 0-9 + */ +var subtypeNameRegExp = /^[A-Za-z0-9][A-Za-z0-9!#$&^_.-]{0,126}$/ +var typeNameRegExp = /^[A-Za-z0-9][A-Za-z0-9!#$&^_-]{0,126}$/ +var typeRegExp = /^ *([A-Za-z0-9][A-Za-z0-9!#$&^_-]{0,126})\/([A-Za-z0-9][A-Za-z0-9!#$&^_.+-]{0,126}) *$/; + +/** + * Module exports. + */ + +exports.format = format +exports.parse = parse + +/** + * Format object to media type. + * + * @param {object} obj + * @return {string} + * @api public + */ + +function format(obj) { + if (!obj || typeof obj !== 'object') { + throw new TypeError('argument obj is required') + } + + var parameters = obj.parameters + var subtype = obj.subtype + var suffix = obj.suffix + var type = obj.type + + if (!type || !typeNameRegExp.test(type)) { + throw new TypeError('invalid type') + } + + if (!subtype || !subtypeNameRegExp.test(subtype)) { + throw new TypeError('invalid subtype') + } + + // format as type/subtype + var string = type + '/' + subtype + + // append +suffix + if (suffix) { + if (!typeNameRegExp.test(suffix)) { + throw new TypeError('invalid suffix') + } + + string += '+' + suffix + } + + // append parameters + if (parameters && typeof parameters === 'object') { + var param + var params = Object.keys(parameters).sort() + + for (var i = 0; i < params.length; i++) { + param = params[i] + + if (!tokenRegExp.test(param)) { + throw new TypeError('invalid parameter name') + } + + string += '; ' + param + '=' + qstring(parameters[param]) + } + } + + return string +} + +/** + * Parse media type to object. + * + * @param {string|object} string + * @return {Object} + * @api public + */ + +function parse(string) { + if (!string) { + throw new TypeError('argument string is required') + } + + // support req/res-like objects as argument + if (typeof string === 'object') { + string = getcontenttype(string) + } + + if (typeof string !== 'string') { + throw new TypeError('argument string is required to be a string') + } + + var index = string.indexOf(';') + var type = index !== -1 + ? string.substr(0, index) + : string + + var key + var match + var obj = splitType(type) + var params = {} + var value + + paramRegExp.lastIndex = index + + while (match = paramRegExp.exec(string)) { + if (match.index !== index) { + throw new TypeError('invalid parameter format') + } + + index += match[0].length + key = match[1].toLowerCase() + value = match[2] + + if (value[0] === '"') { + // remove quotes and escapes + value = value + .substr(1, value.length - 2) + .replace(qescRegExp, '$1') + } + + params[key] = value + } + + if (index !== -1 && index !== string.length) { + throw new TypeError('invalid parameter format') + } + + obj.parameters = params + + return obj +} + +/** + * Get content-type from req/res objects. + * + * @param {object} + * @return {Object} + * @api private + */ + +function getcontenttype(obj) { + if (typeof obj.getHeader === 'function') { + // res-like + return obj.getHeader('content-type') + } + + if (typeof obj.headers === 'object') { + // req-like + return obj.headers && obj.headers['content-type'] + } +} + +/** + * Quote a string if necessary. + * + * @param {string} val + * @return {string} + * @api private + */ + +function qstring(val) { + var str = String(val) + + // no need to quote tokens + if (tokenRegExp.test(str)) { + return str + } + + if (str.length > 0 && !textRegExp.test(str)) { + throw new TypeError('invalid parameter value') + } + + return '"' + str.replace(quoteRegExp, '\\$1') + '"' +} + +/** + * Simply "type/subtype+siffx" into parts. + * + * @param {string} string + * @return {Object} + * @api private + */ + +function splitType(string) { + var match = typeRegExp.exec(string.toLowerCase()) + + if (!match) { + throw new TypeError('invalid media type') + } + + var type = match[1] + var subtype = match[2] + var suffix + + // suffix after last + + var index = subtype.lastIndexOf('+') + if (index !== -1) { + suffix = subtype.substr(index + 1) + subtype = subtype.substr(0, index) + } + + var obj = { + type: type, + subtype: subtype, + suffix: suffix + } + + return obj +} diff --git a/node_modules/body-parser/node_modules/type-is/node_modules/media-typer/package.json b/node_modules/body-parser/node_modules/type-is/node_modules/media-typer/package.json new file mode 100644 index 0000000..bd88bf2 --- /dev/null +++ b/node_modules/body-parser/node_modules/type-is/node_modules/media-typer/package.json @@ -0,0 +1,58 @@ +{ + "name": "media-typer", + "description": "Simple RFC 6838 media type parser and formatter", + "version": "0.3.0", + "author": { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + }, + "license": "MIT", + "repository": { + "type": "git", + "url": "git+https://github.com/jshttp/media-typer.git" + }, + "devDependencies": { + "istanbul": "0.3.2", + "mocha": "~1.21.4", + "should": "~4.0.4" + }, + "files": [ + "LICENSE", + "HISTORY.md", + "index.js" + ], + "engines": { + "node": ">= 0.6" + }, + "scripts": { + "test": "mocha --reporter spec --check-leaks --bail test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot --check-leaks test/", + "test-travis": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter spec --check-leaks test/" + }, + "gitHead": "d49d41ffd0bb5a0655fa44a59df2ec0bfc835b16", + "bugs": { + "url": "https://github.com/jshttp/media-typer/issues" + }, + "homepage": "https://github.com/jshttp/media-typer", + "_id": "media-typer@0.3.0", + "_shasum": "8710d7af0aa626f8fffa1ce00168545263255748", + "_from": "media-typer@0.3.0", + "_npmVersion": "1.4.21", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "maintainers": [ + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + } + ], + "dist": { + "shasum": "8710d7af0aa626f8fffa1ce00168545263255748", + "tarball": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/body-parser/node_modules/type-is/node_modules/mime-types/HISTORY.md b/node_modules/body-parser/node_modules/type-is/node_modules/mime-types/HISTORY.md new file mode 100644 index 0000000..8c0383a --- /dev/null +++ b/node_modules/body-parser/node_modules/type-is/node_modules/mime-types/HISTORY.md @@ -0,0 +1,204 @@ +2.1.12 / 2016-09-18 +=================== + + * deps: mime-db@~1.24.0 + - Add new mime types + - Add `audio/mp3` + +2.1.11 / 2016-05-01 +=================== + + * deps: mime-db@~1.23.0 + - Add new mime types + +2.1.10 / 2016-02-15 +=================== + + * deps: mime-db@~1.22.0 + - Add new mime types + - Fix extension of `application/dash+xml` + - Update primary extension for `audio/mp4` + +2.1.9 / 2016-01-06 +================== + + * deps: mime-db@~1.21.0 + - Add new mime types + +2.1.8 / 2015-11-30 +================== + + * deps: mime-db@~1.20.0 + - Add new mime types + +2.1.7 / 2015-09-20 +================== + + * deps: mime-db@~1.19.0 + - Add new mime types + +2.1.6 / 2015-09-03 +================== + + * deps: mime-db@~1.18.0 + - Add new mime types + +2.1.5 / 2015-08-20 +================== + + * deps: mime-db@~1.17.0 + - Add new mime types + +2.1.4 / 2015-07-30 +================== + + * deps: mime-db@~1.16.0 + - Add new mime types + +2.1.3 / 2015-07-13 +================== + + * deps: mime-db@~1.15.0 + - Add new mime types + +2.1.2 / 2015-06-25 +================== + + * deps: mime-db@~1.14.0 + - Add new mime types + +2.1.1 / 2015-06-08 +================== + + * perf: fix deopt during mapping + +2.1.0 / 2015-06-07 +================== + + * Fix incorrectly treating extension-less file name as extension + - i.e. `'path/to/json'` will no longer return `application/json` + * Fix `.charset(type)` to accept parameters + * Fix `.charset(type)` to match case-insensitive + * Improve generation of extension to MIME mapping + * Refactor internals for readability and no argument reassignment + * Prefer `application/*` MIME types from the same source + * Prefer any type over `application/octet-stream` + * deps: mime-db@~1.13.0 + - Add nginx as a source + - Add new mime types + +2.0.14 / 2015-06-06 +=================== + + * deps: mime-db@~1.12.0 + - Add new mime types + +2.0.13 / 2015-05-31 +=================== + + * deps: mime-db@~1.11.0 + - Add new mime types + +2.0.12 / 2015-05-19 +=================== + + * deps: mime-db@~1.10.0 + - Add new mime types + +2.0.11 / 2015-05-05 +=================== + + * deps: mime-db@~1.9.1 + - Add new mime types + +2.0.10 / 2015-03-13 +=================== + + * deps: mime-db@~1.8.0 + - Add new mime types + +2.0.9 / 2015-02-09 +================== + + * deps: mime-db@~1.7.0 + - Add new mime types + - Community extensions ownership transferred from `node-mime` + +2.0.8 / 2015-01-29 +================== + + * deps: mime-db@~1.6.0 + - Add new mime types + +2.0.7 / 2014-12-30 +================== + + * deps: mime-db@~1.5.0 + - Add new mime types + - Fix various invalid MIME type entries + +2.0.6 / 2014-12-30 +================== + + * deps: mime-db@~1.4.0 + - Add new mime types + - Fix various invalid MIME type entries + - Remove example template MIME types + +2.0.5 / 2014-12-29 +================== + + * deps: mime-db@~1.3.1 + - Fix missing extensions + +2.0.4 / 2014-12-10 +================== + + * deps: mime-db@~1.3.0 + - Add new mime types + +2.0.3 / 2014-11-09 +================== + + * deps: mime-db@~1.2.0 + - Add new mime types + +2.0.2 / 2014-09-28 +================== + + * deps: mime-db@~1.1.0 + - Add new mime types + - Add additional compressible + - Update charsets + +2.0.1 / 2014-09-07 +================== + + * Support Node.js 0.6 + +2.0.0 / 2014-09-02 +================== + + * Use `mime-db` + * Remove `.define()` + +1.0.2 / 2014-08-04 +================== + + * Set charset=utf-8 for `text/javascript` + +1.0.1 / 2014-06-24 +================== + + * Add `text/jsx` type + +1.0.0 / 2014-05-12 +================== + + * Return `false` for unknown types + * Set charset=utf-8 for `application/json` + +0.1.0 / 2014-05-02 +================== + + * Initial release diff --git a/node_modules/body-parser/node_modules/type-is/node_modules/mime-types/LICENSE b/node_modules/body-parser/node_modules/type-is/node_modules/mime-types/LICENSE new file mode 100644 index 0000000..0616607 --- /dev/null +++ b/node_modules/body-parser/node_modules/type-is/node_modules/mime-types/LICENSE @@ -0,0 +1,23 @@ +(The MIT License) + +Copyright (c) 2014 Jonathan Ong +Copyright (c) 2015 Douglas Christopher Wilson + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/body-parser/node_modules/type-is/node_modules/mime-types/README.md b/node_modules/body-parser/node_modules/type-is/node_modules/mime-types/README.md new file mode 100644 index 0000000..e77d615 --- /dev/null +++ b/node_modules/body-parser/node_modules/type-is/node_modules/mime-types/README.md @@ -0,0 +1,103 @@ +# mime-types + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Node.js Version][node-version-image]][node-version-url] +[![Build Status][travis-image]][travis-url] +[![Test Coverage][coveralls-image]][coveralls-url] + +The ultimate javascript content-type utility. + +Similar to [node-mime](https://github.com/broofa/node-mime), except: + +- __No fallbacks.__ Instead of naively returning the first available type, `mime-types` simply returns `false`, + so do `var type = mime.lookup('unrecognized') || 'application/octet-stream'`. +- No `new Mime()` business, so you could do `var lookup = require('mime-types').lookup`. +- Additional mime types are added such as jade and stylus via [mime-db](https://github.com/jshttp/mime-db) +- No `.define()` functionality + +Otherwise, the API is compatible. + +## Install + +```sh +$ npm install mime-types +``` + +## Adding Types + +All mime types are based on [mime-db](https://github.com/jshttp/mime-db), +so open a PR there if you'd like to add mime types. + +## API + +```js +var mime = require('mime-types') +``` + +All functions return `false` if input is invalid or not found. + +### mime.lookup(path) + +Lookup the content-type associated with a file. + +```js +mime.lookup('json') // 'application/json' +mime.lookup('.md') // 'text/x-markdown' +mime.lookup('file.html') // 'text/html' +mime.lookup('folder/file.js') // 'application/javascript' +mime.lookup('folder/.htaccess') // false + +mime.lookup('cats') // false +``` + +### mime.contentType(type) + +Create a full content-type header given a content-type or extension. + +```js +mime.contentType('markdown') // 'text/x-markdown; charset=utf-8' +mime.contentType('file.json') // 'application/json; charset=utf-8' + +// from a full path +mime.contentType(path.extname('/path/to/file.json')) // 'application/json; charset=utf-8' +``` + +### mime.extension(type) + +Get the default extension for a content-type. + +```js +mime.extension('application/octet-stream') // 'bin' +``` + +### mime.charset(type) + +Lookup the implied default charset of a content-type. + +```js +mime.charset('text/x-markdown') // 'UTF-8' +``` + +### var type = mime.types[extension] + +A map of content-types by extension. + +### [extensions...] = mime.extensions[type] + +A map of extensions by content-type. + +## License + +[MIT](LICENSE) + +[npm-image]: https://img.shields.io/npm/v/mime-types.svg +[npm-url]: https://npmjs.org/package/mime-types +[node-version-image]: https://img.shields.io/node/v/mime-types.svg +[node-version-url]: https://nodejs.org/en/download/ +[travis-image]: https://img.shields.io/travis/jshttp/mime-types/master.svg +[travis-url]: https://travis-ci.org/jshttp/mime-types +[coveralls-image]: https://img.shields.io/coveralls/jshttp/mime-types/master.svg +[coveralls-url]: https://coveralls.io/r/jshttp/mime-types +[downloads-image]: https://img.shields.io/npm/dm/mime-types.svg +[downloads-url]: https://npmjs.org/package/mime-types diff --git a/node_modules/body-parser/node_modules/type-is/node_modules/mime-types/index.js b/node_modules/body-parser/node_modules/type-is/node_modules/mime-types/index.js new file mode 100644 index 0000000..9226ca5 --- /dev/null +++ b/node_modules/body-parser/node_modules/type-is/node_modules/mime-types/index.js @@ -0,0 +1,188 @@ +/*! + * mime-types + * Copyright(c) 2014 Jonathan Ong + * Copyright(c) 2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module dependencies. + * @private + */ + +var db = require('mime-db') +var extname = require('path').extname + +/** + * Module variables. + * @private + */ + +var extractTypeRegExp = /^\s*([^;\s]*)(?:;|\s|$)/ +var textTypeRegExp = /^text\//i + +/** + * Module exports. + * @public + */ + +exports.charset = charset +exports.charsets = { lookup: charset } +exports.contentType = contentType +exports.extension = extension +exports.extensions = Object.create(null) +exports.lookup = lookup +exports.types = Object.create(null) + +// Populate the extensions/types maps +populateMaps(exports.extensions, exports.types) + +/** + * Get the default charset for a MIME type. + * + * @param {string} type + * @return {boolean|string} + */ + +function charset (type) { + if (!type || typeof type !== 'string') { + return false + } + + // TODO: use media-typer + var match = extractTypeRegExp.exec(type) + var mime = match && db[match[1].toLowerCase()] + + if (mime && mime.charset) { + return mime.charset + } + + // default text/* to utf-8 + if (match && textTypeRegExp.test(match[1])) { + return 'UTF-8' + } + + return false +} + +/** + * Create a full Content-Type header given a MIME type or extension. + * + * @param {string} str + * @return {boolean|string} + */ + +function contentType (str) { + // TODO: should this even be in this module? + if (!str || typeof str !== 'string') { + return false + } + + var mime = str.indexOf('/') === -1 + ? exports.lookup(str) + : str + + if (!mime) { + return false + } + + // TODO: use content-type or other module + if (mime.indexOf('charset') === -1) { + var charset = exports.charset(mime) + if (charset) mime += '; charset=' + charset.toLowerCase() + } + + return mime +} + +/** + * Get the default extension for a MIME type. + * + * @param {string} type + * @return {boolean|string} + */ + +function extension (type) { + if (!type || typeof type !== 'string') { + return false + } + + // TODO: use media-typer + var match = extractTypeRegExp.exec(type) + + // get extensions + var exts = match && exports.extensions[match[1].toLowerCase()] + + if (!exts || !exts.length) { + return false + } + + return exts[0] +} + +/** + * Lookup the MIME type for a file path/extension. + * + * @param {string} path + * @return {boolean|string} + */ + +function lookup (path) { + if (!path || typeof path !== 'string') { + return false + } + + // get the extension ("ext" or ".ext" or full path) + var extension = extname('x.' + path) + .toLowerCase() + .substr(1) + + if (!extension) { + return false + } + + return exports.types[extension] || false +} + +/** + * Populate the extensions and types maps. + * @private + */ + +function populateMaps (extensions, types) { + // source preference (least -> most) + var preference = ['nginx', 'apache', undefined, 'iana'] + + Object.keys(db).forEach(function forEachMimeType (type) { + var mime = db[type] + var exts = mime.extensions + + if (!exts || !exts.length) { + return + } + + // mime -> extensions + extensions[type] = exts + + // extension -> mime + for (var i = 0; i < exts.length; i++) { + var extension = exts[i] + + if (types[extension]) { + var from = preference.indexOf(db[types[extension]].source) + var to = preference.indexOf(mime.source) + + if (types[extension] !== 'application/octet-stream' && + from > to || (from === to && types[extension].substr(0, 12) === 'application/')) { + // skip the remapping + continue + } + } + + // set the extension -> mime + types[extension] = type + } + }) +} diff --git a/node_modules/body-parser/node_modules/type-is/node_modules/mime-types/node_modules/mime-db/HISTORY.md b/node_modules/body-parser/node_modules/type-is/node_modules/mime-types/node_modules/mime-db/HISTORY.md new file mode 100644 index 0000000..d4796b5 --- /dev/null +++ b/node_modules/body-parser/node_modules/type-is/node_modules/mime-types/node_modules/mime-db/HISTORY.md @@ -0,0 +1,365 @@ +1.24.0 / 2016-09-18 +=================== + + * Add `application/clue_info+xml` + * Add `application/geo+json` + * Add `application/lgr+xml` + * Add `application/vnd.amazon.mobi8-ebook` + * Add `application/vnd.chess-pgn` + * Add `application/vnd.comicbook+zip` + * Add `application/vnd.d2l.coursepackage1p0+zip` + * Add `application/vnd.espass-espass+zip` + * Add `application/vnd.nearst.inv+json` + * Add `application/vnd.oma.lwm2m+json` + * Add `application/vnd.oma.lwm2m+tlv` + * Add `application/vnd.quarantainenet` + * Add `application/vnd.rar` + * Add `audio/mp3` + * Add `image/dicom-rle` + * Add `image/emf` + * Add `image/jls` + * Add `image/wmf` + * Add `model/gltf+json` + * Add `text/vnd.ascii-art` + +1.23.0 / 2016-05-01 +=================== + + * Add `application/efi` + * Add `application/vnd.3gpp.sms+xml` + * Add `application/vnd.3lightssoftware.imagescal` + * Add `application/vnd.coreos.ignition+json` + * Add `application/vnd.desmume.movie` + * Add `application/vnd.onepager` + * Add `application/vnd.vel+json` + * Add `text/prs.prop.logic` + * Add `video/encaprtp` + * Add `video/h265` + * Add `video/iso.segment` + * Add `video/raptorfec` + * Add `video/rtploopback` + * Add `video/vnd.radgamettools.bink` + * Add `video/vnd.radgamettools.smacker` + * Add `video/vp8` + * Add extension `.3gpp` to `audio/3gpp` + +1.22.0 / 2016-02-15 +=================== + + * Add `application/ppsp-tracker+json` + * Add `application/problem+json` + * Add `application/problem+xml` + * Add `application/vnd.hdt` + * Add `application/vnd.ms-printschematicket+xml` + * Add `model/vnd.rosette.annotated-data-model` + * Add `text/slim` + * Add extension `.rng` to `application/xml` + * Fix extension of `application/dash+xml` to be `.mpd` + * Update primary extension to `.m4a` for `audio/mp4` + +1.21.0 / 2016-01-06 +=================== + + * Add `application/emergencycalldata.comment+xml` + * Add `application/emergencycalldata.deviceinfo+xml` + * Add `application/emergencycalldata.providerinfo+xml` + * Add `application/emergencycalldata.serviceinfo+xml` + * Add `application/emergencycalldata.subscriberinfo+xml` + * Add `application/vnd.filmit.zfc` + * Add `application/vnd.google-apps.document` + * Add `application/vnd.google-apps.presentation` + * Add `application/vnd.google-apps.spreadsheet` + * Add `application/vnd.mapbox-vector-tile` + * Add `application/vnd.ms-printdevicecapabilities+xml` + * Add `application/vnd.ms-windows.devicepairing` + * Add `application/vnd.ms-windows.nwprinting.oob` + * Add `application/vnd.tml` + * Add `audio/evs` + +1.20.0 / 2015-11-10 +=================== + + * Add `application/cdni` + * Add `application/csvm+json` + * Add `application/rfc+xml` + * Add `application/vnd.3gpp.access-transfer-events+xml` + * Add `application/vnd.3gpp.srvcc-ext+xml` + * Add `application/vnd.ms-windows.wsd.oob` + * Add `application/vnd.oxli.countgraph` + * Add `application/vnd.pagerduty+json` + * Add `text/x-suse-ymp` + +1.19.0 / 2015-09-17 +=================== + + * Add `application/vnd.3gpp-prose-pc3ch+xml` + * Add `application/vnd.3gpp.srvcc-info+xml` + * Add `application/vnd.apple.pkpass` + * Add `application/vnd.drive+json` + +1.18.0 / 2015-09-03 +=================== + + * Add `application/pkcs12` + * Add `application/vnd.3gpp-prose+xml` + * Add `application/vnd.3gpp.mid-call+xml` + * Add `application/vnd.3gpp.state-and-event-info+xml` + * Add `application/vnd.anki` + * Add `application/vnd.firemonkeys.cloudcell` + * Add `application/vnd.openblox.game+xml` + * Add `application/vnd.openblox.game-binary` + +1.17.0 / 2015-08-13 +=================== + + * Add `application/x-msdos-program` + * Add `audio/g711-0` + * Add `image/vnd.mozilla.apng` + * Add extension `.exe` to `application/x-msdos-program` + +1.16.0 / 2015-07-29 +=================== + + * Add `application/vnd.uri-map` + +1.15.0 / 2015-07-13 +=================== + + * Add `application/x-httpd-php` + +1.14.0 / 2015-06-25 +=================== + + * Add `application/scim+json` + * Add `application/vnd.3gpp.ussd+xml` + * Add `application/vnd.biopax.rdf+xml` + * Add `text/x-processing` + +1.13.0 / 2015-06-07 +=================== + + * Add nginx as a source + * Add `application/x-cocoa` + * Add `application/x-java-archive-diff` + * Add `application/x-makeself` + * Add `application/x-perl` + * Add `application/x-pilot` + * Add `application/x-redhat-package-manager` + * Add `application/x-sea` + * Add `audio/x-m4a` + * Add `audio/x-realaudio` + * Add `image/x-jng` + * Add `text/mathml` + +1.12.0 / 2015-06-05 +=================== + + * Add `application/bdoc` + * Add `application/vnd.hyperdrive+json` + * Add `application/x-bdoc` + * Add extension `.rtf` to `text/rtf` + +1.11.0 / 2015-05-31 +=================== + + * Add `audio/wav` + * Add `audio/wave` + * Add extension `.litcoffee` to `text/coffeescript` + * Add extension `.sfd-hdstx` to `application/vnd.hydrostatix.sof-data` + * Add extension `.n-gage` to `application/vnd.nokia.n-gage.symbian.install` + +1.10.0 / 2015-05-19 +=================== + + * Add `application/vnd.balsamiq.bmpr` + * Add `application/vnd.microsoft.portable-executable` + * Add `application/x-ns-proxy-autoconfig` + +1.9.1 / 2015-04-19 +================== + + * Remove `.json` extension from `application/manifest+json` + - This is causing bugs downstream + +1.9.0 / 2015-04-19 +================== + + * Add `application/manifest+json` + * Add `application/vnd.micro+json` + * Add `image/vnd.zbrush.pcx` + * Add `image/x-ms-bmp` + +1.8.0 / 2015-03-13 +================== + + * Add `application/vnd.citationstyles.style+xml` + * Add `application/vnd.fastcopy-disk-image` + * Add `application/vnd.gov.sk.xmldatacontainer+xml` + * Add extension `.jsonld` to `application/ld+json` + +1.7.0 / 2015-02-08 +================== + + * Add `application/vnd.gerber` + * Add `application/vnd.msa-disk-image` + +1.6.1 / 2015-02-05 +================== + + * Community extensions ownership transferred from `node-mime` + +1.6.0 / 2015-01-29 +================== + + * Add `application/jose` + * Add `application/jose+json` + * Add `application/json-seq` + * Add `application/jwk+json` + * Add `application/jwk-set+json` + * Add `application/jwt` + * Add `application/rdap+json` + * Add `application/vnd.gov.sk.e-form+xml` + * Add `application/vnd.ims.imsccv1p3` + +1.5.0 / 2014-12-30 +================== + + * Add `application/vnd.oracle.resource+json` + * Fix various invalid MIME type entries + - `application/mbox+xml` + - `application/oscp-response` + - `application/vwg-multiplexed` + - `audio/g721` + +1.4.0 / 2014-12-21 +================== + + * Add `application/vnd.ims.imsccv1p2` + * Fix various invalid MIME type entries + - `application/vnd-acucobol` + - `application/vnd-curl` + - `application/vnd-dart` + - `application/vnd-dxr` + - `application/vnd-fdf` + - `application/vnd-mif` + - `application/vnd-sema` + - `application/vnd-wap-wmlc` + - `application/vnd.adobe.flash-movie` + - `application/vnd.dece-zip` + - `application/vnd.dvb_service` + - `application/vnd.micrografx-igx` + - `application/vnd.sealed-doc` + - `application/vnd.sealed-eml` + - `application/vnd.sealed-mht` + - `application/vnd.sealed-ppt` + - `application/vnd.sealed-tiff` + - `application/vnd.sealed-xls` + - `application/vnd.sealedmedia.softseal-html` + - `application/vnd.sealedmedia.softseal-pdf` + - `application/vnd.wap-slc` + - `application/vnd.wap-wbxml` + - `audio/vnd.sealedmedia.softseal-mpeg` + - `image/vnd-djvu` + - `image/vnd-svf` + - `image/vnd-wap-wbmp` + - `image/vnd.sealed-png` + - `image/vnd.sealedmedia.softseal-gif` + - `image/vnd.sealedmedia.softseal-jpg` + - `model/vnd-dwf` + - `model/vnd.parasolid.transmit-binary` + - `model/vnd.parasolid.transmit-text` + - `text/vnd-a` + - `text/vnd-curl` + - `text/vnd.wap-wml` + * Remove example template MIME types + - `application/example` + - `audio/example` + - `image/example` + - `message/example` + - `model/example` + - `multipart/example` + - `text/example` + - `video/example` + +1.3.1 / 2014-12-16 +================== + + * Fix missing extensions + - `application/json5` + - `text/hjson` + +1.3.0 / 2014-12-07 +================== + + * Add `application/a2l` + * Add `application/aml` + * Add `application/atfx` + * Add `application/atxml` + * Add `application/cdfx+xml` + * Add `application/dii` + * Add `application/json5` + * Add `application/lxf` + * Add `application/mf4` + * Add `application/vnd.apache.thrift.compact` + * Add `application/vnd.apache.thrift.json` + * Add `application/vnd.coffeescript` + * Add `application/vnd.enphase.envoy` + * Add `application/vnd.ims.imsccv1p1` + * Add `text/csv-schema` + * Add `text/hjson` + * Add `text/markdown` + * Add `text/yaml` + +1.2.0 / 2014-11-09 +================== + + * Add `application/cea` + * Add `application/dit` + * Add `application/vnd.gov.sk.e-form+zip` + * Add `application/vnd.tmd.mediaflex.api+xml` + * Type `application/epub+zip` is now IANA-registered + +1.1.2 / 2014-10-23 +================== + + * Rebuild database for `application/x-www-form-urlencoded` change + +1.1.1 / 2014-10-20 +================== + + * Mark `application/x-www-form-urlencoded` as compressible. + +1.1.0 / 2014-09-28 +================== + + * Add `application/font-woff2` + +1.0.3 / 2014-09-25 +================== + + * Fix engine requirement in package + +1.0.2 / 2014-09-25 +================== + + * Add `application/coap-group+json` + * Add `application/dcd` + * Add `application/vnd.apache.thrift.binary` + * Add `image/vnd.tencent.tap` + * Mark all JSON-derived types as compressible + * Update `text/vtt` data + +1.0.1 / 2014-08-30 +================== + + * Fix extension ordering + +1.0.0 / 2014-08-30 +================== + + * Add `application/atf` + * Add `application/merge-patch+json` + * Add `multipart/x-mixed-replace` + * Add `source: 'apache'` metadata + * Add `source: 'iana'` metadata + * Remove badly-assumed charset data diff --git a/node_modules/body-parser/node_modules/type-is/node_modules/mime-types/node_modules/mime-db/LICENSE b/node_modules/body-parser/node_modules/type-is/node_modules/mime-types/node_modules/mime-db/LICENSE new file mode 100644 index 0000000..a7ae8ee --- /dev/null +++ b/node_modules/body-parser/node_modules/type-is/node_modules/mime-types/node_modules/mime-db/LICENSE @@ -0,0 +1,22 @@ + +The MIT License (MIT) + +Copyright (c) 2014 Jonathan Ong me@jongleberry.com + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. diff --git a/node_modules/body-parser/node_modules/type-is/node_modules/mime-types/node_modules/mime-db/README.md b/node_modules/body-parser/node_modules/type-is/node_modules/mime-types/node_modules/mime-db/README.md new file mode 100644 index 0000000..7662440 --- /dev/null +++ b/node_modules/body-parser/node_modules/type-is/node_modules/mime-types/node_modules/mime-db/README.md @@ -0,0 +1,82 @@ +# mime-db + +[![NPM Version][npm-version-image]][npm-url] +[![NPM Downloads][npm-downloads-image]][npm-url] +[![Node.js Version][node-image]][node-url] +[![Build Status][travis-image]][travis-url] +[![Coverage Status][coveralls-image]][coveralls-url] + +This is a database of all mime types. +It consists of a single, public JSON file and does not include any logic, +allowing it to remain as un-opinionated as possible with an API. +It aggregates data from the following sources: + +- http://www.iana.org/assignments/media-types/media-types.xhtml +- http://svn.apache.org/repos/asf/httpd/httpd/trunk/docs/conf/mime.types +- http://hg.nginx.org/nginx/raw-file/default/conf/mime.types + +## Installation + +```bash +npm install mime-db +``` + +### Database Download + +If you're crazy enough to use this in the browser, you can just grab the +JSON file using [RawGit](https://rawgit.com/). It is recommended to replace +`master` with [a release tag](https://github.com/jshttp/mime-db/tags) as the +JSON format may change in the future. + +``` +https://cdn.rawgit.com/jshttp/mime-db/master/db.json +``` + +## Usage + +```js +var db = require('mime-db'); + +// grab data on .js files +var data = db['application/javascript']; +``` + +## Data Structure + +The JSON file is a map lookup for lowercased mime types. +Each mime type has the following properties: + +- `.source` - where the mime type is defined. + If not set, it's probably a custom media type. + - `apache` - [Apache common media types](http://svn.apache.org/repos/asf/httpd/httpd/trunk/docs/conf/mime.types) + - `iana` - [IANA-defined media types](http://www.iana.org/assignments/media-types/media-types.xhtml) + - `nginx` - [nginx media types](http://hg.nginx.org/nginx/raw-file/default/conf/mime.types) +- `.extensions[]` - known extensions associated with this mime type. +- `.compressible` - whether a file of this type can be gzipped. +- `.charset` - the default charset associated with this type, if any. + +If unknown, every property could be `undefined`. + +## Contributing + +To edit the database, only make PRs against `src/custom.json` or +`src/custom-suffix.json`. + +To update the build, run `npm run build`. + +## Adding Custom Media Types + +The best way to get new media types included in this library is to register +them with the IANA. The community registration procedure is outlined in +[RFC 6838 section 5](http://tools.ietf.org/html/rfc6838#section-5). Types +registered with the IANA are automatically pulled into this library. + +[npm-version-image]: https://img.shields.io/npm/v/mime-db.svg +[npm-downloads-image]: https://img.shields.io/npm/dm/mime-db.svg +[npm-url]: https://npmjs.org/package/mime-db +[travis-image]: https://img.shields.io/travis/jshttp/mime-db/master.svg +[travis-url]: https://travis-ci.org/jshttp/mime-db +[coveralls-image]: https://img.shields.io/coveralls/jshttp/mime-db/master.svg +[coveralls-url]: https://coveralls.io/r/jshttp/mime-db?branch=master +[node-image]: https://img.shields.io/node/v/mime-db.svg +[node-url]: http://nodejs.org/download/ diff --git a/node_modules/body-parser/node_modules/type-is/node_modules/mime-types/node_modules/mime-db/db.json b/node_modules/body-parser/node_modules/type-is/node_modules/mime-types/node_modules/mime-db/db.json new file mode 100644 index 0000000..63b226f --- /dev/null +++ b/node_modules/body-parser/node_modules/type-is/node_modules/mime-types/node_modules/mime-db/db.json @@ -0,0 +1,6692 @@ +{ + "application/1d-interleaved-parityfec": { + "source": "iana" + }, + "application/3gpdash-qoe-report+xml": { + "source": "iana" + }, + "application/3gpp-ims+xml": { + "source": "iana" + }, + "application/a2l": { + "source": "iana" + }, + "application/activemessage": { + "source": "iana" + }, + "application/alto-costmap+json": { + "source": "iana", + "compressible": true + }, + "application/alto-costmapfilter+json": { + "source": "iana", + "compressible": true + }, + "application/alto-directory+json": { + "source": "iana", + "compressible": true + }, + "application/alto-endpointcost+json": { + "source": "iana", + "compressible": true + }, + "application/alto-endpointcostparams+json": { + "source": "iana", + "compressible": true + }, + "application/alto-endpointprop+json": { + "source": "iana", + "compressible": true + }, + "application/alto-endpointpropparams+json": { + "source": "iana", + "compressible": true + }, + "application/alto-error+json": { + "source": "iana", + "compressible": true + }, + "application/alto-networkmap+json": { + "source": "iana", + "compressible": true + }, + "application/alto-networkmapfilter+json": { + "source": "iana", + "compressible": true + }, + "application/aml": { + "source": "iana" + }, + "application/andrew-inset": { + "source": "iana", + "extensions": ["ez"] + }, + "application/applefile": { + "source": "iana" + }, + "application/applixware": { + "source": "apache", + "extensions": ["aw"] + }, + "application/atf": { + "source": "iana" + }, + "application/atfx": { + "source": "iana" + }, + "application/atom+xml": { + "source": "iana", + "compressible": true, + "extensions": ["atom"] + }, + "application/atomcat+xml": { + "source": "iana", + "extensions": ["atomcat"] + }, + "application/atomdeleted+xml": { + "source": "iana" + }, + "application/atomicmail": { + "source": "iana" + }, + "application/atomsvc+xml": { + "source": "iana", + "extensions": ["atomsvc"] + }, + "application/atxml": { + "source": "iana" + }, + "application/auth-policy+xml": { + "source": "iana" + }, + "application/bacnet-xdd+zip": { + "source": "iana" + }, + "application/batch-smtp": { + "source": "iana" + }, + "application/bdoc": { + "compressible": false, + "extensions": ["bdoc"] + }, + "application/beep+xml": { + "source": "iana" + }, + "application/calendar+json": { + "source": "iana", + "compressible": true + }, + "application/calendar+xml": { + "source": "iana" + }, + "application/call-completion": { + "source": "iana" + }, + "application/cals-1840": { + "source": "iana" + }, + "application/cbor": { + "source": "iana" + }, + "application/ccmp+xml": { + "source": "iana" + }, + "application/ccxml+xml": { + "source": "iana", + "extensions": ["ccxml"] + }, + "application/cdfx+xml": { + "source": "iana" + }, + "application/cdmi-capability": { + "source": "iana", + "extensions": ["cdmia"] + }, + "application/cdmi-container": { + "source": "iana", + "extensions": ["cdmic"] + }, + "application/cdmi-domain": { + "source": "iana", + "extensions": ["cdmid"] + }, + "application/cdmi-object": { + "source": "iana", + "extensions": ["cdmio"] + }, + "application/cdmi-queue": { + "source": "iana", + "extensions": ["cdmiq"] + }, + "application/cdni": { + "source": "iana" + }, + "application/cea": { + "source": "iana" + }, + "application/cea-2018+xml": { + "source": "iana" + }, + "application/cellml+xml": { + "source": "iana" + }, + "application/cfw": { + "source": "iana" + }, + "application/clue_info+xml": { + "source": "iana" + }, + "application/cms": { + "source": "iana" + }, + "application/cnrp+xml": { + "source": "iana" + }, + "application/coap-group+json": { + "source": "iana", + "compressible": true + }, + "application/commonground": { + "source": "iana" + }, + "application/conference-info+xml": { + "source": "iana" + }, + "application/cpl+xml": { + "source": "iana" + }, + "application/csrattrs": { + "source": "iana" + }, + "application/csta+xml": { + "source": "iana" + }, + "application/cstadata+xml": { + "source": "iana" + }, + "application/csvm+json": { + "source": "iana", + "compressible": true + }, + "application/cu-seeme": { + "source": "apache", + "extensions": ["cu"] + }, + "application/cybercash": { + "source": "iana" + }, + "application/dart": { + "compressible": true + }, + "application/dash+xml": { + "source": "iana", + "extensions": ["mpd"] + }, + "application/dashdelta": { + "source": "iana" + }, + "application/davmount+xml": { + "source": "iana", + "extensions": ["davmount"] + }, + "application/dca-rft": { + "source": "iana" + }, + "application/dcd": { + "source": "iana" + }, + "application/dec-dx": { + "source": "iana" + }, + "application/dialog-info+xml": { + "source": "iana" + }, + "application/dicom": { + "source": "iana" + }, + "application/dii": { + "source": "iana" + }, + "application/dit": { + "source": "iana" + }, + "application/dns": { + "source": "iana" + }, + "application/docbook+xml": { + "source": "apache", + "extensions": ["dbk"] + }, + "application/dskpp+xml": { + "source": "iana" + }, + "application/dssc+der": { + "source": "iana", + "extensions": ["dssc"] + }, + "application/dssc+xml": { + "source": "iana", + "extensions": ["xdssc"] + }, + "application/dvcs": { + "source": "iana" + }, + "application/ecmascript": { + "source": "iana", + "compressible": true, + "extensions": ["ecma"] + }, + "application/edi-consent": { + "source": "iana" + }, + "application/edi-x12": { + "source": "iana", + "compressible": false + }, + "application/edifact": { + "source": "iana", + "compressible": false + }, + "application/efi": { + "source": "iana" + }, + "application/emergencycalldata.comment+xml": { + "source": "iana" + }, + "application/emergencycalldata.deviceinfo+xml": { + "source": "iana" + }, + "application/emergencycalldata.providerinfo+xml": { + "source": "iana" + }, + "application/emergencycalldata.serviceinfo+xml": { + "source": "iana" + }, + "application/emergencycalldata.subscriberinfo+xml": { + "source": "iana" + }, + "application/emma+xml": { + "source": "iana", + "extensions": ["emma"] + }, + "application/emotionml+xml": { + "source": "iana" + }, + "application/encaprtp": { + "source": "iana" + }, + "application/epp+xml": { + "source": "iana" + }, + "application/epub+zip": { + "source": "iana", + "extensions": ["epub"] + }, + "application/eshop": { + "source": "iana" + }, + "application/exi": { + "source": "iana", + "extensions": ["exi"] + }, + "application/fastinfoset": { + "source": "iana" + }, + "application/fastsoap": { + "source": "iana" + }, + "application/fdt+xml": { + "source": "iana" + }, + "application/fits": { + "source": "iana" + }, + "application/font-sfnt": { + "source": "iana" + }, + "application/font-tdpfr": { + "source": "iana", + "extensions": ["pfr"] + }, + "application/font-woff": { + "source": "iana", + "compressible": false, + "extensions": ["woff"] + }, + "application/font-woff2": { + "compressible": false, + "extensions": ["woff2"] + }, + "application/framework-attributes+xml": { + "source": "iana" + }, + "application/geo+json": { + "source": "iana", + "compressible": true + }, + "application/gml+xml": { + "source": "apache", + "extensions": ["gml"] + }, + "application/gpx+xml": { + "source": "apache", + "extensions": ["gpx"] + }, + "application/gxf": { + "source": "apache", + "extensions": ["gxf"] + }, + "application/gzip": { + "source": "iana", + "compressible": false + }, + "application/h224": { + "source": "iana" + }, + "application/held+xml": { + "source": "iana" + }, + "application/http": { + "source": "iana" + }, + "application/hyperstudio": { + "source": "iana", + "extensions": ["stk"] + }, + "application/ibe-key-request+xml": { + "source": "iana" + }, + "application/ibe-pkg-reply+xml": { + "source": "iana" + }, + "application/ibe-pp-data": { + "source": "iana" + }, + "application/iges": { + "source": "iana" + }, + "application/im-iscomposing+xml": { + "source": "iana" + }, + "application/index": { + "source": "iana" + }, + "application/index.cmd": { + "source": "iana" + }, + "application/index.obj": { + "source": "iana" + }, + "application/index.response": { + "source": "iana" + }, + "application/index.vnd": { + "source": "iana" + }, + "application/inkml+xml": { + "source": "iana", + "extensions": ["ink","inkml"] + }, + "application/iotp": { + "source": "iana" + }, + "application/ipfix": { + "source": "iana", + "extensions": ["ipfix"] + }, + "application/ipp": { + "source": "iana" + }, + "application/isup": { + "source": "iana" + }, + "application/its+xml": { + "source": "iana" + }, + "application/java-archive": { + "source": "apache", + "compressible": false, + "extensions": ["jar","war","ear"] + }, + "application/java-serialized-object": { + "source": "apache", + "compressible": false, + "extensions": ["ser"] + }, + "application/java-vm": { + "source": "apache", + "compressible": false, + "extensions": ["class"] + }, + "application/javascript": { + "source": "iana", + "charset": "UTF-8", + "compressible": true, + "extensions": ["js"] + }, + "application/jose": { + "source": "iana" + }, + "application/jose+json": { + "source": "iana", + "compressible": true + }, + "application/jrd+json": { + "source": "iana", + "compressible": true + }, + "application/json": { + "source": "iana", + "charset": "UTF-8", + "compressible": true, + "extensions": ["json","map"] + }, + "application/json-patch+json": { + "source": "iana", + "compressible": true + }, + "application/json-seq": { + "source": "iana" + }, + "application/json5": { + "extensions": ["json5"] + }, + "application/jsonml+json": { + "source": "apache", + "compressible": true, + "extensions": ["jsonml"] + }, + "application/jwk+json": { + "source": "iana", + "compressible": true + }, + "application/jwk-set+json": { + "source": "iana", + "compressible": true + }, + "application/jwt": { + "source": "iana" + }, + "application/kpml-request+xml": { + "source": "iana" + }, + "application/kpml-response+xml": { + "source": "iana" + }, + "application/ld+json": { + "source": "iana", + "compressible": true, + "extensions": ["jsonld"] + }, + "application/lgr+xml": { + "source": "iana" + }, + "application/link-format": { + "source": "iana" + }, + "application/load-control+xml": { + "source": "iana" + }, + "application/lost+xml": { + "source": "iana", + "extensions": ["lostxml"] + }, + "application/lostsync+xml": { + "source": "iana" + }, + "application/lxf": { + "source": "iana" + }, + "application/mac-binhex40": { + "source": "iana", + "extensions": ["hqx"] + }, + "application/mac-compactpro": { + "source": "apache", + "extensions": ["cpt"] + }, + "application/macwriteii": { + "source": "iana" + }, + "application/mads+xml": { + "source": "iana", + "extensions": ["mads"] + }, + "application/manifest+json": { + "charset": "UTF-8", + "compressible": true, + "extensions": ["webmanifest"] + }, + "application/marc": { + "source": "iana", + "extensions": ["mrc"] + }, + "application/marcxml+xml": { + "source": "iana", + "extensions": ["mrcx"] + }, + "application/mathematica": { + "source": "iana", + "extensions": ["ma","nb","mb"] + }, + "application/mathml+xml": { + "source": "iana", + "extensions": ["mathml"] + }, + "application/mathml-content+xml": { + "source": "iana" + }, + "application/mathml-presentation+xml": { + "source": "iana" + }, + "application/mbms-associated-procedure-description+xml": { + "source": "iana" + }, + "application/mbms-deregister+xml": { + "source": "iana" + }, + "application/mbms-envelope+xml": { + "source": "iana" + }, + "application/mbms-msk+xml": { + "source": "iana" + }, + "application/mbms-msk-response+xml": { + "source": "iana" + }, + "application/mbms-protection-description+xml": { + "source": "iana" + }, + "application/mbms-reception-report+xml": { + "source": "iana" + }, + "application/mbms-register+xml": { + "source": "iana" + }, + "application/mbms-register-response+xml": { + "source": "iana" + }, + "application/mbms-schedule+xml": { + "source": "iana" + }, + "application/mbms-user-service-description+xml": { + "source": "iana" + }, + "application/mbox": { + "source": "iana", + "extensions": ["mbox"] + }, + "application/media-policy-dataset+xml": { + "source": "iana" + }, + "application/media_control+xml": { + "source": "iana" + }, + "application/mediaservercontrol+xml": { + "source": "iana", + "extensions": ["mscml"] + }, + "application/merge-patch+json": { + "source": "iana", + "compressible": true + }, + "application/metalink+xml": { + "source": "apache", + "extensions": ["metalink"] + }, + "application/metalink4+xml": { + "source": "iana", + "extensions": ["meta4"] + }, + "application/mets+xml": { + "source": "iana", + "extensions": ["mets"] + }, + "application/mf4": { + "source": "iana" + }, + "application/mikey": { + "source": "iana" + }, + "application/mods+xml": { + "source": "iana", + "extensions": ["mods"] + }, + "application/moss-keys": { + "source": "iana" + }, + "application/moss-signature": { + "source": "iana" + }, + "application/mosskey-data": { + "source": "iana" + }, + "application/mosskey-request": { + "source": "iana" + }, + "application/mp21": { + "source": "iana", + "extensions": ["m21","mp21"] + }, + "application/mp4": { + "source": "iana", + "extensions": ["mp4s","m4p"] + }, + "application/mpeg4-generic": { + "source": "iana" + }, + "application/mpeg4-iod": { + "source": "iana" + }, + "application/mpeg4-iod-xmt": { + "source": "iana" + }, + "application/mrb-consumer+xml": { + "source": "iana" + }, + "application/mrb-publish+xml": { + "source": "iana" + }, + "application/msc-ivr+xml": { + "source": "iana" + }, + "application/msc-mixer+xml": { + "source": "iana" + }, + "application/msword": { + "source": "iana", + "compressible": false, + "extensions": ["doc","dot"] + }, + "application/mxf": { + "source": "iana", + "extensions": ["mxf"] + }, + "application/nasdata": { + "source": "iana" + }, + "application/news-checkgroups": { + "source": "iana" + }, + "application/news-groupinfo": { + "source": "iana" + }, + "application/news-transmission": { + "source": "iana" + }, + "application/nlsml+xml": { + "source": "iana" + }, + "application/nss": { + "source": "iana" + }, + "application/ocsp-request": { + "source": "iana" + }, + "application/ocsp-response": { + "source": "iana" + }, + "application/octet-stream": { + "source": "iana", + "compressible": false, + "extensions": ["bin","dms","lrf","mar","so","dist","distz","pkg","bpk","dump","elc","deploy","exe","dll","deb","dmg","iso","img","msi","msp","msm","buffer"] + }, + "application/oda": { + "source": "iana", + "extensions": ["oda"] + }, + "application/odx": { + "source": "iana" + }, + "application/oebps-package+xml": { + "source": "iana", + "extensions": ["opf"] + }, + "application/ogg": { + "source": "iana", + "compressible": false, + "extensions": ["ogx"] + }, + "application/omdoc+xml": { + "source": "apache", + "extensions": ["omdoc"] + }, + "application/onenote": { + "source": "apache", + "extensions": ["onetoc","onetoc2","onetmp","onepkg"] + }, + "application/oxps": { + "source": "iana", + "extensions": ["oxps"] + }, + "application/p2p-overlay+xml": { + "source": "iana" + }, + "application/parityfec": { + "source": "iana" + }, + "application/patch-ops-error+xml": { + "source": "iana", + "extensions": ["xer"] + }, + "application/pdf": { + "source": "iana", + "compressible": false, + "extensions": ["pdf"] + }, + "application/pdx": { + "source": "iana" + }, + "application/pgp-encrypted": { + "source": "iana", + "compressible": false, + "extensions": ["pgp"] + }, + "application/pgp-keys": { + "source": "iana" + }, + "application/pgp-signature": { + "source": "iana", + "extensions": ["asc","sig"] + }, + "application/pics-rules": { + "source": "apache", + "extensions": ["prf"] + }, + "application/pidf+xml": { + "source": "iana" + }, + "application/pidf-diff+xml": { + "source": "iana" + }, + "application/pkcs10": { + "source": "iana", + "extensions": ["p10"] + }, + "application/pkcs12": { + "source": "iana" + }, + "application/pkcs7-mime": { + "source": "iana", + "extensions": ["p7m","p7c"] + }, + "application/pkcs7-signature": { + "source": "iana", + "extensions": ["p7s"] + }, + "application/pkcs8": { + "source": "iana", + "extensions": ["p8"] + }, + "application/pkix-attr-cert": { + "source": "iana", + "extensions": ["ac"] + }, + "application/pkix-cert": { + "source": "iana", + "extensions": ["cer"] + }, + "application/pkix-crl": { + "source": "iana", + "extensions": ["crl"] + }, + "application/pkix-pkipath": { + "source": "iana", + "extensions": ["pkipath"] + }, + "application/pkixcmp": { + "source": "iana", + "extensions": ["pki"] + }, + "application/pls+xml": { + "source": "iana", + "extensions": ["pls"] + }, + "application/poc-settings+xml": { + "source": "iana" + }, + "application/postscript": { + "source": "iana", + "compressible": true, + "extensions": ["ai","eps","ps"] + }, + "application/ppsp-tracker+json": { + "source": "iana", + "compressible": true + }, + "application/problem+json": { + "source": "iana", + "compressible": true + }, + "application/problem+xml": { + "source": "iana" + }, + "application/provenance+xml": { + "source": "iana" + }, + "application/prs.alvestrand.titrax-sheet": { + "source": "iana" + }, + "application/prs.cww": { + "source": "iana", + "extensions": ["cww"] + }, + "application/prs.hpub+zip": { + "source": "iana" + }, + "application/prs.nprend": { + "source": "iana" + }, + "application/prs.plucker": { + "source": "iana" + }, + "application/prs.rdf-xml-crypt": { + "source": "iana" + }, + "application/prs.xsf+xml": { + "source": "iana" + }, + "application/pskc+xml": { + "source": "iana", + "extensions": ["pskcxml"] + }, + "application/qsig": { + "source": "iana" + }, + "application/raptorfec": { + "source": "iana" + }, + "application/rdap+json": { + "source": "iana", + "compressible": true + }, + "application/rdf+xml": { + "source": "iana", + "compressible": true, + "extensions": ["rdf"] + }, + "application/reginfo+xml": { + "source": "iana", + "extensions": ["rif"] + }, + "application/relax-ng-compact-syntax": { + "source": "iana", + "extensions": ["rnc"] + }, + "application/remote-printing": { + "source": "iana" + }, + "application/reputon+json": { + "source": "iana", + "compressible": true + }, + "application/resource-lists+xml": { + "source": "iana", + "extensions": ["rl"] + }, + "application/resource-lists-diff+xml": { + "source": "iana", + "extensions": ["rld"] + }, + "application/rfc+xml": { + "source": "iana" + }, + "application/riscos": { + "source": "iana" + }, + "application/rlmi+xml": { + "source": "iana" + }, + "application/rls-services+xml": { + "source": "iana", + "extensions": ["rs"] + }, + "application/rpki-ghostbusters": { + "source": "iana", + "extensions": ["gbr"] + }, + "application/rpki-manifest": { + "source": "iana", + "extensions": ["mft"] + }, + "application/rpki-roa": { + "source": "iana", + "extensions": ["roa"] + }, + "application/rpki-updown": { + "source": "iana" + }, + "application/rsd+xml": { + "source": "apache", + "extensions": ["rsd"] + }, + "application/rss+xml": { + "source": "apache", + "compressible": true, + "extensions": ["rss"] + }, + "application/rtf": { + "source": "iana", + "compressible": true, + "extensions": ["rtf"] + }, + "application/rtploopback": { + "source": "iana" + }, + "application/rtx": { + "source": "iana" + }, + "application/samlassertion+xml": { + "source": "iana" + }, + "application/samlmetadata+xml": { + "source": "iana" + }, + "application/sbml+xml": { + "source": "iana", + "extensions": ["sbml"] + }, + "application/scaip+xml": { + "source": "iana" + }, + "application/scim+json": { + "source": "iana", + "compressible": true + }, + "application/scvp-cv-request": { + "source": "iana", + "extensions": ["scq"] + }, + "application/scvp-cv-response": { + "source": "iana", + "extensions": ["scs"] + }, + "application/scvp-vp-request": { + "source": "iana", + "extensions": ["spq"] + }, + "application/scvp-vp-response": { + "source": "iana", + "extensions": ["spp"] + }, + "application/sdp": { + "source": "iana", + "extensions": ["sdp"] + }, + "application/sep+xml": { + "source": "iana" + }, + "application/sep-exi": { + "source": "iana" + }, + "application/session-info": { + "source": "iana" + }, + "application/set-payment": { + "source": "iana" + }, + "application/set-payment-initiation": { + "source": "iana", + "extensions": ["setpay"] + }, + "application/set-registration": { + "source": "iana" + }, + "application/set-registration-initiation": { + "source": "iana", + "extensions": ["setreg"] + }, + "application/sgml": { + "source": "iana" + }, + "application/sgml-open-catalog": { + "source": "iana" + }, + "application/shf+xml": { + "source": "iana", + "extensions": ["shf"] + }, + "application/sieve": { + "source": "iana" + }, + "application/simple-filter+xml": { + "source": "iana" + }, + "application/simple-message-summary": { + "source": "iana" + }, + "application/simplesymbolcontainer": { + "source": "iana" + }, + "application/slate": { + "source": "iana" + }, + "application/smil": { + "source": "iana" + }, + "application/smil+xml": { + "source": "iana", + "extensions": ["smi","smil"] + }, + "application/smpte336m": { + "source": "iana" + }, + "application/soap+fastinfoset": { + "source": "iana" + }, + "application/soap+xml": { + "source": "iana", + "compressible": true + }, + "application/sparql-query": { + "source": "iana", + "extensions": ["rq"] + }, + "application/sparql-results+xml": { + "source": "iana", + "extensions": ["srx"] + }, + "application/spirits-event+xml": { + "source": "iana" + }, + "application/sql": { + "source": "iana" + }, + "application/srgs": { + "source": "iana", + "extensions": ["gram"] + }, + "application/srgs+xml": { + "source": "iana", + "extensions": ["grxml"] + }, + "application/sru+xml": { + "source": "iana", + "extensions": ["sru"] + }, + "application/ssdl+xml": { + "source": "apache", + "extensions": ["ssdl"] + }, + "application/ssml+xml": { + "source": "iana", + "extensions": ["ssml"] + }, + "application/tamp-apex-update": { + "source": "iana" + }, + "application/tamp-apex-update-confirm": { + "source": "iana" + }, + "application/tamp-community-update": { + "source": "iana" + }, + "application/tamp-community-update-confirm": { + "source": "iana" + }, + "application/tamp-error": { + "source": "iana" + }, + "application/tamp-sequence-adjust": { + "source": "iana" + }, + "application/tamp-sequence-adjust-confirm": { + "source": "iana" + }, + "application/tamp-status-query": { + "source": "iana" + }, + "application/tamp-status-response": { + "source": "iana" + }, + "application/tamp-update": { + "source": "iana" + }, + "application/tamp-update-confirm": { + "source": "iana" + }, + "application/tar": { + "compressible": true + }, + "application/tei+xml": { + "source": "iana", + "extensions": ["tei","teicorpus"] + }, + "application/thraud+xml": { + "source": "iana", + "extensions": ["tfi"] + }, + "application/timestamp-query": { + "source": "iana" + }, + "application/timestamp-reply": { + "source": "iana" + }, + "application/timestamped-data": { + "source": "iana", + "extensions": ["tsd"] + }, + "application/ttml+xml": { + "source": "iana" + }, + "application/tve-trigger": { + "source": "iana" + }, + "application/ulpfec": { + "source": "iana" + }, + "application/urc-grpsheet+xml": { + "source": "iana" + }, + "application/urc-ressheet+xml": { + "source": "iana" + }, + "application/urc-targetdesc+xml": { + "source": "iana" + }, + "application/urc-uisocketdesc+xml": { + "source": "iana" + }, + "application/vcard+json": { + "source": "iana", + "compressible": true + }, + "application/vcard+xml": { + "source": "iana" + }, + "application/vemmi": { + "source": "iana" + }, + "application/vividence.scriptfile": { + "source": "apache" + }, + "application/vnd.3gpp-prose+xml": { + "source": "iana" + }, + "application/vnd.3gpp-prose-pc3ch+xml": { + "source": "iana" + }, + "application/vnd.3gpp.access-transfer-events+xml": { + "source": "iana" + }, + "application/vnd.3gpp.bsf+xml": { + "source": "iana" + }, + "application/vnd.3gpp.mid-call+xml": { + "source": "iana" + }, + "application/vnd.3gpp.pic-bw-large": { + "source": "iana", + "extensions": ["plb"] + }, + "application/vnd.3gpp.pic-bw-small": { + "source": "iana", + "extensions": ["psb"] + }, + "application/vnd.3gpp.pic-bw-var": { + "source": "iana", + "extensions": ["pvb"] + }, + "application/vnd.3gpp.sms": { + "source": "iana" + }, + "application/vnd.3gpp.sms+xml": { + "source": "iana" + }, + "application/vnd.3gpp.srvcc-ext+xml": { + "source": "iana" + }, + "application/vnd.3gpp.srvcc-info+xml": { + "source": "iana" + }, + "application/vnd.3gpp.state-and-event-info+xml": { + "source": "iana" + }, + "application/vnd.3gpp.ussd+xml": { + "source": "iana" + }, + "application/vnd.3gpp2.bcmcsinfo+xml": { + "source": "iana" + }, + "application/vnd.3gpp2.sms": { + "source": "iana" + }, + "application/vnd.3gpp2.tcap": { + "source": "iana", + "extensions": ["tcap"] + }, + "application/vnd.3lightssoftware.imagescal": { + "source": "iana" + }, + "application/vnd.3m.post-it-notes": { + "source": "iana", + "extensions": ["pwn"] + }, + "application/vnd.accpac.simply.aso": { + "source": "iana", + "extensions": ["aso"] + }, + "application/vnd.accpac.simply.imp": { + "source": "iana", + "extensions": ["imp"] + }, + "application/vnd.acucobol": { + "source": "iana", + "extensions": ["acu"] + }, + "application/vnd.acucorp": { + "source": "iana", + "extensions": ["atc","acutc"] + }, + "application/vnd.adobe.air-application-installer-package+zip": { + "source": "apache", + "extensions": ["air"] + }, + "application/vnd.adobe.flash.movie": { + "source": "iana" + }, + "application/vnd.adobe.formscentral.fcdt": { + "source": "iana", + "extensions": ["fcdt"] + }, + "application/vnd.adobe.fxp": { + "source": "iana", + "extensions": ["fxp","fxpl"] + }, + "application/vnd.adobe.partial-upload": { + "source": "iana" + }, + "application/vnd.adobe.xdp+xml": { + "source": "iana", + "extensions": ["xdp"] + }, + "application/vnd.adobe.xfdf": { + "source": "iana", + "extensions": ["xfdf"] + }, + "application/vnd.aether.imp": { + "source": "iana" + }, + "application/vnd.ah-barcode": { + "source": "iana" + }, + "application/vnd.ahead.space": { + "source": "iana", + "extensions": ["ahead"] + }, + "application/vnd.airzip.filesecure.azf": { + "source": "iana", + "extensions": ["azf"] + }, + "application/vnd.airzip.filesecure.azs": { + "source": "iana", + "extensions": ["azs"] + }, + "application/vnd.amazon.ebook": { + "source": "apache", + "extensions": ["azw"] + }, + "application/vnd.amazon.mobi8-ebook": { + "source": "iana" + }, + "application/vnd.americandynamics.acc": { + "source": "iana", + "extensions": ["acc"] + }, + "application/vnd.amiga.ami": { + "source": "iana", + "extensions": ["ami"] + }, + "application/vnd.amundsen.maze+xml": { + "source": "iana" + }, + "application/vnd.android.package-archive": { + "source": "apache", + "compressible": false, + "extensions": ["apk"] + }, + "application/vnd.anki": { + "source": "iana" + }, + "application/vnd.anser-web-certificate-issue-initiation": { + "source": "iana", + "extensions": ["cii"] + }, + "application/vnd.anser-web-funds-transfer-initiation": { + "source": "apache", + "extensions": ["fti"] + }, + "application/vnd.antix.game-component": { + "source": "iana", + "extensions": ["atx"] + }, + "application/vnd.apache.thrift.binary": { + "source": "iana" + }, + "application/vnd.apache.thrift.compact": { + "source": "iana" + }, + "application/vnd.apache.thrift.json": { + "source": "iana" + }, + "application/vnd.api+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.apple.installer+xml": { + "source": "iana", + "extensions": ["mpkg"] + }, + "application/vnd.apple.mpegurl": { + "source": "iana", + "extensions": ["m3u8"] + }, + "application/vnd.apple.pkpass": { + "compressible": false, + "extensions": ["pkpass"] + }, + "application/vnd.arastra.swi": { + "source": "iana" + }, + "application/vnd.aristanetworks.swi": { + "source": "iana", + "extensions": ["swi"] + }, + "application/vnd.artsquare": { + "source": "iana" + }, + "application/vnd.astraea-software.iota": { + "source": "iana", + "extensions": ["iota"] + }, + "application/vnd.audiograph": { + "source": "iana", + "extensions": ["aep"] + }, + "application/vnd.autopackage": { + "source": "iana" + }, + "application/vnd.avistar+xml": { + "source": "iana" + }, + "application/vnd.balsamiq.bmml+xml": { + "source": "iana" + }, + "application/vnd.balsamiq.bmpr": { + "source": "iana" + }, + "application/vnd.bekitzur-stech+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.biopax.rdf+xml": { + "source": "iana" + }, + "application/vnd.blueice.multipass": { + "source": "iana", + "extensions": ["mpm"] + }, + "application/vnd.bluetooth.ep.oob": { + "source": "iana" + }, + "application/vnd.bluetooth.le.oob": { + "source": "iana" + }, + "application/vnd.bmi": { + "source": "iana", + "extensions": ["bmi"] + }, + "application/vnd.businessobjects": { + "source": "iana", + "extensions": ["rep"] + }, + "application/vnd.cab-jscript": { + "source": "iana" + }, + "application/vnd.canon-cpdl": { + "source": "iana" + }, + "application/vnd.canon-lips": { + "source": "iana" + }, + "application/vnd.cendio.thinlinc.clientconf": { + "source": "iana" + }, + "application/vnd.century-systems.tcp_stream": { + "source": "iana" + }, + "application/vnd.chemdraw+xml": { + "source": "iana", + "extensions": ["cdxml"] + }, + "application/vnd.chess-pgn": { + "source": "iana" + }, + "application/vnd.chipnuts.karaoke-mmd": { + "source": "iana", + "extensions": ["mmd"] + }, + "application/vnd.cinderella": { + "source": "iana", + "extensions": ["cdy"] + }, + "application/vnd.cirpack.isdn-ext": { + "source": "iana" + }, + "application/vnd.citationstyles.style+xml": { + "source": "iana" + }, + "application/vnd.claymore": { + "source": "iana", + "extensions": ["cla"] + }, + "application/vnd.cloanto.rp9": { + "source": "iana", + "extensions": ["rp9"] + }, + "application/vnd.clonk.c4group": { + "source": "iana", + "extensions": ["c4g","c4d","c4f","c4p","c4u"] + }, + "application/vnd.cluetrust.cartomobile-config": { + "source": "iana", + "extensions": ["c11amc"] + }, + "application/vnd.cluetrust.cartomobile-config-pkg": { + "source": "iana", + "extensions": ["c11amz"] + }, + "application/vnd.coffeescript": { + "source": "iana" + }, + "application/vnd.collection+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.collection.doc+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.collection.next+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.comicbook+zip": { + "source": "iana" + }, + "application/vnd.commerce-battelle": { + "source": "iana" + }, + "application/vnd.commonspace": { + "source": "iana", + "extensions": ["csp"] + }, + "application/vnd.contact.cmsg": { + "source": "iana", + "extensions": ["cdbcmsg"] + }, + "application/vnd.coreos.ignition+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.cosmocaller": { + "source": "iana", + "extensions": ["cmc"] + }, + "application/vnd.crick.clicker": { + "source": "iana", + "extensions": ["clkx"] + }, + "application/vnd.crick.clicker.keyboard": { + "source": "iana", + "extensions": ["clkk"] + }, + "application/vnd.crick.clicker.palette": { + "source": "iana", + "extensions": ["clkp"] + }, + "application/vnd.crick.clicker.template": { + "source": "iana", + "extensions": ["clkt"] + }, + "application/vnd.crick.clicker.wordbank": { + "source": "iana", + "extensions": ["clkw"] + }, + "application/vnd.criticaltools.wbs+xml": { + "source": "iana", + "extensions": ["wbs"] + }, + "application/vnd.ctc-posml": { + "source": "iana", + "extensions": ["pml"] + }, + "application/vnd.ctct.ws+xml": { + "source": "iana" + }, + "application/vnd.cups-pdf": { + "source": "iana" + }, + "application/vnd.cups-postscript": { + "source": "iana" + }, + "application/vnd.cups-ppd": { + "source": "iana", + "extensions": ["ppd"] + }, + "application/vnd.cups-raster": { + "source": "iana" + }, + "application/vnd.cups-raw": { + "source": "iana" + }, + "application/vnd.curl": { + "source": "iana" + }, + "application/vnd.curl.car": { + "source": "apache", + "extensions": ["car"] + }, + "application/vnd.curl.pcurl": { + "source": "apache", + "extensions": ["pcurl"] + }, + "application/vnd.cyan.dean.root+xml": { + "source": "iana" + }, + "application/vnd.cybank": { + "source": "iana" + }, + "application/vnd.d2l.coursepackage1p0+zip": { + "source": "iana" + }, + "application/vnd.dart": { + "source": "iana", + "compressible": true, + "extensions": ["dart"] + }, + "application/vnd.data-vision.rdz": { + "source": "iana", + "extensions": ["rdz"] + }, + "application/vnd.debian.binary-package": { + "source": "iana" + }, + "application/vnd.dece.data": { + "source": "iana", + "extensions": ["uvf","uvvf","uvd","uvvd"] + }, + "application/vnd.dece.ttml+xml": { + "source": "iana", + "extensions": ["uvt","uvvt"] + }, + "application/vnd.dece.unspecified": { + "source": "iana", + "extensions": ["uvx","uvvx"] + }, + "application/vnd.dece.zip": { + "source": "iana", + "extensions": ["uvz","uvvz"] + }, + "application/vnd.denovo.fcselayout-link": { + "source": "iana", + "extensions": ["fe_launch"] + }, + "application/vnd.desmume-movie": { + "source": "iana" + }, + "application/vnd.desmume.movie": { + "source": "apache" + }, + "application/vnd.dir-bi.plate-dl-nosuffix": { + "source": "iana" + }, + "application/vnd.dm.delegation+xml": { + "source": "iana" + }, + "application/vnd.dna": { + "source": "iana", + "extensions": ["dna"] + }, + "application/vnd.document+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.dolby.mlp": { + "source": "apache", + "extensions": ["mlp"] + }, + "application/vnd.dolby.mobile.1": { + "source": "iana" + }, + "application/vnd.dolby.mobile.2": { + "source": "iana" + }, + "application/vnd.doremir.scorecloud-binary-document": { + "source": "iana" + }, + "application/vnd.dpgraph": { + "source": "iana", + "extensions": ["dpg"] + }, + "application/vnd.dreamfactory": { + "source": "iana", + "extensions": ["dfac"] + }, + "application/vnd.drive+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.ds-keypoint": { + "source": "apache", + "extensions": ["kpxx"] + }, + "application/vnd.dtg.local": { + "source": "iana" + }, + "application/vnd.dtg.local.flash": { + "source": "iana" + }, + "application/vnd.dtg.local.html": { + "source": "iana" + }, + "application/vnd.dvb.ait": { + "source": "iana", + "extensions": ["ait"] + }, + "application/vnd.dvb.dvbj": { + "source": "iana" + }, + "application/vnd.dvb.esgcontainer": { + "source": "iana" + }, + "application/vnd.dvb.ipdcdftnotifaccess": { + "source": "iana" + }, + "application/vnd.dvb.ipdcesgaccess": { + "source": "iana" + }, + "application/vnd.dvb.ipdcesgaccess2": { + "source": "iana" + }, + "application/vnd.dvb.ipdcesgpdd": { + "source": "iana" + }, + "application/vnd.dvb.ipdcroaming": { + "source": "iana" + }, + "application/vnd.dvb.iptv.alfec-base": { + "source": "iana" + }, + "application/vnd.dvb.iptv.alfec-enhancement": { + "source": "iana" + }, + "application/vnd.dvb.notif-aggregate-root+xml": { + "source": "iana" + }, + "application/vnd.dvb.notif-container+xml": { + "source": "iana" + }, + "application/vnd.dvb.notif-generic+xml": { + "source": "iana" + }, + "application/vnd.dvb.notif-ia-msglist+xml": { + "source": "iana" + }, + "application/vnd.dvb.notif-ia-registration-request+xml": { + "source": "iana" + }, + "application/vnd.dvb.notif-ia-registration-response+xml": { + "source": "iana" + }, + "application/vnd.dvb.notif-init+xml": { + "source": "iana" + }, + "application/vnd.dvb.pfr": { + "source": "iana" + }, + "application/vnd.dvb.service": { + "source": "iana", + "extensions": ["svc"] + }, + "application/vnd.dxr": { + "source": "iana" + }, + "application/vnd.dynageo": { + "source": "iana", + "extensions": ["geo"] + }, + "application/vnd.dzr": { + "source": "iana" + }, + "application/vnd.easykaraoke.cdgdownload": { + "source": "iana" + }, + "application/vnd.ecdis-update": { + "source": "iana" + }, + "application/vnd.ecowin.chart": { + "source": "iana", + "extensions": ["mag"] + }, + "application/vnd.ecowin.filerequest": { + "source": "iana" + }, + "application/vnd.ecowin.fileupdate": { + "source": "iana" + }, + "application/vnd.ecowin.series": { + "source": "iana" + }, + "application/vnd.ecowin.seriesrequest": { + "source": "iana" + }, + "application/vnd.ecowin.seriesupdate": { + "source": "iana" + }, + "application/vnd.emclient.accessrequest+xml": { + "source": "iana" + }, + "application/vnd.enliven": { + "source": "iana", + "extensions": ["nml"] + }, + "application/vnd.enphase.envoy": { + "source": "iana" + }, + "application/vnd.eprints.data+xml": { + "source": "iana" + }, + "application/vnd.epson.esf": { + "source": "iana", + "extensions": ["esf"] + }, + "application/vnd.epson.msf": { + "source": "iana", + "extensions": ["msf"] + }, + "application/vnd.epson.quickanime": { + "source": "iana", + "extensions": ["qam"] + }, + "application/vnd.epson.salt": { + "source": "iana", + "extensions": ["slt"] + }, + "application/vnd.epson.ssf": { + "source": "iana", + "extensions": ["ssf"] + }, + "application/vnd.ericsson.quickcall": { + "source": "iana" + }, + "application/vnd.espass-espass+zip": { + "source": "iana" + }, + "application/vnd.eszigno3+xml": { + "source": "iana", + "extensions": ["es3","et3"] + }, + "application/vnd.etsi.aoc+xml": { + "source": "iana" + }, + "application/vnd.etsi.asic-e+zip": { + "source": "iana" + }, + "application/vnd.etsi.asic-s+zip": { + "source": "iana" + }, + "application/vnd.etsi.cug+xml": { + "source": "iana" + }, + "application/vnd.etsi.iptvcommand+xml": { + "source": "iana" + }, + "application/vnd.etsi.iptvdiscovery+xml": { + "source": "iana" + }, + "application/vnd.etsi.iptvprofile+xml": { + "source": "iana" + }, + "application/vnd.etsi.iptvsad-bc+xml": { + "source": "iana" + }, + "application/vnd.etsi.iptvsad-cod+xml": { + "source": "iana" + }, + "application/vnd.etsi.iptvsad-npvr+xml": { + "source": "iana" + }, + "application/vnd.etsi.iptvservice+xml": { + "source": "iana" + }, + "application/vnd.etsi.iptvsync+xml": { + "source": "iana" + }, + "application/vnd.etsi.iptvueprofile+xml": { + "source": "iana" + }, + "application/vnd.etsi.mcid+xml": { + "source": "iana" + }, + "application/vnd.etsi.mheg5": { + "source": "iana" + }, + "application/vnd.etsi.overload-control-policy-dataset+xml": { + "source": "iana" + }, + "application/vnd.etsi.pstn+xml": { + "source": "iana" + }, + "application/vnd.etsi.sci+xml": { + "source": "iana" + }, + "application/vnd.etsi.simservs+xml": { + "source": "iana" + }, + "application/vnd.etsi.timestamp-token": { + "source": "iana" + }, + "application/vnd.etsi.tsl+xml": { + "source": "iana" + }, + "application/vnd.etsi.tsl.der": { + "source": "iana" + }, + "application/vnd.eudora.data": { + "source": "iana" + }, + "application/vnd.ezpix-album": { + "source": "iana", + "extensions": ["ez2"] + }, + "application/vnd.ezpix-package": { + "source": "iana", + "extensions": ["ez3"] + }, + "application/vnd.f-secure.mobile": { + "source": "iana" + }, + "application/vnd.fastcopy-disk-image": { + "source": "iana" + }, + "application/vnd.fdf": { + "source": "iana", + "extensions": ["fdf"] + }, + "application/vnd.fdsn.mseed": { + "source": "iana", + "extensions": ["mseed"] + }, + "application/vnd.fdsn.seed": { + "source": "iana", + "extensions": ["seed","dataless"] + }, + "application/vnd.ffsns": { + "source": "iana" + }, + "application/vnd.filmit.zfc": { + "source": "iana" + }, + "application/vnd.fints": { + "source": "iana" + }, + "application/vnd.firemonkeys.cloudcell": { + "source": "iana" + }, + "application/vnd.flographit": { + "source": "iana", + "extensions": ["gph"] + }, + "application/vnd.fluxtime.clip": { + "source": "iana", + "extensions": ["ftc"] + }, + "application/vnd.font-fontforge-sfd": { + "source": "iana" + }, + "application/vnd.framemaker": { + "source": "iana", + "extensions": ["fm","frame","maker","book"] + }, + "application/vnd.frogans.fnc": { + "source": "iana", + "extensions": ["fnc"] + }, + "application/vnd.frogans.ltf": { + "source": "iana", + "extensions": ["ltf"] + }, + "application/vnd.fsc.weblaunch": { + "source": "iana", + "extensions": ["fsc"] + }, + "application/vnd.fujitsu.oasys": { + "source": "iana", + "extensions": ["oas"] + }, + "application/vnd.fujitsu.oasys2": { + "source": "iana", + "extensions": ["oa2"] + }, + "application/vnd.fujitsu.oasys3": { + "source": "iana", + "extensions": ["oa3"] + }, + "application/vnd.fujitsu.oasysgp": { + "source": "iana", + "extensions": ["fg5"] + }, + "application/vnd.fujitsu.oasysprs": { + "source": "iana", + "extensions": ["bh2"] + }, + "application/vnd.fujixerox.art-ex": { + "source": "iana" + }, + "application/vnd.fujixerox.art4": { + "source": "iana" + }, + "application/vnd.fujixerox.ddd": { + "source": "iana", + "extensions": ["ddd"] + }, + "application/vnd.fujixerox.docuworks": { + "source": "iana", + "extensions": ["xdw"] + }, + "application/vnd.fujixerox.docuworks.binder": { + "source": "iana", + "extensions": ["xbd"] + }, + "application/vnd.fujixerox.docuworks.container": { + "source": "iana" + }, + "application/vnd.fujixerox.hbpl": { + "source": "iana" + }, + "application/vnd.fut-misnet": { + "source": "iana" + }, + "application/vnd.fuzzysheet": { + "source": "iana", + "extensions": ["fzs"] + }, + "application/vnd.genomatix.tuxedo": { + "source": "iana", + "extensions": ["txd"] + }, + "application/vnd.geo+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.geocube+xml": { + "source": "iana" + }, + "application/vnd.geogebra.file": { + "source": "iana", + "extensions": ["ggb"] + }, + "application/vnd.geogebra.tool": { + "source": "iana", + "extensions": ["ggt"] + }, + "application/vnd.geometry-explorer": { + "source": "iana", + "extensions": ["gex","gre"] + }, + "application/vnd.geonext": { + "source": "iana", + "extensions": ["gxt"] + }, + "application/vnd.geoplan": { + "source": "iana", + "extensions": ["g2w"] + }, + "application/vnd.geospace": { + "source": "iana", + "extensions": ["g3w"] + }, + "application/vnd.gerber": { + "source": "iana" + }, + "application/vnd.globalplatform.card-content-mgt": { + "source": "iana" + }, + "application/vnd.globalplatform.card-content-mgt-response": { + "source": "iana" + }, + "application/vnd.gmx": { + "source": "iana", + "extensions": ["gmx"] + }, + "application/vnd.google-apps.document": { + "compressible": false, + "extensions": ["gdoc"] + }, + "application/vnd.google-apps.presentation": { + "compressible": false, + "extensions": ["gslides"] + }, + "application/vnd.google-apps.spreadsheet": { + "compressible": false, + "extensions": ["gsheet"] + }, + "application/vnd.google-earth.kml+xml": { + "source": "iana", + "compressible": true, + "extensions": ["kml"] + }, + "application/vnd.google-earth.kmz": { + "source": "iana", + "compressible": false, + "extensions": ["kmz"] + }, + "application/vnd.gov.sk.e-form+xml": { + "source": "iana" + }, + "application/vnd.gov.sk.e-form+zip": { + "source": "iana" + }, + "application/vnd.gov.sk.xmldatacontainer+xml": { + "source": "iana" + }, + "application/vnd.grafeq": { + "source": "iana", + "extensions": ["gqf","gqs"] + }, + "application/vnd.gridmp": { + "source": "iana" + }, + "application/vnd.groove-account": { + "source": "iana", + "extensions": ["gac"] + }, + "application/vnd.groove-help": { + "source": "iana", + "extensions": ["ghf"] + }, + "application/vnd.groove-identity-message": { + "source": "iana", + "extensions": ["gim"] + }, + "application/vnd.groove-injector": { + "source": "iana", + "extensions": ["grv"] + }, + "application/vnd.groove-tool-message": { + "source": "iana", + "extensions": ["gtm"] + }, + "application/vnd.groove-tool-template": { + "source": "iana", + "extensions": ["tpl"] + }, + "application/vnd.groove-vcard": { + "source": "iana", + "extensions": ["vcg"] + }, + "application/vnd.hal+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.hal+xml": { + "source": "iana", + "extensions": ["hal"] + }, + "application/vnd.handheld-entertainment+xml": { + "source": "iana", + "extensions": ["zmm"] + }, + "application/vnd.hbci": { + "source": "iana", + "extensions": ["hbci"] + }, + "application/vnd.hcl-bireports": { + "source": "iana" + }, + "application/vnd.hdt": { + "source": "iana" + }, + "application/vnd.heroku+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.hhe.lesson-player": { + "source": "iana", + "extensions": ["les"] + }, + "application/vnd.hp-hpgl": { + "source": "iana", + "extensions": ["hpgl"] + }, + "application/vnd.hp-hpid": { + "source": "iana", + "extensions": ["hpid"] + }, + "application/vnd.hp-hps": { + "source": "iana", + "extensions": ["hps"] + }, + "application/vnd.hp-jlyt": { + "source": "iana", + "extensions": ["jlt"] + }, + "application/vnd.hp-pcl": { + "source": "iana", + "extensions": ["pcl"] + }, + "application/vnd.hp-pclxl": { + "source": "iana", + "extensions": ["pclxl"] + }, + "application/vnd.httphone": { + "source": "iana" + }, + "application/vnd.hydrostatix.sof-data": { + "source": "iana", + "extensions": ["sfd-hdstx"] + }, + "application/vnd.hyperdrive+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.hzn-3d-crossword": { + "source": "iana" + }, + "application/vnd.ibm.afplinedata": { + "source": "iana" + }, + "application/vnd.ibm.electronic-media": { + "source": "iana" + }, + "application/vnd.ibm.minipay": { + "source": "iana", + "extensions": ["mpy"] + }, + "application/vnd.ibm.modcap": { + "source": "iana", + "extensions": ["afp","listafp","list3820"] + }, + "application/vnd.ibm.rights-management": { + "source": "iana", + "extensions": ["irm"] + }, + "application/vnd.ibm.secure-container": { + "source": "iana", + "extensions": ["sc"] + }, + "application/vnd.iccprofile": { + "source": "iana", + "extensions": ["icc","icm"] + }, + "application/vnd.ieee.1905": { + "source": "iana" + }, + "application/vnd.igloader": { + "source": "iana", + "extensions": ["igl"] + }, + "application/vnd.immervision-ivp": { + "source": "iana", + "extensions": ["ivp"] + }, + "application/vnd.immervision-ivu": { + "source": "iana", + "extensions": ["ivu"] + }, + "application/vnd.ims.imsccv1p1": { + "source": "iana" + }, + "application/vnd.ims.imsccv1p2": { + "source": "iana" + }, + "application/vnd.ims.imsccv1p3": { + "source": "iana" + }, + "application/vnd.ims.lis.v2.result+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.ims.lti.v2.toolconsumerprofile+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.ims.lti.v2.toolproxy+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.ims.lti.v2.toolproxy.id+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.ims.lti.v2.toolsettings+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.ims.lti.v2.toolsettings.simple+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.informedcontrol.rms+xml": { + "source": "iana" + }, + "application/vnd.informix-visionary": { + "source": "iana" + }, + "application/vnd.infotech.project": { + "source": "iana" + }, + "application/vnd.infotech.project+xml": { + "source": "iana" + }, + "application/vnd.innopath.wamp.notification": { + "source": "iana" + }, + "application/vnd.insors.igm": { + "source": "iana", + "extensions": ["igm"] + }, + "application/vnd.intercon.formnet": { + "source": "iana", + "extensions": ["xpw","xpx"] + }, + "application/vnd.intergeo": { + "source": "iana", + "extensions": ["i2g"] + }, + "application/vnd.intertrust.digibox": { + "source": "iana" + }, + "application/vnd.intertrust.nncp": { + "source": "iana" + }, + "application/vnd.intu.qbo": { + "source": "iana", + "extensions": ["qbo"] + }, + "application/vnd.intu.qfx": { + "source": "iana", + "extensions": ["qfx"] + }, + "application/vnd.iptc.g2.catalogitem+xml": { + "source": "iana" + }, + "application/vnd.iptc.g2.conceptitem+xml": { + "source": "iana" + }, + "application/vnd.iptc.g2.knowledgeitem+xml": { + "source": "iana" + }, + "application/vnd.iptc.g2.newsitem+xml": { + "source": "iana" + }, + "application/vnd.iptc.g2.newsmessage+xml": { + "source": "iana" + }, + "application/vnd.iptc.g2.packageitem+xml": { + "source": "iana" + }, + "application/vnd.iptc.g2.planningitem+xml": { + "source": "iana" + }, + "application/vnd.ipunplugged.rcprofile": { + "source": "iana", + "extensions": ["rcprofile"] + }, + "application/vnd.irepository.package+xml": { + "source": "iana", + "extensions": ["irp"] + }, + "application/vnd.is-xpr": { + "source": "iana", + "extensions": ["xpr"] + }, + "application/vnd.isac.fcs": { + "source": "iana", + "extensions": ["fcs"] + }, + "application/vnd.jam": { + "source": "iana", + "extensions": ["jam"] + }, + "application/vnd.japannet-directory-service": { + "source": "iana" + }, + "application/vnd.japannet-jpnstore-wakeup": { + "source": "iana" + }, + "application/vnd.japannet-payment-wakeup": { + "source": "iana" + }, + "application/vnd.japannet-registration": { + "source": "iana" + }, + "application/vnd.japannet-registration-wakeup": { + "source": "iana" + }, + "application/vnd.japannet-setstore-wakeup": { + "source": "iana" + }, + "application/vnd.japannet-verification": { + "source": "iana" + }, + "application/vnd.japannet-verification-wakeup": { + "source": "iana" + }, + "application/vnd.jcp.javame.midlet-rms": { + "source": "iana", + "extensions": ["rms"] + }, + "application/vnd.jisp": { + "source": "iana", + "extensions": ["jisp"] + }, + "application/vnd.joost.joda-archive": { + "source": "iana", + "extensions": ["joda"] + }, + "application/vnd.jsk.isdn-ngn": { + "source": "iana" + }, + "application/vnd.kahootz": { + "source": "iana", + "extensions": ["ktz","ktr"] + }, + "application/vnd.kde.karbon": { + "source": "iana", + "extensions": ["karbon"] + }, + "application/vnd.kde.kchart": { + "source": "iana", + "extensions": ["chrt"] + }, + "application/vnd.kde.kformula": { + "source": "iana", + "extensions": ["kfo"] + }, + "application/vnd.kde.kivio": { + "source": "iana", + "extensions": ["flw"] + }, + "application/vnd.kde.kontour": { + "source": "iana", + "extensions": ["kon"] + }, + "application/vnd.kde.kpresenter": { + "source": "iana", + "extensions": ["kpr","kpt"] + }, + "application/vnd.kde.kspread": { + "source": "iana", + "extensions": ["ksp"] + }, + "application/vnd.kde.kword": { + "source": "iana", + "extensions": ["kwd","kwt"] + }, + "application/vnd.kenameaapp": { + "source": "iana", + "extensions": ["htke"] + }, + "application/vnd.kidspiration": { + "source": "iana", + "extensions": ["kia"] + }, + "application/vnd.kinar": { + "source": "iana", + "extensions": ["kne","knp"] + }, + "application/vnd.koan": { + "source": "iana", + "extensions": ["skp","skd","skt","skm"] + }, + "application/vnd.kodak-descriptor": { + "source": "iana", + "extensions": ["sse"] + }, + "application/vnd.las.las+xml": { + "source": "iana", + "extensions": ["lasxml"] + }, + "application/vnd.liberty-request+xml": { + "source": "iana" + }, + "application/vnd.llamagraphics.life-balance.desktop": { + "source": "iana", + "extensions": ["lbd"] + }, + "application/vnd.llamagraphics.life-balance.exchange+xml": { + "source": "iana", + "extensions": ["lbe"] + }, + "application/vnd.lotus-1-2-3": { + "source": "iana", + "extensions": ["123"] + }, + "application/vnd.lotus-approach": { + "source": "iana", + "extensions": ["apr"] + }, + "application/vnd.lotus-freelance": { + "source": "iana", + "extensions": ["pre"] + }, + "application/vnd.lotus-notes": { + "source": "iana", + "extensions": ["nsf"] + }, + "application/vnd.lotus-organizer": { + "source": "iana", + "extensions": ["org"] + }, + "application/vnd.lotus-screencam": { + "source": "iana", + "extensions": ["scm"] + }, + "application/vnd.lotus-wordpro": { + "source": "iana", + "extensions": ["lwp"] + }, + "application/vnd.macports.portpkg": { + "source": "iana", + "extensions": ["portpkg"] + }, + "application/vnd.mapbox-vector-tile": { + "source": "iana" + }, + "application/vnd.marlin.drm.actiontoken+xml": { + "source": "iana" + }, + "application/vnd.marlin.drm.conftoken+xml": { + "source": "iana" + }, + "application/vnd.marlin.drm.license+xml": { + "source": "iana" + }, + "application/vnd.marlin.drm.mdcf": { + "source": "iana" + }, + "application/vnd.mason+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.maxmind.maxmind-db": { + "source": "iana" + }, + "application/vnd.mcd": { + "source": "iana", + "extensions": ["mcd"] + }, + "application/vnd.medcalcdata": { + "source": "iana", + "extensions": ["mc1"] + }, + "application/vnd.mediastation.cdkey": { + "source": "iana", + "extensions": ["cdkey"] + }, + "application/vnd.meridian-slingshot": { + "source": "iana" + }, + "application/vnd.mfer": { + "source": "iana", + "extensions": ["mwf"] + }, + "application/vnd.mfmp": { + "source": "iana", + "extensions": ["mfm"] + }, + "application/vnd.micro+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.micrografx.flo": { + "source": "iana", + "extensions": ["flo"] + }, + "application/vnd.micrografx.igx": { + "source": "iana", + "extensions": ["igx"] + }, + "application/vnd.microsoft.portable-executable": { + "source": "iana" + }, + "application/vnd.miele+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.mif": { + "source": "iana", + "extensions": ["mif"] + }, + "application/vnd.minisoft-hp3000-save": { + "source": "iana" + }, + "application/vnd.mitsubishi.misty-guard.trustweb": { + "source": "iana" + }, + "application/vnd.mobius.daf": { + "source": "iana", + "extensions": ["daf"] + }, + "application/vnd.mobius.dis": { + "source": "iana", + "extensions": ["dis"] + }, + "application/vnd.mobius.mbk": { + "source": "iana", + "extensions": ["mbk"] + }, + "application/vnd.mobius.mqy": { + "source": "iana", + "extensions": ["mqy"] + }, + "application/vnd.mobius.msl": { + "source": "iana", + "extensions": ["msl"] + }, + "application/vnd.mobius.plc": { + "source": "iana", + "extensions": ["plc"] + }, + "application/vnd.mobius.txf": { + "source": "iana", + "extensions": ["txf"] + }, + "application/vnd.mophun.application": { + "source": "iana", + "extensions": ["mpn"] + }, + "application/vnd.mophun.certificate": { + "source": "iana", + "extensions": ["mpc"] + }, + "application/vnd.motorola.flexsuite": { + "source": "iana" + }, + "application/vnd.motorola.flexsuite.adsi": { + "source": "iana" + }, + "application/vnd.motorola.flexsuite.fis": { + "source": "iana" + }, + "application/vnd.motorola.flexsuite.gotap": { + "source": "iana" + }, + "application/vnd.motorola.flexsuite.kmr": { + "source": "iana" + }, + "application/vnd.motorola.flexsuite.ttc": { + "source": "iana" + }, + "application/vnd.motorola.flexsuite.wem": { + "source": "iana" + }, + "application/vnd.motorola.iprm": { + "source": "iana" + }, + "application/vnd.mozilla.xul+xml": { + "source": "iana", + "compressible": true, + "extensions": ["xul"] + }, + "application/vnd.ms-3mfdocument": { + "source": "iana" + }, + "application/vnd.ms-artgalry": { + "source": "iana", + "extensions": ["cil"] + }, + "application/vnd.ms-asf": { + "source": "iana" + }, + "application/vnd.ms-cab-compressed": { + "source": "iana", + "extensions": ["cab"] + }, + "application/vnd.ms-color.iccprofile": { + "source": "apache" + }, + "application/vnd.ms-excel": { + "source": "iana", + "compressible": false, + "extensions": ["xls","xlm","xla","xlc","xlt","xlw"] + }, + "application/vnd.ms-excel.addin.macroenabled.12": { + "source": "iana", + "extensions": ["xlam"] + }, + "application/vnd.ms-excel.sheet.binary.macroenabled.12": { + "source": "iana", + "extensions": ["xlsb"] + }, + "application/vnd.ms-excel.sheet.macroenabled.12": { + "source": "iana", + "extensions": ["xlsm"] + }, + "application/vnd.ms-excel.template.macroenabled.12": { + "source": "iana", + "extensions": ["xltm"] + }, + "application/vnd.ms-fontobject": { + "source": "iana", + "compressible": true, + "extensions": ["eot"] + }, + "application/vnd.ms-htmlhelp": { + "source": "iana", + "extensions": ["chm"] + }, + "application/vnd.ms-ims": { + "source": "iana", + "extensions": ["ims"] + }, + "application/vnd.ms-lrm": { + "source": "iana", + "extensions": ["lrm"] + }, + "application/vnd.ms-office.activex+xml": { + "source": "iana" + }, + "application/vnd.ms-officetheme": { + "source": "iana", + "extensions": ["thmx"] + }, + "application/vnd.ms-opentype": { + "source": "apache", + "compressible": true + }, + "application/vnd.ms-package.obfuscated-opentype": { + "source": "apache" + }, + "application/vnd.ms-pki.seccat": { + "source": "apache", + "extensions": ["cat"] + }, + "application/vnd.ms-pki.stl": { + "source": "apache", + "extensions": ["stl"] + }, + "application/vnd.ms-playready.initiator+xml": { + "source": "iana" + }, + "application/vnd.ms-powerpoint": { + "source": "iana", + "compressible": false, + "extensions": ["ppt","pps","pot"] + }, + "application/vnd.ms-powerpoint.addin.macroenabled.12": { + "source": "iana", + "extensions": ["ppam"] + }, + "application/vnd.ms-powerpoint.presentation.macroenabled.12": { + "source": "iana", + "extensions": ["pptm"] + }, + "application/vnd.ms-powerpoint.slide.macroenabled.12": { + "source": "iana", + "extensions": ["sldm"] + }, + "application/vnd.ms-powerpoint.slideshow.macroenabled.12": { + "source": "iana", + "extensions": ["ppsm"] + }, + "application/vnd.ms-powerpoint.template.macroenabled.12": { + "source": "iana", + "extensions": ["potm"] + }, + "application/vnd.ms-printdevicecapabilities+xml": { + "source": "iana" + }, + "application/vnd.ms-printing.printticket+xml": { + "source": "apache" + }, + "application/vnd.ms-printschematicket+xml": { + "source": "iana" + }, + "application/vnd.ms-project": { + "source": "iana", + "extensions": ["mpp","mpt"] + }, + "application/vnd.ms-tnef": { + "source": "iana" + }, + "application/vnd.ms-windows.devicepairing": { + "source": "iana" + }, + "application/vnd.ms-windows.nwprinting.oob": { + "source": "iana" + }, + "application/vnd.ms-windows.printerpairing": { + "source": "iana" + }, + "application/vnd.ms-windows.wsd.oob": { + "source": "iana" + }, + "application/vnd.ms-wmdrm.lic-chlg-req": { + "source": "iana" + }, + "application/vnd.ms-wmdrm.lic-resp": { + "source": "iana" + }, + "application/vnd.ms-wmdrm.meter-chlg-req": { + "source": "iana" + }, + "application/vnd.ms-wmdrm.meter-resp": { + "source": "iana" + }, + "application/vnd.ms-word.document.macroenabled.12": { + "source": "iana", + "extensions": ["docm"] + }, + "application/vnd.ms-word.template.macroenabled.12": { + "source": "iana", + "extensions": ["dotm"] + }, + "application/vnd.ms-works": { + "source": "iana", + "extensions": ["wps","wks","wcm","wdb"] + }, + "application/vnd.ms-wpl": { + "source": "iana", + "extensions": ["wpl"] + }, + "application/vnd.ms-xpsdocument": { + "source": "iana", + "compressible": false, + "extensions": ["xps"] + }, + "application/vnd.msa-disk-image": { + "source": "iana" + }, + "application/vnd.mseq": { + "source": "iana", + "extensions": ["mseq"] + }, + "application/vnd.msign": { + "source": "iana" + }, + "application/vnd.multiad.creator": { + "source": "iana" + }, + "application/vnd.multiad.creator.cif": { + "source": "iana" + }, + "application/vnd.music-niff": { + "source": "iana" + }, + "application/vnd.musician": { + "source": "iana", + "extensions": ["mus"] + }, + "application/vnd.muvee.style": { + "source": "iana", + "extensions": ["msty"] + }, + "application/vnd.mynfc": { + "source": "iana", + "extensions": ["taglet"] + }, + "application/vnd.ncd.control": { + "source": "iana" + }, + "application/vnd.ncd.reference": { + "source": "iana" + }, + "application/vnd.nearst.inv+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.nervana": { + "source": "iana" + }, + "application/vnd.netfpx": { + "source": "iana" + }, + "application/vnd.neurolanguage.nlu": { + "source": "iana", + "extensions": ["nlu"] + }, + "application/vnd.nintendo.nitro.rom": { + "source": "iana" + }, + "application/vnd.nintendo.snes.rom": { + "source": "iana" + }, + "application/vnd.nitf": { + "source": "iana", + "extensions": ["ntf","nitf"] + }, + "application/vnd.noblenet-directory": { + "source": "iana", + "extensions": ["nnd"] + }, + "application/vnd.noblenet-sealer": { + "source": "iana", + "extensions": ["nns"] + }, + "application/vnd.noblenet-web": { + "source": "iana", + "extensions": ["nnw"] + }, + "application/vnd.nokia.catalogs": { + "source": "iana" + }, + "application/vnd.nokia.conml+wbxml": { + "source": "iana" + }, + "application/vnd.nokia.conml+xml": { + "source": "iana" + }, + "application/vnd.nokia.iptv.config+xml": { + "source": "iana" + }, + "application/vnd.nokia.isds-radio-presets": { + "source": "iana" + }, + "application/vnd.nokia.landmark+wbxml": { + "source": "iana" + }, + "application/vnd.nokia.landmark+xml": { + "source": "iana" + }, + "application/vnd.nokia.landmarkcollection+xml": { + "source": "iana" + }, + "application/vnd.nokia.n-gage.ac+xml": { + "source": "iana" + }, + "application/vnd.nokia.n-gage.data": { + "source": "iana", + "extensions": ["ngdat"] + }, + "application/vnd.nokia.n-gage.symbian.install": { + "source": "iana", + "extensions": ["n-gage"] + }, + "application/vnd.nokia.ncd": { + "source": "iana" + }, + "application/vnd.nokia.pcd+wbxml": { + "source": "iana" + }, + "application/vnd.nokia.pcd+xml": { + "source": "iana" + }, + "application/vnd.nokia.radio-preset": { + "source": "iana", + "extensions": ["rpst"] + }, + "application/vnd.nokia.radio-presets": { + "source": "iana", + "extensions": ["rpss"] + }, + "application/vnd.novadigm.edm": { + "source": "iana", + "extensions": ["edm"] + }, + "application/vnd.novadigm.edx": { + "source": "iana", + "extensions": ["edx"] + }, + "application/vnd.novadigm.ext": { + "source": "iana", + "extensions": ["ext"] + }, + "application/vnd.ntt-local.content-share": { + "source": "iana" + }, + "application/vnd.ntt-local.file-transfer": { + "source": "iana" + }, + "application/vnd.ntt-local.ogw_remote-access": { + "source": "iana" + }, + "application/vnd.ntt-local.sip-ta_remote": { + "source": "iana" + }, + "application/vnd.ntt-local.sip-ta_tcp_stream": { + "source": "iana" + }, + "application/vnd.oasis.opendocument.chart": { + "source": "iana", + "extensions": ["odc"] + }, + "application/vnd.oasis.opendocument.chart-template": { + "source": "iana", + "extensions": ["otc"] + }, + "application/vnd.oasis.opendocument.database": { + "source": "iana", + "extensions": ["odb"] + }, + "application/vnd.oasis.opendocument.formula": { + "source": "iana", + "extensions": ["odf"] + }, + "application/vnd.oasis.opendocument.formula-template": { + "source": "iana", + "extensions": ["odft"] + }, + "application/vnd.oasis.opendocument.graphics": { + "source": "iana", + "compressible": false, + "extensions": ["odg"] + }, + "application/vnd.oasis.opendocument.graphics-template": { + "source": "iana", + "extensions": ["otg"] + }, + "application/vnd.oasis.opendocument.image": { + "source": "iana", + "extensions": ["odi"] + }, + "application/vnd.oasis.opendocument.image-template": { + "source": "iana", + "extensions": ["oti"] + }, + "application/vnd.oasis.opendocument.presentation": { + "source": "iana", + "compressible": false, + "extensions": ["odp"] + }, + "application/vnd.oasis.opendocument.presentation-template": { + "source": "iana", + "extensions": ["otp"] + }, + "application/vnd.oasis.opendocument.spreadsheet": { + "source": "iana", + "compressible": false, + "extensions": ["ods"] + }, + "application/vnd.oasis.opendocument.spreadsheet-template": { + "source": "iana", + "extensions": ["ots"] + }, + "application/vnd.oasis.opendocument.text": { + "source": "iana", + "compressible": false, + "extensions": ["odt"] + }, + "application/vnd.oasis.opendocument.text-master": { + "source": "iana", + "extensions": ["odm"] + }, + "application/vnd.oasis.opendocument.text-template": { + "source": "iana", + "extensions": ["ott"] + }, + "application/vnd.oasis.opendocument.text-web": { + "source": "iana", + "extensions": ["oth"] + }, + "application/vnd.obn": { + "source": "iana" + }, + "application/vnd.oftn.l10n+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.oipf.contentaccessdownload+xml": { + "source": "iana" + }, + "application/vnd.oipf.contentaccessstreaming+xml": { + "source": "iana" + }, + "application/vnd.oipf.cspg-hexbinary": { + "source": "iana" + }, + "application/vnd.oipf.dae.svg+xml": { + "source": "iana" + }, + "application/vnd.oipf.dae.xhtml+xml": { + "source": "iana" + }, + "application/vnd.oipf.mippvcontrolmessage+xml": { + "source": "iana" + }, + "application/vnd.oipf.pae.gem": { + "source": "iana" + }, + "application/vnd.oipf.spdiscovery+xml": { + "source": "iana" + }, + "application/vnd.oipf.spdlist+xml": { + "source": "iana" + }, + "application/vnd.oipf.ueprofile+xml": { + "source": "iana" + }, + "application/vnd.oipf.userprofile+xml": { + "source": "iana" + }, + "application/vnd.olpc-sugar": { + "source": "iana", + "extensions": ["xo"] + }, + "application/vnd.oma-scws-config": { + "source": "iana" + }, + "application/vnd.oma-scws-http-request": { + "source": "iana" + }, + "application/vnd.oma-scws-http-response": { + "source": "iana" + }, + "application/vnd.oma.bcast.associated-procedure-parameter+xml": { + "source": "iana" + }, + "application/vnd.oma.bcast.drm-trigger+xml": { + "source": "iana" + }, + "application/vnd.oma.bcast.imd+xml": { + "source": "iana" + }, + "application/vnd.oma.bcast.ltkm": { + "source": "iana" + }, + "application/vnd.oma.bcast.notification+xml": { + "source": "iana" + }, + "application/vnd.oma.bcast.provisioningtrigger": { + "source": "iana" + }, + "application/vnd.oma.bcast.sgboot": { + "source": "iana" + }, + "application/vnd.oma.bcast.sgdd+xml": { + "source": "iana" + }, + "application/vnd.oma.bcast.sgdu": { + "source": "iana" + }, + "application/vnd.oma.bcast.simple-symbol-container": { + "source": "iana" + }, + "application/vnd.oma.bcast.smartcard-trigger+xml": { + "source": "iana" + }, + "application/vnd.oma.bcast.sprov+xml": { + "source": "iana" + }, + "application/vnd.oma.bcast.stkm": { + "source": "iana" + }, + "application/vnd.oma.cab-address-book+xml": { + "source": "iana" + }, + "application/vnd.oma.cab-feature-handler+xml": { + "source": "iana" + }, + "application/vnd.oma.cab-pcc+xml": { + "source": "iana" + }, + "application/vnd.oma.cab-subs-invite+xml": { + "source": "iana" + }, + "application/vnd.oma.cab-user-prefs+xml": { + "source": "iana" + }, + "application/vnd.oma.dcd": { + "source": "iana" + }, + "application/vnd.oma.dcdc": { + "source": "iana" + }, + "application/vnd.oma.dd2+xml": { + "source": "iana", + "extensions": ["dd2"] + }, + "application/vnd.oma.drm.risd+xml": { + "source": "iana" + }, + "application/vnd.oma.group-usage-list+xml": { + "source": "iana" + }, + "application/vnd.oma.lwm2m+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.oma.lwm2m+tlv": { + "source": "iana" + }, + "application/vnd.oma.pal+xml": { + "source": "iana" + }, + "application/vnd.oma.poc.detailed-progress-report+xml": { + "source": "iana" + }, + "application/vnd.oma.poc.final-report+xml": { + "source": "iana" + }, + "application/vnd.oma.poc.groups+xml": { + "source": "iana" + }, + "application/vnd.oma.poc.invocation-descriptor+xml": { + "source": "iana" + }, + "application/vnd.oma.poc.optimized-progress-report+xml": { + "source": "iana" + }, + "application/vnd.oma.push": { + "source": "iana" + }, + "application/vnd.oma.scidm.messages+xml": { + "source": "iana" + }, + "application/vnd.oma.xcap-directory+xml": { + "source": "iana" + }, + "application/vnd.omads-email+xml": { + "source": "iana" + }, + "application/vnd.omads-file+xml": { + "source": "iana" + }, + "application/vnd.omads-folder+xml": { + "source": "iana" + }, + "application/vnd.omaloc-supl-init": { + "source": "iana" + }, + "application/vnd.onepager": { + "source": "iana" + }, + "application/vnd.openblox.game+xml": { + "source": "iana" + }, + "application/vnd.openblox.game-binary": { + "source": "iana" + }, + "application/vnd.openeye.oeb": { + "source": "iana" + }, + "application/vnd.openofficeorg.extension": { + "source": "apache", + "extensions": ["oxt"] + }, + "application/vnd.openxmlformats-officedocument.custom-properties+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.customxmlproperties+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.drawing+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.drawingml.chart+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.drawingml.chartshapes+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.drawingml.diagramcolors+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.drawingml.diagramdata+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.drawingml.diagramlayout+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.drawingml.diagramstyle+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.extended-properties+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml-template": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml.commentauthors+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml.comments+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml.handoutmaster+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml.notesmaster+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml.notesslide+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml.presentation": { + "source": "iana", + "compressible": false, + "extensions": ["pptx"] + }, + "application/vnd.openxmlformats-officedocument.presentationml.presentation.main+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml.presprops+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml.slide": { + "source": "iana", + "extensions": ["sldx"] + }, + "application/vnd.openxmlformats-officedocument.presentationml.slide+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml.slidelayout+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml.slidemaster+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml.slideshow": { + "source": "iana", + "extensions": ["ppsx"] + }, + "application/vnd.openxmlformats-officedocument.presentationml.slideshow.main+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml.slideupdateinfo+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml.tablestyles+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml.tags+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml.template": { + "source": "apache", + "extensions": ["potx"] + }, + "application/vnd.openxmlformats-officedocument.presentationml.template.main+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml.viewprops+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml-template": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.calcchain+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.chartsheet+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.comments+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.connections+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.dialogsheet+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.externallink+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.pivotcachedefinition+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.pivotcacherecords+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.pivottable+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.querytable+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.revisionheaders+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.revisionlog+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.sharedstrings+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet": { + "source": "iana", + "compressible": false, + "extensions": ["xlsx"] + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet.main+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.sheetmetadata+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.styles+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.table+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.tablesinglecells+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.template": { + "source": "apache", + "extensions": ["xltx"] + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.template.main+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.usernames+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.volatiledependencies+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.worksheet+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.theme+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.themeoverride+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.vmldrawing": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.wordprocessingml-template": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.wordprocessingml.comments+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.wordprocessingml.document": { + "source": "iana", + "compressible": false, + "extensions": ["docx"] + }, + "application/vnd.openxmlformats-officedocument.wordprocessingml.document.glossary+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.wordprocessingml.document.main+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.wordprocessingml.endnotes+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.wordprocessingml.fonttable+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.wordprocessingml.footer+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.wordprocessingml.footnotes+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.wordprocessingml.numbering+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.wordprocessingml.settings+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.wordprocessingml.styles+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.wordprocessingml.template": { + "source": "apache", + "extensions": ["dotx"] + }, + "application/vnd.openxmlformats-officedocument.wordprocessingml.template.main+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.wordprocessingml.websettings+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-package.core-properties+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-package.digital-signature-xmlsignature+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-package.relationships+xml": { + "source": "iana" + }, + "application/vnd.oracle.resource+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.orange.indata": { + "source": "iana" + }, + "application/vnd.osa.netdeploy": { + "source": "iana" + }, + "application/vnd.osgeo.mapguide.package": { + "source": "iana", + "extensions": ["mgp"] + }, + "application/vnd.osgi.bundle": { + "source": "iana" + }, + "application/vnd.osgi.dp": { + "source": "iana", + "extensions": ["dp"] + }, + "application/vnd.osgi.subsystem": { + "source": "iana", + "extensions": ["esa"] + }, + "application/vnd.otps.ct-kip+xml": { + "source": "iana" + }, + "application/vnd.oxli.countgraph": { + "source": "iana" + }, + "application/vnd.pagerduty+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.palm": { + "source": "iana", + "extensions": ["pdb","pqa","oprc"] + }, + "application/vnd.panoply": { + "source": "iana" + }, + "application/vnd.paos+xml": { + "source": "iana" + }, + "application/vnd.paos.xml": { + "source": "apache" + }, + "application/vnd.pawaafile": { + "source": "iana", + "extensions": ["paw"] + }, + "application/vnd.pcos": { + "source": "iana" + }, + "application/vnd.pg.format": { + "source": "iana", + "extensions": ["str"] + }, + "application/vnd.pg.osasli": { + "source": "iana", + "extensions": ["ei6"] + }, + "application/vnd.piaccess.application-licence": { + "source": "iana" + }, + "application/vnd.picsel": { + "source": "iana", + "extensions": ["efif"] + }, + "application/vnd.pmi.widget": { + "source": "iana", + "extensions": ["wg"] + }, + "application/vnd.poc.group-advertisement+xml": { + "source": "iana" + }, + "application/vnd.pocketlearn": { + "source": "iana", + "extensions": ["plf"] + }, + "application/vnd.powerbuilder6": { + "source": "iana", + "extensions": ["pbd"] + }, + "application/vnd.powerbuilder6-s": { + "source": "iana" + }, + "application/vnd.powerbuilder7": { + "source": "iana" + }, + "application/vnd.powerbuilder7-s": { + "source": "iana" + }, + "application/vnd.powerbuilder75": { + "source": "iana" + }, + "application/vnd.powerbuilder75-s": { + "source": "iana" + }, + "application/vnd.preminet": { + "source": "iana" + }, + "application/vnd.previewsystems.box": { + "source": "iana", + "extensions": ["box"] + }, + "application/vnd.proteus.magazine": { + "source": "iana", + "extensions": ["mgz"] + }, + "application/vnd.publishare-delta-tree": { + "source": "iana", + "extensions": ["qps"] + }, + "application/vnd.pvi.ptid1": { + "source": "iana", + "extensions": ["ptid"] + }, + "application/vnd.pwg-multiplexed": { + "source": "iana" + }, + "application/vnd.pwg-xhtml-print+xml": { + "source": "iana" + }, + "application/vnd.qualcomm.brew-app-res": { + "source": "iana" + }, + "application/vnd.quarantainenet": { + "source": "iana" + }, + "application/vnd.quark.quarkxpress": { + "source": "iana", + "extensions": ["qxd","qxt","qwd","qwt","qxl","qxb"] + }, + "application/vnd.quobject-quoxdocument": { + "source": "iana" + }, + "application/vnd.radisys.moml+xml": { + "source": "iana" + }, + "application/vnd.radisys.msml+xml": { + "source": "iana" + }, + "application/vnd.radisys.msml-audit+xml": { + "source": "iana" + }, + "application/vnd.radisys.msml-audit-conf+xml": { + "source": "iana" + }, + "application/vnd.radisys.msml-audit-conn+xml": { + "source": "iana" + }, + "application/vnd.radisys.msml-audit-dialog+xml": { + "source": "iana" + }, + "application/vnd.radisys.msml-audit-stream+xml": { + "source": "iana" + }, + "application/vnd.radisys.msml-conf+xml": { + "source": "iana" + }, + "application/vnd.radisys.msml-dialog+xml": { + "source": "iana" + }, + "application/vnd.radisys.msml-dialog-base+xml": { + "source": "iana" + }, + "application/vnd.radisys.msml-dialog-fax-detect+xml": { + "source": "iana" + }, + "application/vnd.radisys.msml-dialog-fax-sendrecv+xml": { + "source": "iana" + }, + "application/vnd.radisys.msml-dialog-group+xml": { + "source": "iana" + }, + "application/vnd.radisys.msml-dialog-speech+xml": { + "source": "iana" + }, + "application/vnd.radisys.msml-dialog-transform+xml": { + "source": "iana" + }, + "application/vnd.rainstor.data": { + "source": "iana" + }, + "application/vnd.rapid": { + "source": "iana" + }, + "application/vnd.rar": { + "source": "iana" + }, + "application/vnd.realvnc.bed": { + "source": "iana", + "extensions": ["bed"] + }, + "application/vnd.recordare.musicxml": { + "source": "iana", + "extensions": ["mxl"] + }, + "application/vnd.recordare.musicxml+xml": { + "source": "iana", + "extensions": ["musicxml"] + }, + "application/vnd.renlearn.rlprint": { + "source": "iana" + }, + "application/vnd.rig.cryptonote": { + "source": "iana", + "extensions": ["cryptonote"] + }, + "application/vnd.rim.cod": { + "source": "apache", + "extensions": ["cod"] + }, + "application/vnd.rn-realmedia": { + "source": "apache", + "extensions": ["rm"] + }, + "application/vnd.rn-realmedia-vbr": { + "source": "apache", + "extensions": ["rmvb"] + }, + "application/vnd.route66.link66+xml": { + "source": "iana", + "extensions": ["link66"] + }, + "application/vnd.rs-274x": { + "source": "iana" + }, + "application/vnd.ruckus.download": { + "source": "iana" + }, + "application/vnd.s3sms": { + "source": "iana" + }, + "application/vnd.sailingtracker.track": { + "source": "iana", + "extensions": ["st"] + }, + "application/vnd.sbm.cid": { + "source": "iana" + }, + "application/vnd.sbm.mid2": { + "source": "iana" + }, + "application/vnd.scribus": { + "source": "iana" + }, + "application/vnd.sealed.3df": { + "source": "iana" + }, + "application/vnd.sealed.csf": { + "source": "iana" + }, + "application/vnd.sealed.doc": { + "source": "iana" + }, + "application/vnd.sealed.eml": { + "source": "iana" + }, + "application/vnd.sealed.mht": { + "source": "iana" + }, + "application/vnd.sealed.net": { + "source": "iana" + }, + "application/vnd.sealed.ppt": { + "source": "iana" + }, + "application/vnd.sealed.tiff": { + "source": "iana" + }, + "application/vnd.sealed.xls": { + "source": "iana" + }, + "application/vnd.sealedmedia.softseal.html": { + "source": "iana" + }, + "application/vnd.sealedmedia.softseal.pdf": { + "source": "iana" + }, + "application/vnd.seemail": { + "source": "iana", + "extensions": ["see"] + }, + "application/vnd.sema": { + "source": "iana", + "extensions": ["sema"] + }, + "application/vnd.semd": { + "source": "iana", + "extensions": ["semd"] + }, + "application/vnd.semf": { + "source": "iana", + "extensions": ["semf"] + }, + "application/vnd.shana.informed.formdata": { + "source": "iana", + "extensions": ["ifm"] + }, + "application/vnd.shana.informed.formtemplate": { + "source": "iana", + "extensions": ["itp"] + }, + "application/vnd.shana.informed.interchange": { + "source": "iana", + "extensions": ["iif"] + }, + "application/vnd.shana.informed.package": { + "source": "iana", + "extensions": ["ipk"] + }, + "application/vnd.simtech-mindmapper": { + "source": "iana", + "extensions": ["twd","twds"] + }, + "application/vnd.siren+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.smaf": { + "source": "iana", + "extensions": ["mmf"] + }, + "application/vnd.smart.notebook": { + "source": "iana" + }, + "application/vnd.smart.teacher": { + "source": "iana", + "extensions": ["teacher"] + }, + "application/vnd.software602.filler.form+xml": { + "source": "iana" + }, + "application/vnd.software602.filler.form-xml-zip": { + "source": "iana" + }, + "application/vnd.solent.sdkm+xml": { + "source": "iana", + "extensions": ["sdkm","sdkd"] + }, + "application/vnd.spotfire.dxp": { + "source": "iana", + "extensions": ["dxp"] + }, + "application/vnd.spotfire.sfs": { + "source": "iana", + "extensions": ["sfs"] + }, + "application/vnd.sss-cod": { + "source": "iana" + }, + "application/vnd.sss-dtf": { + "source": "iana" + }, + "application/vnd.sss-ntf": { + "source": "iana" + }, + "application/vnd.stardivision.calc": { + "source": "apache", + "extensions": ["sdc"] + }, + "application/vnd.stardivision.draw": { + "source": "apache", + "extensions": ["sda"] + }, + "application/vnd.stardivision.impress": { + "source": "apache", + "extensions": ["sdd"] + }, + "application/vnd.stardivision.math": { + "source": "apache", + "extensions": ["smf"] + }, + "application/vnd.stardivision.writer": { + "source": "apache", + "extensions": ["sdw","vor"] + }, + "application/vnd.stardivision.writer-global": { + "source": "apache", + "extensions": ["sgl"] + }, + "application/vnd.stepmania.package": { + "source": "iana", + "extensions": ["smzip"] + }, + "application/vnd.stepmania.stepchart": { + "source": "iana", + "extensions": ["sm"] + }, + "application/vnd.street-stream": { + "source": "iana" + }, + "application/vnd.sun.wadl+xml": { + "source": "iana" + }, + "application/vnd.sun.xml.calc": { + "source": "apache", + "extensions": ["sxc"] + }, + "application/vnd.sun.xml.calc.template": { + "source": "apache", + "extensions": ["stc"] + }, + "application/vnd.sun.xml.draw": { + "source": "apache", + "extensions": ["sxd"] + }, + "application/vnd.sun.xml.draw.template": { + "source": "apache", + "extensions": ["std"] + }, + "application/vnd.sun.xml.impress": { + "source": "apache", + "extensions": ["sxi"] + }, + "application/vnd.sun.xml.impress.template": { + "source": "apache", + "extensions": ["sti"] + }, + "application/vnd.sun.xml.math": { + "source": "apache", + "extensions": ["sxm"] + }, + "application/vnd.sun.xml.writer": { + "source": "apache", + "extensions": ["sxw"] + }, + "application/vnd.sun.xml.writer.global": { + "source": "apache", + "extensions": ["sxg"] + }, + "application/vnd.sun.xml.writer.template": { + "source": "apache", + "extensions": ["stw"] + }, + "application/vnd.sus-calendar": { + "source": "iana", + "extensions": ["sus","susp"] + }, + "application/vnd.svd": { + "source": "iana", + "extensions": ["svd"] + }, + "application/vnd.swiftview-ics": { + "source": "iana" + }, + "application/vnd.symbian.install": { + "source": "apache", + "extensions": ["sis","sisx"] + }, + "application/vnd.syncml+xml": { + "source": "iana", + "extensions": ["xsm"] + }, + "application/vnd.syncml.dm+wbxml": { + "source": "iana", + "extensions": ["bdm"] + }, + "application/vnd.syncml.dm+xml": { + "source": "iana", + "extensions": ["xdm"] + }, + "application/vnd.syncml.dm.notification": { + "source": "iana" + }, + "application/vnd.syncml.dmddf+wbxml": { + "source": "iana" + }, + "application/vnd.syncml.dmddf+xml": { + "source": "iana" + }, + "application/vnd.syncml.dmtnds+wbxml": { + "source": "iana" + }, + "application/vnd.syncml.dmtnds+xml": { + "source": "iana" + }, + "application/vnd.syncml.ds.notification": { + "source": "iana" + }, + "application/vnd.tao.intent-module-archive": { + "source": "iana", + "extensions": ["tao"] + }, + "application/vnd.tcpdump.pcap": { + "source": "iana", + "extensions": ["pcap","cap","dmp"] + }, + "application/vnd.tmd.mediaflex.api+xml": { + "source": "iana" + }, + "application/vnd.tml": { + "source": "iana" + }, + "application/vnd.tmobile-livetv": { + "source": "iana", + "extensions": ["tmo"] + }, + "application/vnd.trid.tpt": { + "source": "iana", + "extensions": ["tpt"] + }, + "application/vnd.triscape.mxs": { + "source": "iana", + "extensions": ["mxs"] + }, + "application/vnd.trueapp": { + "source": "iana", + "extensions": ["tra"] + }, + "application/vnd.truedoc": { + "source": "iana" + }, + "application/vnd.ubisoft.webplayer": { + "source": "iana" + }, + "application/vnd.ufdl": { + "source": "iana", + "extensions": ["ufd","ufdl"] + }, + "application/vnd.uiq.theme": { + "source": "iana", + "extensions": ["utz"] + }, + "application/vnd.umajin": { + "source": "iana", + "extensions": ["umj"] + }, + "application/vnd.unity": { + "source": "iana", + "extensions": ["unityweb"] + }, + "application/vnd.uoml+xml": { + "source": "iana", + "extensions": ["uoml"] + }, + "application/vnd.uplanet.alert": { + "source": "iana" + }, + "application/vnd.uplanet.alert-wbxml": { + "source": "iana" + }, + "application/vnd.uplanet.bearer-choice": { + "source": "iana" + }, + "application/vnd.uplanet.bearer-choice-wbxml": { + "source": "iana" + }, + "application/vnd.uplanet.cacheop": { + "source": "iana" + }, + "application/vnd.uplanet.cacheop-wbxml": { + "source": "iana" + }, + "application/vnd.uplanet.channel": { + "source": "iana" + }, + "application/vnd.uplanet.channel-wbxml": { + "source": "iana" + }, + "application/vnd.uplanet.list": { + "source": "iana" + }, + "application/vnd.uplanet.list-wbxml": { + "source": "iana" + }, + "application/vnd.uplanet.listcmd": { + "source": "iana" + }, + "application/vnd.uplanet.listcmd-wbxml": { + "source": "iana" + }, + "application/vnd.uplanet.signal": { + "source": "iana" + }, + "application/vnd.uri-map": { + "source": "iana" + }, + "application/vnd.valve.source.material": { + "source": "iana" + }, + "application/vnd.vcx": { + "source": "iana", + "extensions": ["vcx"] + }, + "application/vnd.vd-study": { + "source": "iana" + }, + "application/vnd.vectorworks": { + "source": "iana" + }, + "application/vnd.vel+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.verimatrix.vcas": { + "source": "iana" + }, + "application/vnd.vidsoft.vidconference": { + "source": "iana" + }, + "application/vnd.visio": { + "source": "iana", + "extensions": ["vsd","vst","vss","vsw"] + }, + "application/vnd.visionary": { + "source": "iana", + "extensions": ["vis"] + }, + "application/vnd.vividence.scriptfile": { + "source": "iana" + }, + "application/vnd.vsf": { + "source": "iana", + "extensions": ["vsf"] + }, + "application/vnd.wap.sic": { + "source": "iana" + }, + "application/vnd.wap.slc": { + "source": "iana" + }, + "application/vnd.wap.wbxml": { + "source": "iana", + "extensions": ["wbxml"] + }, + "application/vnd.wap.wmlc": { + "source": "iana", + "extensions": ["wmlc"] + }, + "application/vnd.wap.wmlscriptc": { + "source": "iana", + "extensions": ["wmlsc"] + }, + "application/vnd.webturbo": { + "source": "iana", + "extensions": ["wtb"] + }, + "application/vnd.wfa.p2p": { + "source": "iana" + }, + "application/vnd.wfa.wsc": { + "source": "iana" + }, + "application/vnd.windows.devicepairing": { + "source": "iana" + }, + "application/vnd.wmc": { + "source": "iana" + }, + "application/vnd.wmf.bootstrap": { + "source": "iana" + }, + "application/vnd.wolfram.mathematica": { + "source": "iana" + }, + "application/vnd.wolfram.mathematica.package": { + "source": "iana" + }, + "application/vnd.wolfram.player": { + "source": "iana", + "extensions": ["nbp"] + }, + "application/vnd.wordperfect": { + "source": "iana", + "extensions": ["wpd"] + }, + "application/vnd.wqd": { + "source": "iana", + "extensions": ["wqd"] + }, + "application/vnd.wrq-hp3000-labelled": { + "source": "iana" + }, + "application/vnd.wt.stf": { + "source": "iana", + "extensions": ["stf"] + }, + "application/vnd.wv.csp+wbxml": { + "source": "iana" + }, + "application/vnd.wv.csp+xml": { + "source": "iana" + }, + "application/vnd.wv.ssp+xml": { + "source": "iana" + }, + "application/vnd.xacml+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.xara": { + "source": "iana", + "extensions": ["xar"] + }, + "application/vnd.xfdl": { + "source": "iana", + "extensions": ["xfdl"] + }, + "application/vnd.xfdl.webform": { + "source": "iana" + }, + "application/vnd.xmi+xml": { + "source": "iana" + }, + "application/vnd.xmpie.cpkg": { + "source": "iana" + }, + "application/vnd.xmpie.dpkg": { + "source": "iana" + }, + "application/vnd.xmpie.plan": { + "source": "iana" + }, + "application/vnd.xmpie.ppkg": { + "source": "iana" + }, + "application/vnd.xmpie.xlim": { + "source": "iana" + }, + "application/vnd.yamaha.hv-dic": { + "source": "iana", + "extensions": ["hvd"] + }, + "application/vnd.yamaha.hv-script": { + "source": "iana", + "extensions": ["hvs"] + }, + "application/vnd.yamaha.hv-voice": { + "source": "iana", + "extensions": ["hvp"] + }, + "application/vnd.yamaha.openscoreformat": { + "source": "iana", + "extensions": ["osf"] + }, + "application/vnd.yamaha.openscoreformat.osfpvg+xml": { + "source": "iana", + "extensions": ["osfpvg"] + }, + "application/vnd.yamaha.remote-setup": { + "source": "iana" + }, + "application/vnd.yamaha.smaf-audio": { + "source": "iana", + "extensions": ["saf"] + }, + "application/vnd.yamaha.smaf-phrase": { + "source": "iana", + "extensions": ["spf"] + }, + "application/vnd.yamaha.through-ngn": { + "source": "iana" + }, + "application/vnd.yamaha.tunnel-udpencap": { + "source": "iana" + }, + "application/vnd.yaoweme": { + "source": "iana" + }, + "application/vnd.yellowriver-custom-menu": { + "source": "iana", + "extensions": ["cmp"] + }, + "application/vnd.zul": { + "source": "iana", + "extensions": ["zir","zirz"] + }, + "application/vnd.zzazz.deck+xml": { + "source": "iana", + "extensions": ["zaz"] + }, + "application/voicexml+xml": { + "source": "iana", + "extensions": ["vxml"] + }, + "application/vq-rtcpxr": { + "source": "iana" + }, + "application/watcherinfo+xml": { + "source": "iana" + }, + "application/whoispp-query": { + "source": "iana" + }, + "application/whoispp-response": { + "source": "iana" + }, + "application/widget": { + "source": "iana", + "extensions": ["wgt"] + }, + "application/winhlp": { + "source": "apache", + "extensions": ["hlp"] + }, + "application/wita": { + "source": "iana" + }, + "application/wordperfect5.1": { + "source": "iana" + }, + "application/wsdl+xml": { + "source": "iana", + "extensions": ["wsdl"] + }, + "application/wspolicy+xml": { + "source": "iana", + "extensions": ["wspolicy"] + }, + "application/x-7z-compressed": { + "source": "apache", + "compressible": false, + "extensions": ["7z"] + }, + "application/x-abiword": { + "source": "apache", + "extensions": ["abw"] + }, + "application/x-ace-compressed": { + "source": "apache", + "extensions": ["ace"] + }, + "application/x-amf": { + "source": "apache" + }, + "application/x-apple-diskimage": { + "source": "apache", + "extensions": ["dmg"] + }, + "application/x-authorware-bin": { + "source": "apache", + "extensions": ["aab","x32","u32","vox"] + }, + "application/x-authorware-map": { + "source": "apache", + "extensions": ["aam"] + }, + "application/x-authorware-seg": { + "source": "apache", + "extensions": ["aas"] + }, + "application/x-bcpio": { + "source": "apache", + "extensions": ["bcpio"] + }, + "application/x-bdoc": { + "compressible": false, + "extensions": ["bdoc"] + }, + "application/x-bittorrent": { + "source": "apache", + "extensions": ["torrent"] + }, + "application/x-blorb": { + "source": "apache", + "extensions": ["blb","blorb"] + }, + "application/x-bzip": { + "source": "apache", + "compressible": false, + "extensions": ["bz"] + }, + "application/x-bzip2": { + "source": "apache", + "compressible": false, + "extensions": ["bz2","boz"] + }, + "application/x-cbr": { + "source": "apache", + "extensions": ["cbr","cba","cbt","cbz","cb7"] + }, + "application/x-cdlink": { + "source": "apache", + "extensions": ["vcd"] + }, + "application/x-cfs-compressed": { + "source": "apache", + "extensions": ["cfs"] + }, + "application/x-chat": { + "source": "apache", + "extensions": ["chat"] + }, + "application/x-chess-pgn": { + "source": "apache", + "extensions": ["pgn"] + }, + "application/x-chrome-extension": { + "extensions": ["crx"] + }, + "application/x-cocoa": { + "source": "nginx", + "extensions": ["cco"] + }, + "application/x-compress": { + "source": "apache" + }, + "application/x-conference": { + "source": "apache", + "extensions": ["nsc"] + }, + "application/x-cpio": { + "source": "apache", + "extensions": ["cpio"] + }, + "application/x-csh": { + "source": "apache", + "extensions": ["csh"] + }, + "application/x-deb": { + "compressible": false + }, + "application/x-debian-package": { + "source": "apache", + "extensions": ["deb","udeb"] + }, + "application/x-dgc-compressed": { + "source": "apache", + "extensions": ["dgc"] + }, + "application/x-director": { + "source": "apache", + "extensions": ["dir","dcr","dxr","cst","cct","cxt","w3d","fgd","swa"] + }, + "application/x-doom": { + "source": "apache", + "extensions": ["wad"] + }, + "application/x-dtbncx+xml": { + "source": "apache", + "extensions": ["ncx"] + }, + "application/x-dtbook+xml": { + "source": "apache", + "extensions": ["dtb"] + }, + "application/x-dtbresource+xml": { + "source": "apache", + "extensions": ["res"] + }, + "application/x-dvi": { + "source": "apache", + "compressible": false, + "extensions": ["dvi"] + }, + "application/x-envoy": { + "source": "apache", + "extensions": ["evy"] + }, + "application/x-eva": { + "source": "apache", + "extensions": ["eva"] + }, + "application/x-font-bdf": { + "source": "apache", + "extensions": ["bdf"] + }, + "application/x-font-dos": { + "source": "apache" + }, + "application/x-font-framemaker": { + "source": "apache" + }, + "application/x-font-ghostscript": { + "source": "apache", + "extensions": ["gsf"] + }, + "application/x-font-libgrx": { + "source": "apache" + }, + "application/x-font-linux-psf": { + "source": "apache", + "extensions": ["psf"] + }, + "application/x-font-otf": { + "source": "apache", + "compressible": true, + "extensions": ["otf"] + }, + "application/x-font-pcf": { + "source": "apache", + "extensions": ["pcf"] + }, + "application/x-font-snf": { + "source": "apache", + "extensions": ["snf"] + }, + "application/x-font-speedo": { + "source": "apache" + }, + "application/x-font-sunos-news": { + "source": "apache" + }, + "application/x-font-ttf": { + "source": "apache", + "compressible": true, + "extensions": ["ttf","ttc"] + }, + "application/x-font-type1": { + "source": "apache", + "extensions": ["pfa","pfb","pfm","afm"] + }, + "application/x-font-vfont": { + "source": "apache" + }, + "application/x-freearc": { + "source": "apache", + "extensions": ["arc"] + }, + "application/x-futuresplash": { + "source": "apache", + "extensions": ["spl"] + }, + "application/x-gca-compressed": { + "source": "apache", + "extensions": ["gca"] + }, + "application/x-glulx": { + "source": "apache", + "extensions": ["ulx"] + }, + "application/x-gnumeric": { + "source": "apache", + "extensions": ["gnumeric"] + }, + "application/x-gramps-xml": { + "source": "apache", + "extensions": ["gramps"] + }, + "application/x-gtar": { + "source": "apache", + "extensions": ["gtar"] + }, + "application/x-gzip": { + "source": "apache" + }, + "application/x-hdf": { + "source": "apache", + "extensions": ["hdf"] + }, + "application/x-httpd-php": { + "compressible": true, + "extensions": ["php"] + }, + "application/x-install-instructions": { + "source": "apache", + "extensions": ["install"] + }, + "application/x-iso9660-image": { + "source": "apache", + "extensions": ["iso"] + }, + "application/x-java-archive-diff": { + "source": "nginx", + "extensions": ["jardiff"] + }, + "application/x-java-jnlp-file": { + "source": "apache", + "compressible": false, + "extensions": ["jnlp"] + }, + "application/x-javascript": { + "compressible": true + }, + "application/x-latex": { + "source": "apache", + "compressible": false, + "extensions": ["latex"] + }, + "application/x-lua-bytecode": { + "extensions": ["luac"] + }, + "application/x-lzh-compressed": { + "source": "apache", + "extensions": ["lzh","lha"] + }, + "application/x-makeself": { + "source": "nginx", + "extensions": ["run"] + }, + "application/x-mie": { + "source": "apache", + "extensions": ["mie"] + }, + "application/x-mobipocket-ebook": { + "source": "apache", + "extensions": ["prc","mobi"] + }, + "application/x-mpegurl": { + "compressible": false + }, + "application/x-ms-application": { + "source": "apache", + "extensions": ["application"] + }, + "application/x-ms-shortcut": { + "source": "apache", + "extensions": ["lnk"] + }, + "application/x-ms-wmd": { + "source": "apache", + "extensions": ["wmd"] + }, + "application/x-ms-wmz": { + "source": "apache", + "extensions": ["wmz"] + }, + "application/x-ms-xbap": { + "source": "apache", + "extensions": ["xbap"] + }, + "application/x-msaccess": { + "source": "apache", + "extensions": ["mdb"] + }, + "application/x-msbinder": { + "source": "apache", + "extensions": ["obd"] + }, + "application/x-mscardfile": { + "source": "apache", + "extensions": ["crd"] + }, + "application/x-msclip": { + "source": "apache", + "extensions": ["clp"] + }, + "application/x-msdos-program": { + "extensions": ["exe"] + }, + "application/x-msdownload": { + "source": "apache", + "extensions": ["exe","dll","com","bat","msi"] + }, + "application/x-msmediaview": { + "source": "apache", + "extensions": ["mvb","m13","m14"] + }, + "application/x-msmetafile": { + "source": "apache", + "extensions": ["wmf","wmz","emf","emz"] + }, + "application/x-msmoney": { + "source": "apache", + "extensions": ["mny"] + }, + "application/x-mspublisher": { + "source": "apache", + "extensions": ["pub"] + }, + "application/x-msschedule": { + "source": "apache", + "extensions": ["scd"] + }, + "application/x-msterminal": { + "source": "apache", + "extensions": ["trm"] + }, + "application/x-mswrite": { + "source": "apache", + "extensions": ["wri"] + }, + "application/x-netcdf": { + "source": "apache", + "extensions": ["nc","cdf"] + }, + "application/x-ns-proxy-autoconfig": { + "compressible": true, + "extensions": ["pac"] + }, + "application/x-nzb": { + "source": "apache", + "extensions": ["nzb"] + }, + "application/x-perl": { + "source": "nginx", + "extensions": ["pl","pm"] + }, + "application/x-pilot": { + "source": "nginx", + "extensions": ["prc","pdb"] + }, + "application/x-pkcs12": { + "source": "apache", + "compressible": false, + "extensions": ["p12","pfx"] + }, + "application/x-pkcs7-certificates": { + "source": "apache", + "extensions": ["p7b","spc"] + }, + "application/x-pkcs7-certreqresp": { + "source": "apache", + "extensions": ["p7r"] + }, + "application/x-rar-compressed": { + "source": "apache", + "compressible": false, + "extensions": ["rar"] + }, + "application/x-redhat-package-manager": { + "source": "nginx", + "extensions": ["rpm"] + }, + "application/x-research-info-systems": { + "source": "apache", + "extensions": ["ris"] + }, + "application/x-sea": { + "source": "nginx", + "extensions": ["sea"] + }, + "application/x-sh": { + "source": "apache", + "compressible": true, + "extensions": ["sh"] + }, + "application/x-shar": { + "source": "apache", + "extensions": ["shar"] + }, + "application/x-shockwave-flash": { + "source": "apache", + "compressible": false, + "extensions": ["swf"] + }, + "application/x-silverlight-app": { + "source": "apache", + "extensions": ["xap"] + }, + "application/x-sql": { + "source": "apache", + "extensions": ["sql"] + }, + "application/x-stuffit": { + "source": "apache", + "compressible": false, + "extensions": ["sit"] + }, + "application/x-stuffitx": { + "source": "apache", + "extensions": ["sitx"] + }, + "application/x-subrip": { + "source": "apache", + "extensions": ["srt"] + }, + "application/x-sv4cpio": { + "source": "apache", + "extensions": ["sv4cpio"] + }, + "application/x-sv4crc": { + "source": "apache", + "extensions": ["sv4crc"] + }, + "application/x-t3vm-image": { + "source": "apache", + "extensions": ["t3"] + }, + "application/x-tads": { + "source": "apache", + "extensions": ["gam"] + }, + "application/x-tar": { + "source": "apache", + "compressible": true, + "extensions": ["tar"] + }, + "application/x-tcl": { + "source": "apache", + "extensions": ["tcl","tk"] + }, + "application/x-tex": { + "source": "apache", + "extensions": ["tex"] + }, + "application/x-tex-tfm": { + "source": "apache", + "extensions": ["tfm"] + }, + "application/x-texinfo": { + "source": "apache", + "extensions": ["texinfo","texi"] + }, + "application/x-tgif": { + "source": "apache", + "extensions": ["obj"] + }, + "application/x-ustar": { + "source": "apache", + "extensions": ["ustar"] + }, + "application/x-wais-source": { + "source": "apache", + "extensions": ["src"] + }, + "application/x-web-app-manifest+json": { + "compressible": true, + "extensions": ["webapp"] + }, + "application/x-www-form-urlencoded": { + "source": "iana", + "compressible": true + }, + "application/x-x509-ca-cert": { + "source": "apache", + "extensions": ["der","crt","pem"] + }, + "application/x-xfig": { + "source": "apache", + "extensions": ["fig"] + }, + "application/x-xliff+xml": { + "source": "apache", + "extensions": ["xlf"] + }, + "application/x-xpinstall": { + "source": "apache", + "compressible": false, + "extensions": ["xpi"] + }, + "application/x-xz": { + "source": "apache", + "extensions": ["xz"] + }, + "application/x-zmachine": { + "source": "apache", + "extensions": ["z1","z2","z3","z4","z5","z6","z7","z8"] + }, + "application/x400-bp": { + "source": "iana" + }, + "application/xacml+xml": { + "source": "iana" + }, + "application/xaml+xml": { + "source": "apache", + "extensions": ["xaml"] + }, + "application/xcap-att+xml": { + "source": "iana" + }, + "application/xcap-caps+xml": { + "source": "iana" + }, + "application/xcap-diff+xml": { + "source": "iana", + "extensions": ["xdf"] + }, + "application/xcap-el+xml": { + "source": "iana" + }, + "application/xcap-error+xml": { + "source": "iana" + }, + "application/xcap-ns+xml": { + "source": "iana" + }, + "application/xcon-conference-info+xml": { + "source": "iana" + }, + "application/xcon-conference-info-diff+xml": { + "source": "iana" + }, + "application/xenc+xml": { + "source": "iana", + "extensions": ["xenc"] + }, + "application/xhtml+xml": { + "source": "iana", + "compressible": true, + "extensions": ["xhtml","xht"] + }, + "application/xhtml-voice+xml": { + "source": "apache" + }, + "application/xml": { + "source": "iana", + "compressible": true, + "extensions": ["xml","xsl","xsd","rng"] + }, + "application/xml-dtd": { + "source": "iana", + "compressible": true, + "extensions": ["dtd"] + }, + "application/xml-external-parsed-entity": { + "source": "iana" + }, + "application/xml-patch+xml": { + "source": "iana" + }, + "application/xmpp+xml": { + "source": "iana" + }, + "application/xop+xml": { + "source": "iana", + "compressible": true, + "extensions": ["xop"] + }, + "application/xproc+xml": { + "source": "apache", + "extensions": ["xpl"] + }, + "application/xslt+xml": { + "source": "iana", + "extensions": ["xslt"] + }, + "application/xspf+xml": { + "source": "apache", + "extensions": ["xspf"] + }, + "application/xv+xml": { + "source": "iana", + "extensions": ["mxml","xhvml","xvml","xvm"] + }, + "application/yang": { + "source": "iana", + "extensions": ["yang"] + }, + "application/yin+xml": { + "source": "iana", + "extensions": ["yin"] + }, + "application/zip": { + "source": "iana", + "compressible": false, + "extensions": ["zip"] + }, + "application/zlib": { + "source": "iana" + }, + "audio/1d-interleaved-parityfec": { + "source": "iana" + }, + "audio/32kadpcm": { + "source": "iana" + }, + "audio/3gpp": { + "source": "iana", + "compressible": false, + "extensions": ["3gpp"] + }, + "audio/3gpp2": { + "source": "iana" + }, + "audio/ac3": { + "source": "iana" + }, + "audio/adpcm": { + "source": "apache", + "extensions": ["adp"] + }, + "audio/amr": { + "source": "iana" + }, + "audio/amr-wb": { + "source": "iana" + }, + "audio/amr-wb+": { + "source": "iana" + }, + "audio/aptx": { + "source": "iana" + }, + "audio/asc": { + "source": "iana" + }, + "audio/atrac-advanced-lossless": { + "source": "iana" + }, + "audio/atrac-x": { + "source": "iana" + }, + "audio/atrac3": { + "source": "iana" + }, + "audio/basic": { + "source": "iana", + "compressible": false, + "extensions": ["au","snd"] + }, + "audio/bv16": { + "source": "iana" + }, + "audio/bv32": { + "source": "iana" + }, + "audio/clearmode": { + "source": "iana" + }, + "audio/cn": { + "source": "iana" + }, + "audio/dat12": { + "source": "iana" + }, + "audio/dls": { + "source": "iana" + }, + "audio/dsr-es201108": { + "source": "iana" + }, + "audio/dsr-es202050": { + "source": "iana" + }, + "audio/dsr-es202211": { + "source": "iana" + }, + "audio/dsr-es202212": { + "source": "iana" + }, + "audio/dv": { + "source": "iana" + }, + "audio/dvi4": { + "source": "iana" + }, + "audio/eac3": { + "source": "iana" + }, + "audio/encaprtp": { + "source": "iana" + }, + "audio/evrc": { + "source": "iana" + }, + "audio/evrc-qcp": { + "source": "iana" + }, + "audio/evrc0": { + "source": "iana" + }, + "audio/evrc1": { + "source": "iana" + }, + "audio/evrcb": { + "source": "iana" + }, + "audio/evrcb0": { + "source": "iana" + }, + "audio/evrcb1": { + "source": "iana" + }, + "audio/evrcnw": { + "source": "iana" + }, + "audio/evrcnw0": { + "source": "iana" + }, + "audio/evrcnw1": { + "source": "iana" + }, + "audio/evrcwb": { + "source": "iana" + }, + "audio/evrcwb0": { + "source": "iana" + }, + "audio/evrcwb1": { + "source": "iana" + }, + "audio/evs": { + "source": "iana" + }, + "audio/fwdred": { + "source": "iana" + }, + "audio/g711-0": { + "source": "iana" + }, + "audio/g719": { + "source": "iana" + }, + "audio/g722": { + "source": "iana" + }, + "audio/g7221": { + "source": "iana" + }, + "audio/g723": { + "source": "iana" + }, + "audio/g726-16": { + "source": "iana" + }, + "audio/g726-24": { + "source": "iana" + }, + "audio/g726-32": { + "source": "iana" + }, + "audio/g726-40": { + "source": "iana" + }, + "audio/g728": { + "source": "iana" + }, + "audio/g729": { + "source": "iana" + }, + "audio/g7291": { + "source": "iana" + }, + "audio/g729d": { + "source": "iana" + }, + "audio/g729e": { + "source": "iana" + }, + "audio/gsm": { + "source": "iana" + }, + "audio/gsm-efr": { + "source": "iana" + }, + "audio/gsm-hr-08": { + "source": "iana" + }, + "audio/ilbc": { + "source": "iana" + }, + "audio/ip-mr_v2.5": { + "source": "iana" + }, + "audio/isac": { + "source": "apache" + }, + "audio/l16": { + "source": "iana" + }, + "audio/l20": { + "source": "iana" + }, + "audio/l24": { + "source": "iana", + "compressible": false + }, + "audio/l8": { + "source": "iana" + }, + "audio/lpc": { + "source": "iana" + }, + "audio/midi": { + "source": "apache", + "extensions": ["mid","midi","kar","rmi"] + }, + "audio/mobile-xmf": { + "source": "iana" + }, + "audio/mp3": { + "compressible": false, + "extensions": ["mp3"] + }, + "audio/mp4": { + "source": "iana", + "compressible": false, + "extensions": ["m4a","mp4a"] + }, + "audio/mp4a-latm": { + "source": "iana" + }, + "audio/mpa": { + "source": "iana" + }, + "audio/mpa-robust": { + "source": "iana" + }, + "audio/mpeg": { + "source": "iana", + "compressible": false, + "extensions": ["mpga","mp2","mp2a","mp3","m2a","m3a"] + }, + "audio/mpeg4-generic": { + "source": "iana" + }, + "audio/musepack": { + "source": "apache" + }, + "audio/ogg": { + "source": "iana", + "compressible": false, + "extensions": ["oga","ogg","spx"] + }, + "audio/opus": { + "source": "iana" + }, + "audio/parityfec": { + "source": "iana" + }, + "audio/pcma": { + "source": "iana" + }, + "audio/pcma-wb": { + "source": "iana" + }, + "audio/pcmu": { + "source": "iana" + }, + "audio/pcmu-wb": { + "source": "iana" + }, + "audio/prs.sid": { + "source": "iana" + }, + "audio/qcelp": { + "source": "iana" + }, + "audio/raptorfec": { + "source": "iana" + }, + "audio/red": { + "source": "iana" + }, + "audio/rtp-enc-aescm128": { + "source": "iana" + }, + "audio/rtp-midi": { + "source": "iana" + }, + "audio/rtploopback": { + "source": "iana" + }, + "audio/rtx": { + "source": "iana" + }, + "audio/s3m": { + "source": "apache", + "extensions": ["s3m"] + }, + "audio/silk": { + "source": "apache", + "extensions": ["sil"] + }, + "audio/smv": { + "source": "iana" + }, + "audio/smv-qcp": { + "source": "iana" + }, + "audio/smv0": { + "source": "iana" + }, + "audio/sp-midi": { + "source": "iana" + }, + "audio/speex": { + "source": "iana" + }, + "audio/t140c": { + "source": "iana" + }, + "audio/t38": { + "source": "iana" + }, + "audio/telephone-event": { + "source": "iana" + }, + "audio/tone": { + "source": "iana" + }, + "audio/uemclip": { + "source": "iana" + }, + "audio/ulpfec": { + "source": "iana" + }, + "audio/vdvi": { + "source": "iana" + }, + "audio/vmr-wb": { + "source": "iana" + }, + "audio/vnd.3gpp.iufp": { + "source": "iana" + }, + "audio/vnd.4sb": { + "source": "iana" + }, + "audio/vnd.audiokoz": { + "source": "iana" + }, + "audio/vnd.celp": { + "source": "iana" + }, + "audio/vnd.cisco.nse": { + "source": "iana" + }, + "audio/vnd.cmles.radio-events": { + "source": "iana" + }, + "audio/vnd.cns.anp1": { + "source": "iana" + }, + "audio/vnd.cns.inf1": { + "source": "iana" + }, + "audio/vnd.dece.audio": { + "source": "iana", + "extensions": ["uva","uvva"] + }, + "audio/vnd.digital-winds": { + "source": "iana", + "extensions": ["eol"] + }, + "audio/vnd.dlna.adts": { + "source": "iana" + }, + "audio/vnd.dolby.heaac.1": { + "source": "iana" + }, + "audio/vnd.dolby.heaac.2": { + "source": "iana" + }, + "audio/vnd.dolby.mlp": { + "source": "iana" + }, + "audio/vnd.dolby.mps": { + "source": "iana" + }, + "audio/vnd.dolby.pl2": { + "source": "iana" + }, + "audio/vnd.dolby.pl2x": { + "source": "iana" + }, + "audio/vnd.dolby.pl2z": { + "source": "iana" + }, + "audio/vnd.dolby.pulse.1": { + "source": "iana" + }, + "audio/vnd.dra": { + "source": "iana", + "extensions": ["dra"] + }, + "audio/vnd.dts": { + "source": "iana", + "extensions": ["dts"] + }, + "audio/vnd.dts.hd": { + "source": "iana", + "extensions": ["dtshd"] + }, + "audio/vnd.dvb.file": { + "source": "iana" + }, + "audio/vnd.everad.plj": { + "source": "iana" + }, + "audio/vnd.hns.audio": { + "source": "iana" + }, + "audio/vnd.lucent.voice": { + "source": "iana", + "extensions": ["lvp"] + }, + "audio/vnd.ms-playready.media.pya": { + "source": "iana", + "extensions": ["pya"] + }, + "audio/vnd.nokia.mobile-xmf": { + "source": "iana" + }, + "audio/vnd.nortel.vbk": { + "source": "iana" + }, + "audio/vnd.nuera.ecelp4800": { + "source": "iana", + "extensions": ["ecelp4800"] + }, + "audio/vnd.nuera.ecelp7470": { + "source": "iana", + "extensions": ["ecelp7470"] + }, + "audio/vnd.nuera.ecelp9600": { + "source": "iana", + "extensions": ["ecelp9600"] + }, + "audio/vnd.octel.sbc": { + "source": "iana" + }, + "audio/vnd.qcelp": { + "source": "iana" + }, + "audio/vnd.rhetorex.32kadpcm": { + "source": "iana" + }, + "audio/vnd.rip": { + "source": "iana", + "extensions": ["rip"] + }, + "audio/vnd.rn-realaudio": { + "compressible": false + }, + "audio/vnd.sealedmedia.softseal.mpeg": { + "source": "iana" + }, + "audio/vnd.vmx.cvsd": { + "source": "iana" + }, + "audio/vnd.wave": { + "compressible": false + }, + "audio/vorbis": { + "source": "iana", + "compressible": false + }, + "audio/vorbis-config": { + "source": "iana" + }, + "audio/wav": { + "compressible": false, + "extensions": ["wav"] + }, + "audio/wave": { + "compressible": false, + "extensions": ["wav"] + }, + "audio/webm": { + "source": "apache", + "compressible": false, + "extensions": ["weba"] + }, + "audio/x-aac": { + "source": "apache", + "compressible": false, + "extensions": ["aac"] + }, + "audio/x-aiff": { + "source": "apache", + "extensions": ["aif","aiff","aifc"] + }, + "audio/x-caf": { + "source": "apache", + "compressible": false, + "extensions": ["caf"] + }, + "audio/x-flac": { + "source": "apache", + "extensions": ["flac"] + }, + "audio/x-m4a": { + "source": "nginx", + "extensions": ["m4a"] + }, + "audio/x-matroska": { + "source": "apache", + "extensions": ["mka"] + }, + "audio/x-mpegurl": { + "source": "apache", + "extensions": ["m3u"] + }, + "audio/x-ms-wax": { + "source": "apache", + "extensions": ["wax"] + }, + "audio/x-ms-wma": { + "source": "apache", + "extensions": ["wma"] + }, + "audio/x-pn-realaudio": { + "source": "apache", + "extensions": ["ram","ra"] + }, + "audio/x-pn-realaudio-plugin": { + "source": "apache", + "extensions": ["rmp"] + }, + "audio/x-realaudio": { + "source": "nginx", + "extensions": ["ra"] + }, + "audio/x-tta": { + "source": "apache" + }, + "audio/x-wav": { + "source": "apache", + "extensions": ["wav"] + }, + "audio/xm": { + "source": "apache", + "extensions": ["xm"] + }, + "chemical/x-cdx": { + "source": "apache", + "extensions": ["cdx"] + }, + "chemical/x-cif": { + "source": "apache", + "extensions": ["cif"] + }, + "chemical/x-cmdf": { + "source": "apache", + "extensions": ["cmdf"] + }, + "chemical/x-cml": { + "source": "apache", + "extensions": ["cml"] + }, + "chemical/x-csml": { + "source": "apache", + "extensions": ["csml"] + }, + "chemical/x-pdb": { + "source": "apache" + }, + "chemical/x-xyz": { + "source": "apache", + "extensions": ["xyz"] + }, + "font/opentype": { + "compressible": true, + "extensions": ["otf"] + }, + "image/bmp": { + "source": "iana", + "compressible": true, + "extensions": ["bmp"] + }, + "image/cgm": { + "source": "iana", + "extensions": ["cgm"] + }, + "image/dicom-rle": { + "source": "iana" + }, + "image/emf": { + "source": "iana" + }, + "image/fits": { + "source": "iana" + }, + "image/g3fax": { + "source": "iana", + "extensions": ["g3"] + }, + "image/gif": { + "source": "iana", + "compressible": false, + "extensions": ["gif"] + }, + "image/ief": { + "source": "iana", + "extensions": ["ief"] + }, + "image/jls": { + "source": "iana" + }, + "image/jp2": { + "source": "iana" + }, + "image/jpeg": { + "source": "iana", + "compressible": false, + "extensions": ["jpeg","jpg","jpe"] + }, + "image/jpm": { + "source": "iana" + }, + "image/jpx": { + "source": "iana" + }, + "image/ktx": { + "source": "iana", + "extensions": ["ktx"] + }, + "image/naplps": { + "source": "iana" + }, + "image/pjpeg": { + "compressible": false + }, + "image/png": { + "source": "iana", + "compressible": false, + "extensions": ["png"] + }, + "image/prs.btif": { + "source": "iana", + "extensions": ["btif"] + }, + "image/prs.pti": { + "source": "iana" + }, + "image/pwg-raster": { + "source": "iana" + }, + "image/sgi": { + "source": "apache", + "extensions": ["sgi"] + }, + "image/svg+xml": { + "source": "iana", + "compressible": true, + "extensions": ["svg","svgz"] + }, + "image/t38": { + "source": "iana" + }, + "image/tiff": { + "source": "iana", + "compressible": false, + "extensions": ["tiff","tif"] + }, + "image/tiff-fx": { + "source": "iana" + }, + "image/vnd.adobe.photoshop": { + "source": "iana", + "compressible": true, + "extensions": ["psd"] + }, + "image/vnd.airzip.accelerator.azv": { + "source": "iana" + }, + "image/vnd.cns.inf2": { + "source": "iana" + }, + "image/vnd.dece.graphic": { + "source": "iana", + "extensions": ["uvi","uvvi","uvg","uvvg"] + }, + "image/vnd.djvu": { + "source": "iana", + "extensions": ["djvu","djv"] + }, + "image/vnd.dvb.subtitle": { + "source": "iana", + "extensions": ["sub"] + }, + "image/vnd.dwg": { + "source": "iana", + "extensions": ["dwg"] + }, + "image/vnd.dxf": { + "source": "iana", + "extensions": ["dxf"] + }, + "image/vnd.fastbidsheet": { + "source": "iana", + "extensions": ["fbs"] + }, + "image/vnd.fpx": { + "source": "iana", + "extensions": ["fpx"] + }, + "image/vnd.fst": { + "source": "iana", + "extensions": ["fst"] + }, + "image/vnd.fujixerox.edmics-mmr": { + "source": "iana", + "extensions": ["mmr"] + }, + "image/vnd.fujixerox.edmics-rlc": { + "source": "iana", + "extensions": ["rlc"] + }, + "image/vnd.globalgraphics.pgb": { + "source": "iana" + }, + "image/vnd.microsoft.icon": { + "source": "iana" + }, + "image/vnd.mix": { + "source": "iana" + }, + "image/vnd.mozilla.apng": { + "source": "iana" + }, + "image/vnd.ms-modi": { + "source": "iana", + "extensions": ["mdi"] + }, + "image/vnd.ms-photo": { + "source": "apache", + "extensions": ["wdp"] + }, + "image/vnd.net-fpx": { + "source": "iana", + "extensions": ["npx"] + }, + "image/vnd.radiance": { + "source": "iana" + }, + "image/vnd.sealed.png": { + "source": "iana" + }, + "image/vnd.sealedmedia.softseal.gif": { + "source": "iana" + }, + "image/vnd.sealedmedia.softseal.jpg": { + "source": "iana" + }, + "image/vnd.svf": { + "source": "iana" + }, + "image/vnd.tencent.tap": { + "source": "iana" + }, + "image/vnd.valve.source.texture": { + "source": "iana" + }, + "image/vnd.wap.wbmp": { + "source": "iana", + "extensions": ["wbmp"] + }, + "image/vnd.xiff": { + "source": "iana", + "extensions": ["xif"] + }, + "image/vnd.zbrush.pcx": { + "source": "iana" + }, + "image/webp": { + "source": "apache", + "extensions": ["webp"] + }, + "image/wmf": { + "source": "iana" + }, + "image/x-3ds": { + "source": "apache", + "extensions": ["3ds"] + }, + "image/x-cmu-raster": { + "source": "apache", + "extensions": ["ras"] + }, + "image/x-cmx": { + "source": "apache", + "extensions": ["cmx"] + }, + "image/x-freehand": { + "source": "apache", + "extensions": ["fh","fhc","fh4","fh5","fh7"] + }, + "image/x-icon": { + "source": "apache", + "compressible": true, + "extensions": ["ico"] + }, + "image/x-jng": { + "source": "nginx", + "extensions": ["jng"] + }, + "image/x-mrsid-image": { + "source": "apache", + "extensions": ["sid"] + }, + "image/x-ms-bmp": { + "source": "nginx", + "compressible": true, + "extensions": ["bmp"] + }, + "image/x-pcx": { + "source": "apache", + "extensions": ["pcx"] + }, + "image/x-pict": { + "source": "apache", + "extensions": ["pic","pct"] + }, + "image/x-portable-anymap": { + "source": "apache", + "extensions": ["pnm"] + }, + "image/x-portable-bitmap": { + "source": "apache", + "extensions": ["pbm"] + }, + "image/x-portable-graymap": { + "source": "apache", + "extensions": ["pgm"] + }, + "image/x-portable-pixmap": { + "source": "apache", + "extensions": ["ppm"] + }, + "image/x-rgb": { + "source": "apache", + "extensions": ["rgb"] + }, + "image/x-tga": { + "source": "apache", + "extensions": ["tga"] + }, + "image/x-xbitmap": { + "source": "apache", + "extensions": ["xbm"] + }, + "image/x-xcf": { + "compressible": false + }, + "image/x-xpixmap": { + "source": "apache", + "extensions": ["xpm"] + }, + "image/x-xwindowdump": { + "source": "apache", + "extensions": ["xwd"] + }, + "message/cpim": { + "source": "iana" + }, + "message/delivery-status": { + "source": "iana" + }, + "message/disposition-notification": { + "source": "iana" + }, + "message/external-body": { + "source": "iana" + }, + "message/feedback-report": { + "source": "iana" + }, + "message/global": { + "source": "iana" + }, + "message/global-delivery-status": { + "source": "iana" + }, + "message/global-disposition-notification": { + "source": "iana" + }, + "message/global-headers": { + "source": "iana" + }, + "message/http": { + "source": "iana", + "compressible": false + }, + "message/imdn+xml": { + "source": "iana", + "compressible": true + }, + "message/news": { + "source": "iana" + }, + "message/partial": { + "source": "iana", + "compressible": false + }, + "message/rfc822": { + "source": "iana", + "compressible": true, + "extensions": ["eml","mime"] + }, + "message/s-http": { + "source": "iana" + }, + "message/sip": { + "source": "iana" + }, + "message/sipfrag": { + "source": "iana" + }, + "message/tracking-status": { + "source": "iana" + }, + "message/vnd.si.simp": { + "source": "iana" + }, + "message/vnd.wfa.wsc": { + "source": "iana" + }, + "model/gltf+json": { + "source": "iana", + "compressible": true + }, + "model/iges": { + "source": "iana", + "compressible": false, + "extensions": ["igs","iges"] + }, + "model/mesh": { + "source": "iana", + "compressible": false, + "extensions": ["msh","mesh","silo"] + }, + "model/vnd.collada+xml": { + "source": "iana", + "extensions": ["dae"] + }, + "model/vnd.dwf": { + "source": "iana", + "extensions": ["dwf"] + }, + "model/vnd.flatland.3dml": { + "source": "iana" + }, + "model/vnd.gdl": { + "source": "iana", + "extensions": ["gdl"] + }, + "model/vnd.gs-gdl": { + "source": "apache" + }, + "model/vnd.gs.gdl": { + "source": "iana" + }, + "model/vnd.gtw": { + "source": "iana", + "extensions": ["gtw"] + }, + "model/vnd.moml+xml": { + "source": "iana" + }, + "model/vnd.mts": { + "source": "iana", + "extensions": ["mts"] + }, + "model/vnd.opengex": { + "source": "iana" + }, + "model/vnd.parasolid.transmit.binary": { + "source": "iana" + }, + "model/vnd.parasolid.transmit.text": { + "source": "iana" + }, + "model/vnd.rosette.annotated-data-model": { + "source": "iana" + }, + "model/vnd.valve.source.compiled-map": { + "source": "iana" + }, + "model/vnd.vtu": { + "source": "iana", + "extensions": ["vtu"] + }, + "model/vrml": { + "source": "iana", + "compressible": false, + "extensions": ["wrl","vrml"] + }, + "model/x3d+binary": { + "source": "apache", + "compressible": false, + "extensions": ["x3db","x3dbz"] + }, + "model/x3d+fastinfoset": { + "source": "iana" + }, + "model/x3d+vrml": { + "source": "apache", + "compressible": false, + "extensions": ["x3dv","x3dvz"] + }, + "model/x3d+xml": { + "source": "iana", + "compressible": true, + "extensions": ["x3d","x3dz"] + }, + "model/x3d-vrml": { + "source": "iana" + }, + "multipart/alternative": { + "source": "iana", + "compressible": false + }, + "multipart/appledouble": { + "source": "iana" + }, + "multipart/byteranges": { + "source": "iana" + }, + "multipart/digest": { + "source": "iana" + }, + "multipart/encrypted": { + "source": "iana", + "compressible": false + }, + "multipart/form-data": { + "source": "iana", + "compressible": false + }, + "multipart/header-set": { + "source": "iana" + }, + "multipart/mixed": { + "source": "iana", + "compressible": false + }, + "multipart/parallel": { + "source": "iana" + }, + "multipart/related": { + "source": "iana", + "compressible": false + }, + "multipart/report": { + "source": "iana" + }, + "multipart/signed": { + "source": "iana", + "compressible": false + }, + "multipart/voice-message": { + "source": "iana" + }, + "multipart/x-mixed-replace": { + "source": "iana" + }, + "text/1d-interleaved-parityfec": { + "source": "iana" + }, + "text/cache-manifest": { + "source": "iana", + "compressible": true, + "extensions": ["appcache","manifest"] + }, + "text/calendar": { + "source": "iana", + "extensions": ["ics","ifb"] + }, + "text/calender": { + "compressible": true + }, + "text/cmd": { + "compressible": true + }, + "text/coffeescript": { + "extensions": ["coffee","litcoffee"] + }, + "text/css": { + "source": "iana", + "compressible": true, + "extensions": ["css"] + }, + "text/csv": { + "source": "iana", + "compressible": true, + "extensions": ["csv"] + }, + "text/csv-schema": { + "source": "iana" + }, + "text/directory": { + "source": "iana" + }, + "text/dns": { + "source": "iana" + }, + "text/ecmascript": { + "source": "iana" + }, + "text/encaprtp": { + "source": "iana" + }, + "text/enriched": { + "source": "iana" + }, + "text/fwdred": { + "source": "iana" + }, + "text/grammar-ref-list": { + "source": "iana" + }, + "text/hjson": { + "extensions": ["hjson"] + }, + "text/html": { + "source": "iana", + "compressible": true, + "extensions": ["html","htm","shtml"] + }, + "text/jade": { + "extensions": ["jade"] + }, + "text/javascript": { + "source": "iana", + "compressible": true + }, + "text/jcr-cnd": { + "source": "iana" + }, + "text/jsx": { + "compressible": true, + "extensions": ["jsx"] + }, + "text/less": { + "extensions": ["less"] + }, + "text/markdown": { + "source": "iana" + }, + "text/mathml": { + "source": "nginx", + "extensions": ["mml"] + }, + "text/mizar": { + "source": "iana" + }, + "text/n3": { + "source": "iana", + "compressible": true, + "extensions": ["n3"] + }, + "text/parameters": { + "source": "iana" + }, + "text/parityfec": { + "source": "iana" + }, + "text/plain": { + "source": "iana", + "compressible": true, + "extensions": ["txt","text","conf","def","list","log","in","ini"] + }, + "text/provenance-notation": { + "source": "iana" + }, + "text/prs.fallenstein.rst": { + "source": "iana" + }, + "text/prs.lines.tag": { + "source": "iana", + "extensions": ["dsc"] + }, + "text/prs.prop.logic": { + "source": "iana" + }, + "text/raptorfec": { + "source": "iana" + }, + "text/red": { + "source": "iana" + }, + "text/rfc822-headers": { + "source": "iana" + }, + "text/richtext": { + "source": "iana", + "compressible": true, + "extensions": ["rtx"] + }, + "text/rtf": { + "source": "iana", + "compressible": true, + "extensions": ["rtf"] + }, + "text/rtp-enc-aescm128": { + "source": "iana" + }, + "text/rtploopback": { + "source": "iana" + }, + "text/rtx": { + "source": "iana" + }, + "text/sgml": { + "source": "iana", + "extensions": ["sgml","sgm"] + }, + "text/slim": { + "extensions": ["slim","slm"] + }, + "text/stylus": { + "extensions": ["stylus","styl"] + }, + "text/t140": { + "source": "iana" + }, + "text/tab-separated-values": { + "source": "iana", + "compressible": true, + "extensions": ["tsv"] + }, + "text/troff": { + "source": "iana", + "extensions": ["t","tr","roff","man","me","ms"] + }, + "text/turtle": { + "source": "iana", + "extensions": ["ttl"] + }, + "text/ulpfec": { + "source": "iana" + }, + "text/uri-list": { + "source": "iana", + "compressible": true, + "extensions": ["uri","uris","urls"] + }, + "text/vcard": { + "source": "iana", + "compressible": true, + "extensions": ["vcard"] + }, + "text/vnd.a": { + "source": "iana" + }, + "text/vnd.abc": { + "source": "iana" + }, + "text/vnd.ascii-art": { + "source": "iana" + }, + "text/vnd.curl": { + "source": "iana", + "extensions": ["curl"] + }, + "text/vnd.curl.dcurl": { + "source": "apache", + "extensions": ["dcurl"] + }, + "text/vnd.curl.mcurl": { + "source": "apache", + "extensions": ["mcurl"] + }, + "text/vnd.curl.scurl": { + "source": "apache", + "extensions": ["scurl"] + }, + "text/vnd.debian.copyright": { + "source": "iana" + }, + "text/vnd.dmclientscript": { + "source": "iana" + }, + "text/vnd.dvb.subtitle": { + "source": "iana", + "extensions": ["sub"] + }, + "text/vnd.esmertec.theme-descriptor": { + "source": "iana" + }, + "text/vnd.fly": { + "source": "iana", + "extensions": ["fly"] + }, + "text/vnd.fmi.flexstor": { + "source": "iana", + "extensions": ["flx"] + }, + "text/vnd.graphviz": { + "source": "iana", + "extensions": ["gv"] + }, + "text/vnd.in3d.3dml": { + "source": "iana", + "extensions": ["3dml"] + }, + "text/vnd.in3d.spot": { + "source": "iana", + "extensions": ["spot"] + }, + "text/vnd.iptc.newsml": { + "source": "iana" + }, + "text/vnd.iptc.nitf": { + "source": "iana" + }, + "text/vnd.latex-z": { + "source": "iana" + }, + "text/vnd.motorola.reflex": { + "source": "iana" + }, + "text/vnd.ms-mediapackage": { + "source": "iana" + }, + "text/vnd.net2phone.commcenter.command": { + "source": "iana" + }, + "text/vnd.radisys.msml-basic-layout": { + "source": "iana" + }, + "text/vnd.si.uricatalogue": { + "source": "iana" + }, + "text/vnd.sun.j2me.app-descriptor": { + "source": "iana", + "extensions": ["jad"] + }, + "text/vnd.trolltech.linguist": { + "source": "iana" + }, + "text/vnd.wap.si": { + "source": "iana" + }, + "text/vnd.wap.sl": { + "source": "iana" + }, + "text/vnd.wap.wml": { + "source": "iana", + "extensions": ["wml"] + }, + "text/vnd.wap.wmlscript": { + "source": "iana", + "extensions": ["wmls"] + }, + "text/vtt": { + "charset": "UTF-8", + "compressible": true, + "extensions": ["vtt"] + }, + "text/x-asm": { + "source": "apache", + "extensions": ["s","asm"] + }, + "text/x-c": { + "source": "apache", + "extensions": ["c","cc","cxx","cpp","h","hh","dic"] + }, + "text/x-component": { + "source": "nginx", + "extensions": ["htc"] + }, + "text/x-fortran": { + "source": "apache", + "extensions": ["f","for","f77","f90"] + }, + "text/x-gwt-rpc": { + "compressible": true + }, + "text/x-handlebars-template": { + "extensions": ["hbs"] + }, + "text/x-java-source": { + "source": "apache", + "extensions": ["java"] + }, + "text/x-jquery-tmpl": { + "compressible": true + }, + "text/x-lua": { + "extensions": ["lua"] + }, + "text/x-markdown": { + "compressible": true, + "extensions": ["markdown","md","mkd"] + }, + "text/x-nfo": { + "source": "apache", + "extensions": ["nfo"] + }, + "text/x-opml": { + "source": "apache", + "extensions": ["opml"] + }, + "text/x-pascal": { + "source": "apache", + "extensions": ["p","pas"] + }, + "text/x-processing": { + "compressible": true, + "extensions": ["pde"] + }, + "text/x-sass": { + "extensions": ["sass"] + }, + "text/x-scss": { + "extensions": ["scss"] + }, + "text/x-setext": { + "source": "apache", + "extensions": ["etx"] + }, + "text/x-sfv": { + "source": "apache", + "extensions": ["sfv"] + }, + "text/x-suse-ymp": { + "compressible": true, + "extensions": ["ymp"] + }, + "text/x-uuencode": { + "source": "apache", + "extensions": ["uu"] + }, + "text/x-vcalendar": { + "source": "apache", + "extensions": ["vcs"] + }, + "text/x-vcard": { + "source": "apache", + "extensions": ["vcf"] + }, + "text/xml": { + "source": "iana", + "compressible": true, + "extensions": ["xml"] + }, + "text/xml-external-parsed-entity": { + "source": "iana" + }, + "text/yaml": { + "extensions": ["yaml","yml"] + }, + "video/1d-interleaved-parityfec": { + "source": "apache" + }, + "video/3gpp": { + "source": "apache", + "extensions": ["3gp","3gpp"] + }, + "video/3gpp-tt": { + "source": "apache" + }, + "video/3gpp2": { + "source": "apache", + "extensions": ["3g2"] + }, + "video/bmpeg": { + "source": "apache" + }, + "video/bt656": { + "source": "apache" + }, + "video/celb": { + "source": "apache" + }, + "video/dv": { + "source": "apache" + }, + "video/encaprtp": { + "source": "apache" + }, + "video/h261": { + "source": "apache", + "extensions": ["h261"] + }, + "video/h263": { + "source": "apache", + "extensions": ["h263"] + }, + "video/h263-1998": { + "source": "apache" + }, + "video/h263-2000": { + "source": "apache" + }, + "video/h264": { + "source": "apache", + "extensions": ["h264"] + }, + "video/h264-rcdo": { + "source": "apache" + }, + "video/h264-svc": { + "source": "apache" + }, + "video/h265": { + "source": "apache" + }, + "video/iso.segment": { + "source": "apache" + }, + "video/jpeg": { + "source": "apache", + "extensions": ["jpgv"] + }, + "video/jpeg2000": { + "source": "apache" + }, + "video/jpm": { + "source": "apache", + "extensions": ["jpm","jpgm"] + }, + "video/mj2": { + "source": "apache", + "extensions": ["mj2","mjp2"] + }, + "video/mp1s": { + "source": "apache" + }, + "video/mp2p": { + "source": "apache" + }, + "video/mp2t": { + "source": "apache", + "extensions": ["ts"] + }, + "video/mp4": { + "source": "apache", + "compressible": false, + "extensions": ["mp4","mp4v","mpg4"] + }, + "video/mp4v-es": { + "source": "apache" + }, + "video/mpeg": { + "source": "apache", + "compressible": false, + "extensions": ["mpeg","mpg","mpe","m1v","m2v"] + }, + "video/mpeg4-generic": { + "source": "apache" + }, + "video/mpv": { + "source": "apache" + }, + "video/nv": { + "source": "apache" + }, + "video/ogg": { + "source": "apache", + "compressible": false, + "extensions": ["ogv"] + }, + "video/parityfec": { + "source": "apache" + }, + "video/pointer": { + "source": "apache" + }, + "video/quicktime": { + "source": "apache", + "compressible": false, + "extensions": ["qt","mov"] + }, + "video/raptorfec": { + "source": "apache" + }, + "video/raw": { + "source": "apache" + }, + "video/rtp-enc-aescm128": { + "source": "apache" + }, + "video/rtploopback": { + "source": "apache" + }, + "video/rtx": { + "source": "apache" + }, + "video/smpte292m": { + "source": "apache" + }, + "video/ulpfec": { + "source": "apache" + }, + "video/vc1": { + "source": "apache" + }, + "video/vnd.cctv": { + "source": "apache" + }, + "video/vnd.dece.hd": { + "source": "apache", + "extensions": ["uvh","uvvh"] + }, + "video/vnd.dece.mobile": { + "source": "apache", + "extensions": ["uvm","uvvm"] + }, + "video/vnd.dece.mp4": { + "source": "apache" + }, + "video/vnd.dece.pd": { + "source": "apache", + "extensions": ["uvp","uvvp"] + }, + "video/vnd.dece.sd": { + "source": "apache", + "extensions": ["uvs","uvvs"] + }, + "video/vnd.dece.video": { + "source": "apache", + "extensions": ["uvv","uvvv"] + }, + "video/vnd.directv.mpeg": { + "source": "apache" + }, + "video/vnd.directv.mpeg-tts": { + "source": "apache" + }, + "video/vnd.dlna.mpeg-tts": { + "source": "apache" + }, + "video/vnd.dvb.file": { + "source": "apache", + "extensions": ["dvb"] + }, + "video/vnd.fvt": { + "source": "apache", + "extensions": ["fvt"] + }, + "video/vnd.hns.video": { + "source": "apache" + }, + "video/vnd.iptvforum.1dparityfec-1010": { + "source": "apache" + }, + "video/vnd.iptvforum.1dparityfec-2005": { + "source": "apache" + }, + "video/vnd.iptvforum.2dparityfec-1010": { + "source": "apache" + }, + "video/vnd.iptvforum.2dparityfec-2005": { + "source": "apache" + }, + "video/vnd.iptvforum.ttsavc": { + "source": "apache" + }, + "video/vnd.iptvforum.ttsmpeg2": { + "source": "apache" + }, + "video/vnd.motorola.video": { + "source": "apache" + }, + "video/vnd.motorola.videop": { + "source": "apache" + }, + "video/vnd.mpegurl": { + "source": "apache", + "extensions": ["mxu","m4u"] + }, + "video/vnd.ms-playready.media.pyv": { + "source": "apache", + "extensions": ["pyv"] + }, + "video/vnd.nokia.interleaved-multimedia": { + "source": "apache" + }, + "video/vnd.nokia.videovoip": { + "source": "apache" + }, + "video/vnd.objectvideo": { + "source": "apache" + }, + "video/vnd.radgamettools.bink": { + "source": "apache" + }, + "video/vnd.radgamettools.smacker": { + "source": "apache" + }, + "video/vnd.sealed.mpeg1": { + "source": "apache" + }, + "video/vnd.sealed.mpeg4": { + "source": "apache" + }, + "video/vnd.sealed.swf": { + "source": "apache" + }, + "video/vnd.sealedmedia.softseal.mov": { + "source": "apache" + }, + "video/vnd.uvvu.mp4": { + "source": "apache", + "extensions": ["uvu","uvvu"] + }, + "video/vnd.vivo": { + "source": "apache", + "extensions": ["viv"] + }, + "video/vp8": { + "source": "apache" + }, + "video/webm": { + "source": "apache", + "compressible": false, + "extensions": ["webm"] + }, + "video/x-f4v": { + "source": "apache", + "extensions": ["f4v"] + }, + "video/x-fli": { + "source": "apache", + "extensions": ["fli"] + }, + "video/x-flv": { + "source": "apache", + "compressible": false, + "extensions": ["flv"] + }, + "video/x-m4v": { + "source": "apache", + "extensions": ["m4v"] + }, + "video/x-matroska": { + "source": "apache", + "compressible": false, + "extensions": ["mkv","mk3d","mks"] + }, + "video/x-mng": { + "source": "apache", + "extensions": ["mng"] + }, + "video/x-ms-asf": { + "source": "apache", + "extensions": ["asf","asx"] + }, + "video/x-ms-vob": { + "source": "apache", + "extensions": ["vob"] + }, + "video/x-ms-wm": { + "source": "apache", + "extensions": ["wm"] + }, + "video/x-ms-wmv": { + "source": "apache", + "compressible": false, + "extensions": ["wmv"] + }, + "video/x-ms-wmx": { + "source": "apache", + "extensions": ["wmx"] + }, + "video/x-ms-wvx": { + "source": "apache", + "extensions": ["wvx"] + }, + "video/x-msvideo": { + "source": "apache", + "extensions": ["avi"] + }, + "video/x-sgi-movie": { + "source": "apache", + "extensions": ["movie"] + }, + "video/x-smv": { + "source": "apache", + "extensions": ["smv"] + }, + "x-conference/x-cooltalk": { + "source": "apache", + "extensions": ["ice"] + }, + "x-shader/x-fragment": { + "compressible": true + }, + "x-shader/x-vertex": { + "compressible": true + } +} diff --git a/node_modules/body-parser/node_modules/type-is/node_modules/mime-types/node_modules/mime-db/index.js b/node_modules/body-parser/node_modules/type-is/node_modules/mime-types/node_modules/mime-db/index.js new file mode 100644 index 0000000..551031f --- /dev/null +++ b/node_modules/body-parser/node_modules/type-is/node_modules/mime-types/node_modules/mime-db/index.js @@ -0,0 +1,11 @@ +/*! + * mime-db + * Copyright(c) 2014 Jonathan Ong + * MIT Licensed + */ + +/** + * Module exports. + */ + +module.exports = require('./db.json') diff --git a/node_modules/body-parser/node_modules/type-is/node_modules/mime-types/node_modules/mime-db/package.json b/node_modules/body-parser/node_modules/type-is/node_modules/mime-types/node_modules/mime-db/package.json new file mode 100644 index 0000000..a468393 --- /dev/null +++ b/node_modules/body-parser/node_modules/type-is/node_modules/mime-types/node_modules/mime-db/package.json @@ -0,0 +1,99 @@ +{ + "name": "mime-db", + "description": "Media Type Database", + "version": "1.24.0", + "contributors": [ + { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "Jonathan Ong", + "email": "me@jongleberry.com", + "url": "http://jongleberry.com" + }, + { + "name": "Robert Kieffer", + "email": "robert@broofa.com", + "url": "http://github.com/broofa" + } + ], + "license": "MIT", + "keywords": [ + "mime", + "db", + "type", + "types", + "database", + "charset", + "charsets" + ], + "repository": { + "type": "git", + "url": "git+https://github.com/jshttp/mime-db.git" + }, + "devDependencies": { + "bluebird": "3.4.6", + "co": "4.6.0", + "cogent": "1.0.1", + "csv-parse": "1.1.7", + "gnode": "0.1.2", + "istanbul": "0.4.5", + "mocha": "1.21.5", + "raw-body": "2.1.7", + "stream-to-array": "2.3.0" + }, + "files": [ + "HISTORY.md", + "LICENSE", + "README.md", + "db.json", + "index.js" + ], + "engines": { + "node": ">= 0.6" + }, + "scripts": { + "build": "node scripts/build", + "fetch": "gnode scripts/fetch-apache && gnode scripts/fetch-iana && gnode scripts/fetch-nginx", + "test": "mocha --reporter spec --bail --check-leaks test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot --check-leaks test/", + "test-travis": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter spec --check-leaks test/", + "update": "npm run fetch && npm run build" + }, + "gitHead": "9dd00b34556a8cdd6f3385f09d4989298c4b86e1", + "bugs": { + "url": "https://github.com/jshttp/mime-db/issues" + }, + "homepage": "https://github.com/jshttp/mime-db#readme", + "_id": "mime-db@1.24.0", + "_shasum": "e2d13f939f0016c6e4e9ad25a8652f126c467f0c", + "_from": "mime-db@>=1.24.0 <1.25.0", + "_npmVersion": "2.15.9", + "_nodeVersion": "4.5.0", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "dist": { + "shasum": "e2d13f939f0016c6e4e9ad25a8652f126c467f0c", + "tarball": "https://registry.npmjs.org/mime-db/-/mime-db-1.24.0.tgz" + }, + "maintainers": [ + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "jongleberry", + "email": "jonathanrichardong@gmail.com" + } + ], + "_npmOperationalInternal": { + "host": "packages-16-east.internal.npmjs.com", + "tmp": "tmp/mime-db-1.24.0.tgz_1474198792761_0.7161959335207939" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/mime-db/-/mime-db-1.24.0.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/body-parser/node_modules/type-is/node_modules/mime-types/package.json b/node_modules/body-parser/node_modules/type-is/node_modules/mime-types/package.json new file mode 100644 index 0000000..0ca4603 --- /dev/null +++ b/node_modules/body-parser/node_modules/type-is/node_modules/mime-types/package.json @@ -0,0 +1,94 @@ +{ + "name": "mime-types", + "description": "The ultimate javascript content-type utility.", + "version": "2.1.12", + "contributors": [ + { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "Jeremiah Senkpiel", + "email": "fishrock123@rocketmail.com", + "url": "https://searchbeam.jit.su" + }, + { + "name": "Jonathan Ong", + "email": "me@jongleberry.com", + "url": "http://jongleberry.com" + } + ], + "license": "MIT", + "keywords": [ + "mime", + "types" + ], + "repository": { + "type": "git", + "url": "git+https://github.com/jshttp/mime-types.git" + }, + "dependencies": { + "mime-db": "~1.24.0" + }, + "devDependencies": { + "eslint": "3.5.0", + "eslint-config-standard": "6.0.1", + "eslint-plugin-promise": "2.0.1", + "eslint-plugin-standard": "2.0.0", + "istanbul": "0.4.5", + "mocha": "1.21.5" + }, + "files": [ + "HISTORY.md", + "LICENSE", + "index.js" + ], + "engines": { + "node": ">= 0.6" + }, + "scripts": { + "lint": "eslint **/*.js", + "test": "mocha --reporter spec test/test.js", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot test/test.js", + "test-travis": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter dot test/test.js" + }, + "gitHead": "7193a9094e2efe31da93988350bb0b32ab18b1ea", + "bugs": { + "url": "https://github.com/jshttp/mime-types/issues" + }, + "homepage": "https://github.com/jshttp/mime-types#readme", + "_id": "mime-types@2.1.12", + "_shasum": "152ba256777020dd4663f54c2e7bc26381e71729", + "_from": "mime-types@>=2.1.11 <2.2.0", + "_npmVersion": "2.15.9", + "_nodeVersion": "4.5.0", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "dist": { + "shasum": "152ba256777020dd4663f54c2e7bc26381e71729", + "tarball": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.12.tgz" + }, + "maintainers": [ + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "fishrock123", + "email": "fishrock123@rocketmail.com" + }, + { + "name": "jongleberry", + "email": "jonathanrichardong@gmail.com" + } + ], + "_npmOperationalInternal": { + "host": "packages-12-west.internal.npmjs.com", + "tmp": "tmp/mime-types-2.1.12.tgz_1474237415119_0.03028594213537872" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/mime-types/-/mime-types-2.1.12.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/body-parser/node_modules/type-is/package.json b/node_modules/body-parser/node_modules/type-is/package.json new file mode 100644 index 0000000..5142674 --- /dev/null +++ b/node_modules/body-parser/node_modules/type-is/package.json @@ -0,0 +1,87 @@ +{ + "name": "type-is", + "description": "Infer the content-type of a request.", + "version": "1.6.13", + "contributors": [ + { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "Jonathan Ong", + "email": "me@jongleberry.com", + "url": "http://jongleberry.com" + } + ], + "license": "MIT", + "repository": { + "type": "git", + "url": "git+https://github.com/jshttp/type-is.git" + }, + "dependencies": { + "media-typer": "0.3.0", + "mime-types": "~2.1.11" + }, + "devDependencies": { + "eslint": "2.10.2", + "eslint-config-standard": "5.3.1", + "eslint-plugin-promise": "1.1.0", + "eslint-plugin-standard": "1.3.2", + "istanbul": "0.4.3", + "mocha": "1.21.5" + }, + "engines": { + "node": ">= 0.6" + }, + "files": [ + "LICENSE", + "HISTORY.md", + "index.js" + ], + "scripts": { + "lint": "eslint **/*.js", + "test": "mocha --reporter spec --check-leaks --bail test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot --check-leaks test/", + "test-travis": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter spec --check-leaks test/" + }, + "keywords": [ + "content", + "type", + "checking" + ], + "gitHead": "88c47523fff910343b3ca7d4928dad40f21ea6cd", + "bugs": { + "url": "https://github.com/jshttp/type-is/issues" + }, + "homepage": "https://github.com/jshttp/type-is#readme", + "_id": "type-is@1.6.13", + "_shasum": "6e83ba7bc30cd33a7bb0b7fb00737a2085bf9d08", + "_from": "type-is@>=1.6.13 <1.7.0", + "_npmVersion": "2.15.1", + "_nodeVersion": "4.4.3", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "dist": { + "shasum": "6e83ba7bc30cd33a7bb0b7fb00737a2085bf9d08", + "tarball": "https://registry.npmjs.org/type-is/-/type-is-1.6.13.tgz" + }, + "maintainers": [ + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "jongleberry", + "email": "jonathanrichardong@gmail.com" + } + ], + "_npmOperationalInternal": { + "host": "packages-16-east.internal.npmjs.com", + "tmp": "tmp/type-is-1.6.13.tgz_1463622049206_0.9134831207338721" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/type-is/-/type-is-1.6.13.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/body-parser/package.json b/node_modules/body-parser/package.json new file mode 100644 index 0000000..89687db --- /dev/null +++ b/node_modules/body-parser/package.json @@ -0,0 +1,88 @@ +{ + "name": "body-parser", + "description": "Node.js body parsing middleware", + "version": "1.15.2", + "contributors": [ + { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "Jonathan Ong", + "email": "me@jongleberry.com", + "url": "http://jongleberry.com" + } + ], + "license": "MIT", + "repository": { + "type": "git", + "url": "git+https://github.com/expressjs/body-parser.git" + }, + "dependencies": { + "bytes": "2.4.0", + "content-type": "~1.0.2", + "debug": "~2.2.0", + "depd": "~1.1.0", + "http-errors": "~1.5.0", + "iconv-lite": "0.4.13", + "on-finished": "~2.3.0", + "qs": "6.2.0", + "raw-body": "~2.1.7", + "type-is": "~1.6.13" + }, + "devDependencies": { + "eslint": "2.13.0", + "eslint-config-standard": "5.3.1", + "eslint-plugin-promise": "1.3.2", + "eslint-plugin-standard": "1.3.2", + "istanbul": "0.4.3", + "methods": "1.1.2", + "mocha": "2.5.3", + "supertest": "1.1.0" + }, + "files": [ + "lib/", + "LICENSE", + "HISTORY.md", + "index.js" + ], + "engines": { + "node": ">= 0.8" + }, + "scripts": { + "lint": "eslint **/*.js", + "test": "mocha --require test/support/env --reporter spec --check-leaks --bail test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --require test/support/env --reporter dot --check-leaks test/", + "test-travis": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --require test/support/env --reporter spec --check-leaks test/" + }, + "gitHead": "3c8218446d919a5e87fa696971fb7f69b10afc1c", + "bugs": { + "url": "https://github.com/expressjs/body-parser/issues" + }, + "homepage": "https://github.com/expressjs/body-parser#readme", + "_id": "body-parser@1.15.2", + "_shasum": "d7578cf4f1d11d5f6ea804cef35dc7a7ff6dae67", + "_from": "body-parser@>=1.4.3 <2.0.0", + "_npmVersion": "2.15.1", + "_nodeVersion": "4.4.3", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "dist": { + "shasum": "d7578cf4f1d11d5f6ea804cef35dc7a7ff6dae67", + "tarball": "https://registry.npmjs.org/body-parser/-/body-parser-1.15.2.tgz" + }, + "maintainers": [ + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + } + ], + "_npmOperationalInternal": { + "host": "packages-12-west.internal.npmjs.com", + "tmp": "tmp/body-parser-1.15.2.tgz_1466393694089_0.7908455491997302" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/body-parser/-/body-parser-1.15.2.tgz" +} diff --git a/node_modules/connect-flash/.travis.yml b/node_modules/connect-flash/.travis.yml new file mode 100644 index 0000000..79eed11 --- /dev/null +++ b/node_modules/connect-flash/.travis.yml @@ -0,0 +1,6 @@ +language: "node_js" +node_js: + - 0.4 + - 0.6 + - 0.8 + \ No newline at end of file diff --git a/node_modules/connect-flash/LICENSE b/node_modules/connect-flash/LICENSE new file mode 100644 index 0000000..d61567a --- /dev/null +++ b/node_modules/connect-flash/LICENSE @@ -0,0 +1,20 @@ +(The MIT License) + +Copyright (c) 2012-2013 Jared Hanson + +Permission is hereby granted, free of charge, to any person obtaining a copy of +this software and associated documentation files (the "Software"), to deal in +the Software without restriction, including without limitation the rights to +use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of +the Software, and to permit persons to whom the Software is furnished to do so, +subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS +FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR +COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER +IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN +CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/connect-flash/README.md b/node_modules/connect-flash/README.md new file mode 100644 index 0000000..b3b58b4 --- /dev/null +++ b/node_modules/connect-flash/README.md @@ -0,0 +1,73 @@ +# connect-flash + +The flash is a special area of the session used for storing messages. Messages +are written to the flash and cleared after being displayed to the user. The +flash is typically used in combination with redirects, ensuring that the message +is available to the next page that is to be rendered. + +This middleware was extracted from [Express](http://expressjs.com/) 2.x, after +Express 3.x removed direct support for the flash. connect-flash brings this +functionality back to Express 3.x, as well as any other middleware-compatible +framework or application. +1 for [radical reusability](http://substack.net/posts/b96642/the-node-js-aesthetic). + +## Install + + $ npm install connect-flash + +## Usage + +#### Express 3.x + +Flash messages are stored in the session. First, setup sessions as usual by +enabling `cookieParser` and `session` middleware. Then, use `flash` middleware +provided by connect-flash. + +```javascript +var flash = require('connect-flash'); +var app = express(); + +app.configure(function() { + app.use(express.cookieParser('keyboard cat')); + app.use(express.session({ cookie: { maxAge: 60000 }})); + app.use(flash()); +}); +``` + +With the `flash` middleware in place, all requests will have a `req.flash()` function +that can be used for flash messages. + +```javascript +app.get('/flash', function(req, res){ + // Set a flash message by passing the key, followed by the value, to req.flash(). + req.flash('info', 'Flash is back!') + res.redirect('/'); +}); + +app.get('/', function(req, res){ + // Get an array of flash messages by passing the key to req.flash() + res.render('index', { messages: req.flash('info') }); +}); +``` + +## Examples + +For an example using connect-flash in an Express 3.x app, refer to the [express3](https://github.com/jaredhanson/connect-flash/tree/master/examples/express3) +example. + +## Tests + + $ npm install --dev + $ make test + +[![Build Status](https://secure.travis-ci.org/jaredhanson/connect-flash.png)](http://travis-ci.org/jaredhanson/connect-flash) + +## Credits + + - [Jared Hanson](http://github.com/jaredhanson) + - [TJ Holowaychuk](https://github.com/visionmedia) + +## License + +[The MIT License](http://opensource.org/licenses/MIT) + +Copyright (c) 2012-2013 Jared Hanson <[http://jaredhanson.net/](http://jaredhanson.net/)> diff --git a/node_modules/connect-flash/lib/flash.js b/node_modules/connect-flash/lib/flash.js new file mode 100644 index 0000000..a278bc1 --- /dev/null +++ b/node_modules/connect-flash/lib/flash.js @@ -0,0 +1,82 @@ +/** + * Module dependencies. + */ +var format = require('util').format; +var isArray = require('util').isArray; + + +/** + * Expose `flash()` function on requests. + * + * @return {Function} + * @api public + */ +module.exports = function flash(options) { + options = options || {}; + var safe = (options.unsafe === undefined) ? true : !options.unsafe; + + return function(req, res, next) { + if (req.flash && safe) { return next(); } + req.flash = _flash; + next(); + } +} + +/** + * Queue flash `msg` of the given `type`. + * + * Examples: + * + * req.flash('info', 'email sent'); + * req.flash('error', 'email delivery failed'); + * req.flash('info', 'email re-sent'); + * // => 2 + * + * req.flash('info'); + * // => ['email sent', 'email re-sent'] + * + * req.flash('info'); + * // => [] + * + * req.flash(); + * // => { error: ['email delivery failed'], info: [] } + * + * Formatting: + * + * Flash notifications also support arbitrary formatting support. + * For example you may pass variable arguments to `req.flash()` + * and use the %s specifier to be replaced by the associated argument: + * + * req.flash('info', 'email has been sent to %s.', userName); + * + * Formatting uses `util.format()`, which is available on Node 0.6+. + * + * @param {String} type + * @param {String} msg + * @return {Array|Object|Number} + * @api public + */ +function _flash(type, msg) { + if (this.session === undefined) throw Error('req.flash() requires sessions'); + var msgs = this.session.flash = this.session.flash || {}; + if (type && msg) { + // util.format is available in Node.js 0.6+ + if (arguments.length > 2 && format) { + var args = Array.prototype.slice.call(arguments, 1); + msg = format.apply(undefined, args); + } else if (isArray(msg)) { + msg.forEach(function(val){ + (msgs[type] = msgs[type] || []).push(val); + }); + return msgs[type].length; + } + return (msgs[type] = msgs[type] || []).push(msg); + } else if (type) { + var arr = msgs[type]; + delete msgs[type]; + return arr || []; + } else { + this.session.flash = {}; + return msgs; + } +} diff --git a/node_modules/connect-flash/lib/index.js b/node_modules/connect-flash/lib/index.js new file mode 100644 index 0000000..b4d5961 --- /dev/null +++ b/node_modules/connect-flash/lib/index.js @@ -0,0 +1,4 @@ +/** + * Expose middleware. + */ +exports = module.exports = require('./flash'); diff --git a/node_modules/connect-flash/package.json b/node_modules/connect-flash/package.json new file mode 100644 index 0000000..5e561cd --- /dev/null +++ b/node_modules/connect-flash/package.json @@ -0,0 +1,60 @@ +{ + "name": "connect-flash", + "version": "0.1.1", + "description": "Flash message middleware for Connect.", + "keywords": [ + "connect", + "express", + "flash", + "messages" + ], + "repository": { + "type": "git", + "url": "git://github.com/jaredhanson/connect-flash.git" + }, + "bugs": { + "url": "http://github.com/jaredhanson/connect-flash/issues" + }, + "author": { + "name": "Jared Hanson", + "email": "jaredhanson@gmail.com", + "url": "http://www.jaredhanson.net/" + }, + "licenses": [ + { + "type": "MIT", + "url": "http://www.opensource.org/licenses/MIT" + } + ], + "main": "./lib", + "dependencies": {}, + "devDependencies": { + "vows": "0.6.x" + }, + "scripts": { + "test": "NODE_PATH=lib node_modules/.bin/vows test/*-test.js" + }, + "engines": { + "node": ">= 0.4.0" + }, + "_id": "connect-flash@0.1.1", + "dist": { + "shasum": "d8630f26d95a7f851f9956b1e8cc6732f3b6aa30", + "tarball": "https://registry.npmjs.org/connect-flash/-/connect-flash-0.1.1.tgz" + }, + "_npmVersion": "1.1.62", + "_npmUser": { + "name": "jaredhanson", + "email": "jaredhanson@gmail.com" + }, + "maintainers": [ + { + "name": "jaredhanson", + "email": "jaredhanson@gmail.com" + } + ], + "directories": {}, + "_shasum": "d8630f26d95a7f851f9956b1e8cc6732f3b6aa30", + "_resolved": "http://registry.npmjs.org/connect-flash/-/connect-flash-0.1.1.tgz", + "_from": "connect-flash@>=0.1.1 <0.2.0" +} diff --git a/node_modules/cookie-parser/HISTORY.md b/node_modules/cookie-parser/HISTORY.md new file mode 100644 index 0000000..4f28f50 --- /dev/null +++ b/node_modules/cookie-parser/HISTORY.md @@ -0,0 +1,85 @@ +1.4.3 / 2016-05-26 +================== + + * deps: cookie@0.3.1 + - perf: use for loop in parse + +1.4.2 / 2016-05-20 +================== + + * deps: cookie@0.2.4 + - perf: enable strict mode + - perf: use for loop in parse + - perf: use string concatination for serialization + +1.4.1 / 2016-01-11 +================== + + * deps: cookie@0.2.3 + * perf: enable strict mode + +1.4.0 / 2015-09-18 +================== + + * Accept array of secrets in addition to a single secret + * Fix `JSONCookie` to return `undefined` for non-string arguments + * Fix `signedCookie` to return `undefined` for non-string arguments + * deps: cookie@0.2.2 + +1.3.5 / 2015-05-19 +================== + + * deps: cookie@0.1.3 + - Slight optimizations + +1.3.4 / 2015-02-15 +================== + + * deps: cookie-signature@1.0.6 + +1.3.3 / 2014-09-05 +================== + + * deps: cookie-signature@1.0.5 + +1.3.2 / 2014-06-26 +================== + + * deps: cookie-signature@1.0.4 + - fix for timing attacks + +1.3.1 / 2014-06-17 +================== + + * actually export `signedCookie` + +1.3.0 / 2014-06-17 +================== + + * add `signedCookie` export for single cookie unsigning + +1.2.0 / 2014-06-17 +================== + + * export parsing functions + * `req.cookies` and `req.signedCookies` are now plain objects + * slightly faster parsing of many cookies + +1.1.0 / 2014-05-12 +================== + + * Support for NodeJS version 0.8 + * deps: cookie@0.1.2 + - Fix for maxAge == 0 + - made compat with expires field + - tweak maxAge NaN error message + +1.0.1 / 2014-02-20 +================== + + * add missing dependencies + +1.0.0 / 2014-02-15 +================== + + * Genesis from `connect` diff --git a/node_modules/cookie-parser/LICENSE b/node_modules/cookie-parser/LICENSE new file mode 100644 index 0000000..343f2ad --- /dev/null +++ b/node_modules/cookie-parser/LICENSE @@ -0,0 +1,23 @@ +(The MIT License) + +Copyright (c) 2014 TJ Holowaychuk +Copyright (c) 2015 Douglas Christopher Wilson + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/cookie-parser/README.md b/node_modules/cookie-parser/README.md new file mode 100644 index 0000000..05dbdc5 --- /dev/null +++ b/node_modules/cookie-parser/README.md @@ -0,0 +1,85 @@ +# cookie-parser + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Node.js Version][node-version-image]][node-version-url] +[![Build Status][travis-image]][travis-url] +[![Test Coverage][coveralls-image]][coveralls-url] + +Parse `Cookie` header and populate `req.cookies` with an object keyed by the cookie +names. Optionally you may enable signed cookie support by passing a `secret` string, +which assigns `req.secret` so it may be used by other middleware. + +## Installation + +```sh +$ npm install cookie-parser +``` + +## API + +```js +var express = require('express') +var cookieParser = require('cookie-parser') + +var app = express() +app.use(cookieParser()) +``` + +### cookieParser(secret, options) + +- `secret` a string or array used for signing cookies. This is optional and if not specified, will not parse signed cookies. If a string is provided, this is used as the secret. If an array is provided, an attempt will be made to unsign the cookie with each secret in order. +- `options` an object that is passed to `cookie.parse` as the second option. See [cookie](https://www.npmjs.org/package/cookie) for more information. + - `decode` a function to decode the value of the cookie + +### cookieParser.JSONCookie(str) + +Parse a cookie value as a JSON cookie. This will return the parsed JSON value if it was a JSON cookie, otherwise it will return the passed value. + +### cookieParser.JSONCookies(cookies) + +Given an object, this will iterate over the keys and call `JSONCookie` on each value. This will return the same object passed in. + +### cookieParser.signedCookie(str, secret) + +Parse a cookie value as a signed cookie. This will return the parsed unsigned value if it was a signed cookie and the signature was valid, otherwise it will return the passed value. + +The `secret` argument can be an array or string. If a string is provided, this is used as the secret. If an array is provided, an attempt will be made to unsign the cookie with each secret in order. + +### cookieParser.signedCookies(cookies, secret) + +Given an object, this will iterate over the keys and check if any value is a signed cookie. If it is a signed cookie and the signature is valid, the key will be deleted from the object and added to the new object that is returned. + +The `secret` argument can be an array or string. If a string is provided, this is used as the secret. If an array is provided, an attempt will be made to unsign the cookie with each secret in order. + +## Example + +```js +var express = require('express') +var cookieParser = require('cookie-parser') + +var app = express() +app.use(cookieParser()) + +app.get('/', function(req, res) { + console.log('Cookies: ', req.cookies) +}) + +app.listen(8080) + +// curl command that sends an HTTP request with two cookies +// curl http://127.0.0.1:8080 --cookie "Cho=Kim;Greet=Hello" +``` + +### [MIT Licensed](LICENSE) + +[npm-image]: https://img.shields.io/npm/v/cookie-parser.svg +[npm-url]: https://npmjs.org/package/cookie-parser +[node-version-image]: https://img.shields.io/node/v/cookie-parser.svg +[node-version-url]: https://nodejs.org/en/download +[travis-image]: https://img.shields.io/travis/expressjs/cookie-parser/master.svg +[travis-url]: https://travis-ci.org/expressjs/cookie-parser +[coveralls-image]: https://img.shields.io/coveralls/expressjs/cookie-parser/master.svg +[coveralls-url]: https://coveralls.io/r/expressjs/cookie-parser?branch=master +[downloads-image]: https://img.shields.io/npm/dm/cookie-parser.svg +[downloads-url]: https://npmjs.org/package/cookie-parser diff --git a/node_modules/cookie-parser/index.js b/node_modules/cookie-parser/index.js new file mode 100644 index 0000000..59816a2 --- /dev/null +++ b/node_modules/cookie-parser/index.js @@ -0,0 +1,181 @@ +/*! + * cookie-parser + * Copyright(c) 2014 TJ Holowaychuk + * Copyright(c) 2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict'; + +/** + * Module dependencies. + * @private + */ + +var cookie = require('cookie'); +var signature = require('cookie-signature'); + +/** + * Module exports. + * @public + */ + +module.exports = cookieParser; +module.exports.JSONCookie = JSONCookie; +module.exports.JSONCookies = JSONCookies; +module.exports.signedCookie = signedCookie; +module.exports.signedCookies = signedCookies; + +/** + * Parse Cookie header and populate `req.cookies` + * with an object keyed by the cookie names. + * + * @param {string|array} [secret] A string (or array of strings) representing cookie signing secret(s). + * @param {Object} [options] + * @return {Function} + * @public + */ + +function cookieParser(secret, options) { + return function cookieParser(req, res, next) { + if (req.cookies) { + return next(); + } + + var cookies = req.headers.cookie; + var secrets = !secret || Array.isArray(secret) + ? (secret || []) + : [secret]; + + req.secret = secrets[0]; + req.cookies = Object.create(null); + req.signedCookies = Object.create(null); + + // no cookies + if (!cookies) { + return next(); + } + + req.cookies = cookie.parse(cookies, options); + + // parse signed cookies + if (secrets.length !== 0) { + req.signedCookies = signedCookies(req.cookies, secrets); + req.signedCookies = JSONCookies(req.signedCookies); + } + + // parse JSON cookies + req.cookies = JSONCookies(req.cookies); + + next(); + }; +} + +/** + * Parse JSON cookie string. + * + * @param {String} str + * @return {Object} Parsed object or undefined if not json cookie + * @public + */ + +function JSONCookie(str) { + if (typeof str !== 'string' || str.substr(0, 2) !== 'j:') { + return undefined; + } + + try { + return JSON.parse(str.slice(2)); + } catch (err) { + return undefined; + } +} + +/** + * Parse JSON cookies. + * + * @param {Object} obj + * @return {Object} + * @public + */ + +function JSONCookies(obj) { + var cookies = Object.keys(obj); + var key; + var val; + + for (var i = 0; i < cookies.length; i++) { + key = cookies[i]; + val = JSONCookie(obj[key]); + + if (val) { + obj[key] = val; + } + } + + return obj; +} + +/** + * Parse a signed cookie string, return the decoded value. + * + * @param {String} str signed cookie string + * @param {string|array} secret + * @return {String} decoded value + * @public + */ + +function signedCookie(str, secret) { + if (typeof str !== 'string') { + return undefined; + } + + if (str.substr(0, 2) !== 's:') { + return str; + } + + var secrets = !secret || Array.isArray(secret) + ? (secret || []) + : [secret]; + + for (var i = 0; i < secrets.length; i++) { + var val = signature.unsign(str.slice(2), secrets[i]); + + if (val !== false) { + return val; + } + } + + return false; +} + +/** + * Parse signed cookies, returning an object containing the decoded key/value + * pairs, while removing the signed key from obj. + * + * @param {Object} obj + * @param {string|array} secret + * @return {Object} + * @public + */ + +function signedCookies(obj, secret) { + var cookies = Object.keys(obj); + var dec; + var key; + var ret = Object.create(null); + var val; + + for (var i = 0; i < cookies.length; i++) { + key = cookies[i]; + val = obj[key]; + dec = signedCookie(val, secret); + + if (val !== dec) { + ret[key] = dec; + delete obj[key]; + } + } + + return ret; +} diff --git a/node_modules/cookie-parser/node_modules/cookie-signature/.npmignore b/node_modules/cookie-parser/node_modules/cookie-signature/.npmignore new file mode 100644 index 0000000..f1250e5 --- /dev/null +++ b/node_modules/cookie-parser/node_modules/cookie-signature/.npmignore @@ -0,0 +1,4 @@ +support +test +examples +*.sock diff --git a/node_modules/cookie-parser/node_modules/cookie-signature/History.md b/node_modules/cookie-parser/node_modules/cookie-signature/History.md new file mode 100644 index 0000000..78513cc --- /dev/null +++ b/node_modules/cookie-parser/node_modules/cookie-signature/History.md @@ -0,0 +1,38 @@ +1.0.6 / 2015-02-03 +================== + +* use `npm test` instead of `make test` to run tests +* clearer assertion messages when checking input + + +1.0.5 / 2014-09-05 +================== + +* add license to package.json + +1.0.4 / 2014-06-25 +================== + + * corrected avoidance of timing attacks (thanks @tenbits!) + +1.0.3 / 2014-01-28 +================== + + * [incorrect] fix for timing attacks + +1.0.2 / 2014-01-28 +================== + + * fix missing repository warning + * fix typo in test + +1.0.1 / 2013-04-15 +================== + + * Revert "Changed underlying HMAC algo. to sha512." + * Revert "Fix for timing attacks on MAC verification." + +0.0.1 / 2010-01-03 +================== + + * Initial release diff --git a/node_modules/cookie-parser/node_modules/cookie-signature/Readme.md b/node_modules/cookie-parser/node_modules/cookie-signature/Readme.md new file mode 100644 index 0000000..2559e84 --- /dev/null +++ b/node_modules/cookie-parser/node_modules/cookie-signature/Readme.md @@ -0,0 +1,42 @@ + +# cookie-signature + + Sign and unsign cookies. + +## Example + +```js +var cookie = require('cookie-signature'); + +var val = cookie.sign('hello', 'tobiiscool'); +val.should.equal('hello.DGDUkGlIkCzPz+C0B064FNgHdEjox7ch8tOBGslZ5QI'); + +var val = cookie.sign('hello', 'tobiiscool'); +cookie.unsign(val, 'tobiiscool').should.equal('hello'); +cookie.unsign(val, 'luna').should.be.false; +``` + +## License + +(The MIT License) + +Copyright (c) 2012 LearnBoost <tj@learnboost.com> + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. \ No newline at end of file diff --git a/node_modules/cookie-parser/node_modules/cookie-signature/index.js b/node_modules/cookie-parser/node_modules/cookie-signature/index.js new file mode 100644 index 0000000..b8c9463 --- /dev/null +++ b/node_modules/cookie-parser/node_modules/cookie-signature/index.js @@ -0,0 +1,51 @@ +/** + * Module dependencies. + */ + +var crypto = require('crypto'); + +/** + * Sign the given `val` with `secret`. + * + * @param {String} val + * @param {String} secret + * @return {String} + * @api private + */ + +exports.sign = function(val, secret){ + if ('string' != typeof val) throw new TypeError("Cookie value must be provided as a string."); + if ('string' != typeof secret) throw new TypeError("Secret string must be provided."); + return val + '.' + crypto + .createHmac('sha256', secret) + .update(val) + .digest('base64') + .replace(/\=+$/, ''); +}; + +/** + * Unsign and decode the given `val` with `secret`, + * returning `false` if the signature is invalid. + * + * @param {String} val + * @param {String} secret + * @return {String|Boolean} + * @api private + */ + +exports.unsign = function(val, secret){ + if ('string' != typeof val) throw new TypeError("Signed cookie string must be provided."); + if ('string' != typeof secret) throw new TypeError("Secret string must be provided."); + var str = val.slice(0, val.lastIndexOf('.')) + , mac = exports.sign(str, secret); + + return sha1(mac) == sha1(val) ? str : false; +}; + +/** + * Private + */ + +function sha1(str){ + return crypto.createHash('sha1').update(str).digest('hex'); +} diff --git a/node_modules/cookie-parser/node_modules/cookie-signature/package.json b/node_modules/cookie-parser/node_modules/cookie-signature/package.json new file mode 100644 index 0000000..33c95c0 --- /dev/null +++ b/node_modules/cookie-parser/node_modules/cookie-signature/package.json @@ -0,0 +1,59 @@ +{ + "name": "cookie-signature", + "version": "1.0.6", + "description": "Sign and unsign cookies", + "keywords": [ + "cookie", + "sign", + "unsign" + ], + "author": { + "name": "TJ Holowaychuk", + "email": "tj@learnboost.com" + }, + "license": "MIT", + "repository": { + "type": "git", + "url": "git+https://github.com/visionmedia/node-cookie-signature.git" + }, + "dependencies": {}, + "devDependencies": { + "mocha": "*", + "should": "*" + }, + "scripts": { + "test": "mocha --require should --reporter spec" + }, + "main": "index", + "gitHead": "391b56cf44d88c493491b7e3fc53208cfb976d2a", + "bugs": { + "url": "https://github.com/visionmedia/node-cookie-signature/issues" + }, + "homepage": "https://github.com/visionmedia/node-cookie-signature", + "_id": "cookie-signature@1.0.6", + "_shasum": "e303a882b342cc3ee8ca513a79999734dab3ae2c", + "_from": "cookie-signature@1.0.6", + "_npmVersion": "2.3.0", + "_nodeVersion": "0.10.36", + "_npmUser": { + "name": "natevw", + "email": "natevw@yahoo.com" + }, + "maintainers": [ + { + "name": "tjholowaychuk", + "email": "tj@vision-media.ca" + }, + { + "name": "natevw", + "email": "natevw@yahoo.com" + } + ], + "dist": { + "shasum": "e303a882b342cc3ee8ca513a79999734dab3ae2c", + "tarball": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/cookie-parser/node_modules/cookie/HISTORY.md b/node_modules/cookie-parser/node_modules/cookie/HISTORY.md new file mode 100644 index 0000000..5bd6485 --- /dev/null +++ b/node_modules/cookie-parser/node_modules/cookie/HISTORY.md @@ -0,0 +1,118 @@ +0.3.1 / 2016-05-26 +================== + + * Fix `sameSite: true` to work with draft-7 clients + - `true` now sends `SameSite=Strict` instead of `SameSite` + +0.3.0 / 2016-05-26 +================== + + * Add `sameSite` option + - Replaces `firstPartyOnly` option, never implemented by browsers + * Improve error message when `encode` is not a function + * Improve error message when `expires` is not a `Date` + +0.2.4 / 2016-05-20 +================== + + * perf: enable strict mode + * perf: use for loop in parse + * perf: use string concatination for serialization + +0.2.3 / 2015-10-25 +================== + + * Fix cookie `Max-Age` to never be a floating point number + +0.2.2 / 2015-09-17 +================== + + * Fix regression when setting empty cookie value + - Ease the new restriction, which is just basic header-level validation + * Fix typo in invalid value errors + +0.2.1 / 2015-09-17 +================== + + * Throw on invalid values provided to `serialize` + - Ensures the resulting string is a valid HTTP header value + +0.2.0 / 2015-08-13 +================== + + * Add `firstPartyOnly` option + * Throw better error for invalid argument to parse + * perf: hoist regular expression + +0.1.5 / 2015-09-17 +================== + + * Fix regression when setting empty cookie value + - Ease the new restriction, which is just basic header-level validation + * Fix typo in invalid value errors + +0.1.4 / 2015-09-17 +================== + + * Throw better error for invalid argument to parse + * Throw on invalid values provided to `serialize` + - Ensures the resulting string is a valid HTTP header value + +0.1.3 / 2015-05-19 +================== + + * Reduce the scope of try-catch deopt + * Remove argument reassignments + +0.1.2 / 2014-04-16 +================== + + * Remove unnecessary files from npm package + +0.1.1 / 2014-02-23 +================== + + * Fix bad parse when cookie value contained a comma + * Fix support for `maxAge` of `0` + +0.1.0 / 2013-05-01 +================== + + * Add `decode` option + * Add `encode` option + +0.0.6 / 2013-04-08 +================== + + * Ignore cookie parts missing `=` + +0.0.5 / 2012-10-29 +================== + + * Return raw cookie value if value unescape errors + +0.0.4 / 2012-06-21 +================== + + * Use encode/decodeURIComponent for cookie encoding/decoding + - Improve server/client interoperability + +0.0.3 / 2012-06-06 +================== + + * Only escape special characters per the cookie RFC + +0.0.2 / 2012-06-01 +================== + + * Fix `maxAge` option to not throw error + +0.0.1 / 2012-05-28 +================== + + * Add more tests + +0.0.0 / 2012-05-28 +================== + + * Initial release diff --git a/node_modules/cookie-parser/node_modules/cookie/LICENSE b/node_modules/cookie-parser/node_modules/cookie/LICENSE new file mode 100644 index 0000000..058b6b4 --- /dev/null +++ b/node_modules/cookie-parser/node_modules/cookie/LICENSE @@ -0,0 +1,24 @@ +(The MIT License) + +Copyright (c) 2012-2014 Roman Shtylman +Copyright (c) 2015 Douglas Christopher Wilson + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + diff --git a/node_modules/cookie-parser/node_modules/cookie/README.md b/node_modules/cookie-parser/node_modules/cookie/README.md new file mode 100644 index 0000000..db0d078 --- /dev/null +++ b/node_modules/cookie-parser/node_modules/cookie/README.md @@ -0,0 +1,220 @@ +# cookie + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Node.js Version][node-version-image]][node-version-url] +[![Build Status][travis-image]][travis-url] +[![Test Coverage][coveralls-image]][coveralls-url] + +Basic HTTP cookie parser and serializer for HTTP servers. + +## Installation + +```sh +$ npm install cookie +``` + +## API + +```js +var cookie = require('cookie'); +``` + +### cookie.parse(str, options) + +Parse an HTTP `Cookie` header string and returning an object of all cookie name-value pairs. +The `str` argument is the string representing a `Cookie` header value and `options` is an +optional object containing additional parsing options. + +```js +var cookies = cookie.parse('foo=bar; equation=E%3Dmc%5E2'); +// { foo: 'bar', equation: 'E=mc^2' } +``` + +#### Options + +`cookie.parse` accepts these properties in the options object. + +##### decode + +Specifies a function that will be used to decode a cookie's value. Since the value of a cookie +has a limited character set (and must be a simple string), this function can be used to decode +a previously-encoded cookie value into a JavaScript string or other object. + +The default function is the global `decodeURIComponent`, which will decode any URL-encoded +sequences into their byte representations. + +**note** if an error is thrown from this function, the original, non-decoded cookie value will +be returned as the cookie's value. + +### cookie.serialize(name, value, options) + +Serialize a cookie name-value pair into a `Set-Cookie` header string. The `name` argument is the +name for the cookie, the `value` argument is the value to set the cookie to, and the `options` +argument is an optional object containing additional serialization options. + +```js +var setCookie = cookie.serialize('foo', 'bar'); +// foo=bar +``` + +#### Options + +`cookie.serialize` accepts these properties in the options object. + +##### domain + +Specifies the value for the [`Domain` `Set-Cookie` attribute][rfc-6266-5.2.3]. By default, no +domain is set, and most clients will consider the cookie to apply to only the current domain. + +##### encode + +Specifies a function that will be used to encode a cookie's value. Since value of a cookie +has a limited character set (and must be a simple string), this function can be used to encode +a value into a string suited for a cookie's value. + +The default function is the global `ecodeURIComponent`, which will encode a JavaScript string +into UTF-8 byte sequences and then URL-encode any that fall outside of the cookie range. + +##### expires + +Specifies the `Date` object to be the value for the [`Expires` `Set-Cookie` attribute][rfc-6266-5.2.1]. +By default, no expiration is set, and most clients will consider this a "non-persistent cookie" and +will delete it on a condition like exiting a web browser application. + +**note** the [cookie storage model specification][rfc-6266-5.3] states that if both `expires` and +`magAge` are set, then `maxAge` takes precedence, but it is possiblke not all clients by obey this, +so if both are set, they should point to the same date and time. + +##### httpOnly + +Specifies the `boolean` value for the [`HttpOnly` `Set-Cookie` attribute][rfc-6266-5.2.6]. When truthy, +the `HttpOnly` attribute is set, otherwise it is not. By default, the `HttpOnly` attribute is not set. + +**note** be careful when setting this to `true`, as compliant clients will not allow client-side +JavaScript to see the cookie in `document.cookie`. + +##### maxAge + +Specifies the `number` (in seconds) to be the value for the [`Max-Age` `Set-Cookie` attribute][rfc-6266-5.2.2]. +The given number will be converted to an integer by rounding down. By default, no maximum age is set. + +**note** the [cookie storage model specification][rfc-6266-5.3] states that if both `expires` and +`magAge` are set, then `maxAge` takes precedence, but it is possiblke not all clients by obey this, +so if both are set, they should point to the same date and time. + +##### path + +Specifies the value for the [`Path` `Set-Cookie` attribute][rfc-6266-5.2.4]. By default, the path +is considered the ["default path"][rfc-6266-5.1.4]. By default, no maximum age is set, and most +clients will consider this a "non-persistent cookie" and will delete it on a condition like exiting +a web browser application. + +##### sameSite + +Specifies the `boolean` or `string` to be the value for the [`SameSite` `Set-Cookie` attribute][draft-west-first-party-cookies-07]. + + - `true` will set the `SameSite` attribute to `Strict` for strict same site enforcement. + - `false` will not set the `SameSite` attribute. + - `'lax'` will set the `SameSite` attribute to `Lax` for lax same site enforcement. + - `'strict'` will set the `SameSite` attribute to `Strict` for strict same site enforcement. + +More information about the different enforcement levels can be found in the specification +https://tools.ietf.org/html/draft-west-first-party-cookies-07#section-4.1.1 + +**note** This is an attribute that has not yet been fully standardized, and may change in the future. +This also means many clients may ignore this attribute until they understand it. + +##### secure + +Specifies the `boolean` value for the [`Secure` `Set-Cookie` attribute][rfc-6266-5.2.5]. When truthy, +the `Secure` attribute is set, otherwise it is not. By default, the `Secure` attribute is not set. + +**note** be careful when setting this to `true`, as compliant clients will not send the cookie back to +the server in the future if the browser does not have an HTTPS connection. + +## Example + +The following example uses this module in conjunction with the Node.js core HTTP server +to prompt a user for their name and display it back on future visits. + +```js +var cookie = require('cookie'); +var escapeHtml = require('escape-html'); +var http = require('http'); +var url = require('url'); + +function onRequest(req, res) { + // Parse the query string + var query = url.parse(req.url, true, true).query; + + if (query && query.name) { + // Set a new cookie with the name + res.setHeader('Set-Cookie', cookie.serialize('name', String(query.name), { + httpOnly: true, + maxAge: 60 * 60 * 24 * 7 // 1 week + })); + + // Redirect back after setting cookie + res.statusCode = 302; + res.setHeader('Location', req.headers.referer || '/'); + res.end(); + return; + } + + // Parse the cookies on the request + var cookies = cookie.parse(req.headers.cookie || ''); + + // Get the visitor name set in the cookie + var name = cookies.name; + + res.setHeader('Content-Type', 'text/html; charset=UTF-8'); + + if (name) { + res.write('

Welcome back, ' + escapeHtml(name) + '!

'); + } else { + res.write('

Hello, new visitor!

'); + } + + res.write('
'); + res.write(' '); + res.end(' values + * + * @param {string} str + * @param {object} [options] + * @return {object} + * @public + */ + +function parse(str, options) { + if (typeof str !== 'string') { + throw new TypeError('argument str must be a string'); + } + + var obj = {} + var opt = options || {}; + var pairs = str.split(pairSplitRegExp); + var dec = opt.decode || decode; + + for (var i = 0; i < pairs.length; i++) { + var pair = pairs[i]; + var eq_idx = pair.indexOf('='); + + // skip things that don't look like key=value + if (eq_idx < 0) { + continue; + } + + var key = pair.substr(0, eq_idx).trim() + var val = pair.substr(++eq_idx, pair.length).trim(); + + // quoted values + if ('"' == val[0]) { + val = val.slice(1, -1); + } + + // only assign once + if (undefined == obj[key]) { + obj[key] = tryDecode(val, dec); + } + } + + return obj; +} + +/** + * Serialize data into a cookie header. + * + * Serialize the a name value pair into a cookie string suitable for + * http headers. An optional options object specified cookie parameters. + * + * serialize('foo', 'bar', { httpOnly: true }) + * => "foo=bar; httpOnly" + * + * @param {string} name + * @param {string} val + * @param {object} [options] + * @return {string} + * @public + */ + +function serialize(name, val, options) { + var opt = options || {}; + var enc = opt.encode || encode; + + if (typeof enc !== 'function') { + throw new TypeError('option encode is invalid'); + } + + if (!fieldContentRegExp.test(name)) { + throw new TypeError('argument name is invalid'); + } + + var value = enc(val); + + if (value && !fieldContentRegExp.test(value)) { + throw new TypeError('argument val is invalid'); + } + + var str = name + '=' + value; + + if (null != opt.maxAge) { + var maxAge = opt.maxAge - 0; + if (isNaN(maxAge)) throw new Error('maxAge should be a Number'); + str += '; Max-Age=' + Math.floor(maxAge); + } + + if (opt.domain) { + if (!fieldContentRegExp.test(opt.domain)) { + throw new TypeError('option domain is invalid'); + } + + str += '; Domain=' + opt.domain; + } + + if (opt.path) { + if (!fieldContentRegExp.test(opt.path)) { + throw new TypeError('option path is invalid'); + } + + str += '; Path=' + opt.path; + } + + if (opt.expires) { + if (typeof opt.expires.toUTCString !== 'function') { + throw new TypeError('option expires is invalid'); + } + + str += '; Expires=' + opt.expires.toUTCString(); + } + + if (opt.httpOnly) { + str += '; HttpOnly'; + } + + if (opt.secure) { + str += '; Secure'; + } + + if (opt.sameSite) { + var sameSite = typeof opt.sameSite === 'string' + ? opt.sameSite.toLowerCase() : opt.sameSite; + + switch (sameSite) { + case true: + str += '; SameSite=Strict'; + break; + case 'lax': + str += '; SameSite=Lax'; + break; + case 'strict': + str += '; SameSite=Strict'; + break; + default: + throw new TypeError('option sameSite is invalid'); + } + } + + return str; +} + +/** + * Try decoding a string using a decoding function. + * + * @param {string} str + * @param {function} decode + * @private + */ + +function tryDecode(str, decode) { + try { + return decode(str); + } catch (e) { + return str; + } +} diff --git a/node_modules/cookie-parser/node_modules/cookie/package.json b/node_modules/cookie-parser/node_modules/cookie/package.json new file mode 100644 index 0000000..4a084e0 --- /dev/null +++ b/node_modules/cookie-parser/node_modules/cookie/package.json @@ -0,0 +1,72 @@ +{ + "name": "cookie", + "description": "HTTP server cookie parsing and serialization", + "version": "0.3.1", + "author": { + "name": "Roman Shtylman", + "email": "shtylman@gmail.com" + }, + "contributors": [ + { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + } + ], + "license": "MIT", + "keywords": [ + "cookie", + "cookies" + ], + "repository": { + "type": "git", + "url": "git+https://github.com/jshttp/cookie.git" + }, + "devDependencies": { + "istanbul": "0.4.3", + "mocha": "1.21.5" + }, + "files": [ + "HISTORY.md", + "LICENSE", + "README.md", + "index.js" + ], + "engines": { + "node": ">= 0.6" + }, + "scripts": { + "test": "mocha --reporter spec --bail --check-leaks test/", + "test-ci": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter spec --check-leaks test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot --check-leaks test/" + }, + "gitHead": "e3c77d497d66c8b8d4b677b8954c1b192a09f0b3", + "bugs": { + "url": "https://github.com/jshttp/cookie/issues" + }, + "homepage": "https://github.com/jshttp/cookie", + "_id": "cookie@0.3.1", + "_shasum": "e7e0a1f9ef43b4c8ba925c5c5a96e806d16873bb", + "_from": "cookie@0.3.1", + "_npmVersion": "1.4.28", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "maintainers": [ + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + } + ], + "dist": { + "shasum": "e7e0a1f9ef43b4c8ba925c5c5a96e806d16873bb", + "tarball": "https://registry.npmjs.org/cookie/-/cookie-0.3.1.tgz" + }, + "_npmOperationalInternal": { + "host": "packages-12-west.internal.npmjs.com", + "tmp": "tmp/cookie-0.3.1.tgz_1464323556714_0.6435900838114321" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/cookie/-/cookie-0.3.1.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/cookie-parser/package.json b/node_modules/cookie-parser/package.json new file mode 100644 index 0000000..65ec23e --- /dev/null +++ b/node_modules/cookie-parser/package.json @@ -0,0 +1,80 @@ +{ + "name": "cookie-parser", + "description": "cookie parsing with signatures", + "version": "1.4.3", + "author": { + "name": "TJ Holowaychuk", + "email": "tj@vision-media.ca", + "url": "http://tjholowaychuk.com" + }, + "contributors": [ + { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + } + ], + "license": "MIT", + "repository": { + "type": "git", + "url": "https://github.com/expressjs/cookie-parser" + }, + "keywords": [ + "cookie", + "middleware" + ], + "dependencies": { + "cookie": "0.3.1", + "cookie-signature": "1.0.6" + }, + "devDependencies": { + "istanbul": "0.4.3", + "mocha": "2.5.3", + "supertest": "1.1.0" + }, + "files": [ + "LICENSE", + "HISTORY.md", + "index.js" + ], + "engines": { + "node": ">= 0.8.0" + }, + "scripts": { + "test": "mocha --reporter spec --bail --check-leaks test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot --check-leaks test/", + "test-travis": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter spec --check-leaks test/" + }, + "gitHead": "ad0b2cb834affe3929f0a690cd0494cd0b96d6be", + "bugs": { + "url": "https://github.com/expressjs/cookie-parser/issues" + }, + "homepage": "https://github.com/expressjs/cookie-parser", + "_id": "cookie-parser@1.4.3", + "_shasum": "0fe31fa19d000b95f4aadf1f53fdc2b8a203baa5", + "_from": "cookie-parser@>=1.0.0 <2.0.0", + "_npmVersion": "1.4.28", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "maintainers": [ + { + "name": "defunctzombie", + "email": "shtylman@gmail.com" + }, + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + } + ], + "dist": { + "shasum": "0fe31fa19d000b95f4aadf1f53fdc2b8a203baa5", + "tarball": "https://registry.npmjs.org/cookie-parser/-/cookie-parser-1.4.3.tgz" + }, + "_npmOperationalInternal": { + "host": "packages-16-east.internal.npmjs.com", + "tmp": "tmp/cookie-parser-1.4.3.tgz_1464325360032_0.20419598533771932" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/cookie-parser/-/cookie-parser-1.4.3.tgz" +} diff --git a/node_modules/express-session/HISTORY.md b/node_modules/express-session/HISTORY.md new file mode 100644 index 0000000..972d1c9 --- /dev/null +++ b/node_modules/express-session/HISTORY.md @@ -0,0 +1,322 @@ +1.14.1 / 2016-08-24 +=================== + + * Fix not always resetting session max age before session save + * Fix the cookie `sameSite` option to actually alter the `Set-Cookie` + * deps: uid-safe@~2.1.2 + - deps: base64-url@1.3.2 + +1.14.0 / 2016-07-01 +=================== + + * Correctly inherit from `EventEmitter` class in `Store` base class + * Fix issue where `Set-Cookie` `Expires` was not always updated + * Methods are no longer enumerable on `req.session` object + * deps: cookie@0.3.1 + - Add `sameSite` option + - Improve error message when `encode` is not a function + - Improve error message when `expires` is not a `Date` + - perf: enable strict mode + - perf: use for loop in parse + - perf: use string concatination for serialization + * deps: parseurl@~1.3.1 + - perf: enable strict mode + * deps: uid-safe@~2.1.1 + - Use `random-bytes` for byte source + - deps: base64-url@1.2.2 + * perf: enable strict mode + * perf: remove argument reassignment + +1.13.0 / 2016-01-10 +=================== + + * Fix `rolling: true` to not set cookie when no session exists + - Better `saveUninitialized: false` + `rolling: true` behavior + * deps: crc@3.4.0 + +1.12.1 / 2015-10-29 +=================== + + * deps: cookie@0.2.3 + - Fix cookie `Max-Age` to never be a floating point number + +1.12.0 / 2015-10-25 +=================== + + * Support the value `'auto'` in the `cookie.secure` option + * deps: cookie@0.2.2 + - Throw on invalid values provided to `serialize` + * deps: depd@~1.1.0 + - Enable strict mode in more places + - Support web browser loading + * deps: on-headers@~1.0.1 + - perf: enable strict mode + +1.11.3 / 2015-05-22 +=================== + + * deps: cookie@0.1.3 + - Slight optimizations + * deps: crc@3.3.0 + +1.11.2 / 2015-05-10 +=================== + + * deps: debug@~2.2.0 + - deps: ms@0.7.1 + * deps: uid-safe@~2.0.0 + +1.11.1 / 2015-04-08 +=================== + + * Fix mutating `options.secret` value + +1.11.0 / 2015-04-07 +=================== + + * Support an array in `secret` option for key rotation + * deps: depd@~1.0.1 + +1.10.4 / 2015-03-15 +=================== + + * deps: debug@~2.1.3 + - Fix high intensity foreground color for bold + - deps: ms@0.7.0 + +1.10.3 / 2015-02-16 +=================== + + * deps: cookie-signature@1.0.6 + * deps: uid-safe@1.1.0 + - Use `crypto.randomBytes`, if available + - deps: base64-url@1.2.1 + +1.10.2 / 2015-01-31 +=================== + + * deps: uid-safe@1.0.3 + - Fix error branch that would throw + - deps: base64-url@1.2.0 + +1.10.1 / 2015-01-08 +=================== + + * deps: uid-safe@1.0.2 + - Remove dependency on `mz` + +1.10.0 / 2015-01-05 +=================== + + * Add `store.touch` interface for session stores + * Fix `MemoryStore` expiration with `resave: false` + * deps: debug@~2.1.1 + +1.9.3 / 2014-12-02 +================== + + * Fix error when `req.sessionID` contains a non-string value + +1.9.2 / 2014-11-22 +================== + + * deps: crc@3.2.1 + - Minor fixes + +1.9.1 / 2014-10-22 +================== + + * Remove unnecessary empty write call + - Fixes Node.js 0.11.14 behavior change + - Helps work-around Node.js 0.10.1 zlib bug + +1.9.0 / 2014-09-16 +================== + + * deps: debug@~2.1.0 + - Implement `DEBUG_FD` env variable support + * deps: depd@~1.0.0 + +1.8.2 / 2014-09-15 +================== + + * Use `crc` instead of `buffer-crc32` for speed + * deps: depd@0.4.5 + +1.8.1 / 2014-09-08 +================== + + * Keep `req.session.save` non-enumerable + * Prevent session prototype methods from being overwritten + +1.8.0 / 2014-09-07 +================== + + * Do not resave already-saved session at end of request + * deps: cookie-signature@1.0.5 + * deps: debug@~2.0.0 + +1.7.6 / 2014-08-18 +================== + + * Fix exception on `res.end(null)` calls + +1.7.5 / 2014-08-10 +================== + + * Fix parsing original URL + * deps: on-headers@~1.0.0 + * deps: parseurl@~1.3.0 + +1.7.4 / 2014-08-05 +================== + + * Fix response end delay for non-chunked responses + +1.7.3 / 2014-08-05 +================== + + * Fix `res.end` patch to call correct upstream `res.write` + +1.7.2 / 2014-07-27 +================== + + * deps: depd@0.4.4 + - Work-around v8 generating empty stack traces + +1.7.1 / 2014-07-26 +================== + + * deps: depd@0.4.3 + - Fix exception when global `Error.stackTraceLimit` is too low + +1.7.0 / 2014-07-22 +================== + + * Improve session-ending error handling + - Errors are passed to `next(err)` instead of `console.error` + * deps: debug@1.0.4 + * deps: depd@0.4.2 + - Add `TRACE_DEPRECATION` environment variable + - Remove non-standard grey color from color output + - Support `--no-deprecation` argument + - Support `--trace-deprecation` argument + +1.6.5 / 2014-07-11 +================== + + * Do not require `req.originalUrl` + * deps: debug@1.0.3 + - Add support for multiple wildcards in namespaces + +1.6.4 / 2014-07-07 +================== + + * Fix blank responses for stores with synchronous operations + +1.6.3 / 2014-07-04 +================== + + * Fix resave deprecation message + +1.6.2 / 2014-07-04 +================== + + * Fix confusing option deprecation messages + +1.6.1 / 2014-06-28 +================== + + * Fix saveUninitialized deprecation message + +1.6.0 / 2014-06-28 +================== + + * Add deprecation message to undefined `resave` option + * Add deprecation message to undefined `saveUninitialized` option + * Fix `res.end` patch to return correct value + * Fix `res.end` patch to handle multiple `res.end` calls + * Reject cookies with missing signatures + +1.5.2 / 2014-06-26 +================== + + * deps: cookie-signature@1.0.4 + - fix for timing attacks + +1.5.1 / 2014-06-21 +================== + + * Move hard-to-track-down `req.secret` deprecation message + +1.5.0 / 2014-06-19 +================== + + * Debug name is now "express-session" + * Deprecate integration with `cookie-parser` middleware + * Deprecate looking for secret in `req.secret` + * Directly read cookies; `cookie-parser` no longer required + * Directly set cookies; `res.cookie` no longer required + * Generate session IDs with `uid-safe`, faster and even less collisions + +1.4.0 / 2014-06-17 +================== + + * Add `genid` option to generate custom session IDs + * Add `saveUninitialized` option to control saving uninitialized sessions + * Add `unset` option to control unsetting `req.session` + * Generate session IDs with `rand-token` by default; reduce collisions + * deps: buffer-crc32@0.2.3 + +1.3.1 / 2014-06-14 +================== + + * Add description in package for npmjs.org listing + +1.3.0 / 2014-06-14 +================== + + * Integrate with express "trust proxy" by default + * deps: debug@1.0.2 + +1.2.1 / 2014-05-27 +================== + + * Fix `resave` such that `resave: true` works + +1.2.0 / 2014-05-19 +================== + + * Add `resave` option to control saving unmodified sessions + +1.1.0 / 2014-05-12 +================== + + * Add `name` option; replacement for `key` option + * Use `setImmediate` in MemoryStore for node.js >= 0.10 + +1.0.4 / 2014-04-27 +================== + + * deps: debug@0.8.1 + +1.0.3 / 2014-04-19 +================== + + * Use `res.cookie()` instead of `res.setHeader()` + * deps: cookie@0.1.2 + +1.0.2 / 2014-02-23 +================== + + * Add missing dependency to `package.json` + +1.0.1 / 2014-02-15 +================== + + * Add missing dependencies to `package.json` + +1.0.0 / 2014-02-15 +================== + + * Genesis from `connect` diff --git a/node_modules/express-session/LICENSE b/node_modules/express-session/LICENSE new file mode 100644 index 0000000..9b59ff8 --- /dev/null +++ b/node_modules/express-session/LICENSE @@ -0,0 +1,24 @@ +(The MIT License) + +Copyright (c) 2010 Sencha Inc. +Copyright (c) 2011 TJ Holowaychuk +Copyright (c) 2014-2015 Douglas Christopher Wilson + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/express-session/README.md b/node_modules/express-session/README.md new file mode 100644 index 0000000..f052c87 --- /dev/null +++ b/node_modules/express-session/README.md @@ -0,0 +1,675 @@ +# express-session + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Build Status][travis-image]][travis-url] +[![Test Coverage][coveralls-image]][coveralls-url] +[![Gratipay][gratipay-image]][gratipay-url] + +## Installation + +```bash +$ npm install express-session +``` + +## API + +```js +var session = require('express-session') +``` + +### session(options) + +Create a session middleware with the given `options`. + +**Note** Session data is _not_ saved in the cookie itself, just the session ID. +Session data is stored server-side. + +**Note** Since version 1.5.0, the [`cookie-parser` middleware](https://www.npmjs.com/package/cookie-parser) +no longer needs to be used for this module to work. This module now directly reads +and writes cookies on `req`/`res`. Using `cookie-parser` may result in issues +if the `secret` is not the same between this module and `cookie-parser`. + +**Warning** The default server-side session storage, `MemoryStore`, is _purposely_ +not designed for a production environment. It will leak memory under most +conditions, does not scale past a single process, and is meant for debugging and +developing. + +For a list of stores, see [compatible session stores](#compatible-session-stores). + +#### Options + +`express-session` accepts these properties in the options object. + +##### cookie + +Settings object for the session ID cookie. The default value is +`{ path: '/', httpOnly: true, secure: false, maxAge: null }`. + +The following are options that can be set in this object. + +###### domain + +Specifies the value for the `Domain` `Set-Cookie` attribute. By default, no domain +is set, and most clients will consider the cookie to apply to only the current +domain. + +###### expires + +Specifies the `Date` object to be the value for the `Expires` `Set-Cookie` attribute. +By default, no expiration is set, and most clients will consider this a +"non-persistent cookie" and will delete it on a condition like exiting a web browser +application. + +**Note** If both `expires` and `maxAge` are set in the options, then the last one +defined in the object is what is used. + +**Note** The `expires` option should not be set directly; instead only use the `maxAge` +option. + +###### httpOnly + +Specifies the `boolean` value for the `HttpOnly` `Set-Cookie` attribute. When truthy, +the `HttpOnly` attribute is set, otherwise it is not. By default, the `HttpOnly` +attribute is set. + +**Note** be careful when setting this to `true`, as compliant clients will not allow +client-side JavaScript to see the cookie in `document.cookie`. + +###### maxAge + +Specifies the `number` (in milliseconds) to use when calculating the `Expires` +`Set-Cookie` attribute. This is done by taking the current server time and adding +`maxAge` milliseconds to the value to calculate an `Expires` datetime. By default, +no maximum age is set. + +**Note** If both `expires` and `maxAge` are set in the options, then the last one +defined in the object is what is used. + +###### path + +Specifies the value for the `Path` `Set-Cookie`. By default, this is set to `'/'`, which +is the root path of the domain. + +###### sameSite + +Specifies the `boolean` or `string` to be the value for the `SameSite` `Set-Cookie` attribute. + + - `true` will set the `SameSite` attribute to `Strict` for strict same site enforcement. + - `false` will not set the `SameSite` attribute. + - `'lax'` will set the `SameSite` attribute to `Lax` for lax same site enforcement. + - `'strict'` will set the `SameSite` attribute to `Strict` for strict same site enforcement. + +More information about the different enforcement levels can be found in the specification +https://tools.ietf.org/html/draft-west-first-party-cookies-07#section-4.1.1 + +**Note** This is an attribute that has not yet been fully standardized, and may change in +the future. This also means many clients may ignore this attribute until they understand it. + +###### secure + +Specifies the `boolean` value for the `Secure` `Set-Cookie` attribute. When truthy, +the `Secure` attribute is set, otherwise it is not. By default, the `Secure` +attribute is not set. + +**Note** be careful when setting this to `true`, as compliant clients will not send +the cookie back to the server in the future if the browser does not have an HTTPS +connection. + +Please note that `secure: true` is a **recommended** option. However, it requires +an https-enabled website, i.e., HTTPS is necessary for secure cookies. If `secure` +is set, and you access your site over HTTP, the cookie will not be set. If you +have your node.js behind a proxy and are using `secure: true`, you need to set +"trust proxy" in express: + +```js +var app = express() +app.set('trust proxy', 1) // trust first proxy +app.use(session({ + secret: 'keyboard cat', + resave: false, + saveUninitialized: true, + cookie: { secure: true } +})) +``` + +For using secure cookies in production, but allowing for testing in development, +the following is an example of enabling this setup based on `NODE_ENV` in express: + +```js +var app = express() +var sess = { + secret: 'keyboard cat', + cookie: {} +} + +if (app.get('env') === 'production') { + app.set('trust proxy', 1) // trust first proxy + sess.cookie.secure = true // serve secure cookies +} + +app.use(session(sess)) +``` + +The `cookie.secure` option can also be set to the special value `'auto'` to have +this setting automatically match the determined security of the connection. Be +careful when using this setting if the site is available both as HTTP and HTTPS, +as once the cookie is set on HTTPS, it will no longer be visible over HTTP. This +is useful when the Express `"trust proxy"` setting is properly setup to simplify +development vs production configuration. + +##### genid + +Function to call to generate a new session ID. Provide a function that returns +a string that will be used as a session ID. The function is given `req` as the +first argument if you want to use some value attached to `req` when generating +the ID. + +The default value is a function which uses the `uid-safe` library to generate IDs. + +**NOTE** be careful to generate unique IDs so your sessions do not conflict. + +```js +app.use(session({ + genid: function(req) { + return genuuid() // use UUIDs for session IDs + }, + secret: 'keyboard cat' +})) +``` + +##### name + +The name of the session ID cookie to set in the response (and read from in the +request). + +The default value is `'connect.sid'`. + +**Note** if you have multiple apps running on the same hostname (this is just +the name, i.e. `localhost` or `127.0.0.1`; different schemes and ports do not +name a different hostname), then you need to separate the session cookies from +each other. The simplest method is to simply set different `name`s per app. + +##### proxy + +Trust the reverse proxy when setting secure cookies (via the "X-Forwarded-Proto" +header). + +The default value is `undefined`. + + - `true` The "X-Forwarded-Proto" header will be used. + - `false` All headers are ignored and the connection is considered secure only + if there is a direct TLS/SSL connection. + - `undefined` Uses the "trust proxy" setting from express + +##### resave + +Forces the session to be saved back to the session store, even if the session +was never modified during the request. Depending on your store this may be +necessary, but it can also create race conditions where a client makes two +parallel requests to your server and changes made to the session in one +request may get overwritten when the other request ends, even if it made no +changes (this behavior also depends on what store you're using). + +The default value is `true`, but using the default has been deprecated, +as the default will change in the future. Please research into this setting +and choose what is appropriate to your use-case. Typically, you'll want +`false`. + +How do I know if this is necessary for my store? The best way to know is to +check with your store if it implements the `touch` method. If it does, then +you can safely set `resave: false`. If it does not implement the `touch` +method and your store sets an expiration date on stored sessions, then you +likely need `resave: true`. + +##### rolling + +Force a session identifier cookie to be set on every response. The expiration +is reset to the original [`maxAge`](#cookiemaxage), resetting the expiration +countdown. + +The default value is `false`. + +**Note** When this option is set to `true` but the `saveUninitialized` option is +set to `false`, the cookie will not be set on a response with an uninitialized +session. + +##### saveUninitialized + +Forces a session that is "uninitialized" to be saved to the store. A session is +uninitialized when it is new but not modified. Choosing `false` is useful for +implementing login sessions, reducing server storage usage, or complying with +laws that require permission before setting a cookie. Choosing `false` will also +help with race conditions where a client makes multiple parallel requests +without a session. + +The default value is `true`, but using the default has been deprecated, as the +default will change in the future. Please research into this setting and +choose what is appropriate to your use-case. + +**Note** if you are using Session in conjunction with PassportJS, Passport +will add an empty Passport object to the session for use after a user is +authenticated, which will be treated as a modification to the session, causing +it to be saved. *This has been fixed in PassportJS 0.3.0* + +##### secret + +**Required option** + +This is the secret used to sign the session ID cookie. This can be either a string +for a single secret, or an array of multiple secrets. If an array of secrets is +provided, only the first element will be used to sign the session ID cookie, while +all the elements will be considered when verifying the signature in requests. + +##### store + +The session store instance, defaults to a new `MemoryStore` instance. + +##### unset + +Control the result of unsetting `req.session` (through `delete`, setting to `null`, +etc.). + +The default value is `'keep'`. + + - `'destroy'` The session will be destroyed (deleted) when the response ends. + - `'keep'` The session in the store will be kept, but modifications made during + the request are ignored and not saved. + +### req.session + +To store or access session data, simply use the request property `req.session`, +which is (generally) serialized as JSON by the store, so nested objects +are typically fine. For example below is a user-specific view counter: + +```js +// Use the session middleware +app.use(session({ secret: 'keyboard cat', cookie: { maxAge: 60000 }})) + +// Access the session as req.session +app.get('/', function(req, res, next) { + var sess = req.session + if (sess.views) { + sess.views++ + res.setHeader('Content-Type', 'text/html') + res.write('

views: ' + sess.views + '

') + res.write('

expires in: ' + (sess.cookie.maxAge / 1000) + 's

') + res.end() + } else { + sess.views = 1 + res.end('welcome to the session demo. refresh!') + } +}) +``` + +#### Session.regenerate() + +To regenerate the session simply invoke the method. Once complete, +a new SID and `Session` instance will be initialized at `req.session`. + +```js +req.session.regenerate(function(err) { + // will have a new session here +}) +``` + +#### Session.destroy() + +Destroys the session, removing `req.session`; will be re-generated next request. + +```js +req.session.destroy(function(err) { + // cannot access session here +}) +``` + +#### Session.reload() + +Reloads the session data. + +```js +req.session.reload(function(err) { + // session updated +}) +``` + +#### Session.save() + +Save the session back to the store, replacing the contents on the store with the +contents in memory (though a store may do something else--consult the store's +documentation for exact behavior). + +This method is automatically called at the end of the HTTP response if the +session data has been altered (though this behavior can be altered with various +options in the middleware constructor). Because of this, typically this method +does not need to be called. + +There are some cases where it is useful to call this method, for example, long- +lived requests or in WebSockets. + +```js +req.session.save(function(err) { + // session saved +}) +``` + +#### Session.touch() + +Updates the `.maxAge` property. Typically this is +not necessary to call, as the session middleware does this for you. + +### req.session.id + +Each session has a unique ID associated with it. This property will +contain the session ID and cannot be modified. + +### req.session.cookie + +Each session has a unique cookie object accompany it. This allows +you to alter the session cookie per visitor. For example we can +set `req.session.cookie.expires` to `false` to enable the cookie +to remain for only the duration of the user-agent. + +#### Cookie.maxAge + +Alternatively `req.session.cookie.maxAge` will return the time +remaining in milliseconds, which we may also re-assign a new value +to adjust the `.expires` property appropriately. The following +are essentially equivalent + +```js +var hour = 3600000 +req.session.cookie.expires = new Date(Date.now() + hour) +req.session.cookie.maxAge = hour +``` + +For example when `maxAge` is set to `60000` (one minute), and 30 seconds +has elapsed it will return `30000` until the current request has completed, +at which time `req.session.touch()` is called to reset `req.session.maxAge` +to its original value. + +```js +req.session.cookie.maxAge // => 30000 +``` + +### req.sessionID + +To get the ID of the loaded session, access the request property +`req.sessionID`. This is simply a read-only value set when a session +is loaded/created. + +## Session Store Implementation + +Every session store _must_ be an `EventEmitter` and implement specific +methods. The following methods are the list of **required**, **recommended**, +and **optional**. + + * Required methods are ones that this module will always call on the store. + * Recommended methods are ones that this module will call on the store if + available. + * Optional methods are ones this module does not call at all, but helps + present uniform stores to users. + +For an example implementation view the [connect-redis](http://github.com/visionmedia/connect-redis) repo. + +### store.all(callback) + +**Optional** + +This optional method is used to get all sessions in the store as an array. The +`callback` should be called as `callback(error, sessions)`. + +### store.destroy(sid, callback) + +**Required** + +This required method is used to destroy/delete a session from the store given +a session ID (`sid`). The `callback` should be called as `callback(error)` once +the session is destroyed. + +### store.clear(callback) + +**Optional** + +This optional method is used to delete all sessions from the store. The +`callback` should be called as `callback(error)` once the store is cleared. + +### store.length(callback) + +**Optional** + +This optional method is used to get the count of all sessions in the store. +The `callback` should be called as `callback(error, len)`. + +### store.get(sid, callback) + +**Required** + +This required method is used to get a session from the store given a session +ID (`sid`). The `callback` should be called as `callback(error, session)`. + +The `session` argument should be a session if found, otherwise `null` or +`undefined` if the session was not found (and there was no error). A special +case is made when `error.code === 'ENOENT'` to act like `callback(null, null)`. + +### store.set(sid, session, callback) + +**Required** + +This required method is used to upsert a session into the store given a +session ID (`sid`) and session (`session`) object. The callback should be +called as `callback(error)` once the session has been set in the store. + +### store.touch(sid, session, callback) + +**Recommended** + +This recommended method is used to "touch" a given session given a +session ID (`sid`) and session (`session`) object. The `callback` should be +called as `callback(error)` once the session has been touched. + +This is primarily used when the store will automatically delete idle sessions +and this method is used to signal to the store the given session is active, +potentially resetting the idle timer. + +## Compatible Session Stores + +The following modules implement a session store that is compatible with this +module. Please make a PR to add additional modules :) + +[![★][aerospike-session-store-image] aerospike-session-store][aerospike-session-store-url] A session store using [Aerospike](http://www.aerospike.com/). + +[aerospike-session-store-url]: https://www.npmjs.com/package/aerospike-session-store +[aerospike-session-store-image]: https://img.shields.io/github/stars/aerospike/aerospike-session-store-expressjs.svg?label=%E2%98%85 + +[![★][cassandra-store-image] cassandra-store][cassandra-store-url] An Apache Cassandra-based session store. + +[cassandra-store-url]: https://www.npmjs.com/package/cassandra-store +[cassandra-store-image]: https://img.shields.io/github/stars/webcc/cassandra-store.svg?label=%E2%98%85 + +[![★][cluster-store-image] cluster-store][cluster-store-url] A wrapper for using in-process / embedded +stores - such as SQLite (via knex), leveldb, files, or memory - with node cluster (desirable for Raspberry Pi 2 +and other multi-core embedded devices). + +[cluster-store-url]: https://www.npmjs.com/package/cluster-store +[cluster-store-image]: https://img.shields.io/github/stars/coolaj86/cluster-store.svg?label=%E2%98%85 + +[![★][connect-azuretables-image] connect-azuretables][connect-azuretables-url] An [Azure Table Storage](https://azure.microsoft.com/en-gb/services/storage/tables/)-based session store. + +[connect-azuretables-url]: https://www.npmjs.com/package/connect-azuretables +[connect-azuretables-image]: https://img.shields.io/github/stars/mike-goodwin/connect-azuretables.svg?label=%E2%98%85 + +[![★][connect-couchbase-image] connect-couchbase][connect-couchbase-url] A [couchbase](http://www.couchbase.com/)-based session store. + +[connect-couchbase-url]: https://www.npmjs.com/package/connect-couchbase +[connect-couchbase-image]: https://img.shields.io/github/stars/christophermina/connect-couchbase.svg?label=%E2%98%85 + +[![★][connect-db2-image] connect-db2][connect-db2-url] An IBM DB2-based session store built using [ibm_db](https://www.npmjs.com/package/ibm_db) module. + +[connect-db2-url]: https://www.npmjs.com/package/connect-db2 +[connect-db2-image]: https://img.shields.io/github/stars/wallali/connect-db2.svg?label=%E2%98%85 + +[![★][connect-dynamodb-image] connect-dynamodb][connect-dynamodb-url] A DynamoDB-based session store. + +[connect-dynamodb-url]: https://github.com/ca98am79/connect-dynamodb +[connect-dynamodb-image]: https://img.shields.io/github/stars/ca98am79/connect-dynamodb.svg?label=%E2%98%85 + +[![★][connect-loki-image] connect-loki][connect-loki-url] A Loki.js-based session store. + +[connect-loki-url]: https://www.npmjs.com/package/connect-loki +[connect-loki-image]: https://img.shields.io/github/stars/Requarks/connect-loki.svg?label=%E2%98%85 + +[![★][connect-mssql-image] connect-mssql][connect-mssql-url] A SQL Server-based session store. + +[connect-mssql-url]: https://www.npmjs.com/package/connect-mssql +[connect-mssql-image]: https://img.shields.io/github/stars/patriksimek/connect-mssql.svg?label=%E2%98%85 + +[![★][connect-monetdb-image] connect-monetdb][connect-monetdb-url] A MonetDB-based session store. + +[connect-monetdb-url]: https://www.npmjs.com/package/connect-monetdb +[connect-monetdb-image]: https://img.shields.io/github/stars/MonetDB/npm-connect-monetdb.svg?label=%E2%98%85 + +[![★][connect-mongo-image] connect-mongo][connect-mongo-url] A MongoDB-based session store. + +[connect-mongo-url]: https://www.npmjs.com/package/connect-mongo +[connect-mongo-image]: https://img.shields.io/github/stars/kcbanner/connect-mongo.svg?label=%E2%98%85 + +[![★][connect-mongodb-session-image] connect-mongodb-session][connect-mongodb-session-url] Lightweight MongoDB-based session store built and maintained by MongoDB. + +[connect-mongodb-session-url]: https://www.npmjs.com/package/connect-mongodb-session +[connect-mongodb-session-image]: https://img.shields.io/github/stars/mongodb-js/connect-mongodb-session.svg?label=%E2%98%85 + +[![★][connect-pg-simple-image] connect-pg-simple][connect-pg-simple-url] A PostgreSQL-based session store. + +[connect-pg-simple-url]: https://www.npmjs.com/package/connect-pg-simple +[connect-pg-simple-image]: https://img.shields.io/github/stars/voxpelli/node-connect-pg-simple.svg?label=%E2%98%85 + +[![★][connect-redis-image] connect-redis][connect-redis-url] A Redis-based session store. + +[connect-redis-url]: https://www.npmjs.com/package/connect-redis +[connect-redis-image]: https://img.shields.io/github/stars/tj/connect-redis.svg?label=%E2%98%85 + +[![★][connect-memcached-image] connect-memcached][connect-memcached-url] A memcached-based session store. + +[connect-memcached-url]: https://www.npmjs.com/package/connect-memcached +[connect-memcached-image]: https://img.shields.io/github/stars/balor/connect-memcached.svg?label=%E2%98%85 + +[![★][connect-session-knex-image] connect-session-knex][connect-session-knex-url] A session store using +[Knex.js](http://knexjs.org/), which is a SQL query builder for PostgreSQL, MySQL, MariaDB, SQLite3, and Oracle. + +[connect-session-knex-url]: https://www.npmjs.com/package/connect-session-knex +[connect-session-knex-image]: https://img.shields.io/github/stars/llambda/connect-session-knex.svg?label=%E2%98%85 + +[![★][connect-session-sequelize-image] connect-session-sequelize][connect-session-sequelize-url] A session store using +[Sequelize.js](http://sequelizejs.com/), which is a Node.js / io.js ORM for PostgreSQL, MySQL, SQLite and MSSQL. + +[connect-session-sequelize-url]: https://www.npmjs.com/package/connect-session-sequelize +[connect-session-sequelize-image]: https://img.shields.io/github/stars/mweibel/connect-session-sequelize.svg?label=%E2%98%85 + +[![★][express-mysql-session-image] express-mysql-session][express-mysql-session-url] A session store using native +[MySQL](https://www.mysql.com/) via the [node-mysql](https://github.com/felixge/node-mysql) module. + +[express-mysql-session-url]: https://www.npmjs.com/package/express-mysql-session +[express-mysql-session-image]: https://img.shields.io/github/stars/chill117/express-mysql-session.svg?label=%E2%98%85 + +[![★][connect-sqlite3-image] connect-sqlite3][connect-sqlite3-url] A [SQLite3](https://github.com/mapbox/node-sqlite3) session store modeled after the TJ's `connect-redis` store. + +[connect-sqlite3-url]: https://www.npmjs.com/package/connect-sqlite3 +[connect-sqlite3-image]: https://img.shields.io/github/stars/rawberg/connect-sqlite3.svg?label=%E2%98%85 + +[![★][express-nedb-session-image] express-nedb-session][express-nedb-session-url] A NeDB-based session store. + +[express-nedb-session-url]: https://www.npmjs.com/package/express-nedb-session +[express-nedb-session-image]: https://img.shields.io/github/stars/louischatriot/express-nedb-session.svg?label=%E2%98%85 + +[![★][level-session-store-image] level-session-store][level-session-store-url] A LevelDB-based session store. + +[level-session-store-url]: https://www.npmjs.com/package/level-session-store +[level-session-store-image]: https://img.shields.io/github/stars/scriptollc/level-session-store.svg?label=%E2%98%85 + +[![★][medea-session-store-image] medea-session-store][medea-session-store-url] A Medea-based session store. + +[medea-session-store-url]: https://www.npmjs.com/package/medea-session-store +[medea-session-store-image]: https://img.shields.io/github/stars/BenjaminVadant/medea-session-store.svg?label=%E2%98%85 + +[![★][mssql-session-store-image] mssql-session-store][mssql-session-store-url] A SQL Server-based session store. + +[mssql-session-store-url]: https://www.npmjs.com/package/mssql-session-store +[mssql-session-store-image]: https://img.shields.io/github/stars/jwathen/mssql-session-store.svg?label=%E2%98%85 + +[![★][nedb-session-store-image] nedb-session-store][nedb-session-store-url] An alternate NeDB-based (either in-memory or file-persisted) session store. + +[nedb-session-store-url]: https://www.npmjs.com/package/nedb-session-store +[nedb-session-store-image]: https://img.shields.io/github/stars/JamesMGreene/nedb-session-store.svg?label=%E2%98%85 + +[![★][sequelstore-connect-image] sequelstore-connect][sequelstore-connect-url] A session store using [Sequelize.js](http://sequelizejs.com/). + +[sequelstore-connect-url]: https://www.npmjs.com/package/sequelstore-connect +[sequelstore-connect-image]: https://img.shields.io/github/stars/MattMcFarland/sequelstore-connect.svg?label=%E2%98%85 + +[![★][session-file-store-image] session-file-store][session-file-store-url] A file system-based session store. + +[session-file-store-url]: https://www.npmjs.com/package/session-file-store +[session-file-store-image]: https://img.shields.io/github/stars/valery-barysok/session-file-store.svg?label=%E2%98%85 + +[![★][session-rethinkdb-image] session-rethinkdb][session-rethinkdb-url] A [RethinkDB](http://rethinkdb.com/)-based session store. + +[session-rethinkdb-url]: https://www.npmjs.com/package/session-rethinkdb +[session-rethinkdb-image]: https://img.shields.io/github/stars/llambda/session-rethinkdb.svg?label=%E2%98%85 + +## Example + +A simple example using `express-session` to store page views for a user. + +```js +var express = require('express') +var parseurl = require('parseurl') +var session = require('express-session') + +var app = express() + +app.use(session({ + secret: 'keyboard cat', + resave: false, + saveUninitialized: true +})) + +app.use(function (req, res, next) { + var views = req.session.views + + if (!views) { + views = req.session.views = {} + } + + // get the url pathname + var pathname = parseurl(req).pathname + + // count the views + views[pathname] = (views[pathname] || 0) + 1 + + next() +}) + +app.get('/foo', function (req, res, next) { + res.send('you viewed this page ' + req.session.views['/foo'] + ' times') +}) + +app.get('/bar', function (req, res, next) { + res.send('you viewed this page ' + req.session.views['/bar'] + ' times') +}) +``` + +## License + +[MIT](LICENSE) + +[npm-image]: https://img.shields.io/npm/v/express-session.svg +[npm-url]: https://npmjs.org/package/express-session +[travis-image]: https://img.shields.io/travis/expressjs/session/master.svg +[travis-url]: https://travis-ci.org/expressjs/session +[coveralls-image]: https://img.shields.io/coveralls/expressjs/session/master.svg +[coveralls-url]: https://coveralls.io/r/expressjs/session?branch=master +[downloads-image]: https://img.shields.io/npm/dm/express-session.svg +[downloads-url]: https://npmjs.org/package/express-session +[gratipay-image]: https://img.shields.io/gratipay/dougwilson.svg +[gratipay-url]: https://gratipay.com/dougwilson/ diff --git a/node_modules/express-session/index.js b/node_modules/express-session/index.js new file mode 100644 index 0000000..2241d97 --- /dev/null +++ b/node_modules/express-session/index.js @@ -0,0 +1,647 @@ +/*! + * express-session + * Copyright(c) 2010 Sencha Inc. + * Copyright(c) 2011 TJ Holowaychuk + * Copyright(c) 2014-2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict'; + +/** + * Module dependencies. + * @private + */ + +var cookie = require('cookie'); +var crc = require('crc').crc32; +var debug = require('debug')('express-session'); +var deprecate = require('depd')('express-session'); +var parseUrl = require('parseurl'); +var uid = require('uid-safe').sync + , onHeaders = require('on-headers') + , signature = require('cookie-signature') + +var Session = require('./session/session') + , MemoryStore = require('./session/memory') + , Cookie = require('./session/cookie') + , Store = require('./session/store') + +// environment + +var env = process.env.NODE_ENV; + +/** + * Expose the middleware. + */ + +exports = module.exports = session; + +/** + * Expose constructors. + */ + +exports.Store = Store; +exports.Cookie = Cookie; +exports.Session = Session; +exports.MemoryStore = MemoryStore; + +/** + * Warning message for `MemoryStore` usage in production. + * @private + */ + +var warning = 'Warning: connect.session() MemoryStore is not\n' + + 'designed for a production environment, as it will leak\n' + + 'memory, and will not scale past a single process.'; + +/** + * Node.js 0.8+ async implementation. + * @private + */ + +/* istanbul ignore next */ +var defer = typeof setImmediate === 'function' + ? setImmediate + : function(fn){ process.nextTick(fn.bind.apply(fn, arguments)) } + +/** + * Setup session store with the given `options`. + * + * @param {Object} [options] + * @param {Object} [options.cookie] Options for cookie + * @param {Function} [options.genid] + * @param {String} [options.name=connect.sid] Session ID cookie name + * @param {Boolean} [options.proxy] + * @param {Boolean} [options.resave] Resave unmodified sessions back to the store + * @param {Boolean} [options.rolling] Enable/disable rolling session expiration + * @param {Boolean} [options.saveUninitialized] Save uninitialized sessions to the store + * @param {String|Array} [options.secret] Secret for signing session ID + * @param {Object} [options.store=MemoryStore] Session store + * @param {String} [options.unset] + * @return {Function} middleware + * @public + */ + +function session(options) { + var opts = options || {} + + // get the cookie options + var cookieOptions = opts.cookie || {} + + // get the session id generate function + var generateId = opts.genid || generateSessionId + + // get the session cookie name + var name = opts.name || opts.key || 'connect.sid' + + // get the session store + var store = opts.store || new MemoryStore() + + // get the trust proxy setting + var trustProxy = opts.proxy + + // get the resave session option + var resaveSession = opts.resave; + + // get the rolling session option + var rollingSessions = Boolean(opts.rolling) + + // get the save uninitialized session option + var saveUninitializedSession = opts.saveUninitialized + + // get the cookie signing secret + var secret = opts.secret + + if (typeof generateId !== 'function') { + throw new TypeError('genid option must be a function'); + } + + if (resaveSession === undefined) { + deprecate('undefined resave option; provide resave option'); + resaveSession = true; + } + + if (saveUninitializedSession === undefined) { + deprecate('undefined saveUninitialized option; provide saveUninitialized option'); + saveUninitializedSession = true; + } + + if (opts.unset && opts.unset !== 'destroy' && opts.unset !== 'keep') { + throw new TypeError('unset option must be "destroy" or "keep"'); + } + + // TODO: switch to "destroy" on next major + var unsetDestroy = opts.unset === 'destroy' + + if (Array.isArray(secret) && secret.length === 0) { + throw new TypeError('secret option array must contain one or more strings'); + } + + if (secret && !Array.isArray(secret)) { + secret = [secret]; + } + + if (!secret) { + deprecate('req.secret; provide secret option'); + } + + // notify user that this store is not + // meant for a production environment + if ('production' == env && store instanceof MemoryStore) { + /* istanbul ignore next: not tested */ + console.warn(warning); + } + + // generates the new session + store.generate = function(req){ + req.sessionID = generateId(req); + req.session = new Session(req); + req.session.cookie = new Cookie(cookieOptions); + + if (cookieOptions.secure === 'auto') { + req.session.cookie.secure = issecure(req, trustProxy); + } + }; + + var storeImplementsTouch = typeof store.touch === 'function'; + + // register event listeners for the store to track readiness + var storeReady = true + store.on('disconnect', function ondisconnect() { + storeReady = false + }) + store.on('connect', function onconnect() { + storeReady = true + }) + + return function session(req, res, next) { + // self-awareness + if (req.session) { + next() + return + } + + // Handle connection as if there is no session if + // the store has temporarily disconnected etc + if (!storeReady) { + debug('store is disconnected') + next() + return + } + + // pathname mismatch + var originalPath = parseUrl.original(req).pathname; + if (originalPath.indexOf(cookieOptions.path || '/') !== 0) return next(); + + // ensure a secret is available or bail + if (!secret && !req.secret) { + next(new Error('secret option required for sessions')); + return; + } + + // backwards compatibility for signed cookies + // req.secret is passed from the cookie parser middleware + var secrets = secret || [req.secret]; + + var originalHash; + var originalId; + var savedHash; + var touched = false + + // expose store + req.sessionStore = store; + + // get the session ID from the cookie + var cookieId = req.sessionID = getcookie(req, name, secrets); + + // set-cookie + onHeaders(res, function(){ + if (!req.session) { + debug('no session'); + return; + } + + if (!shouldSetCookie(req)) { + return; + } + + // only send secure cookies via https + if (req.session.cookie.secure && !issecure(req, trustProxy)) { + debug('not secured'); + return; + } + + if (!touched) { + // touch session + req.session.touch() + touched = true + } + + // set cookie + setcookie(res, name, req.sessionID, secrets[0], req.session.cookie.data); + }); + + // proxy end() to commit the session + var _end = res.end; + var _write = res.write; + var ended = false; + res.end = function end(chunk, encoding) { + if (ended) { + return false; + } + + ended = true; + + var ret; + var sync = true; + + function writeend() { + if (sync) { + ret = _end.call(res, chunk, encoding); + sync = false; + return; + } + + _end.call(res); + } + + function writetop() { + if (!sync) { + return ret; + } + + if (chunk == null) { + ret = true; + return ret; + } + + var contentLength = Number(res.getHeader('Content-Length')); + + if (!isNaN(contentLength) && contentLength > 0) { + // measure chunk + chunk = !Buffer.isBuffer(chunk) + ? new Buffer(chunk, encoding) + : chunk; + encoding = undefined; + + if (chunk.length !== 0) { + debug('split response'); + ret = _write.call(res, chunk.slice(0, chunk.length - 1)); + chunk = chunk.slice(chunk.length - 1, chunk.length); + return ret; + } + } + + ret = _write.call(res, chunk, encoding); + sync = false; + + return ret; + } + + if (shouldDestroy(req)) { + // destroy session + debug('destroying'); + store.destroy(req.sessionID, function ondestroy(err) { + if (err) { + defer(next, err); + } + + debug('destroyed'); + writeend(); + }); + + return writetop(); + } + + // no session to save + if (!req.session) { + debug('no session'); + return _end.call(res, chunk, encoding); + } + + if (!touched) { + // touch session + req.session.touch() + touched = true + } + + if (shouldSave(req)) { + req.session.save(function onsave(err) { + if (err) { + defer(next, err); + } + + writeend(); + }); + + return writetop(); + } else if (storeImplementsTouch && shouldTouch(req)) { + // store implements touch method + debug('touching'); + store.touch(req.sessionID, req.session, function ontouch(err) { + if (err) { + defer(next, err); + } + + debug('touched'); + writeend(); + }); + + return writetop(); + } + + return _end.call(res, chunk, encoding); + }; + + // generate the session + function generate() { + store.generate(req); + originalId = req.sessionID; + originalHash = hash(req.session); + wrapmethods(req.session); + } + + // wrap session methods + function wrapmethods(sess) { + var _save = sess.save; + + function save() { + debug('saving %s', this.id); + savedHash = hash(this); + _save.apply(this, arguments); + } + + Object.defineProperty(sess, 'save', { + configurable: true, + enumerable: false, + value: save, + writable: true + }); + } + + // check if session has been modified + function isModified(sess) { + return originalId !== sess.id || originalHash !== hash(sess); + } + + // check if session has been saved + function isSaved(sess) { + return originalId === sess.id && savedHash === hash(sess); + } + + // determine if session should be destroyed + function shouldDestroy(req) { + return req.sessionID && unsetDestroy && req.session == null; + } + + // determine if session should be saved to store + function shouldSave(req) { + // cannot set cookie without a session ID + if (typeof req.sessionID !== 'string') { + debug('session ignored because of bogus req.sessionID %o', req.sessionID); + return false; + } + + return !saveUninitializedSession && cookieId !== req.sessionID + ? isModified(req.session) + : !isSaved(req.session) + } + + // determine if session should be touched + function shouldTouch(req) { + // cannot set cookie without a session ID + if (typeof req.sessionID !== 'string') { + debug('session ignored because of bogus req.sessionID %o', req.sessionID); + return false; + } + + return cookieId === req.sessionID && !shouldSave(req); + } + + // determine if cookie should be set on response + function shouldSetCookie(req) { + // cannot set cookie without a session ID + if (typeof req.sessionID !== 'string') { + return false; + } + + return cookieId != req.sessionID + ? saveUninitializedSession || isModified(req.session) + : rollingSessions || req.session.cookie.expires != null && isModified(req.session); + } + + // generate a session if the browser doesn't send a sessionID + if (!req.sessionID) { + debug('no SID sent, generating session'); + generate(); + next(); + return; + } + + // generate the session object + debug('fetching %s', req.sessionID); + store.get(req.sessionID, function(err, sess){ + // error handling + if (err) { + debug('error %j', err); + + if (err.code !== 'ENOENT') { + next(err); + return; + } + + generate(); + // no session + } else if (!sess) { + debug('no session found'); + generate(); + // populate req.session + } else { + debug('session found'); + store.createSession(req, sess); + originalId = req.sessionID; + originalHash = hash(sess); + + if (!resaveSession) { + savedHash = originalHash + } + + wrapmethods(req.session); + } + + next(); + }); + }; +}; + +/** + * Generate a session ID for a new session. + * + * @return {String} + * @private + */ + +function generateSessionId(sess) { + return uid(24); +} + +/** + * Get the session ID cookie from request. + * + * @return {string} + * @private + */ + +function getcookie(req, name, secrets) { + var header = req.headers.cookie; + var raw; + var val; + + // read from cookie header + if (header) { + var cookies = cookie.parse(header); + + raw = cookies[name]; + + if (raw) { + if (raw.substr(0, 2) === 's:') { + val = unsigncookie(raw.slice(2), secrets); + + if (val === false) { + debug('cookie signature invalid'); + val = undefined; + } + } else { + debug('cookie unsigned') + } + } + } + + // back-compat read from cookieParser() signedCookies data + if (!val && req.signedCookies) { + val = req.signedCookies[name]; + + if (val) { + deprecate('cookie should be available in req.headers.cookie'); + } + } + + // back-compat read from cookieParser() cookies data + if (!val && req.cookies) { + raw = req.cookies[name]; + + if (raw) { + if (raw.substr(0, 2) === 's:') { + val = unsigncookie(raw.slice(2), secrets); + + if (val) { + deprecate('cookie should be available in req.headers.cookie'); + } + + if (val === false) { + debug('cookie signature invalid'); + val = undefined; + } + } else { + debug('cookie unsigned') + } + } + } + + return val; +} + +/** + * Hash the given `sess` object omitting changes to `.cookie`. + * + * @param {Object} sess + * @return {String} + * @private + */ + +function hash(sess) { + return crc(JSON.stringify(sess, function (key, val) { + if (key !== 'cookie') { + return val; + } + })); +} + +/** + * Determine if request is secure. + * + * @param {Object} req + * @param {Boolean} [trustProxy] + * @return {Boolean} + * @private + */ + +function issecure(req, trustProxy) { + // socket is https server + if (req.connection && req.connection.encrypted) { + return true; + } + + // do not trust proxy + if (trustProxy === false) { + return false; + } + + // no explicit trust; try req.secure from express + if (trustProxy !== true) { + var secure = req.secure; + return typeof secure === 'boolean' + ? secure + : false; + } + + // read the proto from x-forwarded-proto header + var header = req.headers['x-forwarded-proto'] || ''; + var index = header.indexOf(','); + var proto = index !== -1 + ? header.substr(0, index).toLowerCase().trim() + : header.toLowerCase().trim() + + return proto === 'https'; +} + +/** + * Set cookie on response. + * + * @private + */ + +function setcookie(res, name, val, secret, options) { + var signed = 's:' + signature.sign(val, secret); + var data = cookie.serialize(name, signed, options); + + debug('set-cookie %s', data); + + var prev = res.getHeader('set-cookie') || []; + var header = Array.isArray(prev) ? prev.concat(data) + : Array.isArray(data) ? [prev].concat(data) + : [prev, data]; + + res.setHeader('set-cookie', header) +} + +/** + * Verify and decode the given `val` with `secrets`. + * + * @param {String} val + * @param {Array} secrets + * @returns {String|Boolean} + * @private + */ +function unsigncookie(val, secrets) { + for (var i = 0; i < secrets.length; i++) { + var result = signature.unsign(val, secrets[i]); + + if (result !== false) { + return result; + } + } + + return false; +} diff --git a/node_modules/express-session/node_modules/cookie-signature/.npmignore b/node_modules/express-session/node_modules/cookie-signature/.npmignore new file mode 100644 index 0000000..f1250e5 --- /dev/null +++ b/node_modules/express-session/node_modules/cookie-signature/.npmignore @@ -0,0 +1,4 @@ +support +test +examples +*.sock diff --git a/node_modules/express-session/node_modules/cookie-signature/History.md b/node_modules/express-session/node_modules/cookie-signature/History.md new file mode 100644 index 0000000..78513cc --- /dev/null +++ b/node_modules/express-session/node_modules/cookie-signature/History.md @@ -0,0 +1,38 @@ +1.0.6 / 2015-02-03 +================== + +* use `npm test` instead of `make test` to run tests +* clearer assertion messages when checking input + + +1.0.5 / 2014-09-05 +================== + +* add license to package.json + +1.0.4 / 2014-06-25 +================== + + * corrected avoidance of timing attacks (thanks @tenbits!) + +1.0.3 / 2014-01-28 +================== + + * [incorrect] fix for timing attacks + +1.0.2 / 2014-01-28 +================== + + * fix missing repository warning + * fix typo in test + +1.0.1 / 2013-04-15 +================== + + * Revert "Changed underlying HMAC algo. to sha512." + * Revert "Fix for timing attacks on MAC verification." + +0.0.1 / 2010-01-03 +================== + + * Initial release diff --git a/node_modules/express-session/node_modules/cookie-signature/Readme.md b/node_modules/express-session/node_modules/cookie-signature/Readme.md new file mode 100644 index 0000000..2559e84 --- /dev/null +++ b/node_modules/express-session/node_modules/cookie-signature/Readme.md @@ -0,0 +1,42 @@ + +# cookie-signature + + Sign and unsign cookies. + +## Example + +```js +var cookie = require('cookie-signature'); + +var val = cookie.sign('hello', 'tobiiscool'); +val.should.equal('hello.DGDUkGlIkCzPz+C0B064FNgHdEjox7ch8tOBGslZ5QI'); + +var val = cookie.sign('hello', 'tobiiscool'); +cookie.unsign(val, 'tobiiscool').should.equal('hello'); +cookie.unsign(val, 'luna').should.be.false; +``` + +## License + +(The MIT License) + +Copyright (c) 2012 LearnBoost <tj@learnboost.com> + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. \ No newline at end of file diff --git a/node_modules/express-session/node_modules/cookie-signature/index.js b/node_modules/express-session/node_modules/cookie-signature/index.js new file mode 100644 index 0000000..b8c9463 --- /dev/null +++ b/node_modules/express-session/node_modules/cookie-signature/index.js @@ -0,0 +1,51 @@ +/** + * Module dependencies. + */ + +var crypto = require('crypto'); + +/** + * Sign the given `val` with `secret`. + * + * @param {String} val + * @param {String} secret + * @return {String} + * @api private + */ + +exports.sign = function(val, secret){ + if ('string' != typeof val) throw new TypeError("Cookie value must be provided as a string."); + if ('string' != typeof secret) throw new TypeError("Secret string must be provided."); + return val + '.' + crypto + .createHmac('sha256', secret) + .update(val) + .digest('base64') + .replace(/\=+$/, ''); +}; + +/** + * Unsign and decode the given `val` with `secret`, + * returning `false` if the signature is invalid. + * + * @param {String} val + * @param {String} secret + * @return {String|Boolean} + * @api private + */ + +exports.unsign = function(val, secret){ + if ('string' != typeof val) throw new TypeError("Signed cookie string must be provided."); + if ('string' != typeof secret) throw new TypeError("Secret string must be provided."); + var str = val.slice(0, val.lastIndexOf('.')) + , mac = exports.sign(str, secret); + + return sha1(mac) == sha1(val) ? str : false; +}; + +/** + * Private + */ + +function sha1(str){ + return crypto.createHash('sha1').update(str).digest('hex'); +} diff --git a/node_modules/express-session/node_modules/cookie-signature/package.json b/node_modules/express-session/node_modules/cookie-signature/package.json new file mode 100644 index 0000000..33c95c0 --- /dev/null +++ b/node_modules/express-session/node_modules/cookie-signature/package.json @@ -0,0 +1,59 @@ +{ + "name": "cookie-signature", + "version": "1.0.6", + "description": "Sign and unsign cookies", + "keywords": [ + "cookie", + "sign", + "unsign" + ], + "author": { + "name": "TJ Holowaychuk", + "email": "tj@learnboost.com" + }, + "license": "MIT", + "repository": { + "type": "git", + "url": "git+https://github.com/visionmedia/node-cookie-signature.git" + }, + "dependencies": {}, + "devDependencies": { + "mocha": "*", + "should": "*" + }, + "scripts": { + "test": "mocha --require should --reporter spec" + }, + "main": "index", + "gitHead": "391b56cf44d88c493491b7e3fc53208cfb976d2a", + "bugs": { + "url": "https://github.com/visionmedia/node-cookie-signature/issues" + }, + "homepage": "https://github.com/visionmedia/node-cookie-signature", + "_id": "cookie-signature@1.0.6", + "_shasum": "e303a882b342cc3ee8ca513a79999734dab3ae2c", + "_from": "cookie-signature@1.0.6", + "_npmVersion": "2.3.0", + "_nodeVersion": "0.10.36", + "_npmUser": { + "name": "natevw", + "email": "natevw@yahoo.com" + }, + "maintainers": [ + { + "name": "tjholowaychuk", + "email": "tj@vision-media.ca" + }, + { + "name": "natevw", + "email": "natevw@yahoo.com" + } + ], + "dist": { + "shasum": "e303a882b342cc3ee8ca513a79999734dab3ae2c", + "tarball": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/express-session/node_modules/cookie/HISTORY.md b/node_modules/express-session/node_modules/cookie/HISTORY.md new file mode 100644 index 0000000..5bd6485 --- /dev/null +++ b/node_modules/express-session/node_modules/cookie/HISTORY.md @@ -0,0 +1,118 @@ +0.3.1 / 2016-05-26 +================== + + * Fix `sameSite: true` to work with draft-7 clients + - `true` now sends `SameSite=Strict` instead of `SameSite` + +0.3.0 / 2016-05-26 +================== + + * Add `sameSite` option + - Replaces `firstPartyOnly` option, never implemented by browsers + * Improve error message when `encode` is not a function + * Improve error message when `expires` is not a `Date` + +0.2.4 / 2016-05-20 +================== + + * perf: enable strict mode + * perf: use for loop in parse + * perf: use string concatination for serialization + +0.2.3 / 2015-10-25 +================== + + * Fix cookie `Max-Age` to never be a floating point number + +0.2.2 / 2015-09-17 +================== + + * Fix regression when setting empty cookie value + - Ease the new restriction, which is just basic header-level validation + * Fix typo in invalid value errors + +0.2.1 / 2015-09-17 +================== + + * Throw on invalid values provided to `serialize` + - Ensures the resulting string is a valid HTTP header value + +0.2.0 / 2015-08-13 +================== + + * Add `firstPartyOnly` option + * Throw better error for invalid argument to parse + * perf: hoist regular expression + +0.1.5 / 2015-09-17 +================== + + * Fix regression when setting empty cookie value + - Ease the new restriction, which is just basic header-level validation + * Fix typo in invalid value errors + +0.1.4 / 2015-09-17 +================== + + * Throw better error for invalid argument to parse + * Throw on invalid values provided to `serialize` + - Ensures the resulting string is a valid HTTP header value + +0.1.3 / 2015-05-19 +================== + + * Reduce the scope of try-catch deopt + * Remove argument reassignments + +0.1.2 / 2014-04-16 +================== + + * Remove unnecessary files from npm package + +0.1.1 / 2014-02-23 +================== + + * Fix bad parse when cookie value contained a comma + * Fix support for `maxAge` of `0` + +0.1.0 / 2013-05-01 +================== + + * Add `decode` option + * Add `encode` option + +0.0.6 / 2013-04-08 +================== + + * Ignore cookie parts missing `=` + +0.0.5 / 2012-10-29 +================== + + * Return raw cookie value if value unescape errors + +0.0.4 / 2012-06-21 +================== + + * Use encode/decodeURIComponent for cookie encoding/decoding + - Improve server/client interoperability + +0.0.3 / 2012-06-06 +================== + + * Only escape special characters per the cookie RFC + +0.0.2 / 2012-06-01 +================== + + * Fix `maxAge` option to not throw error + +0.0.1 / 2012-05-28 +================== + + * Add more tests + +0.0.0 / 2012-05-28 +================== + + * Initial release diff --git a/node_modules/express-session/node_modules/cookie/LICENSE b/node_modules/express-session/node_modules/cookie/LICENSE new file mode 100644 index 0000000..058b6b4 --- /dev/null +++ b/node_modules/express-session/node_modules/cookie/LICENSE @@ -0,0 +1,24 @@ +(The MIT License) + +Copyright (c) 2012-2014 Roman Shtylman +Copyright (c) 2015 Douglas Christopher Wilson + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + diff --git a/node_modules/express-session/node_modules/cookie/README.md b/node_modules/express-session/node_modules/cookie/README.md new file mode 100644 index 0000000..db0d078 --- /dev/null +++ b/node_modules/express-session/node_modules/cookie/README.md @@ -0,0 +1,220 @@ +# cookie + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Node.js Version][node-version-image]][node-version-url] +[![Build Status][travis-image]][travis-url] +[![Test Coverage][coveralls-image]][coveralls-url] + +Basic HTTP cookie parser and serializer for HTTP servers. + +## Installation + +```sh +$ npm install cookie +``` + +## API + +```js +var cookie = require('cookie'); +``` + +### cookie.parse(str, options) + +Parse an HTTP `Cookie` header string and returning an object of all cookie name-value pairs. +The `str` argument is the string representing a `Cookie` header value and `options` is an +optional object containing additional parsing options. + +```js +var cookies = cookie.parse('foo=bar; equation=E%3Dmc%5E2'); +// { foo: 'bar', equation: 'E=mc^2' } +``` + +#### Options + +`cookie.parse` accepts these properties in the options object. + +##### decode + +Specifies a function that will be used to decode a cookie's value. Since the value of a cookie +has a limited character set (and must be a simple string), this function can be used to decode +a previously-encoded cookie value into a JavaScript string or other object. + +The default function is the global `decodeURIComponent`, which will decode any URL-encoded +sequences into their byte representations. + +**note** if an error is thrown from this function, the original, non-decoded cookie value will +be returned as the cookie's value. + +### cookie.serialize(name, value, options) + +Serialize a cookie name-value pair into a `Set-Cookie` header string. The `name` argument is the +name for the cookie, the `value` argument is the value to set the cookie to, and the `options` +argument is an optional object containing additional serialization options. + +```js +var setCookie = cookie.serialize('foo', 'bar'); +// foo=bar +``` + +#### Options + +`cookie.serialize` accepts these properties in the options object. + +##### domain + +Specifies the value for the [`Domain` `Set-Cookie` attribute][rfc-6266-5.2.3]. By default, no +domain is set, and most clients will consider the cookie to apply to only the current domain. + +##### encode + +Specifies a function that will be used to encode a cookie's value. Since value of a cookie +has a limited character set (and must be a simple string), this function can be used to encode +a value into a string suited for a cookie's value. + +The default function is the global `ecodeURIComponent`, which will encode a JavaScript string +into UTF-8 byte sequences and then URL-encode any that fall outside of the cookie range. + +##### expires + +Specifies the `Date` object to be the value for the [`Expires` `Set-Cookie` attribute][rfc-6266-5.2.1]. +By default, no expiration is set, and most clients will consider this a "non-persistent cookie" and +will delete it on a condition like exiting a web browser application. + +**note** the [cookie storage model specification][rfc-6266-5.3] states that if both `expires` and +`magAge` are set, then `maxAge` takes precedence, but it is possiblke not all clients by obey this, +so if both are set, they should point to the same date and time. + +##### httpOnly + +Specifies the `boolean` value for the [`HttpOnly` `Set-Cookie` attribute][rfc-6266-5.2.6]. When truthy, +the `HttpOnly` attribute is set, otherwise it is not. By default, the `HttpOnly` attribute is not set. + +**note** be careful when setting this to `true`, as compliant clients will not allow client-side +JavaScript to see the cookie in `document.cookie`. + +##### maxAge + +Specifies the `number` (in seconds) to be the value for the [`Max-Age` `Set-Cookie` attribute][rfc-6266-5.2.2]. +The given number will be converted to an integer by rounding down. By default, no maximum age is set. + +**note** the [cookie storage model specification][rfc-6266-5.3] states that if both `expires` and +`magAge` are set, then `maxAge` takes precedence, but it is possiblke not all clients by obey this, +so if both are set, they should point to the same date and time. + +##### path + +Specifies the value for the [`Path` `Set-Cookie` attribute][rfc-6266-5.2.4]. By default, the path +is considered the ["default path"][rfc-6266-5.1.4]. By default, no maximum age is set, and most +clients will consider this a "non-persistent cookie" and will delete it on a condition like exiting +a web browser application. + +##### sameSite + +Specifies the `boolean` or `string` to be the value for the [`SameSite` `Set-Cookie` attribute][draft-west-first-party-cookies-07]. + + - `true` will set the `SameSite` attribute to `Strict` for strict same site enforcement. + - `false` will not set the `SameSite` attribute. + - `'lax'` will set the `SameSite` attribute to `Lax` for lax same site enforcement. + - `'strict'` will set the `SameSite` attribute to `Strict` for strict same site enforcement. + +More information about the different enforcement levels can be found in the specification +https://tools.ietf.org/html/draft-west-first-party-cookies-07#section-4.1.1 + +**note** This is an attribute that has not yet been fully standardized, and may change in the future. +This also means many clients may ignore this attribute until they understand it. + +##### secure + +Specifies the `boolean` value for the [`Secure` `Set-Cookie` attribute][rfc-6266-5.2.5]. When truthy, +the `Secure` attribute is set, otherwise it is not. By default, the `Secure` attribute is not set. + +**note** be careful when setting this to `true`, as compliant clients will not send the cookie back to +the server in the future if the browser does not have an HTTPS connection. + +## Example + +The following example uses this module in conjunction with the Node.js core HTTP server +to prompt a user for their name and display it back on future visits. + +```js +var cookie = require('cookie'); +var escapeHtml = require('escape-html'); +var http = require('http'); +var url = require('url'); + +function onRequest(req, res) { + // Parse the query string + var query = url.parse(req.url, true, true).query; + + if (query && query.name) { + // Set a new cookie with the name + res.setHeader('Set-Cookie', cookie.serialize('name', String(query.name), { + httpOnly: true, + maxAge: 60 * 60 * 24 * 7 // 1 week + })); + + // Redirect back after setting cookie + res.statusCode = 302; + res.setHeader('Location', req.headers.referer || '/'); + res.end(); + return; + } + + // Parse the cookies on the request + var cookies = cookie.parse(req.headers.cookie || ''); + + // Get the visitor name set in the cookie + var name = cookies.name; + + res.setHeader('Content-Type', 'text/html; charset=UTF-8'); + + if (name) { + res.write('

Welcome back, ' + escapeHtml(name) + '!

'); + } else { + res.write('

Hello, new visitor!

'); + } + + res.write(''); + res.write(' '); + res.end(' values + * + * @param {string} str + * @param {object} [options] + * @return {object} + * @public + */ + +function parse(str, options) { + if (typeof str !== 'string') { + throw new TypeError('argument str must be a string'); + } + + var obj = {} + var opt = options || {}; + var pairs = str.split(pairSplitRegExp); + var dec = opt.decode || decode; + + for (var i = 0; i < pairs.length; i++) { + var pair = pairs[i]; + var eq_idx = pair.indexOf('='); + + // skip things that don't look like key=value + if (eq_idx < 0) { + continue; + } + + var key = pair.substr(0, eq_idx).trim() + var val = pair.substr(++eq_idx, pair.length).trim(); + + // quoted values + if ('"' == val[0]) { + val = val.slice(1, -1); + } + + // only assign once + if (undefined == obj[key]) { + obj[key] = tryDecode(val, dec); + } + } + + return obj; +} + +/** + * Serialize data into a cookie header. + * + * Serialize the a name value pair into a cookie string suitable for + * http headers. An optional options object specified cookie parameters. + * + * serialize('foo', 'bar', { httpOnly: true }) + * => "foo=bar; httpOnly" + * + * @param {string} name + * @param {string} val + * @param {object} [options] + * @return {string} + * @public + */ + +function serialize(name, val, options) { + var opt = options || {}; + var enc = opt.encode || encode; + + if (typeof enc !== 'function') { + throw new TypeError('option encode is invalid'); + } + + if (!fieldContentRegExp.test(name)) { + throw new TypeError('argument name is invalid'); + } + + var value = enc(val); + + if (value && !fieldContentRegExp.test(value)) { + throw new TypeError('argument val is invalid'); + } + + var str = name + '=' + value; + + if (null != opt.maxAge) { + var maxAge = opt.maxAge - 0; + if (isNaN(maxAge)) throw new Error('maxAge should be a Number'); + str += '; Max-Age=' + Math.floor(maxAge); + } + + if (opt.domain) { + if (!fieldContentRegExp.test(opt.domain)) { + throw new TypeError('option domain is invalid'); + } + + str += '; Domain=' + opt.domain; + } + + if (opt.path) { + if (!fieldContentRegExp.test(opt.path)) { + throw new TypeError('option path is invalid'); + } + + str += '; Path=' + opt.path; + } + + if (opt.expires) { + if (typeof opt.expires.toUTCString !== 'function') { + throw new TypeError('option expires is invalid'); + } + + str += '; Expires=' + opt.expires.toUTCString(); + } + + if (opt.httpOnly) { + str += '; HttpOnly'; + } + + if (opt.secure) { + str += '; Secure'; + } + + if (opt.sameSite) { + var sameSite = typeof opt.sameSite === 'string' + ? opt.sameSite.toLowerCase() : opt.sameSite; + + switch (sameSite) { + case true: + str += '; SameSite=Strict'; + break; + case 'lax': + str += '; SameSite=Lax'; + break; + case 'strict': + str += '; SameSite=Strict'; + break; + default: + throw new TypeError('option sameSite is invalid'); + } + } + + return str; +} + +/** + * Try decoding a string using a decoding function. + * + * @param {string} str + * @param {function} decode + * @private + */ + +function tryDecode(str, decode) { + try { + return decode(str); + } catch (e) { + return str; + } +} diff --git a/node_modules/express-session/node_modules/cookie/package.json b/node_modules/express-session/node_modules/cookie/package.json new file mode 100644 index 0000000..4a084e0 --- /dev/null +++ b/node_modules/express-session/node_modules/cookie/package.json @@ -0,0 +1,72 @@ +{ + "name": "cookie", + "description": "HTTP server cookie parsing and serialization", + "version": "0.3.1", + "author": { + "name": "Roman Shtylman", + "email": "shtylman@gmail.com" + }, + "contributors": [ + { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + } + ], + "license": "MIT", + "keywords": [ + "cookie", + "cookies" + ], + "repository": { + "type": "git", + "url": "git+https://github.com/jshttp/cookie.git" + }, + "devDependencies": { + "istanbul": "0.4.3", + "mocha": "1.21.5" + }, + "files": [ + "HISTORY.md", + "LICENSE", + "README.md", + "index.js" + ], + "engines": { + "node": ">= 0.6" + }, + "scripts": { + "test": "mocha --reporter spec --bail --check-leaks test/", + "test-ci": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter spec --check-leaks test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot --check-leaks test/" + }, + "gitHead": "e3c77d497d66c8b8d4b677b8954c1b192a09f0b3", + "bugs": { + "url": "https://github.com/jshttp/cookie/issues" + }, + "homepage": "https://github.com/jshttp/cookie", + "_id": "cookie@0.3.1", + "_shasum": "e7e0a1f9ef43b4c8ba925c5c5a96e806d16873bb", + "_from": "cookie@0.3.1", + "_npmVersion": "1.4.28", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "maintainers": [ + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + } + ], + "dist": { + "shasum": "e7e0a1f9ef43b4c8ba925c5c5a96e806d16873bb", + "tarball": "https://registry.npmjs.org/cookie/-/cookie-0.3.1.tgz" + }, + "_npmOperationalInternal": { + "host": "packages-12-west.internal.npmjs.com", + "tmp": "tmp/cookie-0.3.1.tgz_1464323556714_0.6435900838114321" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/cookie/-/cookie-0.3.1.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/express-session/node_modules/crc/LICENSE b/node_modules/express-session/node_modules/crc/LICENSE new file mode 100644 index 0000000..c49097c --- /dev/null +++ b/node_modules/express-session/node_modules/crc/LICENSE @@ -0,0 +1,22 @@ +The MIT License (MIT) + +Copyright 2014 Alex Gorbatchev + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +"Software"), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND +NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE +LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION +OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION +WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/express-session/node_modules/crc/README.md b/node_modules/express-session/node_modules/crc/README.md new file mode 100644 index 0000000..499b766 --- /dev/null +++ b/node_modules/express-session/node_modules/crc/README.md @@ -0,0 +1,100 @@ +# crc + +[![GitTip](http://img.shields.io/gittip/alexgorbatchev.svg?style=flat)](https://www.gittip.com/alexgorbatchev/) +[![Dependency status](http://img.shields.io/david/alexgorbatchev/node-crc.svg?style=flat)](https://david-dm.org/alexgorbatchev/node-crc) +[![devDependency Status](http://img.shields.io/david/dev/alexgorbatchev/node-crc.svg?style=flat)](https://david-dm.org/alexgorbatchev/node-crc#info=devDependencies) +[![Build Status](http://img.shields.io/travis/alexgorbatchev/node-crc.svg?style=flat&branch=master)](https://travis-ci.org/alexgorbatchev/node-crc) + +[![NPM](https://nodei.co/npm/crc.svg?style=flat)](https://npmjs.org/package/crc) + +Module for calculating Cyclic Redundancy Check (CRC) for Node.js and the Browser. + +## Features + +* Full test suite comparing values against reference `pycrc` implementation. +* Version 3.x is 3x to 4x faster than version 2.x. +* Pure JavaScript implementation, no dependencies. +* Provides CRC Tables for optimized calculations. +* Provides support for the following CRC algorithms: + * CRC1 `crc.crc1(…)` + * CRC8 `crc.crc8(…)` + * CRC8 1-Wire `crc.crc81wire(…)` + * CRC16 `crc.crc16(…)` + * CRC16 CCITT `crc.crc16ccitt(…)` + * CRC16 Modbus `crc.crc16modbus(…)` + * CRC16 Kermit `crc.crc16kermit(…)` + * CRC16 XModem `crc.crc16xmodem(…)` + * CRC24 `crc.crc24(…)` + * CRC32 `crc.crc32(…)` + +## IMPORTANT + +If you've used `crc` module prior to version 2.x, you might have some inconsistencies with the current implementation because it relied on very old code and wasn't checked against reference implementation. If you upgrading from 1.x, please take special care. + +## Support + + Please support me on [GitTip](https://www.gittip.com/alexgorbatchev/). I'm sure you know that it takes a lot of personal time to write and even more time to maintain open source projects. If you use this package, buy me a beer on GitTip or via Bitcoin [`1CZyBREeHTmy8C5zVGHZHPwqBuWFmEuUCQ`](https://blockchain.info/address/1CZyBREeHTmy8C5zVGHZHPwqBuWFmEuUCQ) + +## Installation + + npm install crc + +## Running tests + + $ npm install + $ npm test + +## Usage Example + +Calculate a CRC32: + + var crc = require('crc'); + + crc.crc32('hello').toString(16); + # => "3610a686" + +Calculate a CRC32 of a file: + + crc.crc32(fs.readFileSync('README.md', 'utf8')).toString(16); + # => "127ad531" + +Or using a `Buffer`: + + crc.crc32(fs.readFileSync('README.md')).toString(16); + # => "127ad531" + +Incrementally calculate a CRC32: + + value = crc.crc32('one'); + value = crc.crc32('two', value); + value = crc.crc32('three', value); + value.toString(16); + # => "9e1c092" + +## Thanks! + +[pycrc](http://www.tty1.net/pycrc/) library is which the source of all of the CRC tables. + +# License + +The MIT License (MIT) + +Copyright (c) 2014 Alex Gorbatchev + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. diff --git a/node_modules/express-session/node_modules/crc/lib/crc1.js b/node_modules/express-session/node_modules/crc/lib/crc1.js new file mode 100644 index 0000000..23e1625 --- /dev/null +++ b/node_modules/express-session/node_modules/crc/lib/crc1.js @@ -0,0 +1,24 @@ +'use strict'; + +var _buffer = require('buffer'); + +var _define_crc = require('./define_crc'); + +var _define_crc2 = _interopRequireDefault(_define_crc); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +module.exports = (0, _define_crc2.default)('crc1', function (buf, previous) { + if (!_buffer.Buffer.isBuffer(buf)) buf = (0, _buffer.Buffer)(buf); + + var crc = ~ ~previous; + var accum = 0; + + for (var index = 0; index < buf.length; index++) { + var byte = buf[index]; + accum += byte; + } + + crc += accum % 256; + return crc % 256; +}); \ No newline at end of file diff --git a/node_modules/express-session/node_modules/crc/lib/crc16.js b/node_modules/express-session/node_modules/crc/lib/crc16.js new file mode 100644 index 0000000..feff26a --- /dev/null +++ b/node_modules/express-session/node_modules/crc/lib/crc16.js @@ -0,0 +1,27 @@ +'use strict'; + +var _buffer = require('buffer'); + +var _define_crc = require('./define_crc'); + +var _define_crc2 = _interopRequireDefault(_define_crc); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +// Generated by `./pycrc.py --algorithm=table-driven --model=crc-16 --generate=c` +var TABLE = [0x0000, 0xc0c1, 0xc181, 0x0140, 0xc301, 0x03c0, 0x0280, 0xc241, 0xc601, 0x06c0, 0x0780, 0xc741, 0x0500, 0xc5c1, 0xc481, 0x0440, 0xcc01, 0x0cc0, 0x0d80, 0xcd41, 0x0f00, 0xcfc1, 0xce81, 0x0e40, 0x0a00, 0xcac1, 0xcb81, 0x0b40, 0xc901, 0x09c0, 0x0880, 0xc841, 0xd801, 0x18c0, 0x1980, 0xd941, 0x1b00, 0xdbc1, 0xda81, 0x1a40, 0x1e00, 0xdec1, 0xdf81, 0x1f40, 0xdd01, 0x1dc0, 0x1c80, 0xdc41, 0x1400, 0xd4c1, 0xd581, 0x1540, 0xd701, 0x17c0, 0x1680, 0xd641, 0xd201, 0x12c0, 0x1380, 0xd341, 0x1100, 0xd1c1, 0xd081, 0x1040, 0xf001, 0x30c0, 0x3180, 0xf141, 0x3300, 0xf3c1, 0xf281, 0x3240, 0x3600, 0xf6c1, 0xf781, 0x3740, 0xf501, 0x35c0, 0x3480, 0xf441, 0x3c00, 0xfcc1, 0xfd81, 0x3d40, 0xff01, 0x3fc0, 0x3e80, 0xfe41, 0xfa01, 0x3ac0, 0x3b80, 0xfb41, 0x3900, 0xf9c1, 0xf881, 0x3840, 0x2800, 0xe8c1, 0xe981, 0x2940, 0xeb01, 0x2bc0, 0x2a80, 0xea41, 0xee01, 0x2ec0, 0x2f80, 0xef41, 0x2d00, 0xedc1, 0xec81, 0x2c40, 0xe401, 0x24c0, 0x2580, 0xe541, 0x2700, 0xe7c1, 0xe681, 0x2640, 0x2200, 0xe2c1, 0xe381, 0x2340, 0xe101, 0x21c0, 0x2080, 0xe041, 0xa001, 0x60c0, 0x6180, 0xa141, 0x6300, 0xa3c1, 0xa281, 0x6240, 0x6600, 0xa6c1, 0xa781, 0x6740, 0xa501, 0x65c0, 0x6480, 0xa441, 0x6c00, 0xacc1, 0xad81, 0x6d40, 0xaf01, 0x6fc0, 0x6e80, 0xae41, 0xaa01, 0x6ac0, 0x6b80, 0xab41, 0x6900, 0xa9c1, 0xa881, 0x6840, 0x7800, 0xb8c1, 0xb981, 0x7940, 0xbb01, 0x7bc0, 0x7a80, 0xba41, 0xbe01, 0x7ec0, 0x7f80, 0xbf41, 0x7d00, 0xbdc1, 0xbc81, 0x7c40, 0xb401, 0x74c0, 0x7580, 0xb541, 0x7700, 0xb7c1, 0xb681, 0x7640, 0x7200, 0xb2c1, 0xb381, 0x7340, 0xb101, 0x71c0, 0x7080, 0xb041, 0x5000, 0x90c1, 0x9181, 0x5140, 0x9301, 0x53c0, 0x5280, 0x9241, 0x9601, 0x56c0, 0x5780, 0x9741, 0x5500, 0x95c1, 0x9481, 0x5440, 0x9c01, 0x5cc0, 0x5d80, 0x9d41, 0x5f00, 0x9fc1, 0x9e81, 0x5e40, 0x5a00, 0x9ac1, 0x9b81, 0x5b40, 0x9901, 0x59c0, 0x5880, 0x9841, 0x8801, 0x48c0, 0x4980, 0x8941, 0x4b00, 0x8bc1, 0x8a81, 0x4a40, 0x4e00, 0x8ec1, 0x8f81, 0x4f40, 0x8d01, 0x4dc0, 0x4c80, 0x8c41, 0x4400, 0x84c1, 0x8581, 0x4540, 0x8701, 0x47c0, 0x4680, 0x8641, 0x8201, 0x42c0, 0x4380, 0x8341, 0x4100, 0x81c1, 0x8081, 0x4040]; + +if (typeof Int32Array !== 'undefined') TABLE = new Int32Array(TABLE); + +module.exports = (0, _define_crc2.default)('crc-16', function (buf, previous) { + if (!_buffer.Buffer.isBuffer(buf)) buf = (0, _buffer.Buffer)(buf); + + var crc = ~ ~previous; + + for (var index = 0; index < buf.length; index++) { + var byte = buf[index]; + crc = (TABLE[(crc ^ byte) & 0xff] ^ crc >> 8) & 0xffff; + } + + return crc; +}); \ No newline at end of file diff --git a/node_modules/express-session/node_modules/crc/lib/crc16_ccitt.js b/node_modules/express-session/node_modules/crc/lib/crc16_ccitt.js new file mode 100644 index 0000000..01051d1 --- /dev/null +++ b/node_modules/express-session/node_modules/crc/lib/crc16_ccitt.js @@ -0,0 +1,27 @@ +'use strict'; + +var _buffer = require('buffer'); + +var _define_crc = require('./define_crc'); + +var _define_crc2 = _interopRequireDefault(_define_crc); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +// Generated by `./pycrc.py --algorithm=table-driven --model=ccitt --generate=c` +var TABLE = [0x0000, 0x1021, 0x2042, 0x3063, 0x4084, 0x50a5, 0x60c6, 0x70e7, 0x8108, 0x9129, 0xa14a, 0xb16b, 0xc18c, 0xd1ad, 0xe1ce, 0xf1ef, 0x1231, 0x0210, 0x3273, 0x2252, 0x52b5, 0x4294, 0x72f7, 0x62d6, 0x9339, 0x8318, 0xb37b, 0xa35a, 0xd3bd, 0xc39c, 0xf3ff, 0xe3de, 0x2462, 0x3443, 0x0420, 0x1401, 0x64e6, 0x74c7, 0x44a4, 0x5485, 0xa56a, 0xb54b, 0x8528, 0x9509, 0xe5ee, 0xf5cf, 0xc5ac, 0xd58d, 0x3653, 0x2672, 0x1611, 0x0630, 0x76d7, 0x66f6, 0x5695, 0x46b4, 0xb75b, 0xa77a, 0x9719, 0x8738, 0xf7df, 0xe7fe, 0xd79d, 0xc7bc, 0x48c4, 0x58e5, 0x6886, 0x78a7, 0x0840, 0x1861, 0x2802, 0x3823, 0xc9cc, 0xd9ed, 0xe98e, 0xf9af, 0x8948, 0x9969, 0xa90a, 0xb92b, 0x5af5, 0x4ad4, 0x7ab7, 0x6a96, 0x1a71, 0x0a50, 0x3a33, 0x2a12, 0xdbfd, 0xcbdc, 0xfbbf, 0xeb9e, 0x9b79, 0x8b58, 0xbb3b, 0xab1a, 0x6ca6, 0x7c87, 0x4ce4, 0x5cc5, 0x2c22, 0x3c03, 0x0c60, 0x1c41, 0xedae, 0xfd8f, 0xcdec, 0xddcd, 0xad2a, 0xbd0b, 0x8d68, 0x9d49, 0x7e97, 0x6eb6, 0x5ed5, 0x4ef4, 0x3e13, 0x2e32, 0x1e51, 0x0e70, 0xff9f, 0xefbe, 0xdfdd, 0xcffc, 0xbf1b, 0xaf3a, 0x9f59, 0x8f78, 0x9188, 0x81a9, 0xb1ca, 0xa1eb, 0xd10c, 0xc12d, 0xf14e, 0xe16f, 0x1080, 0x00a1, 0x30c2, 0x20e3, 0x5004, 0x4025, 0x7046, 0x6067, 0x83b9, 0x9398, 0xa3fb, 0xb3da, 0xc33d, 0xd31c, 0xe37f, 0xf35e, 0x02b1, 0x1290, 0x22f3, 0x32d2, 0x4235, 0x5214, 0x6277, 0x7256, 0xb5ea, 0xa5cb, 0x95a8, 0x8589, 0xf56e, 0xe54f, 0xd52c, 0xc50d, 0x34e2, 0x24c3, 0x14a0, 0x0481, 0x7466, 0x6447, 0x5424, 0x4405, 0xa7db, 0xb7fa, 0x8799, 0x97b8, 0xe75f, 0xf77e, 0xc71d, 0xd73c, 0x26d3, 0x36f2, 0x0691, 0x16b0, 0x6657, 0x7676, 0x4615, 0x5634, 0xd94c, 0xc96d, 0xf90e, 0xe92f, 0x99c8, 0x89e9, 0xb98a, 0xa9ab, 0x5844, 0x4865, 0x7806, 0x6827, 0x18c0, 0x08e1, 0x3882, 0x28a3, 0xcb7d, 0xdb5c, 0xeb3f, 0xfb1e, 0x8bf9, 0x9bd8, 0xabbb, 0xbb9a, 0x4a75, 0x5a54, 0x6a37, 0x7a16, 0x0af1, 0x1ad0, 0x2ab3, 0x3a92, 0xfd2e, 0xed0f, 0xdd6c, 0xcd4d, 0xbdaa, 0xad8b, 0x9de8, 0x8dc9, 0x7c26, 0x6c07, 0x5c64, 0x4c45, 0x3ca2, 0x2c83, 0x1ce0, 0x0cc1, 0xef1f, 0xff3e, 0xcf5d, 0xdf7c, 0xaf9b, 0xbfba, 0x8fd9, 0x9ff8, 0x6e17, 0x7e36, 0x4e55, 0x5e74, 0x2e93, 0x3eb2, 0x0ed1, 0x1ef0]; + +if (typeof Int32Array !== 'undefined') TABLE = new Int32Array(TABLE); + +module.exports = (0, _define_crc2.default)('ccitt', function (buf, previous) { + if (!_buffer.Buffer.isBuffer(buf)) buf = (0, _buffer.Buffer)(buf); + + var crc = typeof previous !== 'undefined' ? ~ ~previous : 0xffff; + + for (var index = 0; index < buf.length; index++) { + var byte = buf[index]; + crc = (TABLE[(crc >> 8 ^ byte) & 0xff] ^ crc << 8) & 0xffff; + } + + return crc; +}); \ No newline at end of file diff --git a/node_modules/express-session/node_modules/crc/lib/crc16_kermit.js b/node_modules/express-session/node_modules/crc/lib/crc16_kermit.js new file mode 100644 index 0000000..9174f4f --- /dev/null +++ b/node_modules/express-session/node_modules/crc/lib/crc16_kermit.js @@ -0,0 +1,27 @@ +'use strict'; + +var _buffer = require('buffer'); + +var _define_crc = require('./define_crc'); + +var _define_crc2 = _interopRequireDefault(_define_crc); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +// Generated by `./pycrc.py --algorithm=table-driven --model=kermit --generate=c` +var TABLE = [0x0000, 0x1189, 0x2312, 0x329b, 0x4624, 0x57ad, 0x6536, 0x74bf, 0x8c48, 0x9dc1, 0xaf5a, 0xbed3, 0xca6c, 0xdbe5, 0xe97e, 0xf8f7, 0x1081, 0x0108, 0x3393, 0x221a, 0x56a5, 0x472c, 0x75b7, 0x643e, 0x9cc9, 0x8d40, 0xbfdb, 0xae52, 0xdaed, 0xcb64, 0xf9ff, 0xe876, 0x2102, 0x308b, 0x0210, 0x1399, 0x6726, 0x76af, 0x4434, 0x55bd, 0xad4a, 0xbcc3, 0x8e58, 0x9fd1, 0xeb6e, 0xfae7, 0xc87c, 0xd9f5, 0x3183, 0x200a, 0x1291, 0x0318, 0x77a7, 0x662e, 0x54b5, 0x453c, 0xbdcb, 0xac42, 0x9ed9, 0x8f50, 0xfbef, 0xea66, 0xd8fd, 0xc974, 0x4204, 0x538d, 0x6116, 0x709f, 0x0420, 0x15a9, 0x2732, 0x36bb, 0xce4c, 0xdfc5, 0xed5e, 0xfcd7, 0x8868, 0x99e1, 0xab7a, 0xbaf3, 0x5285, 0x430c, 0x7197, 0x601e, 0x14a1, 0x0528, 0x37b3, 0x263a, 0xdecd, 0xcf44, 0xfddf, 0xec56, 0x98e9, 0x8960, 0xbbfb, 0xaa72, 0x6306, 0x728f, 0x4014, 0x519d, 0x2522, 0x34ab, 0x0630, 0x17b9, 0xef4e, 0xfec7, 0xcc5c, 0xddd5, 0xa96a, 0xb8e3, 0x8a78, 0x9bf1, 0x7387, 0x620e, 0x5095, 0x411c, 0x35a3, 0x242a, 0x16b1, 0x0738, 0xffcf, 0xee46, 0xdcdd, 0xcd54, 0xb9eb, 0xa862, 0x9af9, 0x8b70, 0x8408, 0x9581, 0xa71a, 0xb693, 0xc22c, 0xd3a5, 0xe13e, 0xf0b7, 0x0840, 0x19c9, 0x2b52, 0x3adb, 0x4e64, 0x5fed, 0x6d76, 0x7cff, 0x9489, 0x8500, 0xb79b, 0xa612, 0xd2ad, 0xc324, 0xf1bf, 0xe036, 0x18c1, 0x0948, 0x3bd3, 0x2a5a, 0x5ee5, 0x4f6c, 0x7df7, 0x6c7e, 0xa50a, 0xb483, 0x8618, 0x9791, 0xe32e, 0xf2a7, 0xc03c, 0xd1b5, 0x2942, 0x38cb, 0x0a50, 0x1bd9, 0x6f66, 0x7eef, 0x4c74, 0x5dfd, 0xb58b, 0xa402, 0x9699, 0x8710, 0xf3af, 0xe226, 0xd0bd, 0xc134, 0x39c3, 0x284a, 0x1ad1, 0x0b58, 0x7fe7, 0x6e6e, 0x5cf5, 0x4d7c, 0xc60c, 0xd785, 0xe51e, 0xf497, 0x8028, 0x91a1, 0xa33a, 0xb2b3, 0x4a44, 0x5bcd, 0x6956, 0x78df, 0x0c60, 0x1de9, 0x2f72, 0x3efb, 0xd68d, 0xc704, 0xf59f, 0xe416, 0x90a9, 0x8120, 0xb3bb, 0xa232, 0x5ac5, 0x4b4c, 0x79d7, 0x685e, 0x1ce1, 0x0d68, 0x3ff3, 0x2e7a, 0xe70e, 0xf687, 0xc41c, 0xd595, 0xa12a, 0xb0a3, 0x8238, 0x93b1, 0x6b46, 0x7acf, 0x4854, 0x59dd, 0x2d62, 0x3ceb, 0x0e70, 0x1ff9, 0xf78f, 0xe606, 0xd49d, 0xc514, 0xb1ab, 0xa022, 0x92b9, 0x8330, 0x7bc7, 0x6a4e, 0x58d5, 0x495c, 0x3de3, 0x2c6a, 0x1ef1, 0x0f78]; + +if (typeof Int32Array !== 'undefined') TABLE = new Int32Array(TABLE); + +module.exports = (0, _define_crc2.default)('kermit', function (buf, previous) { + if (!_buffer.Buffer.isBuffer(buf)) buf = (0, _buffer.Buffer)(buf); + + var crc = typeof previous !== 'undefined' ? ~ ~previous : 0x0000; + + for (var index = 0; index < buf.length; index++) { + var byte = buf[index]; + crc = (TABLE[(crc ^ byte) & 0xff] ^ crc >> 8) & 0xffff; + } + + return crc; +}); \ No newline at end of file diff --git a/node_modules/express-session/node_modules/crc/lib/crc16_modbus.js b/node_modules/express-session/node_modules/crc/lib/crc16_modbus.js new file mode 100644 index 0000000..7ce82a0 --- /dev/null +++ b/node_modules/express-session/node_modules/crc/lib/crc16_modbus.js @@ -0,0 +1,27 @@ +'use strict'; + +var _buffer = require('buffer'); + +var _define_crc = require('./define_crc'); + +var _define_crc2 = _interopRequireDefault(_define_crc); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +// Generated by `./pycrc.py --algorithm=table-driven --model=crc-16-modbus --generate=c` +var TABLE = [0x0000, 0xc0c1, 0xc181, 0x0140, 0xc301, 0x03c0, 0x0280, 0xc241, 0xc601, 0x06c0, 0x0780, 0xc741, 0x0500, 0xc5c1, 0xc481, 0x0440, 0xcc01, 0x0cc0, 0x0d80, 0xcd41, 0x0f00, 0xcfc1, 0xce81, 0x0e40, 0x0a00, 0xcac1, 0xcb81, 0x0b40, 0xc901, 0x09c0, 0x0880, 0xc841, 0xd801, 0x18c0, 0x1980, 0xd941, 0x1b00, 0xdbc1, 0xda81, 0x1a40, 0x1e00, 0xdec1, 0xdf81, 0x1f40, 0xdd01, 0x1dc0, 0x1c80, 0xdc41, 0x1400, 0xd4c1, 0xd581, 0x1540, 0xd701, 0x17c0, 0x1680, 0xd641, 0xd201, 0x12c0, 0x1380, 0xd341, 0x1100, 0xd1c1, 0xd081, 0x1040, 0xf001, 0x30c0, 0x3180, 0xf141, 0x3300, 0xf3c1, 0xf281, 0x3240, 0x3600, 0xf6c1, 0xf781, 0x3740, 0xf501, 0x35c0, 0x3480, 0xf441, 0x3c00, 0xfcc1, 0xfd81, 0x3d40, 0xff01, 0x3fc0, 0x3e80, 0xfe41, 0xfa01, 0x3ac0, 0x3b80, 0xfb41, 0x3900, 0xf9c1, 0xf881, 0x3840, 0x2800, 0xe8c1, 0xe981, 0x2940, 0xeb01, 0x2bc0, 0x2a80, 0xea41, 0xee01, 0x2ec0, 0x2f80, 0xef41, 0x2d00, 0xedc1, 0xec81, 0x2c40, 0xe401, 0x24c0, 0x2580, 0xe541, 0x2700, 0xe7c1, 0xe681, 0x2640, 0x2200, 0xe2c1, 0xe381, 0x2340, 0xe101, 0x21c0, 0x2080, 0xe041, 0xa001, 0x60c0, 0x6180, 0xa141, 0x6300, 0xa3c1, 0xa281, 0x6240, 0x6600, 0xa6c1, 0xa781, 0x6740, 0xa501, 0x65c0, 0x6480, 0xa441, 0x6c00, 0xacc1, 0xad81, 0x6d40, 0xaf01, 0x6fc0, 0x6e80, 0xae41, 0xaa01, 0x6ac0, 0x6b80, 0xab41, 0x6900, 0xa9c1, 0xa881, 0x6840, 0x7800, 0xb8c1, 0xb981, 0x7940, 0xbb01, 0x7bc0, 0x7a80, 0xba41, 0xbe01, 0x7ec0, 0x7f80, 0xbf41, 0x7d00, 0xbdc1, 0xbc81, 0x7c40, 0xb401, 0x74c0, 0x7580, 0xb541, 0x7700, 0xb7c1, 0xb681, 0x7640, 0x7200, 0xb2c1, 0xb381, 0x7340, 0xb101, 0x71c0, 0x7080, 0xb041, 0x5000, 0x90c1, 0x9181, 0x5140, 0x9301, 0x53c0, 0x5280, 0x9241, 0x9601, 0x56c0, 0x5780, 0x9741, 0x5500, 0x95c1, 0x9481, 0x5440, 0x9c01, 0x5cc0, 0x5d80, 0x9d41, 0x5f00, 0x9fc1, 0x9e81, 0x5e40, 0x5a00, 0x9ac1, 0x9b81, 0x5b40, 0x9901, 0x59c0, 0x5880, 0x9841, 0x8801, 0x48c0, 0x4980, 0x8941, 0x4b00, 0x8bc1, 0x8a81, 0x4a40, 0x4e00, 0x8ec1, 0x8f81, 0x4f40, 0x8d01, 0x4dc0, 0x4c80, 0x8c41, 0x4400, 0x84c1, 0x8581, 0x4540, 0x8701, 0x47c0, 0x4680, 0x8641, 0x8201, 0x42c0, 0x4380, 0x8341, 0x4100, 0x81c1, 0x8081, 0x4040]; + +if (typeof Int32Array !== 'undefined') TABLE = new Int32Array(TABLE); + +module.exports = (0, _define_crc2.default)('crc-16-modbus', function (buf, previous) { + if (!_buffer.Buffer.isBuffer(buf)) buf = (0, _buffer.Buffer)(buf); + + var crc = typeof previous !== 'undefined' ? ~ ~previous : 0xffff; + + for (var index = 0; index < buf.length; index++) { + var byte = buf[index]; + crc = (TABLE[(crc ^ byte) & 0xff] ^ crc >> 8) & 0xffff; + } + + return crc; +}); \ No newline at end of file diff --git a/node_modules/express-session/node_modules/crc/lib/crc16_xmodem.js b/node_modules/express-session/node_modules/crc/lib/crc16_xmodem.js new file mode 100644 index 0000000..2bc58a6 --- /dev/null +++ b/node_modules/express-session/node_modules/crc/lib/crc16_xmodem.js @@ -0,0 +1,31 @@ +'use strict'; + +var _buffer = require('buffer'); + +var _define_crc = require('./define_crc'); + +var _define_crc2 = _interopRequireDefault(_define_crc); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +module.exports = (0, _define_crc2.default)('xmodem', function (buf, previous) { + if (!_buffer.Buffer.isBuffer(buf)) buf = (0, _buffer.Buffer)(buf); + + var crc = typeof previous !== 'undefined' ? ~ ~previous : 0x0; + + for (var index = 0; index < buf.length; index++) { + var byte = buf[index]; + var code = crc >>> 8 & 0xFF; + + code ^= byte & 0xFF; + code ^= code >>> 4; + crc = crc << 8 & 0xFFFF; + crc ^= code; + code = code << 5 & 0xFFFF; + crc ^= code; + code = code << 7 & 0xFFFF; + crc ^= code; + } + + return crc; +}); \ No newline at end of file diff --git a/node_modules/express-session/node_modules/crc/lib/crc24.js b/node_modules/express-session/node_modules/crc/lib/crc24.js new file mode 100644 index 0000000..610aedb --- /dev/null +++ b/node_modules/express-session/node_modules/crc/lib/crc24.js @@ -0,0 +1,27 @@ +'use strict'; + +var _buffer = require('buffer'); + +var _define_crc = require('./define_crc'); + +var _define_crc2 = _interopRequireDefault(_define_crc); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +// Generated by `./pycrc.py --algorithm=table-drive --model=crc-24 --generate=c` +var TABLE = [0x000000, 0x864cfb, 0x8ad50d, 0x0c99f6, 0x93e6e1, 0x15aa1a, 0x1933ec, 0x9f7f17, 0xa18139, 0x27cdc2, 0x2b5434, 0xad18cf, 0x3267d8, 0xb42b23, 0xb8b2d5, 0x3efe2e, 0xc54e89, 0x430272, 0x4f9b84, 0xc9d77f, 0x56a868, 0xd0e493, 0xdc7d65, 0x5a319e, 0x64cfb0, 0xe2834b, 0xee1abd, 0x685646, 0xf72951, 0x7165aa, 0x7dfc5c, 0xfbb0a7, 0x0cd1e9, 0x8a9d12, 0x8604e4, 0x00481f, 0x9f3708, 0x197bf3, 0x15e205, 0x93aefe, 0xad50d0, 0x2b1c2b, 0x2785dd, 0xa1c926, 0x3eb631, 0xb8faca, 0xb4633c, 0x322fc7, 0xc99f60, 0x4fd39b, 0x434a6d, 0xc50696, 0x5a7981, 0xdc357a, 0xd0ac8c, 0x56e077, 0x681e59, 0xee52a2, 0xe2cb54, 0x6487af, 0xfbf8b8, 0x7db443, 0x712db5, 0xf7614e, 0x19a3d2, 0x9fef29, 0x9376df, 0x153a24, 0x8a4533, 0x0c09c8, 0x00903e, 0x86dcc5, 0xb822eb, 0x3e6e10, 0x32f7e6, 0xb4bb1d, 0x2bc40a, 0xad88f1, 0xa11107, 0x275dfc, 0xdced5b, 0x5aa1a0, 0x563856, 0xd074ad, 0x4f0bba, 0xc94741, 0xc5deb7, 0x43924c, 0x7d6c62, 0xfb2099, 0xf7b96f, 0x71f594, 0xee8a83, 0x68c678, 0x645f8e, 0xe21375, 0x15723b, 0x933ec0, 0x9fa736, 0x19ebcd, 0x8694da, 0x00d821, 0x0c41d7, 0x8a0d2c, 0xb4f302, 0x32bff9, 0x3e260f, 0xb86af4, 0x2715e3, 0xa15918, 0xadc0ee, 0x2b8c15, 0xd03cb2, 0x567049, 0x5ae9bf, 0xdca544, 0x43da53, 0xc596a8, 0xc90f5e, 0x4f43a5, 0x71bd8b, 0xf7f170, 0xfb6886, 0x7d247d, 0xe25b6a, 0x641791, 0x688e67, 0xeec29c, 0x3347a4, 0xb50b5f, 0xb992a9, 0x3fde52, 0xa0a145, 0x26edbe, 0x2a7448, 0xac38b3, 0x92c69d, 0x148a66, 0x181390, 0x9e5f6b, 0x01207c, 0x876c87, 0x8bf571, 0x0db98a, 0xf6092d, 0x7045d6, 0x7cdc20, 0xfa90db, 0x65efcc, 0xe3a337, 0xef3ac1, 0x69763a, 0x578814, 0xd1c4ef, 0xdd5d19, 0x5b11e2, 0xc46ef5, 0x42220e, 0x4ebbf8, 0xc8f703, 0x3f964d, 0xb9dab6, 0xb54340, 0x330fbb, 0xac70ac, 0x2a3c57, 0x26a5a1, 0xa0e95a, 0x9e1774, 0x185b8f, 0x14c279, 0x928e82, 0x0df195, 0x8bbd6e, 0x872498, 0x016863, 0xfad8c4, 0x7c943f, 0x700dc9, 0xf64132, 0x693e25, 0xef72de, 0xe3eb28, 0x65a7d3, 0x5b59fd, 0xdd1506, 0xd18cf0, 0x57c00b, 0xc8bf1c, 0x4ef3e7, 0x426a11, 0xc426ea, 0x2ae476, 0xaca88d, 0xa0317b, 0x267d80, 0xb90297, 0x3f4e6c, 0x33d79a, 0xb59b61, 0x8b654f, 0x0d29b4, 0x01b042, 0x87fcb9, 0x1883ae, 0x9ecf55, 0x9256a3, 0x141a58, 0xefaaff, 0x69e604, 0x657ff2, 0xe33309, 0x7c4c1e, 0xfa00e5, 0xf69913, 0x70d5e8, 0x4e2bc6, 0xc8673d, 0xc4fecb, 0x42b230, 0xddcd27, 0x5b81dc, 0x57182a, 0xd154d1, 0x26359f, 0xa07964, 0xace092, 0x2aac69, 0xb5d37e, 0x339f85, 0x3f0673, 0xb94a88, 0x87b4a6, 0x01f85d, 0x0d61ab, 0x8b2d50, 0x145247, 0x921ebc, 0x9e874a, 0x18cbb1, 0xe37b16, 0x6537ed, 0x69ae1b, 0xefe2e0, 0x709df7, 0xf6d10c, 0xfa48fa, 0x7c0401, 0x42fa2f, 0xc4b6d4, 0xc82f22, 0x4e63d9, 0xd11cce, 0x575035, 0x5bc9c3, 0xdd8538]; + +if (typeof Int32Array !== 'undefined') TABLE = new Int32Array(TABLE); + +module.exports = (0, _define_crc2.default)('crc-24', function (buf, previous) { + if (!_buffer.Buffer.isBuffer(buf)) buf = (0, _buffer.Buffer)(buf); + + var crc = typeof previous !== 'undefined' ? ~ ~previous : 0xb704ce; + + for (var index = 0; index < buf.length; index++) { + var byte = buf[index]; + crc = (TABLE[(crc >> 16 ^ byte) & 0xff] ^ crc << 8) & 0xffffff; + } + + return crc; +}); \ No newline at end of file diff --git a/node_modules/express-session/node_modules/crc/lib/crc32.js b/node_modules/express-session/node_modules/crc/lib/crc32.js new file mode 100644 index 0000000..f52abc9 --- /dev/null +++ b/node_modules/express-session/node_modules/crc/lib/crc32.js @@ -0,0 +1,27 @@ +'use strict'; + +var _buffer = require('buffer'); + +var _define_crc = require('./define_crc'); + +var _define_crc2 = _interopRequireDefault(_define_crc); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +// Generated by `./pycrc.py --algorithm=table-driven --model=crc-32 --generate=c` +var TABLE = [0x00000000, 0x77073096, 0xee0e612c, 0x990951ba, 0x076dc419, 0x706af48f, 0xe963a535, 0x9e6495a3, 0x0edb8832, 0x79dcb8a4, 0xe0d5e91e, 0x97d2d988, 0x09b64c2b, 0x7eb17cbd, 0xe7b82d07, 0x90bf1d91, 0x1db71064, 0x6ab020f2, 0xf3b97148, 0x84be41de, 0x1adad47d, 0x6ddde4eb, 0xf4d4b551, 0x83d385c7, 0x136c9856, 0x646ba8c0, 0xfd62f97a, 0x8a65c9ec, 0x14015c4f, 0x63066cd9, 0xfa0f3d63, 0x8d080df5, 0x3b6e20c8, 0x4c69105e, 0xd56041e4, 0xa2677172, 0x3c03e4d1, 0x4b04d447, 0xd20d85fd, 0xa50ab56b, 0x35b5a8fa, 0x42b2986c, 0xdbbbc9d6, 0xacbcf940, 0x32d86ce3, 0x45df5c75, 0xdcd60dcf, 0xabd13d59, 0x26d930ac, 0x51de003a, 0xc8d75180, 0xbfd06116, 0x21b4f4b5, 0x56b3c423, 0xcfba9599, 0xb8bda50f, 0x2802b89e, 0x5f058808, 0xc60cd9b2, 0xb10be924, 0x2f6f7c87, 0x58684c11, 0xc1611dab, 0xb6662d3d, 0x76dc4190, 0x01db7106, 0x98d220bc, 0xefd5102a, 0x71b18589, 0x06b6b51f, 0x9fbfe4a5, 0xe8b8d433, 0x7807c9a2, 0x0f00f934, 0x9609a88e, 0xe10e9818, 0x7f6a0dbb, 0x086d3d2d, 0x91646c97, 0xe6635c01, 0x6b6b51f4, 0x1c6c6162, 0x856530d8, 0xf262004e, 0x6c0695ed, 0x1b01a57b, 0x8208f4c1, 0xf50fc457, 0x65b0d9c6, 0x12b7e950, 0x8bbeb8ea, 0xfcb9887c, 0x62dd1ddf, 0x15da2d49, 0x8cd37cf3, 0xfbd44c65, 0x4db26158, 0x3ab551ce, 0xa3bc0074, 0xd4bb30e2, 0x4adfa541, 0x3dd895d7, 0xa4d1c46d, 0xd3d6f4fb, 0x4369e96a, 0x346ed9fc, 0xad678846, 0xda60b8d0, 0x44042d73, 0x33031de5, 0xaa0a4c5f, 0xdd0d7cc9, 0x5005713c, 0x270241aa, 0xbe0b1010, 0xc90c2086, 0x5768b525, 0x206f85b3, 0xb966d409, 0xce61e49f, 0x5edef90e, 0x29d9c998, 0xb0d09822, 0xc7d7a8b4, 0x59b33d17, 0x2eb40d81, 0xb7bd5c3b, 0xc0ba6cad, 0xedb88320, 0x9abfb3b6, 0x03b6e20c, 0x74b1d29a, 0xead54739, 0x9dd277af, 0x04db2615, 0x73dc1683, 0xe3630b12, 0x94643b84, 0x0d6d6a3e, 0x7a6a5aa8, 0xe40ecf0b, 0x9309ff9d, 0x0a00ae27, 0x7d079eb1, 0xf00f9344, 0x8708a3d2, 0x1e01f268, 0x6906c2fe, 0xf762575d, 0x806567cb, 0x196c3671, 0x6e6b06e7, 0xfed41b76, 0x89d32be0, 0x10da7a5a, 0x67dd4acc, 0xf9b9df6f, 0x8ebeeff9, 0x17b7be43, 0x60b08ed5, 0xd6d6a3e8, 0xa1d1937e, 0x38d8c2c4, 0x4fdff252, 0xd1bb67f1, 0xa6bc5767, 0x3fb506dd, 0x48b2364b, 0xd80d2bda, 0xaf0a1b4c, 0x36034af6, 0x41047a60, 0xdf60efc3, 0xa867df55, 0x316e8eef, 0x4669be79, 0xcb61b38c, 0xbc66831a, 0x256fd2a0, 0x5268e236, 0xcc0c7795, 0xbb0b4703, 0x220216b9, 0x5505262f, 0xc5ba3bbe, 0xb2bd0b28, 0x2bb45a92, 0x5cb36a04, 0xc2d7ffa7, 0xb5d0cf31, 0x2cd99e8b, 0x5bdeae1d, 0x9b64c2b0, 0xec63f226, 0x756aa39c, 0x026d930a, 0x9c0906a9, 0xeb0e363f, 0x72076785, 0x05005713, 0x95bf4a82, 0xe2b87a14, 0x7bb12bae, 0x0cb61b38, 0x92d28e9b, 0xe5d5be0d, 0x7cdcefb7, 0x0bdbdf21, 0x86d3d2d4, 0xf1d4e242, 0x68ddb3f8, 0x1fda836e, 0x81be16cd, 0xf6b9265b, 0x6fb077e1, 0x18b74777, 0x88085ae6, 0xff0f6a70, 0x66063bca, 0x11010b5c, 0x8f659eff, 0xf862ae69, 0x616bffd3, 0x166ccf45, 0xa00ae278, 0xd70dd2ee, 0x4e048354, 0x3903b3c2, 0xa7672661, 0xd06016f7, 0x4969474d, 0x3e6e77db, 0xaed16a4a, 0xd9d65adc, 0x40df0b66, 0x37d83bf0, 0xa9bcae53, 0xdebb9ec5, 0x47b2cf7f, 0x30b5ffe9, 0xbdbdf21c, 0xcabac28a, 0x53b39330, 0x24b4a3a6, 0xbad03605, 0xcdd70693, 0x54de5729, 0x23d967bf, 0xb3667a2e, 0xc4614ab8, 0x5d681b02, 0x2a6f2b94, 0xb40bbe37, 0xc30c8ea1, 0x5a05df1b, 0x2d02ef8d]; + +if (typeof Int32Array !== 'undefined') TABLE = new Int32Array(TABLE); + +module.exports = (0, _define_crc2.default)('crc-32', function (buf, previous) { + if (!_buffer.Buffer.isBuffer(buf)) buf = (0, _buffer.Buffer)(buf); + + var crc = previous === 0 ? 0 : ~ ~previous ^ -1; + + for (var index = 0; index < buf.length; index++) { + var byte = buf[index]; + crc = TABLE[(crc ^ byte) & 0xff] ^ crc >>> 8; + } + + return crc ^ -1; +}); \ No newline at end of file diff --git a/node_modules/express-session/node_modules/crc/lib/crc8.js b/node_modules/express-session/node_modules/crc/lib/crc8.js new file mode 100644 index 0000000..97feb1c --- /dev/null +++ b/node_modules/express-session/node_modules/crc/lib/crc8.js @@ -0,0 +1,27 @@ +'use strict'; + +var _buffer = require('buffer'); + +var _define_crc = require('./define_crc'); + +var _define_crc2 = _interopRequireDefault(_define_crc); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +// Generated by `./pycrc.py --algorithm=table-driven --model=crc-8 --generate=c` +var TABLE = [0x00, 0x07, 0x0e, 0x09, 0x1c, 0x1b, 0x12, 0x15, 0x38, 0x3f, 0x36, 0x31, 0x24, 0x23, 0x2a, 0x2d, 0x70, 0x77, 0x7e, 0x79, 0x6c, 0x6b, 0x62, 0x65, 0x48, 0x4f, 0x46, 0x41, 0x54, 0x53, 0x5a, 0x5d, 0xe0, 0xe7, 0xee, 0xe9, 0xfc, 0xfb, 0xf2, 0xf5, 0xd8, 0xdf, 0xd6, 0xd1, 0xc4, 0xc3, 0xca, 0xcd, 0x90, 0x97, 0x9e, 0x99, 0x8c, 0x8b, 0x82, 0x85, 0xa8, 0xaf, 0xa6, 0xa1, 0xb4, 0xb3, 0xba, 0xbd, 0xc7, 0xc0, 0xc9, 0xce, 0xdb, 0xdc, 0xd5, 0xd2, 0xff, 0xf8, 0xf1, 0xf6, 0xe3, 0xe4, 0xed, 0xea, 0xb7, 0xb0, 0xb9, 0xbe, 0xab, 0xac, 0xa5, 0xa2, 0x8f, 0x88, 0x81, 0x86, 0x93, 0x94, 0x9d, 0x9a, 0x27, 0x20, 0x29, 0x2e, 0x3b, 0x3c, 0x35, 0x32, 0x1f, 0x18, 0x11, 0x16, 0x03, 0x04, 0x0d, 0x0a, 0x57, 0x50, 0x59, 0x5e, 0x4b, 0x4c, 0x45, 0x42, 0x6f, 0x68, 0x61, 0x66, 0x73, 0x74, 0x7d, 0x7a, 0x89, 0x8e, 0x87, 0x80, 0x95, 0x92, 0x9b, 0x9c, 0xb1, 0xb6, 0xbf, 0xb8, 0xad, 0xaa, 0xa3, 0xa4, 0xf9, 0xfe, 0xf7, 0xf0, 0xe5, 0xe2, 0xeb, 0xec, 0xc1, 0xc6, 0xcf, 0xc8, 0xdd, 0xda, 0xd3, 0xd4, 0x69, 0x6e, 0x67, 0x60, 0x75, 0x72, 0x7b, 0x7c, 0x51, 0x56, 0x5f, 0x58, 0x4d, 0x4a, 0x43, 0x44, 0x19, 0x1e, 0x17, 0x10, 0x05, 0x02, 0x0b, 0x0c, 0x21, 0x26, 0x2f, 0x28, 0x3d, 0x3a, 0x33, 0x34, 0x4e, 0x49, 0x40, 0x47, 0x52, 0x55, 0x5c, 0x5b, 0x76, 0x71, 0x78, 0x7f, 0x6a, 0x6d, 0x64, 0x63, 0x3e, 0x39, 0x30, 0x37, 0x22, 0x25, 0x2c, 0x2b, 0x06, 0x01, 0x08, 0x0f, 0x1a, 0x1d, 0x14, 0x13, 0xae, 0xa9, 0xa0, 0xa7, 0xb2, 0xb5, 0xbc, 0xbb, 0x96, 0x91, 0x98, 0x9f, 0x8a, 0x8d, 0x84, 0x83, 0xde, 0xd9, 0xd0, 0xd7, 0xc2, 0xc5, 0xcc, 0xcb, 0xe6, 0xe1, 0xe8, 0xef, 0xfa, 0xfd, 0xf4, 0xf3]; + +if (typeof Int32Array !== 'undefined') TABLE = new Int32Array(TABLE); + +module.exports = (0, _define_crc2.default)('crc-8', function (buf, previous) { + if (!_buffer.Buffer.isBuffer(buf)) buf = (0, _buffer.Buffer)(buf); + + var crc = ~ ~previous; + + for (var index = 0; index < buf.length; index++) { + var byte = buf[index]; + crc = TABLE[(crc ^ byte) & 0xff] & 0xff; + } + + return crc; +}); \ No newline at end of file diff --git a/node_modules/express-session/node_modules/crc/lib/crc8_1wire.js b/node_modules/express-session/node_modules/crc/lib/crc8_1wire.js new file mode 100644 index 0000000..d5ced54 --- /dev/null +++ b/node_modules/express-session/node_modules/crc/lib/crc8_1wire.js @@ -0,0 +1,27 @@ +'use strict'; + +var _buffer = require('buffer'); + +var _define_crc = require('./define_crc'); + +var _define_crc2 = _interopRequireDefault(_define_crc); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +// Generated by `./pycrc.py --algorithm=table-driven --model=dallas-1-wire --generate=c` +var TABLE = [0x00, 0x5e, 0xbc, 0xe2, 0x61, 0x3f, 0xdd, 0x83, 0xc2, 0x9c, 0x7e, 0x20, 0xa3, 0xfd, 0x1f, 0x41, 0x9d, 0xc3, 0x21, 0x7f, 0xfc, 0xa2, 0x40, 0x1e, 0x5f, 0x01, 0xe3, 0xbd, 0x3e, 0x60, 0x82, 0xdc, 0x23, 0x7d, 0x9f, 0xc1, 0x42, 0x1c, 0xfe, 0xa0, 0xe1, 0xbf, 0x5d, 0x03, 0x80, 0xde, 0x3c, 0x62, 0xbe, 0xe0, 0x02, 0x5c, 0xdf, 0x81, 0x63, 0x3d, 0x7c, 0x22, 0xc0, 0x9e, 0x1d, 0x43, 0xa1, 0xff, 0x46, 0x18, 0xfa, 0xa4, 0x27, 0x79, 0x9b, 0xc5, 0x84, 0xda, 0x38, 0x66, 0xe5, 0xbb, 0x59, 0x07, 0xdb, 0x85, 0x67, 0x39, 0xba, 0xe4, 0x06, 0x58, 0x19, 0x47, 0xa5, 0xfb, 0x78, 0x26, 0xc4, 0x9a, 0x65, 0x3b, 0xd9, 0x87, 0x04, 0x5a, 0xb8, 0xe6, 0xa7, 0xf9, 0x1b, 0x45, 0xc6, 0x98, 0x7a, 0x24, 0xf8, 0xa6, 0x44, 0x1a, 0x99, 0xc7, 0x25, 0x7b, 0x3a, 0x64, 0x86, 0xd8, 0x5b, 0x05, 0xe7, 0xb9, 0x8c, 0xd2, 0x30, 0x6e, 0xed, 0xb3, 0x51, 0x0f, 0x4e, 0x10, 0xf2, 0xac, 0x2f, 0x71, 0x93, 0xcd, 0x11, 0x4f, 0xad, 0xf3, 0x70, 0x2e, 0xcc, 0x92, 0xd3, 0x8d, 0x6f, 0x31, 0xb2, 0xec, 0x0e, 0x50, 0xaf, 0xf1, 0x13, 0x4d, 0xce, 0x90, 0x72, 0x2c, 0x6d, 0x33, 0xd1, 0x8f, 0x0c, 0x52, 0xb0, 0xee, 0x32, 0x6c, 0x8e, 0xd0, 0x53, 0x0d, 0xef, 0xb1, 0xf0, 0xae, 0x4c, 0x12, 0x91, 0xcf, 0x2d, 0x73, 0xca, 0x94, 0x76, 0x28, 0xab, 0xf5, 0x17, 0x49, 0x08, 0x56, 0xb4, 0xea, 0x69, 0x37, 0xd5, 0x8b, 0x57, 0x09, 0xeb, 0xb5, 0x36, 0x68, 0x8a, 0xd4, 0x95, 0xcb, 0x29, 0x77, 0xf4, 0xaa, 0x48, 0x16, 0xe9, 0xb7, 0x55, 0x0b, 0x88, 0xd6, 0x34, 0x6a, 0x2b, 0x75, 0x97, 0xc9, 0x4a, 0x14, 0xf6, 0xa8, 0x74, 0x2a, 0xc8, 0x96, 0x15, 0x4b, 0xa9, 0xf7, 0xb6, 0xe8, 0x0a, 0x54, 0xd7, 0x89, 0x6b, 0x35]; + +if (typeof Int32Array !== 'undefined') TABLE = new Int32Array(TABLE); + +module.exports = (0, _define_crc2.default)('dallas-1-wire', function (buf, previous) { + if (!_buffer.Buffer.isBuffer(buf)) buf = (0, _buffer.Buffer)(buf); + + var crc = ~ ~previous; + + for (var index = 0; index < buf.length; index++) { + var byte = buf[index]; + crc = TABLE[(crc ^ byte) & 0xff] & 0xff; + } + + return crc; +}); \ No newline at end of file diff --git a/node_modules/express-session/node_modules/crc/lib/define_crc.js b/node_modules/express-session/node_modules/crc/lib/define_crc.js new file mode 100644 index 0000000..70c3bdc --- /dev/null +++ b/node_modules/express-session/node_modules/crc/lib/define_crc.js @@ -0,0 +1,16 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +exports.default = function (model, calc) { + var fn = function fn(buf, previous) { + return calc(buf, previous) >>> 0; + }; + fn.signed = calc; + fn.unsigned = fn; + fn.model = model; + + return fn; +}; \ No newline at end of file diff --git a/node_modules/express-session/node_modules/crc/lib/index.js b/node_modules/express-session/node_modules/crc/lib/index.js new file mode 100644 index 0000000..d25d8df --- /dev/null +++ b/node_modules/express-session/node_modules/crc/lib/index.js @@ -0,0 +1,14 @@ +'use strict'; + +module.exports = { + crc1: require('./crc1'), + crc8: require('./crc8'), + crc81wire: require('./crc8_1wire'), + crc16: require('./crc16'), + crc16ccitt: require('./crc16_ccitt'), + crc16modbus: require('./crc16_modbus'), + crc16xmodem: require('./crc16_xmodem'), + crc16kermit: require('./crc16_kermit'), + crc24: require('./crc24'), + crc32: require('./crc32') +}; \ No newline at end of file diff --git a/node_modules/express-session/node_modules/crc/package.json b/node_modules/express-session/node_modules/crc/package.json new file mode 100644 index 0000000..4a470d1 --- /dev/null +++ b/node_modules/express-session/node_modules/crc/package.json @@ -0,0 +1,66 @@ +{ + "name": "crc", + "version": "3.4.0", + "description": "Module for calculating Cyclic Redundancy Check (CRC) for Node.js and the Browser.", + "keywords": [ + "crc" + ], + "files": [ + "lib" + ], + "main": "./lib/index.js", + "scripts": { + "test": "mocha test/*.test.js", + "pretest": "cd src && babel --out-dir ../lib *.js" + }, + "author": { + "name": "Alex Gorbatchev", + "url": "https://github.com/alexgorbatchev" + }, + "devDependencies": { + "babel-core": "^6.1.21", + "babel-preset-es2015": "^6.1.18", + "beautify-benchmark": "^0.2.4", + "benchmark": "^1.0.0", + "buffer-crc32": "^0.2.3", + "chai": "^3.4.1", + "mocha": "*", + "seedrandom": "^2.3.6" + }, + "homepage": "https://github.com/alexgorbatchev/node-crc", + "bugs": { + "url": "https://github.com/alexgorbatchev/node-crc/issues" + }, + "repository": { + "type": "git", + "url": "git://github.com/alexgorbatchev/node-crc.git" + }, + "license": "MIT", + "babel": { + "presets": [ + "es2015" + ] + }, + "gitHead": "3726e792cb4a328ef2d935cfd896e54fa9529aaf", + "_id": "crc@3.4.0", + "_shasum": "4258e351613a74ef1153dfcb05e820c3e9715d7f", + "_from": "crc@3.4.0", + "_npmVersion": "2.11.3", + "_nodeVersion": "0.12.7", + "_npmUser": { + "name": "alexgorbatchev", + "email": "alex.gorbatchev@gmail.com" + }, + "dist": { + "shasum": "4258e351613a74ef1153dfcb05e820c3e9715d7f", + "tarball": "https://registry.npmjs.org/crc/-/crc-3.4.0.tgz" + }, + "maintainers": [ + { + "name": "alexgorbatchev", + "email": "alex.gorbatchev@gmail.com" + } + ], + "directories": {}, + "_resolved": "http://registry.npmjs.org/crc/-/crc-3.4.0.tgz" +} diff --git a/node_modules/express-session/node_modules/debug/.jshintrc b/node_modules/express-session/node_modules/debug/.jshintrc new file mode 100644 index 0000000..299877f --- /dev/null +++ b/node_modules/express-session/node_modules/debug/.jshintrc @@ -0,0 +1,3 @@ +{ + "laxbreak": true +} diff --git a/node_modules/express-session/node_modules/debug/.npmignore b/node_modules/express-session/node_modules/debug/.npmignore new file mode 100644 index 0000000..7e6163d --- /dev/null +++ b/node_modules/express-session/node_modules/debug/.npmignore @@ -0,0 +1,6 @@ +support +test +examples +example +*.sock +dist diff --git a/node_modules/express-session/node_modules/debug/History.md b/node_modules/express-session/node_modules/debug/History.md new file mode 100644 index 0000000..854c971 --- /dev/null +++ b/node_modules/express-session/node_modules/debug/History.md @@ -0,0 +1,195 @@ + +2.2.0 / 2015-05-09 +================== + + * package: update "ms" to v0.7.1 (#202, @dougwilson) + * README: add logging to file example (#193, @DanielOchoa) + * README: fixed a typo (#191, @amir-s) + * browser: expose `storage` (#190, @stephenmathieson) + * Makefile: add a `distclean` target (#189, @stephenmathieson) + +2.1.3 / 2015-03-13 +================== + + * Updated stdout/stderr example (#186) + * Updated example/stdout.js to match debug current behaviour + * Renamed example/stderr.js to stdout.js + * Update Readme.md (#184) + * replace high intensity foreground color for bold (#182, #183) + +2.1.2 / 2015-03-01 +================== + + * dist: recompile + * update "ms" to v0.7.0 + * package: update "browserify" to v9.0.3 + * component: fix "ms.js" repo location + * changed bower package name + * updated documentation about using debug in a browser + * fix: security error on safari (#167, #168, @yields) + +2.1.1 / 2014-12-29 +================== + + * browser: use `typeof` to check for `console` existence + * browser: check for `console.log` truthiness (fix IE 8/9) + * browser: add support for Chrome apps + * Readme: added Windows usage remarks + * Add `bower.json` to properly support bower install + +2.1.0 / 2014-10-15 +================== + + * node: implement `DEBUG_FD` env variable support + * package: update "browserify" to v6.1.0 + * package: add "license" field to package.json (#135, @panuhorsmalahti) + +2.0.0 / 2014-09-01 +================== + + * package: update "browserify" to v5.11.0 + * node: use stderr rather than stdout for logging (#29, @stephenmathieson) + +1.0.4 / 2014-07-15 +================== + + * dist: recompile + * example: remove `console.info()` log usage + * example: add "Content-Type" UTF-8 header to browser example + * browser: place %c marker after the space character + * browser: reset the "content" color via `color: inherit` + * browser: add colors support for Firefox >= v31 + * debug: prefer an instance `log()` function over the global one (#119) + * Readme: update documentation about styled console logs for FF v31 (#116, @wryk) + +1.0.3 / 2014-07-09 +================== + + * Add support for multiple wildcards in namespaces (#122, @seegno) + * browser: fix lint + +1.0.2 / 2014-06-10 +================== + + * browser: update color palette (#113, @gscottolson) + * common: make console logging function configurable (#108, @timoxley) + * node: fix %o colors on old node <= 0.8.x + * Makefile: find node path using shell/which (#109, @timoxley) + +1.0.1 / 2014-06-06 +================== + + * browser: use `removeItem()` to clear localStorage + * browser, node: don't set DEBUG if namespaces is undefined (#107, @leedm777) + * package: add "contributors" section + * node: fix comment typo + * README: list authors + +1.0.0 / 2014-06-04 +================== + + * make ms diff be global, not be scope + * debug: ignore empty strings in enable() + * node: make DEBUG_COLORS able to disable coloring + * *: export the `colors` array + * npmignore: don't publish the `dist` dir + * Makefile: refactor to use browserify + * package: add "browserify" as a dev dependency + * Readme: add Web Inspector Colors section + * node: reset terminal color for the debug content + * node: map "%o" to `util.inspect()` + * browser: map "%j" to `JSON.stringify()` + * debug: add custom "formatters" + * debug: use "ms" module for humanizing the diff + * Readme: add "bash" syntax highlighting + * browser: add Firebug color support + * browser: add colors for WebKit browsers + * node: apply log to `console` + * rewrite: abstract common logic for Node & browsers + * add .jshintrc file + +0.8.1 / 2014-04-14 +================== + + * package: re-add the "component" section + +0.8.0 / 2014-03-30 +================== + + * add `enable()` method for nodejs. Closes #27 + * change from stderr to stdout + * remove unnecessary index.js file + +0.7.4 / 2013-11-13 +================== + + * remove "browserify" key from package.json (fixes something in browserify) + +0.7.3 / 2013-10-30 +================== + + * fix: catch localStorage security error when cookies are blocked (Chrome) + * add debug(err) support. Closes #46 + * add .browser prop to package.json. Closes #42 + +0.7.2 / 2013-02-06 +================== + + * fix package.json + * fix: Mobile Safari (private mode) is broken with debug + * fix: Use unicode to send escape character to shell instead of octal to work with strict mode javascript + +0.7.1 / 2013-02-05 +================== + + * add repository URL to package.json + * add DEBUG_COLORED to force colored output + * add browserify support + * fix component. Closes #24 + +0.7.0 / 2012-05-04 +================== + + * Added .component to package.json + * Added debug.component.js build + +0.6.0 / 2012-03-16 +================== + + * Added support for "-" prefix in DEBUG [Vinay Pulim] + * Added `.enabled` flag to the node version [TooTallNate] + +0.5.0 / 2012-02-02 +================== + + * Added: humanize diffs. Closes #8 + * Added `debug.disable()` to the CS variant + * Removed padding. Closes #10 + * Fixed: persist client-side variant again. Closes #9 + +0.4.0 / 2012-02-01 +================== + + * Added browser variant support for older browsers [TooTallNate] + * Added `debug.enable('project:*')` to browser variant [TooTallNate] + * Added padding to diff (moved it to the right) + +0.3.0 / 2012-01-26 +================== + + * Added millisecond diff when isatty, otherwise UTC string + +0.2.0 / 2012-01-22 +================== + + * Added wildcard support + +0.1.0 / 2011-12-02 +================== + + * Added: remove colors unless stderr isatty [TooTallNate] + +0.0.1 / 2010-01-03 +================== + + * Initial release diff --git a/node_modules/express-session/node_modules/debug/Makefile b/node_modules/express-session/node_modules/debug/Makefile new file mode 100644 index 0000000..5cf4a59 --- /dev/null +++ b/node_modules/express-session/node_modules/debug/Makefile @@ -0,0 +1,36 @@ + +# get Makefile directory name: http://stackoverflow.com/a/5982798/376773 +THIS_MAKEFILE_PATH:=$(word $(words $(MAKEFILE_LIST)),$(MAKEFILE_LIST)) +THIS_DIR:=$(shell cd $(dir $(THIS_MAKEFILE_PATH));pwd) + +# BIN directory +BIN := $(THIS_DIR)/node_modules/.bin + +# applications +NODE ?= $(shell which node) +NPM ?= $(NODE) $(shell which npm) +BROWSERIFY ?= $(NODE) $(BIN)/browserify + +all: dist/debug.js + +install: node_modules + +clean: + @rm -rf dist + +dist: + @mkdir -p $@ + +dist/debug.js: node_modules browser.js debug.js dist + @$(BROWSERIFY) \ + --standalone debug \ + . > $@ + +distclean: clean + @rm -rf node_modules + +node_modules: package.json + @NODE_ENV= $(NPM) install + @touch node_modules + +.PHONY: all install clean distclean diff --git a/node_modules/express-session/node_modules/debug/Readme.md b/node_modules/express-session/node_modules/debug/Readme.md new file mode 100644 index 0000000..b4f45e3 --- /dev/null +++ b/node_modules/express-session/node_modules/debug/Readme.md @@ -0,0 +1,188 @@ +# debug + + tiny node.js debugging utility modelled after node core's debugging technique. + +## Installation + +```bash +$ npm install debug +``` + +## Usage + + With `debug` you simply invoke the exported function to generate your debug function, passing it a name which will determine if a noop function is returned, or a decorated `console.error`, so all of the `console` format string goodies you're used to work fine. A unique color is selected per-function for visibility. + +Example _app.js_: + +```js +var debug = require('debug')('http') + , http = require('http') + , name = 'My App'; + +// fake app + +debug('booting %s', name); + +http.createServer(function(req, res){ + debug(req.method + ' ' + req.url); + res.end('hello\n'); +}).listen(3000, function(){ + debug('listening'); +}); + +// fake worker of some kind + +require('./worker'); +``` + +Example _worker.js_: + +```js +var debug = require('debug')('worker'); + +setInterval(function(){ + debug('doing some work'); +}, 1000); +``` + + The __DEBUG__ environment variable is then used to enable these based on space or comma-delimited names. Here are some examples: + + ![debug http and worker](http://f.cl.ly/items/18471z1H402O24072r1J/Screenshot.png) + + ![debug worker](http://f.cl.ly/items/1X413v1a3M0d3C2c1E0i/Screenshot.png) + +#### Windows note + + On Windows the environment variable is set using the `set` command. + + ```cmd + set DEBUG=*,-not_this + ``` + +Then, run the program to be debugged as usual. + +## Millisecond diff + + When actively developing an application it can be useful to see when the time spent between one `debug()` call and the next. Suppose for example you invoke `debug()` before requesting a resource, and after as well, the "+NNNms" will show you how much time was spent between calls. + + ![](http://f.cl.ly/items/2i3h1d3t121M2Z1A3Q0N/Screenshot.png) + + When stdout is not a TTY, `Date#toUTCString()` is used, making it more useful for logging the debug information as shown below: + + ![](http://f.cl.ly/items/112H3i0e0o0P0a2Q2r11/Screenshot.png) + +## Conventions + + If you're using this in one or more of your libraries, you _should_ use the name of your library so that developers may toggle debugging as desired without guessing names. If you have more than one debuggers you _should_ prefix them with your library name and use ":" to separate features. For example "bodyParser" from Connect would then be "connect:bodyParser". + +## Wildcards + + The `*` character may be used as a wildcard. Suppose for example your library has debuggers named "connect:bodyParser", "connect:compress", "connect:session", instead of listing all three with `DEBUG=connect:bodyParser,connect:compress,connect:session`, you may simply do `DEBUG=connect:*`, or to run everything using this module simply use `DEBUG=*`. + + You can also exclude specific debuggers by prefixing them with a "-" character. For example, `DEBUG=*,-connect:*` would include all debuggers except those starting with "connect:". + +## Browser support + + Debug works in the browser as well, currently persisted by `localStorage`. Consider the situation shown below where you have `worker:a` and `worker:b`, and wish to debug both. Somewhere in the code on your page, include: + +```js +window.myDebug = require("debug"); +``` + + ("debug" is a global object in the browser so we give this object a different name.) When your page is open in the browser, type the following in the console: + +```js +myDebug.enable("worker:*") +``` + + Refresh the page. Debug output will continue to be sent to the console until it is disabled by typing `myDebug.disable()` in the console. + +```js +a = debug('worker:a'); +b = debug('worker:b'); + +setInterval(function(){ + a('doing some work'); +}, 1000); + +setInterval(function(){ + b('doing some work'); +}, 1200); +``` + +#### Web Inspector Colors + + Colors are also enabled on "Web Inspectors" that understand the `%c` formatting + option. These are WebKit web inspectors, Firefox ([since version + 31](https://hacks.mozilla.org/2014/05/editable-box-model-multiple-selection-sublime-text-keys-much-more-firefox-developer-tools-episode-31/)) + and the Firebug plugin for Firefox (any version). + + Colored output looks something like: + + ![](https://cloud.githubusercontent.com/assets/71256/3139768/b98c5fd8-e8ef-11e3-862a-f7253b6f47c6.png) + +### stderr vs stdout + +You can set an alternative logging method per-namespace by overriding the `log` method on a per-namespace or globally: + +Example _stdout.js_: + +```js +var debug = require('debug'); +var error = debug('app:error'); + +// by default stderr is used +error('goes to stderr!'); + +var log = debug('app:log'); +// set this namespace to log via console.log +log.log = console.log.bind(console); // don't forget to bind to console! +log('goes to stdout'); +error('still goes to stderr!'); + +// set all output to go via console.info +// overrides all per-namespace log settings +debug.log = console.info.bind(console); +error('now goes to stdout via console.info'); +log('still goes to stdout, but via console.info now'); +``` + +### Save debug output to a file + +You can save all debug statements to a file by piping them. + +Example: + +```bash +$ DEBUG_FD=3 node your-app.js 3> whatever.log +``` + +## Authors + + - TJ Holowaychuk + - Nathan Rajlich + +## License + +(The MIT License) + +Copyright (c) 2014 TJ Holowaychuk <tj@vision-media.ca> + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/express-session/node_modules/debug/bower.json b/node_modules/express-session/node_modules/debug/bower.json new file mode 100644 index 0000000..6af573f --- /dev/null +++ b/node_modules/express-session/node_modules/debug/bower.json @@ -0,0 +1,28 @@ +{ + "name": "visionmedia-debug", + "main": "dist/debug.js", + "version": "2.2.0", + "homepage": "https://github.com/visionmedia/debug", + "authors": [ + "TJ Holowaychuk " + ], + "description": "visionmedia-debug", + "moduleType": [ + "amd", + "es6", + "globals", + "node" + ], + "keywords": [ + "visionmedia", + "debug" + ], + "license": "MIT", + "ignore": [ + "**/.*", + "node_modules", + "bower_components", + "test", + "tests" + ] +} diff --git a/node_modules/express-session/node_modules/debug/browser.js b/node_modules/express-session/node_modules/debug/browser.js new file mode 100644 index 0000000..7c76452 --- /dev/null +++ b/node_modules/express-session/node_modules/debug/browser.js @@ -0,0 +1,168 @@ + +/** + * This is the web browser implementation of `debug()`. + * + * Expose `debug()` as the module. + */ + +exports = module.exports = require('./debug'); +exports.log = log; +exports.formatArgs = formatArgs; +exports.save = save; +exports.load = load; +exports.useColors = useColors; +exports.storage = 'undefined' != typeof chrome + && 'undefined' != typeof chrome.storage + ? chrome.storage.local + : localstorage(); + +/** + * Colors. + */ + +exports.colors = [ + 'lightseagreen', + 'forestgreen', + 'goldenrod', + 'dodgerblue', + 'darkorchid', + 'crimson' +]; + +/** + * Currently only WebKit-based Web Inspectors, Firefox >= v31, + * and the Firebug extension (any Firefox version) are known + * to support "%c" CSS customizations. + * + * TODO: add a `localStorage` variable to explicitly enable/disable colors + */ + +function useColors() { + // is webkit? http://stackoverflow.com/a/16459606/376773 + return ('WebkitAppearance' in document.documentElement.style) || + // is firebug? http://stackoverflow.com/a/398120/376773 + (window.console && (console.firebug || (console.exception && console.table))) || + // is firefox >= v31? + // https://developer.mozilla.org/en-US/docs/Tools/Web_Console#Styling_messages + (navigator.userAgent.toLowerCase().match(/firefox\/(\d+)/) && parseInt(RegExp.$1, 10) >= 31); +} + +/** + * Map %j to `JSON.stringify()`, since no Web Inspectors do that by default. + */ + +exports.formatters.j = function(v) { + return JSON.stringify(v); +}; + + +/** + * Colorize log arguments if enabled. + * + * @api public + */ + +function formatArgs() { + var args = arguments; + var useColors = this.useColors; + + args[0] = (useColors ? '%c' : '') + + this.namespace + + (useColors ? ' %c' : ' ') + + args[0] + + (useColors ? '%c ' : ' ') + + '+' + exports.humanize(this.diff); + + if (!useColors) return args; + + var c = 'color: ' + this.color; + args = [args[0], c, 'color: inherit'].concat(Array.prototype.slice.call(args, 1)); + + // the final "%c" is somewhat tricky, because there could be other + // arguments passed either before or after the %c, so we need to + // figure out the correct index to insert the CSS into + var index = 0; + var lastC = 0; + args[0].replace(/%[a-z%]/g, function(match) { + if ('%%' === match) return; + index++; + if ('%c' === match) { + // we only are interested in the *last* %c + // (the user may have provided their own) + lastC = index; + } + }); + + args.splice(lastC, 0, c); + return args; +} + +/** + * Invokes `console.log()` when available. + * No-op when `console.log` is not a "function". + * + * @api public + */ + +function log() { + // this hackery is required for IE8/9, where + // the `console.log` function doesn't have 'apply' + return 'object' === typeof console + && console.log + && Function.prototype.apply.call(console.log, console, arguments); +} + +/** + * Save `namespaces`. + * + * @param {String} namespaces + * @api private + */ + +function save(namespaces) { + try { + if (null == namespaces) { + exports.storage.removeItem('debug'); + } else { + exports.storage.debug = namespaces; + } + } catch(e) {} +} + +/** + * Load `namespaces`. + * + * @return {String} returns the previously persisted debug modes + * @api private + */ + +function load() { + var r; + try { + r = exports.storage.debug; + } catch(e) {} + return r; +} + +/** + * Enable namespaces listed in `localStorage.debug` initially. + */ + +exports.enable(load()); + +/** + * Localstorage attempts to return the localstorage. + * + * This is necessary because safari throws + * when a user disables cookies/localstorage + * and you attempt to access it. + * + * @return {LocalStorage} + * @api private + */ + +function localstorage(){ + try { + return window.localStorage; + } catch (e) {} +} diff --git a/node_modules/express-session/node_modules/debug/component.json b/node_modules/express-session/node_modules/debug/component.json new file mode 100644 index 0000000..ca10637 --- /dev/null +++ b/node_modules/express-session/node_modules/debug/component.json @@ -0,0 +1,19 @@ +{ + "name": "debug", + "repo": "visionmedia/debug", + "description": "small debugging utility", + "version": "2.2.0", + "keywords": [ + "debug", + "log", + "debugger" + ], + "main": "browser.js", + "scripts": [ + "browser.js", + "debug.js" + ], + "dependencies": { + "rauchg/ms.js": "0.7.1" + } +} diff --git a/node_modules/express-session/node_modules/debug/debug.js b/node_modules/express-session/node_modules/debug/debug.js new file mode 100644 index 0000000..7571a86 --- /dev/null +++ b/node_modules/express-session/node_modules/debug/debug.js @@ -0,0 +1,197 @@ + +/** + * This is the common logic for both the Node.js and web browser + * implementations of `debug()`. + * + * Expose `debug()` as the module. + */ + +exports = module.exports = debug; +exports.coerce = coerce; +exports.disable = disable; +exports.enable = enable; +exports.enabled = enabled; +exports.humanize = require('ms'); + +/** + * The currently active debug mode names, and names to skip. + */ + +exports.names = []; +exports.skips = []; + +/** + * Map of special "%n" handling functions, for the debug "format" argument. + * + * Valid key names are a single, lowercased letter, i.e. "n". + */ + +exports.formatters = {}; + +/** + * Previously assigned color. + */ + +var prevColor = 0; + +/** + * Previous log timestamp. + */ + +var prevTime; + +/** + * Select a color. + * + * @return {Number} + * @api private + */ + +function selectColor() { + return exports.colors[prevColor++ % exports.colors.length]; +} + +/** + * Create a debugger with the given `namespace`. + * + * @param {String} namespace + * @return {Function} + * @api public + */ + +function debug(namespace) { + + // define the `disabled` version + function disabled() { + } + disabled.enabled = false; + + // define the `enabled` version + function enabled() { + + var self = enabled; + + // set `diff` timestamp + var curr = +new Date(); + var ms = curr - (prevTime || curr); + self.diff = ms; + self.prev = prevTime; + self.curr = curr; + prevTime = curr; + + // add the `color` if not set + if (null == self.useColors) self.useColors = exports.useColors(); + if (null == self.color && self.useColors) self.color = selectColor(); + + var args = Array.prototype.slice.call(arguments); + + args[0] = exports.coerce(args[0]); + + if ('string' !== typeof args[0]) { + // anything else let's inspect with %o + args = ['%o'].concat(args); + } + + // apply any `formatters` transformations + var index = 0; + args[0] = args[0].replace(/%([a-z%])/g, function(match, format) { + // if we encounter an escaped % then don't increase the array index + if (match === '%%') return match; + index++; + var formatter = exports.formatters[format]; + if ('function' === typeof formatter) { + var val = args[index]; + match = formatter.call(self, val); + + // now we need to remove `args[index]` since it's inlined in the `format` + args.splice(index, 1); + index--; + } + return match; + }); + + if ('function' === typeof exports.formatArgs) { + args = exports.formatArgs.apply(self, args); + } + var logFn = enabled.log || exports.log || console.log.bind(console); + logFn.apply(self, args); + } + enabled.enabled = true; + + var fn = exports.enabled(namespace) ? enabled : disabled; + + fn.namespace = namespace; + + return fn; +} + +/** + * Enables a debug mode by namespaces. This can include modes + * separated by a colon and wildcards. + * + * @param {String} namespaces + * @api public + */ + +function enable(namespaces) { + exports.save(namespaces); + + var split = (namespaces || '').split(/[\s,]+/); + var len = split.length; + + for (var i = 0; i < len; i++) { + if (!split[i]) continue; // ignore empty strings + namespaces = split[i].replace(/\*/g, '.*?'); + if (namespaces[0] === '-') { + exports.skips.push(new RegExp('^' + namespaces.substr(1) + '$')); + } else { + exports.names.push(new RegExp('^' + namespaces + '$')); + } + } +} + +/** + * Disable debug output. + * + * @api public + */ + +function disable() { + exports.enable(''); +} + +/** + * Returns true if the given mode name is enabled, false otherwise. + * + * @param {String} name + * @return {Boolean} + * @api public + */ + +function enabled(name) { + var i, len; + for (i = 0, len = exports.skips.length; i < len; i++) { + if (exports.skips[i].test(name)) { + return false; + } + } + for (i = 0, len = exports.names.length; i < len; i++) { + if (exports.names[i].test(name)) { + return true; + } + } + return false; +} + +/** + * Coerce `val`. + * + * @param {Mixed} val + * @return {Mixed} + * @api private + */ + +function coerce(val) { + if (val instanceof Error) return val.stack || val.message; + return val; +} diff --git a/node_modules/express-session/node_modules/debug/node.js b/node_modules/express-session/node_modules/debug/node.js new file mode 100644 index 0000000..1d392a8 --- /dev/null +++ b/node_modules/express-session/node_modules/debug/node.js @@ -0,0 +1,209 @@ + +/** + * Module dependencies. + */ + +var tty = require('tty'); +var util = require('util'); + +/** + * This is the Node.js implementation of `debug()`. + * + * Expose `debug()` as the module. + */ + +exports = module.exports = require('./debug'); +exports.log = log; +exports.formatArgs = formatArgs; +exports.save = save; +exports.load = load; +exports.useColors = useColors; + +/** + * Colors. + */ + +exports.colors = [6, 2, 3, 4, 5, 1]; + +/** + * The file descriptor to write the `debug()` calls to. + * Set the `DEBUG_FD` env variable to override with another value. i.e.: + * + * $ DEBUG_FD=3 node script.js 3>debug.log + */ + +var fd = parseInt(process.env.DEBUG_FD, 10) || 2; +var stream = 1 === fd ? process.stdout : + 2 === fd ? process.stderr : + createWritableStdioStream(fd); + +/** + * Is stdout a TTY? Colored output is enabled when `true`. + */ + +function useColors() { + var debugColors = (process.env.DEBUG_COLORS || '').trim().toLowerCase(); + if (0 === debugColors.length) { + return tty.isatty(fd); + } else { + return '0' !== debugColors + && 'no' !== debugColors + && 'false' !== debugColors + && 'disabled' !== debugColors; + } +} + +/** + * Map %o to `util.inspect()`, since Node doesn't do that out of the box. + */ + +var inspect = (4 === util.inspect.length ? + // node <= 0.8.x + function (v, colors) { + return util.inspect(v, void 0, void 0, colors); + } : + // node > 0.8.x + function (v, colors) { + return util.inspect(v, { colors: colors }); + } +); + +exports.formatters.o = function(v) { + return inspect(v, this.useColors) + .replace(/\s*\n\s*/g, ' '); +}; + +/** + * Adds ANSI color escape codes if enabled. + * + * @api public + */ + +function formatArgs() { + var args = arguments; + var useColors = this.useColors; + var name = this.namespace; + + if (useColors) { + var c = this.color; + + args[0] = ' \u001b[3' + c + ';1m' + name + ' ' + + '\u001b[0m' + + args[0] + '\u001b[3' + c + 'm' + + ' +' + exports.humanize(this.diff) + '\u001b[0m'; + } else { + args[0] = new Date().toUTCString() + + ' ' + name + ' ' + args[0]; + } + return args; +} + +/** + * Invokes `console.error()` with the specified arguments. + */ + +function log() { + return stream.write(util.format.apply(this, arguments) + '\n'); +} + +/** + * Save `namespaces`. + * + * @param {String} namespaces + * @api private + */ + +function save(namespaces) { + if (null == namespaces) { + // If you set a process.env field to null or undefined, it gets cast to the + // string 'null' or 'undefined'. Just delete instead. + delete process.env.DEBUG; + } else { + process.env.DEBUG = namespaces; + } +} + +/** + * Load `namespaces`. + * + * @return {String} returns the previously persisted debug modes + * @api private + */ + +function load() { + return process.env.DEBUG; +} + +/** + * Copied from `node/src/node.js`. + * + * XXX: It's lame that node doesn't expose this API out-of-the-box. It also + * relies on the undocumented `tty_wrap.guessHandleType()` which is also lame. + */ + +function createWritableStdioStream (fd) { + var stream; + var tty_wrap = process.binding('tty_wrap'); + + // Note stream._type is used for test-module-load-list.js + + switch (tty_wrap.guessHandleType(fd)) { + case 'TTY': + stream = new tty.WriteStream(fd); + stream._type = 'tty'; + + // Hack to have stream not keep the event loop alive. + // See https://github.com/joyent/node/issues/1726 + if (stream._handle && stream._handle.unref) { + stream._handle.unref(); + } + break; + + case 'FILE': + var fs = require('fs'); + stream = new fs.SyncWriteStream(fd, { autoClose: false }); + stream._type = 'fs'; + break; + + case 'PIPE': + case 'TCP': + var net = require('net'); + stream = new net.Socket({ + fd: fd, + readable: false, + writable: true + }); + + // FIXME Should probably have an option in net.Socket to create a + // stream from an existing fd which is writable only. But for now + // we'll just add this hack and set the `readable` member to false. + // Test: ./node test/fixtures/echo.js < /etc/passwd + stream.readable = false; + stream.read = null; + stream._type = 'pipe'; + + // FIXME Hack to have stream not keep the event loop alive. + // See https://github.com/joyent/node/issues/1726 + if (stream._handle && stream._handle.unref) { + stream._handle.unref(); + } + break; + + default: + // Probably an error on in uv_guess_handle() + throw new Error('Implement me. Unknown stream file type!'); + } + + // For supporting legacy API we put the FD here. + stream.fd = fd; + + stream._isStdio = true; + + return stream; +} + +/** + * Enable namespaces listed in `process.env.DEBUG` initially. + */ + +exports.enable(load()); diff --git a/node_modules/express-session/node_modules/debug/node_modules/ms/.npmignore b/node_modules/express-session/node_modules/debug/node_modules/ms/.npmignore new file mode 100644 index 0000000..d1aa0ce --- /dev/null +++ b/node_modules/express-session/node_modules/debug/node_modules/ms/.npmignore @@ -0,0 +1,5 @@ +node_modules +test +History.md +Makefile +component.json diff --git a/node_modules/express-session/node_modules/debug/node_modules/ms/History.md b/node_modules/express-session/node_modules/debug/node_modules/ms/History.md new file mode 100644 index 0000000..32fdfc1 --- /dev/null +++ b/node_modules/express-session/node_modules/debug/node_modules/ms/History.md @@ -0,0 +1,66 @@ + +0.7.1 / 2015-04-20 +================== + + * prevent extraordinary long inputs (@evilpacket) + * Fixed broken readme link + +0.7.0 / 2014-11-24 +================== + + * add time abbreviations, updated tests and readme for the new units + * fix example in the readme. + * add LICENSE file + +0.6.2 / 2013-12-05 +================== + + * Adding repository section to package.json to suppress warning from NPM. + +0.6.1 / 2013-05-10 +================== + + * fix singularization [visionmedia] + +0.6.0 / 2013-03-15 +================== + + * fix minutes + +0.5.1 / 2013-02-24 +================== + + * add component namespace + +0.5.0 / 2012-11-09 +================== + + * add short formatting as default and .long option + * add .license property to component.json + * add version to component.json + +0.4.0 / 2012-10-22 +================== + + * add rounding to fix crazy decimals + +0.3.0 / 2012-09-07 +================== + + * fix `ms()` [visionmedia] + +0.2.0 / 2012-09-03 +================== + + * add component.json [visionmedia] + * add days support [visionmedia] + * add hours support [visionmedia] + * add minutes support [visionmedia] + * add seconds support [visionmedia] + * add ms string support [visionmedia] + * refactor tests to facilitate ms(number) [visionmedia] + +0.1.0 / 2012-03-07 +================== + + * Initial release diff --git a/node_modules/express-session/node_modules/debug/node_modules/ms/LICENSE b/node_modules/express-session/node_modules/debug/node_modules/ms/LICENSE new file mode 100644 index 0000000..6c07561 --- /dev/null +++ b/node_modules/express-session/node_modules/debug/node_modules/ms/LICENSE @@ -0,0 +1,20 @@ +(The MIT License) + +Copyright (c) 2014 Guillermo Rauch + +Permission is hereby granted, free of charge, to any person obtaining a copy of +this software and associated documentation files (the "Software"), to deal in +the Software without restriction, including without limitation the rights to +use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of +the Software, and to permit persons to whom the Software is furnished to do so, +subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS +FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR +COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER +IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN +CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/express-session/node_modules/debug/node_modules/ms/README.md b/node_modules/express-session/node_modules/debug/node_modules/ms/README.md new file mode 100644 index 0000000..9b4fd03 --- /dev/null +++ b/node_modules/express-session/node_modules/debug/node_modules/ms/README.md @@ -0,0 +1,35 @@ +# ms.js: miliseconds conversion utility + +```js +ms('2 days') // 172800000 +ms('1d') // 86400000 +ms('10h') // 36000000 +ms('2.5 hrs') // 9000000 +ms('2h') // 7200000 +ms('1m') // 60000 +ms('5s') // 5000 +ms('100') // 100 +``` + +```js +ms(60000) // "1m" +ms(2 * 60000) // "2m" +ms(ms('10 hours')) // "10h" +``` + +```js +ms(60000, { long: true }) // "1 minute" +ms(2 * 60000, { long: true }) // "2 minutes" +ms(ms('10 hours'), { long: true }) // "10 hours" +``` + +- Node/Browser compatible. Published as [`ms`](https://www.npmjs.org/package/ms) in [NPM](http://nodejs.org/download). +- If a number is supplied to `ms`, a string with a unit is returned. +- If a string that contains the number is supplied, it returns it as +a number (e.g: it returns `100` for `'100'`). +- If you pass a string with a number and a valid unit, the number of +equivalent ms is returned. + +## License + +MIT diff --git a/node_modules/express-session/node_modules/debug/node_modules/ms/index.js b/node_modules/express-session/node_modules/debug/node_modules/ms/index.js new file mode 100644 index 0000000..4f92771 --- /dev/null +++ b/node_modules/express-session/node_modules/debug/node_modules/ms/index.js @@ -0,0 +1,125 @@ +/** + * Helpers. + */ + +var s = 1000; +var m = s * 60; +var h = m * 60; +var d = h * 24; +var y = d * 365.25; + +/** + * Parse or format the given `val`. + * + * Options: + * + * - `long` verbose formatting [false] + * + * @param {String|Number} val + * @param {Object} options + * @return {String|Number} + * @api public + */ + +module.exports = function(val, options){ + options = options || {}; + if ('string' == typeof val) return parse(val); + return options.long + ? long(val) + : short(val); +}; + +/** + * Parse the given `str` and return milliseconds. + * + * @param {String} str + * @return {Number} + * @api private + */ + +function parse(str) { + str = '' + str; + if (str.length > 10000) return; + var match = /^((?:\d+)?\.?\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|years?|yrs?|y)?$/i.exec(str); + if (!match) return; + var n = parseFloat(match[1]); + var type = (match[2] || 'ms').toLowerCase(); + switch (type) { + case 'years': + case 'year': + case 'yrs': + case 'yr': + case 'y': + return n * y; + case 'days': + case 'day': + case 'd': + return n * d; + case 'hours': + case 'hour': + case 'hrs': + case 'hr': + case 'h': + return n * h; + case 'minutes': + case 'minute': + case 'mins': + case 'min': + case 'm': + return n * m; + case 'seconds': + case 'second': + case 'secs': + case 'sec': + case 's': + return n * s; + case 'milliseconds': + case 'millisecond': + case 'msecs': + case 'msec': + case 'ms': + return n; + } +} + +/** + * Short format for `ms`. + * + * @param {Number} ms + * @return {String} + * @api private + */ + +function short(ms) { + if (ms >= d) return Math.round(ms / d) + 'd'; + if (ms >= h) return Math.round(ms / h) + 'h'; + if (ms >= m) return Math.round(ms / m) + 'm'; + if (ms >= s) return Math.round(ms / s) + 's'; + return ms + 'ms'; +} + +/** + * Long format for `ms`. + * + * @param {Number} ms + * @return {String} + * @api private + */ + +function long(ms) { + return plural(ms, d, 'day') + || plural(ms, h, 'hour') + || plural(ms, m, 'minute') + || plural(ms, s, 'second') + || ms + ' ms'; +} + +/** + * Pluralization helper. + */ + +function plural(ms, n, name) { + if (ms < n) return; + if (ms < n * 1.5) return Math.floor(ms / n) + ' ' + name; + return Math.ceil(ms / n) + ' ' + name + 's'; +} diff --git a/node_modules/express-session/node_modules/debug/node_modules/ms/package.json b/node_modules/express-session/node_modules/debug/node_modules/ms/package.json new file mode 100644 index 0000000..64818de --- /dev/null +++ b/node_modules/express-session/node_modules/debug/node_modules/ms/package.json @@ -0,0 +1,48 @@ +{ + "name": "ms", + "version": "0.7.1", + "description": "Tiny ms conversion utility", + "repository": { + "type": "git", + "url": "git://github.com/guille/ms.js.git" + }, + "main": "./index", + "devDependencies": { + "mocha": "*", + "expect.js": "*", + "serve": "*" + }, + "component": { + "scripts": { + "ms/index.js": "index.js" + } + }, + "gitHead": "713dcf26d9e6fd9dbc95affe7eff9783b7f1b909", + "bugs": { + "url": "https://github.com/guille/ms.js/issues" + }, + "homepage": "https://github.com/guille/ms.js", + "_id": "ms@0.7.1", + "scripts": {}, + "_shasum": "9cd13c03adbff25b65effde7ce864ee952017098", + "_from": "ms@0.7.1", + "_npmVersion": "2.7.5", + "_nodeVersion": "0.12.2", + "_npmUser": { + "name": "rauchg", + "email": "rauchg@gmail.com" + }, + "maintainers": [ + { + "name": "rauchg", + "email": "rauchg@gmail.com" + } + ], + "dist": { + "shasum": "9cd13c03adbff25b65effde7ce864ee952017098", + "tarball": "https://registry.npmjs.org/ms/-/ms-0.7.1.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/ms/-/ms-0.7.1.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/express-session/node_modules/debug/package.json b/node_modules/express-session/node_modules/debug/package.json new file mode 100644 index 0000000..5228b80 --- /dev/null +++ b/node_modules/express-session/node_modules/debug/package.json @@ -0,0 +1,73 @@ +{ + "name": "debug", + "version": "2.2.0", + "repository": { + "type": "git", + "url": "git://github.com/visionmedia/debug.git" + }, + "description": "small debugging utility", + "keywords": [ + "debug", + "log", + "debugger" + ], + "author": { + "name": "TJ Holowaychuk", + "email": "tj@vision-media.ca" + }, + "contributors": [ + { + "name": "Nathan Rajlich", + "email": "nathan@tootallnate.net", + "url": "http://n8.io" + } + ], + "license": "MIT", + "dependencies": { + "ms": "0.7.1" + }, + "devDependencies": { + "browserify": "9.0.3", + "mocha": "*" + }, + "main": "./node.js", + "browser": "./browser.js", + "component": { + "scripts": { + "debug/index.js": "browser.js", + "debug/debug.js": "debug.js" + } + }, + "gitHead": "b38458422b5aa8aa6d286b10dfe427e8a67e2b35", + "bugs": { + "url": "https://github.com/visionmedia/debug/issues" + }, + "homepage": "https://github.com/visionmedia/debug", + "_id": "debug@2.2.0", + "scripts": {}, + "_shasum": "f87057e995b1a1f6ae6a4960664137bc56f039da", + "_from": "debug@>=2.2.0 <2.3.0", + "_npmVersion": "2.7.4", + "_nodeVersion": "0.12.2", + "_npmUser": { + "name": "tootallnate", + "email": "nathan@tootallnate.net" + }, + "maintainers": [ + { + "name": "tjholowaychuk", + "email": "tj@vision-media.ca" + }, + { + "name": "tootallnate", + "email": "nathan@tootallnate.net" + } + ], + "dist": { + "shasum": "f87057e995b1a1f6ae6a4960664137bc56f039da", + "tarball": "https://registry.npmjs.org/debug/-/debug-2.2.0.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/debug/-/debug-2.2.0.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/express-session/node_modules/depd/History.md b/node_modules/express-session/node_modules/depd/History.md new file mode 100644 index 0000000..ace1171 --- /dev/null +++ b/node_modules/express-session/node_modules/depd/History.md @@ -0,0 +1,84 @@ +1.1.0 / 2015-09-14 +================== + + * Enable strict mode in more places + * Support io.js 3.x + * Support io.js 2.x + * Support web browser loading + - Requires bundler like Browserify or webpack + +1.0.1 / 2015-04-07 +================== + + * Fix `TypeError`s when under `'use strict'` code + * Fix useless type name on auto-generated messages + * Support io.js 1.x + * Support Node.js 0.12 + +1.0.0 / 2014-09-17 +================== + + * No changes + +0.4.5 / 2014-09-09 +================== + + * Improve call speed to functions using the function wrapper + * Support Node.js 0.6 + +0.4.4 / 2014-07-27 +================== + + * Work-around v8 generating empty stack traces + +0.4.3 / 2014-07-26 +================== + + * Fix exception when global `Error.stackTraceLimit` is too low + +0.4.2 / 2014-07-19 +================== + + * Correct call site for wrapped functions and properties + +0.4.1 / 2014-07-19 +================== + + * Improve automatic message generation for function properties + +0.4.0 / 2014-07-19 +================== + + * Add `TRACE_DEPRECATION` environment variable + * Remove non-standard grey color from color output + * Support `--no-deprecation` argument + * Support `--trace-deprecation` argument + * Support `deprecate.property(fn, prop, message)` + +0.3.0 / 2014-06-16 +================== + + * Add `NO_DEPRECATION` environment variable + +0.2.0 / 2014-06-15 +================== + + * Add `deprecate.property(obj, prop, message)` + * Remove `supports-color` dependency for node.js 0.8 + +0.1.0 / 2014-06-15 +================== + + * Add `deprecate.function(fn, message)` + * Add `process.on('deprecation', fn)` emitter + * Automatically generate message when omitted from `deprecate()` + +0.0.1 / 2014-06-15 +================== + + * Fix warning for dynamic calls at singe call site + +0.0.0 / 2014-06-15 +================== + + * Initial implementation diff --git a/node_modules/express-session/node_modules/depd/LICENSE b/node_modules/express-session/node_modules/depd/LICENSE new file mode 100644 index 0000000..142ede3 --- /dev/null +++ b/node_modules/express-session/node_modules/depd/LICENSE @@ -0,0 +1,22 @@ +(The MIT License) + +Copyright (c) 2014-2015 Douglas Christopher Wilson + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/express-session/node_modules/depd/Readme.md b/node_modules/express-session/node_modules/depd/Readme.md new file mode 100644 index 0000000..09bb979 --- /dev/null +++ b/node_modules/express-session/node_modules/depd/Readme.md @@ -0,0 +1,281 @@ +# depd + +[![NPM Version][npm-version-image]][npm-url] +[![NPM Downloads][npm-downloads-image]][npm-url] +[![Node.js Version][node-image]][node-url] +[![Linux Build][travis-image]][travis-url] +[![Windows Build][appveyor-image]][appveyor-url] +[![Coverage Status][coveralls-image]][coveralls-url] +[![Gratipay][gratipay-image]][gratipay-url] + +Deprecate all the things + +> With great modules comes great responsibility; mark things deprecated! + +## Install + +This module is installed directly using `npm`: + +```sh +$ npm install depd +``` + +This module can also be bundled with systems like +[Browserify](http://browserify.org/) or [webpack](https://webpack.github.io/), +though by default this module will alter it's API to no longer display or +track deprecations. + +## API + +```js +var deprecate = require('depd')('my-module') +``` + +This library allows you to display deprecation messages to your users. +This library goes above and beyond with deprecation warnings by +introspection of the call stack (but only the bits that it is interested +in). + +Instead of just warning on the first invocation of a deprecated +function and never again, this module will warn on the first invocation +of a deprecated function per unique call site, making it ideal to alert +users of all deprecated uses across the code base, rather than just +whatever happens to execute first. + +The deprecation warnings from this module also include the file and line +information for the call into the module that the deprecated function was +in. + +**NOTE** this library has a similar interface to the `debug` module, and +this module uses the calling file to get the boundary for the call stacks, +so you should always create a new `deprecate` object in each file and not +within some central file. + +### depd(namespace) + +Create a new deprecate function that uses the given namespace name in the +messages and will display the call site prior to the stack entering the +file this function was called from. It is highly suggested you use the +name of your module as the namespace. + +### deprecate(message) + +Call this function from deprecated code to display a deprecation message. +This message will appear once per unique caller site. Caller site is the +first call site in the stack in a different file from the caller of this +function. + +If the message is omitted, a message is generated for you based on the site +of the `deprecate()` call and will display the name of the function called, +similar to the name displayed in a stack trace. + +### deprecate.function(fn, message) + +Call this function to wrap a given function in a deprecation message on any +call to the function. An optional message can be supplied to provide a custom +message. + +### deprecate.property(obj, prop, message) + +Call this function to wrap a given property on object in a deprecation message +on any accessing or setting of the property. An optional message can be supplied +to provide a custom message. + +The method must be called on the object where the property belongs (not +inherited from the prototype). + +If the property is a data descriptor, it will be converted to an accessor +descriptor in order to display the deprecation message. + +### process.on('deprecation', fn) + +This module will allow easy capturing of deprecation errors by emitting the +errors as the type "deprecation" on the global `process`. If there are no +listeners for this type, the errors are written to STDERR as normal, but if +there are any listeners, nothing will be written to STDERR and instead only +emitted. From there, you can write the errors in a different format or to a +logging source. + +The error represents the deprecation and is emitted only once with the same +rules as writing to STDERR. The error has the following properties: + + - `message` - This is the message given by the library + - `name` - This is always `'DeprecationError'` + - `namespace` - This is the namespace the deprecation came from + - `stack` - This is the stack of the call to the deprecated thing + +Example `error.stack` output: + +``` +DeprecationError: my-cool-module deprecated oldfunction + at Object. ([eval]-wrapper:6:22) + at Module._compile (module.js:456:26) + at evalScript (node.js:532:25) + at startup (node.js:80:7) + at node.js:902:3 +``` + +### process.env.NO_DEPRECATION + +As a user of modules that are deprecated, the environment variable `NO_DEPRECATION` +is provided as a quick solution to silencing deprecation warnings from being +output. The format of this is similar to that of `DEBUG`: + +```sh +$ NO_DEPRECATION=my-module,othermod node app.js +``` + +This will suppress deprecations from being output for "my-module" and "othermod". +The value is a list of comma-separated namespaces. To suppress every warning +across all namespaces, use the value `*` for a namespace. + +Providing the argument `--no-deprecation` to the `node` executable will suppress +all deprecations (only available in Node.js 0.8 or higher). + +**NOTE** This will not suppress the deperecations given to any "deprecation" +event listeners, just the output to STDERR. + +### process.env.TRACE_DEPRECATION + +As a user of modules that are deprecated, the environment variable `TRACE_DEPRECATION` +is provided as a solution to getting more detailed location information in deprecation +warnings by including the entire stack trace. The format of this is the same as +`NO_DEPRECATION`: + +```sh +$ TRACE_DEPRECATION=my-module,othermod node app.js +``` + +This will include stack traces for deprecations being output for "my-module" and +"othermod". The value is a list of comma-separated namespaces. To trace every +warning across all namespaces, use the value `*` for a namespace. + +Providing the argument `--trace-deprecation` to the `node` executable will trace +all deprecations (only available in Node.js 0.8 or higher). + +**NOTE** This will not trace the deperecations silenced by `NO_DEPRECATION`. + +## Display + +![message](files/message.png) + +When a user calls a function in your library that you mark deprecated, they +will see the following written to STDERR (in the given colors, similar colors +and layout to the `debug` module): + +``` +bright cyan bright yellow +| | reset cyan +| | | | +▼ ▼ ▼ ▼ +my-cool-module deprecated oldfunction [eval]-wrapper:6:22 +▲ ▲ ▲ ▲ +| | | | +namespace | | location of mycoolmod.oldfunction() call + | deprecation message + the word "deprecated" +``` + +If the user redirects their STDERR to a file or somewhere that does not support +colors, they see (similar layout to the `debug` module): + +``` +Sun, 15 Jun 2014 05:21:37 GMT my-cool-module deprecated oldfunction at [eval]-wrapper:6:22 +▲ ▲ ▲ ▲ ▲ +| | | | | +timestamp of message namespace | | location of mycoolmod.oldfunction() call + | deprecation message + the word "deprecated" +``` + +## Examples + +### Deprecating all calls to a function + +This will display a deprecated message about "oldfunction" being deprecated +from "my-module" on STDERR. + +```js +var deprecate = require('depd')('my-cool-module') + +// message automatically derived from function name +// Object.oldfunction +exports.oldfunction = deprecate.function(function oldfunction() { + // all calls to function are deprecated +}) + +// specific message +exports.oldfunction = deprecate.function(function () { + // all calls to function are deprecated +}, 'oldfunction') +``` + +### Conditionally deprecating a function call + +This will display a deprecated message about "weirdfunction" being deprecated +from "my-module" on STDERR when called with less than 2 arguments. + +```js +var deprecate = require('depd')('my-cool-module') + +exports.weirdfunction = function () { + if (arguments.length < 2) { + // calls with 0 or 1 args are deprecated + deprecate('weirdfunction args < 2') + } +} +``` + +When calling `deprecate` as a function, the warning is counted per call site +within your own module, so you can display different deprecations depending +on different situations and the users will still get all the warnings: + +```js +var deprecate = require('depd')('my-cool-module') + +exports.weirdfunction = function () { + if (arguments.length < 2) { + // calls with 0 or 1 args are deprecated + deprecate('weirdfunction args < 2') + } else if (typeof arguments[0] !== 'string') { + // calls with non-string first argument are deprecated + deprecate('weirdfunction non-string first arg') + } +} +``` + +### Deprecating property access + +This will display a deprecated message about "oldprop" being deprecated +from "my-module" on STDERR when accessed. A deprecation will be displayed +when setting the value and when getting the value. + +```js +var deprecate = require('depd')('my-cool-module') + +exports.oldprop = 'something' + +// message automatically derives from property name +deprecate.property(exports, 'oldprop') + +// explicit message +deprecate.property(exports, 'oldprop', 'oldprop >= 0.10') +``` + +## License + +[MIT](LICENSE) + +[npm-version-image]: https://img.shields.io/npm/v/depd.svg +[npm-downloads-image]: https://img.shields.io/npm/dm/depd.svg +[npm-url]: https://npmjs.org/package/depd +[travis-image]: https://img.shields.io/travis/dougwilson/nodejs-depd/master.svg?label=linux +[travis-url]: https://travis-ci.org/dougwilson/nodejs-depd +[appveyor-image]: https://img.shields.io/appveyor/ci/dougwilson/nodejs-depd/master.svg?label=windows +[appveyor-url]: https://ci.appveyor.com/project/dougwilson/nodejs-depd +[coveralls-image]: https://img.shields.io/coveralls/dougwilson/nodejs-depd/master.svg +[coveralls-url]: https://coveralls.io/r/dougwilson/nodejs-depd?branch=master +[node-image]: https://img.shields.io/node/v/depd.svg +[node-url]: http://nodejs.org/download/ +[gratipay-image]: https://img.shields.io/gratipay/dougwilson.svg +[gratipay-url]: https://www.gratipay.com/dougwilson/ diff --git a/node_modules/express-session/node_modules/depd/index.js b/node_modules/express-session/node_modules/depd/index.js new file mode 100644 index 0000000..fddcae8 --- /dev/null +++ b/node_modules/express-session/node_modules/depd/index.js @@ -0,0 +1,521 @@ +/*! + * depd + * Copyright(c) 2014-2015 Douglas Christopher Wilson + * MIT Licensed + */ + +/** + * Module dependencies. + */ + +var callSiteToString = require('./lib/compat').callSiteToString +var eventListenerCount = require('./lib/compat').eventListenerCount +var relative = require('path').relative + +/** + * Module exports. + */ + +module.exports = depd + +/** + * Get the path to base files on. + */ + +var basePath = process.cwd() + +/** + * Determine if namespace is contained in the string. + */ + +function containsNamespace(str, namespace) { + var val = str.split(/[ ,]+/) + + namespace = String(namespace).toLowerCase() + + for (var i = 0 ; i < val.length; i++) { + if (!(str = val[i])) continue; + + // namespace contained + if (str === '*' || str.toLowerCase() === namespace) { + return true + } + } + + return false +} + +/** + * Convert a data descriptor to accessor descriptor. + */ + +function convertDataDescriptorToAccessor(obj, prop, message) { + var descriptor = Object.getOwnPropertyDescriptor(obj, prop) + var value = descriptor.value + + descriptor.get = function getter() { return value } + + if (descriptor.writable) { + descriptor.set = function setter(val) { return value = val } + } + + delete descriptor.value + delete descriptor.writable + + Object.defineProperty(obj, prop, descriptor) + + return descriptor +} + +/** + * Create arguments string to keep arity. + */ + +function createArgumentsString(arity) { + var str = '' + + for (var i = 0; i < arity; i++) { + str += ', arg' + i + } + + return str.substr(2) +} + +/** + * Create stack string from stack. + */ + +function createStackString(stack) { + var str = this.name + ': ' + this.namespace + + if (this.message) { + str += ' deprecated ' + this.message + } + + for (var i = 0; i < stack.length; i++) { + str += '\n at ' + callSiteToString(stack[i]) + } + + return str +} + +/** + * Create deprecate for namespace in caller. + */ + +function depd(namespace) { + if (!namespace) { + throw new TypeError('argument namespace is required') + } + + var stack = getStack() + var site = callSiteLocation(stack[1]) + var file = site[0] + + function deprecate(message) { + // call to self as log + log.call(deprecate, message) + } + + deprecate._file = file + deprecate._ignored = isignored(namespace) + deprecate._namespace = namespace + deprecate._traced = istraced(namespace) + deprecate._warned = Object.create(null) + + deprecate.function = wrapfunction + deprecate.property = wrapproperty + + return deprecate +} + +/** + * Determine if namespace is ignored. + */ + +function isignored(namespace) { + /* istanbul ignore next: tested in a child processs */ + if (process.noDeprecation) { + // --no-deprecation support + return true + } + + var str = process.env.NO_DEPRECATION || '' + + // namespace ignored + return containsNamespace(str, namespace) +} + +/** + * Determine if namespace is traced. + */ + +function istraced(namespace) { + /* istanbul ignore next: tested in a child processs */ + if (process.traceDeprecation) { + // --trace-deprecation support + return true + } + + var str = process.env.TRACE_DEPRECATION || '' + + // namespace traced + return containsNamespace(str, namespace) +} + +/** + * Display deprecation message. + */ + +function log(message, site) { + var haslisteners = eventListenerCount(process, 'deprecation') !== 0 + + // abort early if no destination + if (!haslisteners && this._ignored) { + return + } + + var caller + var callFile + var callSite + var i = 0 + var seen = false + var stack = getStack() + var file = this._file + + if (site) { + // provided site + callSite = callSiteLocation(stack[1]) + callSite.name = site.name + file = callSite[0] + } else { + // get call site + i = 2 + site = callSiteLocation(stack[i]) + callSite = site + } + + // get caller of deprecated thing in relation to file + for (; i < stack.length; i++) { + caller = callSiteLocation(stack[i]) + callFile = caller[0] + + if (callFile === file) { + seen = true + } else if (callFile === this._file) { + file = this._file + } else if (seen) { + break + } + } + + var key = caller + ? site.join(':') + '__' + caller.join(':') + : undefined + + if (key !== undefined && key in this._warned) { + // already warned + return + } + + this._warned[key] = true + + // generate automatic message from call site + if (!message) { + message = callSite === site || !callSite.name + ? defaultMessage(site) + : defaultMessage(callSite) + } + + // emit deprecation if listeners exist + if (haslisteners) { + var err = DeprecationError(this._namespace, message, stack.slice(i)) + process.emit('deprecation', err) + return + } + + // format and write message + var format = process.stderr.isTTY + ? formatColor + : formatPlain + var msg = format.call(this, message, caller, stack.slice(i)) + process.stderr.write(msg + '\n', 'utf8') + + return +} + +/** + * Get call site location as array. + */ + +function callSiteLocation(callSite) { + var file = callSite.getFileName() || '' + var line = callSite.getLineNumber() + var colm = callSite.getColumnNumber() + + if (callSite.isEval()) { + file = callSite.getEvalOrigin() + ', ' + file + } + + var site = [file, line, colm] + + site.callSite = callSite + site.name = callSite.getFunctionName() + + return site +} + +/** + * Generate a default message from the site. + */ + +function defaultMessage(site) { + var callSite = site.callSite + var funcName = site.name + + // make useful anonymous name + if (!funcName) { + funcName = '' + } + + var context = callSite.getThis() + var typeName = context && callSite.getTypeName() + + // ignore useless type name + if (typeName === 'Object') { + typeName = undefined + } + + // make useful type name + if (typeName === 'Function') { + typeName = context.name || typeName + } + + return typeName && callSite.getMethodName() + ? typeName + '.' + funcName + : funcName +} + +/** + * Format deprecation message without color. + */ + +function formatPlain(msg, caller, stack) { + var timestamp = new Date().toUTCString() + + var formatted = timestamp + + ' ' + this._namespace + + ' deprecated ' + msg + + // add stack trace + if (this._traced) { + for (var i = 0; i < stack.length; i++) { + formatted += '\n at ' + callSiteToString(stack[i]) + } + + return formatted + } + + if (caller) { + formatted += ' at ' + formatLocation(caller) + } + + return formatted +} + +/** + * Format deprecation message with color. + */ + +function formatColor(msg, caller, stack) { + var formatted = '\x1b[36;1m' + this._namespace + '\x1b[22;39m' // bold cyan + + ' \x1b[33;1mdeprecated\x1b[22;39m' // bold yellow + + ' \x1b[0m' + msg + '\x1b[39m' // reset + + // add stack trace + if (this._traced) { + for (var i = 0; i < stack.length; i++) { + formatted += '\n \x1b[36mat ' + callSiteToString(stack[i]) + '\x1b[39m' // cyan + } + + return formatted + } + + if (caller) { + formatted += ' \x1b[36m' + formatLocation(caller) + '\x1b[39m' // cyan + } + + return formatted +} + +/** + * Format call site location. + */ + +function formatLocation(callSite) { + return relative(basePath, callSite[0]) + + ':' + callSite[1] + + ':' + callSite[2] +} + +/** + * Get the stack as array of call sites. + */ + +function getStack() { + var limit = Error.stackTraceLimit + var obj = {} + var prep = Error.prepareStackTrace + + Error.prepareStackTrace = prepareObjectStackTrace + Error.stackTraceLimit = Math.max(10, limit) + + // capture the stack + Error.captureStackTrace(obj) + + // slice this function off the top + var stack = obj.stack.slice(1) + + Error.prepareStackTrace = prep + Error.stackTraceLimit = limit + + return stack +} + +/** + * Capture call site stack from v8. + */ + +function prepareObjectStackTrace(obj, stack) { + return stack +} + +/** + * Return a wrapped function in a deprecation message. + */ + +function wrapfunction(fn, message) { + if (typeof fn !== 'function') { + throw new TypeError('argument fn must be a function') + } + + var args = createArgumentsString(fn.length) + var deprecate = this + var stack = getStack() + var site = callSiteLocation(stack[1]) + + site.name = fn.name + + var deprecatedfn = eval('(function (' + args + ') {\n' + + '"use strict"\n' + + 'log.call(deprecate, message, site)\n' + + 'return fn.apply(this, arguments)\n' + + '})') + + return deprecatedfn +} + +/** + * Wrap property in a deprecation message. + */ + +function wrapproperty(obj, prop, message) { + if (!obj || (typeof obj !== 'object' && typeof obj !== 'function')) { + throw new TypeError('argument obj must be object') + } + + var descriptor = Object.getOwnPropertyDescriptor(obj, prop) + + if (!descriptor) { + throw new TypeError('must call property on owner object') + } + + if (!descriptor.configurable) { + throw new TypeError('property must be configurable') + } + + var deprecate = this + var stack = getStack() + var site = callSiteLocation(stack[1]) + + // set site name + site.name = prop + + // convert data descriptor + if ('value' in descriptor) { + descriptor = convertDataDescriptorToAccessor(obj, prop, message) + } + + var get = descriptor.get + var set = descriptor.set + + // wrap getter + if (typeof get === 'function') { + descriptor.get = function getter() { + log.call(deprecate, message, site) + return get.apply(this, arguments) + } + } + + // wrap setter + if (typeof set === 'function') { + descriptor.set = function setter() { + log.call(deprecate, message, site) + return set.apply(this, arguments) + } + } + + Object.defineProperty(obj, prop, descriptor) +} + +/** + * Create DeprecationError for deprecation + */ + +function DeprecationError(namespace, message, stack) { + var error = new Error() + var stackString + + Object.defineProperty(error, 'constructor', { + value: DeprecationError + }) + + Object.defineProperty(error, 'message', { + configurable: true, + enumerable: false, + value: message, + writable: true + }) + + Object.defineProperty(error, 'name', { + enumerable: false, + configurable: true, + value: 'DeprecationError', + writable: true + }) + + Object.defineProperty(error, 'namespace', { + configurable: true, + enumerable: false, + value: namespace, + writable: true + }) + + Object.defineProperty(error, 'stack', { + configurable: true, + enumerable: false, + get: function () { + if (stackString !== undefined) { + return stackString + } + + // prepare stack trace + return stackString = createStackString.call(this, stack) + }, + set: function setter(val) { + stackString = val + } + }) + + return error +} diff --git a/node_modules/express-session/node_modules/depd/lib/browser/index.js b/node_modules/express-session/node_modules/depd/lib/browser/index.js new file mode 100644 index 0000000..f464e05 --- /dev/null +++ b/node_modules/express-session/node_modules/depd/lib/browser/index.js @@ -0,0 +1,79 @@ +/*! + * depd + * Copyright(c) 2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module exports. + * @public + */ + +module.exports = depd + +/** + * Create deprecate for namespace in caller. + */ + +function depd(namespace) { + if (!namespace) { + throw new TypeError('argument namespace is required') + } + + function deprecate(message) { + // no-op in browser + } + + deprecate._file = undefined + deprecate._ignored = true + deprecate._namespace = namespace + deprecate._traced = false + deprecate._warned = Object.create(null) + + deprecate.function = wrapfunction + deprecate.property = wrapproperty + + return deprecate +} + +/** + * Return a wrapped function in a deprecation message. + * + * This is a no-op version of the wrapper, which does nothing but call + * validation. + */ + +function wrapfunction(fn, message) { + if (typeof fn !== 'function') { + throw new TypeError('argument fn must be a function') + } + + return fn +} + +/** + * Wrap property in a deprecation message. + * + * This is a no-op version of the wrapper, which does nothing but call + * validation. + */ + +function wrapproperty(obj, prop, message) { + if (!obj || (typeof obj !== 'object' && typeof obj !== 'function')) { + throw new TypeError('argument obj must be object') + } + + var descriptor = Object.getOwnPropertyDescriptor(obj, prop) + + if (!descriptor) { + throw new TypeError('must call property on owner object') + } + + if (!descriptor.configurable) { + throw new TypeError('property must be configurable') + } + + return +} diff --git a/node_modules/express-session/node_modules/depd/lib/compat/buffer-concat.js b/node_modules/express-session/node_modules/depd/lib/compat/buffer-concat.js new file mode 100644 index 0000000..4b73381 --- /dev/null +++ b/node_modules/express-session/node_modules/depd/lib/compat/buffer-concat.js @@ -0,0 +1,35 @@ +/*! + * depd + * Copyright(c) 2014 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module exports. + */ + +module.exports = bufferConcat + +/** + * Concatenate an array of Buffers. + */ + +function bufferConcat(bufs) { + var length = 0 + + for (var i = 0, len = bufs.length; i < len; i++) { + length += bufs[i].length + } + + var buf = new Buffer(length) + var pos = 0 + + for (var i = 0, len = bufs.length; i < len; i++) { + bufs[i].copy(buf, pos) + pos += bufs[i].length + } + + return buf +} diff --git a/node_modules/express-session/node_modules/depd/lib/compat/callsite-tostring.js b/node_modules/express-session/node_modules/depd/lib/compat/callsite-tostring.js new file mode 100644 index 0000000..9ecef34 --- /dev/null +++ b/node_modules/express-session/node_modules/depd/lib/compat/callsite-tostring.js @@ -0,0 +1,103 @@ +/*! + * depd + * Copyright(c) 2014 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module exports. + */ + +module.exports = callSiteToString + +/** + * Format a CallSite file location to a string. + */ + +function callSiteFileLocation(callSite) { + var fileName + var fileLocation = '' + + if (callSite.isNative()) { + fileLocation = 'native' + } else if (callSite.isEval()) { + fileName = callSite.getScriptNameOrSourceURL() + if (!fileName) { + fileLocation = callSite.getEvalOrigin() + } + } else { + fileName = callSite.getFileName() + } + + if (fileName) { + fileLocation += fileName + + var lineNumber = callSite.getLineNumber() + if (lineNumber != null) { + fileLocation += ':' + lineNumber + + var columnNumber = callSite.getColumnNumber() + if (columnNumber) { + fileLocation += ':' + columnNumber + } + } + } + + return fileLocation || 'unknown source' +} + +/** + * Format a CallSite to a string. + */ + +function callSiteToString(callSite) { + var addSuffix = true + var fileLocation = callSiteFileLocation(callSite) + var functionName = callSite.getFunctionName() + var isConstructor = callSite.isConstructor() + var isMethodCall = !(callSite.isToplevel() || isConstructor) + var line = '' + + if (isMethodCall) { + var methodName = callSite.getMethodName() + var typeName = getConstructorName(callSite) + + if (functionName) { + if (typeName && functionName.indexOf(typeName) !== 0) { + line += typeName + '.' + } + + line += functionName + + if (methodName && functionName.lastIndexOf('.' + methodName) !== functionName.length - methodName.length - 1) { + line += ' [as ' + methodName + ']' + } + } else { + line += typeName + '.' + (methodName || '') + } + } else if (isConstructor) { + line += 'new ' + (functionName || '') + } else if (functionName) { + line += functionName + } else { + addSuffix = false + line += fileLocation + } + + if (addSuffix) { + line += ' (' + fileLocation + ')' + } + + return line +} + +/** + * Get constructor name of reviver. + */ + +function getConstructorName(obj) { + var receiver = obj.receiver + return (receiver.constructor && receiver.constructor.name) || null +} diff --git a/node_modules/express-session/node_modules/depd/lib/compat/event-listener-count.js b/node_modules/express-session/node_modules/depd/lib/compat/event-listener-count.js new file mode 100644 index 0000000..a05fceb --- /dev/null +++ b/node_modules/express-session/node_modules/depd/lib/compat/event-listener-count.js @@ -0,0 +1,22 @@ +/*! + * depd + * Copyright(c) 2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module exports. + * @public + */ + +module.exports = eventListenerCount + +/** + * Get the count of listeners on an event emitter of a specific type. + */ + +function eventListenerCount(emitter, type) { + return emitter.listeners(type).length +} diff --git a/node_modules/express-session/node_modules/depd/lib/compat/index.js b/node_modules/express-session/node_modules/depd/lib/compat/index.js new file mode 100644 index 0000000..aa3c1de --- /dev/null +++ b/node_modules/express-session/node_modules/depd/lib/compat/index.js @@ -0,0 +1,84 @@ +/*! + * depd + * Copyright(c) 2014-2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module dependencies. + * @private + */ + +var Buffer = require('buffer') +var EventEmitter = require('events').EventEmitter + +/** + * Module exports. + * @public + */ + +lazyProperty(module.exports, 'bufferConcat', function bufferConcat() { + return Buffer.concat || require('./buffer-concat') +}) + +lazyProperty(module.exports, 'callSiteToString', function callSiteToString() { + var limit = Error.stackTraceLimit + var obj = {} + var prep = Error.prepareStackTrace + + function prepareObjectStackTrace(obj, stack) { + return stack + } + + Error.prepareStackTrace = prepareObjectStackTrace + Error.stackTraceLimit = 2 + + // capture the stack + Error.captureStackTrace(obj) + + // slice the stack + var stack = obj.stack.slice() + + Error.prepareStackTrace = prep + Error.stackTraceLimit = limit + + return stack[0].toString ? toString : require('./callsite-tostring') +}) + +lazyProperty(module.exports, 'eventListenerCount', function eventListenerCount() { + return EventEmitter.listenerCount || require('./event-listener-count') +}) + +/** + * Define a lazy property. + */ + +function lazyProperty(obj, prop, getter) { + function get() { + var val = getter() + + Object.defineProperty(obj, prop, { + configurable: true, + enumerable: true, + value: val + }) + + return val + } + + Object.defineProperty(obj, prop, { + configurable: true, + enumerable: true, + get: get + }) +} + +/** + * Call toString() on the obj + */ + +function toString(obj) { + return obj.toString() +} diff --git a/node_modules/express-session/node_modules/depd/package.json b/node_modules/express-session/node_modules/depd/package.json new file mode 100644 index 0000000..57bfc94 --- /dev/null +++ b/node_modules/express-session/node_modules/depd/package.json @@ -0,0 +1,67 @@ +{ + "name": "depd", + "description": "Deprecate all the things", + "version": "1.1.0", + "author": { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + }, + "license": "MIT", + "keywords": [ + "deprecate", + "deprecated" + ], + "repository": { + "type": "git", + "url": "git+https://github.com/dougwilson/nodejs-depd.git" + }, + "browser": "lib/browser/index.js", + "devDependencies": { + "benchmark": "1.0.0", + "beautify-benchmark": "0.2.4", + "istanbul": "0.3.5", + "mocha": "~1.21.5" + }, + "files": [ + "lib/", + "History.md", + "LICENSE", + "index.js", + "Readme.md" + ], + "engines": { + "node": ">= 0.6" + }, + "scripts": { + "bench": "node benchmark/index.js", + "test": "mocha --reporter spec --bail test/", + "test-ci": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter spec --no-exit test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot test/" + }, + "gitHead": "78c659de20283e3a6bee92bda455e6daff01686a", + "bugs": { + "url": "https://github.com/dougwilson/nodejs-depd/issues" + }, + "homepage": "https://github.com/dougwilson/nodejs-depd", + "_id": "depd@1.1.0", + "_shasum": "e1bd82c6aab6ced965b97b88b17ed3e528ca18c3", + "_from": "depd@>=1.1.0 <1.2.0", + "_npmVersion": "1.4.28", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "maintainers": [ + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + } + ], + "dist": { + "shasum": "e1bd82c6aab6ced965b97b88b17ed3e528ca18c3", + "tarball": "https://registry.npmjs.org/depd/-/depd-1.1.0.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/depd/-/depd-1.1.0.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/express-session/node_modules/on-headers/HISTORY.md b/node_modules/express-session/node_modules/on-headers/HISTORY.md new file mode 100644 index 0000000..e51ff01 --- /dev/null +++ b/node_modules/express-session/node_modules/on-headers/HISTORY.md @@ -0,0 +1,16 @@ +1.0.1 / 2015-09-29 +================== + + * perf: enable strict mode + +1.0.0 / 2014-08-10 +================== + + * Honor `res.statusCode` change in `listener` + * Move to `jshttp` orgainzation + * Prevent `arguments`-related de-opt + +0.0.0 / 2014-05-13 +================== + + * Initial implementation diff --git a/node_modules/express-session/node_modules/on-headers/LICENSE b/node_modules/express-session/node_modules/on-headers/LICENSE new file mode 100644 index 0000000..b7dce6c --- /dev/null +++ b/node_modules/express-session/node_modules/on-headers/LICENSE @@ -0,0 +1,22 @@ +(The MIT License) + +Copyright (c) 2014 Douglas Christopher Wilson + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/express-session/node_modules/on-headers/README.md b/node_modules/express-session/node_modules/on-headers/README.md new file mode 100644 index 0000000..48ed9ae --- /dev/null +++ b/node_modules/express-session/node_modules/on-headers/README.md @@ -0,0 +1,76 @@ +# on-headers + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Node.js Version][node-version-image]][node-version-url] +[![Build Status][travis-image]][travis-url] +[![Test Coverage][coveralls-image]][coveralls-url] + +Execute a listener when a response is about to write headers. + +## Installation + +```sh +$ npm install on-headers +``` + +## API + +```js +var onHeaders = require('on-headers') +``` + +### onHeaders(res, listener) + +This will add the listener `listener` to fire when headers are emitted for `res`. +The listener is passed the `response` object as it's context (`this`). Headers are +considered to be emitted only once, right before they are sent to the client. + +When this is called multiple times on the same `res`, the `listener`s are fired +in the reverse order they were added. + +## Examples + +```js +var http = require('http') +var onHeaders = require('on-headers') + +http +.createServer(onRequest) +.listen(3000) + +function addPoweredBy() { + // set if not set by end of request + if (!this.getHeader('X-Powered-By')) { + this.setHeader('X-Powered-By', 'Node.js') + } +} + +function onRequest(req, res) { + onHeaders(res, addPoweredBy) + + res.setHeader('Content-Type', 'text/plain') + res.end('hello!') +} +``` + +## Testing + +```sh +$ npm test +``` + +## License + +[MIT](LICENSE) + +[npm-image]: https://img.shields.io/npm/v/on-headers.svg +[npm-url]: https://npmjs.org/package/on-headers +[node-version-image]: https://img.shields.io/node/v/on-headers.svg +[node-version-url]: http://nodejs.org/download/ +[travis-image]: https://img.shields.io/travis/jshttp/on-headers/master.svg +[travis-url]: https://travis-ci.org/jshttp/on-headers +[coveralls-image]: https://img.shields.io/coveralls/jshttp/on-headers/master.svg +[coveralls-url]: https://coveralls.io/r/jshttp/on-headers?branch=master +[downloads-image]: https://img.shields.io/npm/dm/on-headers.svg +[downloads-url]: https://npmjs.org/package/on-headers diff --git a/node_modules/express-session/node_modules/on-headers/index.js b/node_modules/express-session/node_modules/on-headers/index.js new file mode 100644 index 0000000..089f2b3 --- /dev/null +++ b/node_modules/express-session/node_modules/on-headers/index.js @@ -0,0 +1,93 @@ +/*! + * on-headers + * Copyright(c) 2014 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Reference to Array slice. + */ + +var slice = Array.prototype.slice + +/** + * Execute a listener when a response is about to write headers. + * + * @param {Object} res + * @return {Function} listener + * @api public + */ + +module.exports = function onHeaders(res, listener) { + if (!res) { + throw new TypeError('argument res is required') + } + + if (typeof listener !== 'function') { + throw new TypeError('argument listener must be a function') + } + + res.writeHead = createWriteHead(res.writeHead, listener) +} + +function createWriteHead(prevWriteHead, listener) { + var fired = false; + + // return function with core name and argument list + return function writeHead(statusCode) { + // set headers from arguments + var args = setWriteHeadHeaders.apply(this, arguments); + + // fire listener + if (!fired) { + fired = true + listener.call(this) + + // pass-along an updated status code + if (typeof args[0] === 'number' && this.statusCode !== args[0]) { + args[0] = this.statusCode + args.length = 1 + } + } + + prevWriteHead.apply(this, args); + } +} + +function setWriteHeadHeaders(statusCode) { + var length = arguments.length + var headerIndex = length > 1 && typeof arguments[1] === 'string' + ? 2 + : 1 + + var headers = length >= headerIndex + 1 + ? arguments[headerIndex] + : undefined + + this.statusCode = statusCode + + // the following block is from node.js core + if (Array.isArray(headers)) { + // handle array case + for (var i = 0, len = headers.length; i < len; ++i) { + this.setHeader(headers[i][0], headers[i][1]) + } + } else if (headers) { + // handle object case + var keys = Object.keys(headers) + for (var i = 0; i < keys.length; i++) { + var k = keys[i] + if (k) this.setHeader(k, headers[k]) + } + } + + // copy leading arguments + var args = new Array(Math.min(length, headerIndex)) + for (var i = 0; i < args.length; i++) { + args[i] = arguments[i] + } + + return args +} diff --git a/node_modules/express-session/node_modules/on-headers/package.json b/node_modules/express-session/node_modules/on-headers/package.json new file mode 100644 index 0000000..41ddd65 --- /dev/null +++ b/node_modules/express-session/node_modules/on-headers/package.json @@ -0,0 +1,70 @@ +{ + "name": "on-headers", + "description": "Execute a listener when a response is about to write headers", + "version": "1.0.1", + "author": { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + }, + "license": "MIT", + "keywords": [ + "event", + "headers", + "http", + "onheaders" + ], + "repository": { + "type": "git", + "url": "git+https://github.com/jshttp/on-headers.git" + }, + "dependencies": {}, + "devDependencies": { + "istanbul": "0.3.21", + "mocha": "2.3.3", + "supertest": "1.1.0" + }, + "files": [ + "LICENSE", + "HISTORY.md", + "README.md", + "index.js" + ], + "engines": { + "node": ">= 0.8" + }, + "scripts": { + "test": "mocha --reporter spec --bail --check-leaks test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot --check-leaks test/", + "test-travis": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter spec --check-leaks test/" + }, + "gitHead": "ab0156a979d72353cfe666cccb3639e016b00280", + "bugs": { + "url": "https://github.com/jshttp/on-headers/issues" + }, + "homepage": "https://github.com/jshttp/on-headers", + "_id": "on-headers@1.0.1", + "_shasum": "928f5d0f470d49342651ea6794b0857c100693f7", + "_from": "on-headers@>=1.0.1 <1.1.0", + "_npmVersion": "1.4.28", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "maintainers": [ + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "jongleberry", + "email": "jonathanrichardong@gmail.com" + } + ], + "dist": { + "shasum": "928f5d0f470d49342651ea6794b0857c100693f7", + "tarball": "https://registry.npmjs.org/on-headers/-/on-headers-1.0.1.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/on-headers/-/on-headers-1.0.1.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/express-session/node_modules/parseurl/HISTORY.md b/node_modules/express-session/node_modules/parseurl/HISTORY.md new file mode 100644 index 0000000..395041e --- /dev/null +++ b/node_modules/express-session/node_modules/parseurl/HISTORY.md @@ -0,0 +1,47 @@ +1.3.1 / 2016-01-17 +================== + + * perf: enable strict mode + +1.3.0 / 2014-08-09 +================== + + * Add `parseurl.original` for parsing `req.originalUrl` with fallback + * Return `undefined` if `req.url` is `undefined` + +1.2.0 / 2014-07-21 +================== + + * Cache URLs based on original value + * Remove no-longer-needed URL mis-parse work-around + * Simplify the "fast-path" `RegExp` + +1.1.3 / 2014-07-08 +================== + + * Fix typo + +1.1.2 / 2014-07-08 +================== + + * Seriously fix Node.js 0.8 compatibility + +1.1.1 / 2014-07-08 +================== + + * Fix Node.js 0.8 compatibility + +1.1.0 / 2014-07-08 +================== + + * Incorporate URL href-only parse fast-path + +1.0.1 / 2014-03-08 +================== + + * Add missing `require` + +1.0.0 / 2014-03-08 +================== + + * Genesis from `connect` diff --git a/node_modules/express-session/node_modules/parseurl/LICENSE b/node_modules/express-session/node_modules/parseurl/LICENSE new file mode 100644 index 0000000..ec7dfe7 --- /dev/null +++ b/node_modules/express-session/node_modules/parseurl/LICENSE @@ -0,0 +1,24 @@ + +(The MIT License) + +Copyright (c) 2014 Jonathan Ong +Copyright (c) 2014 Douglas Christopher Wilson + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/express-session/node_modules/parseurl/README.md b/node_modules/express-session/node_modules/parseurl/README.md new file mode 100644 index 0000000..f4796eb --- /dev/null +++ b/node_modules/express-session/node_modules/parseurl/README.md @@ -0,0 +1,120 @@ +# parseurl + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Node.js Version][node-version-image]][node-version-url] +[![Build Status][travis-image]][travis-url] +[![Test Coverage][coveralls-image]][coveralls-url] + +Parse a URL with memoization. + +## Install + +```bash +$ npm install parseurl +``` + +## API + +```js +var parseurl = require('parseurl') +``` + +### parseurl(req) + +Parse the URL of the given request object (looks at the `req.url` property) +and return the result. The result is the same as `url.parse` in Node.js core. +Calling this function multiple times on the same `req` where `req.url` does +not change will return a cached parsed object, rather than parsing again. + +### parseurl.original(req) + +Parse the original URL of the given request object and return the result. +This works by trying to parse `req.originalUrl` if it is a string, otherwise +parses `req.url`. The result is the same as `url.parse` in Node.js core. +Calling this function multiple times on the same `req` where `req.originalUrl` +does not change will return a cached parsed object, rather than parsing again. + +## Benchmark + +```bash +$ npm run-script bench + +> parseurl@1.3.1 bench nodejs-parseurl +> node benchmark/index.js + +> node benchmark/fullurl.js + + Parsing URL "http://localhost:8888/foo/bar?user=tj&pet=fluffy" + + 1 test completed. + 2 tests completed. + 3 tests completed. + + fasturl x 1,290,780 ops/sec ±0.46% (195 runs sampled) + nativeurl x 56,401 ops/sec ±0.22% (196 runs sampled) + parseurl x 55,231 ops/sec ±0.22% (194 runs sampled) + +> node benchmark/pathquery.js + + Parsing URL "/foo/bar?user=tj&pet=fluffy" + + 1 test completed. + 2 tests completed. + 3 tests completed. + + fasturl x 1,986,668 ops/sec ±0.27% (190 runs sampled) + nativeurl x 98,740 ops/sec ±0.21% (195 runs sampled) + parseurl x 2,628,171 ops/sec ±0.36% (195 runs sampled) + +> node benchmark/samerequest.js + + Parsing URL "/foo/bar?user=tj&pet=fluffy" on same request object + + 1 test completed. + 2 tests completed. + 3 tests completed. + + fasturl x 2,184,468 ops/sec ±0.40% (194 runs sampled) + nativeurl x 99,437 ops/sec ±0.71% (194 runs sampled) + parseurl x 10,498,005 ops/sec ±0.61% (186 runs sampled) + +> node benchmark/simplepath.js + + Parsing URL "/foo/bar" + + 1 test completed. + 2 tests completed. + 3 tests completed. + + fasturl x 4,535,825 ops/sec ±0.27% (191 runs sampled) + nativeurl x 98,769 ops/sec ±0.54% (191 runs sampled) + parseurl x 4,164,865 ops/sec ±0.34% (192 runs sampled) + +> node benchmark/slash.js + + Parsing URL "/" + + 1 test completed. + 2 tests completed. + 3 tests completed. + + fasturl x 4,908,405 ops/sec ±0.42% (191 runs sampled) + nativeurl x 100,945 ops/sec ±0.59% (188 runs sampled) + parseurl x 4,333,208 ops/sec ±0.27% (194 runs sampled) +``` + +## License + + [MIT](LICENSE) + +[npm-image]: https://img.shields.io/npm/v/parseurl.svg +[npm-url]: https://npmjs.org/package/parseurl +[node-version-image]: https://img.shields.io/node/v/parseurl.svg +[node-version-url]: http://nodejs.org/download/ +[travis-image]: https://img.shields.io/travis/pillarjs/parseurl/master.svg +[travis-url]: https://travis-ci.org/pillarjs/parseurl +[coveralls-image]: https://img.shields.io/coveralls/pillarjs/parseurl/master.svg +[coveralls-url]: https://coveralls.io/r/pillarjs/parseurl?branch=master +[downloads-image]: https://img.shields.io/npm/dm/parseurl.svg +[downloads-url]: https://npmjs.org/package/parseurl diff --git a/node_modules/express-session/node_modules/parseurl/index.js b/node_modules/express-session/node_modules/parseurl/index.js new file mode 100644 index 0000000..56cc6ec --- /dev/null +++ b/node_modules/express-session/node_modules/parseurl/index.js @@ -0,0 +1,138 @@ +/*! + * parseurl + * Copyright(c) 2014 Jonathan Ong + * Copyright(c) 2014 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module dependencies. + */ + +var url = require('url') +var parse = url.parse +var Url = url.Url + +/** + * Pattern for a simple path case. + * See: https://github.com/joyent/node/pull/7878 + */ + +var simplePathRegExp = /^(\/\/?(?!\/)[^\?#\s]*)(\?[^#\s]*)?$/ + +/** + * Exports. + */ + +module.exports = parseurl +module.exports.original = originalurl + +/** + * Parse the `req` url with memoization. + * + * @param {ServerRequest} req + * @return {Object} + * @api public + */ + +function parseurl(req) { + var url = req.url + + if (url === undefined) { + // URL is undefined + return undefined + } + + var parsed = req._parsedUrl + + if (fresh(url, parsed)) { + // Return cached URL parse + return parsed + } + + // Parse the URL + parsed = fastparse(url) + parsed._raw = url + + return req._parsedUrl = parsed +}; + +/** + * Parse the `req` original url with fallback and memoization. + * + * @param {ServerRequest} req + * @return {Object} + * @api public + */ + +function originalurl(req) { + var url = req.originalUrl + + if (typeof url !== 'string') { + // Fallback + return parseurl(req) + } + + var parsed = req._parsedOriginalUrl + + if (fresh(url, parsed)) { + // Return cached URL parse + return parsed + } + + // Parse the URL + parsed = fastparse(url) + parsed._raw = url + + return req._parsedOriginalUrl = parsed +}; + +/** + * Parse the `str` url with fast-path short-cut. + * + * @param {string} str + * @return {Object} + * @api private + */ + +function fastparse(str) { + // Try fast path regexp + // See: https://github.com/joyent/node/pull/7878 + var simplePath = typeof str === 'string' && simplePathRegExp.exec(str) + + // Construct simple URL + if (simplePath) { + var pathname = simplePath[1] + var search = simplePath[2] || null + var url = Url !== undefined + ? new Url() + : {} + url.path = str + url.href = str + url.pathname = pathname + url.search = search + url.query = search && search.substr(1) + + return url + } + + return parse(str) +} + +/** + * Determine if parsed is still fresh for url. + * + * @param {string} url + * @param {object} parsedUrl + * @return {boolean} + * @api private + */ + +function fresh(url, parsedUrl) { + return typeof parsedUrl === 'object' + && parsedUrl !== null + && (Url === undefined || parsedUrl instanceof Url) + && parsedUrl._raw === url +} diff --git a/node_modules/express-session/node_modules/parseurl/package.json b/node_modules/express-session/node_modules/parseurl/package.json new file mode 100644 index 0000000..35e6d20 --- /dev/null +++ b/node_modules/express-session/node_modules/parseurl/package.json @@ -0,0 +1,89 @@ +{ + "name": "parseurl", + "description": "parse a url with memoization", + "version": "1.3.1", + "author": { + "name": "Jonathan Ong", + "email": "me@jongleberry.com", + "url": "http://jongleberry.com" + }, + "contributors": [ + { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + } + ], + "repository": { + "type": "git", + "url": "git+https://github.com/pillarjs/parseurl.git" + }, + "license": "MIT", + "devDependencies": { + "benchmark": "2.0.0", + "beautify-benchmark": "0.2.4", + "fast-url-parser": "1.1.3", + "istanbul": "0.4.2", + "mocha": "~1.21.5" + }, + "files": [ + "LICENSE", + "HISTORY.md", + "README.md", + "index.js" + ], + "engines": { + "node": ">= 0.8" + }, + "scripts": { + "bench": "node benchmark/index.js", + "test": "mocha --check-leaks --bail --reporter spec test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --check-leaks --reporter dot test/", + "test-travis": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --check-leaks --reporter spec test/" + }, + "gitHead": "6d22d376d75b927ab2b5347ce3a1d6735133dd43", + "bugs": { + "url": "https://github.com/pillarjs/parseurl/issues" + }, + "homepage": "https://github.com/pillarjs/parseurl", + "_id": "parseurl@1.3.1", + "_shasum": "c8ab8c9223ba34888aa64a297b28853bec18da56", + "_from": "parseurl@>=1.3.1 <1.4.0", + "_npmVersion": "1.4.28", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "maintainers": [ + { + "name": "jongleberry", + "email": "jonathanrichardong@gmail.com" + }, + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "tjholowaychuk", + "email": "tj@vision-media.ca" + }, + { + "name": "mscdex", + "email": "mscdex@mscdex.net" + }, + { + "name": "fishrock123", + "email": "fishrock123@rocketmail.com" + }, + { + "name": "defunctzombie", + "email": "shtylman@gmail.com" + } + ], + "dist": { + "shasum": "c8ab8c9223ba34888aa64a297b28853bec18da56", + "tarball": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.1.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/parseurl/-/parseurl-1.3.1.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/express-session/node_modules/uid-safe/HISTORY.md b/node_modules/express-session/node_modules/uid-safe/HISTORY.md new file mode 100644 index 0000000..d102772 --- /dev/null +++ b/node_modules/express-session/node_modules/uid-safe/HISTORY.md @@ -0,0 +1,46 @@ +2.1.2 / 2016-08-15 +================== + + * deps: base64-url@1.3.2 + +2.1.1 / 2016-05-04 +================== + + * deps: base64-url@1.2.2 + +2.1.0 / 2016-01-17 +================== + + * Use `random-bytes` for byte source + +2.0.0 / 2015-05-08 +================== + + * Use global `Promise` when returning a promise + +1.1.0 / 2015-02-01 +================== + + * Use `crypto.randomBytes`, if available + * deps: base64-url@1.2.1 + +1.0.3 / 2015-01-31 +================== + + * Fix error branch that would throw + * deps: base64-url@1.2.0 + +1.0.2 / 2015-01-08 +================== + + * Remove dependency on `mz` + +1.0.1 / 2014-06-18 +================== + + * Remove direct `bluebird` dependency + +1.0.0 / 2014-06-18 +================== + + * Initial release diff --git a/node_modules/express-session/node_modules/uid-safe/LICENSE b/node_modules/express-session/node_modules/uid-safe/LICENSE new file mode 100644 index 0000000..7a7a4e1 --- /dev/null +++ b/node_modules/express-session/node_modules/uid-safe/LICENSE @@ -0,0 +1,22 @@ +The MIT License (MIT) + +Copyright (c) 2014 Jonathan Ong +Copyright (c) 2015-2016 Douglas Christopher Wilson + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. diff --git a/node_modules/express-session/node_modules/uid-safe/README.md b/node_modules/express-session/node_modules/uid-safe/README.md new file mode 100644 index 0000000..fa02be8 --- /dev/null +++ b/node_modules/express-session/node_modules/uid-safe/README.md @@ -0,0 +1,77 @@ +# uid-safe + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Node.js Version][node-version-image]][node-version-url] +[![Build Status][travis-image]][travis-url] +[![Test Coverage][coveralls-image]][coveralls-url] + +URL and cookie safe UIDs + +Create cryptographically secure UIDs safe for both cookie and URL usage. +This is in contrast to modules such as [rand-token](https://www.npmjs.com/package/rand-token) +and [uid2](https://www.npmjs.com/package/uid2) whose UIDs are actually skewed +due to the use of `%` and unnecessarily truncate the UID. +Use this if you could still use UIDs with `-` and `_` in them. + +## Installation + +```sh +$ npm install uid-safe +``` + +## API + +```js +var uid = require('uid-safe') +``` + +### uid(byteLength, callback) + +Asynchronously create a UID with a specific byte length. Because `base64` +encoding is used underneath, this is not the string length. For example, +to create a UID of length 24, you want a byte length of 18. + +```js +uid(18, function (err, string) { + if (err) throw err + // do something with the string +}) +``` + +### uid(byteLength) + +Asynchronously create a UID with a specific byte length and return a +`Promise`. + +**Note**: To use promises in Node.js _prior to 0.12_, promises must be +"polyfilled" using `global.Promise = require('bluebird')`. + +```js +uid(18).then(function (string) { + // do something with the string +}) +``` + +### uid.sync(byteLength) + +A synchronous version of above. + +```js +var string = uid.sync(18) +``` + +## License + +[MIT](LICENSE) + +[npm-image]: https://img.shields.io/npm/v/uid-safe.svg +[npm-url]: https://npmjs.org/package/uid-safe +[node-version-image]: https://img.shields.io/node/v/uid-safe.svg +[node-version-url]: https://nodejs.org/en/download/ +[travis-image]: https://img.shields.io/travis/crypto-utils/uid-safe/master.svg +[travis-url]: https://travis-ci.org/crypto-utils/uid-safe +[coveralls-image]: https://img.shields.io/coveralls/crypto-utils/uid-safe/master.svg +[coveralls-url]: https://coveralls.io/r/crypto-utils/uid-safe?branch=master +[downloads-image]: https://img.shields.io/npm/dm/uid-safe.svg +[downloads-url]: https://npmjs.org/package/uid-safe diff --git a/node_modules/express-session/node_modules/uid-safe/index.js b/node_modules/express-session/node_modules/uid-safe/index.js new file mode 100644 index 0000000..92ab744 --- /dev/null +++ b/node_modules/express-session/node_modules/uid-safe/index.js @@ -0,0 +1,96 @@ +/*! + * uid-safe + * Copyright(c) 2014 Jonathan Ong + * Copyright(c) 2015-2016 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module dependencies. + * @private + */ + +var escape = require('base64-url').escape +var randomBytes = require('random-bytes') + +/** + * Module exports. + * @public + */ + +module.exports = uid +module.exports.sync = uidSync + +/** + * Create a unique ID. + * + * @param {number} length + * @param {function} [callback] + * @return {Promise} + * @public + */ + +function uid (length, callback) { + // validate callback is a function, if provided + if (callback !== undefined && typeof callback !== 'function') { + throw new TypeError('argument callback must be a function') + } + + // require the callback without promises + if (!callback && !global.Promise) { + throw new TypeError('argument callback is required') + } + + if (callback) { + // classic callback style + return generateUid(length, callback) + } + + return new Promise(function executor (resolve, reject) { + generateUid(length, function onUid (err, str) { + if (err) return reject(err) + resolve(str) + }) + }) +} + +/** + * Create a unique ID sync. + * + * @param {number} length + * @return {string} + * @public + */ + +function uidSync (length) { + return toString(randomBytes.sync(length)) +} + +/** + * Generate a unique ID string. + * + * @param {number} length + * @param {function} callback + * @private + */ + +function generateUid (length, callback) { + randomBytes(length, function (err, buf) { + if (err) return callback(err) + callback(null, toString(buf)) + }) +} + +/** + * Change a Buffer into a string. + * + * @param {Buffer} buf + * @return {string} + * @private + */ + +function toString (buf) { + return escape(buf.toString('base64')) +} diff --git a/node_modules/express-session/node_modules/uid-safe/node_modules/base64-url/LICENSE b/node_modules/express-session/node_modules/uid-safe/node_modules/base64-url/LICENSE new file mode 100644 index 0000000..9549143 --- /dev/null +++ b/node_modules/express-session/node_modules/uid-safe/node_modules/base64-url/LICENSE @@ -0,0 +1,15 @@ +The ISC License + +Copyright (c) 2014, Joaquim José F. Serafim + +Permission to use, copy, modify, and/or distribute this software for any +purpose with or without fee is hereby granted, provided that the above +copyright notice and this permission notice appear in all copies. + +THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES +WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF +MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR +ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES +WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN +ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR +IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. diff --git a/node_modules/express-session/node_modules/uid-safe/node_modules/base64-url/README.md b/node_modules/express-session/node_modules/uid-safe/node_modules/base64-url/README.md new file mode 100644 index 0000000..dfa3e70 --- /dev/null +++ b/node_modules/express-session/node_modules/uid-safe/node_modules/base64-url/README.md @@ -0,0 +1,50 @@ +# base64-url + +Base64 encode, decode, escape and unescape for URL applications. + + + +[![Build Status](https://travis-ci.org/joaquimserafim/base64-url.png?branch=master)](https://travis-ci.org/joaquimserafim/base64-url) + + +## API + +```js +base64url.encode('Node.js is awesome.'); +// returns Tm9kZS5qcyBpcyBhd2Vzb21lLg + +base64url.decode('Tm9kZS5qcyBpcyBhd2Vzb21lLg'); +// returns Node.js is awesome. + +base64url.escape('This+is/goingto+escape=='); +// returns This-is_goingto-escape + +base64url.unescape('This-is_goingto-escape'); +// returns This+is/goingto+escape== +``` + + +## Development + +**this projet has been set up with a precommit that forces you to follow a code style, no jshint issues and 100% of code coverage before commit** + + +to run test +``` js +npm test +``` + +to run lint +``` js +npm run lint +``` + +to run code style +``` js +npm run style +``` + +to check code coverage +``` js +npm run coverage:check +``` diff --git a/node_modules/express-session/node_modules/uid-safe/node_modules/base64-url/index.js b/node_modules/express-session/node_modules/uid-safe/node_modules/base64-url/index.js new file mode 100644 index 0000000..9ba16e9 --- /dev/null +++ b/node_modules/express-session/node_modules/uid-safe/node_modules/base64-url/index.js @@ -0,0 +1,23 @@ +'use strict'; + +var base64url = module.exports; + +base64url.unescape = function unescape (str) { + return (str + '==='.slice((str.length + 3) % 4)) + .replace(/\-/g, '+') + .replace(/_/g, '/'); +}; + +base64url.escape = function escape (str) { + return str.replace(/\+/g, '-') + .replace(/\//g, '_') + .replace(/=/g, ''); +}; + +base64url.encode = function encode (str) { + return this.escape(new Buffer(str).toString('base64')); +}; + +base64url.decode = function decode (str) { + return new Buffer(this.unescape(str), 'base64').toString(); +}; diff --git a/node_modules/express-session/node_modules/uid-safe/node_modules/base64-url/package.json b/node_modules/express-session/node_modules/uid-safe/node_modules/base64-url/package.json new file mode 100644 index 0000000..f00fc5d --- /dev/null +++ b/node_modules/express-session/node_modules/uid-safe/node_modules/base64-url/package.json @@ -0,0 +1,73 @@ +{ + "name": "base64-url", + "version": "1.3.2", + "description": "Base64 encode, decode, escape and unescape for URL applications", + "main": "index.js", + "files": [ + "LICENSE", + "README.md", + "index.js" + ], + "scripts": { + "test": "istanbul cover tape test.js", + "lint": "jshint -c .jshintrc *.js", + "style": "jscs -p google *.js", + "coverage:check": "istanbul check-coverage --statements 100 --functions 100 --lines 100 --branches 100", + "coverage": "open coverage/lcov-report/index.html" + }, + "repository": { + "type": "git", + "url": "git://github.com/joaquimserafim/base64-url.git" + }, + "keywords": [ + "base64", + "base64url" + ], + "author": { + "name": "@joaquimserafim" + }, + "license": "ISC", + "bugs": { + "url": "https://github.com/joaquimserafim/base64-url/issues" + }, + "homepage": "https://github.com/joaquimserafim/base64-url", + "devDependencies": { + "istanbul": "^0.3.5", + "jscs": "^1.9.0", + "jshint": "^2.5.11", + "pre-commit": "^1.1.3", + "tape": "^4.6.0" + }, + "pre-commit": [ + "lint", + "style", + "test", + "coverage:check" + ], + "gitHead": "356442c220fe38d00fa34078519c9b3ac31b1312", + "_id": "base64-url@1.3.2", + "_shasum": "4b08113b49d23889f306be64372762d31412f7a8", + "_from": "base64-url@1.3.2", + "_npmVersion": "2.15.0", + "_nodeVersion": "4.4.2", + "_npmUser": { + "name": "quim", + "email": "joaquim.serafim@gmail.com" + }, + "dist": { + "shasum": "4b08113b49d23889f306be64372762d31412f7a8", + "tarball": "https://registry.npmjs.org/base64-url/-/base64-url-1.3.2.tgz" + }, + "maintainers": [ + { + "name": "quim", + "email": "joaquim.serafim@gmail.com" + } + ], + "_npmOperationalInternal": { + "host": "packages-16-east.internal.npmjs.com", + "tmp": "tmp/base64-url-1.3.2.tgz_1468593630635_0.8208693880587816" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/base64-url/-/base64-url-1.3.2.tgz" +} diff --git a/node_modules/express-session/node_modules/uid-safe/node_modules/random-bytes/HISTORY.md b/node_modules/express-session/node_modules/uid-safe/node_modules/random-bytes/HISTORY.md new file mode 100644 index 0000000..8cabd9d --- /dev/null +++ b/node_modules/express-session/node_modules/uid-safe/node_modules/random-bytes/HISTORY.md @@ -0,0 +1,4 @@ +1.0.0 / 2016-01-17 +================== + + * Initial release diff --git a/node_modules/express-session/node_modules/uid-safe/node_modules/random-bytes/LICENSE b/node_modules/express-session/node_modules/uid-safe/node_modules/random-bytes/LICENSE new file mode 100644 index 0000000..c24dbe3 --- /dev/null +++ b/node_modules/express-session/node_modules/uid-safe/node_modules/random-bytes/LICENSE @@ -0,0 +1,21 @@ +The MIT License (MIT) + +Copyright (c) 2016 Douglas Christopher Wilson + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. diff --git a/node_modules/express-session/node_modules/uid-safe/node_modules/random-bytes/README.md b/node_modules/express-session/node_modules/uid-safe/node_modules/random-bytes/README.md new file mode 100644 index 0000000..df5aacc --- /dev/null +++ b/node_modules/express-session/node_modules/uid-safe/node_modules/random-bytes/README.md @@ -0,0 +1,77 @@ +# random-bytes + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Node.js Version][node-version-image]][node-version-url] +[![Build Status][travis-image]][travis-url] +[![Test Coverage][coveralls-image]][coveralls-url] + +Generate strong pseudo-random bytes. + +This module is a simple wrapper around the Node.js core `crypto.randomBytes` API, +with the following additions: + + * A `Promise` interface for environments with promises. + * For Node.js versions that do not wait for the PRNG to be seeded, this module + will wait a bit. + +## Installation + +```sh +$ npm install random-bytes +``` + +## API + +```js +var randomBytes = require('random-bytes') +``` + +### randomBytes(size, callback) + +Generates strong pseudo-random bytes. The `size` argument is a number indicating +the number of bytes to generate. + +```js +randomBytes(12, function (error, bytes) { + if (error) throw error + // do something with the bytes +}) +``` + +### randomBytes(size) + +Generates strong pseudo-random bytes and return a `Promise`. The `size` argument is +a number indicating the number of bytes to generate. + +**Note**: To use promises in Node.js _prior to 0.12_, promises must be +"polyfilled" using `global.Promise = require('bluebird')`. + +```js +randomBytes(18).then(function (string) { + // do something with the string +}) +``` + +### randomBytes.sync(size) + +A synchronous version of above. + +```js +var bytes = randomBytes.sync(18) +``` + +## License + +[MIT](LICENSE) + +[npm-image]: https://img.shields.io/npm/v/random-bytes.svg +[npm-url]: https://npmjs.org/package/random-bytes +[node-version-image]: https://img.shields.io/node/v/random-bytes.svg +[node-version-url]: http://nodejs.org/download/ +[travis-image]: https://img.shields.io/travis/crypto-utils/random-bytes/master.svg +[travis-url]: https://travis-ci.org/crypto-utils/random-bytes +[coveralls-image]: https://img.shields.io/coveralls/crypto-utils/random-bytes/master.svg +[coveralls-url]: https://coveralls.io/r/crypto-utils/random-bytes?branch=master +[downloads-image]: https://img.shields.io/npm/dm/random-bytes.svg +[downloads-url]: https://npmjs.org/package/random-bytes diff --git a/node_modules/express-session/node_modules/uid-safe/node_modules/random-bytes/index.js b/node_modules/express-session/node_modules/uid-safe/node_modules/random-bytes/index.js new file mode 100644 index 0000000..9ad930f --- /dev/null +++ b/node_modules/express-session/node_modules/uid-safe/node_modules/random-bytes/index.js @@ -0,0 +1,101 @@ +/*! + * random-bytes + * Copyright(c) 2016 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module dependencies. + * @private + */ + +var crypto = require('crypto') + +/** + * Module variables. + * @private + */ + +var generateAttempts = crypto.randomBytes === crypto.pseudoRandomBytes ? 1 : 3 + +/** + * Module exports. + * @public + */ + +module.exports = randomBytes +module.exports.sync = randomBytesSync + +/** + * Generates strong pseudo-random bytes. + * + * @param {number} size + * @param {function} [callback] + * @return {Promise} + * @public + */ + +function randomBytes(size, callback) { + // validate callback is a function, if provided + if (callback !== undefined && typeof callback !== 'function') { + throw new TypeError('argument callback must be a function') + } + + // require the callback without promises + if (!callback && !global.Promise) { + throw new TypeError('argument callback is required') + } + + if (callback) { + // classic callback style + return generateRandomBytes(size, generateAttempts, callback) + } + + return new Promise(function executor(resolve, reject) { + generateRandomBytes(size, generateAttempts, function onRandomBytes(err, str) { + if (err) return reject(err) + resolve(str) + }) + }) +} + +/** + * Generates strong pseudo-random bytes sync. + * + * @param {number} size + * @return {Buffer} + * @public + */ + +function randomBytesSync(size) { + var err = null + + for (var i = 0; i < generateAttempts; i++) { + try { + return crypto.randomBytes(size) + } catch (e) { + err = e + } + } + + throw err +} + +/** + * Generates strong pseudo-random bytes. + * + * @param {number} size + * @param {number} attempts + * @param {function} callback + * @private + */ + +function generateRandomBytes(size, attempts, callback) { + crypto.randomBytes(size, function onRandomBytes(err, buf) { + if (!err) return callback(null, buf) + if (!--attempts) return callback(err) + setTimeout(generateRandomBytes.bind(null, size, attempts, callback), 10) + }) +} diff --git a/node_modules/express-session/node_modules/uid-safe/node_modules/random-bytes/package.json b/node_modules/express-session/node_modules/uid-safe/node_modules/random-bytes/package.json new file mode 100644 index 0000000..7b05edb --- /dev/null +++ b/node_modules/express-session/node_modules/uid-safe/node_modules/random-bytes/package.json @@ -0,0 +1,67 @@ +{ + "name": "random-bytes", + "description": "URL and cookie safe UIDs", + "version": "1.0.0", + "contributors": [ + { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + } + ], + "license": "MIT", + "repository": { + "type": "git", + "url": "https://github.com/crypto-utils/random-bytes" + }, + "devDependencies": { + "bluebird": "3.1.1", + "istanbul": "0.4.2", + "mocha": "2.3.4", + "proxyquire": "1.2.0" + }, + "files": [ + "LICENSE", + "HISTORY.md", + "README.md", + "index.js" + ], + "engines": { + "node": ">= 0.8" + }, + "scripts": { + "test": "mocha --trace-deprecation --reporter spec --bail --check-leaks test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --trace-deprecation --reporter dot --check-leaks test/", + "test-travis": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --trace-deprecation --reporter spec --check-leaks test/" + }, + "keywords": [ + "bytes", + "generator", + "random", + "safe" + ], + "gitHead": "3dcd47425a3dfe858ee8debcd4db0c1222110bc3", + "bugs": { + "url": "https://github.com/crypto-utils/random-bytes/issues" + }, + "homepage": "https://github.com/crypto-utils/random-bytes", + "_id": "random-bytes@1.0.0", + "_shasum": "4f68a1dc0ae58bd3fb95848c30324db75d64360b", + "_from": "random-bytes@>=1.0.0 <1.1.0", + "_npmVersion": "1.4.28", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "maintainers": [ + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + } + ], + "dist": { + "shasum": "4f68a1dc0ae58bd3fb95848c30324db75d64360b", + "tarball": "https://registry.npmjs.org/random-bytes/-/random-bytes-1.0.0.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/random-bytes/-/random-bytes-1.0.0.tgz" +} diff --git a/node_modules/express-session/node_modules/uid-safe/package.json b/node_modules/express-session/node_modules/uid-safe/package.json new file mode 100644 index 0000000..779196e --- /dev/null +++ b/node_modules/express-session/node_modules/uid-safe/package.json @@ -0,0 +1,92 @@ +{ + "name": "uid-safe", + "description": "URL and cookie safe UIDs", + "version": "2.1.2", + "contributors": [ + { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "Jonathan Ong", + "email": "me@jongleberry.com", + "url": "http://jongleberry.com" + } + ], + "license": "MIT", + "repository": { + "type": "git", + "url": "https://github.com/crypto-utils/uid-safe" + }, + "dependencies": { + "base64-url": "1.3.2", + "random-bytes": "~1.0.0" + }, + "devDependencies": { + "bluebird": "3.4.1", + "eslint": "2.13.1", + "eslint-config-standard": "5.3.5", + "eslint-plugin-promise": "2.0.1", + "eslint-plugin-standard": "2.0.0", + "istanbul": "0.4.4", + "mocha": "2.5.3" + }, + "files": [ + "LICENSE", + "HISTORY.md", + "README.md", + "index.js" + ], + "engines": { + "node": ">= 0.8" + }, + "scripts": { + "lint": "eslint **/*.js", + "test": "mocha --trace-deprecation --reporter spec --bail --check-leaks test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --trace-deprecation --reporter dot --check-leaks test/", + "test-travis": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --trace-deprecation --reporter spec --check-leaks test/" + }, + "keywords": [ + "random", + "generator", + "uid", + "safe" + ], + "gitHead": "32285798f2d803ac9442aae092943346a97c1d11", + "bugs": { + "url": "https://github.com/crypto-utils/uid-safe/issues" + }, + "homepage": "https://github.com/crypto-utils/uid-safe", + "_id": "uid-safe@2.1.2", + "_shasum": "c934b3caead0fdcd0fb2cff3a8876d06fe0ee0fd", + "_from": "uid-safe@>=2.1.2 <2.2.0", + "_npmVersion": "1.4.28", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "maintainers": [ + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "fishrock123", + "email": "fishrock123@rocketmail.com" + }, + { + "name": "jongleberry", + "email": "jonathanrichardong@gmail.com" + } + ], + "dist": { + "shasum": "c934b3caead0fdcd0fb2cff3a8876d06fe0ee0fd", + "tarball": "https://registry.npmjs.org/uid-safe/-/uid-safe-2.1.2.tgz" + }, + "_npmOperationalInternal": { + "host": "packages-12-west.internal.npmjs.com", + "tmp": "tmp/uid-safe-2.1.2.tgz_1471284806211_0.030802547931671143" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/uid-safe/-/uid-safe-2.1.2.tgz" +} diff --git a/node_modules/express-session/node_modules/utils-merge/.travis.yml b/node_modules/express-session/node_modules/utils-merge/.travis.yml new file mode 100644 index 0000000..af92b02 --- /dev/null +++ b/node_modules/express-session/node_modules/utils-merge/.travis.yml @@ -0,0 +1,6 @@ +language: "node_js" +node_js: + - "0.4" + - "0.6" + - "0.8" + - "0.10" diff --git a/node_modules/express-session/node_modules/utils-merge/LICENSE b/node_modules/express-session/node_modules/utils-merge/LICENSE new file mode 100644 index 0000000..e33bd10 --- /dev/null +++ b/node_modules/express-session/node_modules/utils-merge/LICENSE @@ -0,0 +1,20 @@ +(The MIT License) + +Copyright (c) 2013 Jared Hanson + +Permission is hereby granted, free of charge, to any person obtaining a copy of +this software and associated documentation files (the "Software"), to deal in +the Software without restriction, including without limitation the rights to +use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of +the Software, and to permit persons to whom the Software is furnished to do so, +subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS +FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR +COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER +IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN +CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/express-session/node_modules/utils-merge/README.md b/node_modules/express-session/node_modules/utils-merge/README.md new file mode 100644 index 0000000..2f94e9b --- /dev/null +++ b/node_modules/express-session/node_modules/utils-merge/README.md @@ -0,0 +1,34 @@ +# utils-merge + +Merges the properties from a source object into a destination object. + +## Install + + $ npm install utils-merge + +## Usage + +```javascript +var a = { foo: 'bar' } + , b = { bar: 'baz' }; + +merge(a, b); +// => { foo: 'bar', bar: 'baz' } +``` + +## Tests + + $ npm install + $ npm test + +[![Build Status](https://secure.travis-ci.org/jaredhanson/utils-merge.png)](http://travis-ci.org/jaredhanson/utils-merge) + +## Credits + + - [Jared Hanson](http://github.com/jaredhanson) + +## License + +[The MIT License](http://opensource.org/licenses/MIT) + +Copyright (c) 2013 Jared Hanson <[http://jaredhanson.net/](http://jaredhanson.net/)> diff --git a/node_modules/express-session/node_modules/utils-merge/index.js b/node_modules/express-session/node_modules/utils-merge/index.js new file mode 100644 index 0000000..4265c69 --- /dev/null +++ b/node_modules/express-session/node_modules/utils-merge/index.js @@ -0,0 +1,23 @@ +/** + * Merge object b with object a. + * + * var a = { foo: 'bar' } + * , b = { bar: 'baz' }; + * + * merge(a, b); + * // => { foo: 'bar', bar: 'baz' } + * + * @param {Object} a + * @param {Object} b + * @return {Object} + * @api public + */ + +exports = module.exports = function(a, b){ + if (a && b) { + for (var key in b) { + a[key] = b[key]; + } + } + return a; +}; diff --git a/node_modules/express-session/node_modules/utils-merge/package.json b/node_modules/express-session/node_modules/utils-merge/package.json new file mode 100644 index 0000000..83c37a4 --- /dev/null +++ b/node_modules/express-session/node_modules/utils-merge/package.json @@ -0,0 +1,60 @@ +{ + "name": "utils-merge", + "version": "1.0.0", + "description": "merge() utility function", + "keywords": [ + "util" + ], + "repository": { + "type": "git", + "url": "git://github.com/jaredhanson/utils-merge.git" + }, + "bugs": { + "url": "http://github.com/jaredhanson/utils-merge/issues" + }, + "author": { + "name": "Jared Hanson", + "email": "jaredhanson@gmail.com", + "url": "http://www.jaredhanson.net/" + }, + "licenses": [ + { + "type": "MIT", + "url": "http://www.opensource.org/licenses/MIT" + } + ], + "main": "./index", + "dependencies": {}, + "devDependencies": { + "mocha": "1.x.x", + "chai": "1.x.x" + }, + "scripts": { + "test": "mocha --reporter spec --require test/bootstrap/node test/*.test.js" + }, + "engines": { + "node": ">= 0.4.0" + }, + "_id": "utils-merge@1.0.0", + "dist": { + "shasum": "0294fb922bb9375153541c4f7096231f287c8af8", + "tarball": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.0.tgz" + }, + "_from": "utils-merge@1.0.0", + "_npmVersion": "1.2.25", + "_npmUser": { + "name": "jaredhanson", + "email": "jaredhanson@gmail.com" + }, + "maintainers": [ + { + "name": "jaredhanson", + "email": "jaredhanson@gmail.com" + } + ], + "directories": {}, + "_shasum": "0294fb922bb9375153541c4f7096231f287c8af8", + "_resolved": "http://registry.npmjs.org/utils-merge/-/utils-merge-1.0.0.tgz", + "readme": "ERROR: No README data found!", + "homepage": "https://github.com/jaredhanson/utils-merge#readme" +} diff --git a/node_modules/express-session/package.json b/node_modules/express-session/package.json new file mode 100644 index 0000000..639dc96 --- /dev/null +++ b/node_modules/express-session/package.json @@ -0,0 +1,95 @@ +{ + "name": "express-session", + "version": "1.14.1", + "description": "Simple session middleware for Express", + "author": { + "name": "TJ Holowaychuk", + "email": "tj@vision-media.ca", + "url": "http://tjholowaychuk.com" + }, + "contributors": [ + { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "Joe Wagner", + "email": "njwjs722@gmail.com" + } + ], + "repository": { + "type": "git", + "url": "https://github.com/expressjs/session" + }, + "license": "MIT", + "dependencies": { + "cookie": "0.3.1", + "cookie-signature": "1.0.6", + "crc": "3.4.0", + "debug": "~2.2.0", + "depd": "~1.1.0", + "on-headers": "~1.0.1", + "parseurl": "~1.3.1", + "uid-safe": "~2.1.2", + "utils-merge": "1.0.0" + }, + "devDependencies": { + "after": "0.8.2", + "cookie-parser": "1.4.3", + "express": "4.14.0", + "istanbul": "0.4.5", + "mocha": "2.5.3", + "supertest": "1.1.0" + }, + "files": [ + "session/", + "HISTORY.md", + "LICENSE", + "index.js" + ], + "engines": { + "node": ">= 0.8.0" + }, + "scripts": { + "test": "mocha --bail --reporter spec test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot test/", + "test-travis": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter spec test/" + }, + "gitHead": "19b8f725d924035574d71e22bcb0a7d06c09ae80", + "bugs": { + "url": "https://github.com/expressjs/session/issues" + }, + "homepage": "https://github.com/expressjs/session", + "_id": "express-session@1.14.1", + "_shasum": "600364f0f6bf5dce32649e006770bdeee80aec99", + "_from": "express-session@>=1.0.0 <2.0.0", + "_npmVersion": "1.4.28", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "maintainers": [ + { + "name": "defunctzombie", + "email": "shtylman@gmail.com" + }, + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "mscdex", + "email": "mscdex@mscdex.net" + } + ], + "dist": { + "shasum": "600364f0f6bf5dce32649e006770bdeee80aec99", + "tarball": "https://registry.npmjs.org/express-session/-/express-session-1.14.1.tgz" + }, + "_npmOperationalInternal": { + "host": "packages-16-east.internal.npmjs.com", + "tmp": "tmp/express-session-1.14.1.tgz_1472059273028_0.5192838909570128" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/express-session/-/express-session-1.14.1.tgz" +} diff --git a/node_modules/express-session/session/cookie.js b/node_modules/express-session/session/cookie.js new file mode 100644 index 0000000..60ef22a --- /dev/null +++ b/node_modules/express-session/session/cookie.js @@ -0,0 +1,130 @@ +/*! + * Connect - session - Cookie + * Copyright(c) 2010 Sencha Inc. + * Copyright(c) 2011 TJ Holowaychuk + * MIT Licensed + */ + +'use strict'; + +/** + * Module dependencies. + */ + +var merge = require('utils-merge') + , cookie = require('cookie'); + +/** + * Initialize a new `Cookie` with the given `options`. + * + * @param {IncomingMessage} req + * @param {Object} options + * @api private + */ + +var Cookie = module.exports = function Cookie(options) { + this.path = '/'; + this.maxAge = null; + this.httpOnly = true; + if (options) merge(this, options); + this.originalMaxAge = undefined == this.originalMaxAge + ? this.maxAge + : this.originalMaxAge; +}; + +/*! + * Prototype. + */ + +Cookie.prototype = { + + /** + * Set expires `date`. + * + * @param {Date} date + * @api public + */ + + set expires(date) { + this._expires = date; + this.originalMaxAge = this.maxAge; + }, + + /** + * Get expires `date`. + * + * @return {Date} + * @api public + */ + + get expires() { + return this._expires; + }, + + /** + * Set expires via max-age in `ms`. + * + * @param {Number} ms + * @api public + */ + + set maxAge(ms) { + this.expires = 'number' == typeof ms + ? new Date(Date.now() + ms) + : ms; + }, + + /** + * Get expires max-age in `ms`. + * + * @return {Number} + * @api public + */ + + get maxAge() { + return this.expires instanceof Date + ? this.expires.valueOf() - Date.now() + : this.expires; + }, + + /** + * Return cookie data object. + * + * @return {Object} + * @api private + */ + + get data() { + return { + originalMaxAge: this.originalMaxAge + , expires: this._expires + , secure: this.secure + , httpOnly: this.httpOnly + , domain: this.domain + , path: this.path + , sameSite: this.sameSite + } + }, + + /** + * Return a serialized cookie string. + * + * @return {String} + * @api public + */ + + serialize: function(name, val){ + return cookie.serialize(name, val, this.data); + }, + + /** + * Return JSON representation of this cookie. + * + * @return {Object} + * @api private + */ + + toJSON: function(){ + return this.data; + } +}; diff --git a/node_modules/express-session/session/memory.js b/node_modules/express-session/session/memory.js new file mode 100644 index 0000000..25252b6 --- /dev/null +++ b/node_modules/express-session/session/memory.js @@ -0,0 +1,185 @@ +/*! + * express-session + * Copyright(c) 2010 Sencha Inc. + * Copyright(c) 2011 TJ Holowaychuk + * Copyright(c) 2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict'; + +/** + * Module dependencies. + * @private + */ + +var Store = require('./store') +var util = require('util') + +/** + * Shim setImmediate for node.js < 0.10 + * @private + */ + +/* istanbul ignore next */ +var defer = typeof setImmediate === 'function' + ? setImmediate + : function(fn){ process.nextTick(fn.bind.apply(fn, arguments)) } + +/** + * Module exports. + */ + +module.exports = MemoryStore + +/** + * A session store in memory. + * @public + */ + +function MemoryStore() { + Store.call(this) + this.sessions = Object.create(null) +} + +/** + * Inherit from Store. + */ + +util.inherits(MemoryStore, Store) + +/** + * Get all active sessions. + * + * @param {function} callback + * @public + */ + +MemoryStore.prototype.all = function all(callback) { + var sessionIds = Object.keys(this.sessions) + var sessions = Object.create(null) + + for (var i = 0; i < sessionIds.length; i++) { + var sessionId = sessionIds[i] + var session = getSession.call(this, sessionId) + + if (session) { + sessions[sessionId] = session; + } + } + + callback && defer(callback, null, sessions) +} + +/** + * Clear all sessions. + * + * @param {function} callback + * @public + */ + +MemoryStore.prototype.clear = function clear(callback) { + this.sessions = Object.create(null) + callback && defer(callback) +} + +/** + * Destroy the session associated with the given session ID. + * + * @param {string} sessionId + * @public + */ + +MemoryStore.prototype.destroy = function destroy(sessionId, callback) { + delete this.sessions[sessionId] + callback && defer(callback) +} + +/** + * Fetch session by the given session ID. + * + * @param {string} sessionId + * @param {function} callback + * @public + */ + +MemoryStore.prototype.get = function get(sessionId, callback) { + defer(callback, null, getSession.call(this, sessionId)) +} + +/** + * Commit the given session associated with the given sessionId to the store. + * + * @param {string} sessionId + * @param {object} session + * @param {function} callback + * @public + */ + +MemoryStore.prototype.set = function set(sessionId, session, callback) { + this.sessions[sessionId] = JSON.stringify(session) + callback && defer(callback) +} + +/** + * Get number of active sessions. + * + * @param {function} callback + * @public + */ + +MemoryStore.prototype.length = function length(callback) { + this.all(function (err, sessions) { + if (err) return callback(err) + callback(null, Object.keys(sessions).length) + }) +} + +/** + * Touch the given session object associated with the given session ID. + * + * @param {string} sessionId + * @param {object} session + * @param {function} callback + * @public + */ + +MemoryStore.prototype.touch = function touch(sessionId, session, callback) { + var currentSession = getSession.call(this, sessionId) + + if (currentSession) { + // update expiration + currentSession.cookie = session.cookie + this.sessions[sessionId] = JSON.stringify(currentSession) + } + + callback && defer(callback) +} + +/** + * Get session from the store. + * @private + */ + +function getSession(sessionId) { + var sess = this.sessions[sessionId] + + if (!sess) { + return + } + + // parse + sess = JSON.parse(sess) + + var expires = typeof sess.cookie.expires === 'string' + ? new Date(sess.cookie.expires) + : sess.cookie.expires + + // destroy expired session + if (expires && expires <= Date.now()) { + delete this.sessions[sessionId] + return + } + + return sess +} diff --git a/node_modules/express-session/session/session.js b/node_modules/express-session/session/session.js new file mode 100644 index 0000000..2eacde6 --- /dev/null +++ b/node_modules/express-session/session/session.js @@ -0,0 +1,142 @@ +/*! + * Connect - session - Session + * Copyright(c) 2010 Sencha Inc. + * Copyright(c) 2011 TJ Holowaychuk + * MIT Licensed + */ + +'use strict'; + +/** + * Expose Session. + */ + +module.exports = Session; + +/** + * Create a new `Session` with the given request and `data`. + * + * @param {IncomingRequest} req + * @param {Object} data + * @api private + */ + +function Session(req, data) { + Object.defineProperty(this, 'req', { value: req }); + Object.defineProperty(this, 'id', { value: req.sessionID }); + + if (typeof data === 'object' && data !== null) { + // merge data into this, ignoring prototype properties + for (var prop in data) { + if (!(prop in this)) { + this[prop] = data[prop] + } + } + } +} + +/** + * Update reset `.cookie.maxAge` to prevent + * the cookie from expiring when the + * session is still active. + * + * @return {Session} for chaining + * @api public + */ + +defineMethod(Session.prototype, 'touch', function touch() { + return this.resetMaxAge(); +}); + +/** + * Reset `.maxAge` to `.originalMaxAge`. + * + * @return {Session} for chaining + * @api public + */ + +defineMethod(Session.prototype, 'resetMaxAge', function resetMaxAge() { + this.cookie.maxAge = this.cookie.originalMaxAge; + return this; +}); + +/** + * Save the session data with optional callback `fn(err)`. + * + * @param {Function} fn + * @return {Session} for chaining + * @api public + */ + +defineMethod(Session.prototype, 'save', function save(fn) { + this.req.sessionStore.set(this.id, this, fn || function(){}); + return this; +}); + +/** + * Re-loads the session data _without_ altering + * the maxAge properties. Invokes the callback `fn(err)`, + * after which time if no exception has occurred the + * `req.session` property will be a new `Session` object, + * although representing the same session. + * + * @param {Function} fn + * @return {Session} for chaining + * @api public + */ + +defineMethod(Session.prototype, 'reload', function reload(fn) { + var req = this.req + , store = this.req.sessionStore; + store.get(this.id, function(err, sess){ + if (err) return fn(err); + if (!sess) return fn(new Error('failed to load session')); + store.createSession(req, sess); + fn(); + }); + return this; +}); + +/** + * Destroy `this` session. + * + * @param {Function} fn + * @return {Session} for chaining + * @api public + */ + +defineMethod(Session.prototype, 'destroy', function destroy(fn) { + delete this.req.session; + this.req.sessionStore.destroy(this.id, fn); + return this; +}); + +/** + * Regenerate this request's session. + * + * @param {Function} fn + * @return {Session} for chaining + * @api public + */ + +defineMethod(Session.prototype, 'regenerate', function regenerate(fn) { + this.req.sessionStore.regenerate(this.req, fn); + return this; +}); + +/** + * Helper function for creating a method on a prototype. + * + * @param {Object} obj + * @param {String} name + * @param {Function} fn + * @private + */ +function defineMethod(obj, name, fn) { + Object.defineProperty(obj, name, { + configurable: true, + enumerable: false, + value: fn, + writable: true + }); +}; diff --git a/node_modules/express-session/session/store.js b/node_modules/express-session/session/store.js new file mode 100644 index 0000000..387469c --- /dev/null +++ b/node_modules/express-session/session/store.js @@ -0,0 +1,94 @@ +/*! + * Connect - session - Store + * Copyright(c) 2010 Sencha Inc. + * Copyright(c) 2011 TJ Holowaychuk + * MIT Licensed + */ + +'use strict'; + +/** + * Module dependencies. + * @private + */ + +var Cookie = require('./cookie') +var EventEmitter = require('events').EventEmitter +var Session = require('./session') +var util = require('util') + +/** + * Module exports. + * @public + */ + +module.exports = Store + +/** + * Abstract base class for session stores. + * @public + */ + +function Store () { + EventEmitter.call(this) +} + +/** + * Inherit from EventEmitter. + */ + +util.inherits(Store, EventEmitter) + +/** + * Re-generate the given requests's session. + * + * @param {IncomingRequest} req + * @return {Function} fn + * @api public + */ + +Store.prototype.regenerate = function(req, fn){ + var self = this; + this.destroy(req.sessionID, function(err){ + self.generate(req); + fn(err); + }); +}; + +/** + * Load a `Session` instance via the given `sid` + * and invoke the callback `fn(err, sess)`. + * + * @param {String} sid + * @param {Function} fn + * @api public + */ + +Store.prototype.load = function(sid, fn){ + var self = this; + this.get(sid, function(err, sess){ + if (err) return fn(err); + if (!sess) return fn(); + var req = { sessionID: sid, sessionStore: self }; + fn(null, self.createSession(req, sess)) + }); +}; + +/** + * Create session from JSON `sess` data. + * + * @param {IncomingRequest} req + * @param {Object} sess + * @return {Session} + * @api private + */ + +Store.prototype.createSession = function(req, sess){ + var expires = sess.cookie.expires + , orig = sess.cookie.originalMaxAge; + sess.cookie = new Cookie(sess.cookie); + if ('string' == typeof expires) sess.cookie.expires = new Date(expires); + sess.cookie.originalMaxAge = orig; + req.session = new Session(req, sess); + return req.session; +}; diff --git a/node_modules/express/History.md b/node_modules/express/History.md new file mode 100644 index 0000000..40a5ed7 --- /dev/null +++ b/node_modules/express/History.md @@ -0,0 +1,3142 @@ +4.14.0 / 2016-06-16 +=================== + + * Add `acceptRanges` option to `res.sendFile`/`res.sendfile` + * Add `cacheControl` option to `res.sendFile`/`res.sendfile` + * Add `options` argument to `req.range` + - Includes the `combine` option + * Encode URL in `res.location`/`res.redirect` if not already encoded + * Fix some redirect handling in `res.sendFile`/`res.sendfile` + * Fix Windows absolute path check using forward slashes + * Improve error with invalid arguments to `req.get()` + * Improve performance for `res.json`/`res.jsonp` in most cases + * Improve `Range` header handling in `res.sendFile`/`res.sendfile` + * deps: accepts@~1.3.3 + - Fix including type extensions in parameters in `Accept` parsing + - Fix parsing `Accept` parameters with quoted equals + - Fix parsing `Accept` parameters with quoted semicolons + - Many performance improvments + - deps: mime-types@~2.1.11 + - deps: negotiator@0.6.1 + * deps: content-type@~1.0.2 + - perf: enable strict mode + * deps: cookie@0.3.1 + - Add `sameSite` option + - Fix cookie `Max-Age` to never be a floating point number + - Improve error message when `encode` is not a function + - Improve error message when `expires` is not a `Date` + - Throw better error for invalid argument to parse + - Throw on invalid values provided to `serialize` + - perf: enable strict mode + - perf: hoist regular expression + - perf: use for loop in parse + - perf: use string concatination for serialization + * deps: finalhandler@0.5.0 + - Change invalid or non-numeric status code to 500 + - Overwrite status message to match set status code + - Prefer `err.statusCode` if `err.status` is invalid + - Set response headers from `err.headers` object + - Use `statuses` instead of `http` module for status messages + * deps: proxy-addr@~1.1.2 + - Fix accepting various invalid netmasks + - Fix IPv6-mapped IPv4 validation edge cases + - IPv4 netmasks must be contingous + - IPv6 addresses cannot be used as a netmask + - deps: ipaddr.js@1.1.1 + * deps: qs@6.2.0 + - Add `decoder` option in `parse` function + * deps: range-parser@~1.2.0 + - Add `combine` option to combine overlapping ranges + - Fix incorrectly returning -1 when there is at least one valid range + - perf: remove internal function + * deps: send@0.14.1 + - Add `acceptRanges` option + - Add `cacheControl` option + - Attempt to combine multiple ranges into single range + - Correctly inherit from `Stream` class + - Fix `Content-Range` header in 416 responses when using `start`/`end` options + - Fix `Content-Range` header missing from default 416 responses + - Fix redirect error when `path` contains raw non-URL characters + - Fix redirect when `path` starts with multiple forward slashes + - Ignore non-byte `Range` headers + - deps: http-errors@~1.5.0 + - deps: range-parser@~1.2.0 + - deps: statuses@~1.3.0 + - perf: remove argument reassignment + * deps: serve-static@~1.11.1 + - Add `acceptRanges` option + - Add `cacheControl` option + - Attempt to combine multiple ranges into single range + - Fix redirect error when `req.url` contains raw non-URL characters + - Ignore non-byte `Range` headers + - Use status code 301 for redirects + - deps: send@0.14.1 + * deps: type-is@~1.6.13 + - Fix type error when given invalid type to match against + - deps: mime-types@~2.1.11 + * deps: vary@~1.1.0 + - Only accept valid field names in the `field` argument + * perf: use strict equality when possible + +4.13.4 / 2016-01-21 +=================== + + * deps: content-disposition@0.5.1 + - perf: enable strict mode + * deps: cookie@0.1.5 + - Throw on invalid values provided to `serialize` + * deps: depd@~1.1.0 + - Support web browser loading + - perf: enable strict mode + * deps: escape-html@~1.0.3 + - perf: enable strict mode + - perf: optimize string replacement + - perf: use faster string coercion + * deps: finalhandler@0.4.1 + - deps: escape-html@~1.0.3 + * deps: merge-descriptors@1.0.1 + - perf: enable strict mode + * deps: methods@~1.1.2 + - perf: enable strict mode + * deps: parseurl@~1.3.1 + - perf: enable strict mode + * deps: proxy-addr@~1.0.10 + - deps: ipaddr.js@1.0.5 + - perf: enable strict mode + * deps: range-parser@~1.0.3 + - perf: enable strict mode + * deps: send@0.13.1 + - deps: depd@~1.1.0 + - deps: destroy@~1.0.4 + - deps: escape-html@~1.0.3 + - deps: range-parser@~1.0.3 + * deps: serve-static@~1.10.2 + - deps: escape-html@~1.0.3 + - deps: parseurl@~1.3.0 + - deps: send@0.13.1 + +4.13.3 / 2015-08-02 +=================== + + * Fix infinite loop condition using `mergeParams: true` + * Fix inner numeric indices incorrectly altering parent `req.params` + +4.13.2 / 2015-07-31 +=================== + + * deps: accepts@~1.2.12 + - deps: mime-types@~2.1.4 + * deps: array-flatten@1.1.1 + - perf: enable strict mode + * deps: path-to-regexp@0.1.7 + - Fix regression with escaped round brackets and matching groups + * deps: type-is@~1.6.6 + - deps: mime-types@~2.1.4 + +4.13.1 / 2015-07-05 +=================== + + * deps: accepts@~1.2.10 + - deps: mime-types@~2.1.2 + * deps: qs@4.0.0 + - Fix dropping parameters like `hasOwnProperty` + - Fix various parsing edge cases + * deps: type-is@~1.6.4 + - deps: mime-types@~2.1.2 + - perf: enable strict mode + - perf: remove argument reassignment + +4.13.0 / 2015-06-20 +=================== + + * Add settings to debug output + * Fix `res.format` error when only `default` provided + * Fix issue where `next('route')` in `app.param` would incorrectly skip values + * Fix hiding platform issues with `decodeURIComponent` + - Only `URIError`s are a 400 + * Fix using `*` before params in routes + * Fix using capture groups before params in routes + * Simplify `res.cookie` to call `res.append` + * Use `array-flatten` module for flattening arrays + * deps: accepts@~1.2.9 + - deps: mime-types@~2.1.1 + - perf: avoid argument reassignment & argument slice + - perf: avoid negotiator recursive construction + - perf: enable strict mode + - perf: remove unnecessary bitwise operator + * deps: cookie@0.1.3 + - perf: deduce the scope of try-catch deopt + - perf: remove argument reassignments + * deps: escape-html@1.0.2 + * deps: etag@~1.7.0 + - Always include entity length in ETags for hash length extensions + - Generate non-Stats ETags using MD5 only (no longer CRC32) + - Improve stat performance by removing hashing + - Improve support for JXcore + - Remove base64 padding in ETags to shorten + - Support "fake" stats objects in environments without fs + - Use MD5 instead of MD4 in weak ETags over 1KB + * deps: finalhandler@0.4.0 + - Fix a false-positive when unpiping in Node.js 0.8 + - Support `statusCode` property on `Error` objects + - Use `unpipe` module for unpiping requests + - deps: escape-html@1.0.2 + - deps: on-finished@~2.3.0 + - perf: enable strict mode + - perf: remove argument reassignment + * deps: fresh@0.3.0 + - Add weak `ETag` matching support + * deps: on-finished@~2.3.0 + - Add defined behavior for HTTP `CONNECT` requests + - Add defined behavior for HTTP `Upgrade` requests + - deps: ee-first@1.1.1 + * deps: path-to-regexp@0.1.6 + * deps: send@0.13.0 + - Allow Node.js HTTP server to set `Date` response header + - Fix incorrectly removing `Content-Location` on 304 response + - Improve the default redirect response headers + - Send appropriate headers on default error response + - Use `http-errors` for standard emitted errors + - Use `statuses` instead of `http` module for status messages + - deps: escape-html@1.0.2 + - deps: etag@~1.7.0 + - deps: fresh@0.3.0 + - deps: on-finished@~2.3.0 + - perf: enable strict mode + - perf: remove unnecessary array allocations + * deps: serve-static@~1.10.0 + - Add `fallthrough` option + - Fix reading options from options prototype + - Improve the default redirect response headers + - Malformed URLs now `next()` instead of 400 + - deps: escape-html@1.0.2 + - deps: send@0.13.0 + - perf: enable strict mode + - perf: remove argument reassignment + * deps: type-is@~1.6.3 + - deps: mime-types@~2.1.1 + - perf: reduce try block size + - perf: remove bitwise operations + * perf: enable strict mode + * perf: isolate `app.render` try block + * perf: remove argument reassignments in application + * perf: remove argument reassignments in request prototype + * perf: remove argument reassignments in response prototype + * perf: remove argument reassignments in routing + * perf: remove argument reassignments in `View` + * perf: skip attempting to decode zero length string + * perf: use saved reference to `http.STATUS_CODES` + +4.12.4 / 2015-05-17 +=================== + + * deps: accepts@~1.2.7 + - deps: mime-types@~2.0.11 + - deps: negotiator@0.5.3 + * deps: debug@~2.2.0 + - deps: ms@0.7.1 + * deps: depd@~1.0.1 + * deps: etag@~1.6.0 + - Improve support for JXcore + - Support "fake" stats objects in environments without `fs` + * deps: finalhandler@0.3.6 + - deps: debug@~2.2.0 + - deps: on-finished@~2.2.1 + * deps: on-finished@~2.2.1 + - Fix `isFinished(req)` when data buffered + * deps: proxy-addr@~1.0.8 + - deps: ipaddr.js@1.0.1 + * deps: qs@2.4.2 + - Fix allowing parameters like `constructor` + * deps: send@0.12.3 + - deps: debug@~2.2.0 + - deps: depd@~1.0.1 + - deps: etag@~1.6.0 + - deps: ms@0.7.1 + - deps: on-finished@~2.2.1 + * deps: serve-static@~1.9.3 + - deps: send@0.12.3 + * deps: type-is@~1.6.2 + - deps: mime-types@~2.0.11 + +4.12.3 / 2015-03-17 +=================== + + * deps: accepts@~1.2.5 + - deps: mime-types@~2.0.10 + * deps: debug@~2.1.3 + - Fix high intensity foreground color for bold + - deps: ms@0.7.0 + * deps: finalhandler@0.3.4 + - deps: debug@~2.1.3 + * deps: proxy-addr@~1.0.7 + - deps: ipaddr.js@0.1.9 + * deps: qs@2.4.1 + - Fix error when parameter `hasOwnProperty` is present + * deps: send@0.12.2 + - Throw errors early for invalid `extensions` or `index` options + - deps: debug@~2.1.3 + * deps: serve-static@~1.9.2 + - deps: send@0.12.2 + * deps: type-is@~1.6.1 + - deps: mime-types@~2.0.10 + +4.12.2 / 2015-03-02 +=================== + + * Fix regression where `"Request aborted"` is logged using `res.sendFile` + +4.12.1 / 2015-03-01 +=================== + + * Fix constructing application with non-configurable prototype properties + * Fix `ECONNRESET` errors from `res.sendFile` usage + * Fix `req.host` when using "trust proxy" hops count + * Fix `req.protocol`/`req.secure` when using "trust proxy" hops count + * Fix wrong `code` on aborted connections from `res.sendFile` + * deps: merge-descriptors@1.0.0 + +4.12.0 / 2015-02-23 +=================== + + * Fix `"trust proxy"` setting to inherit when app is mounted + * Generate `ETag`s for all request responses + - No longer restricted to only responses for `GET` and `HEAD` requests + * Use `content-type` to parse `Content-Type` headers + * deps: accepts@~1.2.4 + - Fix preference sorting to be stable for long acceptable lists + - deps: mime-types@~2.0.9 + - deps: negotiator@0.5.1 + * deps: cookie-signature@1.0.6 + * deps: send@0.12.1 + - Always read the stat size from the file + - Fix mutating passed-in `options` + - deps: mime@1.3.4 + * deps: serve-static@~1.9.1 + - deps: send@0.12.1 + * deps: type-is@~1.6.0 + - fix argument reassignment + - fix false-positives in `hasBody` `Transfer-Encoding` check + - support wildcard for both type and subtype (`*/*`) + - deps: mime-types@~2.0.9 + +4.11.2 / 2015-02-01 +=================== + + * Fix `res.redirect` double-calling `res.end` for `HEAD` requests + * deps: accepts@~1.2.3 + - deps: mime-types@~2.0.8 + * deps: proxy-addr@~1.0.6 + - deps: ipaddr.js@0.1.8 + * deps: type-is@~1.5.6 + - deps: mime-types@~2.0.8 + +4.11.1 / 2015-01-20 +=================== + + * deps: send@0.11.1 + - Fix root path disclosure + * deps: serve-static@~1.8.1 + - Fix redirect loop in Node.js 0.11.14 + - Fix root path disclosure + - deps: send@0.11.1 + +4.11.0 / 2015-01-13 +=================== + + * Add `res.append(field, val)` to append headers + * Deprecate leading `:` in `name` for `app.param(name, fn)` + * Deprecate `req.param()` -- use `req.params`, `req.body`, or `req.query` instead + * Deprecate `app.param(fn)` + * Fix `OPTIONS` responses to include the `HEAD` method properly + * Fix `res.sendFile` not always detecting aborted connection + * Match routes iteratively to prevent stack overflows + * deps: accepts@~1.2.2 + - deps: mime-types@~2.0.7 + - deps: negotiator@0.5.0 + * deps: send@0.11.0 + - deps: debug@~2.1.1 + - deps: etag@~1.5.1 + - deps: ms@0.7.0 + - deps: on-finished@~2.2.0 + * deps: serve-static@~1.8.0 + - deps: send@0.11.0 + +4.10.8 / 2015-01-13 +=================== + + * Fix crash from error within `OPTIONS` response handler + * deps: proxy-addr@~1.0.5 + - deps: ipaddr.js@0.1.6 + +4.10.7 / 2015-01-04 +=================== + + * Fix `Allow` header for `OPTIONS` to not contain duplicate methods + * Fix incorrect "Request aborted" for `res.sendFile` when `HEAD` or 304 + * deps: debug@~2.1.1 + * deps: finalhandler@0.3.3 + - deps: debug@~2.1.1 + - deps: on-finished@~2.2.0 + * deps: methods@~1.1.1 + * deps: on-finished@~2.2.0 + * deps: serve-static@~1.7.2 + - Fix potential open redirect when mounted at root + * deps: type-is@~1.5.5 + - deps: mime-types@~2.0.7 + +4.10.6 / 2014-12-12 +=================== + + * Fix exception in `req.fresh`/`req.stale` without response headers + +4.10.5 / 2014-12-10 +=================== + + * Fix `res.send` double-calling `res.end` for `HEAD` requests + * deps: accepts@~1.1.4 + - deps: mime-types@~2.0.4 + * deps: type-is@~1.5.4 + - deps: mime-types@~2.0.4 + +4.10.4 / 2014-11-24 +=================== + + * Fix `res.sendfile` logging standard write errors + +4.10.3 / 2014-11-23 +=================== + + * Fix `res.sendFile` logging standard write errors + * deps: etag@~1.5.1 + * deps: proxy-addr@~1.0.4 + - deps: ipaddr.js@0.1.5 + * deps: qs@2.3.3 + - Fix `arrayLimit` behavior + +4.10.2 / 2014-11-09 +=================== + + * Correctly invoke async router callback asynchronously + * deps: accepts@~1.1.3 + - deps: mime-types@~2.0.3 + * deps: type-is@~1.5.3 + - deps: mime-types@~2.0.3 + +4.10.1 / 2014-10-28 +=================== + + * Fix handling of URLs containing `://` in the path + * deps: qs@2.3.2 + - Fix parsing of mixed objects and values + +4.10.0 / 2014-10-23 +=================== + + * Add support for `app.set('views', array)` + - Views are looked up in sequence in array of directories + * Fix `res.send(status)` to mention `res.sendStatus(status)` + * Fix handling of invalid empty URLs + * Use `content-disposition` module for `res.attachment`/`res.download` + - Sends standards-compliant `Content-Disposition` header + - Full Unicode support + * Use `path.resolve` in view lookup + * deps: debug@~2.1.0 + - Implement `DEBUG_FD` env variable support + * deps: depd@~1.0.0 + * deps: etag@~1.5.0 + - Improve string performance + - Slightly improve speed for weak ETags over 1KB + * deps: finalhandler@0.3.2 + - Terminate in progress response only on error + - Use `on-finished` to determine request status + - deps: debug@~2.1.0 + - deps: on-finished@~2.1.1 + * deps: on-finished@~2.1.1 + - Fix handling of pipelined requests + * deps: qs@2.3.0 + - Fix parsing of mixed implicit and explicit arrays + * deps: send@0.10.1 + - deps: debug@~2.1.0 + - deps: depd@~1.0.0 + - deps: etag@~1.5.0 + - deps: on-finished@~2.1.1 + * deps: serve-static@~1.7.1 + - deps: send@0.10.1 + +4.9.8 / 2014-10-17 +================== + + * Fix `res.redirect` body when redirect status specified + * deps: accepts@~1.1.2 + - Fix error when media type has invalid parameter + - deps: negotiator@0.4.9 + +4.9.7 / 2014-10-10 +================== + + * Fix using same param name in array of paths + +4.9.6 / 2014-10-08 +================== + + * deps: accepts@~1.1.1 + - deps: mime-types@~2.0.2 + - deps: negotiator@0.4.8 + * deps: serve-static@~1.6.4 + - Fix redirect loop when index file serving disabled + * deps: type-is@~1.5.2 + - deps: mime-types@~2.0.2 + +4.9.5 / 2014-09-24 +================== + + * deps: etag@~1.4.0 + * deps: proxy-addr@~1.0.3 + - Use `forwarded` npm module + * deps: send@0.9.3 + - deps: etag@~1.4.0 + * deps: serve-static@~1.6.3 + - deps: send@0.9.3 + +4.9.4 / 2014-09-19 +================== + + * deps: qs@2.2.4 + - Fix issue with object keys starting with numbers truncated + +4.9.3 / 2014-09-18 +================== + + * deps: proxy-addr@~1.0.2 + - Fix a global leak when multiple subnets are trusted + - deps: ipaddr.js@0.1.3 + +4.9.2 / 2014-09-17 +================== + + * Fix regression for empty string `path` in `app.use` + * Fix `router.use` to accept array of middleware without path + * Improve error message for bad `app.use` arguments + +4.9.1 / 2014-09-16 +================== + + * Fix `app.use` to accept array of middleware without path + * deps: depd@0.4.5 + * deps: etag@~1.3.1 + * deps: send@0.9.2 + - deps: depd@0.4.5 + - deps: etag@~1.3.1 + - deps: range-parser@~1.0.2 + * deps: serve-static@~1.6.2 + - deps: send@0.9.2 + +4.9.0 / 2014-09-08 +================== + + * Add `res.sendStatus` + * Invoke callback for sendfile when client aborts + - Applies to `res.sendFile`, `res.sendfile`, and `res.download` + - `err` will be populated with request aborted error + * Support IP address host in `req.subdomains` + * Use `etag` to generate `ETag` headers + * deps: accepts@~1.1.0 + - update `mime-types` + * deps: cookie-signature@1.0.5 + * deps: debug@~2.0.0 + * deps: finalhandler@0.2.0 + - Set `X-Content-Type-Options: nosniff` header + - deps: debug@~2.0.0 + * deps: fresh@0.2.4 + * deps: media-typer@0.3.0 + - Throw error when parameter format invalid on parse + * deps: qs@2.2.3 + - Fix issue where first empty value in array is discarded + * deps: range-parser@~1.0.2 + * deps: send@0.9.1 + - Add `lastModified` option + - Use `etag` to generate `ETag` header + - deps: debug@~2.0.0 + - deps: fresh@0.2.4 + * deps: serve-static@~1.6.1 + - Add `lastModified` option + - deps: send@0.9.1 + * deps: type-is@~1.5.1 + - fix `hasbody` to be true for `content-length: 0` + - deps: media-typer@0.3.0 + - deps: mime-types@~2.0.1 + * deps: vary@~1.0.0 + - Accept valid `Vary` header string as `field` + +4.8.8 / 2014-09-04 +================== + + * deps: send@0.8.5 + - Fix a path traversal issue when using `root` + - Fix malicious path detection for empty string path + * deps: serve-static@~1.5.4 + - deps: send@0.8.5 + +4.8.7 / 2014-08-29 +================== + + * deps: qs@2.2.2 + - Remove unnecessary cloning + +4.8.6 / 2014-08-27 +================== + + * deps: qs@2.2.0 + - Array parsing fix + - Performance improvements + +4.8.5 / 2014-08-18 +================== + + * deps: send@0.8.3 + - deps: destroy@1.0.3 + - deps: on-finished@2.1.0 + * deps: serve-static@~1.5.3 + - deps: send@0.8.3 + +4.8.4 / 2014-08-14 +================== + + * deps: qs@1.2.2 + * deps: send@0.8.2 + - Work around `fd` leak in Node.js 0.10 for `fs.ReadStream` + * deps: serve-static@~1.5.2 + - deps: send@0.8.2 + +4.8.3 / 2014-08-10 +================== + + * deps: parseurl@~1.3.0 + * deps: qs@1.2.1 + * deps: serve-static@~1.5.1 + - Fix parsing of weird `req.originalUrl` values + - deps: parseurl@~1.3.0 + - deps: utils-merge@1.0.0 + +4.8.2 / 2014-08-07 +================== + + * deps: qs@1.2.0 + - Fix parsing array of objects + +4.8.1 / 2014-08-06 +================== + + * fix incorrect deprecation warnings on `res.download` + * deps: qs@1.1.0 + - Accept urlencoded square brackets + - Accept empty values in implicit array notation + +4.8.0 / 2014-08-05 +================== + + * add `res.sendFile` + - accepts a file system path instead of a URL + - requires an absolute path or `root` option specified + * deprecate `res.sendfile` -- use `res.sendFile` instead + * support mounted app as any argument to `app.use()` + * deps: qs@1.0.2 + - Complete rewrite + - Limits array length to 20 + - Limits object depth to 5 + - Limits parameters to 1,000 + * deps: send@0.8.1 + - Add `extensions` option + * deps: serve-static@~1.5.0 + - Add `extensions` option + - deps: send@0.8.1 + +4.7.4 / 2014-08-04 +================== + + * fix `res.sendfile` regression for serving directory index files + * deps: send@0.7.4 + - Fix incorrect 403 on Windows and Node.js 0.11 + - Fix serving index files without root dir + * deps: serve-static@~1.4.4 + - deps: send@0.7.4 + +4.7.3 / 2014-08-04 +================== + + * deps: send@0.7.3 + - Fix incorrect 403 on Windows and Node.js 0.11 + * deps: serve-static@~1.4.3 + - Fix incorrect 403 on Windows and Node.js 0.11 + - deps: send@0.7.3 + +4.7.2 / 2014-07-27 +================== + + * deps: depd@0.4.4 + - Work-around v8 generating empty stack traces + * deps: send@0.7.2 + - deps: depd@0.4.4 + * deps: serve-static@~1.4.2 + +4.7.1 / 2014-07-26 +================== + + * deps: depd@0.4.3 + - Fix exception when global `Error.stackTraceLimit` is too low + * deps: send@0.7.1 + - deps: depd@0.4.3 + * deps: serve-static@~1.4.1 + +4.7.0 / 2014-07-25 +================== + + * fix `req.protocol` for proxy-direct connections + * configurable query parser with `app.set('query parser', parser)` + - `app.set('query parser', 'extended')` parse with "qs" module + - `app.set('query parser', 'simple')` parse with "querystring" core module + - `app.set('query parser', false)` disable query string parsing + - `app.set('query parser', true)` enable simple parsing + * deprecate `res.json(status, obj)` -- use `res.status(status).json(obj)` instead + * deprecate `res.jsonp(status, obj)` -- use `res.status(status).jsonp(obj)` instead + * deprecate `res.send(status, body)` -- use `res.status(status).send(body)` instead + * deps: debug@1.0.4 + * deps: depd@0.4.2 + - Add `TRACE_DEPRECATION` environment variable + - Remove non-standard grey color from color output + - Support `--no-deprecation` argument + - Support `--trace-deprecation` argument + * deps: finalhandler@0.1.0 + - Respond after request fully read + - deps: debug@1.0.4 + * deps: parseurl@~1.2.0 + - Cache URLs based on original value + - Remove no-longer-needed URL mis-parse work-around + - Simplify the "fast-path" `RegExp` + * deps: send@0.7.0 + - Add `dotfiles` option + - Cap `maxAge` value to 1 year + - deps: debug@1.0.4 + - deps: depd@0.4.2 + * deps: serve-static@~1.4.0 + - deps: parseurl@~1.2.0 + - deps: send@0.7.0 + * perf: prevent multiple `Buffer` creation in `res.send` + +4.6.1 / 2014-07-12 +================== + + * fix `subapp.mountpath` regression for `app.use(subapp)` + +4.6.0 / 2014-07-11 +================== + + * accept multiple callbacks to `app.use()` + * add explicit "Rosetta Flash JSONP abuse" protection + - previous versions are not vulnerable; this is just explicit protection + * catch errors in multiple `req.param(name, fn)` handlers + * deprecate `res.redirect(url, status)` -- use `res.redirect(status, url)` instead + * fix `res.send(status, num)` to send `num` as json (not error) + * remove unnecessary escaping when `res.jsonp` returns JSON response + * support non-string `path` in `app.use(path, fn)` + - supports array of paths + - supports `RegExp` + * router: fix optimization on router exit + * router: refactor location of `try` blocks + * router: speed up standard `app.use(fn)` + * deps: debug@1.0.3 + - Add support for multiple wildcards in namespaces + * deps: finalhandler@0.0.3 + - deps: debug@1.0.3 + * deps: methods@1.1.0 + - add `CONNECT` + * deps: parseurl@~1.1.3 + - faster parsing of href-only URLs + * deps: path-to-regexp@0.1.3 + * deps: send@0.6.0 + - deps: debug@1.0.3 + * deps: serve-static@~1.3.2 + - deps: parseurl@~1.1.3 + - deps: send@0.6.0 + * perf: fix arguments reassign deopt in some `res` methods + +4.5.1 / 2014-07-06 +================== + + * fix routing regression when altering `req.method` + +4.5.0 / 2014-07-04 +================== + + * add deprecation message to non-plural `req.accepts*` + * add deprecation message to `res.send(body, status)` + * add deprecation message to `res.vary()` + * add `headers` option to `res.sendfile` + - use to set headers on successful file transfer + * add `mergeParams` option to `Router` + - merges `req.params` from parent routes + * add `req.hostname` -- correct name for what `req.host` returns + * deprecate things with `depd` module + * deprecate `req.host` -- use `req.hostname` instead + * fix behavior when handling request without routes + * fix handling when `route.all` is only route + * invoke `router.param()` only when route matches + * restore `req.params` after invoking router + * use `finalhandler` for final response handling + * use `media-typer` to alter content-type charset + * deps: accepts@~1.0.7 + * deps: send@0.5.0 + - Accept string for `maxage` (converted by `ms`) + - Include link in default redirect response + * deps: serve-static@~1.3.0 + - Accept string for `maxAge` (converted by `ms`) + - Add `setHeaders` option + - Include HTML link in redirect response + - deps: send@0.5.0 + * deps: type-is@~1.3.2 + +4.4.5 / 2014-06-26 +================== + + * deps: cookie-signature@1.0.4 + - fix for timing attacks + +4.4.4 / 2014-06-20 +================== + + * fix `res.attachment` Unicode filenames in Safari + * fix "trim prefix" debug message in `express:router` + * deps: accepts@~1.0.5 + * deps: buffer-crc32@0.2.3 + +4.4.3 / 2014-06-11 +================== + + * fix persistence of modified `req.params[name]` from `app.param()` + * deps: accepts@1.0.3 + - deps: negotiator@0.4.6 + * deps: debug@1.0.2 + * deps: send@0.4.3 + - Do not throw un-catchable error on file open race condition + - Use `escape-html` for HTML escaping + - deps: debug@1.0.2 + - deps: finished@1.2.2 + - deps: fresh@0.2.2 + * deps: serve-static@1.2.3 + - Do not throw un-catchable error on file open race condition + - deps: send@0.4.3 + +4.4.2 / 2014-06-09 +================== + + * fix catching errors from top-level handlers + * use `vary` module for `res.vary` + * deps: debug@1.0.1 + * deps: proxy-addr@1.0.1 + * deps: send@0.4.2 + - fix "event emitter leak" warnings + - deps: debug@1.0.1 + - deps: finished@1.2.1 + * deps: serve-static@1.2.2 + - fix "event emitter leak" warnings + - deps: send@0.4.2 + * deps: type-is@1.2.1 + +4.4.1 / 2014-06-02 +================== + + * deps: methods@1.0.1 + * deps: send@0.4.1 + - Send `max-age` in `Cache-Control` in correct format + * deps: serve-static@1.2.1 + - use `escape-html` for escaping + - deps: send@0.4.1 + +4.4.0 / 2014-05-30 +================== + + * custom etag control with `app.set('etag', val)` + - `app.set('etag', function(body, encoding){ return '"etag"' })` custom etag generation + - `app.set('etag', 'weak')` weak tag + - `app.set('etag', 'strong')` strong etag + - `app.set('etag', false)` turn off + - `app.set('etag', true)` standard etag + * mark `res.send` ETag as weak and reduce collisions + * update accepts to 1.0.2 + - Fix interpretation when header not in request + * update send to 0.4.0 + - Calculate ETag with md5 for reduced collisions + - Ignore stream errors after request ends + - deps: debug@0.8.1 + * update serve-static to 1.2.0 + - Calculate ETag with md5 for reduced collisions + - Ignore stream errors after request ends + - deps: send@0.4.0 + +4.3.2 / 2014-05-28 +================== + + * fix handling of errors from `router.param()` callbacks + +4.3.1 / 2014-05-23 +================== + + * revert "fix behavior of multiple `app.VERB` for the same path" + - this caused a regression in the order of route execution + +4.3.0 / 2014-05-21 +================== + + * add `req.baseUrl` to access the path stripped from `req.url` in routes + * fix behavior of multiple `app.VERB` for the same path + * fix issue routing requests among sub routers + * invoke `router.param()` only when necessary instead of every match + * proper proxy trust with `app.set('trust proxy', trust)` + - `app.set('trust proxy', 1)` trust first hop + - `app.set('trust proxy', 'loopback')` trust loopback addresses + - `app.set('trust proxy', '10.0.0.1')` trust single IP + - `app.set('trust proxy', '10.0.0.1/16')` trust subnet + - `app.set('trust proxy', '10.0.0.1, 10.0.0.2')` trust list + - `app.set('trust proxy', false)` turn off + - `app.set('trust proxy', true)` trust everything + * set proper `charset` in `Content-Type` for `res.send` + * update type-is to 1.2.0 + - support suffix matching + +4.2.0 / 2014-05-11 +================== + + * deprecate `app.del()` -- use `app.delete()` instead + * deprecate `res.json(obj, status)` -- use `res.json(status, obj)` instead + - the edge-case `res.json(status, num)` requires `res.status(status).json(num)` + * deprecate `res.jsonp(obj, status)` -- use `res.jsonp(status, obj)` instead + - the edge-case `res.jsonp(status, num)` requires `res.status(status).jsonp(num)` + * fix `req.next` when inside router instance + * include `ETag` header in `HEAD` requests + * keep previous `Content-Type` for `res.jsonp` + * support PURGE method + - add `app.purge` + - add `router.purge` + - include PURGE in `app.all` + * update debug to 0.8.0 + - add `enable()` method + - change from stderr to stdout + * update methods to 1.0.0 + - add PURGE + +4.1.2 / 2014-05-08 +================== + + * fix `req.host` for IPv6 literals + * fix `res.jsonp` error if callback param is object + +4.1.1 / 2014-04-27 +================== + + * fix package.json to reflect supported node version + +4.1.0 / 2014-04-24 +================== + + * pass options from `res.sendfile` to `send` + * preserve casing of headers in `res.header` and `res.set` + * support unicode file names in `res.attachment` and `res.download` + * update accepts to 1.0.1 + - deps: negotiator@0.4.0 + * update cookie to 0.1.2 + - Fix for maxAge == 0 + - made compat with expires field + * update send to 0.3.0 + - Accept API options in options object + - Coerce option types + - Control whether to generate etags + - Default directory access to 403 when index disabled + - Fix sending files with dots without root set + - Include file path in etag + - Make "Can't set headers after they are sent." catchable + - Send full entity-body for multi range requests + - Set etags to "weak" + - Support "If-Range" header + - Support multiple index paths + - deps: mime@1.2.11 + * update serve-static to 1.1.0 + - Accept options directly to `send` module + - Resolve relative paths at middleware setup + - Use parseurl to parse the URL from request + - deps: send@0.3.0 + * update type-is to 1.1.0 + - add non-array values support + - add `multipart` as a shorthand + +4.0.0 / 2014-04-09 +================== + + * remove: + - node 0.8 support + - connect and connect's patches except for charset handling + - express(1) - moved to [express-generator](https://github.com/expressjs/generator) + - `express.createServer()` - it has been deprecated for a long time. Use `express()` + - `app.configure` - use logic in your own app code + - `app.router` - is removed + - `req.auth` - use `basic-auth` instead + - `req.accepted*` - use `req.accepts*()` instead + - `res.location` - relative URL resolution is removed + - `res.charset` - include the charset in the content type when using `res.set()` + - all bundled middleware except `static` + * change: + - `app.route` -> `app.mountpath` when mounting an express app in another express app + - `json spaces` no longer enabled by default in development + - `req.accepts*` -> `req.accepts*s` - i.e. `req.acceptsEncoding` -> `req.acceptsEncodings` + - `req.params` is now an object instead of an array + - `res.locals` is no longer a function. It is a plain js object. Treat it as such. + - `res.headerSent` -> `res.headersSent` to match node.js ServerResponse object + * refactor: + - `req.accepts*` with [accepts](https://github.com/expressjs/accepts) + - `req.is` with [type-is](https://github.com/expressjs/type-is) + - [path-to-regexp](https://github.com/component/path-to-regexp) + * add: + - `app.router()` - returns the app Router instance + - `app.route()` - Proxy to the app's `Router#route()` method to create a new route + - Router & Route - public API + +3.21.2 / 2015-07-31 +=================== + + * deps: connect@2.30.2 + - deps: body-parser@~1.13.3 + - deps: compression@~1.5.2 + - deps: errorhandler@~1.4.2 + - deps: method-override@~2.3.5 + - deps: serve-index@~1.7.2 + - deps: type-is@~1.6.6 + - deps: vhost@~3.0.1 + * deps: vary@~1.0.1 + - Fix setting empty header from empty `field` + - perf: enable strict mode + - perf: remove argument reassignments + +3.21.1 / 2015-07-05 +=================== + + * deps: basic-auth@~1.0.3 + * deps: connect@2.30.1 + - deps: body-parser@~1.13.2 + - deps: compression@~1.5.1 + - deps: errorhandler@~1.4.1 + - deps: morgan@~1.6.1 + - deps: pause@0.1.0 + - deps: qs@4.0.0 + - deps: serve-index@~1.7.1 + - deps: type-is@~1.6.4 + +3.21.0 / 2015-06-18 +=================== + + * deps: basic-auth@1.0.2 + - perf: enable strict mode + - perf: hoist regular expression + - perf: parse with regular expressions + - perf: remove argument reassignment + * deps: connect@2.30.0 + - deps: body-parser@~1.13.1 + - deps: bytes@2.1.0 + - deps: compression@~1.5.0 + - deps: cookie@0.1.3 + - deps: cookie-parser@~1.3.5 + - deps: csurf@~1.8.3 + - deps: errorhandler@~1.4.0 + - deps: express-session@~1.11.3 + - deps: finalhandler@0.4.0 + - deps: fresh@0.3.0 + - deps: morgan@~1.6.0 + - deps: serve-favicon@~2.3.0 + - deps: serve-index@~1.7.0 + - deps: serve-static@~1.10.0 + - deps: type-is@~1.6.3 + * deps: cookie@0.1.3 + - perf: deduce the scope of try-catch deopt + - perf: remove argument reassignments + * deps: escape-html@1.0.2 + * deps: etag@~1.7.0 + - Always include entity length in ETags for hash length extensions + - Generate non-Stats ETags using MD5 only (no longer CRC32) + - Improve stat performance by removing hashing + - Improve support for JXcore + - Remove base64 padding in ETags to shorten + - Support "fake" stats objects in environments without fs + - Use MD5 instead of MD4 in weak ETags over 1KB + * deps: fresh@0.3.0 + - Add weak `ETag` matching support + * deps: mkdirp@0.5.1 + - Work in global strict mode + * deps: send@0.13.0 + - Allow Node.js HTTP server to set `Date` response header + - Fix incorrectly removing `Content-Location` on 304 response + - Improve the default redirect response headers + - Send appropriate headers on default error response + - Use `http-errors` for standard emitted errors + - Use `statuses` instead of `http` module for status messages + - deps: escape-html@1.0.2 + - deps: etag@~1.7.0 + - deps: fresh@0.3.0 + - deps: on-finished@~2.3.0 + - perf: enable strict mode + - perf: remove unnecessary array allocations + +3.20.3 / 2015-05-17 +=================== + + * deps: connect@2.29.2 + - deps: body-parser@~1.12.4 + - deps: compression@~1.4.4 + - deps: connect-timeout@~1.6.2 + - deps: debug@~2.2.0 + - deps: depd@~1.0.1 + - deps: errorhandler@~1.3.6 + - deps: finalhandler@0.3.6 + - deps: method-override@~2.3.3 + - deps: morgan@~1.5.3 + - deps: qs@2.4.2 + - deps: response-time@~2.3.1 + - deps: serve-favicon@~2.2.1 + - deps: serve-index@~1.6.4 + - deps: serve-static@~1.9.3 + - deps: type-is@~1.6.2 + * deps: debug@~2.2.0 + - deps: ms@0.7.1 + * deps: depd@~1.0.1 + * deps: proxy-addr@~1.0.8 + - deps: ipaddr.js@1.0.1 + * deps: send@0.12.3 + - deps: debug@~2.2.0 + - deps: depd@~1.0.1 + - deps: etag@~1.6.0 + - deps: ms@0.7.1 + - deps: on-finished@~2.2.1 + +3.20.2 / 2015-03-16 +=================== + + * deps: connect@2.29.1 + - deps: body-parser@~1.12.2 + - deps: compression@~1.4.3 + - deps: connect-timeout@~1.6.1 + - deps: debug@~2.1.3 + - deps: errorhandler@~1.3.5 + - deps: express-session@~1.10.4 + - deps: finalhandler@0.3.4 + - deps: method-override@~2.3.2 + - deps: morgan@~1.5.2 + - deps: qs@2.4.1 + - deps: serve-index@~1.6.3 + - deps: serve-static@~1.9.2 + - deps: type-is@~1.6.1 + * deps: debug@~2.1.3 + - Fix high intensity foreground color for bold + - deps: ms@0.7.0 + * deps: merge-descriptors@1.0.0 + * deps: proxy-addr@~1.0.7 + - deps: ipaddr.js@0.1.9 + * deps: send@0.12.2 + - Throw errors early for invalid `extensions` or `index` options + - deps: debug@~2.1.3 + +3.20.1 / 2015-02-28 +=================== + + * Fix `req.host` when using "trust proxy" hops count + * Fix `req.protocol`/`req.secure` when using "trust proxy" hops count + +3.20.0 / 2015-02-18 +=================== + + * Fix `"trust proxy"` setting to inherit when app is mounted + * Generate `ETag`s for all request responses + - No longer restricted to only responses for `GET` and `HEAD` requests + * Use `content-type` to parse `Content-Type` headers + * deps: connect@2.29.0 + - Use `content-type` to parse `Content-Type` headers + - deps: body-parser@~1.12.0 + - deps: compression@~1.4.1 + - deps: connect-timeout@~1.6.0 + - deps: cookie-parser@~1.3.4 + - deps: cookie-signature@1.0.6 + - deps: csurf@~1.7.0 + - deps: errorhandler@~1.3.4 + - deps: express-session@~1.10.3 + - deps: http-errors@~1.3.1 + - deps: response-time@~2.3.0 + - deps: serve-index@~1.6.2 + - deps: serve-static@~1.9.1 + - deps: type-is@~1.6.0 + * deps: cookie-signature@1.0.6 + * deps: send@0.12.1 + - Always read the stat size from the file + - Fix mutating passed-in `options` + - deps: mime@1.3.4 + +3.19.2 / 2015-02-01 +=================== + + * deps: connect@2.28.3 + - deps: compression@~1.3.1 + - deps: csurf@~1.6.6 + - deps: errorhandler@~1.3.3 + - deps: express-session@~1.10.2 + - deps: serve-index@~1.6.1 + - deps: type-is@~1.5.6 + * deps: proxy-addr@~1.0.6 + - deps: ipaddr.js@0.1.8 + +3.19.1 / 2015-01-20 +=================== + + * deps: connect@2.28.2 + - deps: body-parser@~1.10.2 + - deps: serve-static@~1.8.1 + * deps: send@0.11.1 + - Fix root path disclosure + +3.19.0 / 2015-01-09 +=================== + + * Fix `OPTIONS` responses to include the `HEAD` method property + * Use `readline` for prompt in `express(1)` + * deps: commander@2.6.0 + * deps: connect@2.28.1 + - deps: body-parser@~1.10.1 + - deps: compression@~1.3.0 + - deps: connect-timeout@~1.5.0 + - deps: csurf@~1.6.4 + - deps: debug@~2.1.1 + - deps: errorhandler@~1.3.2 + - deps: express-session@~1.10.1 + - deps: finalhandler@0.3.3 + - deps: method-override@~2.3.1 + - deps: morgan@~1.5.1 + - deps: serve-favicon@~2.2.0 + - deps: serve-index@~1.6.0 + - deps: serve-static@~1.8.0 + - deps: type-is@~1.5.5 + * deps: debug@~2.1.1 + * deps: methods@~1.1.1 + * deps: proxy-addr@~1.0.5 + - deps: ipaddr.js@0.1.6 + * deps: send@0.11.0 + - deps: debug@~2.1.1 + - deps: etag@~1.5.1 + - deps: ms@0.7.0 + - deps: on-finished@~2.2.0 + +3.18.6 / 2014-12-12 +=================== + + * Fix exception in `req.fresh`/`req.stale` without response headers + +3.18.5 / 2014-12-11 +=================== + + * deps: connect@2.27.6 + - deps: compression@~1.2.2 + - deps: express-session@~1.9.3 + - deps: http-errors@~1.2.8 + - deps: serve-index@~1.5.3 + - deps: type-is@~1.5.4 + +3.18.4 / 2014-11-23 +=================== + + * deps: connect@2.27.4 + - deps: body-parser@~1.9.3 + - deps: compression@~1.2.1 + - deps: errorhandler@~1.2.3 + - deps: express-session@~1.9.2 + - deps: qs@2.3.3 + - deps: serve-favicon@~2.1.7 + - deps: serve-static@~1.5.1 + - deps: type-is@~1.5.3 + * deps: etag@~1.5.1 + * deps: proxy-addr@~1.0.4 + - deps: ipaddr.js@0.1.5 + +3.18.3 / 2014-11-09 +=================== + + * deps: connect@2.27.3 + - Correctly invoke async callback asynchronously + - deps: csurf@~1.6.3 + +3.18.2 / 2014-10-28 +=================== + + * deps: connect@2.27.2 + - Fix handling of URLs containing `://` in the path + - deps: body-parser@~1.9.2 + - deps: qs@2.3.2 + +3.18.1 / 2014-10-22 +=================== + + * Fix internal `utils.merge` deprecation warnings + * deps: connect@2.27.1 + - deps: body-parser@~1.9.1 + - deps: express-session@~1.9.1 + - deps: finalhandler@0.3.2 + - deps: morgan@~1.4.1 + - deps: qs@2.3.0 + - deps: serve-static@~1.7.1 + * deps: send@0.10.1 + - deps: on-finished@~2.1.1 + +3.18.0 / 2014-10-17 +=================== + + * Use `content-disposition` module for `res.attachment`/`res.download` + - Sends standards-compliant `Content-Disposition` header + - Full Unicode support + * Use `etag` module to generate `ETag` headers + * deps: connect@2.27.0 + - Use `http-errors` module for creating errors + - Use `utils-merge` module for merging objects + - deps: body-parser@~1.9.0 + - deps: compression@~1.2.0 + - deps: connect-timeout@~1.4.0 + - deps: debug@~2.1.0 + - deps: depd@~1.0.0 + - deps: express-session@~1.9.0 + - deps: finalhandler@0.3.1 + - deps: method-override@~2.3.0 + - deps: morgan@~1.4.0 + - deps: response-time@~2.2.0 + - deps: serve-favicon@~2.1.6 + - deps: serve-index@~1.5.0 + - deps: serve-static@~1.7.0 + * deps: debug@~2.1.0 + - Implement `DEBUG_FD` env variable support + * deps: depd@~1.0.0 + * deps: send@0.10.0 + - deps: debug@~2.1.0 + - deps: depd@~1.0.0 + - deps: etag@~1.5.0 + +3.17.8 / 2014-10-15 +=================== + + * deps: connect@2.26.6 + - deps: compression@~1.1.2 + - deps: csurf@~1.6.2 + - deps: errorhandler@~1.2.2 + +3.17.7 / 2014-10-08 +=================== + + * deps: connect@2.26.5 + - Fix accepting non-object arguments to `logger` + - deps: serve-static@~1.6.4 + +3.17.6 / 2014-10-02 +=================== + + * deps: connect@2.26.4 + - deps: morgan@~1.3.2 + - deps: type-is@~1.5.2 + +3.17.5 / 2014-09-24 +=================== + + * deps: connect@2.26.3 + - deps: body-parser@~1.8.4 + - deps: serve-favicon@~2.1.5 + - deps: serve-static@~1.6.3 + * deps: proxy-addr@~1.0.3 + - Use `forwarded` npm module + * deps: send@0.9.3 + - deps: etag@~1.4.0 + +3.17.4 / 2014-09-19 +=================== + + * deps: connect@2.26.2 + - deps: body-parser@~1.8.3 + - deps: qs@2.2.4 + +3.17.3 / 2014-09-18 +=================== + + * deps: proxy-addr@~1.0.2 + - Fix a global leak when multiple subnets are trusted + - deps: ipaddr.js@0.1.3 + +3.17.2 / 2014-09-15 +=================== + + * Use `crc` instead of `buffer-crc32` for speed + * deps: connect@2.26.1 + - deps: body-parser@~1.8.2 + - deps: depd@0.4.5 + - deps: express-session@~1.8.2 + - deps: morgan@~1.3.1 + - deps: serve-favicon@~2.1.3 + - deps: serve-static@~1.6.2 + * deps: depd@0.4.5 + * deps: send@0.9.2 + - deps: depd@0.4.5 + - deps: etag@~1.3.1 + - deps: range-parser@~1.0.2 + +3.17.1 / 2014-09-08 +=================== + + * Fix error in `req.subdomains` on empty host + +3.17.0 / 2014-09-08 +=================== + + * Support `X-Forwarded-Host` in `req.subdomains` + * Support IP address host in `req.subdomains` + * deps: connect@2.26.0 + - deps: body-parser@~1.8.1 + - deps: compression@~1.1.0 + - deps: connect-timeout@~1.3.0 + - deps: cookie-parser@~1.3.3 + - deps: cookie-signature@1.0.5 + - deps: csurf@~1.6.1 + - deps: debug@~2.0.0 + - deps: errorhandler@~1.2.0 + - deps: express-session@~1.8.1 + - deps: finalhandler@0.2.0 + - deps: fresh@0.2.4 + - deps: media-typer@0.3.0 + - deps: method-override@~2.2.0 + - deps: morgan@~1.3.0 + - deps: qs@2.2.3 + - deps: serve-favicon@~2.1.3 + - deps: serve-index@~1.2.1 + - deps: serve-static@~1.6.1 + - deps: type-is@~1.5.1 + - deps: vhost@~3.0.0 + * deps: cookie-signature@1.0.5 + * deps: debug@~2.0.0 + * deps: fresh@0.2.4 + * deps: media-typer@0.3.0 + - Throw error when parameter format invalid on parse + * deps: range-parser@~1.0.2 + * deps: send@0.9.1 + - Add `lastModified` option + - Use `etag` to generate `ETag` header + - deps: debug@~2.0.0 + - deps: fresh@0.2.4 + * deps: vary@~1.0.0 + - Accept valid `Vary` header string as `field` + +3.16.10 / 2014-09-04 +==================== + + * deps: connect@2.25.10 + - deps: serve-static@~1.5.4 + * deps: send@0.8.5 + - Fix a path traversal issue when using `root` + - Fix malicious path detection for empty string path + +3.16.9 / 2014-08-29 +=================== + + * deps: connect@2.25.9 + - deps: body-parser@~1.6.7 + - deps: qs@2.2.2 + +3.16.8 / 2014-08-27 +=================== + + * deps: connect@2.25.8 + - deps: body-parser@~1.6.6 + - deps: csurf@~1.4.1 + - deps: qs@2.2.0 + +3.16.7 / 2014-08-18 +=================== + + * deps: connect@2.25.7 + - deps: body-parser@~1.6.5 + - deps: express-session@~1.7.6 + - deps: morgan@~1.2.3 + - deps: serve-static@~1.5.3 + * deps: send@0.8.3 + - deps: destroy@1.0.3 + - deps: on-finished@2.1.0 + +3.16.6 / 2014-08-14 +=================== + + * deps: connect@2.25.6 + - deps: body-parser@~1.6.4 + - deps: qs@1.2.2 + - deps: serve-static@~1.5.2 + * deps: send@0.8.2 + - Work around `fd` leak in Node.js 0.10 for `fs.ReadStream` + +3.16.5 / 2014-08-11 +=================== + + * deps: connect@2.25.5 + - Fix backwards compatibility in `logger` + +3.16.4 / 2014-08-10 +=================== + + * Fix original URL parsing in `res.location` + * deps: connect@2.25.4 + - Fix `query` middleware breaking with argument + - deps: body-parser@~1.6.3 + - deps: compression@~1.0.11 + - deps: connect-timeout@~1.2.2 + - deps: express-session@~1.7.5 + - deps: method-override@~2.1.3 + - deps: on-headers@~1.0.0 + - deps: parseurl@~1.3.0 + - deps: qs@1.2.1 + - deps: response-time@~2.0.1 + - deps: serve-index@~1.1.6 + - deps: serve-static@~1.5.1 + * deps: parseurl@~1.3.0 + +3.16.3 / 2014-08-07 +=================== + + * deps: connect@2.25.3 + - deps: multiparty@3.3.2 + +3.16.2 / 2014-08-07 +=================== + + * deps: connect@2.25.2 + - deps: body-parser@~1.6.2 + - deps: qs@1.2.0 + +3.16.1 / 2014-08-06 +=================== + + * deps: connect@2.25.1 + - deps: body-parser@~1.6.1 + - deps: qs@1.1.0 + +3.16.0 / 2014-08-05 +=================== + + * deps: connect@2.25.0 + - deps: body-parser@~1.6.0 + - deps: compression@~1.0.10 + - deps: csurf@~1.4.0 + - deps: express-session@~1.7.4 + - deps: qs@1.0.2 + - deps: serve-static@~1.5.0 + * deps: send@0.8.1 + - Add `extensions` option + +3.15.3 / 2014-08-04 +=================== + + * fix `res.sendfile` regression for serving directory index files + * deps: connect@2.24.3 + - deps: serve-index@~1.1.5 + - deps: serve-static@~1.4.4 + * deps: send@0.7.4 + - Fix incorrect 403 on Windows and Node.js 0.11 + - Fix serving index files without root dir + +3.15.2 / 2014-07-27 +=================== + + * deps: connect@2.24.2 + - deps: body-parser@~1.5.2 + - deps: depd@0.4.4 + - deps: express-session@~1.7.2 + - deps: morgan@~1.2.2 + - deps: serve-static@~1.4.2 + * deps: depd@0.4.4 + - Work-around v8 generating empty stack traces + * deps: send@0.7.2 + - deps: depd@0.4.4 + +3.15.1 / 2014-07-26 +=================== + + * deps: connect@2.24.1 + - deps: body-parser@~1.5.1 + - deps: depd@0.4.3 + - deps: express-session@~1.7.1 + - deps: morgan@~1.2.1 + - deps: serve-index@~1.1.4 + - deps: serve-static@~1.4.1 + * deps: depd@0.4.3 + - Fix exception when global `Error.stackTraceLimit` is too low + * deps: send@0.7.1 + - deps: depd@0.4.3 + +3.15.0 / 2014-07-22 +=================== + + * Fix `req.protocol` for proxy-direct connections + * Pass options from `res.sendfile` to `send` + * deps: connect@2.24.0 + - deps: body-parser@~1.5.0 + - deps: compression@~1.0.9 + - deps: connect-timeout@~1.2.1 + - deps: debug@1.0.4 + - deps: depd@0.4.2 + - deps: express-session@~1.7.0 + - deps: finalhandler@0.1.0 + - deps: method-override@~2.1.2 + - deps: morgan@~1.2.0 + - deps: multiparty@3.3.1 + - deps: parseurl@~1.2.0 + - deps: serve-static@~1.4.0 + * deps: debug@1.0.4 + * deps: depd@0.4.2 + - Add `TRACE_DEPRECATION` environment variable + - Remove non-standard grey color from color output + - Support `--no-deprecation` argument + - Support `--trace-deprecation` argument + * deps: parseurl@~1.2.0 + - Cache URLs based on original value + - Remove no-longer-needed URL mis-parse work-around + - Simplify the "fast-path" `RegExp` + * deps: send@0.7.0 + - Add `dotfiles` option + - Cap `maxAge` value to 1 year + - deps: debug@1.0.4 + - deps: depd@0.4.2 + +3.14.0 / 2014-07-11 +=================== + + * add explicit "Rosetta Flash JSONP abuse" protection + - previous versions are not vulnerable; this is just explicit protection + * deprecate `res.redirect(url, status)` -- use `res.redirect(status, url)` instead + * fix `res.send(status, num)` to send `num` as json (not error) + * remove unnecessary escaping when `res.jsonp` returns JSON response + * deps: basic-auth@1.0.0 + - support empty password + - support empty username + * deps: connect@2.23.0 + - deps: debug@1.0.3 + - deps: express-session@~1.6.4 + - deps: method-override@~2.1.0 + - deps: parseurl@~1.1.3 + - deps: serve-static@~1.3.1 + * deps: debug@1.0.3 + - Add support for multiple wildcards in namespaces + * deps: methods@1.1.0 + - add `CONNECT` + * deps: parseurl@~1.1.3 + - faster parsing of href-only URLs + +3.13.0 / 2014-07-03 +=================== + + * add deprecation message to `app.configure` + * add deprecation message to `req.auth` + * use `basic-auth` to parse `Authorization` header + * deps: connect@2.22.0 + - deps: csurf@~1.3.0 + - deps: express-session@~1.6.1 + - deps: multiparty@3.3.0 + - deps: serve-static@~1.3.0 + * deps: send@0.5.0 + - Accept string for `maxage` (converted by `ms`) + - Include link in default redirect response + +3.12.1 / 2014-06-26 +=================== + + * deps: connect@2.21.1 + - deps: cookie-parser@1.3.2 + - deps: cookie-signature@1.0.4 + - deps: express-session@~1.5.2 + - deps: type-is@~1.3.2 + * deps: cookie-signature@1.0.4 + - fix for timing attacks + +3.12.0 / 2014-06-21 +=================== + + * use `media-typer` to alter content-type charset + * deps: connect@2.21.0 + - deprecate `connect(middleware)` -- use `app.use(middleware)` instead + - deprecate `connect.createServer()` -- use `connect()` instead + - fix `res.setHeader()` patch to work with with get -> append -> set pattern + - deps: compression@~1.0.8 + - deps: errorhandler@~1.1.1 + - deps: express-session@~1.5.0 + - deps: serve-index@~1.1.3 + +3.11.0 / 2014-06-19 +=================== + + * deprecate things with `depd` module + * deps: buffer-crc32@0.2.3 + * deps: connect@2.20.2 + - deprecate `verify` option to `json` -- use `body-parser` npm module instead + - deprecate `verify` option to `urlencoded` -- use `body-parser` npm module instead + - deprecate things with `depd` module + - use `finalhandler` for final response handling + - use `media-typer` to parse `content-type` for charset + - deps: body-parser@1.4.3 + - deps: connect-timeout@1.1.1 + - deps: cookie-parser@1.3.1 + - deps: csurf@1.2.2 + - deps: errorhandler@1.1.0 + - deps: express-session@1.4.0 + - deps: multiparty@3.2.9 + - deps: serve-index@1.1.2 + - deps: type-is@1.3.1 + - deps: vhost@2.0.0 + +3.10.5 / 2014-06-11 +=================== + + * deps: connect@2.19.6 + - deps: body-parser@1.3.1 + - deps: compression@1.0.7 + - deps: debug@1.0.2 + - deps: serve-index@1.1.1 + - deps: serve-static@1.2.3 + * deps: debug@1.0.2 + * deps: send@0.4.3 + - Do not throw un-catchable error on file open race condition + - Use `escape-html` for HTML escaping + - deps: debug@1.0.2 + - deps: finished@1.2.2 + - deps: fresh@0.2.2 + +3.10.4 / 2014-06-09 +=================== + + * deps: connect@2.19.5 + - fix "event emitter leak" warnings + - deps: csurf@1.2.1 + - deps: debug@1.0.1 + - deps: serve-static@1.2.2 + - deps: type-is@1.2.1 + * deps: debug@1.0.1 + * deps: send@0.4.2 + - fix "event emitter leak" warnings + - deps: finished@1.2.1 + - deps: debug@1.0.1 + +3.10.3 / 2014-06-05 +=================== + + * use `vary` module for `res.vary` + * deps: connect@2.19.4 + - deps: errorhandler@1.0.2 + - deps: method-override@2.0.2 + - deps: serve-favicon@2.0.1 + * deps: debug@1.0.0 + +3.10.2 / 2014-06-03 +=================== + + * deps: connect@2.19.3 + - deps: compression@1.0.6 + +3.10.1 / 2014-06-03 +=================== + + * deps: connect@2.19.2 + - deps: compression@1.0.4 + * deps: proxy-addr@1.0.1 + +3.10.0 / 2014-06-02 +=================== + + * deps: connect@2.19.1 + - deprecate `methodOverride()` -- use `method-override` npm module instead + - deps: body-parser@1.3.0 + - deps: method-override@2.0.1 + - deps: multiparty@3.2.8 + - deps: response-time@2.0.0 + - deps: serve-static@1.2.1 + * deps: methods@1.0.1 + * deps: send@0.4.1 + - Send `max-age` in `Cache-Control` in correct format + +3.9.0 / 2014-05-30 +================== + + * custom etag control with `app.set('etag', val)` + - `app.set('etag', function(body, encoding){ return '"etag"' })` custom etag generation + - `app.set('etag', 'weak')` weak tag + - `app.set('etag', 'strong')` strong etag + - `app.set('etag', false)` turn off + - `app.set('etag', true)` standard etag + * Include ETag in HEAD requests + * mark `res.send` ETag as weak and reduce collisions + * update connect to 2.18.0 + - deps: compression@1.0.3 + - deps: serve-index@1.1.0 + - deps: serve-static@1.2.0 + * update send to 0.4.0 + - Calculate ETag with md5 for reduced collisions + - Ignore stream errors after request ends + - deps: debug@0.8.1 + +3.8.1 / 2014-05-27 +================== + + * update connect to 2.17.3 + - deps: body-parser@1.2.2 + - deps: express-session@1.2.1 + - deps: method-override@1.0.2 + +3.8.0 / 2014-05-21 +================== + + * keep previous `Content-Type` for `res.jsonp` + * set proper `charset` in `Content-Type` for `res.send` + * update connect to 2.17.1 + - fix `res.charset` appending charset when `content-type` has one + - deps: express-session@1.2.0 + - deps: morgan@1.1.1 + - deps: serve-index@1.0.3 + +3.7.0 / 2014-05-18 +================== + + * proper proxy trust with `app.set('trust proxy', trust)` + - `app.set('trust proxy', 1)` trust first hop + - `app.set('trust proxy', 'loopback')` trust loopback addresses + - `app.set('trust proxy', '10.0.0.1')` trust single IP + - `app.set('trust proxy', '10.0.0.1/16')` trust subnet + - `app.set('trust proxy', '10.0.0.1, 10.0.0.2')` trust list + - `app.set('trust proxy', false)` turn off + - `app.set('trust proxy', true)` trust everything + * update connect to 2.16.2 + - deprecate `res.headerSent` -- use `res.headersSent` + - deprecate `res.on("header")` -- use on-headers module instead + - fix edge-case in `res.appendHeader` that would append in wrong order + - json: use body-parser + - urlencoded: use body-parser + - dep: bytes@1.0.0 + - dep: cookie-parser@1.1.0 + - dep: csurf@1.2.0 + - dep: express-session@1.1.0 + - dep: method-override@1.0.1 + +3.6.0 / 2014-05-09 +================== + + * deprecate `app.del()` -- use `app.delete()` instead + * deprecate `res.json(obj, status)` -- use `res.json(status, obj)` instead + - the edge-case `res.json(status, num)` requires `res.status(status).json(num)` + * deprecate `res.jsonp(obj, status)` -- use `res.jsonp(status, obj)` instead + - the edge-case `res.jsonp(status, num)` requires `res.status(status).jsonp(num)` + * support PURGE method + - add `app.purge` + - add `router.purge` + - include PURGE in `app.all` + * update connect to 2.15.0 + * Add `res.appendHeader` + * Call error stack even when response has been sent + * Patch `res.headerSent` to return Boolean + * Patch `res.headersSent` for node.js 0.8 + * Prevent default 404 handler after response sent + * dep: compression@1.0.2 + * dep: connect-timeout@1.1.0 + * dep: debug@^0.8.0 + * dep: errorhandler@1.0.1 + * dep: express-session@1.0.4 + * dep: morgan@1.0.1 + * dep: serve-favicon@2.0.0 + * dep: serve-index@1.0.2 + * update debug to 0.8.0 + * add `enable()` method + * change from stderr to stdout + * update methods to 1.0.0 + - add PURGE + * update mkdirp to 0.5.0 + +3.5.3 / 2014-05-08 +================== + + * fix `req.host` for IPv6 literals + * fix `res.jsonp` error if callback param is object + +3.5.2 / 2014-04-24 +================== + + * update connect to 2.14.5 + * update cookie to 0.1.2 + * update mkdirp to 0.4.0 + * update send to 0.3.0 + +3.5.1 / 2014-03-25 +================== + + * pin less-middleware in generated app + +3.5.0 / 2014-03-06 +================== + + * bump deps + +3.4.8 / 2014-01-13 +================== + + * prevent incorrect automatic OPTIONS responses #1868 @dpatti + * update binary and examples for jade 1.0 #1876 @yossi, #1877 @reqshark, #1892 @matheusazzi + * throw 400 in case of malformed paths @rlidwka + +3.4.7 / 2013-12-10 +================== + + * update connect + +3.4.6 / 2013-12-01 +================== + + * update connect (raw-body) + +3.4.5 / 2013-11-27 +================== + + * update connect + * res.location: remove leading ./ #1802 @kapouer + * res.redirect: fix `res.redirect('toString') #1829 @michaelficarra + * res.send: always send ETag when content-length > 0 + * router: add Router.all() method + +3.4.4 / 2013-10-29 +================== + + * update connect + * update supertest + * update methods + * express(1): replace bodyParser() with urlencoded() and json() #1795 @chirag04 + +3.4.3 / 2013-10-23 +================== + + * update connect + +3.4.2 / 2013-10-18 +================== + + * update connect + * downgrade commander + +3.4.1 / 2013-10-15 +================== + + * update connect + * update commander + * jsonp: check if callback is a function + * router: wrap encodeURIComponent in a try/catch #1735 (@lxe) + * res.format: now includes charset @1747 (@sorribas) + * res.links: allow multiple calls @1746 (@sorribas) + +3.4.0 / 2013-09-07 +================== + + * add res.vary(). Closes #1682 + * update connect + +3.3.8 / 2013-09-02 +================== + + * update connect + +3.3.7 / 2013-08-28 +================== + + * update connect + +3.3.6 / 2013-08-27 +================== + + * Revert "remove charset from json responses. Closes #1631" (causes issues in some clients) + * add: req.accepts take an argument list + +3.3.4 / 2013-07-08 +================== + + * update send and connect + +3.3.3 / 2013-07-04 +================== + + * update connect + +3.3.2 / 2013-07-03 +================== + + * update connect + * update send + * remove .version export + +3.3.1 / 2013-06-27 +================== + + * update connect + +3.3.0 / 2013-06-26 +================== + + * update connect + * add support for multiple X-Forwarded-Proto values. Closes #1646 + * change: remove charset from json responses. Closes #1631 + * change: return actual booleans from req.accept* functions + * fix jsonp callback array throw + +3.2.6 / 2013-06-02 +================== + + * update connect + +3.2.5 / 2013-05-21 +================== + + * update connect + * update node-cookie + * add: throw a meaningful error when there is no default engine + * change generation of ETags with res.send() to GET requests only. Closes #1619 + +3.2.4 / 2013-05-09 +================== + + * fix `req.subdomains` when no Host is present + * fix `req.host` when no Host is present, return undefined + +3.2.3 / 2013-05-07 +================== + + * update connect / qs + +3.2.2 / 2013-05-03 +================== + + * update qs + +3.2.1 / 2013-04-29 +================== + + * add app.VERB() paths array deprecation warning + * update connect + * update qs and remove all ~ semver crap + * fix: accept number as value of Signed Cookie + +3.2.0 / 2013-04-15 +================== + + * add "view" constructor setting to override view behaviour + * add req.acceptsEncoding(name) + * add req.acceptedEncodings + * revert cookie signature change causing session race conditions + * fix sorting of Accept values of the same quality + +3.1.2 / 2013-04-12 +================== + + * add support for custom Accept parameters + * update cookie-signature + +3.1.1 / 2013-04-01 +================== + + * add X-Forwarded-Host support to `req.host` + * fix relative redirects + * update mkdirp + * update buffer-crc32 + * remove legacy app.configure() method from app template. + +3.1.0 / 2013-01-25 +================== + + * add support for leading "." in "view engine" setting + * add array support to `res.set()` + * add node 0.8.x to travis.yml + * add "subdomain offset" setting for tweaking `req.subdomains` + * add `res.location(url)` implementing `res.redirect()`-like setting of Location + * use app.get() for x-powered-by setting for inheritance + * fix colons in passwords for `req.auth` + +3.0.6 / 2013-01-04 +================== + + * add http verb methods to Router + * update connect + * fix mangling of the `res.cookie()` options object + * fix jsonp whitespace escape. Closes #1132 + +3.0.5 / 2012-12-19 +================== + + * add throwing when a non-function is passed to a route + * fix: explicitly remove Transfer-Encoding header from 204 and 304 responses + * revert "add 'etag' option" + +3.0.4 / 2012-12-05 +================== + + * add 'etag' option to disable `res.send()` Etags + * add escaping of urls in text/plain in `res.redirect()` + for old browsers interpreting as html + * change crc32 module for a more liberal license + * update connect + +3.0.3 / 2012-11-13 +================== + + * update connect + * update cookie module + * fix cookie max-age + +3.0.2 / 2012-11-08 +================== + + * add OPTIONS to cors example. Closes #1398 + * fix route chaining regression. Closes #1397 + +3.0.1 / 2012-11-01 +================== + + * update connect + +3.0.0 / 2012-10-23 +================== + + * add `make clean` + * add "Basic" check to req.auth + * add `req.auth` test coverage + * add cb && cb(payload) to `res.jsonp()`. Closes #1374 + * add backwards compat for `res.redirect()` status. Closes #1336 + * add support for `res.json()` to retain previously defined Content-Types. Closes #1349 + * update connect + * change `res.redirect()` to utilize a pathname-relative Location again. Closes #1382 + * remove non-primitive string support for `res.send()` + * fix view-locals example. Closes #1370 + * fix route-separation example + +3.0.0rc5 / 2012-09-18 +================== + + * update connect + * add redis search example + * add static-files example + * add "x-powered-by" setting (`app.disable('x-powered-by')`) + * add "application/octet-stream" redirect Accept test case. Closes #1317 + +3.0.0rc4 / 2012-08-30 +================== + + * add `res.jsonp()`. Closes #1307 + * add "verbose errors" option to error-pages example + * add another route example to express(1) so people are not so confused + * add redis online user activity tracking example + * update connect dep + * fix etag quoting. Closes #1310 + * fix error-pages 404 status + * fix jsonp callback char restrictions + * remove old OPTIONS default response + +3.0.0rc3 / 2012-08-13 +================== + + * update connect dep + * fix signed cookies to work with `connect.cookieParser()` ("s:" prefix was missing) [tnydwrds] + * fix `res.render()` clobbering of "locals" + +3.0.0rc2 / 2012-08-03 +================== + + * add CORS example + * update connect dep + * deprecate `.createServer()` & remove old stale examples + * fix: escape `res.redirect()` link + * fix vhost example + +3.0.0rc1 / 2012-07-24 +================== + + * add more examples to view-locals + * add scheme-relative redirects (`res.redirect("//foo.com")`) support + * update cookie dep + * update connect dep + * update send dep + * fix `express(1)` -h flag, use -H for hogan. Closes #1245 + * fix `res.sendfile()` socket error handling regression + +3.0.0beta7 / 2012-07-16 +================== + + * update connect dep for `send()` root normalization regression + +3.0.0beta6 / 2012-07-13 +================== + + * add `err.view` property for view errors. Closes #1226 + * add "jsonp callback name" setting + * add support for "/foo/:bar*" non-greedy matches + * change `res.sendfile()` to use `send()` module + * change `res.send` to use "response-send" module + * remove `app.locals.use` and `res.locals.use`, use regular middleware + +3.0.0beta5 / 2012-07-03 +================== + + * add "make check" support + * add route-map example + * add `res.json(obj, status)` support back for BC + * add "methods" dep, remove internal methods module + * update connect dep + * update auth example to utilize cores pbkdf2 + * updated tests to use "supertest" + +3.0.0beta4 / 2012-06-25 +================== + + * Added `req.auth` + * Added `req.range(size)` + * Added `res.links(obj)` + * Added `res.send(body, status)` support back for backwards compat + * Added `.default()` support to `res.format()` + * Added 2xx / 304 check to `req.fresh` + * Revert "Added + support to the router" + * Fixed `res.send()` freshness check, respect res.statusCode + +3.0.0beta3 / 2012-06-15 +================== + + * Added hogan `--hjs` to express(1) [nullfirm] + * Added another example to content-negotiation + * Added `fresh` dep + * Changed: `res.send()` always checks freshness + * Fixed: expose connects mime module. Closes #1165 + +3.0.0beta2 / 2012-06-06 +================== + + * Added `+` support to the router + * Added `req.host` + * Changed `req.param()` to check route first + * Update connect dep + +3.0.0beta1 / 2012-06-01 +================== + + * Added `res.format()` callback to override default 406 behaviour + * Fixed `res.redirect()` 406. Closes #1154 + +3.0.0alpha5 / 2012-05-30 +================== + + * Added `req.ip` + * Added `{ signed: true }` option to `res.cookie()` + * Removed `res.signedCookie()` + * Changed: dont reverse `req.ips` + * Fixed "trust proxy" setting check for `req.ips` + +3.0.0alpha4 / 2012-05-09 +================== + + * Added: allow `[]` in jsonp callback. Closes #1128 + * Added `PORT` env var support in generated template. Closes #1118 [benatkin] + * Updated: connect 2.2.2 + +3.0.0alpha3 / 2012-05-04 +================== + + * Added public `app.routes`. Closes #887 + * Added _view-locals_ example + * Added _mvc_ example + * Added `res.locals.use()`. Closes #1120 + * Added conditional-GET support to `res.send()` + * Added: coerce `res.set()` values to strings + * Changed: moved `static()` in generated apps below router + * Changed: `res.send()` only set ETag when not previously set + * Changed connect 2.2.1 dep + * Changed: `make test` now runs unit / acceptance tests + * Fixed req/res proto inheritance + +3.0.0alpha2 / 2012-04-26 +================== + + * Added `make benchmark` back + * Added `res.send()` support for `String` objects + * Added client-side data exposing example + * Added `res.header()` and `req.header()` aliases for BC + * Added `express.createServer()` for BC + * Perf: memoize parsed urls + * Perf: connect 2.2.0 dep + * Changed: make `expressInit()` middleware self-aware + * Fixed: use app.get() for all core settings + * Fixed redis session example + * Fixed session example. Closes #1105 + * Fixed generated express dep. Closes #1078 + +3.0.0alpha1 / 2012-04-15 +================== + + * Added `app.locals.use(callback)` + * Added `app.locals` object + * Added `app.locals(obj)` + * Added `res.locals` object + * Added `res.locals(obj)` + * Added `res.format()` for content-negotiation + * Added `app.engine()` + * Added `res.cookie()` JSON cookie support + * Added "trust proxy" setting + * Added `req.subdomains` + * Added `req.protocol` + * Added `req.secure` + * Added `req.path` + * Added `req.ips` + * Added `req.fresh` + * Added `req.stale` + * Added comma-delimited / array support for `req.accepts()` + * Added debug instrumentation + * Added `res.set(obj)` + * Added `res.set(field, value)` + * Added `res.get(field)` + * Added `app.get(setting)`. Closes #842 + * Added `req.acceptsLanguage()` + * Added `req.acceptsCharset()` + * Added `req.accepted` + * Added `req.acceptedLanguages` + * Added `req.acceptedCharsets` + * Added "json replacer" setting + * Added "json spaces" setting + * Added X-Forwarded-Proto support to `res.redirect()`. Closes #92 + * Added `--less` support to express(1) + * Added `express.response` prototype + * Added `express.request` prototype + * Added `express.application` prototype + * Added `app.path()` + * Added `app.render()` + * Added `res.type()` to replace `res.contentType()` + * Changed: `res.redirect()` to add relative support + * Changed: enable "jsonp callback" by default + * Changed: renamed "case sensitive routes" to "case sensitive routing" + * Rewrite of all tests with mocha + * Removed "root" setting + * Removed `res.redirect('home')` support + * Removed `req.notify()` + * Removed `app.register()` + * Removed `app.redirect()` + * Removed `app.is()` + * Removed `app.helpers()` + * Removed `app.dynamicHelpers()` + * Fixed `res.sendfile()` with non-GET. Closes #723 + * Fixed express(1) public dir for windows. Closes #866 + +2.5.9/ 2012-04-02 +================== + + * Added support for PURGE request method [pbuyle] + * Fixed `express(1)` generated app `app.address()` before `listening` [mmalecki] + +2.5.8 / 2012-02-08 +================== + + * Update mkdirp dep. Closes #991 + +2.5.7 / 2012-02-06 +================== + + * Fixed `app.all` duplicate DELETE requests [mscdex] + +2.5.6 / 2012-01-13 +================== + + * Updated hamljs dev dep. Closes #953 + +2.5.5 / 2012-01-08 +================== + + * Fixed: set `filename` on cached templates [matthewleon] + +2.5.4 / 2012-01-02 +================== + + * Fixed `express(1)` eol on 0.4.x. Closes #947 + +2.5.3 / 2011-12-30 +================== + + * Fixed `req.is()` when a charset is present + +2.5.2 / 2011-12-10 +================== + + * Fixed: express(1) LF -> CRLF for windows + +2.5.1 / 2011-11-17 +================== + + * Changed: updated connect to 1.8.x + * Removed sass.js support from express(1) + +2.5.0 / 2011-10-24 +================== + + * Added ./routes dir for generated app by default + * Added npm install reminder to express(1) app gen + * Added 0.5.x support + * Removed `make test-cov` since it wont work with node 0.5.x + * Fixed express(1) public dir for windows. Closes #866 + +2.4.7 / 2011-10-05 +================== + + * Added mkdirp to express(1). Closes #795 + * Added simple _json-config_ example + * Added shorthand for the parsed request's pathname via `req.path` + * Changed connect dep to 1.7.x to fix npm issue... + * Fixed `res.redirect()` __HEAD__ support. [reported by xerox] + * Fixed `req.flash()`, only escape args + * Fixed absolute path checking on windows. Closes #829 [reported by andrewpmckenzie] + +2.4.6 / 2011-08-22 +================== + + * Fixed multiple param callback regression. Closes #824 [reported by TroyGoode] + +2.4.5 / 2011-08-19 +================== + + * Added support for routes to handle errors. Closes #809 + * Added `app.routes.all()`. Closes #803 + * Added "basepath" setting to work in conjunction with reverse proxies etc. + * Refactored `Route` to use a single array of callbacks + * Added support for multiple callbacks for `app.param()`. Closes #801 +Closes #805 + * Changed: removed .call(self) for route callbacks + * Dependency: `qs >= 0.3.1` + * Fixed `res.redirect()` on windows due to `join()` usage. Closes #808 + +2.4.4 / 2011-08-05 +================== + + * Fixed `res.header()` intention of a set, even when `undefined` + * Fixed `*`, value no longer required + * Fixed `res.send(204)` support. Closes #771 + +2.4.3 / 2011-07-14 +================== + + * Added docs for `status` option special-case. Closes #739 + * Fixed `options.filename`, exposing the view path to template engines + +2.4.2. / 2011-07-06 +================== + + * Revert "removed jsonp stripping" for XSS + +2.4.1 / 2011-07-06 +================== + + * Added `res.json()` JSONP support. Closes #737 + * Added _extending-templates_ example. Closes #730 + * Added "strict routing" setting for trailing slashes + * Added support for multiple envs in `app.configure()` calls. Closes #735 + * Changed: `res.send()` using `res.json()` + * Changed: when cookie `path === null` don't default it + * Changed; default cookie path to "home" setting. Closes #731 + * Removed _pids/logs_ creation from express(1) + +2.4.0 / 2011-06-28 +================== + + * Added chainable `res.status(code)` + * Added `res.json()`, an explicit version of `res.send(obj)` + * Added simple web-service example + +2.3.12 / 2011-06-22 +================== + + * \#express is now on freenode! come join! + * Added `req.get(field, param)` + * Added links to Japanese documentation, thanks @hideyukisaito! + * Added; the `express(1)` generated app outputs the env + * Added `content-negotiation` example + * Dependency: connect >= 1.5.1 < 2.0.0 + * Fixed view layout bug. Closes #720 + * Fixed; ignore body on 304. Closes #701 + +2.3.11 / 2011-06-04 +================== + + * Added `npm test` + * Removed generation of dummy test file from `express(1)` + * Fixed; `express(1)` adds express as a dep + * Fixed; prune on `prepublish` + +2.3.10 / 2011-05-27 +================== + + * Added `req.route`, exposing the current route + * Added _package.json_ generation support to `express(1)` + * Fixed call to `app.param()` function for optional params. Closes #682 + +2.3.9 / 2011-05-25 +================== + + * Fixed bug-ish with `../' in `res.partial()` calls + +2.3.8 / 2011-05-24 +================== + + * Fixed `app.options()` + +2.3.7 / 2011-05-23 +================== + + * Added route `Collection`, ex: `app.get('/user/:id').remove();` + * Added support for `app.param(fn)` to define param logic + * Removed `app.param()` support for callback with return value + * Removed module.parent check from express(1) generated app. Closes #670 + * Refactored router. Closes #639 + +2.3.6 / 2011-05-20 +================== + + * Changed; using devDependencies instead of git submodules + * Fixed redis session example + * Fixed markdown example + * Fixed view caching, should not be enabled in development + +2.3.5 / 2011-05-20 +================== + + * Added export `.view` as alias for `.View` + +2.3.4 / 2011-05-08 +================== + + * Added `./examples/say` + * Fixed `res.sendfile()` bug preventing the transfer of files with spaces + +2.3.3 / 2011-05-03 +================== + + * Added "case sensitive routes" option. + * Changed; split methods supported per rfc [slaskis] + * Fixed route-specific middleware when using the same callback function several times + +2.3.2 / 2011-04-27 +================== + + * Fixed view hints + +2.3.1 / 2011-04-26 +================== + + * Added `app.match()` as `app.match.all()` + * Added `app.lookup()` as `app.lookup.all()` + * Added `app.remove()` for `app.remove.all()` + * Added `app.remove.VERB()` + * Fixed template caching collision issue. Closes #644 + * Moved router over from connect and started refactor + +2.3.0 / 2011-04-25 +================== + + * Added options support to `res.clearCookie()` + * Added `res.helpers()` as alias of `res.locals()` + * Added; json defaults to UTF-8 with `res.send()`. Closes #632. [Daniel * Dependency `connect >= 1.4.0` + * Changed; auto set Content-Type in res.attachement [Aaron Heckmann] + * Renamed "cache views" to "view cache". Closes #628 + * Fixed caching of views when using several apps. Closes #637 + * Fixed gotcha invoking `app.param()` callbacks once per route middleware. +Closes #638 + * Fixed partial lookup precedence. Closes #631 +Shaw] + +2.2.2 / 2011-04-12 +================== + + * Added second callback support for `res.download()` connection errors + * Fixed `filename` option passing to template engine + +2.2.1 / 2011-04-04 +================== + + * Added `layout(path)` helper to change the layout within a view. Closes #610 + * Fixed `partial()` collection object support. + Previously only anything with `.length` would work. + When `.length` is present one must still be aware of holes, + however now `{ collection: {foo: 'bar'}}` is valid, exposes + `keyInCollection` and `keysInCollection`. + + * Performance improved with better view caching + * Removed `request` and `response` locals + * Changed; errorHandler page title is now `Express` instead of `Connect` + +2.2.0 / 2011-03-30 +================== + + * Added `app.lookup.VERB()`, ex `app.lookup.put('/user/:id')`. Closes #606 + * Added `app.match.VERB()`, ex `app.match.put('/user/12')`. Closes #606 + * Added `app.VERB(path)` as alias of `app.lookup.VERB()`. + * Dependency `connect >= 1.2.0` + +2.1.1 / 2011-03-29 +================== + + * Added; expose `err.view` object when failing to locate a view + * Fixed `res.partial()` call `next(err)` when no callback is given [reported by aheckmann] + * Fixed; `res.send(undefined)` responds with 204 [aheckmann] + +2.1.0 / 2011-03-24 +================== + + * Added `/_?` partial lookup support. Closes #447 + * Added `request`, `response`, and `app` local variables + * Added `settings` local variable, containing the app's settings + * Added `req.flash()` exception if `req.session` is not available + * Added `res.send(bool)` support (json response) + * Fixed stylus example for latest version + * Fixed; wrap try/catch around `res.render()` + +2.0.0 / 2011-03-17 +================== + + * Fixed up index view path alternative. + * Changed; `res.locals()` without object returns the locals + +2.0.0rc3 / 2011-03-17 +================== + + * Added `res.locals(obj)` to compliment `res.local(key, val)` + * Added `res.partial()` callback support + * Fixed recursive error reporting issue in `res.render()` + +2.0.0rc2 / 2011-03-17 +================== + + * Changed; `partial()` "locals" are now optional + * Fixed `SlowBuffer` support. Closes #584 [reported by tyrda01] + * Fixed .filename view engine option [reported by drudge] + * Fixed blog example + * Fixed `{req,res}.app` reference when mounting [Ben Weaver] + +2.0.0rc / 2011-03-14 +================== + + * Fixed; expose `HTTPSServer` constructor + * Fixed express(1) default test charset. Closes #579 [reported by secoif] + * Fixed; default charset to utf-8 instead of utf8 for lame IE [reported by NickP] + +2.0.0beta3 / 2011-03-09 +================== + + * Added support for `res.contentType()` literal + The original `res.contentType('.json')`, + `res.contentType('application/json')`, and `res.contentType('json')` + will work now. + * Added `res.render()` status option support back + * Added charset option for `res.render()` + * Added `.charset` support (via connect 1.0.4) + * Added view resolution hints when in development and a lookup fails + * Added layout lookup support relative to the page view. + For example while rendering `./views/user/index.jade` if you create + `./views/user/layout.jade` it will be used in favour of the root layout. + * Fixed `res.redirect()`. RFC states absolute url [reported by unlink] + * Fixed; default `res.send()` string charset to utf8 + * Removed `Partial` constructor (not currently used) + +2.0.0beta2 / 2011-03-07 +================== + + * Added res.render() `.locals` support back to aid in migration process + * Fixed flash example + +2.0.0beta / 2011-03-03 +================== + + * Added HTTPS support + * Added `res.cookie()` maxAge support + * Added `req.header()` _Referrer_ / _Referer_ special-case, either works + * Added mount support for `res.redirect()`, now respects the mount-point + * Added `union()` util, taking place of `merge(clone())` combo + * Added stylus support to express(1) generated app + * Added secret to session middleware used in examples and generated app + * Added `res.local(name, val)` for progressive view locals + * Added default param support to `req.param(name, default)` + * Added `app.disabled()` and `app.enabled()` + * Added `app.register()` support for omitting leading ".", either works + * Added `res.partial()`, using the same interface as `partial()` within a view. Closes #539 + * Added `app.param()` to map route params to async/sync logic + * Added; aliased `app.helpers()` as `app.locals()`. Closes #481 + * Added extname with no leading "." support to `res.contentType()` + * Added `cache views` setting, defaulting to enabled in "production" env + * Added index file partial resolution, eg: partial('user') may try _views/user/index.jade_. + * Added `req.accepts()` support for extensions + * Changed; `res.download()` and `res.sendfile()` now utilize Connect's + static file server `connect.static.send()`. + * Changed; replaced `connect.utils.mime()` with npm _mime_ module + * Changed; allow `req.query` to be pre-defined (via middleware or other parent + * Changed view partial resolution, now relative to parent view + * Changed view engine signature. no longer `engine.render(str, options, callback)`, now `engine.compile(str, options) -> Function`, the returned function accepts `fn(locals)`. + * Fixed `req.param()` bug returning Array.prototype methods. Closes #552 + * Fixed; using `Stream#pipe()` instead of `sys.pump()` in `res.sendfile()` + * Fixed; using _qs_ module instead of _querystring_ + * Fixed; strip unsafe chars from jsonp callbacks + * Removed "stream threshold" setting + +1.0.8 / 2011-03-01 +================== + + * Allow `req.query` to be pre-defined (via middleware or other parent app) + * "connect": ">= 0.5.0 < 1.0.0". Closes #547 + * Removed the long deprecated __EXPRESS_ENV__ support + +1.0.7 / 2011-02-07 +================== + + * Fixed `render()` setting inheritance. + Mounted apps would not inherit "view engine" + +1.0.6 / 2011-02-07 +================== + + * Fixed `view engine` setting bug when period is in dirname + +1.0.5 / 2011-02-05 +================== + + * Added secret to generated app `session()` call + +1.0.4 / 2011-02-05 +================== + + * Added `qs` dependency to _package.json_ + * Fixed namespaced `require()`s for latest connect support + +1.0.3 / 2011-01-13 +================== + + * Remove unsafe characters from JSONP callback names [Ryan Grove] + +1.0.2 / 2011-01-10 +================== + + * Removed nested require, using `connect.router` + +1.0.1 / 2010-12-29 +================== + + * Fixed for middleware stacked via `createServer()` + previously the `foo` middleware passed to `createServer(foo)` + would not have access to Express methods such as `res.send()` + or props like `req.query` etc. + +1.0.0 / 2010-11-16 +================== + + * Added; deduce partial object names from the last segment. + For example by default `partial('forum/post', postObject)` will + give you the _post_ object, providing a meaningful default. + * Added http status code string representation to `res.redirect()` body + * Added; `res.redirect()` supporting _text/plain_ and _text/html_ via __Accept__. + * Added `req.is()` to aid in content negotiation + * Added partial local inheritance [suggested by masylum]. Closes #102 + providing access to parent template locals. + * Added _-s, --session[s]_ flag to express(1) to add session related middleware + * Added _--template_ flag to express(1) to specify the + template engine to use. + * Added _--css_ flag to express(1) to specify the + stylesheet engine to use (or just plain css by default). + * Added `app.all()` support [thanks aheckmann] + * Added partial direct object support. + You may now `partial('user', user)` providing the "user" local, + vs previously `partial('user', { object: user })`. + * Added _route-separation_ example since many people question ways + to do this with CommonJS modules. Also view the _blog_ example for + an alternative. + * Performance; caching view path derived partial object names + * Fixed partial local inheritance precedence. [reported by Nick Poulden] Closes #454 + * Fixed jsonp support; _text/javascript_ as per mailinglist discussion + +1.0.0rc4 / 2010-10-14 +================== + + * Added _NODE_ENV_ support, _EXPRESS_ENV_ is deprecated and will be removed in 1.0.0 + * Added route-middleware support (very helpful, see the [docs](http://expressjs.com/guide.html#Route-Middleware)) + * Added _jsonp callback_ setting to enable/disable jsonp autowrapping [Dav Glass] + * Added callback query check on response.send to autowrap JSON objects for simple webservice implementations [Dav Glass] + * Added `partial()` support for array-like collections. Closes #434 + * Added support for swappable querystring parsers + * Added session usage docs. Closes #443 + * Added dynamic helper caching. Closes #439 [suggested by maritz] + * Added authentication example + * Added basic Range support to `res.sendfile()` (and `res.download()` etc) + * Changed; `express(1)` generated app using 2 spaces instead of 4 + * Default env to "development" again [aheckmann] + * Removed _context_ option is no more, use "scope" + * Fixed; exposing _./support_ libs to examples so they can run without installs + * Fixed mvc example + +1.0.0rc3 / 2010-09-20 +================== + + * Added confirmation for `express(1)` app generation. Closes #391 + * Added extending of flash formatters via `app.flashFormatters` + * Added flash formatter support. Closes #411 + * Added streaming support to `res.sendfile()` using `sys.pump()` when >= "stream threshold" + * Added _stream threshold_ setting for `res.sendfile()` + * Added `res.send()` __HEAD__ support + * Added `res.clearCookie()` + * Added `res.cookie()` + * Added `res.render()` headers option + * Added `res.redirect()` response bodies + * Added `res.render()` status option support. Closes #425 [thanks aheckmann] + * Fixed `res.sendfile()` responding with 403 on malicious path + * Fixed `res.download()` bug; when an error occurs remove _Content-Disposition_ + * Fixed; mounted apps settings now inherit from parent app [aheckmann] + * Fixed; stripping Content-Length / Content-Type when 204 + * Fixed `res.send()` 204. Closes #419 + * Fixed multiple _Set-Cookie_ headers via `res.header()`. Closes #402 + * Fixed bug messing with error handlers when `listenFD()` is called instead of `listen()`. [thanks guillermo] + + +1.0.0rc2 / 2010-08-17 +================== + + * Added `app.register()` for template engine mapping. Closes #390 + * Added `res.render()` callback support as second argument (no options) + * Added callback support to `res.download()` + * Added callback support for `res.sendfile()` + * Added support for middleware access via `express.middlewareName()` vs `connect.middlewareName()` + * Added "partials" setting to docs + * Added default expresso tests to `express(1)` generated app. Closes #384 + * Fixed `res.sendfile()` error handling, defer via `next()` + * Fixed `res.render()` callback when a layout is used [thanks guillermo] + * Fixed; `make install` creating ~/.node_libraries when not present + * Fixed issue preventing error handlers from being defined anywhere. Closes #387 + +1.0.0rc / 2010-07-28 +================== + + * Added mounted hook. Closes #369 + * Added connect dependency to _package.json_ + + * Removed "reload views" setting and support code + development env never caches, production always caches. + + * Removed _param_ in route callbacks, signature is now + simply (req, res, next), previously (req, res, params, next). + Use _req.params_ for path captures, _req.query_ for GET params. + + * Fixed "home" setting + * Fixed middleware/router precedence issue. Closes #366 + * Fixed; _configure()_ callbacks called immediately. Closes #368 + +1.0.0beta2 / 2010-07-23 +================== + + * Added more examples + * Added; exporting `Server` constructor + * Added `Server#helpers()` for view locals + * Added `Server#dynamicHelpers()` for dynamic view locals. Closes #349 + * Added support for absolute view paths + * Added; _home_ setting defaults to `Server#route` for mounted apps. Closes #363 + * Added Guillermo Rauch to the contributor list + * Added support for "as" for non-collection partials. Closes #341 + * Fixed _install.sh_, ensuring _~/.node_libraries_ exists. Closes #362 [thanks jf] + * Fixed `res.render()` exceptions, now passed to `next()` when no callback is given [thanks guillermo] + * Fixed instanceof `Array` checks, now `Array.isArray()` + * Fixed express(1) expansion of public dirs. Closes #348 + * Fixed middleware precedence. Closes #345 + * Fixed view watcher, now async [thanks aheckmann] + +1.0.0beta / 2010-07-15 +================== + + * Re-write + - much faster + - much lighter + - Check [ExpressJS.com](http://expressjs.com) for migration guide and updated docs + +0.14.0 / 2010-06-15 +================== + + * Utilize relative requires + * Added Static bufferSize option [aheckmann] + * Fixed caching of view and partial subdirectories [aheckmann] + * Fixed mime.type() comments now that ".ext" is not supported + * Updated haml submodule + * Updated class submodule + * Removed bin/express + +0.13.0 / 2010-06-01 +================== + + * Added node v0.1.97 compatibility + * Added support for deleting cookies via Request#cookie('key', null) + * Updated haml submodule + * Fixed not-found page, now using using charset utf-8 + * Fixed show-exceptions page, now using using charset utf-8 + * Fixed view support due to fs.readFile Buffers + * Changed; mime.type() no longer accepts ".type" due to node extname() changes + +0.12.0 / 2010-05-22 +================== + + * Added node v0.1.96 compatibility + * Added view `helpers` export which act as additional local variables + * Updated haml submodule + * Changed ETag; removed inode, modified time only + * Fixed LF to CRLF for setting multiple cookies + * Fixed cookie complation; values are now urlencoded + * Fixed cookies parsing; accepts quoted values and url escaped cookies + +0.11.0 / 2010-05-06 +================== + + * Added support for layouts using different engines + - this.render('page.html.haml', { layout: 'super-cool-layout.html.ejs' }) + - this.render('page.html.haml', { layout: 'foo' }) // assumes 'foo.html.haml' + - this.render('page.html.haml', { layout: false }) // no layout + * Updated ext submodule + * Updated haml submodule + * Fixed EJS partial support by passing along the context. Issue #307 + +0.10.1 / 2010-05-03 +================== + + * Fixed binary uploads. + +0.10.0 / 2010-04-30 +================== + + * Added charset support via Request#charset (automatically assigned to 'UTF-8' when respond()'s + encoding is set to 'utf8' or 'utf-8'. + * Added "encoding" option to Request#render(). Closes #299 + * Added "dump exceptions" setting, which is enabled by default. + * Added simple ejs template engine support + * Added error response support for text/plain, application/json. Closes #297 + * Added callback function param to Request#error() + * Added Request#sendHead() + * Added Request#stream() + * Added support for Request#respond(304, null) for empty response bodies + * Added ETag support to Request#sendfile() + * Added options to Request#sendfile(), passed to fs.createReadStream() + * Added filename arg to Request#download() + * Performance enhanced due to pre-reversing plugins so that plugins.reverse() is not called on each request + * Performance enhanced by preventing several calls to toLowerCase() in Router#match() + * Changed; Request#sendfile() now streams + * Changed; Renamed Request#halt() to Request#respond(). Closes #289 + * Changed; Using sys.inspect() instead of JSON.encode() for error output + * Changed; run() returns the http.Server instance. Closes #298 + * Changed; Defaulting Server#host to null (INADDR_ANY) + * Changed; Logger "common" format scale of 0.4f + * Removed Logger "request" format + * Fixed; Catching ENOENT in view caching, preventing error when "views/partials" is not found + * Fixed several issues with http client + * Fixed Logger Content-Length output + * Fixed bug preventing Opera from retaining the generated session id. Closes #292 + +0.9.0 / 2010-04-14 +================== + + * Added DSL level error() route support + * Added DSL level notFound() route support + * Added Request#error() + * Added Request#notFound() + * Added Request#render() callback function. Closes #258 + * Added "max upload size" setting + * Added "magic" variables to collection partials (\_\_index\_\_, \_\_length\_\_, \_\_isFirst\_\_, \_\_isLast\_\_). Closes #254 + * Added [haml.js](http://github.com/visionmedia/haml.js) submodule; removed haml-js + * Added callback function support to Request#halt() as 3rd/4th arg + * Added preprocessing of route param wildcards using param(). Closes #251 + * Added view partial support (with collections etc) + * Fixed bug preventing falsey params (such as ?page=0). Closes #286 + * Fixed setting of multiple cookies. Closes #199 + * Changed; view naming convention is now NAME.TYPE.ENGINE (for example page.html.haml) + * Changed; session cookie is now httpOnly + * Changed; Request is no longer global + * Changed; Event is no longer global + * Changed; "sys" module is no longer global + * Changed; moved Request#download to Static plugin where it belongs + * Changed; Request instance created before body parsing. Closes #262 + * Changed; Pre-caching views in memory when "cache view contents" is enabled. Closes #253 + * Changed; Pre-caching view partials in memory when "cache view partials" is enabled + * Updated support to node --version 0.1.90 + * Updated dependencies + * Removed set("session cookie") in favour of use(Session, { cookie: { ... }}) + * Removed utils.mixin(); use Object#mergeDeep() + +0.8.0 / 2010-03-19 +================== + + * Added coffeescript example app. Closes #242 + * Changed; cache api now async friendly. Closes #240 + * Removed deprecated 'express/static' support. Use 'express/plugins/static' + +0.7.6 / 2010-03-19 +================== + + * Added Request#isXHR. Closes #229 + * Added `make install` (for the executable) + * Added `express` executable for setting up simple app templates + * Added "GET /public/*" to Static plugin, defaulting to /public + * Added Static plugin + * Fixed; Request#render() only calls cache.get() once + * Fixed; Namespacing View caches with "view:" + * Fixed; Namespacing Static caches with "static:" + * Fixed; Both example apps now use the Static plugin + * Fixed set("views"). Closes #239 + * Fixed missing space for combined log format + * Deprecated Request#sendfile() and 'express/static' + * Removed Server#running + +0.7.5 / 2010-03-16 +================== + + * Added Request#flash() support without args, now returns all flashes + * Updated ext submodule + +0.7.4 / 2010-03-16 +================== + + * Fixed session reaper + * Changed; class.js replacing js-oo Class implementation (quite a bit faster, no browser cruft) + +0.7.3 / 2010-03-16 +================== + + * Added package.json + * Fixed requiring of haml / sass due to kiwi removal + +0.7.2 / 2010-03-16 +================== + + * Fixed GIT submodules (HAH!) + +0.7.1 / 2010-03-16 +================== + + * Changed; Express now using submodules again until a PM is adopted + * Changed; chat example using millisecond conversions from ext + +0.7.0 / 2010-03-15 +================== + + * Added Request#pass() support (finds the next matching route, or the given path) + * Added Logger plugin (default "common" format replaces CommonLogger) + * Removed Profiler plugin + * Removed CommonLogger plugin + +0.6.0 / 2010-03-11 +================== + + * Added seed.yml for kiwi package management support + * Added HTTP client query string support when method is GET. Closes #205 + + * Added support for arbitrary view engines. + For example "foo.engine.html" will now require('engine'), + the exports from this module are cached after the first require(). + + * Added async plugin support + + * Removed usage of RESTful route funcs as http client + get() etc, use http.get() and friends + + * Removed custom exceptions + +0.5.0 / 2010-03-10 +================== + + * Added ext dependency (library of js extensions) + * Removed extname() / basename() utils. Use path module + * Removed toArray() util. Use arguments.values + * Removed escapeRegexp() util. Use RegExp.escape() + * Removed process.mixin() dependency. Use utils.mixin() + * Removed Collection + * Removed ElementCollection + * Shameless self promotion of ebook "Advanced JavaScript" (http://dev-mag.com) ;) + +0.4.0 / 2010-02-11 +================== + + * Added flash() example to sample upload app + * Added high level restful http client module (express/http) + * Changed; RESTful route functions double as HTTP clients. Closes #69 + * Changed; throwing error when routes are added at runtime + * Changed; defaulting render() context to the current Request. Closes #197 + * Updated haml submodule + +0.3.0 / 2010-02-11 +================== + + * Updated haml / sass submodules. Closes #200 + * Added flash message support. Closes #64 + * Added accepts() now allows multiple args. fixes #117 + * Added support for plugins to halt. Closes #189 + * Added alternate layout support. Closes #119 + * Removed Route#run(). Closes #188 + * Fixed broken specs due to use(Cookie) missing + +0.2.1 / 2010-02-05 +================== + + * Added "plot" format option for Profiler (for gnuplot processing) + * Added request number to Profiler plugin + * Fixed binary encoding for multi-part file uploads, was previously defaulting to UTF8 + * Fixed issue with routes not firing when not files are present. Closes #184 + * Fixed process.Promise -> events.Promise + +0.2.0 / 2010-02-03 +================== + + * Added parseParam() support for name[] etc. (allows for file inputs with "multiple" attr) Closes #180 + * Added Both Cache and Session option "reapInterval" may be "reapEvery". Closes #174 + * Added expiration support to cache api with reaper. Closes #133 + * Added cache Store.Memory#reap() + * Added Cache; cache api now uses first class Cache instances + * Added abstract session Store. Closes #172 + * Changed; cache Memory.Store#get() utilizing Collection + * Renamed MemoryStore -> Store.Memory + * Fixed use() of the same plugin several time will always use latest options. Closes #176 + +0.1.0 / 2010-02-03 +================== + + * Changed; Hooks (before / after) pass request as arg as well as evaluated in their context + * Updated node support to 0.1.27 Closes #169 + * Updated dirname(__filename) -> __dirname + * Updated libxmljs support to v0.2.0 + * Added session support with memory store / reaping + * Added quick uid() helper + * Added multi-part upload support + * Added Sass.js support / submodule + * Added production env caching view contents and static files + * Added static file caching. Closes #136 + * Added cache plugin with memory stores + * Added support to StaticFile so that it works with non-textual files. + * Removed dirname() helper + * Removed several globals (now their modules must be required) + +0.0.2 / 2010-01-10 +================== + + * Added view benchmarks; currently haml vs ejs + * Added Request#attachment() specs. Closes #116 + * Added use of node's parseQuery() util. Closes #123 + * Added `make init` for submodules + * Updated Haml + * Updated sample chat app to show messages on load + * Updated libxmljs parseString -> parseHtmlString + * Fixed `make init` to work with older versions of git + * Fixed specs can now run independent specs for those who cant build deps. Closes #127 + * Fixed issues introduced by the node url module changes. Closes 126. + * Fixed two assertions failing due to Collection#keys() returning strings + * Fixed faulty Collection#toArray() spec due to keys() returning strings + * Fixed `make test` now builds libxmljs.node before testing + +0.0.1 / 2010-01-03 +================== + + * Initial release diff --git a/node_modules/express/LICENSE b/node_modules/express/LICENSE new file mode 100644 index 0000000..aa927e4 --- /dev/null +++ b/node_modules/express/LICENSE @@ -0,0 +1,24 @@ +(The MIT License) + +Copyright (c) 2009-2014 TJ Holowaychuk +Copyright (c) 2013-2014 Roman Shtylman +Copyright (c) 2014-2015 Douglas Christopher Wilson + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/express/Readme.md b/node_modules/express/Readme.md new file mode 100644 index 0000000..e9bfaeb --- /dev/null +++ b/node_modules/express/Readme.md @@ -0,0 +1,142 @@ +[![Express Logo](https://i.cloudup.com/zfY6lL7eFa-3000x3000.png)](http://expressjs.com/) + + Fast, unopinionated, minimalist web framework for [node](http://nodejs.org). + + [![NPM Version][npm-image]][npm-url] + [![NPM Downloads][downloads-image]][downloads-url] + [![Linux Build][travis-image]][travis-url] + [![Windows Build][appveyor-image]][appveyor-url] + [![Test Coverage][coveralls-image]][coveralls-url] + +```js +var express = require('express') +var app = express() + +app.get('/', function (req, res) { + res.send('Hello World') +}) + +app.listen(3000) +``` + +## Installation + +```bash +$ npm install express +``` + +## Features + + * Robust routing + * Focus on high performance + * Super-high test coverage + * HTTP helpers (redirection, caching, etc) + * View system supporting 14+ template engines + * Content negotiation + * Executable for generating applications quickly + +## Docs & Community + + * [Website and Documentation](http://expressjs.com/) - [[website repo](https://github.com/strongloop/expressjs.com)] + * [#express](https://webchat.freenode.net/?channels=express) on freenode IRC + * [Github Organization](https://github.com/expressjs) for Official Middleware & Modules + * Visit the [Wiki](https://github.com/expressjs/express/wiki) + * [Google Group](https://groups.google.com/group/express-js) for discussion + * [Gitter](https://gitter.im/expressjs/express) for support and discussion + * [Русскоязычная документация](http://jsman.ru/express/) + +**PROTIP** Be sure to read [Migrating from 3.x to 4.x](https://github.com/expressjs/express/wiki/Migrating-from-3.x-to-4.x) as well as [New features in 4.x](https://github.com/expressjs/express/wiki/New-features-in-4.x). + +###Security Issues + +If you discover a security vulnerability in Express, please see [Security Policies and Procedures](Security.md). + +## Quick Start + + The quickest way to get started with express is to utilize the executable [`express(1)`](https://github.com/expressjs/generator) to generate an application as shown below: + + Install the executable. The executable's major version will match Express's: + +```bash +$ npm install -g express-generator@4 +``` + + Create the app: + +```bash +$ express /tmp/foo && cd /tmp/foo +``` + + Install dependencies: + +```bash +$ npm install +``` + + Start the server: + +```bash +$ npm start +``` + +## Philosophy + + The Express philosophy is to provide small, robust tooling for HTTP servers, making + it a great solution for single page applications, web sites, hybrids, or public + HTTP APIs. + + Express does not force you to use any specific ORM or template engine. With support for over + 14 template engines via [Consolidate.js](https://github.com/tj/consolidate.js), + you can quickly craft your perfect framework. + +## Examples + + To view the examples, clone the Express repo and install the dependencies: + +```bash +$ git clone git://github.com/expressjs/express.git --depth 1 +$ cd express +$ npm install +``` + + Then run whichever example you want: + +```bash +$ node examples/content-negotiation +``` + +## Tests + + To run the test suite, first install the dependencies, then run `npm test`: + +```bash +$ npm install +$ npm test +``` + +## People + +The original author of Express is [TJ Holowaychuk](https://github.com/tj) [![TJ's Gratipay][gratipay-image-visionmedia]][gratipay-url-visionmedia] + +The current lead maintainer is [Douglas Christopher Wilson](https://github.com/dougwilson) [![Doug's Gratipay][gratipay-image-dougwilson]][gratipay-url-dougwilson] + +[List of all contributors](https://github.com/expressjs/express/graphs/contributors) + +## License + + [MIT](LICENSE) + +[npm-image]: https://img.shields.io/npm/v/express.svg +[npm-url]: https://npmjs.org/package/express +[downloads-image]: https://img.shields.io/npm/dm/express.svg +[downloads-url]: https://npmjs.org/package/express +[travis-image]: https://img.shields.io/travis/expressjs/express/master.svg?label=linux +[travis-url]: https://travis-ci.org/expressjs/express +[appveyor-image]: https://img.shields.io/appveyor/ci/dougwilson/express/master.svg?label=windows +[appveyor-url]: https://ci.appveyor.com/project/dougwilson/express +[coveralls-image]: https://img.shields.io/coveralls/expressjs/express/master.svg +[coveralls-url]: https://coveralls.io/r/expressjs/express?branch=master +[gratipay-image-visionmedia]: https://img.shields.io/gratipay/visionmedia.svg +[gratipay-url-visionmedia]: https://gratipay.com/visionmedia/ +[gratipay-image-dougwilson]: https://img.shields.io/gratipay/dougwilson.svg +[gratipay-url-dougwilson]: https://gratipay.com/dougwilson/ diff --git a/node_modules/express/index.js b/node_modules/express/index.js new file mode 100644 index 0000000..d219b0c --- /dev/null +++ b/node_modules/express/index.js @@ -0,0 +1,11 @@ +/*! + * express + * Copyright(c) 2009-2013 TJ Holowaychuk + * Copyright(c) 2013 Roman Shtylman + * Copyright(c) 2014-2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict'; + +module.exports = require('./lib/express'); diff --git a/node_modules/express/lib/application.js b/node_modules/express/lib/application.js new file mode 100644 index 0000000..0ee4def --- /dev/null +++ b/node_modules/express/lib/application.js @@ -0,0 +1,643 @@ +/*! + * express + * Copyright(c) 2009-2013 TJ Holowaychuk + * Copyright(c) 2013 Roman Shtylman + * Copyright(c) 2014-2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict'; + +/** + * Module dependencies. + * @private + */ + +var finalhandler = require('finalhandler'); +var Router = require('./router'); +var methods = require('methods'); +var middleware = require('./middleware/init'); +var query = require('./middleware/query'); +var debug = require('debug')('express:application'); +var View = require('./view'); +var http = require('http'); +var compileETag = require('./utils').compileETag; +var compileQueryParser = require('./utils').compileQueryParser; +var compileTrust = require('./utils').compileTrust; +var deprecate = require('depd')('express'); +var flatten = require('array-flatten'); +var merge = require('utils-merge'); +var resolve = require('path').resolve; +var slice = Array.prototype.slice; + +/** + * Application prototype. + */ + +var app = exports = module.exports = {}; + +/** + * Variable for trust proxy inheritance back-compat + * @private + */ + +var trustProxyDefaultSymbol = '@@symbol:trust_proxy_default'; + +/** + * Initialize the server. + * + * - setup default configuration + * - setup default middleware + * - setup route reflection methods + * + * @private + */ + +app.init = function init() { + this.cache = {}; + this.engines = {}; + this.settings = {}; + + this.defaultConfiguration(); +}; + +/** + * Initialize application configuration. + * @private + */ + +app.defaultConfiguration = function defaultConfiguration() { + var env = process.env.NODE_ENV || 'development'; + + // default settings + this.enable('x-powered-by'); + this.set('etag', 'weak'); + this.set('env', env); + this.set('query parser', 'extended'); + this.set('subdomain offset', 2); + this.set('trust proxy', false); + + // trust proxy inherit back-compat + Object.defineProperty(this.settings, trustProxyDefaultSymbol, { + configurable: true, + value: true + }); + + debug('booting in %s mode', env); + + this.on('mount', function onmount(parent) { + // inherit trust proxy + if (this.settings[trustProxyDefaultSymbol] === true + && typeof parent.settings['trust proxy fn'] === 'function') { + delete this.settings['trust proxy']; + delete this.settings['trust proxy fn']; + } + + // inherit protos + this.request.__proto__ = parent.request; + this.response.__proto__ = parent.response; + this.engines.__proto__ = parent.engines; + this.settings.__proto__ = parent.settings; + }); + + // setup locals + this.locals = Object.create(null); + + // top-most app is mounted at / + this.mountpath = '/'; + + // default locals + this.locals.settings = this.settings; + + // default configuration + this.set('view', View); + this.set('views', resolve('views')); + this.set('jsonp callback name', 'callback'); + + if (env === 'production') { + this.enable('view cache'); + } + + Object.defineProperty(this, 'router', { + get: function() { + throw new Error('\'app.router\' is deprecated!\nPlease see the 3.x to 4.x migration guide for details on how to update your app.'); + } + }); +}; + +/** + * lazily adds the base router if it has not yet been added. + * + * We cannot add the base router in the defaultConfiguration because + * it reads app settings which might be set after that has run. + * + * @private + */ +app.lazyrouter = function lazyrouter() { + if (!this._router) { + this._router = new Router({ + caseSensitive: this.enabled('case sensitive routing'), + strict: this.enabled('strict routing') + }); + + this._router.use(query(this.get('query parser fn'))); + this._router.use(middleware.init(this)); + } +}; + +/** + * Dispatch a req, res pair into the application. Starts pipeline processing. + * + * If no callback is provided, then default error handlers will respond + * in the event of an error bubbling through the stack. + * + * @private + */ + +app.handle = function handle(req, res, callback) { + var router = this._router; + + // final handler + var done = callback || finalhandler(req, res, { + env: this.get('env'), + onerror: logerror.bind(this) + }); + + // no routes + if (!router) { + debug('no routes defined on app'); + done(); + return; + } + + router.handle(req, res, done); +}; + +/** + * Proxy `Router#use()` to add middleware to the app router. + * See Router#use() documentation for details. + * + * If the _fn_ parameter is an express app, then it will be + * mounted at the _route_ specified. + * + * @public + */ + +app.use = function use(fn) { + var offset = 0; + var path = '/'; + + // default path to '/' + // disambiguate app.use([fn]) + if (typeof fn !== 'function') { + var arg = fn; + + while (Array.isArray(arg) && arg.length !== 0) { + arg = arg[0]; + } + + // first arg is the path + if (typeof arg !== 'function') { + offset = 1; + path = fn; + } + } + + var fns = flatten(slice.call(arguments, offset)); + + if (fns.length === 0) { + throw new TypeError('app.use() requires middleware functions'); + } + + // setup router + this.lazyrouter(); + var router = this._router; + + fns.forEach(function (fn) { + // non-express app + if (!fn || !fn.handle || !fn.set) { + return router.use(path, fn); + } + + debug('.use app under %s', path); + fn.mountpath = path; + fn.parent = this; + + // restore .app property on req and res + router.use(path, function mounted_app(req, res, next) { + var orig = req.app; + fn.handle(req, res, function (err) { + req.__proto__ = orig.request; + res.__proto__ = orig.response; + next(err); + }); + }); + + // mounted an app + fn.emit('mount', this); + }, this); + + return this; +}; + +/** + * Proxy to the app `Router#route()` + * Returns a new `Route` instance for the _path_. + * + * Routes are isolated middleware stacks for specific paths. + * See the Route api docs for details. + * + * @public + */ + +app.route = function route(path) { + this.lazyrouter(); + return this._router.route(path); +}; + +/** + * Register the given template engine callback `fn` + * as `ext`. + * + * By default will `require()` the engine based on the + * file extension. For example if you try to render + * a "foo.jade" file Express will invoke the following internally: + * + * app.engine('jade', require('jade').__express); + * + * For engines that do not provide `.__express` out of the box, + * or if you wish to "map" a different extension to the template engine + * you may use this method. For example mapping the EJS template engine to + * ".html" files: + * + * app.engine('html', require('ejs').renderFile); + * + * In this case EJS provides a `.renderFile()` method with + * the same signature that Express expects: `(path, options, callback)`, + * though note that it aliases this method as `ejs.__express` internally + * so if you're using ".ejs" extensions you dont need to do anything. + * + * Some template engines do not follow this convention, the + * [Consolidate.js](https://github.com/tj/consolidate.js) + * library was created to map all of node's popular template + * engines to follow this convention, thus allowing them to + * work seamlessly within Express. + * + * @param {String} ext + * @param {Function} fn + * @return {app} for chaining + * @public + */ + +app.engine = function engine(ext, fn) { + if (typeof fn !== 'function') { + throw new Error('callback function required'); + } + + // get file extension + var extension = ext[0] !== '.' + ? '.' + ext + : ext; + + // store engine + this.engines[extension] = fn; + + return this; +}; + +/** + * Proxy to `Router#param()` with one added api feature. The _name_ parameter + * can be an array of names. + * + * See the Router#param() docs for more details. + * + * @param {String|Array} name + * @param {Function} fn + * @return {app} for chaining + * @public + */ + +app.param = function param(name, fn) { + this.lazyrouter(); + + if (Array.isArray(name)) { + for (var i = 0; i < name.length; i++) { + this.param(name[i], fn); + } + + return this; + } + + this._router.param(name, fn); + + return this; +}; + +/** + * Assign `setting` to `val`, or return `setting`'s value. + * + * app.set('foo', 'bar'); + * app.get('foo'); + * // => "bar" + * + * Mounted servers inherit their parent server's settings. + * + * @param {String} setting + * @param {*} [val] + * @return {Server} for chaining + * @public + */ + +app.set = function set(setting, val) { + if (arguments.length === 1) { + // app.get(setting) + return this.settings[setting]; + } + + debug('set "%s" to %o', setting, val); + + // set value + this.settings[setting] = val; + + // trigger matched settings + switch (setting) { + case 'etag': + this.set('etag fn', compileETag(val)); + break; + case 'query parser': + this.set('query parser fn', compileQueryParser(val)); + break; + case 'trust proxy': + this.set('trust proxy fn', compileTrust(val)); + + // trust proxy inherit back-compat + Object.defineProperty(this.settings, trustProxyDefaultSymbol, { + configurable: true, + value: false + }); + + break; + } + + return this; +}; + +/** + * Return the app's absolute pathname + * based on the parent(s) that have + * mounted it. + * + * For example if the application was + * mounted as "/admin", which itself + * was mounted as "/blog" then the + * return value would be "/blog/admin". + * + * @return {String} + * @private + */ + +app.path = function path() { + return this.parent + ? this.parent.path() + this.mountpath + : ''; +}; + +/** + * Check if `setting` is enabled (truthy). + * + * app.enabled('foo') + * // => false + * + * app.enable('foo') + * app.enabled('foo') + * // => true + * + * @param {String} setting + * @return {Boolean} + * @public + */ + +app.enabled = function enabled(setting) { + return Boolean(this.set(setting)); +}; + +/** + * Check if `setting` is disabled. + * + * app.disabled('foo') + * // => true + * + * app.enable('foo') + * app.disabled('foo') + * // => false + * + * @param {String} setting + * @return {Boolean} + * @public + */ + +app.disabled = function disabled(setting) { + return !this.set(setting); +}; + +/** + * Enable `setting`. + * + * @param {String} setting + * @return {app} for chaining + * @public + */ + +app.enable = function enable(setting) { + return this.set(setting, true); +}; + +/** + * Disable `setting`. + * + * @param {String} setting + * @return {app} for chaining + * @public + */ + +app.disable = function disable(setting) { + return this.set(setting, false); +}; + +/** + * Delegate `.VERB(...)` calls to `router.VERB(...)`. + */ + +methods.forEach(function(method){ + app[method] = function(path){ + if (method === 'get' && arguments.length === 1) { + // app.get(setting) + return this.set(path); + } + + this.lazyrouter(); + + var route = this._router.route(path); + route[method].apply(route, slice.call(arguments, 1)); + return this; + }; +}); + +/** + * Special-cased "all" method, applying the given route `path`, + * middleware, and callback to _every_ HTTP method. + * + * @param {String} path + * @param {Function} ... + * @return {app} for chaining + * @public + */ + +app.all = function all(path) { + this.lazyrouter(); + + var route = this._router.route(path); + var args = slice.call(arguments, 1); + + for (var i = 0; i < methods.length; i++) { + route[methods[i]].apply(route, args); + } + + return this; +}; + +// del -> delete alias + +app.del = deprecate.function(app.delete, 'app.del: Use app.delete instead'); + +/** + * Render the given view `name` name with `options` + * and a callback accepting an error and the + * rendered template string. + * + * Example: + * + * app.render('email', { name: 'Tobi' }, function(err, html){ + * // ... + * }) + * + * @param {String} name + * @param {Object|Function} options or fn + * @param {Function} callback + * @public + */ + +app.render = function render(name, options, callback) { + var cache = this.cache; + var done = callback; + var engines = this.engines; + var opts = options; + var renderOptions = {}; + var view; + + // support callback function as second arg + if (typeof options === 'function') { + done = options; + opts = {}; + } + + // merge app.locals + merge(renderOptions, this.locals); + + // merge options._locals + if (opts._locals) { + merge(renderOptions, opts._locals); + } + + // merge options + merge(renderOptions, opts); + + // set .cache unless explicitly provided + if (renderOptions.cache == null) { + renderOptions.cache = this.enabled('view cache'); + } + + // primed cache + if (renderOptions.cache) { + view = cache[name]; + } + + // view + if (!view) { + var View = this.get('view'); + + view = new View(name, { + defaultEngine: this.get('view engine'), + root: this.get('views'), + engines: engines + }); + + if (!view.path) { + var dirs = Array.isArray(view.root) && view.root.length > 1 + ? 'directories "' + view.root.slice(0, -1).join('", "') + '" or "' + view.root[view.root.length - 1] + '"' + : 'directory "' + view.root + '"' + var err = new Error('Failed to lookup view "' + name + '" in views ' + dirs); + err.view = view; + return done(err); + } + + // prime the cache + if (renderOptions.cache) { + cache[name] = view; + } + } + + // render + tryRender(view, renderOptions, done); +}; + +/** + * Listen for connections. + * + * A node `http.Server` is returned, with this + * application (which is a `Function`) as its + * callback. If you wish to create both an HTTP + * and HTTPS server you may do so with the "http" + * and "https" modules as shown here: + * + * var http = require('http') + * , https = require('https') + * , express = require('express') + * , app = express(); + * + * http.createServer(app).listen(80); + * https.createServer({ ... }, app).listen(443); + * + * @return {http.Server} + * @public + */ + +app.listen = function listen() { + var server = http.createServer(this); + return server.listen.apply(server, arguments); +}; + +/** + * Log error using console.error. + * + * @param {Error} err + * @private + */ + +function logerror(err) { + /* istanbul ignore next */ + if (this.get('env') !== 'test') console.error(err.stack || err.toString()); +} + +/** + * Try rendering a view. + * @private + */ + +function tryRender(view, options, callback) { + try { + view.render(options, callback); + } catch (err) { + callback(err); + } +} diff --git a/node_modules/express/lib/express.js b/node_modules/express/lib/express.js new file mode 100644 index 0000000..540c8be --- /dev/null +++ b/node_modules/express/lib/express.js @@ -0,0 +1,103 @@ +/*! + * express + * Copyright(c) 2009-2013 TJ Holowaychuk + * Copyright(c) 2013 Roman Shtylman + * Copyright(c) 2014-2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict'; + +/** + * Module dependencies. + */ + +var EventEmitter = require('events').EventEmitter; +var mixin = require('merge-descriptors'); +var proto = require('./application'); +var Route = require('./router/route'); +var Router = require('./router'); +var req = require('./request'); +var res = require('./response'); + +/** + * Expose `createApplication()`. + */ + +exports = module.exports = createApplication; + +/** + * Create an express application. + * + * @return {Function} + * @api public + */ + +function createApplication() { + var app = function(req, res, next) { + app.handle(req, res, next); + }; + + mixin(app, EventEmitter.prototype, false); + mixin(app, proto, false); + + app.request = { __proto__: req, app: app }; + app.response = { __proto__: res, app: app }; + app.init(); + return app; +} + +/** + * Expose the prototypes. + */ + +exports.application = proto; +exports.request = req; +exports.response = res; + +/** + * Expose constructors. + */ + +exports.Route = Route; +exports.Router = Router; + +/** + * Expose middleware + */ + +exports.query = require('./middleware/query'); +exports.static = require('serve-static'); + +/** + * Replace removed middleware with an appropriate error message. + */ + +[ + 'json', + 'urlencoded', + 'bodyParser', + 'compress', + 'cookieSession', + 'session', + 'logger', + 'cookieParser', + 'favicon', + 'responseTime', + 'errorHandler', + 'timeout', + 'methodOverride', + 'vhost', + 'csrf', + 'directory', + 'limit', + 'multipart', + 'staticCache', +].forEach(function (name) { + Object.defineProperty(exports, name, { + get: function () { + throw new Error('Most middleware (like ' + name + ') is no longer bundled with Express and must be installed separately. Please see https://github.com/senchalabs/connect#middleware.'); + }, + configurable: true + }); +}); diff --git a/node_modules/express/lib/middleware/init.js b/node_modules/express/lib/middleware/init.js new file mode 100644 index 0000000..f3119ed --- /dev/null +++ b/node_modules/express/lib/middleware/init.js @@ -0,0 +1,36 @@ +/*! + * express + * Copyright(c) 2009-2013 TJ Holowaychuk + * Copyright(c) 2013 Roman Shtylman + * Copyright(c) 2014-2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict'; + +/** + * Initialization middleware, exposing the + * request and response to each other, as well + * as defaulting the X-Powered-By header field. + * + * @param {Function} app + * @return {Function} + * @api private + */ + +exports.init = function(app){ + return function expressInit(req, res, next){ + if (app.enabled('x-powered-by')) res.setHeader('X-Powered-By', 'Express'); + req.res = res; + res.req = req; + req.next = next; + + req.__proto__ = app.request; + res.__proto__ = app.response; + + res.locals = res.locals || Object.create(null); + + next(); + }; +}; + diff --git a/node_modules/express/lib/middleware/query.js b/node_modules/express/lib/middleware/query.js new file mode 100644 index 0000000..5f76f84 --- /dev/null +++ b/node_modules/express/lib/middleware/query.js @@ -0,0 +1,46 @@ +/*! + * express + * Copyright(c) 2009-2013 TJ Holowaychuk + * Copyright(c) 2013 Roman Shtylman + * Copyright(c) 2014-2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict'; + +/** + * Module dependencies. + */ + +var parseUrl = require('parseurl'); +var qs = require('qs'); + +/** + * @param {Object} options + * @return {Function} + * @api public + */ + +module.exports = function query(options) { + var opts = Object.create(options || null); + var queryparse = qs.parse; + + if (typeof options === 'function') { + queryparse = options; + opts = undefined; + } + + if (opts !== undefined && opts.allowPrototypes === undefined) { + // back-compat for qs module + opts.allowPrototypes = true; + } + + return function query(req, res, next){ + if (!req.query) { + var val = parseUrl(req).query; + req.query = queryparse(val, opts); + } + + next(); + }; +}; diff --git a/node_modules/express/lib/request.js b/node_modules/express/lib/request.js new file mode 100644 index 0000000..557d050 --- /dev/null +++ b/node_modules/express/lib/request.js @@ -0,0 +1,502 @@ +/*! + * express + * Copyright(c) 2009-2013 TJ Holowaychuk + * Copyright(c) 2013 Roman Shtylman + * Copyright(c) 2014-2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict'; + +/** + * Module dependencies. + * @private + */ + +var accepts = require('accepts'); +var deprecate = require('depd')('express'); +var isIP = require('net').isIP; +var typeis = require('type-is'); +var http = require('http'); +var fresh = require('fresh'); +var parseRange = require('range-parser'); +var parse = require('parseurl'); +var proxyaddr = require('proxy-addr'); + +/** + * Request prototype. + */ + +var req = exports = module.exports = { + __proto__: http.IncomingMessage.prototype +}; + +/** + * Return request header. + * + * The `Referrer` header field is special-cased, + * both `Referrer` and `Referer` are interchangeable. + * + * Examples: + * + * req.get('Content-Type'); + * // => "text/plain" + * + * req.get('content-type'); + * // => "text/plain" + * + * req.get('Something'); + * // => undefined + * + * Aliased as `req.header()`. + * + * @param {String} name + * @return {String} + * @public + */ + +req.get = +req.header = function header(name) { + if (!name) { + throw new TypeError('name argument is required to req.get'); + } + + if (typeof name !== 'string') { + throw new TypeError('name must be a string to req.get'); + } + + var lc = name.toLowerCase(); + + switch (lc) { + case 'referer': + case 'referrer': + return this.headers.referrer + || this.headers.referer; + default: + return this.headers[lc]; + } +}; + +/** + * To do: update docs. + * + * Check if the given `type(s)` is acceptable, returning + * the best match when true, otherwise `undefined`, in which + * case you should respond with 406 "Not Acceptable". + * + * The `type` value may be a single MIME type string + * such as "application/json", an extension name + * such as "json", a comma-delimited list such as "json, html, text/plain", + * an argument list such as `"json", "html", "text/plain"`, + * or an array `["json", "html", "text/plain"]`. When a list + * or array is given, the _best_ match, if any is returned. + * + * Examples: + * + * // Accept: text/html + * req.accepts('html'); + * // => "html" + * + * // Accept: text/*, application/json + * req.accepts('html'); + * // => "html" + * req.accepts('text/html'); + * // => "text/html" + * req.accepts('json, text'); + * // => "json" + * req.accepts('application/json'); + * // => "application/json" + * + * // Accept: text/*, application/json + * req.accepts('image/png'); + * req.accepts('png'); + * // => undefined + * + * // Accept: text/*;q=.5, application/json + * req.accepts(['html', 'json']); + * req.accepts('html', 'json'); + * req.accepts('html, json'); + * // => "json" + * + * @param {String|Array} type(s) + * @return {String|Array|Boolean} + * @public + */ + +req.accepts = function(){ + var accept = accepts(this); + return accept.types.apply(accept, arguments); +}; + +/** + * Check if the given `encoding`s are accepted. + * + * @param {String} ...encoding + * @return {String|Array} + * @public + */ + +req.acceptsEncodings = function(){ + var accept = accepts(this); + return accept.encodings.apply(accept, arguments); +}; + +req.acceptsEncoding = deprecate.function(req.acceptsEncodings, + 'req.acceptsEncoding: Use acceptsEncodings instead'); + +/** + * Check if the given `charset`s are acceptable, + * otherwise you should respond with 406 "Not Acceptable". + * + * @param {String} ...charset + * @return {String|Array} + * @public + */ + +req.acceptsCharsets = function(){ + var accept = accepts(this); + return accept.charsets.apply(accept, arguments); +}; + +req.acceptsCharset = deprecate.function(req.acceptsCharsets, + 'req.acceptsCharset: Use acceptsCharsets instead'); + +/** + * Check if the given `lang`s are acceptable, + * otherwise you should respond with 406 "Not Acceptable". + * + * @param {String} ...lang + * @return {String|Array} + * @public + */ + +req.acceptsLanguages = function(){ + var accept = accepts(this); + return accept.languages.apply(accept, arguments); +}; + +req.acceptsLanguage = deprecate.function(req.acceptsLanguages, + 'req.acceptsLanguage: Use acceptsLanguages instead'); + +/** + * Parse Range header field, capping to the given `size`. + * + * Unspecified ranges such as "0-" require knowledge of your resource length. In + * the case of a byte range this is of course the total number of bytes. If the + * Range header field is not given `undefined` is returned, `-1` when unsatisfiable, + * and `-2` when syntactically invalid. + * + * When ranges are returned, the array has a "type" property which is the type of + * range that is required (most commonly, "bytes"). Each array element is an object + * with a "start" and "end" property for the portion of the range. + * + * The "combine" option can be set to `true` and overlapping & adjacent ranges + * will be combined into a single range. + * + * NOTE: remember that ranges are inclusive, so for example "Range: users=0-3" + * should respond with 4 users when available, not 3. + * + * @param {number} size + * @param {object} [options] + * @param {boolean} [options.combine=false] + * @return {number|array} + * @public + */ + +req.range = function range(size, options) { + var range = this.get('Range'); + if (!range) return; + return parseRange(size, range, options); +}; + +/** + * Return the value of param `name` when present or `defaultValue`. + * + * - Checks route placeholders, ex: _/user/:id_ + * - Checks body params, ex: id=12, {"id":12} + * - Checks query string params, ex: ?id=12 + * + * To utilize request bodies, `req.body` + * should be an object. This can be done by using + * the `bodyParser()` middleware. + * + * @param {String} name + * @param {Mixed} [defaultValue] + * @return {String} + * @public + */ + +req.param = function param(name, defaultValue) { + var params = this.params || {}; + var body = this.body || {}; + var query = this.query || {}; + + var args = arguments.length === 1 + ? 'name' + : 'name, default'; + deprecate('req.param(' + args + '): Use req.params, req.body, or req.query instead'); + + if (null != params[name] && params.hasOwnProperty(name)) return params[name]; + if (null != body[name]) return body[name]; + if (null != query[name]) return query[name]; + + return defaultValue; +}; + +/** + * Check if the incoming request contains the "Content-Type" + * header field, and it contains the give mime `type`. + * + * Examples: + * + * // With Content-Type: text/html; charset=utf-8 + * req.is('html'); + * req.is('text/html'); + * req.is('text/*'); + * // => true + * + * // When Content-Type is application/json + * req.is('json'); + * req.is('application/json'); + * req.is('application/*'); + * // => true + * + * req.is('html'); + * // => false + * + * @param {String|Array} types... + * @return {String|false|null} + * @public + */ + +req.is = function is(types) { + var arr = types; + + // support flattened arguments + if (!Array.isArray(types)) { + arr = new Array(arguments.length); + for (var i = 0; i < arr.length; i++) { + arr[i] = arguments[i]; + } + } + + return typeis(this, arr); +}; + +/** + * Return the protocol string "http" or "https" + * when requested with TLS. When the "trust proxy" + * setting trusts the socket address, the + * "X-Forwarded-Proto" header field will be trusted + * and used if present. + * + * If you're running behind a reverse proxy that + * supplies https for you this may be enabled. + * + * @return {String} + * @public + */ + +defineGetter(req, 'protocol', function protocol(){ + var proto = this.connection.encrypted + ? 'https' + : 'http'; + var trust = this.app.get('trust proxy fn'); + + if (!trust(this.connection.remoteAddress, 0)) { + return proto; + } + + // Note: X-Forwarded-Proto is normally only ever a + // single value, but this is to be safe. + proto = this.get('X-Forwarded-Proto') || proto; + return proto.split(/\s*,\s*/)[0]; +}); + +/** + * Short-hand for: + * + * req.protocol === 'https' + * + * @return {Boolean} + * @public + */ + +defineGetter(req, 'secure', function secure(){ + return this.protocol === 'https'; +}); + +/** + * Return the remote address from the trusted proxy. + * + * The is the remote address on the socket unless + * "trust proxy" is set. + * + * @return {String} + * @public + */ + +defineGetter(req, 'ip', function ip(){ + var trust = this.app.get('trust proxy fn'); + return proxyaddr(this, trust); +}); + +/** + * When "trust proxy" is set, trusted proxy addresses + client. + * + * For example if the value were "client, proxy1, proxy2" + * you would receive the array `["client", "proxy1", "proxy2"]` + * where "proxy2" is the furthest down-stream and "proxy1" and + * "proxy2" were trusted. + * + * @return {Array} + * @public + */ + +defineGetter(req, 'ips', function ips() { + var trust = this.app.get('trust proxy fn'); + var addrs = proxyaddr.all(this, trust); + return addrs.slice(1).reverse(); +}); + +/** + * Return subdomains as an array. + * + * Subdomains are the dot-separated parts of the host before the main domain of + * the app. By default, the domain of the app is assumed to be the last two + * parts of the host. This can be changed by setting "subdomain offset". + * + * For example, if the domain is "tobi.ferrets.example.com": + * If "subdomain offset" is not set, req.subdomains is `["ferrets", "tobi"]`. + * If "subdomain offset" is 3, req.subdomains is `["tobi"]`. + * + * @return {Array} + * @public + */ + +defineGetter(req, 'subdomains', function subdomains() { + var hostname = this.hostname; + + if (!hostname) return []; + + var offset = this.app.get('subdomain offset'); + var subdomains = !isIP(hostname) + ? hostname.split('.').reverse() + : [hostname]; + + return subdomains.slice(offset); +}); + +/** + * Short-hand for `url.parse(req.url).pathname`. + * + * @return {String} + * @public + */ + +defineGetter(req, 'path', function path() { + return parse(this).pathname; +}); + +/** + * Parse the "Host" header field to a hostname. + * + * When the "trust proxy" setting trusts the socket + * address, the "X-Forwarded-Host" header field will + * be trusted. + * + * @return {String} + * @public + */ + +defineGetter(req, 'hostname', function hostname(){ + var trust = this.app.get('trust proxy fn'); + var host = this.get('X-Forwarded-Host'); + + if (!host || !trust(this.connection.remoteAddress, 0)) { + host = this.get('Host'); + } + + if (!host) return; + + // IPv6 literal support + var offset = host[0] === '[' + ? host.indexOf(']') + 1 + : 0; + var index = host.indexOf(':', offset); + + return index !== -1 + ? host.substring(0, index) + : host; +}); + +// TODO: change req.host to return host in next major + +defineGetter(req, 'host', deprecate.function(function host(){ + return this.hostname; +}, 'req.host: Use req.hostname instead')); + +/** + * Check if the request is fresh, aka + * Last-Modified and/or the ETag + * still match. + * + * @return {Boolean} + * @public + */ + +defineGetter(req, 'fresh', function(){ + var method = this.method; + var s = this.res.statusCode; + + // GET or HEAD for weak freshness validation only + if ('GET' !== method && 'HEAD' !== method) return false; + + // 2xx or 304 as per rfc2616 14.26 + if ((s >= 200 && s < 300) || 304 === s) { + return fresh(this.headers, (this.res._headers || {})); + } + + return false; +}); + +/** + * Check if the request is stale, aka + * "Last-Modified" and / or the "ETag" for the + * resource has changed. + * + * @return {Boolean} + * @public + */ + +defineGetter(req, 'stale', function stale(){ + return !this.fresh; +}); + +/** + * Check if the request was an _XMLHttpRequest_. + * + * @return {Boolean} + * @public + */ + +defineGetter(req, 'xhr', function xhr(){ + var val = this.get('X-Requested-With') || ''; + return val.toLowerCase() === 'xmlhttprequest'; +}); + +/** + * Helper function for creating a getter on an object. + * + * @param {Object} obj + * @param {String} name + * @param {Function} getter + * @private + */ +function defineGetter(obj, name, getter) { + Object.defineProperty(obj, name, { + configurable: true, + enumerable: true, + get: getter + }); +}; diff --git a/node_modules/express/lib/response.js b/node_modules/express/lib/response.js new file mode 100644 index 0000000..6128f45 --- /dev/null +++ b/node_modules/express/lib/response.js @@ -0,0 +1,1065 @@ +/*! + * express + * Copyright(c) 2009-2013 TJ Holowaychuk + * Copyright(c) 2014-2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict'; + +/** + * Module dependencies. + * @private + */ + +var contentDisposition = require('content-disposition'); +var deprecate = require('depd')('express'); +var encodeUrl = require('encodeurl'); +var escapeHtml = require('escape-html'); +var http = require('http'); +var isAbsolute = require('./utils').isAbsolute; +var onFinished = require('on-finished'); +var path = require('path'); +var merge = require('utils-merge'); +var sign = require('cookie-signature').sign; +var normalizeType = require('./utils').normalizeType; +var normalizeTypes = require('./utils').normalizeTypes; +var setCharset = require('./utils').setCharset; +var statusCodes = http.STATUS_CODES; +var cookie = require('cookie'); +var send = require('send'); +var extname = path.extname; +var mime = send.mime; +var resolve = path.resolve; +var vary = require('vary'); + +/** + * Response prototype. + */ + +var res = module.exports = { + __proto__: http.ServerResponse.prototype +}; + +/** + * Module variables. + * @private + */ + +var charsetRegExp = /;\s*charset\s*=/; + +/** + * Set status `code`. + * + * @param {Number} code + * @return {ServerResponse} + * @public + */ + +res.status = function status(code) { + this.statusCode = code; + return this; +}; + +/** + * Set Link header field with the given `links`. + * + * Examples: + * + * res.links({ + * next: 'http://api.example.com/users?page=2', + * last: 'http://api.example.com/users?page=5' + * }); + * + * @param {Object} links + * @return {ServerResponse} + * @public + */ + +res.links = function(links){ + var link = this.get('Link') || ''; + if (link) link += ', '; + return this.set('Link', link + Object.keys(links).map(function(rel){ + return '<' + links[rel] + '>; rel="' + rel + '"'; + }).join(', ')); +}; + +/** + * Send a response. + * + * Examples: + * + * res.send(new Buffer('wahoo')); + * res.send({ some: 'json' }); + * res.send('

some html

'); + * + * @param {string|number|boolean|object|Buffer} body + * @public + */ + +res.send = function send(body) { + var chunk = body; + var encoding; + var len; + var req = this.req; + var type; + + // settings + var app = this.app; + + // allow status / body + if (arguments.length === 2) { + // res.send(body, status) backwards compat + if (typeof arguments[0] !== 'number' && typeof arguments[1] === 'number') { + deprecate('res.send(body, status): Use res.status(status).send(body) instead'); + this.statusCode = arguments[1]; + } else { + deprecate('res.send(status, body): Use res.status(status).send(body) instead'); + this.statusCode = arguments[0]; + chunk = arguments[1]; + } + } + + // disambiguate res.send(status) and res.send(status, num) + if (typeof chunk === 'number' && arguments.length === 1) { + // res.send(status) will set status message as text string + if (!this.get('Content-Type')) { + this.type('txt'); + } + + deprecate('res.send(status): Use res.sendStatus(status) instead'); + this.statusCode = chunk; + chunk = statusCodes[chunk]; + } + + switch (typeof chunk) { + // string defaulting to html + case 'string': + if (!this.get('Content-Type')) { + this.type('html'); + } + break; + case 'boolean': + case 'number': + case 'object': + if (chunk === null) { + chunk = ''; + } else if (Buffer.isBuffer(chunk)) { + if (!this.get('Content-Type')) { + this.type('bin'); + } + } else { + return this.json(chunk); + } + break; + } + + // write strings in utf-8 + if (typeof chunk === 'string') { + encoding = 'utf8'; + type = this.get('Content-Type'); + + // reflect this in content-type + if (typeof type === 'string') { + this.set('Content-Type', setCharset(type, 'utf-8')); + } + } + + // populate Content-Length + if (chunk !== undefined) { + if (!Buffer.isBuffer(chunk)) { + // convert chunk to Buffer; saves later double conversions + chunk = new Buffer(chunk, encoding); + encoding = undefined; + } + + len = chunk.length; + this.set('Content-Length', len); + } + + // populate ETag + var etag; + var generateETag = len !== undefined && app.get('etag fn'); + if (typeof generateETag === 'function' && !this.get('ETag')) { + if ((etag = generateETag(chunk, encoding))) { + this.set('ETag', etag); + } + } + + // freshness + if (req.fresh) this.statusCode = 304; + + // strip irrelevant headers + if (204 === this.statusCode || 304 === this.statusCode) { + this.removeHeader('Content-Type'); + this.removeHeader('Content-Length'); + this.removeHeader('Transfer-Encoding'); + chunk = ''; + } + + if (req.method === 'HEAD') { + // skip body for HEAD + this.end(); + } else { + // respond + this.end(chunk, encoding); + } + + return this; +}; + +/** + * Send JSON response. + * + * Examples: + * + * res.json(null); + * res.json({ user: 'tj' }); + * + * @param {string|number|boolean|object} obj + * @public + */ + +res.json = function json(obj) { + var val = obj; + + // allow status / body + if (arguments.length === 2) { + // res.json(body, status) backwards compat + if (typeof arguments[1] === 'number') { + deprecate('res.json(obj, status): Use res.status(status).json(obj) instead'); + this.statusCode = arguments[1]; + } else { + deprecate('res.json(status, obj): Use res.status(status).json(obj) instead'); + this.statusCode = arguments[0]; + val = arguments[1]; + } + } + + // settings + var app = this.app; + var replacer = app.get('json replacer'); + var spaces = app.get('json spaces'); + var body = stringify(val, replacer, spaces); + + // content-type + if (!this.get('Content-Type')) { + this.set('Content-Type', 'application/json'); + } + + return this.send(body); +}; + +/** + * Send JSON response with JSONP callback support. + * + * Examples: + * + * res.jsonp(null); + * res.jsonp({ user: 'tj' }); + * + * @param {string|number|boolean|object} obj + * @public + */ + +res.jsonp = function jsonp(obj) { + var val = obj; + + // allow status / body + if (arguments.length === 2) { + // res.json(body, status) backwards compat + if (typeof arguments[1] === 'number') { + deprecate('res.jsonp(obj, status): Use res.status(status).json(obj) instead'); + this.statusCode = arguments[1]; + } else { + deprecate('res.jsonp(status, obj): Use res.status(status).jsonp(obj) instead'); + this.statusCode = arguments[0]; + val = arguments[1]; + } + } + + // settings + var app = this.app; + var replacer = app.get('json replacer'); + var spaces = app.get('json spaces'); + var body = stringify(val, replacer, spaces); + var callback = this.req.query[app.get('jsonp callback name')]; + + // content-type + if (!this.get('Content-Type')) { + this.set('X-Content-Type-Options', 'nosniff'); + this.set('Content-Type', 'application/json'); + } + + // fixup callback + if (Array.isArray(callback)) { + callback = callback[0]; + } + + // jsonp + if (typeof callback === 'string' && callback.length !== 0) { + this.charset = 'utf-8'; + this.set('X-Content-Type-Options', 'nosniff'); + this.set('Content-Type', 'text/javascript'); + + // restrict callback charset + callback = callback.replace(/[^\[\]\w$.]/g, ''); + + // replace chars not allowed in JavaScript that are in JSON + body = body + .replace(/\u2028/g, '\\u2028') + .replace(/\u2029/g, '\\u2029'); + + // the /**/ is a specific security mitigation for "Rosetta Flash JSONP abuse" + // the typeof check is just to reduce client error noise + body = '/**/ typeof ' + callback + ' === \'function\' && ' + callback + '(' + body + ');'; + } + + return this.send(body); +}; + +/** + * Send given HTTP status code. + * + * Sets the response status to `statusCode` and the body of the + * response to the standard description from node's http.STATUS_CODES + * or the statusCode number if no description. + * + * Examples: + * + * res.sendStatus(200); + * + * @param {number} statusCode + * @public + */ + +res.sendStatus = function sendStatus(statusCode) { + var body = statusCodes[statusCode] || String(statusCode); + + this.statusCode = statusCode; + this.type('txt'); + + return this.send(body); +}; + +/** + * Transfer the file at the given `path`. + * + * Automatically sets the _Content-Type_ response header field. + * The callback `callback(err)` is invoked when the transfer is complete + * or when an error occurs. Be sure to check `res.sentHeader` + * if you wish to attempt responding, as the header and some data + * may have already been transferred. + * + * Options: + * + * - `maxAge` defaulting to 0 (can be string converted by `ms`) + * - `root` root directory for relative filenames + * - `headers` object of headers to serve with file + * - `dotfiles` serve dotfiles, defaulting to false; can be `"allow"` to send them + * + * Other options are passed along to `send`. + * + * Examples: + * + * The following example illustrates how `res.sendFile()` may + * be used as an alternative for the `static()` middleware for + * dynamic situations. The code backing `res.sendFile()` is actually + * the same code, so HTTP cache support etc is identical. + * + * app.get('/user/:uid/photos/:file', function(req, res){ + * var uid = req.params.uid + * , file = req.params.file; + * + * req.user.mayViewFilesFrom(uid, function(yes){ + * if (yes) { + * res.sendFile('/uploads/' + uid + '/' + file); + * } else { + * res.send(403, 'Sorry! you cant see that.'); + * } + * }); + * }); + * + * @public + */ + +res.sendFile = function sendFile(path, options, callback) { + var done = callback; + var req = this.req; + var res = this; + var next = req.next; + var opts = options || {}; + + if (!path) { + throw new TypeError('path argument is required to res.sendFile'); + } + + // support function as second arg + if (typeof options === 'function') { + done = options; + opts = {}; + } + + if (!opts.root && !isAbsolute(path)) { + throw new TypeError('path must be absolute or specify root to res.sendFile'); + } + + // create file stream + var pathname = encodeURI(path); + var file = send(req, pathname, opts); + + // transfer + sendfile(res, file, opts, function (err) { + if (done) return done(err); + if (err && err.code === 'EISDIR') return next(); + + // next() all but write errors + if (err && err.code !== 'ECONNABORTED' && err.syscall !== 'write') { + next(err); + } + }); +}; + +/** + * Transfer the file at the given `path`. + * + * Automatically sets the _Content-Type_ response header field. + * The callback `callback(err)` is invoked when the transfer is complete + * or when an error occurs. Be sure to check `res.sentHeader` + * if you wish to attempt responding, as the header and some data + * may have already been transferred. + * + * Options: + * + * - `maxAge` defaulting to 0 (can be string converted by `ms`) + * - `root` root directory for relative filenames + * - `headers` object of headers to serve with file + * - `dotfiles` serve dotfiles, defaulting to false; can be `"allow"` to send them + * + * Other options are passed along to `send`. + * + * Examples: + * + * The following example illustrates how `res.sendfile()` may + * be used as an alternative for the `static()` middleware for + * dynamic situations. The code backing `res.sendfile()` is actually + * the same code, so HTTP cache support etc is identical. + * + * app.get('/user/:uid/photos/:file', function(req, res){ + * var uid = req.params.uid + * , file = req.params.file; + * + * req.user.mayViewFilesFrom(uid, function(yes){ + * if (yes) { + * res.sendfile('/uploads/' + uid + '/' + file); + * } else { + * res.send(403, 'Sorry! you cant see that.'); + * } + * }); + * }); + * + * @public + */ + +res.sendfile = function (path, options, callback) { + var done = callback; + var req = this.req; + var res = this; + var next = req.next; + var opts = options || {}; + + // support function as second arg + if (typeof options === 'function') { + done = options; + opts = {}; + } + + // create file stream + var file = send(req, path, opts); + + // transfer + sendfile(res, file, opts, function (err) { + if (done) return done(err); + if (err && err.code === 'EISDIR') return next(); + + // next() all but write errors + if (err && err.code !== 'ECONNABORT' && err.syscall !== 'write') { + next(err); + } + }); +}; + +res.sendfile = deprecate.function(res.sendfile, + 'res.sendfile: Use res.sendFile instead'); + +/** + * Transfer the file at the given `path` as an attachment. + * + * Optionally providing an alternate attachment `filename`, + * and optional callback `callback(err)`. The callback is invoked + * when the data transfer is complete, or when an error has + * ocurred. Be sure to check `res.headersSent` if you plan to respond. + * + * This method uses `res.sendfile()`. + * + * @public + */ + +res.download = function download(path, filename, callback) { + var done = callback; + var name = filename; + + // support function as second arg + if (typeof filename === 'function') { + done = filename; + name = null; + } + + // set Content-Disposition when file is sent + var headers = { + 'Content-Disposition': contentDisposition(name || path) + }; + + // Resolve the full path for sendFile + var fullPath = resolve(path); + + return this.sendFile(fullPath, { headers: headers }, done); +}; + +/** + * Set _Content-Type_ response header with `type` through `mime.lookup()` + * when it does not contain "/", or set the Content-Type to `type` otherwise. + * + * Examples: + * + * res.type('.html'); + * res.type('html'); + * res.type('json'); + * res.type('application/json'); + * res.type('png'); + * + * @param {String} type + * @return {ServerResponse} for chaining + * @public + */ + +res.contentType = +res.type = function contentType(type) { + var ct = type.indexOf('/') === -1 + ? mime.lookup(type) + : type; + + return this.set('Content-Type', ct); +}; + +/** + * Respond to the Acceptable formats using an `obj` + * of mime-type callbacks. + * + * This method uses `req.accepted`, an array of + * acceptable types ordered by their quality values. + * When "Accept" is not present the _first_ callback + * is invoked, otherwise the first match is used. When + * no match is performed the server responds with + * 406 "Not Acceptable". + * + * Content-Type is set for you, however if you choose + * you may alter this within the callback using `res.type()` + * or `res.set('Content-Type', ...)`. + * + * res.format({ + * 'text/plain': function(){ + * res.send('hey'); + * }, + * + * 'text/html': function(){ + * res.send('

hey

'); + * }, + * + * 'appliation/json': function(){ + * res.send({ message: 'hey' }); + * } + * }); + * + * In addition to canonicalized MIME types you may + * also use extnames mapped to these types: + * + * res.format({ + * text: function(){ + * res.send('hey'); + * }, + * + * html: function(){ + * res.send('

hey

'); + * }, + * + * json: function(){ + * res.send({ message: 'hey' }); + * } + * }); + * + * By default Express passes an `Error` + * with a `.status` of 406 to `next(err)` + * if a match is not made. If you provide + * a `.default` callback it will be invoked + * instead. + * + * @param {Object} obj + * @return {ServerResponse} for chaining + * @public + */ + +res.format = function(obj){ + var req = this.req; + var next = req.next; + + var fn = obj.default; + if (fn) delete obj.default; + var keys = Object.keys(obj); + + var key = keys.length > 0 + ? req.accepts(keys) + : false; + + this.vary("Accept"); + + if (key) { + this.set('Content-Type', normalizeType(key).value); + obj[key](req, this, next); + } else if (fn) { + fn(); + } else { + var err = new Error('Not Acceptable'); + err.status = err.statusCode = 406; + err.types = normalizeTypes(keys).map(function(o){ return o.value }); + next(err); + } + + return this; +}; + +/** + * Set _Content-Disposition_ header to _attachment_ with optional `filename`. + * + * @param {String} filename + * @return {ServerResponse} + * @public + */ + +res.attachment = function attachment(filename) { + if (filename) { + this.type(extname(filename)); + } + + this.set('Content-Disposition', contentDisposition(filename)); + + return this; +}; + +/** + * Append additional header `field` with value `val`. + * + * Example: + * + * res.append('Link', ['', '']); + * res.append('Set-Cookie', 'foo=bar; Path=/; HttpOnly'); + * res.append('Warning', '199 Miscellaneous warning'); + * + * @param {String} field + * @param {String|Array} val + * @return {ServerResponse} for chaining + * @public + */ + +res.append = function append(field, val) { + var prev = this.get(field); + var value = val; + + if (prev) { + // concat the new and prev vals + value = Array.isArray(prev) ? prev.concat(val) + : Array.isArray(val) ? [prev].concat(val) + : [prev, val]; + } + + return this.set(field, value); +}; + +/** + * Set header `field` to `val`, or pass + * an object of header fields. + * + * Examples: + * + * res.set('Foo', ['bar', 'baz']); + * res.set('Accept', 'application/json'); + * res.set({ Accept: 'text/plain', 'X-API-Key': 'tobi' }); + * + * Aliased as `res.header()`. + * + * @param {String|Object} field + * @param {String|Array} val + * @return {ServerResponse} for chaining + * @public + */ + +res.set = +res.header = function header(field, val) { + if (arguments.length === 2) { + var value = Array.isArray(val) + ? val.map(String) + : String(val); + + // add charset to content-type + if (field.toLowerCase() === 'content-type' && !charsetRegExp.test(value)) { + var charset = mime.charsets.lookup(value.split(';')[0]); + if (charset) value += '; charset=' + charset.toLowerCase(); + } + + this.setHeader(field, value); + } else { + for (var key in field) { + this.set(key, field[key]); + } + } + return this; +}; + +/** + * Get value for header `field`. + * + * @param {String} field + * @return {String} + * @public + */ + +res.get = function(field){ + return this.getHeader(field); +}; + +/** + * Clear cookie `name`. + * + * @param {String} name + * @param {Object} [options] + * @return {ServerResponse} for chaining + * @public + */ + +res.clearCookie = function clearCookie(name, options) { + var opts = merge({ expires: new Date(1), path: '/' }, options); + + return this.cookie(name, '', opts); +}; + +/** + * Set cookie `name` to `value`, with the given `options`. + * + * Options: + * + * - `maxAge` max-age in milliseconds, converted to `expires` + * - `signed` sign the cookie + * - `path` defaults to "/" + * + * Examples: + * + * // "Remember Me" for 15 minutes + * res.cookie('rememberme', '1', { expires: new Date(Date.now() + 900000), httpOnly: true }); + * + * // save as above + * res.cookie('rememberme', '1', { maxAge: 900000, httpOnly: true }) + * + * @param {String} name + * @param {String|Object} value + * @param {Options} options + * @return {ServerResponse} for chaining + * @public + */ + +res.cookie = function (name, value, options) { + var opts = merge({}, options); + var secret = this.req.secret; + var signed = opts.signed; + + if (signed && !secret) { + throw new Error('cookieParser("secret") required for signed cookies'); + } + + var val = typeof value === 'object' + ? 'j:' + JSON.stringify(value) + : String(value); + + if (signed) { + val = 's:' + sign(val, secret); + } + + if ('maxAge' in opts) { + opts.expires = new Date(Date.now() + opts.maxAge); + opts.maxAge /= 1000; + } + + if (opts.path == null) { + opts.path = '/'; + } + + this.append('Set-Cookie', cookie.serialize(name, String(val), opts)); + + return this; +}; + +/** + * Set the location header to `url`. + * + * The given `url` can also be "back", which redirects + * to the _Referrer_ or _Referer_ headers or "/". + * + * Examples: + * + * res.location('/foo/bar').; + * res.location('http://example.com'); + * res.location('../login'); + * + * @param {String} url + * @return {ServerResponse} for chaining + * @public + */ + +res.location = function location(url) { + var loc = url; + + // "back" is an alias for the referrer + if (url === 'back') { + loc = this.req.get('Referrer') || '/'; + } + + // set location + return this.set('Location', encodeUrl(loc)); +}; + +/** + * Redirect to the given `url` with optional response `status` + * defaulting to 302. + * + * The resulting `url` is determined by `res.location()`, so + * it will play nicely with mounted apps, relative paths, + * `"back"` etc. + * + * Examples: + * + * res.redirect('/foo/bar'); + * res.redirect('http://example.com'); + * res.redirect(301, 'http://example.com'); + * res.redirect('../login'); // /blog/post/1 -> /blog/login + * + * @public + */ + +res.redirect = function redirect(url) { + var address = url; + var body; + var status = 302; + + // allow status / url + if (arguments.length === 2) { + if (typeof arguments[0] === 'number') { + status = arguments[0]; + address = arguments[1]; + } else { + deprecate('res.redirect(url, status): Use res.redirect(status, url) instead'); + status = arguments[1]; + } + } + + // Set location header + address = this.location(address).get('Location'); + + // Support text/{plain,html} by default + this.format({ + text: function(){ + body = statusCodes[status] + '. Redirecting to ' + address; + }, + + html: function(){ + var u = escapeHtml(address); + body = '

' + statusCodes[status] + '. Redirecting to ' + u + '

'; + }, + + default: function(){ + body = ''; + } + }); + + // Respond + this.statusCode = status; + this.set('Content-Length', Buffer.byteLength(body)); + + if (this.req.method === 'HEAD') { + this.end(); + } else { + this.end(body); + } +}; + +/** + * Add `field` to Vary. If already present in the Vary set, then + * this call is simply ignored. + * + * @param {Array|String} field + * @return {ServerResponse} for chaining + * @public + */ + +res.vary = function(field){ + // checks for back-compat + if (!field || (Array.isArray(field) && !field.length)) { + deprecate('res.vary(): Provide a field name'); + return this; + } + + vary(this, field); + + return this; +}; + +/** + * Render `view` with the given `options` and optional callback `fn`. + * When a callback function is given a response will _not_ be made + * automatically, otherwise a response of _200_ and _text/html_ is given. + * + * Options: + * + * - `cache` boolean hinting to the engine it should cache + * - `filename` filename of the view being rendered + * + * @public + */ + +res.render = function render(view, options, callback) { + var app = this.req.app; + var done = callback; + var opts = options || {}; + var req = this.req; + var self = this; + + // support callback function as second arg + if (typeof options === 'function') { + done = options; + opts = {}; + } + + // merge res.locals + opts._locals = self.locals; + + // default callback to respond + done = done || function (err, str) { + if (err) return req.next(err); + self.send(str); + }; + + // render + app.render(view, opts, done); +}; + +// pipe the send file stream +function sendfile(res, file, options, callback) { + var done = false; + var streaming; + + // request aborted + function onaborted() { + if (done) return; + done = true; + + var err = new Error('Request aborted'); + err.code = 'ECONNABORTED'; + callback(err); + } + + // directory + function ondirectory() { + if (done) return; + done = true; + + var err = new Error('EISDIR, read'); + err.code = 'EISDIR'; + callback(err); + } + + // errors + function onerror(err) { + if (done) return; + done = true; + callback(err); + } + + // ended + function onend() { + if (done) return; + done = true; + callback(); + } + + // file + function onfile() { + streaming = false; + } + + // finished + function onfinish(err) { + if (err && err.code === 'ECONNRESET') return onaborted(); + if (err) return onerror(err); + if (done) return; + + setImmediate(function () { + if (streaming !== false && !done) { + onaborted(); + return; + } + + if (done) return; + done = true; + callback(); + }); + } + + // streaming + function onstream() { + streaming = true; + } + + file.on('directory', ondirectory); + file.on('end', onend); + file.on('error', onerror); + file.on('file', onfile); + file.on('stream', onstream); + onFinished(res, onfinish); + + if (options.headers) { + // set headers on successful transfer + file.on('headers', function headers(res) { + var obj = options.headers; + var keys = Object.keys(obj); + + for (var i = 0; i < keys.length; i++) { + var k = keys[i]; + res.setHeader(k, obj[k]); + } + }); + } + + // pipe + file.pipe(res); +} + +/** + * Stringify JSON, like JSON.stringify, but v8 optimized. + * @private + */ + +function stringify(value, replacer, spaces) { + // v8 checks arguments.length for optimizing simple call + // https://bugs.chromium.org/p/v8/issues/detail?id=4730 + return replacer || spaces + ? JSON.stringify(value, replacer, spaces) + : JSON.stringify(value); +} diff --git a/node_modules/express/lib/router/index.js b/node_modules/express/lib/router/index.js new file mode 100644 index 0000000..dac2514 --- /dev/null +++ b/node_modules/express/lib/router/index.js @@ -0,0 +1,645 @@ +/*! + * express + * Copyright(c) 2009-2013 TJ Holowaychuk + * Copyright(c) 2013 Roman Shtylman + * Copyright(c) 2014-2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict'; + +/** + * Module dependencies. + * @private + */ + +var Route = require('./route'); +var Layer = require('./layer'); +var methods = require('methods'); +var mixin = require('utils-merge'); +var debug = require('debug')('express:router'); +var deprecate = require('depd')('express'); +var flatten = require('array-flatten'); +var parseUrl = require('parseurl'); + +/** + * Module variables. + * @private + */ + +var objectRegExp = /^\[object (\S+)\]$/; +var slice = Array.prototype.slice; +var toString = Object.prototype.toString; + +/** + * Initialize a new `Router` with the given `options`. + * + * @param {Object} options + * @return {Router} which is an callable function + * @public + */ + +var proto = module.exports = function(options) { + var opts = options || {}; + + function router(req, res, next) { + router.handle(req, res, next); + } + + // mixin Router class functions + router.__proto__ = proto; + + router.params = {}; + router._params = []; + router.caseSensitive = opts.caseSensitive; + router.mergeParams = opts.mergeParams; + router.strict = opts.strict; + router.stack = []; + + return router; +}; + +/** + * Map the given param placeholder `name`(s) to the given callback. + * + * Parameter mapping is used to provide pre-conditions to routes + * which use normalized placeholders. For example a _:user_id_ parameter + * could automatically load a user's information from the database without + * any additional code, + * + * The callback uses the same signature as middleware, the only difference + * being that the value of the placeholder is passed, in this case the _id_ + * of the user. Once the `next()` function is invoked, just like middleware + * it will continue on to execute the route, or subsequent parameter functions. + * + * Just like in middleware, you must either respond to the request or call next + * to avoid stalling the request. + * + * app.param('user_id', function(req, res, next, id){ + * User.find(id, function(err, user){ + * if (err) { + * return next(err); + * } else if (!user) { + * return next(new Error('failed to load user')); + * } + * req.user = user; + * next(); + * }); + * }); + * + * @param {String} name + * @param {Function} fn + * @return {app} for chaining + * @public + */ + +proto.param = function param(name, fn) { + // param logic + if (typeof name === 'function') { + deprecate('router.param(fn): Refactor to use path params'); + this._params.push(name); + return; + } + + // apply param functions + var params = this._params; + var len = params.length; + var ret; + + if (name[0] === ':') { + deprecate('router.param(' + JSON.stringify(name) + ', fn): Use router.param(' + JSON.stringify(name.substr(1)) + ', fn) instead'); + name = name.substr(1); + } + + for (var i = 0; i < len; ++i) { + if (ret = params[i](name, fn)) { + fn = ret; + } + } + + // ensure we end up with a + // middleware function + if ('function' !== typeof fn) { + throw new Error('invalid param() call for ' + name + ', got ' + fn); + } + + (this.params[name] = this.params[name] || []).push(fn); + return this; +}; + +/** + * Dispatch a req, res into the router. + * @private + */ + +proto.handle = function handle(req, res, out) { + var self = this; + + debug('dispatching %s %s', req.method, req.url); + + var search = 1 + req.url.indexOf('?'); + var pathlength = search ? search - 1 : req.url.length; + var fqdn = req.url[0] !== '/' && 1 + req.url.substr(0, pathlength).indexOf('://'); + var protohost = fqdn ? req.url.substr(0, req.url.indexOf('/', 2 + fqdn)) : ''; + var idx = 0; + var removed = ''; + var slashAdded = false; + var paramcalled = {}; + + // store options for OPTIONS request + // only used if OPTIONS request + var options = []; + + // middleware and routes + var stack = self.stack; + + // manage inter-router variables + var parentParams = req.params; + var parentUrl = req.baseUrl || ''; + var done = restore(out, req, 'baseUrl', 'next', 'params'); + + // setup next layer + req.next = next; + + // for options requests, respond with a default if nothing else responds + if (req.method === 'OPTIONS') { + done = wrap(done, function(old, err) { + if (err || options.length === 0) return old(err); + sendOptionsResponse(res, options, old); + }); + } + + // setup basic req values + req.baseUrl = parentUrl; + req.originalUrl = req.originalUrl || req.url; + + next(); + + function next(err) { + var layerError = err === 'route' + ? null + : err; + + // remove added slash + if (slashAdded) { + req.url = req.url.substr(1); + slashAdded = false; + } + + // restore altered req.url + if (removed.length !== 0) { + req.baseUrl = parentUrl; + req.url = protohost + removed + req.url.substr(protohost.length); + removed = ''; + } + + // no more matching layers + if (idx >= stack.length) { + setImmediate(done, layerError); + return; + } + + // get pathname of request + var path = getPathname(req); + + if (path == null) { + return done(layerError); + } + + // find next matching layer + var layer; + var match; + var route; + + while (match !== true && idx < stack.length) { + layer = stack[idx++]; + match = matchLayer(layer, path); + route = layer.route; + + if (typeof match !== 'boolean') { + // hold on to layerError + layerError = layerError || match; + } + + if (match !== true) { + continue; + } + + if (!route) { + // process non-route handlers normally + continue; + } + + if (layerError) { + // routes do not match with a pending error + match = false; + continue; + } + + var method = req.method; + var has_method = route._handles_method(method); + + // build up automatic options response + if (!has_method && method === 'OPTIONS') { + appendMethods(options, route._options()); + } + + // don't even bother matching route + if (!has_method && method !== 'HEAD') { + match = false; + continue; + } + } + + // no match + if (match !== true) { + return done(layerError); + } + + // store route for dispatch on change + if (route) { + req.route = route; + } + + // Capture one-time layer values + req.params = self.mergeParams + ? mergeParams(layer.params, parentParams) + : layer.params; + var layerPath = layer.path; + + // this should be done for the layer + self.process_params(layer, paramcalled, req, res, function (err) { + if (err) { + return next(layerError || err); + } + + if (route) { + return layer.handle_request(req, res, next); + } + + trim_prefix(layer, layerError, layerPath, path); + }); + } + + function trim_prefix(layer, layerError, layerPath, path) { + var c = path[layerPath.length]; + if (c && '/' !== c && '.' !== c) return next(layerError); + + // Trim off the part of the url that matches the route + // middleware (.use stuff) needs to have the path stripped + if (layerPath.length !== 0) { + debug('trim prefix (%s) from url %s', layerPath, req.url); + removed = layerPath; + req.url = protohost + req.url.substr(protohost.length + removed.length); + + // Ensure leading slash + if (!fqdn && req.url[0] !== '/') { + req.url = '/' + req.url; + slashAdded = true; + } + + // Setup base URL (no trailing slash) + req.baseUrl = parentUrl + (removed[removed.length - 1] === '/' + ? removed.substring(0, removed.length - 1) + : removed); + } + + debug('%s %s : %s', layer.name, layerPath, req.originalUrl); + + if (layerError) { + layer.handle_error(layerError, req, res, next); + } else { + layer.handle_request(req, res, next); + } + } +}; + +/** + * Process any parameters for the layer. + * @private + */ + +proto.process_params = function process_params(layer, called, req, res, done) { + var params = this.params; + + // captured parameters from the layer, keys and values + var keys = layer.keys; + + // fast track + if (!keys || keys.length === 0) { + return done(); + } + + var i = 0; + var name; + var paramIndex = 0; + var key; + var paramVal; + var paramCallbacks; + var paramCalled; + + // process params in order + // param callbacks can be async + function param(err) { + if (err) { + return done(err); + } + + if (i >= keys.length ) { + return done(); + } + + paramIndex = 0; + key = keys[i++]; + + if (!key) { + return done(); + } + + name = key.name; + paramVal = req.params[name]; + paramCallbacks = params[name]; + paramCalled = called[name]; + + if (paramVal === undefined || !paramCallbacks) { + return param(); + } + + // param previously called with same value or error occurred + if (paramCalled && (paramCalled.match === paramVal + || (paramCalled.error && paramCalled.error !== 'route'))) { + // restore value + req.params[name] = paramCalled.value; + + // next param + return param(paramCalled.error); + } + + called[name] = paramCalled = { + error: null, + match: paramVal, + value: paramVal + }; + + paramCallback(); + } + + // single param callbacks + function paramCallback(err) { + var fn = paramCallbacks[paramIndex++]; + + // store updated value + paramCalled.value = req.params[key.name]; + + if (err) { + // store error + paramCalled.error = err; + param(err); + return; + } + + if (!fn) return param(); + + try { + fn(req, res, paramCallback, paramVal, key.name); + } catch (e) { + paramCallback(e); + } + } + + param(); +}; + +/** + * Use the given middleware function, with optional path, defaulting to "/". + * + * Use (like `.all`) will run for any http METHOD, but it will not add + * handlers for those methods so OPTIONS requests will not consider `.use` + * functions even if they could respond. + * + * The other difference is that _route_ path is stripped and not visible + * to the handler function. The main effect of this feature is that mounted + * handlers can operate without any code changes regardless of the "prefix" + * pathname. + * + * @public + */ + +proto.use = function use(fn) { + var offset = 0; + var path = '/'; + + // default path to '/' + // disambiguate router.use([fn]) + if (typeof fn !== 'function') { + var arg = fn; + + while (Array.isArray(arg) && arg.length !== 0) { + arg = arg[0]; + } + + // first arg is the path + if (typeof arg !== 'function') { + offset = 1; + path = fn; + } + } + + var callbacks = flatten(slice.call(arguments, offset)); + + if (callbacks.length === 0) { + throw new TypeError('Router.use() requires middleware functions'); + } + + for (var i = 0; i < callbacks.length; i++) { + var fn = callbacks[i]; + + if (typeof fn !== 'function') { + throw new TypeError('Router.use() requires middleware function but got a ' + gettype(fn)); + } + + // add the middleware + debug('use %s %s', path, fn.name || ''); + + var layer = new Layer(path, { + sensitive: this.caseSensitive, + strict: false, + end: false + }, fn); + + layer.route = undefined; + + this.stack.push(layer); + } + + return this; +}; + +/** + * Create a new Route for the given path. + * + * Each route contains a separate middleware stack and VERB handlers. + * + * See the Route api documentation for details on adding handlers + * and middleware to routes. + * + * @param {String} path + * @return {Route} + * @public + */ + +proto.route = function route(path) { + var route = new Route(path); + + var layer = new Layer(path, { + sensitive: this.caseSensitive, + strict: this.strict, + end: true + }, route.dispatch.bind(route)); + + layer.route = route; + + this.stack.push(layer); + return route; +}; + +// create Router#VERB functions +methods.concat('all').forEach(function(method){ + proto[method] = function(path){ + var route = this.route(path) + route[method].apply(route, slice.call(arguments, 1)); + return this; + }; +}); + +// append methods to a list of methods +function appendMethods(list, addition) { + for (var i = 0; i < addition.length; i++) { + var method = addition[i]; + if (list.indexOf(method) === -1) { + list.push(method); + } + } +} + +// get pathname of request +function getPathname(req) { + try { + return parseUrl(req).pathname; + } catch (err) { + return undefined; + } +} + +// get type for error message +function gettype(obj) { + var type = typeof obj; + + if (type !== 'object') { + return type; + } + + // inspect [[Class]] for objects + return toString.call(obj) + .replace(objectRegExp, '$1'); +} + +/** + * Match path to a layer. + * + * @param {Layer} layer + * @param {string} path + * @private + */ + +function matchLayer(layer, path) { + try { + return layer.match(path); + } catch (err) { + return err; + } +} + +// merge params with parent params +function mergeParams(params, parent) { + if (typeof parent !== 'object' || !parent) { + return params; + } + + // make copy of parent for base + var obj = mixin({}, parent); + + // simple non-numeric merging + if (!(0 in params) || !(0 in parent)) { + return mixin(obj, params); + } + + var i = 0; + var o = 0; + + // determine numeric gaps + while (i in params) { + i++; + } + + while (o in parent) { + o++; + } + + // offset numeric indices in params before merge + for (i--; i >= 0; i--) { + params[i + o] = params[i]; + + // create holes for the merge when necessary + if (i < o) { + delete params[i]; + } + } + + return mixin(obj, params); +} + +// restore obj props after function +function restore(fn, obj) { + var props = new Array(arguments.length - 2); + var vals = new Array(arguments.length - 2); + + for (var i = 0; i < props.length; i++) { + props[i] = arguments[i + 2]; + vals[i] = obj[props[i]]; + } + + return function(err){ + // restore vals + for (var i = 0; i < props.length; i++) { + obj[props[i]] = vals[i]; + } + + return fn.apply(this, arguments); + }; +} + +// send an OPTIONS response +function sendOptionsResponse(res, options, next) { + try { + var body = options.join(','); + res.set('Allow', body); + res.send(body); + } catch (err) { + next(err); + } +} + +// wrap a function +function wrap(old, fn) { + return function proxy() { + var args = new Array(arguments.length + 1); + + args[0] = old; + for (var i = 0, len = arguments.length; i < len; i++) { + args[i + 1] = arguments[i]; + } + + fn.apply(this, args); + }; +} diff --git a/node_modules/express/lib/router/layer.js b/node_modules/express/lib/router/layer.js new file mode 100644 index 0000000..fe9210c --- /dev/null +++ b/node_modules/express/lib/router/layer.js @@ -0,0 +1,176 @@ +/*! + * express + * Copyright(c) 2009-2013 TJ Holowaychuk + * Copyright(c) 2013 Roman Shtylman + * Copyright(c) 2014-2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict'; + +/** + * Module dependencies. + * @private + */ + +var pathRegexp = require('path-to-regexp'); +var debug = require('debug')('express:router:layer'); + +/** + * Module variables. + * @private + */ + +var hasOwnProperty = Object.prototype.hasOwnProperty; + +/** + * Module exports. + * @public + */ + +module.exports = Layer; + +function Layer(path, options, fn) { + if (!(this instanceof Layer)) { + return new Layer(path, options, fn); + } + + debug('new %s', path); + var opts = options || {}; + + this.handle = fn; + this.name = fn.name || ''; + this.params = undefined; + this.path = undefined; + this.regexp = pathRegexp(path, this.keys = [], opts); + + if (path === '/' && opts.end === false) { + this.regexp.fast_slash = true; + } +} + +/** + * Handle the error for the layer. + * + * @param {Error} error + * @param {Request} req + * @param {Response} res + * @param {function} next + * @api private + */ + +Layer.prototype.handle_error = function handle_error(error, req, res, next) { + var fn = this.handle; + + if (fn.length !== 4) { + // not a standard error handler + return next(error); + } + + try { + fn(error, req, res, next); + } catch (err) { + next(err); + } +}; + +/** + * Handle the request for the layer. + * + * @param {Request} req + * @param {Response} res + * @param {function} next + * @api private + */ + +Layer.prototype.handle_request = function handle(req, res, next) { + var fn = this.handle; + + if (fn.length > 3) { + // not a standard request handler + return next(); + } + + try { + fn(req, res, next); + } catch (err) { + next(err); + } +}; + +/** + * Check if this route matches `path`, if so + * populate `.params`. + * + * @param {String} path + * @return {Boolean} + * @api private + */ + +Layer.prototype.match = function match(path) { + if (path == null) { + // no path, nothing matches + this.params = undefined; + this.path = undefined; + return false; + } + + if (this.regexp.fast_slash) { + // fast path non-ending match for / (everything matches) + this.params = {}; + this.path = ''; + return true; + } + + var m = this.regexp.exec(path); + + if (!m) { + this.params = undefined; + this.path = undefined; + return false; + } + + // store values + this.params = {}; + this.path = m[0]; + + var keys = this.keys; + var params = this.params; + + for (var i = 1; i < m.length; i++) { + var key = keys[i - 1]; + var prop = key.name; + var val = decode_param(m[i]); + + if (val !== undefined || !(hasOwnProperty.call(params, prop))) { + params[prop] = val; + } + } + + return true; +}; + +/** + * Decode param value. + * + * @param {string} val + * @return {string} + * @private + */ + +function decode_param(val) { + if (typeof val !== 'string' || val.length === 0) { + return val; + } + + try { + return decodeURIComponent(val); + } catch (err) { + if (err instanceof URIError) { + err.message = 'Failed to decode param \'' + val + '\''; + err.status = err.statusCode = 400; + } + + throw err; + } +} diff --git a/node_modules/express/lib/router/route.js b/node_modules/express/lib/router/route.js new file mode 100644 index 0000000..2788d7b --- /dev/null +++ b/node_modules/express/lib/router/route.js @@ -0,0 +1,210 @@ +/*! + * express + * Copyright(c) 2009-2013 TJ Holowaychuk + * Copyright(c) 2013 Roman Shtylman + * Copyright(c) 2014-2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict'; + +/** + * Module dependencies. + * @private + */ + +var debug = require('debug')('express:router:route'); +var flatten = require('array-flatten'); +var Layer = require('./layer'); +var methods = require('methods'); + +/** + * Module variables. + * @private + */ + +var slice = Array.prototype.slice; +var toString = Object.prototype.toString; + +/** + * Module exports. + * @public + */ + +module.exports = Route; + +/** + * Initialize `Route` with the given `path`, + * + * @param {String} path + * @public + */ + +function Route(path) { + this.path = path; + this.stack = []; + + debug('new %s', path); + + // route handlers for various http methods + this.methods = {}; +} + +/** + * Determine if the route handles a given method. + * @private + */ + +Route.prototype._handles_method = function _handles_method(method) { + if (this.methods._all) { + return true; + } + + var name = method.toLowerCase(); + + if (name === 'head' && !this.methods['head']) { + name = 'get'; + } + + return Boolean(this.methods[name]); +}; + +/** + * @return {Array} supported HTTP methods + * @private + */ + +Route.prototype._options = function _options() { + var methods = Object.keys(this.methods); + + // append automatic head + if (this.methods.get && !this.methods.head) { + methods.push('head'); + } + + for (var i = 0; i < methods.length; i++) { + // make upper case + methods[i] = methods[i].toUpperCase(); + } + + return methods; +}; + +/** + * dispatch req, res into this route + * @private + */ + +Route.prototype.dispatch = function dispatch(req, res, done) { + var idx = 0; + var stack = this.stack; + if (stack.length === 0) { + return done(); + } + + var method = req.method.toLowerCase(); + if (method === 'head' && !this.methods['head']) { + method = 'get'; + } + + req.route = this; + + next(); + + function next(err) { + if (err && err === 'route') { + return done(); + } + + var layer = stack[idx++]; + if (!layer) { + return done(err); + } + + if (layer.method && layer.method !== method) { + return next(err); + } + + if (err) { + layer.handle_error(err, req, res, next); + } else { + layer.handle_request(req, res, next); + } + } +}; + +/** + * Add a handler for all HTTP verbs to this route. + * + * Behaves just like middleware and can respond or call `next` + * to continue processing. + * + * You can use multiple `.all` call to add multiple handlers. + * + * function check_something(req, res, next){ + * next(); + * }; + * + * function validate_user(req, res, next){ + * next(); + * }; + * + * route + * .all(validate_user) + * .all(check_something) + * .get(function(req, res, next){ + * res.send('hello world'); + * }); + * + * @param {function} handler + * @return {Route} for chaining + * @api public + */ + +Route.prototype.all = function all() { + var handles = flatten(slice.call(arguments)); + + for (var i = 0; i < handles.length; i++) { + var handle = handles[i]; + + if (typeof handle !== 'function') { + var type = toString.call(handle); + var msg = 'Route.all() requires callback functions but got a ' + type; + throw new TypeError(msg); + } + + var layer = Layer('/', {}, handle); + layer.method = undefined; + + this.methods._all = true; + this.stack.push(layer); + } + + return this; +}; + +methods.forEach(function(method){ + Route.prototype[method] = function(){ + var handles = flatten(slice.call(arguments)); + + for (var i = 0; i < handles.length; i++) { + var handle = handles[i]; + + if (typeof handle !== 'function') { + var type = toString.call(handle); + var msg = 'Route.' + method + '() requires callback functions but got a ' + type; + throw new Error(msg); + } + + debug('%s %s', method, this.path); + + var layer = Layer('/', {}, handle); + layer.method = method; + + this.methods[method] = true; + this.stack.push(layer); + } + + return this; + }; +}); diff --git a/node_modules/express/lib/utils.js b/node_modules/express/lib/utils.js new file mode 100644 index 0000000..f418c58 --- /dev/null +++ b/node_modules/express/lib/utils.js @@ -0,0 +1,299 @@ +/*! + * express + * Copyright(c) 2009-2013 TJ Holowaychuk + * Copyright(c) 2014-2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict'; + +/** + * Module dependencies. + * @api private + */ + +var contentDisposition = require('content-disposition'); +var contentType = require('content-type'); +var deprecate = require('depd')('express'); +var flatten = require('array-flatten'); +var mime = require('send').mime; +var basename = require('path').basename; +var etag = require('etag'); +var proxyaddr = require('proxy-addr'); +var qs = require('qs'); +var querystring = require('querystring'); + +/** + * Return strong ETag for `body`. + * + * @param {String|Buffer} body + * @param {String} [encoding] + * @return {String} + * @api private + */ + +exports.etag = function (body, encoding) { + var buf = !Buffer.isBuffer(body) + ? new Buffer(body, encoding) + : body; + + return etag(buf, {weak: false}); +}; + +/** + * Return weak ETag for `body`. + * + * @param {String|Buffer} body + * @param {String} [encoding] + * @return {String} + * @api private + */ + +exports.wetag = function wetag(body, encoding){ + var buf = !Buffer.isBuffer(body) + ? new Buffer(body, encoding) + : body; + + return etag(buf, {weak: true}); +}; + +/** + * Check if `path` looks absolute. + * + * @param {String} path + * @return {Boolean} + * @api private + */ + +exports.isAbsolute = function(path){ + if ('/' === path[0]) return true; + if (':' === path[1] && ('\\' === path[2] || '/' === path[2])) return true; // Windows device path + if ('\\\\' === path.substring(0, 2)) return true; // Microsoft Azure absolute path +}; + +/** + * Flatten the given `arr`. + * + * @param {Array} arr + * @return {Array} + * @api private + */ + +exports.flatten = deprecate.function(flatten, + 'utils.flatten: use array-flatten npm module instead'); + +/** + * Normalize the given `type`, for example "html" becomes "text/html". + * + * @param {String} type + * @return {Object} + * @api private + */ + +exports.normalizeType = function(type){ + return ~type.indexOf('/') + ? acceptParams(type) + : { value: mime.lookup(type), params: {} }; +}; + +/** + * Normalize `types`, for example "html" becomes "text/html". + * + * @param {Array} types + * @return {Array} + * @api private + */ + +exports.normalizeTypes = function(types){ + var ret = []; + + for (var i = 0; i < types.length; ++i) { + ret.push(exports.normalizeType(types[i])); + } + + return ret; +}; + +/** + * Generate Content-Disposition header appropriate for the filename. + * non-ascii filenames are urlencoded and a filename* parameter is added + * + * @param {String} filename + * @return {String} + * @api private + */ + +exports.contentDisposition = deprecate.function(contentDisposition, + 'utils.contentDisposition: use content-disposition npm module instead'); + +/** + * Parse accept params `str` returning an + * object with `.value`, `.quality` and `.params`. + * also includes `.originalIndex` for stable sorting + * + * @param {String} str + * @return {Object} + * @api private + */ + +function acceptParams(str, index) { + var parts = str.split(/ *; */); + var ret = { value: parts[0], quality: 1, params: {}, originalIndex: index }; + + for (var i = 1; i < parts.length; ++i) { + var pms = parts[i].split(/ *= */); + if ('q' === pms[0]) { + ret.quality = parseFloat(pms[1]); + } else { + ret.params[pms[0]] = pms[1]; + } + } + + return ret; +} + +/** + * Compile "etag" value to function. + * + * @param {Boolean|String|Function} val + * @return {Function} + * @api private + */ + +exports.compileETag = function(val) { + var fn; + + if (typeof val === 'function') { + return val; + } + + switch (val) { + case true: + fn = exports.wetag; + break; + case false: + break; + case 'strong': + fn = exports.etag; + break; + case 'weak': + fn = exports.wetag; + break; + default: + throw new TypeError('unknown value for etag function: ' + val); + } + + return fn; +} + +/** + * Compile "query parser" value to function. + * + * @param {String|Function} val + * @return {Function} + * @api private + */ + +exports.compileQueryParser = function compileQueryParser(val) { + var fn; + + if (typeof val === 'function') { + return val; + } + + switch (val) { + case true: + fn = querystring.parse; + break; + case false: + fn = newObject; + break; + case 'extended': + fn = parseExtendedQueryString; + break; + case 'simple': + fn = querystring.parse; + break; + default: + throw new TypeError('unknown value for query parser function: ' + val); + } + + return fn; +} + +/** + * Compile "proxy trust" value to function. + * + * @param {Boolean|String|Number|Array|Function} val + * @return {Function} + * @api private + */ + +exports.compileTrust = function(val) { + if (typeof val === 'function') return val; + + if (val === true) { + // Support plain true/false + return function(){ return true }; + } + + if (typeof val === 'number') { + // Support trusting hop count + return function(a, i){ return i < val }; + } + + if (typeof val === 'string') { + // Support comma-separated values + val = val.split(/ *, */); + } + + return proxyaddr.compile(val || []); +} + +/** + * Set the charset in a given Content-Type string. + * + * @param {String} type + * @param {String} charset + * @return {String} + * @api private + */ + +exports.setCharset = function setCharset(type, charset) { + if (!type || !charset) { + return type; + } + + // parse type + var parsed = contentType.parse(type); + + // set charset + parsed.parameters.charset = charset; + + // format type + return contentType.format(parsed); +}; + +/** + * Parse an extended query string with qs. + * + * @return {Object} + * @private + */ + +function parseExtendedQueryString(str) { + return qs.parse(str, { + allowPrototypes: true + }); +} + +/** + * Return new empty object. + * + * @return {Object} + * @api private + */ + +function newObject() { + return {}; +} diff --git a/node_modules/express/lib/view.js b/node_modules/express/lib/view.js new file mode 100644 index 0000000..52415d4 --- /dev/null +++ b/node_modules/express/lib/view.js @@ -0,0 +1,173 @@ +/*! + * express + * Copyright(c) 2009-2013 TJ Holowaychuk + * Copyright(c) 2013 Roman Shtylman + * Copyright(c) 2014-2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict'; + +/** + * Module dependencies. + * @private + */ + +var debug = require('debug')('express:view'); +var path = require('path'); +var fs = require('fs'); +var utils = require('./utils'); + +/** + * Module variables. + * @private + */ + +var dirname = path.dirname; +var basename = path.basename; +var extname = path.extname; +var join = path.join; +var resolve = path.resolve; + +/** + * Module exports. + * @public + */ + +module.exports = View; + +/** + * Initialize a new `View` with the given `name`. + * + * Options: + * + * - `defaultEngine` the default template engine name + * - `engines` template engine require() cache + * - `root` root path for view lookup + * + * @param {string} name + * @param {object} options + * @public + */ + +function View(name, options) { + var opts = options || {}; + + this.defaultEngine = opts.defaultEngine; + this.ext = extname(name); + this.name = name; + this.root = opts.root; + + if (!this.ext && !this.defaultEngine) { + throw new Error('No default engine was specified and no extension was provided.'); + } + + var fileName = name; + + if (!this.ext) { + // get extension from default engine name + this.ext = this.defaultEngine[0] !== '.' + ? '.' + this.defaultEngine + : this.defaultEngine; + + fileName += this.ext; + } + + if (!opts.engines[this.ext]) { + // load engine + opts.engines[this.ext] = require(this.ext.substr(1)).__express; + } + + // store loaded engine + this.engine = opts.engines[this.ext]; + + // lookup path + this.path = this.lookup(fileName); +} + +/** + * Lookup view by the given `name` + * + * @param {string} name + * @private + */ + +View.prototype.lookup = function lookup(name) { + var path; + var roots = [].concat(this.root); + + debug('lookup "%s"', name); + + for (var i = 0; i < roots.length && !path; i++) { + var root = roots[i]; + + // resolve the path + var loc = resolve(root, name); + var dir = dirname(loc); + var file = basename(loc); + + // resolve the file + path = this.resolve(dir, file); + } + + return path; +}; + +/** + * Render with the given options. + * + * @param {object} options + * @param {function} callback + * @private + */ + +View.prototype.render = function render(options, callback) { + debug('render "%s"', this.path); + this.engine(this.path, options, callback); +}; + +/** + * Resolve the file within the given directory. + * + * @param {string} dir + * @param {string} file + * @private + */ + +View.prototype.resolve = function resolve(dir, file) { + var ext = this.ext; + + // . + var path = join(dir, file); + var stat = tryStat(path); + + if (stat && stat.isFile()) { + return path; + } + + // /index. + path = join(dir, basename(file, ext), 'index' + ext); + stat = tryStat(path); + + if (stat && stat.isFile()) { + return path; + } +}; + +/** + * Return a stat, maybe. + * + * @param {string} path + * @return {fs.Stats} + * @private + */ + +function tryStat(path) { + debug('stat "%s"', path); + + try { + return fs.statSync(path); + } catch (e) { + return undefined; + } +} diff --git a/node_modules/express/node_modules/accepts/HISTORY.md b/node_modules/express/node_modules/accepts/HISTORY.md new file mode 100644 index 0000000..0477ed7 --- /dev/null +++ b/node_modules/express/node_modules/accepts/HISTORY.md @@ -0,0 +1,212 @@ +1.3.3 / 2016-05-02 +================== + + * deps: mime-types@~2.1.11 + - deps: mime-db@~1.23.0 + * deps: negotiator@0.6.1 + - perf: improve `Accept` parsing speed + - perf: improve `Accept-Charset` parsing speed + - perf: improve `Accept-Encoding` parsing speed + - perf: improve `Accept-Language` parsing speed + +1.3.2 / 2016-03-08 +================== + + * deps: mime-types@~2.1.10 + - Fix extension of `application/dash+xml` + - Update primary extension for `audio/mp4` + - deps: mime-db@~1.22.0 + +1.3.1 / 2016-01-19 +================== + + * deps: mime-types@~2.1.9 + - deps: mime-db@~1.21.0 + +1.3.0 / 2015-09-29 +================== + + * deps: mime-types@~2.1.7 + - deps: mime-db@~1.19.0 + * deps: negotiator@0.6.0 + - Fix including type extensions in parameters in `Accept` parsing + - Fix parsing `Accept` parameters with quoted equals + - Fix parsing `Accept` parameters with quoted semicolons + - Lazy-load modules from main entry point + - perf: delay type concatenation until needed + - perf: enable strict mode + - perf: hoist regular expressions + - perf: remove closures getting spec properties + - perf: remove a closure from media type parsing + - perf: remove property delete from media type parsing + +1.2.13 / 2015-09-06 +=================== + + * deps: mime-types@~2.1.6 + - deps: mime-db@~1.18.0 + +1.2.12 / 2015-07-30 +=================== + + * deps: mime-types@~2.1.4 + - deps: mime-db@~1.16.0 + +1.2.11 / 2015-07-16 +=================== + + * deps: mime-types@~2.1.3 + - deps: mime-db@~1.15.0 + +1.2.10 / 2015-07-01 +=================== + + * deps: mime-types@~2.1.2 + - deps: mime-db@~1.14.0 + +1.2.9 / 2015-06-08 +================== + + * deps: mime-types@~2.1.1 + - perf: fix deopt during mapping + +1.2.8 / 2015-06-07 +================== + + * deps: mime-types@~2.1.0 + - deps: mime-db@~1.13.0 + * perf: avoid argument reassignment & argument slice + * perf: avoid negotiator recursive construction + * perf: enable strict mode + * perf: remove unnecessary bitwise operator + +1.2.7 / 2015-05-10 +================== + + * deps: negotiator@0.5.3 + - Fix media type parameter matching to be case-insensitive + +1.2.6 / 2015-05-07 +================== + + * deps: mime-types@~2.0.11 + - deps: mime-db@~1.9.1 + * deps: negotiator@0.5.2 + - Fix comparing media types with quoted values + - Fix splitting media types with quoted commas + +1.2.5 / 2015-03-13 +================== + + * deps: mime-types@~2.0.10 + - deps: mime-db@~1.8.0 + +1.2.4 / 2015-02-14 +================== + + * Support Node.js 0.6 + * deps: mime-types@~2.0.9 + - deps: mime-db@~1.7.0 + * deps: negotiator@0.5.1 + - Fix preference sorting to be stable for long acceptable lists + +1.2.3 / 2015-01-31 +================== + + * deps: mime-types@~2.0.8 + - deps: mime-db@~1.6.0 + +1.2.2 / 2014-12-30 +================== + + * deps: mime-types@~2.0.7 + - deps: mime-db@~1.5.0 + +1.2.1 / 2014-12-30 +================== + + * deps: mime-types@~2.0.5 + - deps: mime-db@~1.3.1 + +1.2.0 / 2014-12-19 +================== + + * deps: negotiator@0.5.0 + - Fix list return order when large accepted list + - Fix missing identity encoding when q=0 exists + - Remove dynamic building of Negotiator class + +1.1.4 / 2014-12-10 +================== + + * deps: mime-types@~2.0.4 + - deps: mime-db@~1.3.0 + +1.1.3 / 2014-11-09 +================== + + * deps: mime-types@~2.0.3 + - deps: mime-db@~1.2.0 + +1.1.2 / 2014-10-14 +================== + + * deps: negotiator@0.4.9 + - Fix error when media type has invalid parameter + +1.1.1 / 2014-09-28 +================== + + * deps: mime-types@~2.0.2 + - deps: mime-db@~1.1.0 + * deps: negotiator@0.4.8 + - Fix all negotiations to be case-insensitive + - Stable sort preferences of same quality according to client order + +1.1.0 / 2014-09-02 +================== + + * update `mime-types` + +1.0.7 / 2014-07-04 +================== + + * Fix wrong type returned from `type` when match after unknown extension + +1.0.6 / 2014-06-24 +================== + + * deps: negotiator@0.4.7 + +1.0.5 / 2014-06-20 +================== + + * fix crash when unknown extension given + +1.0.4 / 2014-06-19 +================== + + * use `mime-types` + +1.0.3 / 2014-06-11 +================== + + * deps: negotiator@0.4.6 + - Order by specificity when quality is the same + +1.0.2 / 2014-05-29 +================== + + * Fix interpretation when header not in request + * deps: pin negotiator@0.4.5 + +1.0.1 / 2014-01-18 +================== + + * Identity encoding isn't always acceptable + * deps: negotiator@~0.4.0 + +1.0.0 / 2013-12-27 +================== + + * Genesis diff --git a/node_modules/express/node_modules/accepts/LICENSE b/node_modules/express/node_modules/accepts/LICENSE new file mode 100644 index 0000000..0616607 --- /dev/null +++ b/node_modules/express/node_modules/accepts/LICENSE @@ -0,0 +1,23 @@ +(The MIT License) + +Copyright (c) 2014 Jonathan Ong +Copyright (c) 2015 Douglas Christopher Wilson + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/express/node_modules/accepts/README.md b/node_modules/express/node_modules/accepts/README.md new file mode 100644 index 0000000..ae36676 --- /dev/null +++ b/node_modules/express/node_modules/accepts/README.md @@ -0,0 +1,135 @@ +# accepts + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Node.js Version][node-version-image]][node-version-url] +[![Build Status][travis-image]][travis-url] +[![Test Coverage][coveralls-image]][coveralls-url] + +Higher level content negotiation based on [negotiator](https://www.npmjs.com/package/negotiator). Extracted from [koa](https://www.npmjs.com/package/koa) for general use. + +In addition to negotiator, it allows: + +- Allows types as an array or arguments list, ie `(['text/html', 'application/json'])` as well as `('text/html', 'application/json')`. +- Allows type shorthands such as `json`. +- Returns `false` when no types match +- Treats non-existent headers as `*` + +## Installation + +```sh +npm install accepts +``` + +## API + +```js +var accepts = require('accepts') +``` + +### accepts(req) + +Create a new `Accepts` object for the given `req`. + +#### .charset(charsets) + +Return the first accepted charset. If nothing in `charsets` is accepted, +then `false` is returned. + +#### .charsets() + +Return the charsets that the request accepts, in the order of the client's +preference (most preferred first). + +#### .encoding(encodings) + +Return the first accepted encoding. If nothing in `encodings` is accepted, +then `false` is returned. + +#### .encodings() + +Return the encodings that the request accepts, in the order of the client's +preference (most preferred first). + +#### .language(languages) + +Return the first accepted language. If nothing in `languages` is accepted, +then `false` is returned. + +#### .languages() + +Return the languages that the request accepts, in the order of the client's +preference (most preferred first). + +#### .type(types) + +Return the first accepted type (and it is returned as the same text as what +appears in the `types` array). If nothing in `types` is accepted, then `false` +is returned. + +The `types` array can contain full MIME types or file extensions. Any value +that is not a full MIME types is passed to `require('mime-types').lookup`. + +#### .types() + +Return the types that the request accepts, in the order of the client's +preference (most preferred first). + +## Examples + +### Simple type negotiation + +This simple example shows how to use `accepts` to return a different typed +respond body based on what the client wants to accept. The server lists it's +preferences in order and will get back the best match between the client and +server. + +```js +var accepts = require('accepts') +var http = require('http') + +function app(req, res) { + var accept = accepts(req) + + // the order of this list is significant; should be server preferred order + switch(accept.type(['json', 'html'])) { + case 'json': + res.setHeader('Content-Type', 'application/json') + res.write('{"hello":"world!"}') + break + case 'html': + res.setHeader('Content-Type', 'text/html') + res.write('hello, world!') + break + default: + // the fallback is text/plain, so no need to specify it above + res.setHeader('Content-Type', 'text/plain') + res.write('hello, world!') + break + } + + res.end() +} + +http.createServer(app).listen(3000) +``` + +You can test this out with the cURL program: +```sh +curl -I -H'Accept: text/html' http://localhost:3000/ +``` + +## License + +[MIT](LICENSE) + +[npm-image]: https://img.shields.io/npm/v/accepts.svg +[npm-url]: https://npmjs.org/package/accepts +[node-version-image]: https://img.shields.io/node/v/accepts.svg +[node-version-url]: http://nodejs.org/download/ +[travis-image]: https://img.shields.io/travis/jshttp/accepts/master.svg +[travis-url]: https://travis-ci.org/jshttp/accepts +[coveralls-image]: https://img.shields.io/coveralls/jshttp/accepts/master.svg +[coveralls-url]: https://coveralls.io/r/jshttp/accepts +[downloads-image]: https://img.shields.io/npm/dm/accepts.svg +[downloads-url]: https://npmjs.org/package/accepts diff --git a/node_modules/express/node_modules/accepts/index.js b/node_modules/express/node_modules/accepts/index.js new file mode 100644 index 0000000..e80192a --- /dev/null +++ b/node_modules/express/node_modules/accepts/index.js @@ -0,0 +1,231 @@ +/*! + * accepts + * Copyright(c) 2014 Jonathan Ong + * Copyright(c) 2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module dependencies. + * @private + */ + +var Negotiator = require('negotiator') +var mime = require('mime-types') + +/** + * Module exports. + * @public + */ + +module.exports = Accepts + +/** + * Create a new Accepts object for the given req. + * + * @param {object} req + * @public + */ + +function Accepts(req) { + if (!(this instanceof Accepts)) + return new Accepts(req) + + this.headers = req.headers + this.negotiator = new Negotiator(req) +} + +/** + * Check if the given `type(s)` is acceptable, returning + * the best match when true, otherwise `undefined`, in which + * case you should respond with 406 "Not Acceptable". + * + * The `type` value may be a single mime type string + * such as "application/json", the extension name + * such as "json" or an array `["json", "html", "text/plain"]`. When a list + * or array is given the _best_ match, if any is returned. + * + * Examples: + * + * // Accept: text/html + * this.types('html'); + * // => "html" + * + * // Accept: text/*, application/json + * this.types('html'); + * // => "html" + * this.types('text/html'); + * // => "text/html" + * this.types('json', 'text'); + * // => "json" + * this.types('application/json'); + * // => "application/json" + * + * // Accept: text/*, application/json + * this.types('image/png'); + * this.types('png'); + * // => undefined + * + * // Accept: text/*;q=.5, application/json + * this.types(['html', 'json']); + * this.types('html', 'json'); + * // => "json" + * + * @param {String|Array} types... + * @return {String|Array|Boolean} + * @public + */ + +Accepts.prototype.type = +Accepts.prototype.types = function (types_) { + var types = types_ + + // support flattened arguments + if (types && !Array.isArray(types)) { + types = new Array(arguments.length) + for (var i = 0; i < types.length; i++) { + types[i] = arguments[i] + } + } + + // no types, return all requested types + if (!types || types.length === 0) { + return this.negotiator.mediaTypes() + } + + if (!this.headers.accept) return types[0]; + var mimes = types.map(extToMime); + var accepts = this.negotiator.mediaTypes(mimes.filter(validMime)); + var first = accepts[0]; + if (!first) return false; + return types[mimes.indexOf(first)]; +} + +/** + * Return accepted encodings or best fit based on `encodings`. + * + * Given `Accept-Encoding: gzip, deflate` + * an array sorted by quality is returned: + * + * ['gzip', 'deflate'] + * + * @param {String|Array} encodings... + * @return {String|Array} + * @public + */ + +Accepts.prototype.encoding = +Accepts.prototype.encodings = function (encodings_) { + var encodings = encodings_ + + // support flattened arguments + if (encodings && !Array.isArray(encodings)) { + encodings = new Array(arguments.length) + for (var i = 0; i < encodings.length; i++) { + encodings[i] = arguments[i] + } + } + + // no encodings, return all requested encodings + if (!encodings || encodings.length === 0) { + return this.negotiator.encodings() + } + + return this.negotiator.encodings(encodings)[0] || false +} + +/** + * Return accepted charsets or best fit based on `charsets`. + * + * Given `Accept-Charset: utf-8, iso-8859-1;q=0.2, utf-7;q=0.5` + * an array sorted by quality is returned: + * + * ['utf-8', 'utf-7', 'iso-8859-1'] + * + * @param {String|Array} charsets... + * @return {String|Array} + * @public + */ + +Accepts.prototype.charset = +Accepts.prototype.charsets = function (charsets_) { + var charsets = charsets_ + + // support flattened arguments + if (charsets && !Array.isArray(charsets)) { + charsets = new Array(arguments.length) + for (var i = 0; i < charsets.length; i++) { + charsets[i] = arguments[i] + } + } + + // no charsets, return all requested charsets + if (!charsets || charsets.length === 0) { + return this.negotiator.charsets() + } + + return this.negotiator.charsets(charsets)[0] || false +} + +/** + * Return accepted languages or best fit based on `langs`. + * + * Given `Accept-Language: en;q=0.8, es, pt` + * an array sorted by quality is returned: + * + * ['es', 'pt', 'en'] + * + * @param {String|Array} langs... + * @return {Array|String} + * @public + */ + +Accepts.prototype.lang = +Accepts.prototype.langs = +Accepts.prototype.language = +Accepts.prototype.languages = function (languages_) { + var languages = languages_ + + // support flattened arguments + if (languages && !Array.isArray(languages)) { + languages = new Array(arguments.length) + for (var i = 0; i < languages.length; i++) { + languages[i] = arguments[i] + } + } + + // no languages, return all requested languages + if (!languages || languages.length === 0) { + return this.negotiator.languages() + } + + return this.negotiator.languages(languages)[0] || false +} + +/** + * Convert extnames to mime. + * + * @param {String} type + * @return {String} + * @private + */ + +function extToMime(type) { + return type.indexOf('/') === -1 + ? mime.lookup(type) + : type +} + +/** + * Check if mime is valid. + * + * @param {String} type + * @return {String} + * @private + */ + +function validMime(type) { + return typeof type === 'string'; +} diff --git a/node_modules/express/node_modules/accepts/node_modules/mime-types/HISTORY.md b/node_modules/express/node_modules/accepts/node_modules/mime-types/HISTORY.md new file mode 100644 index 0000000..8c0383a --- /dev/null +++ b/node_modules/express/node_modules/accepts/node_modules/mime-types/HISTORY.md @@ -0,0 +1,204 @@ +2.1.12 / 2016-09-18 +=================== + + * deps: mime-db@~1.24.0 + - Add new mime types + - Add `audio/mp3` + +2.1.11 / 2016-05-01 +=================== + + * deps: mime-db@~1.23.0 + - Add new mime types + +2.1.10 / 2016-02-15 +=================== + + * deps: mime-db@~1.22.0 + - Add new mime types + - Fix extension of `application/dash+xml` + - Update primary extension for `audio/mp4` + +2.1.9 / 2016-01-06 +================== + + * deps: mime-db@~1.21.0 + - Add new mime types + +2.1.8 / 2015-11-30 +================== + + * deps: mime-db@~1.20.0 + - Add new mime types + +2.1.7 / 2015-09-20 +================== + + * deps: mime-db@~1.19.0 + - Add new mime types + +2.1.6 / 2015-09-03 +================== + + * deps: mime-db@~1.18.0 + - Add new mime types + +2.1.5 / 2015-08-20 +================== + + * deps: mime-db@~1.17.0 + - Add new mime types + +2.1.4 / 2015-07-30 +================== + + * deps: mime-db@~1.16.0 + - Add new mime types + +2.1.3 / 2015-07-13 +================== + + * deps: mime-db@~1.15.0 + - Add new mime types + +2.1.2 / 2015-06-25 +================== + + * deps: mime-db@~1.14.0 + - Add new mime types + +2.1.1 / 2015-06-08 +================== + + * perf: fix deopt during mapping + +2.1.0 / 2015-06-07 +================== + + * Fix incorrectly treating extension-less file name as extension + - i.e. `'path/to/json'` will no longer return `application/json` + * Fix `.charset(type)` to accept parameters + * Fix `.charset(type)` to match case-insensitive + * Improve generation of extension to MIME mapping + * Refactor internals for readability and no argument reassignment + * Prefer `application/*` MIME types from the same source + * Prefer any type over `application/octet-stream` + * deps: mime-db@~1.13.0 + - Add nginx as a source + - Add new mime types + +2.0.14 / 2015-06-06 +=================== + + * deps: mime-db@~1.12.0 + - Add new mime types + +2.0.13 / 2015-05-31 +=================== + + * deps: mime-db@~1.11.0 + - Add new mime types + +2.0.12 / 2015-05-19 +=================== + + * deps: mime-db@~1.10.0 + - Add new mime types + +2.0.11 / 2015-05-05 +=================== + + * deps: mime-db@~1.9.1 + - Add new mime types + +2.0.10 / 2015-03-13 +=================== + + * deps: mime-db@~1.8.0 + - Add new mime types + +2.0.9 / 2015-02-09 +================== + + * deps: mime-db@~1.7.0 + - Add new mime types + - Community extensions ownership transferred from `node-mime` + +2.0.8 / 2015-01-29 +================== + + * deps: mime-db@~1.6.0 + - Add new mime types + +2.0.7 / 2014-12-30 +================== + + * deps: mime-db@~1.5.0 + - Add new mime types + - Fix various invalid MIME type entries + +2.0.6 / 2014-12-30 +================== + + * deps: mime-db@~1.4.0 + - Add new mime types + - Fix various invalid MIME type entries + - Remove example template MIME types + +2.0.5 / 2014-12-29 +================== + + * deps: mime-db@~1.3.1 + - Fix missing extensions + +2.0.4 / 2014-12-10 +================== + + * deps: mime-db@~1.3.0 + - Add new mime types + +2.0.3 / 2014-11-09 +================== + + * deps: mime-db@~1.2.0 + - Add new mime types + +2.0.2 / 2014-09-28 +================== + + * deps: mime-db@~1.1.0 + - Add new mime types + - Add additional compressible + - Update charsets + +2.0.1 / 2014-09-07 +================== + + * Support Node.js 0.6 + +2.0.0 / 2014-09-02 +================== + + * Use `mime-db` + * Remove `.define()` + +1.0.2 / 2014-08-04 +================== + + * Set charset=utf-8 for `text/javascript` + +1.0.1 / 2014-06-24 +================== + + * Add `text/jsx` type + +1.0.0 / 2014-05-12 +================== + + * Return `false` for unknown types + * Set charset=utf-8 for `application/json` + +0.1.0 / 2014-05-02 +================== + + * Initial release diff --git a/node_modules/express/node_modules/accepts/node_modules/mime-types/LICENSE b/node_modules/express/node_modules/accepts/node_modules/mime-types/LICENSE new file mode 100644 index 0000000..0616607 --- /dev/null +++ b/node_modules/express/node_modules/accepts/node_modules/mime-types/LICENSE @@ -0,0 +1,23 @@ +(The MIT License) + +Copyright (c) 2014 Jonathan Ong +Copyright (c) 2015 Douglas Christopher Wilson + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/express/node_modules/accepts/node_modules/mime-types/README.md b/node_modules/express/node_modules/accepts/node_modules/mime-types/README.md new file mode 100644 index 0000000..e77d615 --- /dev/null +++ b/node_modules/express/node_modules/accepts/node_modules/mime-types/README.md @@ -0,0 +1,103 @@ +# mime-types + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Node.js Version][node-version-image]][node-version-url] +[![Build Status][travis-image]][travis-url] +[![Test Coverage][coveralls-image]][coveralls-url] + +The ultimate javascript content-type utility. + +Similar to [node-mime](https://github.com/broofa/node-mime), except: + +- __No fallbacks.__ Instead of naively returning the first available type, `mime-types` simply returns `false`, + so do `var type = mime.lookup('unrecognized') || 'application/octet-stream'`. +- No `new Mime()` business, so you could do `var lookup = require('mime-types').lookup`. +- Additional mime types are added such as jade and stylus via [mime-db](https://github.com/jshttp/mime-db) +- No `.define()` functionality + +Otherwise, the API is compatible. + +## Install + +```sh +$ npm install mime-types +``` + +## Adding Types + +All mime types are based on [mime-db](https://github.com/jshttp/mime-db), +so open a PR there if you'd like to add mime types. + +## API + +```js +var mime = require('mime-types') +``` + +All functions return `false` if input is invalid or not found. + +### mime.lookup(path) + +Lookup the content-type associated with a file. + +```js +mime.lookup('json') // 'application/json' +mime.lookup('.md') // 'text/x-markdown' +mime.lookup('file.html') // 'text/html' +mime.lookup('folder/file.js') // 'application/javascript' +mime.lookup('folder/.htaccess') // false + +mime.lookup('cats') // false +``` + +### mime.contentType(type) + +Create a full content-type header given a content-type or extension. + +```js +mime.contentType('markdown') // 'text/x-markdown; charset=utf-8' +mime.contentType('file.json') // 'application/json; charset=utf-8' + +// from a full path +mime.contentType(path.extname('/path/to/file.json')) // 'application/json; charset=utf-8' +``` + +### mime.extension(type) + +Get the default extension for a content-type. + +```js +mime.extension('application/octet-stream') // 'bin' +``` + +### mime.charset(type) + +Lookup the implied default charset of a content-type. + +```js +mime.charset('text/x-markdown') // 'UTF-8' +``` + +### var type = mime.types[extension] + +A map of content-types by extension. + +### [extensions...] = mime.extensions[type] + +A map of extensions by content-type. + +## License + +[MIT](LICENSE) + +[npm-image]: https://img.shields.io/npm/v/mime-types.svg +[npm-url]: https://npmjs.org/package/mime-types +[node-version-image]: https://img.shields.io/node/v/mime-types.svg +[node-version-url]: https://nodejs.org/en/download/ +[travis-image]: https://img.shields.io/travis/jshttp/mime-types/master.svg +[travis-url]: https://travis-ci.org/jshttp/mime-types +[coveralls-image]: https://img.shields.io/coveralls/jshttp/mime-types/master.svg +[coveralls-url]: https://coveralls.io/r/jshttp/mime-types +[downloads-image]: https://img.shields.io/npm/dm/mime-types.svg +[downloads-url]: https://npmjs.org/package/mime-types diff --git a/node_modules/express/node_modules/accepts/node_modules/mime-types/index.js b/node_modules/express/node_modules/accepts/node_modules/mime-types/index.js new file mode 100644 index 0000000..9226ca5 --- /dev/null +++ b/node_modules/express/node_modules/accepts/node_modules/mime-types/index.js @@ -0,0 +1,188 @@ +/*! + * mime-types + * Copyright(c) 2014 Jonathan Ong + * Copyright(c) 2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module dependencies. + * @private + */ + +var db = require('mime-db') +var extname = require('path').extname + +/** + * Module variables. + * @private + */ + +var extractTypeRegExp = /^\s*([^;\s]*)(?:;|\s|$)/ +var textTypeRegExp = /^text\//i + +/** + * Module exports. + * @public + */ + +exports.charset = charset +exports.charsets = { lookup: charset } +exports.contentType = contentType +exports.extension = extension +exports.extensions = Object.create(null) +exports.lookup = lookup +exports.types = Object.create(null) + +// Populate the extensions/types maps +populateMaps(exports.extensions, exports.types) + +/** + * Get the default charset for a MIME type. + * + * @param {string} type + * @return {boolean|string} + */ + +function charset (type) { + if (!type || typeof type !== 'string') { + return false + } + + // TODO: use media-typer + var match = extractTypeRegExp.exec(type) + var mime = match && db[match[1].toLowerCase()] + + if (mime && mime.charset) { + return mime.charset + } + + // default text/* to utf-8 + if (match && textTypeRegExp.test(match[1])) { + return 'UTF-8' + } + + return false +} + +/** + * Create a full Content-Type header given a MIME type or extension. + * + * @param {string} str + * @return {boolean|string} + */ + +function contentType (str) { + // TODO: should this even be in this module? + if (!str || typeof str !== 'string') { + return false + } + + var mime = str.indexOf('/') === -1 + ? exports.lookup(str) + : str + + if (!mime) { + return false + } + + // TODO: use content-type or other module + if (mime.indexOf('charset') === -1) { + var charset = exports.charset(mime) + if (charset) mime += '; charset=' + charset.toLowerCase() + } + + return mime +} + +/** + * Get the default extension for a MIME type. + * + * @param {string} type + * @return {boolean|string} + */ + +function extension (type) { + if (!type || typeof type !== 'string') { + return false + } + + // TODO: use media-typer + var match = extractTypeRegExp.exec(type) + + // get extensions + var exts = match && exports.extensions[match[1].toLowerCase()] + + if (!exts || !exts.length) { + return false + } + + return exts[0] +} + +/** + * Lookup the MIME type for a file path/extension. + * + * @param {string} path + * @return {boolean|string} + */ + +function lookup (path) { + if (!path || typeof path !== 'string') { + return false + } + + // get the extension ("ext" or ".ext" or full path) + var extension = extname('x.' + path) + .toLowerCase() + .substr(1) + + if (!extension) { + return false + } + + return exports.types[extension] || false +} + +/** + * Populate the extensions and types maps. + * @private + */ + +function populateMaps (extensions, types) { + // source preference (least -> most) + var preference = ['nginx', 'apache', undefined, 'iana'] + + Object.keys(db).forEach(function forEachMimeType (type) { + var mime = db[type] + var exts = mime.extensions + + if (!exts || !exts.length) { + return + } + + // mime -> extensions + extensions[type] = exts + + // extension -> mime + for (var i = 0; i < exts.length; i++) { + var extension = exts[i] + + if (types[extension]) { + var from = preference.indexOf(db[types[extension]].source) + var to = preference.indexOf(mime.source) + + if (types[extension] !== 'application/octet-stream' && + from > to || (from === to && types[extension].substr(0, 12) === 'application/')) { + // skip the remapping + continue + } + } + + // set the extension -> mime + types[extension] = type + } + }) +} diff --git a/node_modules/express/node_modules/accepts/node_modules/mime-types/node_modules/mime-db/HISTORY.md b/node_modules/express/node_modules/accepts/node_modules/mime-types/node_modules/mime-db/HISTORY.md new file mode 100644 index 0000000..d4796b5 --- /dev/null +++ b/node_modules/express/node_modules/accepts/node_modules/mime-types/node_modules/mime-db/HISTORY.md @@ -0,0 +1,365 @@ +1.24.0 / 2016-09-18 +=================== + + * Add `application/clue_info+xml` + * Add `application/geo+json` + * Add `application/lgr+xml` + * Add `application/vnd.amazon.mobi8-ebook` + * Add `application/vnd.chess-pgn` + * Add `application/vnd.comicbook+zip` + * Add `application/vnd.d2l.coursepackage1p0+zip` + * Add `application/vnd.espass-espass+zip` + * Add `application/vnd.nearst.inv+json` + * Add `application/vnd.oma.lwm2m+json` + * Add `application/vnd.oma.lwm2m+tlv` + * Add `application/vnd.quarantainenet` + * Add `application/vnd.rar` + * Add `audio/mp3` + * Add `image/dicom-rle` + * Add `image/emf` + * Add `image/jls` + * Add `image/wmf` + * Add `model/gltf+json` + * Add `text/vnd.ascii-art` + +1.23.0 / 2016-05-01 +=================== + + * Add `application/efi` + * Add `application/vnd.3gpp.sms+xml` + * Add `application/vnd.3lightssoftware.imagescal` + * Add `application/vnd.coreos.ignition+json` + * Add `application/vnd.desmume.movie` + * Add `application/vnd.onepager` + * Add `application/vnd.vel+json` + * Add `text/prs.prop.logic` + * Add `video/encaprtp` + * Add `video/h265` + * Add `video/iso.segment` + * Add `video/raptorfec` + * Add `video/rtploopback` + * Add `video/vnd.radgamettools.bink` + * Add `video/vnd.radgamettools.smacker` + * Add `video/vp8` + * Add extension `.3gpp` to `audio/3gpp` + +1.22.0 / 2016-02-15 +=================== + + * Add `application/ppsp-tracker+json` + * Add `application/problem+json` + * Add `application/problem+xml` + * Add `application/vnd.hdt` + * Add `application/vnd.ms-printschematicket+xml` + * Add `model/vnd.rosette.annotated-data-model` + * Add `text/slim` + * Add extension `.rng` to `application/xml` + * Fix extension of `application/dash+xml` to be `.mpd` + * Update primary extension to `.m4a` for `audio/mp4` + +1.21.0 / 2016-01-06 +=================== + + * Add `application/emergencycalldata.comment+xml` + * Add `application/emergencycalldata.deviceinfo+xml` + * Add `application/emergencycalldata.providerinfo+xml` + * Add `application/emergencycalldata.serviceinfo+xml` + * Add `application/emergencycalldata.subscriberinfo+xml` + * Add `application/vnd.filmit.zfc` + * Add `application/vnd.google-apps.document` + * Add `application/vnd.google-apps.presentation` + * Add `application/vnd.google-apps.spreadsheet` + * Add `application/vnd.mapbox-vector-tile` + * Add `application/vnd.ms-printdevicecapabilities+xml` + * Add `application/vnd.ms-windows.devicepairing` + * Add `application/vnd.ms-windows.nwprinting.oob` + * Add `application/vnd.tml` + * Add `audio/evs` + +1.20.0 / 2015-11-10 +=================== + + * Add `application/cdni` + * Add `application/csvm+json` + * Add `application/rfc+xml` + * Add `application/vnd.3gpp.access-transfer-events+xml` + * Add `application/vnd.3gpp.srvcc-ext+xml` + * Add `application/vnd.ms-windows.wsd.oob` + * Add `application/vnd.oxli.countgraph` + * Add `application/vnd.pagerduty+json` + * Add `text/x-suse-ymp` + +1.19.0 / 2015-09-17 +=================== + + * Add `application/vnd.3gpp-prose-pc3ch+xml` + * Add `application/vnd.3gpp.srvcc-info+xml` + * Add `application/vnd.apple.pkpass` + * Add `application/vnd.drive+json` + +1.18.0 / 2015-09-03 +=================== + + * Add `application/pkcs12` + * Add `application/vnd.3gpp-prose+xml` + * Add `application/vnd.3gpp.mid-call+xml` + * Add `application/vnd.3gpp.state-and-event-info+xml` + * Add `application/vnd.anki` + * Add `application/vnd.firemonkeys.cloudcell` + * Add `application/vnd.openblox.game+xml` + * Add `application/vnd.openblox.game-binary` + +1.17.0 / 2015-08-13 +=================== + + * Add `application/x-msdos-program` + * Add `audio/g711-0` + * Add `image/vnd.mozilla.apng` + * Add extension `.exe` to `application/x-msdos-program` + +1.16.0 / 2015-07-29 +=================== + + * Add `application/vnd.uri-map` + +1.15.0 / 2015-07-13 +=================== + + * Add `application/x-httpd-php` + +1.14.0 / 2015-06-25 +=================== + + * Add `application/scim+json` + * Add `application/vnd.3gpp.ussd+xml` + * Add `application/vnd.biopax.rdf+xml` + * Add `text/x-processing` + +1.13.0 / 2015-06-07 +=================== + + * Add nginx as a source + * Add `application/x-cocoa` + * Add `application/x-java-archive-diff` + * Add `application/x-makeself` + * Add `application/x-perl` + * Add `application/x-pilot` + * Add `application/x-redhat-package-manager` + * Add `application/x-sea` + * Add `audio/x-m4a` + * Add `audio/x-realaudio` + * Add `image/x-jng` + * Add `text/mathml` + +1.12.0 / 2015-06-05 +=================== + + * Add `application/bdoc` + * Add `application/vnd.hyperdrive+json` + * Add `application/x-bdoc` + * Add extension `.rtf` to `text/rtf` + +1.11.0 / 2015-05-31 +=================== + + * Add `audio/wav` + * Add `audio/wave` + * Add extension `.litcoffee` to `text/coffeescript` + * Add extension `.sfd-hdstx` to `application/vnd.hydrostatix.sof-data` + * Add extension `.n-gage` to `application/vnd.nokia.n-gage.symbian.install` + +1.10.0 / 2015-05-19 +=================== + + * Add `application/vnd.balsamiq.bmpr` + * Add `application/vnd.microsoft.portable-executable` + * Add `application/x-ns-proxy-autoconfig` + +1.9.1 / 2015-04-19 +================== + + * Remove `.json` extension from `application/manifest+json` + - This is causing bugs downstream + +1.9.0 / 2015-04-19 +================== + + * Add `application/manifest+json` + * Add `application/vnd.micro+json` + * Add `image/vnd.zbrush.pcx` + * Add `image/x-ms-bmp` + +1.8.0 / 2015-03-13 +================== + + * Add `application/vnd.citationstyles.style+xml` + * Add `application/vnd.fastcopy-disk-image` + * Add `application/vnd.gov.sk.xmldatacontainer+xml` + * Add extension `.jsonld` to `application/ld+json` + +1.7.0 / 2015-02-08 +================== + + * Add `application/vnd.gerber` + * Add `application/vnd.msa-disk-image` + +1.6.1 / 2015-02-05 +================== + + * Community extensions ownership transferred from `node-mime` + +1.6.0 / 2015-01-29 +================== + + * Add `application/jose` + * Add `application/jose+json` + * Add `application/json-seq` + * Add `application/jwk+json` + * Add `application/jwk-set+json` + * Add `application/jwt` + * Add `application/rdap+json` + * Add `application/vnd.gov.sk.e-form+xml` + * Add `application/vnd.ims.imsccv1p3` + +1.5.0 / 2014-12-30 +================== + + * Add `application/vnd.oracle.resource+json` + * Fix various invalid MIME type entries + - `application/mbox+xml` + - `application/oscp-response` + - `application/vwg-multiplexed` + - `audio/g721` + +1.4.0 / 2014-12-21 +================== + + * Add `application/vnd.ims.imsccv1p2` + * Fix various invalid MIME type entries + - `application/vnd-acucobol` + - `application/vnd-curl` + - `application/vnd-dart` + - `application/vnd-dxr` + - `application/vnd-fdf` + - `application/vnd-mif` + - `application/vnd-sema` + - `application/vnd-wap-wmlc` + - `application/vnd.adobe.flash-movie` + - `application/vnd.dece-zip` + - `application/vnd.dvb_service` + - `application/vnd.micrografx-igx` + - `application/vnd.sealed-doc` + - `application/vnd.sealed-eml` + - `application/vnd.sealed-mht` + - `application/vnd.sealed-ppt` + - `application/vnd.sealed-tiff` + - `application/vnd.sealed-xls` + - `application/vnd.sealedmedia.softseal-html` + - `application/vnd.sealedmedia.softseal-pdf` + - `application/vnd.wap-slc` + - `application/vnd.wap-wbxml` + - `audio/vnd.sealedmedia.softseal-mpeg` + - `image/vnd-djvu` + - `image/vnd-svf` + - `image/vnd-wap-wbmp` + - `image/vnd.sealed-png` + - `image/vnd.sealedmedia.softseal-gif` + - `image/vnd.sealedmedia.softseal-jpg` + - `model/vnd-dwf` + - `model/vnd.parasolid.transmit-binary` + - `model/vnd.parasolid.transmit-text` + - `text/vnd-a` + - `text/vnd-curl` + - `text/vnd.wap-wml` + * Remove example template MIME types + - `application/example` + - `audio/example` + - `image/example` + - `message/example` + - `model/example` + - `multipart/example` + - `text/example` + - `video/example` + +1.3.1 / 2014-12-16 +================== + + * Fix missing extensions + - `application/json5` + - `text/hjson` + +1.3.0 / 2014-12-07 +================== + + * Add `application/a2l` + * Add `application/aml` + * Add `application/atfx` + * Add `application/atxml` + * Add `application/cdfx+xml` + * Add `application/dii` + * Add `application/json5` + * Add `application/lxf` + * Add `application/mf4` + * Add `application/vnd.apache.thrift.compact` + * Add `application/vnd.apache.thrift.json` + * Add `application/vnd.coffeescript` + * Add `application/vnd.enphase.envoy` + * Add `application/vnd.ims.imsccv1p1` + * Add `text/csv-schema` + * Add `text/hjson` + * Add `text/markdown` + * Add `text/yaml` + +1.2.0 / 2014-11-09 +================== + + * Add `application/cea` + * Add `application/dit` + * Add `application/vnd.gov.sk.e-form+zip` + * Add `application/vnd.tmd.mediaflex.api+xml` + * Type `application/epub+zip` is now IANA-registered + +1.1.2 / 2014-10-23 +================== + + * Rebuild database for `application/x-www-form-urlencoded` change + +1.1.1 / 2014-10-20 +================== + + * Mark `application/x-www-form-urlencoded` as compressible. + +1.1.0 / 2014-09-28 +================== + + * Add `application/font-woff2` + +1.0.3 / 2014-09-25 +================== + + * Fix engine requirement in package + +1.0.2 / 2014-09-25 +================== + + * Add `application/coap-group+json` + * Add `application/dcd` + * Add `application/vnd.apache.thrift.binary` + * Add `image/vnd.tencent.tap` + * Mark all JSON-derived types as compressible + * Update `text/vtt` data + +1.0.1 / 2014-08-30 +================== + + * Fix extension ordering + +1.0.0 / 2014-08-30 +================== + + * Add `application/atf` + * Add `application/merge-patch+json` + * Add `multipart/x-mixed-replace` + * Add `source: 'apache'` metadata + * Add `source: 'iana'` metadata + * Remove badly-assumed charset data diff --git a/node_modules/express/node_modules/accepts/node_modules/mime-types/node_modules/mime-db/LICENSE b/node_modules/express/node_modules/accepts/node_modules/mime-types/node_modules/mime-db/LICENSE new file mode 100644 index 0000000..a7ae8ee --- /dev/null +++ b/node_modules/express/node_modules/accepts/node_modules/mime-types/node_modules/mime-db/LICENSE @@ -0,0 +1,22 @@ + +The MIT License (MIT) + +Copyright (c) 2014 Jonathan Ong me@jongleberry.com + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. diff --git a/node_modules/express/node_modules/accepts/node_modules/mime-types/node_modules/mime-db/README.md b/node_modules/express/node_modules/accepts/node_modules/mime-types/node_modules/mime-db/README.md new file mode 100644 index 0000000..7662440 --- /dev/null +++ b/node_modules/express/node_modules/accepts/node_modules/mime-types/node_modules/mime-db/README.md @@ -0,0 +1,82 @@ +# mime-db + +[![NPM Version][npm-version-image]][npm-url] +[![NPM Downloads][npm-downloads-image]][npm-url] +[![Node.js Version][node-image]][node-url] +[![Build Status][travis-image]][travis-url] +[![Coverage Status][coveralls-image]][coveralls-url] + +This is a database of all mime types. +It consists of a single, public JSON file and does not include any logic, +allowing it to remain as un-opinionated as possible with an API. +It aggregates data from the following sources: + +- http://www.iana.org/assignments/media-types/media-types.xhtml +- http://svn.apache.org/repos/asf/httpd/httpd/trunk/docs/conf/mime.types +- http://hg.nginx.org/nginx/raw-file/default/conf/mime.types + +## Installation + +```bash +npm install mime-db +``` + +### Database Download + +If you're crazy enough to use this in the browser, you can just grab the +JSON file using [RawGit](https://rawgit.com/). It is recommended to replace +`master` with [a release tag](https://github.com/jshttp/mime-db/tags) as the +JSON format may change in the future. + +``` +https://cdn.rawgit.com/jshttp/mime-db/master/db.json +``` + +## Usage + +```js +var db = require('mime-db'); + +// grab data on .js files +var data = db['application/javascript']; +``` + +## Data Structure + +The JSON file is a map lookup for lowercased mime types. +Each mime type has the following properties: + +- `.source` - where the mime type is defined. + If not set, it's probably a custom media type. + - `apache` - [Apache common media types](http://svn.apache.org/repos/asf/httpd/httpd/trunk/docs/conf/mime.types) + - `iana` - [IANA-defined media types](http://www.iana.org/assignments/media-types/media-types.xhtml) + - `nginx` - [nginx media types](http://hg.nginx.org/nginx/raw-file/default/conf/mime.types) +- `.extensions[]` - known extensions associated with this mime type. +- `.compressible` - whether a file of this type can be gzipped. +- `.charset` - the default charset associated with this type, if any. + +If unknown, every property could be `undefined`. + +## Contributing + +To edit the database, only make PRs against `src/custom.json` or +`src/custom-suffix.json`. + +To update the build, run `npm run build`. + +## Adding Custom Media Types + +The best way to get new media types included in this library is to register +them with the IANA. The community registration procedure is outlined in +[RFC 6838 section 5](http://tools.ietf.org/html/rfc6838#section-5). Types +registered with the IANA are automatically pulled into this library. + +[npm-version-image]: https://img.shields.io/npm/v/mime-db.svg +[npm-downloads-image]: https://img.shields.io/npm/dm/mime-db.svg +[npm-url]: https://npmjs.org/package/mime-db +[travis-image]: https://img.shields.io/travis/jshttp/mime-db/master.svg +[travis-url]: https://travis-ci.org/jshttp/mime-db +[coveralls-image]: https://img.shields.io/coveralls/jshttp/mime-db/master.svg +[coveralls-url]: https://coveralls.io/r/jshttp/mime-db?branch=master +[node-image]: https://img.shields.io/node/v/mime-db.svg +[node-url]: http://nodejs.org/download/ diff --git a/node_modules/express/node_modules/accepts/node_modules/mime-types/node_modules/mime-db/db.json b/node_modules/express/node_modules/accepts/node_modules/mime-types/node_modules/mime-db/db.json new file mode 100644 index 0000000..63b226f --- /dev/null +++ b/node_modules/express/node_modules/accepts/node_modules/mime-types/node_modules/mime-db/db.json @@ -0,0 +1,6692 @@ +{ + "application/1d-interleaved-parityfec": { + "source": "iana" + }, + "application/3gpdash-qoe-report+xml": { + "source": "iana" + }, + "application/3gpp-ims+xml": { + "source": "iana" + }, + "application/a2l": { + "source": "iana" + }, + "application/activemessage": { + "source": "iana" + }, + "application/alto-costmap+json": { + "source": "iana", + "compressible": true + }, + "application/alto-costmapfilter+json": { + "source": "iana", + "compressible": true + }, + "application/alto-directory+json": { + "source": "iana", + "compressible": true + }, + "application/alto-endpointcost+json": { + "source": "iana", + "compressible": true + }, + "application/alto-endpointcostparams+json": { + "source": "iana", + "compressible": true + }, + "application/alto-endpointprop+json": { + "source": "iana", + "compressible": true + }, + "application/alto-endpointpropparams+json": { + "source": "iana", + "compressible": true + }, + "application/alto-error+json": { + "source": "iana", + "compressible": true + }, + "application/alto-networkmap+json": { + "source": "iana", + "compressible": true + }, + "application/alto-networkmapfilter+json": { + "source": "iana", + "compressible": true + }, + "application/aml": { + "source": "iana" + }, + "application/andrew-inset": { + "source": "iana", + "extensions": ["ez"] + }, + "application/applefile": { + "source": "iana" + }, + "application/applixware": { + "source": "apache", + "extensions": ["aw"] + }, + "application/atf": { + "source": "iana" + }, + "application/atfx": { + "source": "iana" + }, + "application/atom+xml": { + "source": "iana", + "compressible": true, + "extensions": ["atom"] + }, + "application/atomcat+xml": { + "source": "iana", + "extensions": ["atomcat"] + }, + "application/atomdeleted+xml": { + "source": "iana" + }, + "application/atomicmail": { + "source": "iana" + }, + "application/atomsvc+xml": { + "source": "iana", + "extensions": ["atomsvc"] + }, + "application/atxml": { + "source": "iana" + }, + "application/auth-policy+xml": { + "source": "iana" + }, + "application/bacnet-xdd+zip": { + "source": "iana" + }, + "application/batch-smtp": { + "source": "iana" + }, + "application/bdoc": { + "compressible": false, + "extensions": ["bdoc"] + }, + "application/beep+xml": { + "source": "iana" + }, + "application/calendar+json": { + "source": "iana", + "compressible": true + }, + "application/calendar+xml": { + "source": "iana" + }, + "application/call-completion": { + "source": "iana" + }, + "application/cals-1840": { + "source": "iana" + }, + "application/cbor": { + "source": "iana" + }, + "application/ccmp+xml": { + "source": "iana" + }, + "application/ccxml+xml": { + "source": "iana", + "extensions": ["ccxml"] + }, + "application/cdfx+xml": { + "source": "iana" + }, + "application/cdmi-capability": { + "source": "iana", + "extensions": ["cdmia"] + }, + "application/cdmi-container": { + "source": "iana", + "extensions": ["cdmic"] + }, + "application/cdmi-domain": { + "source": "iana", + "extensions": ["cdmid"] + }, + "application/cdmi-object": { + "source": "iana", + "extensions": ["cdmio"] + }, + "application/cdmi-queue": { + "source": "iana", + "extensions": ["cdmiq"] + }, + "application/cdni": { + "source": "iana" + }, + "application/cea": { + "source": "iana" + }, + "application/cea-2018+xml": { + "source": "iana" + }, + "application/cellml+xml": { + "source": "iana" + }, + "application/cfw": { + "source": "iana" + }, + "application/clue_info+xml": { + "source": "iana" + }, + "application/cms": { + "source": "iana" + }, + "application/cnrp+xml": { + "source": "iana" + }, + "application/coap-group+json": { + "source": "iana", + "compressible": true + }, + "application/commonground": { + "source": "iana" + }, + "application/conference-info+xml": { + "source": "iana" + }, + "application/cpl+xml": { + "source": "iana" + }, + "application/csrattrs": { + "source": "iana" + }, + "application/csta+xml": { + "source": "iana" + }, + "application/cstadata+xml": { + "source": "iana" + }, + "application/csvm+json": { + "source": "iana", + "compressible": true + }, + "application/cu-seeme": { + "source": "apache", + "extensions": ["cu"] + }, + "application/cybercash": { + "source": "iana" + }, + "application/dart": { + "compressible": true + }, + "application/dash+xml": { + "source": "iana", + "extensions": ["mpd"] + }, + "application/dashdelta": { + "source": "iana" + }, + "application/davmount+xml": { + "source": "iana", + "extensions": ["davmount"] + }, + "application/dca-rft": { + "source": "iana" + }, + "application/dcd": { + "source": "iana" + }, + "application/dec-dx": { + "source": "iana" + }, + "application/dialog-info+xml": { + "source": "iana" + }, + "application/dicom": { + "source": "iana" + }, + "application/dii": { + "source": "iana" + }, + "application/dit": { + "source": "iana" + }, + "application/dns": { + "source": "iana" + }, + "application/docbook+xml": { + "source": "apache", + "extensions": ["dbk"] + }, + "application/dskpp+xml": { + "source": "iana" + }, + "application/dssc+der": { + "source": "iana", + "extensions": ["dssc"] + }, + "application/dssc+xml": { + "source": "iana", + "extensions": ["xdssc"] + }, + "application/dvcs": { + "source": "iana" + }, + "application/ecmascript": { + "source": "iana", + "compressible": true, + "extensions": ["ecma"] + }, + "application/edi-consent": { + "source": "iana" + }, + "application/edi-x12": { + "source": "iana", + "compressible": false + }, + "application/edifact": { + "source": "iana", + "compressible": false + }, + "application/efi": { + "source": "iana" + }, + "application/emergencycalldata.comment+xml": { + "source": "iana" + }, + "application/emergencycalldata.deviceinfo+xml": { + "source": "iana" + }, + "application/emergencycalldata.providerinfo+xml": { + "source": "iana" + }, + "application/emergencycalldata.serviceinfo+xml": { + "source": "iana" + }, + "application/emergencycalldata.subscriberinfo+xml": { + "source": "iana" + }, + "application/emma+xml": { + "source": "iana", + "extensions": ["emma"] + }, + "application/emotionml+xml": { + "source": "iana" + }, + "application/encaprtp": { + "source": "iana" + }, + "application/epp+xml": { + "source": "iana" + }, + "application/epub+zip": { + "source": "iana", + "extensions": ["epub"] + }, + "application/eshop": { + "source": "iana" + }, + "application/exi": { + "source": "iana", + "extensions": ["exi"] + }, + "application/fastinfoset": { + "source": "iana" + }, + "application/fastsoap": { + "source": "iana" + }, + "application/fdt+xml": { + "source": "iana" + }, + "application/fits": { + "source": "iana" + }, + "application/font-sfnt": { + "source": "iana" + }, + "application/font-tdpfr": { + "source": "iana", + "extensions": ["pfr"] + }, + "application/font-woff": { + "source": "iana", + "compressible": false, + "extensions": ["woff"] + }, + "application/font-woff2": { + "compressible": false, + "extensions": ["woff2"] + }, + "application/framework-attributes+xml": { + "source": "iana" + }, + "application/geo+json": { + "source": "iana", + "compressible": true + }, + "application/gml+xml": { + "source": "apache", + "extensions": ["gml"] + }, + "application/gpx+xml": { + "source": "apache", + "extensions": ["gpx"] + }, + "application/gxf": { + "source": "apache", + "extensions": ["gxf"] + }, + "application/gzip": { + "source": "iana", + "compressible": false + }, + "application/h224": { + "source": "iana" + }, + "application/held+xml": { + "source": "iana" + }, + "application/http": { + "source": "iana" + }, + "application/hyperstudio": { + "source": "iana", + "extensions": ["stk"] + }, + "application/ibe-key-request+xml": { + "source": "iana" + }, + "application/ibe-pkg-reply+xml": { + "source": "iana" + }, + "application/ibe-pp-data": { + "source": "iana" + }, + "application/iges": { + "source": "iana" + }, + "application/im-iscomposing+xml": { + "source": "iana" + }, + "application/index": { + "source": "iana" + }, + "application/index.cmd": { + "source": "iana" + }, + "application/index.obj": { + "source": "iana" + }, + "application/index.response": { + "source": "iana" + }, + "application/index.vnd": { + "source": "iana" + }, + "application/inkml+xml": { + "source": "iana", + "extensions": ["ink","inkml"] + }, + "application/iotp": { + "source": "iana" + }, + "application/ipfix": { + "source": "iana", + "extensions": ["ipfix"] + }, + "application/ipp": { + "source": "iana" + }, + "application/isup": { + "source": "iana" + }, + "application/its+xml": { + "source": "iana" + }, + "application/java-archive": { + "source": "apache", + "compressible": false, + "extensions": ["jar","war","ear"] + }, + "application/java-serialized-object": { + "source": "apache", + "compressible": false, + "extensions": ["ser"] + }, + "application/java-vm": { + "source": "apache", + "compressible": false, + "extensions": ["class"] + }, + "application/javascript": { + "source": "iana", + "charset": "UTF-8", + "compressible": true, + "extensions": ["js"] + }, + "application/jose": { + "source": "iana" + }, + "application/jose+json": { + "source": "iana", + "compressible": true + }, + "application/jrd+json": { + "source": "iana", + "compressible": true + }, + "application/json": { + "source": "iana", + "charset": "UTF-8", + "compressible": true, + "extensions": ["json","map"] + }, + "application/json-patch+json": { + "source": "iana", + "compressible": true + }, + "application/json-seq": { + "source": "iana" + }, + "application/json5": { + "extensions": ["json5"] + }, + "application/jsonml+json": { + "source": "apache", + "compressible": true, + "extensions": ["jsonml"] + }, + "application/jwk+json": { + "source": "iana", + "compressible": true + }, + "application/jwk-set+json": { + "source": "iana", + "compressible": true + }, + "application/jwt": { + "source": "iana" + }, + "application/kpml-request+xml": { + "source": "iana" + }, + "application/kpml-response+xml": { + "source": "iana" + }, + "application/ld+json": { + "source": "iana", + "compressible": true, + "extensions": ["jsonld"] + }, + "application/lgr+xml": { + "source": "iana" + }, + "application/link-format": { + "source": "iana" + }, + "application/load-control+xml": { + "source": "iana" + }, + "application/lost+xml": { + "source": "iana", + "extensions": ["lostxml"] + }, + "application/lostsync+xml": { + "source": "iana" + }, + "application/lxf": { + "source": "iana" + }, + "application/mac-binhex40": { + "source": "iana", + "extensions": ["hqx"] + }, + "application/mac-compactpro": { + "source": "apache", + "extensions": ["cpt"] + }, + "application/macwriteii": { + "source": "iana" + }, + "application/mads+xml": { + "source": "iana", + "extensions": ["mads"] + }, + "application/manifest+json": { + "charset": "UTF-8", + "compressible": true, + "extensions": ["webmanifest"] + }, + "application/marc": { + "source": "iana", + "extensions": ["mrc"] + }, + "application/marcxml+xml": { + "source": "iana", + "extensions": ["mrcx"] + }, + "application/mathematica": { + "source": "iana", + "extensions": ["ma","nb","mb"] + }, + "application/mathml+xml": { + "source": "iana", + "extensions": ["mathml"] + }, + "application/mathml-content+xml": { + "source": "iana" + }, + "application/mathml-presentation+xml": { + "source": "iana" + }, + "application/mbms-associated-procedure-description+xml": { + "source": "iana" + }, + "application/mbms-deregister+xml": { + "source": "iana" + }, + "application/mbms-envelope+xml": { + "source": "iana" + }, + "application/mbms-msk+xml": { + "source": "iana" + }, + "application/mbms-msk-response+xml": { + "source": "iana" + }, + "application/mbms-protection-description+xml": { + "source": "iana" + }, + "application/mbms-reception-report+xml": { + "source": "iana" + }, + "application/mbms-register+xml": { + "source": "iana" + }, + "application/mbms-register-response+xml": { + "source": "iana" + }, + "application/mbms-schedule+xml": { + "source": "iana" + }, + "application/mbms-user-service-description+xml": { + "source": "iana" + }, + "application/mbox": { + "source": "iana", + "extensions": ["mbox"] + }, + "application/media-policy-dataset+xml": { + "source": "iana" + }, + "application/media_control+xml": { + "source": "iana" + }, + "application/mediaservercontrol+xml": { + "source": "iana", + "extensions": ["mscml"] + }, + "application/merge-patch+json": { + "source": "iana", + "compressible": true + }, + "application/metalink+xml": { + "source": "apache", + "extensions": ["metalink"] + }, + "application/metalink4+xml": { + "source": "iana", + "extensions": ["meta4"] + }, + "application/mets+xml": { + "source": "iana", + "extensions": ["mets"] + }, + "application/mf4": { + "source": "iana" + }, + "application/mikey": { + "source": "iana" + }, + "application/mods+xml": { + "source": "iana", + "extensions": ["mods"] + }, + "application/moss-keys": { + "source": "iana" + }, + "application/moss-signature": { + "source": "iana" + }, + "application/mosskey-data": { + "source": "iana" + }, + "application/mosskey-request": { + "source": "iana" + }, + "application/mp21": { + "source": "iana", + "extensions": ["m21","mp21"] + }, + "application/mp4": { + "source": "iana", + "extensions": ["mp4s","m4p"] + }, + "application/mpeg4-generic": { + "source": "iana" + }, + "application/mpeg4-iod": { + "source": "iana" + }, + "application/mpeg4-iod-xmt": { + "source": "iana" + }, + "application/mrb-consumer+xml": { + "source": "iana" + }, + "application/mrb-publish+xml": { + "source": "iana" + }, + "application/msc-ivr+xml": { + "source": "iana" + }, + "application/msc-mixer+xml": { + "source": "iana" + }, + "application/msword": { + "source": "iana", + "compressible": false, + "extensions": ["doc","dot"] + }, + "application/mxf": { + "source": "iana", + "extensions": ["mxf"] + }, + "application/nasdata": { + "source": "iana" + }, + "application/news-checkgroups": { + "source": "iana" + }, + "application/news-groupinfo": { + "source": "iana" + }, + "application/news-transmission": { + "source": "iana" + }, + "application/nlsml+xml": { + "source": "iana" + }, + "application/nss": { + "source": "iana" + }, + "application/ocsp-request": { + "source": "iana" + }, + "application/ocsp-response": { + "source": "iana" + }, + "application/octet-stream": { + "source": "iana", + "compressible": false, + "extensions": ["bin","dms","lrf","mar","so","dist","distz","pkg","bpk","dump","elc","deploy","exe","dll","deb","dmg","iso","img","msi","msp","msm","buffer"] + }, + "application/oda": { + "source": "iana", + "extensions": ["oda"] + }, + "application/odx": { + "source": "iana" + }, + "application/oebps-package+xml": { + "source": "iana", + "extensions": ["opf"] + }, + "application/ogg": { + "source": "iana", + "compressible": false, + "extensions": ["ogx"] + }, + "application/omdoc+xml": { + "source": "apache", + "extensions": ["omdoc"] + }, + "application/onenote": { + "source": "apache", + "extensions": ["onetoc","onetoc2","onetmp","onepkg"] + }, + "application/oxps": { + "source": "iana", + "extensions": ["oxps"] + }, + "application/p2p-overlay+xml": { + "source": "iana" + }, + "application/parityfec": { + "source": "iana" + }, + "application/patch-ops-error+xml": { + "source": "iana", + "extensions": ["xer"] + }, + "application/pdf": { + "source": "iana", + "compressible": false, + "extensions": ["pdf"] + }, + "application/pdx": { + "source": "iana" + }, + "application/pgp-encrypted": { + "source": "iana", + "compressible": false, + "extensions": ["pgp"] + }, + "application/pgp-keys": { + "source": "iana" + }, + "application/pgp-signature": { + "source": "iana", + "extensions": ["asc","sig"] + }, + "application/pics-rules": { + "source": "apache", + "extensions": ["prf"] + }, + "application/pidf+xml": { + "source": "iana" + }, + "application/pidf-diff+xml": { + "source": "iana" + }, + "application/pkcs10": { + "source": "iana", + "extensions": ["p10"] + }, + "application/pkcs12": { + "source": "iana" + }, + "application/pkcs7-mime": { + "source": "iana", + "extensions": ["p7m","p7c"] + }, + "application/pkcs7-signature": { + "source": "iana", + "extensions": ["p7s"] + }, + "application/pkcs8": { + "source": "iana", + "extensions": ["p8"] + }, + "application/pkix-attr-cert": { + "source": "iana", + "extensions": ["ac"] + }, + "application/pkix-cert": { + "source": "iana", + "extensions": ["cer"] + }, + "application/pkix-crl": { + "source": "iana", + "extensions": ["crl"] + }, + "application/pkix-pkipath": { + "source": "iana", + "extensions": ["pkipath"] + }, + "application/pkixcmp": { + "source": "iana", + "extensions": ["pki"] + }, + "application/pls+xml": { + "source": "iana", + "extensions": ["pls"] + }, + "application/poc-settings+xml": { + "source": "iana" + }, + "application/postscript": { + "source": "iana", + "compressible": true, + "extensions": ["ai","eps","ps"] + }, + "application/ppsp-tracker+json": { + "source": "iana", + "compressible": true + }, + "application/problem+json": { + "source": "iana", + "compressible": true + }, + "application/problem+xml": { + "source": "iana" + }, + "application/provenance+xml": { + "source": "iana" + }, + "application/prs.alvestrand.titrax-sheet": { + "source": "iana" + }, + "application/prs.cww": { + "source": "iana", + "extensions": ["cww"] + }, + "application/prs.hpub+zip": { + "source": "iana" + }, + "application/prs.nprend": { + "source": "iana" + }, + "application/prs.plucker": { + "source": "iana" + }, + "application/prs.rdf-xml-crypt": { + "source": "iana" + }, + "application/prs.xsf+xml": { + "source": "iana" + }, + "application/pskc+xml": { + "source": "iana", + "extensions": ["pskcxml"] + }, + "application/qsig": { + "source": "iana" + }, + "application/raptorfec": { + "source": "iana" + }, + "application/rdap+json": { + "source": "iana", + "compressible": true + }, + "application/rdf+xml": { + "source": "iana", + "compressible": true, + "extensions": ["rdf"] + }, + "application/reginfo+xml": { + "source": "iana", + "extensions": ["rif"] + }, + "application/relax-ng-compact-syntax": { + "source": "iana", + "extensions": ["rnc"] + }, + "application/remote-printing": { + "source": "iana" + }, + "application/reputon+json": { + "source": "iana", + "compressible": true + }, + "application/resource-lists+xml": { + "source": "iana", + "extensions": ["rl"] + }, + "application/resource-lists-diff+xml": { + "source": "iana", + "extensions": ["rld"] + }, + "application/rfc+xml": { + "source": "iana" + }, + "application/riscos": { + "source": "iana" + }, + "application/rlmi+xml": { + "source": "iana" + }, + "application/rls-services+xml": { + "source": "iana", + "extensions": ["rs"] + }, + "application/rpki-ghostbusters": { + "source": "iana", + "extensions": ["gbr"] + }, + "application/rpki-manifest": { + "source": "iana", + "extensions": ["mft"] + }, + "application/rpki-roa": { + "source": "iana", + "extensions": ["roa"] + }, + "application/rpki-updown": { + "source": "iana" + }, + "application/rsd+xml": { + "source": "apache", + "extensions": ["rsd"] + }, + "application/rss+xml": { + "source": "apache", + "compressible": true, + "extensions": ["rss"] + }, + "application/rtf": { + "source": "iana", + "compressible": true, + "extensions": ["rtf"] + }, + "application/rtploopback": { + "source": "iana" + }, + "application/rtx": { + "source": "iana" + }, + "application/samlassertion+xml": { + "source": "iana" + }, + "application/samlmetadata+xml": { + "source": "iana" + }, + "application/sbml+xml": { + "source": "iana", + "extensions": ["sbml"] + }, + "application/scaip+xml": { + "source": "iana" + }, + "application/scim+json": { + "source": "iana", + "compressible": true + }, + "application/scvp-cv-request": { + "source": "iana", + "extensions": ["scq"] + }, + "application/scvp-cv-response": { + "source": "iana", + "extensions": ["scs"] + }, + "application/scvp-vp-request": { + "source": "iana", + "extensions": ["spq"] + }, + "application/scvp-vp-response": { + "source": "iana", + "extensions": ["spp"] + }, + "application/sdp": { + "source": "iana", + "extensions": ["sdp"] + }, + "application/sep+xml": { + "source": "iana" + }, + "application/sep-exi": { + "source": "iana" + }, + "application/session-info": { + "source": "iana" + }, + "application/set-payment": { + "source": "iana" + }, + "application/set-payment-initiation": { + "source": "iana", + "extensions": ["setpay"] + }, + "application/set-registration": { + "source": "iana" + }, + "application/set-registration-initiation": { + "source": "iana", + "extensions": ["setreg"] + }, + "application/sgml": { + "source": "iana" + }, + "application/sgml-open-catalog": { + "source": "iana" + }, + "application/shf+xml": { + "source": "iana", + "extensions": ["shf"] + }, + "application/sieve": { + "source": "iana" + }, + "application/simple-filter+xml": { + "source": "iana" + }, + "application/simple-message-summary": { + "source": "iana" + }, + "application/simplesymbolcontainer": { + "source": "iana" + }, + "application/slate": { + "source": "iana" + }, + "application/smil": { + "source": "iana" + }, + "application/smil+xml": { + "source": "iana", + "extensions": ["smi","smil"] + }, + "application/smpte336m": { + "source": "iana" + }, + "application/soap+fastinfoset": { + "source": "iana" + }, + "application/soap+xml": { + "source": "iana", + "compressible": true + }, + "application/sparql-query": { + "source": "iana", + "extensions": ["rq"] + }, + "application/sparql-results+xml": { + "source": "iana", + "extensions": ["srx"] + }, + "application/spirits-event+xml": { + "source": "iana" + }, + "application/sql": { + "source": "iana" + }, + "application/srgs": { + "source": "iana", + "extensions": ["gram"] + }, + "application/srgs+xml": { + "source": "iana", + "extensions": ["grxml"] + }, + "application/sru+xml": { + "source": "iana", + "extensions": ["sru"] + }, + "application/ssdl+xml": { + "source": "apache", + "extensions": ["ssdl"] + }, + "application/ssml+xml": { + "source": "iana", + "extensions": ["ssml"] + }, + "application/tamp-apex-update": { + "source": "iana" + }, + "application/tamp-apex-update-confirm": { + "source": "iana" + }, + "application/tamp-community-update": { + "source": "iana" + }, + "application/tamp-community-update-confirm": { + "source": "iana" + }, + "application/tamp-error": { + "source": "iana" + }, + "application/tamp-sequence-adjust": { + "source": "iana" + }, + "application/tamp-sequence-adjust-confirm": { + "source": "iana" + }, + "application/tamp-status-query": { + "source": "iana" + }, + "application/tamp-status-response": { + "source": "iana" + }, + "application/tamp-update": { + "source": "iana" + }, + "application/tamp-update-confirm": { + "source": "iana" + }, + "application/tar": { + "compressible": true + }, + "application/tei+xml": { + "source": "iana", + "extensions": ["tei","teicorpus"] + }, + "application/thraud+xml": { + "source": "iana", + "extensions": ["tfi"] + }, + "application/timestamp-query": { + "source": "iana" + }, + "application/timestamp-reply": { + "source": "iana" + }, + "application/timestamped-data": { + "source": "iana", + "extensions": ["tsd"] + }, + "application/ttml+xml": { + "source": "iana" + }, + "application/tve-trigger": { + "source": "iana" + }, + "application/ulpfec": { + "source": "iana" + }, + "application/urc-grpsheet+xml": { + "source": "iana" + }, + "application/urc-ressheet+xml": { + "source": "iana" + }, + "application/urc-targetdesc+xml": { + "source": "iana" + }, + "application/urc-uisocketdesc+xml": { + "source": "iana" + }, + "application/vcard+json": { + "source": "iana", + "compressible": true + }, + "application/vcard+xml": { + "source": "iana" + }, + "application/vemmi": { + "source": "iana" + }, + "application/vividence.scriptfile": { + "source": "apache" + }, + "application/vnd.3gpp-prose+xml": { + "source": "iana" + }, + "application/vnd.3gpp-prose-pc3ch+xml": { + "source": "iana" + }, + "application/vnd.3gpp.access-transfer-events+xml": { + "source": "iana" + }, + "application/vnd.3gpp.bsf+xml": { + "source": "iana" + }, + "application/vnd.3gpp.mid-call+xml": { + "source": "iana" + }, + "application/vnd.3gpp.pic-bw-large": { + "source": "iana", + "extensions": ["plb"] + }, + "application/vnd.3gpp.pic-bw-small": { + "source": "iana", + "extensions": ["psb"] + }, + "application/vnd.3gpp.pic-bw-var": { + "source": "iana", + "extensions": ["pvb"] + }, + "application/vnd.3gpp.sms": { + "source": "iana" + }, + "application/vnd.3gpp.sms+xml": { + "source": "iana" + }, + "application/vnd.3gpp.srvcc-ext+xml": { + "source": "iana" + }, + "application/vnd.3gpp.srvcc-info+xml": { + "source": "iana" + }, + "application/vnd.3gpp.state-and-event-info+xml": { + "source": "iana" + }, + "application/vnd.3gpp.ussd+xml": { + "source": "iana" + }, + "application/vnd.3gpp2.bcmcsinfo+xml": { + "source": "iana" + }, + "application/vnd.3gpp2.sms": { + "source": "iana" + }, + "application/vnd.3gpp2.tcap": { + "source": "iana", + "extensions": ["tcap"] + }, + "application/vnd.3lightssoftware.imagescal": { + "source": "iana" + }, + "application/vnd.3m.post-it-notes": { + "source": "iana", + "extensions": ["pwn"] + }, + "application/vnd.accpac.simply.aso": { + "source": "iana", + "extensions": ["aso"] + }, + "application/vnd.accpac.simply.imp": { + "source": "iana", + "extensions": ["imp"] + }, + "application/vnd.acucobol": { + "source": "iana", + "extensions": ["acu"] + }, + "application/vnd.acucorp": { + "source": "iana", + "extensions": ["atc","acutc"] + }, + "application/vnd.adobe.air-application-installer-package+zip": { + "source": "apache", + "extensions": ["air"] + }, + "application/vnd.adobe.flash.movie": { + "source": "iana" + }, + "application/vnd.adobe.formscentral.fcdt": { + "source": "iana", + "extensions": ["fcdt"] + }, + "application/vnd.adobe.fxp": { + "source": "iana", + "extensions": ["fxp","fxpl"] + }, + "application/vnd.adobe.partial-upload": { + "source": "iana" + }, + "application/vnd.adobe.xdp+xml": { + "source": "iana", + "extensions": ["xdp"] + }, + "application/vnd.adobe.xfdf": { + "source": "iana", + "extensions": ["xfdf"] + }, + "application/vnd.aether.imp": { + "source": "iana" + }, + "application/vnd.ah-barcode": { + "source": "iana" + }, + "application/vnd.ahead.space": { + "source": "iana", + "extensions": ["ahead"] + }, + "application/vnd.airzip.filesecure.azf": { + "source": "iana", + "extensions": ["azf"] + }, + "application/vnd.airzip.filesecure.azs": { + "source": "iana", + "extensions": ["azs"] + }, + "application/vnd.amazon.ebook": { + "source": "apache", + "extensions": ["azw"] + }, + "application/vnd.amazon.mobi8-ebook": { + "source": "iana" + }, + "application/vnd.americandynamics.acc": { + "source": "iana", + "extensions": ["acc"] + }, + "application/vnd.amiga.ami": { + "source": "iana", + "extensions": ["ami"] + }, + "application/vnd.amundsen.maze+xml": { + "source": "iana" + }, + "application/vnd.android.package-archive": { + "source": "apache", + "compressible": false, + "extensions": ["apk"] + }, + "application/vnd.anki": { + "source": "iana" + }, + "application/vnd.anser-web-certificate-issue-initiation": { + "source": "iana", + "extensions": ["cii"] + }, + "application/vnd.anser-web-funds-transfer-initiation": { + "source": "apache", + "extensions": ["fti"] + }, + "application/vnd.antix.game-component": { + "source": "iana", + "extensions": ["atx"] + }, + "application/vnd.apache.thrift.binary": { + "source": "iana" + }, + "application/vnd.apache.thrift.compact": { + "source": "iana" + }, + "application/vnd.apache.thrift.json": { + "source": "iana" + }, + "application/vnd.api+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.apple.installer+xml": { + "source": "iana", + "extensions": ["mpkg"] + }, + "application/vnd.apple.mpegurl": { + "source": "iana", + "extensions": ["m3u8"] + }, + "application/vnd.apple.pkpass": { + "compressible": false, + "extensions": ["pkpass"] + }, + "application/vnd.arastra.swi": { + "source": "iana" + }, + "application/vnd.aristanetworks.swi": { + "source": "iana", + "extensions": ["swi"] + }, + "application/vnd.artsquare": { + "source": "iana" + }, + "application/vnd.astraea-software.iota": { + "source": "iana", + "extensions": ["iota"] + }, + "application/vnd.audiograph": { + "source": "iana", + "extensions": ["aep"] + }, + "application/vnd.autopackage": { + "source": "iana" + }, + "application/vnd.avistar+xml": { + "source": "iana" + }, + "application/vnd.balsamiq.bmml+xml": { + "source": "iana" + }, + "application/vnd.balsamiq.bmpr": { + "source": "iana" + }, + "application/vnd.bekitzur-stech+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.biopax.rdf+xml": { + "source": "iana" + }, + "application/vnd.blueice.multipass": { + "source": "iana", + "extensions": ["mpm"] + }, + "application/vnd.bluetooth.ep.oob": { + "source": "iana" + }, + "application/vnd.bluetooth.le.oob": { + "source": "iana" + }, + "application/vnd.bmi": { + "source": "iana", + "extensions": ["bmi"] + }, + "application/vnd.businessobjects": { + "source": "iana", + "extensions": ["rep"] + }, + "application/vnd.cab-jscript": { + "source": "iana" + }, + "application/vnd.canon-cpdl": { + "source": "iana" + }, + "application/vnd.canon-lips": { + "source": "iana" + }, + "application/vnd.cendio.thinlinc.clientconf": { + "source": "iana" + }, + "application/vnd.century-systems.tcp_stream": { + "source": "iana" + }, + "application/vnd.chemdraw+xml": { + "source": "iana", + "extensions": ["cdxml"] + }, + "application/vnd.chess-pgn": { + "source": "iana" + }, + "application/vnd.chipnuts.karaoke-mmd": { + "source": "iana", + "extensions": ["mmd"] + }, + "application/vnd.cinderella": { + "source": "iana", + "extensions": ["cdy"] + }, + "application/vnd.cirpack.isdn-ext": { + "source": "iana" + }, + "application/vnd.citationstyles.style+xml": { + "source": "iana" + }, + "application/vnd.claymore": { + "source": "iana", + "extensions": ["cla"] + }, + "application/vnd.cloanto.rp9": { + "source": "iana", + "extensions": ["rp9"] + }, + "application/vnd.clonk.c4group": { + "source": "iana", + "extensions": ["c4g","c4d","c4f","c4p","c4u"] + }, + "application/vnd.cluetrust.cartomobile-config": { + "source": "iana", + "extensions": ["c11amc"] + }, + "application/vnd.cluetrust.cartomobile-config-pkg": { + "source": "iana", + "extensions": ["c11amz"] + }, + "application/vnd.coffeescript": { + "source": "iana" + }, + "application/vnd.collection+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.collection.doc+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.collection.next+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.comicbook+zip": { + "source": "iana" + }, + "application/vnd.commerce-battelle": { + "source": "iana" + }, + "application/vnd.commonspace": { + "source": "iana", + "extensions": ["csp"] + }, + "application/vnd.contact.cmsg": { + "source": "iana", + "extensions": ["cdbcmsg"] + }, + "application/vnd.coreos.ignition+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.cosmocaller": { + "source": "iana", + "extensions": ["cmc"] + }, + "application/vnd.crick.clicker": { + "source": "iana", + "extensions": ["clkx"] + }, + "application/vnd.crick.clicker.keyboard": { + "source": "iana", + "extensions": ["clkk"] + }, + "application/vnd.crick.clicker.palette": { + "source": "iana", + "extensions": ["clkp"] + }, + "application/vnd.crick.clicker.template": { + "source": "iana", + "extensions": ["clkt"] + }, + "application/vnd.crick.clicker.wordbank": { + "source": "iana", + "extensions": ["clkw"] + }, + "application/vnd.criticaltools.wbs+xml": { + "source": "iana", + "extensions": ["wbs"] + }, + "application/vnd.ctc-posml": { + "source": "iana", + "extensions": ["pml"] + }, + "application/vnd.ctct.ws+xml": { + "source": "iana" + }, + "application/vnd.cups-pdf": { + "source": "iana" + }, + "application/vnd.cups-postscript": { + "source": "iana" + }, + "application/vnd.cups-ppd": { + "source": "iana", + "extensions": ["ppd"] + }, + "application/vnd.cups-raster": { + "source": "iana" + }, + "application/vnd.cups-raw": { + "source": "iana" + }, + "application/vnd.curl": { + "source": "iana" + }, + "application/vnd.curl.car": { + "source": "apache", + "extensions": ["car"] + }, + "application/vnd.curl.pcurl": { + "source": "apache", + "extensions": ["pcurl"] + }, + "application/vnd.cyan.dean.root+xml": { + "source": "iana" + }, + "application/vnd.cybank": { + "source": "iana" + }, + "application/vnd.d2l.coursepackage1p0+zip": { + "source": "iana" + }, + "application/vnd.dart": { + "source": "iana", + "compressible": true, + "extensions": ["dart"] + }, + "application/vnd.data-vision.rdz": { + "source": "iana", + "extensions": ["rdz"] + }, + "application/vnd.debian.binary-package": { + "source": "iana" + }, + "application/vnd.dece.data": { + "source": "iana", + "extensions": ["uvf","uvvf","uvd","uvvd"] + }, + "application/vnd.dece.ttml+xml": { + "source": "iana", + "extensions": ["uvt","uvvt"] + }, + "application/vnd.dece.unspecified": { + "source": "iana", + "extensions": ["uvx","uvvx"] + }, + "application/vnd.dece.zip": { + "source": "iana", + "extensions": ["uvz","uvvz"] + }, + "application/vnd.denovo.fcselayout-link": { + "source": "iana", + "extensions": ["fe_launch"] + }, + "application/vnd.desmume-movie": { + "source": "iana" + }, + "application/vnd.desmume.movie": { + "source": "apache" + }, + "application/vnd.dir-bi.plate-dl-nosuffix": { + "source": "iana" + }, + "application/vnd.dm.delegation+xml": { + "source": "iana" + }, + "application/vnd.dna": { + "source": "iana", + "extensions": ["dna"] + }, + "application/vnd.document+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.dolby.mlp": { + "source": "apache", + "extensions": ["mlp"] + }, + "application/vnd.dolby.mobile.1": { + "source": "iana" + }, + "application/vnd.dolby.mobile.2": { + "source": "iana" + }, + "application/vnd.doremir.scorecloud-binary-document": { + "source": "iana" + }, + "application/vnd.dpgraph": { + "source": "iana", + "extensions": ["dpg"] + }, + "application/vnd.dreamfactory": { + "source": "iana", + "extensions": ["dfac"] + }, + "application/vnd.drive+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.ds-keypoint": { + "source": "apache", + "extensions": ["kpxx"] + }, + "application/vnd.dtg.local": { + "source": "iana" + }, + "application/vnd.dtg.local.flash": { + "source": "iana" + }, + "application/vnd.dtg.local.html": { + "source": "iana" + }, + "application/vnd.dvb.ait": { + "source": "iana", + "extensions": ["ait"] + }, + "application/vnd.dvb.dvbj": { + "source": "iana" + }, + "application/vnd.dvb.esgcontainer": { + "source": "iana" + }, + "application/vnd.dvb.ipdcdftnotifaccess": { + "source": "iana" + }, + "application/vnd.dvb.ipdcesgaccess": { + "source": "iana" + }, + "application/vnd.dvb.ipdcesgaccess2": { + "source": "iana" + }, + "application/vnd.dvb.ipdcesgpdd": { + "source": "iana" + }, + "application/vnd.dvb.ipdcroaming": { + "source": "iana" + }, + "application/vnd.dvb.iptv.alfec-base": { + "source": "iana" + }, + "application/vnd.dvb.iptv.alfec-enhancement": { + "source": "iana" + }, + "application/vnd.dvb.notif-aggregate-root+xml": { + "source": "iana" + }, + "application/vnd.dvb.notif-container+xml": { + "source": "iana" + }, + "application/vnd.dvb.notif-generic+xml": { + "source": "iana" + }, + "application/vnd.dvb.notif-ia-msglist+xml": { + "source": "iana" + }, + "application/vnd.dvb.notif-ia-registration-request+xml": { + "source": "iana" + }, + "application/vnd.dvb.notif-ia-registration-response+xml": { + "source": "iana" + }, + "application/vnd.dvb.notif-init+xml": { + "source": "iana" + }, + "application/vnd.dvb.pfr": { + "source": "iana" + }, + "application/vnd.dvb.service": { + "source": "iana", + "extensions": ["svc"] + }, + "application/vnd.dxr": { + "source": "iana" + }, + "application/vnd.dynageo": { + "source": "iana", + "extensions": ["geo"] + }, + "application/vnd.dzr": { + "source": "iana" + }, + "application/vnd.easykaraoke.cdgdownload": { + "source": "iana" + }, + "application/vnd.ecdis-update": { + "source": "iana" + }, + "application/vnd.ecowin.chart": { + "source": "iana", + "extensions": ["mag"] + }, + "application/vnd.ecowin.filerequest": { + "source": "iana" + }, + "application/vnd.ecowin.fileupdate": { + "source": "iana" + }, + "application/vnd.ecowin.series": { + "source": "iana" + }, + "application/vnd.ecowin.seriesrequest": { + "source": "iana" + }, + "application/vnd.ecowin.seriesupdate": { + "source": "iana" + }, + "application/vnd.emclient.accessrequest+xml": { + "source": "iana" + }, + "application/vnd.enliven": { + "source": "iana", + "extensions": ["nml"] + }, + "application/vnd.enphase.envoy": { + "source": "iana" + }, + "application/vnd.eprints.data+xml": { + "source": "iana" + }, + "application/vnd.epson.esf": { + "source": "iana", + "extensions": ["esf"] + }, + "application/vnd.epson.msf": { + "source": "iana", + "extensions": ["msf"] + }, + "application/vnd.epson.quickanime": { + "source": "iana", + "extensions": ["qam"] + }, + "application/vnd.epson.salt": { + "source": "iana", + "extensions": ["slt"] + }, + "application/vnd.epson.ssf": { + "source": "iana", + "extensions": ["ssf"] + }, + "application/vnd.ericsson.quickcall": { + "source": "iana" + }, + "application/vnd.espass-espass+zip": { + "source": "iana" + }, + "application/vnd.eszigno3+xml": { + "source": "iana", + "extensions": ["es3","et3"] + }, + "application/vnd.etsi.aoc+xml": { + "source": "iana" + }, + "application/vnd.etsi.asic-e+zip": { + "source": "iana" + }, + "application/vnd.etsi.asic-s+zip": { + "source": "iana" + }, + "application/vnd.etsi.cug+xml": { + "source": "iana" + }, + "application/vnd.etsi.iptvcommand+xml": { + "source": "iana" + }, + "application/vnd.etsi.iptvdiscovery+xml": { + "source": "iana" + }, + "application/vnd.etsi.iptvprofile+xml": { + "source": "iana" + }, + "application/vnd.etsi.iptvsad-bc+xml": { + "source": "iana" + }, + "application/vnd.etsi.iptvsad-cod+xml": { + "source": "iana" + }, + "application/vnd.etsi.iptvsad-npvr+xml": { + "source": "iana" + }, + "application/vnd.etsi.iptvservice+xml": { + "source": "iana" + }, + "application/vnd.etsi.iptvsync+xml": { + "source": "iana" + }, + "application/vnd.etsi.iptvueprofile+xml": { + "source": "iana" + }, + "application/vnd.etsi.mcid+xml": { + "source": "iana" + }, + "application/vnd.etsi.mheg5": { + "source": "iana" + }, + "application/vnd.etsi.overload-control-policy-dataset+xml": { + "source": "iana" + }, + "application/vnd.etsi.pstn+xml": { + "source": "iana" + }, + "application/vnd.etsi.sci+xml": { + "source": "iana" + }, + "application/vnd.etsi.simservs+xml": { + "source": "iana" + }, + "application/vnd.etsi.timestamp-token": { + "source": "iana" + }, + "application/vnd.etsi.tsl+xml": { + "source": "iana" + }, + "application/vnd.etsi.tsl.der": { + "source": "iana" + }, + "application/vnd.eudora.data": { + "source": "iana" + }, + "application/vnd.ezpix-album": { + "source": "iana", + "extensions": ["ez2"] + }, + "application/vnd.ezpix-package": { + "source": "iana", + "extensions": ["ez3"] + }, + "application/vnd.f-secure.mobile": { + "source": "iana" + }, + "application/vnd.fastcopy-disk-image": { + "source": "iana" + }, + "application/vnd.fdf": { + "source": "iana", + "extensions": ["fdf"] + }, + "application/vnd.fdsn.mseed": { + "source": "iana", + "extensions": ["mseed"] + }, + "application/vnd.fdsn.seed": { + "source": "iana", + "extensions": ["seed","dataless"] + }, + "application/vnd.ffsns": { + "source": "iana" + }, + "application/vnd.filmit.zfc": { + "source": "iana" + }, + "application/vnd.fints": { + "source": "iana" + }, + "application/vnd.firemonkeys.cloudcell": { + "source": "iana" + }, + "application/vnd.flographit": { + "source": "iana", + "extensions": ["gph"] + }, + "application/vnd.fluxtime.clip": { + "source": "iana", + "extensions": ["ftc"] + }, + "application/vnd.font-fontforge-sfd": { + "source": "iana" + }, + "application/vnd.framemaker": { + "source": "iana", + "extensions": ["fm","frame","maker","book"] + }, + "application/vnd.frogans.fnc": { + "source": "iana", + "extensions": ["fnc"] + }, + "application/vnd.frogans.ltf": { + "source": "iana", + "extensions": ["ltf"] + }, + "application/vnd.fsc.weblaunch": { + "source": "iana", + "extensions": ["fsc"] + }, + "application/vnd.fujitsu.oasys": { + "source": "iana", + "extensions": ["oas"] + }, + "application/vnd.fujitsu.oasys2": { + "source": "iana", + "extensions": ["oa2"] + }, + "application/vnd.fujitsu.oasys3": { + "source": "iana", + "extensions": ["oa3"] + }, + "application/vnd.fujitsu.oasysgp": { + "source": "iana", + "extensions": ["fg5"] + }, + "application/vnd.fujitsu.oasysprs": { + "source": "iana", + "extensions": ["bh2"] + }, + "application/vnd.fujixerox.art-ex": { + "source": "iana" + }, + "application/vnd.fujixerox.art4": { + "source": "iana" + }, + "application/vnd.fujixerox.ddd": { + "source": "iana", + "extensions": ["ddd"] + }, + "application/vnd.fujixerox.docuworks": { + "source": "iana", + "extensions": ["xdw"] + }, + "application/vnd.fujixerox.docuworks.binder": { + "source": "iana", + "extensions": ["xbd"] + }, + "application/vnd.fujixerox.docuworks.container": { + "source": "iana" + }, + "application/vnd.fujixerox.hbpl": { + "source": "iana" + }, + "application/vnd.fut-misnet": { + "source": "iana" + }, + "application/vnd.fuzzysheet": { + "source": "iana", + "extensions": ["fzs"] + }, + "application/vnd.genomatix.tuxedo": { + "source": "iana", + "extensions": ["txd"] + }, + "application/vnd.geo+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.geocube+xml": { + "source": "iana" + }, + "application/vnd.geogebra.file": { + "source": "iana", + "extensions": ["ggb"] + }, + "application/vnd.geogebra.tool": { + "source": "iana", + "extensions": ["ggt"] + }, + "application/vnd.geometry-explorer": { + "source": "iana", + "extensions": ["gex","gre"] + }, + "application/vnd.geonext": { + "source": "iana", + "extensions": ["gxt"] + }, + "application/vnd.geoplan": { + "source": "iana", + "extensions": ["g2w"] + }, + "application/vnd.geospace": { + "source": "iana", + "extensions": ["g3w"] + }, + "application/vnd.gerber": { + "source": "iana" + }, + "application/vnd.globalplatform.card-content-mgt": { + "source": "iana" + }, + "application/vnd.globalplatform.card-content-mgt-response": { + "source": "iana" + }, + "application/vnd.gmx": { + "source": "iana", + "extensions": ["gmx"] + }, + "application/vnd.google-apps.document": { + "compressible": false, + "extensions": ["gdoc"] + }, + "application/vnd.google-apps.presentation": { + "compressible": false, + "extensions": ["gslides"] + }, + "application/vnd.google-apps.spreadsheet": { + "compressible": false, + "extensions": ["gsheet"] + }, + "application/vnd.google-earth.kml+xml": { + "source": "iana", + "compressible": true, + "extensions": ["kml"] + }, + "application/vnd.google-earth.kmz": { + "source": "iana", + "compressible": false, + "extensions": ["kmz"] + }, + "application/vnd.gov.sk.e-form+xml": { + "source": "iana" + }, + "application/vnd.gov.sk.e-form+zip": { + "source": "iana" + }, + "application/vnd.gov.sk.xmldatacontainer+xml": { + "source": "iana" + }, + "application/vnd.grafeq": { + "source": "iana", + "extensions": ["gqf","gqs"] + }, + "application/vnd.gridmp": { + "source": "iana" + }, + "application/vnd.groove-account": { + "source": "iana", + "extensions": ["gac"] + }, + "application/vnd.groove-help": { + "source": "iana", + "extensions": ["ghf"] + }, + "application/vnd.groove-identity-message": { + "source": "iana", + "extensions": ["gim"] + }, + "application/vnd.groove-injector": { + "source": "iana", + "extensions": ["grv"] + }, + "application/vnd.groove-tool-message": { + "source": "iana", + "extensions": ["gtm"] + }, + "application/vnd.groove-tool-template": { + "source": "iana", + "extensions": ["tpl"] + }, + "application/vnd.groove-vcard": { + "source": "iana", + "extensions": ["vcg"] + }, + "application/vnd.hal+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.hal+xml": { + "source": "iana", + "extensions": ["hal"] + }, + "application/vnd.handheld-entertainment+xml": { + "source": "iana", + "extensions": ["zmm"] + }, + "application/vnd.hbci": { + "source": "iana", + "extensions": ["hbci"] + }, + "application/vnd.hcl-bireports": { + "source": "iana" + }, + "application/vnd.hdt": { + "source": "iana" + }, + "application/vnd.heroku+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.hhe.lesson-player": { + "source": "iana", + "extensions": ["les"] + }, + "application/vnd.hp-hpgl": { + "source": "iana", + "extensions": ["hpgl"] + }, + "application/vnd.hp-hpid": { + "source": "iana", + "extensions": ["hpid"] + }, + "application/vnd.hp-hps": { + "source": "iana", + "extensions": ["hps"] + }, + "application/vnd.hp-jlyt": { + "source": "iana", + "extensions": ["jlt"] + }, + "application/vnd.hp-pcl": { + "source": "iana", + "extensions": ["pcl"] + }, + "application/vnd.hp-pclxl": { + "source": "iana", + "extensions": ["pclxl"] + }, + "application/vnd.httphone": { + "source": "iana" + }, + "application/vnd.hydrostatix.sof-data": { + "source": "iana", + "extensions": ["sfd-hdstx"] + }, + "application/vnd.hyperdrive+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.hzn-3d-crossword": { + "source": "iana" + }, + "application/vnd.ibm.afplinedata": { + "source": "iana" + }, + "application/vnd.ibm.electronic-media": { + "source": "iana" + }, + "application/vnd.ibm.minipay": { + "source": "iana", + "extensions": ["mpy"] + }, + "application/vnd.ibm.modcap": { + "source": "iana", + "extensions": ["afp","listafp","list3820"] + }, + "application/vnd.ibm.rights-management": { + "source": "iana", + "extensions": ["irm"] + }, + "application/vnd.ibm.secure-container": { + "source": "iana", + "extensions": ["sc"] + }, + "application/vnd.iccprofile": { + "source": "iana", + "extensions": ["icc","icm"] + }, + "application/vnd.ieee.1905": { + "source": "iana" + }, + "application/vnd.igloader": { + "source": "iana", + "extensions": ["igl"] + }, + "application/vnd.immervision-ivp": { + "source": "iana", + "extensions": ["ivp"] + }, + "application/vnd.immervision-ivu": { + "source": "iana", + "extensions": ["ivu"] + }, + "application/vnd.ims.imsccv1p1": { + "source": "iana" + }, + "application/vnd.ims.imsccv1p2": { + "source": "iana" + }, + "application/vnd.ims.imsccv1p3": { + "source": "iana" + }, + "application/vnd.ims.lis.v2.result+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.ims.lti.v2.toolconsumerprofile+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.ims.lti.v2.toolproxy+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.ims.lti.v2.toolproxy.id+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.ims.lti.v2.toolsettings+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.ims.lti.v2.toolsettings.simple+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.informedcontrol.rms+xml": { + "source": "iana" + }, + "application/vnd.informix-visionary": { + "source": "iana" + }, + "application/vnd.infotech.project": { + "source": "iana" + }, + "application/vnd.infotech.project+xml": { + "source": "iana" + }, + "application/vnd.innopath.wamp.notification": { + "source": "iana" + }, + "application/vnd.insors.igm": { + "source": "iana", + "extensions": ["igm"] + }, + "application/vnd.intercon.formnet": { + "source": "iana", + "extensions": ["xpw","xpx"] + }, + "application/vnd.intergeo": { + "source": "iana", + "extensions": ["i2g"] + }, + "application/vnd.intertrust.digibox": { + "source": "iana" + }, + "application/vnd.intertrust.nncp": { + "source": "iana" + }, + "application/vnd.intu.qbo": { + "source": "iana", + "extensions": ["qbo"] + }, + "application/vnd.intu.qfx": { + "source": "iana", + "extensions": ["qfx"] + }, + "application/vnd.iptc.g2.catalogitem+xml": { + "source": "iana" + }, + "application/vnd.iptc.g2.conceptitem+xml": { + "source": "iana" + }, + "application/vnd.iptc.g2.knowledgeitem+xml": { + "source": "iana" + }, + "application/vnd.iptc.g2.newsitem+xml": { + "source": "iana" + }, + "application/vnd.iptc.g2.newsmessage+xml": { + "source": "iana" + }, + "application/vnd.iptc.g2.packageitem+xml": { + "source": "iana" + }, + "application/vnd.iptc.g2.planningitem+xml": { + "source": "iana" + }, + "application/vnd.ipunplugged.rcprofile": { + "source": "iana", + "extensions": ["rcprofile"] + }, + "application/vnd.irepository.package+xml": { + "source": "iana", + "extensions": ["irp"] + }, + "application/vnd.is-xpr": { + "source": "iana", + "extensions": ["xpr"] + }, + "application/vnd.isac.fcs": { + "source": "iana", + "extensions": ["fcs"] + }, + "application/vnd.jam": { + "source": "iana", + "extensions": ["jam"] + }, + "application/vnd.japannet-directory-service": { + "source": "iana" + }, + "application/vnd.japannet-jpnstore-wakeup": { + "source": "iana" + }, + "application/vnd.japannet-payment-wakeup": { + "source": "iana" + }, + "application/vnd.japannet-registration": { + "source": "iana" + }, + "application/vnd.japannet-registration-wakeup": { + "source": "iana" + }, + "application/vnd.japannet-setstore-wakeup": { + "source": "iana" + }, + "application/vnd.japannet-verification": { + "source": "iana" + }, + "application/vnd.japannet-verification-wakeup": { + "source": "iana" + }, + "application/vnd.jcp.javame.midlet-rms": { + "source": "iana", + "extensions": ["rms"] + }, + "application/vnd.jisp": { + "source": "iana", + "extensions": ["jisp"] + }, + "application/vnd.joost.joda-archive": { + "source": "iana", + "extensions": ["joda"] + }, + "application/vnd.jsk.isdn-ngn": { + "source": "iana" + }, + "application/vnd.kahootz": { + "source": "iana", + "extensions": ["ktz","ktr"] + }, + "application/vnd.kde.karbon": { + "source": "iana", + "extensions": ["karbon"] + }, + "application/vnd.kde.kchart": { + "source": "iana", + "extensions": ["chrt"] + }, + "application/vnd.kde.kformula": { + "source": "iana", + "extensions": ["kfo"] + }, + "application/vnd.kde.kivio": { + "source": "iana", + "extensions": ["flw"] + }, + "application/vnd.kde.kontour": { + "source": "iana", + "extensions": ["kon"] + }, + "application/vnd.kde.kpresenter": { + "source": "iana", + "extensions": ["kpr","kpt"] + }, + "application/vnd.kde.kspread": { + "source": "iana", + "extensions": ["ksp"] + }, + "application/vnd.kde.kword": { + "source": "iana", + "extensions": ["kwd","kwt"] + }, + "application/vnd.kenameaapp": { + "source": "iana", + "extensions": ["htke"] + }, + "application/vnd.kidspiration": { + "source": "iana", + "extensions": ["kia"] + }, + "application/vnd.kinar": { + "source": "iana", + "extensions": ["kne","knp"] + }, + "application/vnd.koan": { + "source": "iana", + "extensions": ["skp","skd","skt","skm"] + }, + "application/vnd.kodak-descriptor": { + "source": "iana", + "extensions": ["sse"] + }, + "application/vnd.las.las+xml": { + "source": "iana", + "extensions": ["lasxml"] + }, + "application/vnd.liberty-request+xml": { + "source": "iana" + }, + "application/vnd.llamagraphics.life-balance.desktop": { + "source": "iana", + "extensions": ["lbd"] + }, + "application/vnd.llamagraphics.life-balance.exchange+xml": { + "source": "iana", + "extensions": ["lbe"] + }, + "application/vnd.lotus-1-2-3": { + "source": "iana", + "extensions": ["123"] + }, + "application/vnd.lotus-approach": { + "source": "iana", + "extensions": ["apr"] + }, + "application/vnd.lotus-freelance": { + "source": "iana", + "extensions": ["pre"] + }, + "application/vnd.lotus-notes": { + "source": "iana", + "extensions": ["nsf"] + }, + "application/vnd.lotus-organizer": { + "source": "iana", + "extensions": ["org"] + }, + "application/vnd.lotus-screencam": { + "source": "iana", + "extensions": ["scm"] + }, + "application/vnd.lotus-wordpro": { + "source": "iana", + "extensions": ["lwp"] + }, + "application/vnd.macports.portpkg": { + "source": "iana", + "extensions": ["portpkg"] + }, + "application/vnd.mapbox-vector-tile": { + "source": "iana" + }, + "application/vnd.marlin.drm.actiontoken+xml": { + "source": "iana" + }, + "application/vnd.marlin.drm.conftoken+xml": { + "source": "iana" + }, + "application/vnd.marlin.drm.license+xml": { + "source": "iana" + }, + "application/vnd.marlin.drm.mdcf": { + "source": "iana" + }, + "application/vnd.mason+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.maxmind.maxmind-db": { + "source": "iana" + }, + "application/vnd.mcd": { + "source": "iana", + "extensions": ["mcd"] + }, + "application/vnd.medcalcdata": { + "source": "iana", + "extensions": ["mc1"] + }, + "application/vnd.mediastation.cdkey": { + "source": "iana", + "extensions": ["cdkey"] + }, + "application/vnd.meridian-slingshot": { + "source": "iana" + }, + "application/vnd.mfer": { + "source": "iana", + "extensions": ["mwf"] + }, + "application/vnd.mfmp": { + "source": "iana", + "extensions": ["mfm"] + }, + "application/vnd.micro+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.micrografx.flo": { + "source": "iana", + "extensions": ["flo"] + }, + "application/vnd.micrografx.igx": { + "source": "iana", + "extensions": ["igx"] + }, + "application/vnd.microsoft.portable-executable": { + "source": "iana" + }, + "application/vnd.miele+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.mif": { + "source": "iana", + "extensions": ["mif"] + }, + "application/vnd.minisoft-hp3000-save": { + "source": "iana" + }, + "application/vnd.mitsubishi.misty-guard.trustweb": { + "source": "iana" + }, + "application/vnd.mobius.daf": { + "source": "iana", + "extensions": ["daf"] + }, + "application/vnd.mobius.dis": { + "source": "iana", + "extensions": ["dis"] + }, + "application/vnd.mobius.mbk": { + "source": "iana", + "extensions": ["mbk"] + }, + "application/vnd.mobius.mqy": { + "source": "iana", + "extensions": ["mqy"] + }, + "application/vnd.mobius.msl": { + "source": "iana", + "extensions": ["msl"] + }, + "application/vnd.mobius.plc": { + "source": "iana", + "extensions": ["plc"] + }, + "application/vnd.mobius.txf": { + "source": "iana", + "extensions": ["txf"] + }, + "application/vnd.mophun.application": { + "source": "iana", + "extensions": ["mpn"] + }, + "application/vnd.mophun.certificate": { + "source": "iana", + "extensions": ["mpc"] + }, + "application/vnd.motorola.flexsuite": { + "source": "iana" + }, + "application/vnd.motorola.flexsuite.adsi": { + "source": "iana" + }, + "application/vnd.motorola.flexsuite.fis": { + "source": "iana" + }, + "application/vnd.motorola.flexsuite.gotap": { + "source": "iana" + }, + "application/vnd.motorola.flexsuite.kmr": { + "source": "iana" + }, + "application/vnd.motorola.flexsuite.ttc": { + "source": "iana" + }, + "application/vnd.motorola.flexsuite.wem": { + "source": "iana" + }, + "application/vnd.motorola.iprm": { + "source": "iana" + }, + "application/vnd.mozilla.xul+xml": { + "source": "iana", + "compressible": true, + "extensions": ["xul"] + }, + "application/vnd.ms-3mfdocument": { + "source": "iana" + }, + "application/vnd.ms-artgalry": { + "source": "iana", + "extensions": ["cil"] + }, + "application/vnd.ms-asf": { + "source": "iana" + }, + "application/vnd.ms-cab-compressed": { + "source": "iana", + "extensions": ["cab"] + }, + "application/vnd.ms-color.iccprofile": { + "source": "apache" + }, + "application/vnd.ms-excel": { + "source": "iana", + "compressible": false, + "extensions": ["xls","xlm","xla","xlc","xlt","xlw"] + }, + "application/vnd.ms-excel.addin.macroenabled.12": { + "source": "iana", + "extensions": ["xlam"] + }, + "application/vnd.ms-excel.sheet.binary.macroenabled.12": { + "source": "iana", + "extensions": ["xlsb"] + }, + "application/vnd.ms-excel.sheet.macroenabled.12": { + "source": "iana", + "extensions": ["xlsm"] + }, + "application/vnd.ms-excel.template.macroenabled.12": { + "source": "iana", + "extensions": ["xltm"] + }, + "application/vnd.ms-fontobject": { + "source": "iana", + "compressible": true, + "extensions": ["eot"] + }, + "application/vnd.ms-htmlhelp": { + "source": "iana", + "extensions": ["chm"] + }, + "application/vnd.ms-ims": { + "source": "iana", + "extensions": ["ims"] + }, + "application/vnd.ms-lrm": { + "source": "iana", + "extensions": ["lrm"] + }, + "application/vnd.ms-office.activex+xml": { + "source": "iana" + }, + "application/vnd.ms-officetheme": { + "source": "iana", + "extensions": ["thmx"] + }, + "application/vnd.ms-opentype": { + "source": "apache", + "compressible": true + }, + "application/vnd.ms-package.obfuscated-opentype": { + "source": "apache" + }, + "application/vnd.ms-pki.seccat": { + "source": "apache", + "extensions": ["cat"] + }, + "application/vnd.ms-pki.stl": { + "source": "apache", + "extensions": ["stl"] + }, + "application/vnd.ms-playready.initiator+xml": { + "source": "iana" + }, + "application/vnd.ms-powerpoint": { + "source": "iana", + "compressible": false, + "extensions": ["ppt","pps","pot"] + }, + "application/vnd.ms-powerpoint.addin.macroenabled.12": { + "source": "iana", + "extensions": ["ppam"] + }, + "application/vnd.ms-powerpoint.presentation.macroenabled.12": { + "source": "iana", + "extensions": ["pptm"] + }, + "application/vnd.ms-powerpoint.slide.macroenabled.12": { + "source": "iana", + "extensions": ["sldm"] + }, + "application/vnd.ms-powerpoint.slideshow.macroenabled.12": { + "source": "iana", + "extensions": ["ppsm"] + }, + "application/vnd.ms-powerpoint.template.macroenabled.12": { + "source": "iana", + "extensions": ["potm"] + }, + "application/vnd.ms-printdevicecapabilities+xml": { + "source": "iana" + }, + "application/vnd.ms-printing.printticket+xml": { + "source": "apache" + }, + "application/vnd.ms-printschematicket+xml": { + "source": "iana" + }, + "application/vnd.ms-project": { + "source": "iana", + "extensions": ["mpp","mpt"] + }, + "application/vnd.ms-tnef": { + "source": "iana" + }, + "application/vnd.ms-windows.devicepairing": { + "source": "iana" + }, + "application/vnd.ms-windows.nwprinting.oob": { + "source": "iana" + }, + "application/vnd.ms-windows.printerpairing": { + "source": "iana" + }, + "application/vnd.ms-windows.wsd.oob": { + "source": "iana" + }, + "application/vnd.ms-wmdrm.lic-chlg-req": { + "source": "iana" + }, + "application/vnd.ms-wmdrm.lic-resp": { + "source": "iana" + }, + "application/vnd.ms-wmdrm.meter-chlg-req": { + "source": "iana" + }, + "application/vnd.ms-wmdrm.meter-resp": { + "source": "iana" + }, + "application/vnd.ms-word.document.macroenabled.12": { + "source": "iana", + "extensions": ["docm"] + }, + "application/vnd.ms-word.template.macroenabled.12": { + "source": "iana", + "extensions": ["dotm"] + }, + "application/vnd.ms-works": { + "source": "iana", + "extensions": ["wps","wks","wcm","wdb"] + }, + "application/vnd.ms-wpl": { + "source": "iana", + "extensions": ["wpl"] + }, + "application/vnd.ms-xpsdocument": { + "source": "iana", + "compressible": false, + "extensions": ["xps"] + }, + "application/vnd.msa-disk-image": { + "source": "iana" + }, + "application/vnd.mseq": { + "source": "iana", + "extensions": ["mseq"] + }, + "application/vnd.msign": { + "source": "iana" + }, + "application/vnd.multiad.creator": { + "source": "iana" + }, + "application/vnd.multiad.creator.cif": { + "source": "iana" + }, + "application/vnd.music-niff": { + "source": "iana" + }, + "application/vnd.musician": { + "source": "iana", + "extensions": ["mus"] + }, + "application/vnd.muvee.style": { + "source": "iana", + "extensions": ["msty"] + }, + "application/vnd.mynfc": { + "source": "iana", + "extensions": ["taglet"] + }, + "application/vnd.ncd.control": { + "source": "iana" + }, + "application/vnd.ncd.reference": { + "source": "iana" + }, + "application/vnd.nearst.inv+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.nervana": { + "source": "iana" + }, + "application/vnd.netfpx": { + "source": "iana" + }, + "application/vnd.neurolanguage.nlu": { + "source": "iana", + "extensions": ["nlu"] + }, + "application/vnd.nintendo.nitro.rom": { + "source": "iana" + }, + "application/vnd.nintendo.snes.rom": { + "source": "iana" + }, + "application/vnd.nitf": { + "source": "iana", + "extensions": ["ntf","nitf"] + }, + "application/vnd.noblenet-directory": { + "source": "iana", + "extensions": ["nnd"] + }, + "application/vnd.noblenet-sealer": { + "source": "iana", + "extensions": ["nns"] + }, + "application/vnd.noblenet-web": { + "source": "iana", + "extensions": ["nnw"] + }, + "application/vnd.nokia.catalogs": { + "source": "iana" + }, + "application/vnd.nokia.conml+wbxml": { + "source": "iana" + }, + "application/vnd.nokia.conml+xml": { + "source": "iana" + }, + "application/vnd.nokia.iptv.config+xml": { + "source": "iana" + }, + "application/vnd.nokia.isds-radio-presets": { + "source": "iana" + }, + "application/vnd.nokia.landmark+wbxml": { + "source": "iana" + }, + "application/vnd.nokia.landmark+xml": { + "source": "iana" + }, + "application/vnd.nokia.landmarkcollection+xml": { + "source": "iana" + }, + "application/vnd.nokia.n-gage.ac+xml": { + "source": "iana" + }, + "application/vnd.nokia.n-gage.data": { + "source": "iana", + "extensions": ["ngdat"] + }, + "application/vnd.nokia.n-gage.symbian.install": { + "source": "iana", + "extensions": ["n-gage"] + }, + "application/vnd.nokia.ncd": { + "source": "iana" + }, + "application/vnd.nokia.pcd+wbxml": { + "source": "iana" + }, + "application/vnd.nokia.pcd+xml": { + "source": "iana" + }, + "application/vnd.nokia.radio-preset": { + "source": "iana", + "extensions": ["rpst"] + }, + "application/vnd.nokia.radio-presets": { + "source": "iana", + "extensions": ["rpss"] + }, + "application/vnd.novadigm.edm": { + "source": "iana", + "extensions": ["edm"] + }, + "application/vnd.novadigm.edx": { + "source": "iana", + "extensions": ["edx"] + }, + "application/vnd.novadigm.ext": { + "source": "iana", + "extensions": ["ext"] + }, + "application/vnd.ntt-local.content-share": { + "source": "iana" + }, + "application/vnd.ntt-local.file-transfer": { + "source": "iana" + }, + "application/vnd.ntt-local.ogw_remote-access": { + "source": "iana" + }, + "application/vnd.ntt-local.sip-ta_remote": { + "source": "iana" + }, + "application/vnd.ntt-local.sip-ta_tcp_stream": { + "source": "iana" + }, + "application/vnd.oasis.opendocument.chart": { + "source": "iana", + "extensions": ["odc"] + }, + "application/vnd.oasis.opendocument.chart-template": { + "source": "iana", + "extensions": ["otc"] + }, + "application/vnd.oasis.opendocument.database": { + "source": "iana", + "extensions": ["odb"] + }, + "application/vnd.oasis.opendocument.formula": { + "source": "iana", + "extensions": ["odf"] + }, + "application/vnd.oasis.opendocument.formula-template": { + "source": "iana", + "extensions": ["odft"] + }, + "application/vnd.oasis.opendocument.graphics": { + "source": "iana", + "compressible": false, + "extensions": ["odg"] + }, + "application/vnd.oasis.opendocument.graphics-template": { + "source": "iana", + "extensions": ["otg"] + }, + "application/vnd.oasis.opendocument.image": { + "source": "iana", + "extensions": ["odi"] + }, + "application/vnd.oasis.opendocument.image-template": { + "source": "iana", + "extensions": ["oti"] + }, + "application/vnd.oasis.opendocument.presentation": { + "source": "iana", + "compressible": false, + "extensions": ["odp"] + }, + "application/vnd.oasis.opendocument.presentation-template": { + "source": "iana", + "extensions": ["otp"] + }, + "application/vnd.oasis.opendocument.spreadsheet": { + "source": "iana", + "compressible": false, + "extensions": ["ods"] + }, + "application/vnd.oasis.opendocument.spreadsheet-template": { + "source": "iana", + "extensions": ["ots"] + }, + "application/vnd.oasis.opendocument.text": { + "source": "iana", + "compressible": false, + "extensions": ["odt"] + }, + "application/vnd.oasis.opendocument.text-master": { + "source": "iana", + "extensions": ["odm"] + }, + "application/vnd.oasis.opendocument.text-template": { + "source": "iana", + "extensions": ["ott"] + }, + "application/vnd.oasis.opendocument.text-web": { + "source": "iana", + "extensions": ["oth"] + }, + "application/vnd.obn": { + "source": "iana" + }, + "application/vnd.oftn.l10n+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.oipf.contentaccessdownload+xml": { + "source": "iana" + }, + "application/vnd.oipf.contentaccessstreaming+xml": { + "source": "iana" + }, + "application/vnd.oipf.cspg-hexbinary": { + "source": "iana" + }, + "application/vnd.oipf.dae.svg+xml": { + "source": "iana" + }, + "application/vnd.oipf.dae.xhtml+xml": { + "source": "iana" + }, + "application/vnd.oipf.mippvcontrolmessage+xml": { + "source": "iana" + }, + "application/vnd.oipf.pae.gem": { + "source": "iana" + }, + "application/vnd.oipf.spdiscovery+xml": { + "source": "iana" + }, + "application/vnd.oipf.spdlist+xml": { + "source": "iana" + }, + "application/vnd.oipf.ueprofile+xml": { + "source": "iana" + }, + "application/vnd.oipf.userprofile+xml": { + "source": "iana" + }, + "application/vnd.olpc-sugar": { + "source": "iana", + "extensions": ["xo"] + }, + "application/vnd.oma-scws-config": { + "source": "iana" + }, + "application/vnd.oma-scws-http-request": { + "source": "iana" + }, + "application/vnd.oma-scws-http-response": { + "source": "iana" + }, + "application/vnd.oma.bcast.associated-procedure-parameter+xml": { + "source": "iana" + }, + "application/vnd.oma.bcast.drm-trigger+xml": { + "source": "iana" + }, + "application/vnd.oma.bcast.imd+xml": { + "source": "iana" + }, + "application/vnd.oma.bcast.ltkm": { + "source": "iana" + }, + "application/vnd.oma.bcast.notification+xml": { + "source": "iana" + }, + "application/vnd.oma.bcast.provisioningtrigger": { + "source": "iana" + }, + "application/vnd.oma.bcast.sgboot": { + "source": "iana" + }, + "application/vnd.oma.bcast.sgdd+xml": { + "source": "iana" + }, + "application/vnd.oma.bcast.sgdu": { + "source": "iana" + }, + "application/vnd.oma.bcast.simple-symbol-container": { + "source": "iana" + }, + "application/vnd.oma.bcast.smartcard-trigger+xml": { + "source": "iana" + }, + "application/vnd.oma.bcast.sprov+xml": { + "source": "iana" + }, + "application/vnd.oma.bcast.stkm": { + "source": "iana" + }, + "application/vnd.oma.cab-address-book+xml": { + "source": "iana" + }, + "application/vnd.oma.cab-feature-handler+xml": { + "source": "iana" + }, + "application/vnd.oma.cab-pcc+xml": { + "source": "iana" + }, + "application/vnd.oma.cab-subs-invite+xml": { + "source": "iana" + }, + "application/vnd.oma.cab-user-prefs+xml": { + "source": "iana" + }, + "application/vnd.oma.dcd": { + "source": "iana" + }, + "application/vnd.oma.dcdc": { + "source": "iana" + }, + "application/vnd.oma.dd2+xml": { + "source": "iana", + "extensions": ["dd2"] + }, + "application/vnd.oma.drm.risd+xml": { + "source": "iana" + }, + "application/vnd.oma.group-usage-list+xml": { + "source": "iana" + }, + "application/vnd.oma.lwm2m+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.oma.lwm2m+tlv": { + "source": "iana" + }, + "application/vnd.oma.pal+xml": { + "source": "iana" + }, + "application/vnd.oma.poc.detailed-progress-report+xml": { + "source": "iana" + }, + "application/vnd.oma.poc.final-report+xml": { + "source": "iana" + }, + "application/vnd.oma.poc.groups+xml": { + "source": "iana" + }, + "application/vnd.oma.poc.invocation-descriptor+xml": { + "source": "iana" + }, + "application/vnd.oma.poc.optimized-progress-report+xml": { + "source": "iana" + }, + "application/vnd.oma.push": { + "source": "iana" + }, + "application/vnd.oma.scidm.messages+xml": { + "source": "iana" + }, + "application/vnd.oma.xcap-directory+xml": { + "source": "iana" + }, + "application/vnd.omads-email+xml": { + "source": "iana" + }, + "application/vnd.omads-file+xml": { + "source": "iana" + }, + "application/vnd.omads-folder+xml": { + "source": "iana" + }, + "application/vnd.omaloc-supl-init": { + "source": "iana" + }, + "application/vnd.onepager": { + "source": "iana" + }, + "application/vnd.openblox.game+xml": { + "source": "iana" + }, + "application/vnd.openblox.game-binary": { + "source": "iana" + }, + "application/vnd.openeye.oeb": { + "source": "iana" + }, + "application/vnd.openofficeorg.extension": { + "source": "apache", + "extensions": ["oxt"] + }, + "application/vnd.openxmlformats-officedocument.custom-properties+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.customxmlproperties+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.drawing+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.drawingml.chart+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.drawingml.chartshapes+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.drawingml.diagramcolors+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.drawingml.diagramdata+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.drawingml.diagramlayout+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.drawingml.diagramstyle+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.extended-properties+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml-template": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml.commentauthors+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml.comments+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml.handoutmaster+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml.notesmaster+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml.notesslide+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml.presentation": { + "source": "iana", + "compressible": false, + "extensions": ["pptx"] + }, + "application/vnd.openxmlformats-officedocument.presentationml.presentation.main+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml.presprops+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml.slide": { + "source": "iana", + "extensions": ["sldx"] + }, + "application/vnd.openxmlformats-officedocument.presentationml.slide+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml.slidelayout+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml.slidemaster+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml.slideshow": { + "source": "iana", + "extensions": ["ppsx"] + }, + "application/vnd.openxmlformats-officedocument.presentationml.slideshow.main+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml.slideupdateinfo+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml.tablestyles+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml.tags+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml.template": { + "source": "apache", + "extensions": ["potx"] + }, + "application/vnd.openxmlformats-officedocument.presentationml.template.main+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml.viewprops+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml-template": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.calcchain+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.chartsheet+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.comments+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.connections+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.dialogsheet+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.externallink+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.pivotcachedefinition+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.pivotcacherecords+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.pivottable+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.querytable+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.revisionheaders+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.revisionlog+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.sharedstrings+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet": { + "source": "iana", + "compressible": false, + "extensions": ["xlsx"] + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet.main+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.sheetmetadata+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.styles+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.table+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.tablesinglecells+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.template": { + "source": "apache", + "extensions": ["xltx"] + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.template.main+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.usernames+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.volatiledependencies+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.worksheet+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.theme+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.themeoverride+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.vmldrawing": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.wordprocessingml-template": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.wordprocessingml.comments+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.wordprocessingml.document": { + "source": "iana", + "compressible": false, + "extensions": ["docx"] + }, + "application/vnd.openxmlformats-officedocument.wordprocessingml.document.glossary+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.wordprocessingml.document.main+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.wordprocessingml.endnotes+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.wordprocessingml.fonttable+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.wordprocessingml.footer+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.wordprocessingml.footnotes+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.wordprocessingml.numbering+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.wordprocessingml.settings+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.wordprocessingml.styles+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.wordprocessingml.template": { + "source": "apache", + "extensions": ["dotx"] + }, + "application/vnd.openxmlformats-officedocument.wordprocessingml.template.main+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.wordprocessingml.websettings+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-package.core-properties+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-package.digital-signature-xmlsignature+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-package.relationships+xml": { + "source": "iana" + }, + "application/vnd.oracle.resource+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.orange.indata": { + "source": "iana" + }, + "application/vnd.osa.netdeploy": { + "source": "iana" + }, + "application/vnd.osgeo.mapguide.package": { + "source": "iana", + "extensions": ["mgp"] + }, + "application/vnd.osgi.bundle": { + "source": "iana" + }, + "application/vnd.osgi.dp": { + "source": "iana", + "extensions": ["dp"] + }, + "application/vnd.osgi.subsystem": { + "source": "iana", + "extensions": ["esa"] + }, + "application/vnd.otps.ct-kip+xml": { + "source": "iana" + }, + "application/vnd.oxli.countgraph": { + "source": "iana" + }, + "application/vnd.pagerduty+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.palm": { + "source": "iana", + "extensions": ["pdb","pqa","oprc"] + }, + "application/vnd.panoply": { + "source": "iana" + }, + "application/vnd.paos+xml": { + "source": "iana" + }, + "application/vnd.paos.xml": { + "source": "apache" + }, + "application/vnd.pawaafile": { + "source": "iana", + "extensions": ["paw"] + }, + "application/vnd.pcos": { + "source": "iana" + }, + "application/vnd.pg.format": { + "source": "iana", + "extensions": ["str"] + }, + "application/vnd.pg.osasli": { + "source": "iana", + "extensions": ["ei6"] + }, + "application/vnd.piaccess.application-licence": { + "source": "iana" + }, + "application/vnd.picsel": { + "source": "iana", + "extensions": ["efif"] + }, + "application/vnd.pmi.widget": { + "source": "iana", + "extensions": ["wg"] + }, + "application/vnd.poc.group-advertisement+xml": { + "source": "iana" + }, + "application/vnd.pocketlearn": { + "source": "iana", + "extensions": ["plf"] + }, + "application/vnd.powerbuilder6": { + "source": "iana", + "extensions": ["pbd"] + }, + "application/vnd.powerbuilder6-s": { + "source": "iana" + }, + "application/vnd.powerbuilder7": { + "source": "iana" + }, + "application/vnd.powerbuilder7-s": { + "source": "iana" + }, + "application/vnd.powerbuilder75": { + "source": "iana" + }, + "application/vnd.powerbuilder75-s": { + "source": "iana" + }, + "application/vnd.preminet": { + "source": "iana" + }, + "application/vnd.previewsystems.box": { + "source": "iana", + "extensions": ["box"] + }, + "application/vnd.proteus.magazine": { + "source": "iana", + "extensions": ["mgz"] + }, + "application/vnd.publishare-delta-tree": { + "source": "iana", + "extensions": ["qps"] + }, + "application/vnd.pvi.ptid1": { + "source": "iana", + "extensions": ["ptid"] + }, + "application/vnd.pwg-multiplexed": { + "source": "iana" + }, + "application/vnd.pwg-xhtml-print+xml": { + "source": "iana" + }, + "application/vnd.qualcomm.brew-app-res": { + "source": "iana" + }, + "application/vnd.quarantainenet": { + "source": "iana" + }, + "application/vnd.quark.quarkxpress": { + "source": "iana", + "extensions": ["qxd","qxt","qwd","qwt","qxl","qxb"] + }, + "application/vnd.quobject-quoxdocument": { + "source": "iana" + }, + "application/vnd.radisys.moml+xml": { + "source": "iana" + }, + "application/vnd.radisys.msml+xml": { + "source": "iana" + }, + "application/vnd.radisys.msml-audit+xml": { + "source": "iana" + }, + "application/vnd.radisys.msml-audit-conf+xml": { + "source": "iana" + }, + "application/vnd.radisys.msml-audit-conn+xml": { + "source": "iana" + }, + "application/vnd.radisys.msml-audit-dialog+xml": { + "source": "iana" + }, + "application/vnd.radisys.msml-audit-stream+xml": { + "source": "iana" + }, + "application/vnd.radisys.msml-conf+xml": { + "source": "iana" + }, + "application/vnd.radisys.msml-dialog+xml": { + "source": "iana" + }, + "application/vnd.radisys.msml-dialog-base+xml": { + "source": "iana" + }, + "application/vnd.radisys.msml-dialog-fax-detect+xml": { + "source": "iana" + }, + "application/vnd.radisys.msml-dialog-fax-sendrecv+xml": { + "source": "iana" + }, + "application/vnd.radisys.msml-dialog-group+xml": { + "source": "iana" + }, + "application/vnd.radisys.msml-dialog-speech+xml": { + "source": "iana" + }, + "application/vnd.radisys.msml-dialog-transform+xml": { + "source": "iana" + }, + "application/vnd.rainstor.data": { + "source": "iana" + }, + "application/vnd.rapid": { + "source": "iana" + }, + "application/vnd.rar": { + "source": "iana" + }, + "application/vnd.realvnc.bed": { + "source": "iana", + "extensions": ["bed"] + }, + "application/vnd.recordare.musicxml": { + "source": "iana", + "extensions": ["mxl"] + }, + "application/vnd.recordare.musicxml+xml": { + "source": "iana", + "extensions": ["musicxml"] + }, + "application/vnd.renlearn.rlprint": { + "source": "iana" + }, + "application/vnd.rig.cryptonote": { + "source": "iana", + "extensions": ["cryptonote"] + }, + "application/vnd.rim.cod": { + "source": "apache", + "extensions": ["cod"] + }, + "application/vnd.rn-realmedia": { + "source": "apache", + "extensions": ["rm"] + }, + "application/vnd.rn-realmedia-vbr": { + "source": "apache", + "extensions": ["rmvb"] + }, + "application/vnd.route66.link66+xml": { + "source": "iana", + "extensions": ["link66"] + }, + "application/vnd.rs-274x": { + "source": "iana" + }, + "application/vnd.ruckus.download": { + "source": "iana" + }, + "application/vnd.s3sms": { + "source": "iana" + }, + "application/vnd.sailingtracker.track": { + "source": "iana", + "extensions": ["st"] + }, + "application/vnd.sbm.cid": { + "source": "iana" + }, + "application/vnd.sbm.mid2": { + "source": "iana" + }, + "application/vnd.scribus": { + "source": "iana" + }, + "application/vnd.sealed.3df": { + "source": "iana" + }, + "application/vnd.sealed.csf": { + "source": "iana" + }, + "application/vnd.sealed.doc": { + "source": "iana" + }, + "application/vnd.sealed.eml": { + "source": "iana" + }, + "application/vnd.sealed.mht": { + "source": "iana" + }, + "application/vnd.sealed.net": { + "source": "iana" + }, + "application/vnd.sealed.ppt": { + "source": "iana" + }, + "application/vnd.sealed.tiff": { + "source": "iana" + }, + "application/vnd.sealed.xls": { + "source": "iana" + }, + "application/vnd.sealedmedia.softseal.html": { + "source": "iana" + }, + "application/vnd.sealedmedia.softseal.pdf": { + "source": "iana" + }, + "application/vnd.seemail": { + "source": "iana", + "extensions": ["see"] + }, + "application/vnd.sema": { + "source": "iana", + "extensions": ["sema"] + }, + "application/vnd.semd": { + "source": "iana", + "extensions": ["semd"] + }, + "application/vnd.semf": { + "source": "iana", + "extensions": ["semf"] + }, + "application/vnd.shana.informed.formdata": { + "source": "iana", + "extensions": ["ifm"] + }, + "application/vnd.shana.informed.formtemplate": { + "source": "iana", + "extensions": ["itp"] + }, + "application/vnd.shana.informed.interchange": { + "source": "iana", + "extensions": ["iif"] + }, + "application/vnd.shana.informed.package": { + "source": "iana", + "extensions": ["ipk"] + }, + "application/vnd.simtech-mindmapper": { + "source": "iana", + "extensions": ["twd","twds"] + }, + "application/vnd.siren+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.smaf": { + "source": "iana", + "extensions": ["mmf"] + }, + "application/vnd.smart.notebook": { + "source": "iana" + }, + "application/vnd.smart.teacher": { + "source": "iana", + "extensions": ["teacher"] + }, + "application/vnd.software602.filler.form+xml": { + "source": "iana" + }, + "application/vnd.software602.filler.form-xml-zip": { + "source": "iana" + }, + "application/vnd.solent.sdkm+xml": { + "source": "iana", + "extensions": ["sdkm","sdkd"] + }, + "application/vnd.spotfire.dxp": { + "source": "iana", + "extensions": ["dxp"] + }, + "application/vnd.spotfire.sfs": { + "source": "iana", + "extensions": ["sfs"] + }, + "application/vnd.sss-cod": { + "source": "iana" + }, + "application/vnd.sss-dtf": { + "source": "iana" + }, + "application/vnd.sss-ntf": { + "source": "iana" + }, + "application/vnd.stardivision.calc": { + "source": "apache", + "extensions": ["sdc"] + }, + "application/vnd.stardivision.draw": { + "source": "apache", + "extensions": ["sda"] + }, + "application/vnd.stardivision.impress": { + "source": "apache", + "extensions": ["sdd"] + }, + "application/vnd.stardivision.math": { + "source": "apache", + "extensions": ["smf"] + }, + "application/vnd.stardivision.writer": { + "source": "apache", + "extensions": ["sdw","vor"] + }, + "application/vnd.stardivision.writer-global": { + "source": "apache", + "extensions": ["sgl"] + }, + "application/vnd.stepmania.package": { + "source": "iana", + "extensions": ["smzip"] + }, + "application/vnd.stepmania.stepchart": { + "source": "iana", + "extensions": ["sm"] + }, + "application/vnd.street-stream": { + "source": "iana" + }, + "application/vnd.sun.wadl+xml": { + "source": "iana" + }, + "application/vnd.sun.xml.calc": { + "source": "apache", + "extensions": ["sxc"] + }, + "application/vnd.sun.xml.calc.template": { + "source": "apache", + "extensions": ["stc"] + }, + "application/vnd.sun.xml.draw": { + "source": "apache", + "extensions": ["sxd"] + }, + "application/vnd.sun.xml.draw.template": { + "source": "apache", + "extensions": ["std"] + }, + "application/vnd.sun.xml.impress": { + "source": "apache", + "extensions": ["sxi"] + }, + "application/vnd.sun.xml.impress.template": { + "source": "apache", + "extensions": ["sti"] + }, + "application/vnd.sun.xml.math": { + "source": "apache", + "extensions": ["sxm"] + }, + "application/vnd.sun.xml.writer": { + "source": "apache", + "extensions": ["sxw"] + }, + "application/vnd.sun.xml.writer.global": { + "source": "apache", + "extensions": ["sxg"] + }, + "application/vnd.sun.xml.writer.template": { + "source": "apache", + "extensions": ["stw"] + }, + "application/vnd.sus-calendar": { + "source": "iana", + "extensions": ["sus","susp"] + }, + "application/vnd.svd": { + "source": "iana", + "extensions": ["svd"] + }, + "application/vnd.swiftview-ics": { + "source": "iana" + }, + "application/vnd.symbian.install": { + "source": "apache", + "extensions": ["sis","sisx"] + }, + "application/vnd.syncml+xml": { + "source": "iana", + "extensions": ["xsm"] + }, + "application/vnd.syncml.dm+wbxml": { + "source": "iana", + "extensions": ["bdm"] + }, + "application/vnd.syncml.dm+xml": { + "source": "iana", + "extensions": ["xdm"] + }, + "application/vnd.syncml.dm.notification": { + "source": "iana" + }, + "application/vnd.syncml.dmddf+wbxml": { + "source": "iana" + }, + "application/vnd.syncml.dmddf+xml": { + "source": "iana" + }, + "application/vnd.syncml.dmtnds+wbxml": { + "source": "iana" + }, + "application/vnd.syncml.dmtnds+xml": { + "source": "iana" + }, + "application/vnd.syncml.ds.notification": { + "source": "iana" + }, + "application/vnd.tao.intent-module-archive": { + "source": "iana", + "extensions": ["tao"] + }, + "application/vnd.tcpdump.pcap": { + "source": "iana", + "extensions": ["pcap","cap","dmp"] + }, + "application/vnd.tmd.mediaflex.api+xml": { + "source": "iana" + }, + "application/vnd.tml": { + "source": "iana" + }, + "application/vnd.tmobile-livetv": { + "source": "iana", + "extensions": ["tmo"] + }, + "application/vnd.trid.tpt": { + "source": "iana", + "extensions": ["tpt"] + }, + "application/vnd.triscape.mxs": { + "source": "iana", + "extensions": ["mxs"] + }, + "application/vnd.trueapp": { + "source": "iana", + "extensions": ["tra"] + }, + "application/vnd.truedoc": { + "source": "iana" + }, + "application/vnd.ubisoft.webplayer": { + "source": "iana" + }, + "application/vnd.ufdl": { + "source": "iana", + "extensions": ["ufd","ufdl"] + }, + "application/vnd.uiq.theme": { + "source": "iana", + "extensions": ["utz"] + }, + "application/vnd.umajin": { + "source": "iana", + "extensions": ["umj"] + }, + "application/vnd.unity": { + "source": "iana", + "extensions": ["unityweb"] + }, + "application/vnd.uoml+xml": { + "source": "iana", + "extensions": ["uoml"] + }, + "application/vnd.uplanet.alert": { + "source": "iana" + }, + "application/vnd.uplanet.alert-wbxml": { + "source": "iana" + }, + "application/vnd.uplanet.bearer-choice": { + "source": "iana" + }, + "application/vnd.uplanet.bearer-choice-wbxml": { + "source": "iana" + }, + "application/vnd.uplanet.cacheop": { + "source": "iana" + }, + "application/vnd.uplanet.cacheop-wbxml": { + "source": "iana" + }, + "application/vnd.uplanet.channel": { + "source": "iana" + }, + "application/vnd.uplanet.channel-wbxml": { + "source": "iana" + }, + "application/vnd.uplanet.list": { + "source": "iana" + }, + "application/vnd.uplanet.list-wbxml": { + "source": "iana" + }, + "application/vnd.uplanet.listcmd": { + "source": "iana" + }, + "application/vnd.uplanet.listcmd-wbxml": { + "source": "iana" + }, + "application/vnd.uplanet.signal": { + "source": "iana" + }, + "application/vnd.uri-map": { + "source": "iana" + }, + "application/vnd.valve.source.material": { + "source": "iana" + }, + "application/vnd.vcx": { + "source": "iana", + "extensions": ["vcx"] + }, + "application/vnd.vd-study": { + "source": "iana" + }, + "application/vnd.vectorworks": { + "source": "iana" + }, + "application/vnd.vel+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.verimatrix.vcas": { + "source": "iana" + }, + "application/vnd.vidsoft.vidconference": { + "source": "iana" + }, + "application/vnd.visio": { + "source": "iana", + "extensions": ["vsd","vst","vss","vsw"] + }, + "application/vnd.visionary": { + "source": "iana", + "extensions": ["vis"] + }, + "application/vnd.vividence.scriptfile": { + "source": "iana" + }, + "application/vnd.vsf": { + "source": "iana", + "extensions": ["vsf"] + }, + "application/vnd.wap.sic": { + "source": "iana" + }, + "application/vnd.wap.slc": { + "source": "iana" + }, + "application/vnd.wap.wbxml": { + "source": "iana", + "extensions": ["wbxml"] + }, + "application/vnd.wap.wmlc": { + "source": "iana", + "extensions": ["wmlc"] + }, + "application/vnd.wap.wmlscriptc": { + "source": "iana", + "extensions": ["wmlsc"] + }, + "application/vnd.webturbo": { + "source": "iana", + "extensions": ["wtb"] + }, + "application/vnd.wfa.p2p": { + "source": "iana" + }, + "application/vnd.wfa.wsc": { + "source": "iana" + }, + "application/vnd.windows.devicepairing": { + "source": "iana" + }, + "application/vnd.wmc": { + "source": "iana" + }, + "application/vnd.wmf.bootstrap": { + "source": "iana" + }, + "application/vnd.wolfram.mathematica": { + "source": "iana" + }, + "application/vnd.wolfram.mathematica.package": { + "source": "iana" + }, + "application/vnd.wolfram.player": { + "source": "iana", + "extensions": ["nbp"] + }, + "application/vnd.wordperfect": { + "source": "iana", + "extensions": ["wpd"] + }, + "application/vnd.wqd": { + "source": "iana", + "extensions": ["wqd"] + }, + "application/vnd.wrq-hp3000-labelled": { + "source": "iana" + }, + "application/vnd.wt.stf": { + "source": "iana", + "extensions": ["stf"] + }, + "application/vnd.wv.csp+wbxml": { + "source": "iana" + }, + "application/vnd.wv.csp+xml": { + "source": "iana" + }, + "application/vnd.wv.ssp+xml": { + "source": "iana" + }, + "application/vnd.xacml+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.xara": { + "source": "iana", + "extensions": ["xar"] + }, + "application/vnd.xfdl": { + "source": "iana", + "extensions": ["xfdl"] + }, + "application/vnd.xfdl.webform": { + "source": "iana" + }, + "application/vnd.xmi+xml": { + "source": "iana" + }, + "application/vnd.xmpie.cpkg": { + "source": "iana" + }, + "application/vnd.xmpie.dpkg": { + "source": "iana" + }, + "application/vnd.xmpie.plan": { + "source": "iana" + }, + "application/vnd.xmpie.ppkg": { + "source": "iana" + }, + "application/vnd.xmpie.xlim": { + "source": "iana" + }, + "application/vnd.yamaha.hv-dic": { + "source": "iana", + "extensions": ["hvd"] + }, + "application/vnd.yamaha.hv-script": { + "source": "iana", + "extensions": ["hvs"] + }, + "application/vnd.yamaha.hv-voice": { + "source": "iana", + "extensions": ["hvp"] + }, + "application/vnd.yamaha.openscoreformat": { + "source": "iana", + "extensions": ["osf"] + }, + "application/vnd.yamaha.openscoreformat.osfpvg+xml": { + "source": "iana", + "extensions": ["osfpvg"] + }, + "application/vnd.yamaha.remote-setup": { + "source": "iana" + }, + "application/vnd.yamaha.smaf-audio": { + "source": "iana", + "extensions": ["saf"] + }, + "application/vnd.yamaha.smaf-phrase": { + "source": "iana", + "extensions": ["spf"] + }, + "application/vnd.yamaha.through-ngn": { + "source": "iana" + }, + "application/vnd.yamaha.tunnel-udpencap": { + "source": "iana" + }, + "application/vnd.yaoweme": { + "source": "iana" + }, + "application/vnd.yellowriver-custom-menu": { + "source": "iana", + "extensions": ["cmp"] + }, + "application/vnd.zul": { + "source": "iana", + "extensions": ["zir","zirz"] + }, + "application/vnd.zzazz.deck+xml": { + "source": "iana", + "extensions": ["zaz"] + }, + "application/voicexml+xml": { + "source": "iana", + "extensions": ["vxml"] + }, + "application/vq-rtcpxr": { + "source": "iana" + }, + "application/watcherinfo+xml": { + "source": "iana" + }, + "application/whoispp-query": { + "source": "iana" + }, + "application/whoispp-response": { + "source": "iana" + }, + "application/widget": { + "source": "iana", + "extensions": ["wgt"] + }, + "application/winhlp": { + "source": "apache", + "extensions": ["hlp"] + }, + "application/wita": { + "source": "iana" + }, + "application/wordperfect5.1": { + "source": "iana" + }, + "application/wsdl+xml": { + "source": "iana", + "extensions": ["wsdl"] + }, + "application/wspolicy+xml": { + "source": "iana", + "extensions": ["wspolicy"] + }, + "application/x-7z-compressed": { + "source": "apache", + "compressible": false, + "extensions": ["7z"] + }, + "application/x-abiword": { + "source": "apache", + "extensions": ["abw"] + }, + "application/x-ace-compressed": { + "source": "apache", + "extensions": ["ace"] + }, + "application/x-amf": { + "source": "apache" + }, + "application/x-apple-diskimage": { + "source": "apache", + "extensions": ["dmg"] + }, + "application/x-authorware-bin": { + "source": "apache", + "extensions": ["aab","x32","u32","vox"] + }, + "application/x-authorware-map": { + "source": "apache", + "extensions": ["aam"] + }, + "application/x-authorware-seg": { + "source": "apache", + "extensions": ["aas"] + }, + "application/x-bcpio": { + "source": "apache", + "extensions": ["bcpio"] + }, + "application/x-bdoc": { + "compressible": false, + "extensions": ["bdoc"] + }, + "application/x-bittorrent": { + "source": "apache", + "extensions": ["torrent"] + }, + "application/x-blorb": { + "source": "apache", + "extensions": ["blb","blorb"] + }, + "application/x-bzip": { + "source": "apache", + "compressible": false, + "extensions": ["bz"] + }, + "application/x-bzip2": { + "source": "apache", + "compressible": false, + "extensions": ["bz2","boz"] + }, + "application/x-cbr": { + "source": "apache", + "extensions": ["cbr","cba","cbt","cbz","cb7"] + }, + "application/x-cdlink": { + "source": "apache", + "extensions": ["vcd"] + }, + "application/x-cfs-compressed": { + "source": "apache", + "extensions": ["cfs"] + }, + "application/x-chat": { + "source": "apache", + "extensions": ["chat"] + }, + "application/x-chess-pgn": { + "source": "apache", + "extensions": ["pgn"] + }, + "application/x-chrome-extension": { + "extensions": ["crx"] + }, + "application/x-cocoa": { + "source": "nginx", + "extensions": ["cco"] + }, + "application/x-compress": { + "source": "apache" + }, + "application/x-conference": { + "source": "apache", + "extensions": ["nsc"] + }, + "application/x-cpio": { + "source": "apache", + "extensions": ["cpio"] + }, + "application/x-csh": { + "source": "apache", + "extensions": ["csh"] + }, + "application/x-deb": { + "compressible": false + }, + "application/x-debian-package": { + "source": "apache", + "extensions": ["deb","udeb"] + }, + "application/x-dgc-compressed": { + "source": "apache", + "extensions": ["dgc"] + }, + "application/x-director": { + "source": "apache", + "extensions": ["dir","dcr","dxr","cst","cct","cxt","w3d","fgd","swa"] + }, + "application/x-doom": { + "source": "apache", + "extensions": ["wad"] + }, + "application/x-dtbncx+xml": { + "source": "apache", + "extensions": ["ncx"] + }, + "application/x-dtbook+xml": { + "source": "apache", + "extensions": ["dtb"] + }, + "application/x-dtbresource+xml": { + "source": "apache", + "extensions": ["res"] + }, + "application/x-dvi": { + "source": "apache", + "compressible": false, + "extensions": ["dvi"] + }, + "application/x-envoy": { + "source": "apache", + "extensions": ["evy"] + }, + "application/x-eva": { + "source": "apache", + "extensions": ["eva"] + }, + "application/x-font-bdf": { + "source": "apache", + "extensions": ["bdf"] + }, + "application/x-font-dos": { + "source": "apache" + }, + "application/x-font-framemaker": { + "source": "apache" + }, + "application/x-font-ghostscript": { + "source": "apache", + "extensions": ["gsf"] + }, + "application/x-font-libgrx": { + "source": "apache" + }, + "application/x-font-linux-psf": { + "source": "apache", + "extensions": ["psf"] + }, + "application/x-font-otf": { + "source": "apache", + "compressible": true, + "extensions": ["otf"] + }, + "application/x-font-pcf": { + "source": "apache", + "extensions": ["pcf"] + }, + "application/x-font-snf": { + "source": "apache", + "extensions": ["snf"] + }, + "application/x-font-speedo": { + "source": "apache" + }, + "application/x-font-sunos-news": { + "source": "apache" + }, + "application/x-font-ttf": { + "source": "apache", + "compressible": true, + "extensions": ["ttf","ttc"] + }, + "application/x-font-type1": { + "source": "apache", + "extensions": ["pfa","pfb","pfm","afm"] + }, + "application/x-font-vfont": { + "source": "apache" + }, + "application/x-freearc": { + "source": "apache", + "extensions": ["arc"] + }, + "application/x-futuresplash": { + "source": "apache", + "extensions": ["spl"] + }, + "application/x-gca-compressed": { + "source": "apache", + "extensions": ["gca"] + }, + "application/x-glulx": { + "source": "apache", + "extensions": ["ulx"] + }, + "application/x-gnumeric": { + "source": "apache", + "extensions": ["gnumeric"] + }, + "application/x-gramps-xml": { + "source": "apache", + "extensions": ["gramps"] + }, + "application/x-gtar": { + "source": "apache", + "extensions": ["gtar"] + }, + "application/x-gzip": { + "source": "apache" + }, + "application/x-hdf": { + "source": "apache", + "extensions": ["hdf"] + }, + "application/x-httpd-php": { + "compressible": true, + "extensions": ["php"] + }, + "application/x-install-instructions": { + "source": "apache", + "extensions": ["install"] + }, + "application/x-iso9660-image": { + "source": "apache", + "extensions": ["iso"] + }, + "application/x-java-archive-diff": { + "source": "nginx", + "extensions": ["jardiff"] + }, + "application/x-java-jnlp-file": { + "source": "apache", + "compressible": false, + "extensions": ["jnlp"] + }, + "application/x-javascript": { + "compressible": true + }, + "application/x-latex": { + "source": "apache", + "compressible": false, + "extensions": ["latex"] + }, + "application/x-lua-bytecode": { + "extensions": ["luac"] + }, + "application/x-lzh-compressed": { + "source": "apache", + "extensions": ["lzh","lha"] + }, + "application/x-makeself": { + "source": "nginx", + "extensions": ["run"] + }, + "application/x-mie": { + "source": "apache", + "extensions": ["mie"] + }, + "application/x-mobipocket-ebook": { + "source": "apache", + "extensions": ["prc","mobi"] + }, + "application/x-mpegurl": { + "compressible": false + }, + "application/x-ms-application": { + "source": "apache", + "extensions": ["application"] + }, + "application/x-ms-shortcut": { + "source": "apache", + "extensions": ["lnk"] + }, + "application/x-ms-wmd": { + "source": "apache", + "extensions": ["wmd"] + }, + "application/x-ms-wmz": { + "source": "apache", + "extensions": ["wmz"] + }, + "application/x-ms-xbap": { + "source": "apache", + "extensions": ["xbap"] + }, + "application/x-msaccess": { + "source": "apache", + "extensions": ["mdb"] + }, + "application/x-msbinder": { + "source": "apache", + "extensions": ["obd"] + }, + "application/x-mscardfile": { + "source": "apache", + "extensions": ["crd"] + }, + "application/x-msclip": { + "source": "apache", + "extensions": ["clp"] + }, + "application/x-msdos-program": { + "extensions": ["exe"] + }, + "application/x-msdownload": { + "source": "apache", + "extensions": ["exe","dll","com","bat","msi"] + }, + "application/x-msmediaview": { + "source": "apache", + "extensions": ["mvb","m13","m14"] + }, + "application/x-msmetafile": { + "source": "apache", + "extensions": ["wmf","wmz","emf","emz"] + }, + "application/x-msmoney": { + "source": "apache", + "extensions": ["mny"] + }, + "application/x-mspublisher": { + "source": "apache", + "extensions": ["pub"] + }, + "application/x-msschedule": { + "source": "apache", + "extensions": ["scd"] + }, + "application/x-msterminal": { + "source": "apache", + "extensions": ["trm"] + }, + "application/x-mswrite": { + "source": "apache", + "extensions": ["wri"] + }, + "application/x-netcdf": { + "source": "apache", + "extensions": ["nc","cdf"] + }, + "application/x-ns-proxy-autoconfig": { + "compressible": true, + "extensions": ["pac"] + }, + "application/x-nzb": { + "source": "apache", + "extensions": ["nzb"] + }, + "application/x-perl": { + "source": "nginx", + "extensions": ["pl","pm"] + }, + "application/x-pilot": { + "source": "nginx", + "extensions": ["prc","pdb"] + }, + "application/x-pkcs12": { + "source": "apache", + "compressible": false, + "extensions": ["p12","pfx"] + }, + "application/x-pkcs7-certificates": { + "source": "apache", + "extensions": ["p7b","spc"] + }, + "application/x-pkcs7-certreqresp": { + "source": "apache", + "extensions": ["p7r"] + }, + "application/x-rar-compressed": { + "source": "apache", + "compressible": false, + "extensions": ["rar"] + }, + "application/x-redhat-package-manager": { + "source": "nginx", + "extensions": ["rpm"] + }, + "application/x-research-info-systems": { + "source": "apache", + "extensions": ["ris"] + }, + "application/x-sea": { + "source": "nginx", + "extensions": ["sea"] + }, + "application/x-sh": { + "source": "apache", + "compressible": true, + "extensions": ["sh"] + }, + "application/x-shar": { + "source": "apache", + "extensions": ["shar"] + }, + "application/x-shockwave-flash": { + "source": "apache", + "compressible": false, + "extensions": ["swf"] + }, + "application/x-silverlight-app": { + "source": "apache", + "extensions": ["xap"] + }, + "application/x-sql": { + "source": "apache", + "extensions": ["sql"] + }, + "application/x-stuffit": { + "source": "apache", + "compressible": false, + "extensions": ["sit"] + }, + "application/x-stuffitx": { + "source": "apache", + "extensions": ["sitx"] + }, + "application/x-subrip": { + "source": "apache", + "extensions": ["srt"] + }, + "application/x-sv4cpio": { + "source": "apache", + "extensions": ["sv4cpio"] + }, + "application/x-sv4crc": { + "source": "apache", + "extensions": ["sv4crc"] + }, + "application/x-t3vm-image": { + "source": "apache", + "extensions": ["t3"] + }, + "application/x-tads": { + "source": "apache", + "extensions": ["gam"] + }, + "application/x-tar": { + "source": "apache", + "compressible": true, + "extensions": ["tar"] + }, + "application/x-tcl": { + "source": "apache", + "extensions": ["tcl","tk"] + }, + "application/x-tex": { + "source": "apache", + "extensions": ["tex"] + }, + "application/x-tex-tfm": { + "source": "apache", + "extensions": ["tfm"] + }, + "application/x-texinfo": { + "source": "apache", + "extensions": ["texinfo","texi"] + }, + "application/x-tgif": { + "source": "apache", + "extensions": ["obj"] + }, + "application/x-ustar": { + "source": "apache", + "extensions": ["ustar"] + }, + "application/x-wais-source": { + "source": "apache", + "extensions": ["src"] + }, + "application/x-web-app-manifest+json": { + "compressible": true, + "extensions": ["webapp"] + }, + "application/x-www-form-urlencoded": { + "source": "iana", + "compressible": true + }, + "application/x-x509-ca-cert": { + "source": "apache", + "extensions": ["der","crt","pem"] + }, + "application/x-xfig": { + "source": "apache", + "extensions": ["fig"] + }, + "application/x-xliff+xml": { + "source": "apache", + "extensions": ["xlf"] + }, + "application/x-xpinstall": { + "source": "apache", + "compressible": false, + "extensions": ["xpi"] + }, + "application/x-xz": { + "source": "apache", + "extensions": ["xz"] + }, + "application/x-zmachine": { + "source": "apache", + "extensions": ["z1","z2","z3","z4","z5","z6","z7","z8"] + }, + "application/x400-bp": { + "source": "iana" + }, + "application/xacml+xml": { + "source": "iana" + }, + "application/xaml+xml": { + "source": "apache", + "extensions": ["xaml"] + }, + "application/xcap-att+xml": { + "source": "iana" + }, + "application/xcap-caps+xml": { + "source": "iana" + }, + "application/xcap-diff+xml": { + "source": "iana", + "extensions": ["xdf"] + }, + "application/xcap-el+xml": { + "source": "iana" + }, + "application/xcap-error+xml": { + "source": "iana" + }, + "application/xcap-ns+xml": { + "source": "iana" + }, + "application/xcon-conference-info+xml": { + "source": "iana" + }, + "application/xcon-conference-info-diff+xml": { + "source": "iana" + }, + "application/xenc+xml": { + "source": "iana", + "extensions": ["xenc"] + }, + "application/xhtml+xml": { + "source": "iana", + "compressible": true, + "extensions": ["xhtml","xht"] + }, + "application/xhtml-voice+xml": { + "source": "apache" + }, + "application/xml": { + "source": "iana", + "compressible": true, + "extensions": ["xml","xsl","xsd","rng"] + }, + "application/xml-dtd": { + "source": "iana", + "compressible": true, + "extensions": ["dtd"] + }, + "application/xml-external-parsed-entity": { + "source": "iana" + }, + "application/xml-patch+xml": { + "source": "iana" + }, + "application/xmpp+xml": { + "source": "iana" + }, + "application/xop+xml": { + "source": "iana", + "compressible": true, + "extensions": ["xop"] + }, + "application/xproc+xml": { + "source": "apache", + "extensions": ["xpl"] + }, + "application/xslt+xml": { + "source": "iana", + "extensions": ["xslt"] + }, + "application/xspf+xml": { + "source": "apache", + "extensions": ["xspf"] + }, + "application/xv+xml": { + "source": "iana", + "extensions": ["mxml","xhvml","xvml","xvm"] + }, + "application/yang": { + "source": "iana", + "extensions": ["yang"] + }, + "application/yin+xml": { + "source": "iana", + "extensions": ["yin"] + }, + "application/zip": { + "source": "iana", + "compressible": false, + "extensions": ["zip"] + }, + "application/zlib": { + "source": "iana" + }, + "audio/1d-interleaved-parityfec": { + "source": "iana" + }, + "audio/32kadpcm": { + "source": "iana" + }, + "audio/3gpp": { + "source": "iana", + "compressible": false, + "extensions": ["3gpp"] + }, + "audio/3gpp2": { + "source": "iana" + }, + "audio/ac3": { + "source": "iana" + }, + "audio/adpcm": { + "source": "apache", + "extensions": ["adp"] + }, + "audio/amr": { + "source": "iana" + }, + "audio/amr-wb": { + "source": "iana" + }, + "audio/amr-wb+": { + "source": "iana" + }, + "audio/aptx": { + "source": "iana" + }, + "audio/asc": { + "source": "iana" + }, + "audio/atrac-advanced-lossless": { + "source": "iana" + }, + "audio/atrac-x": { + "source": "iana" + }, + "audio/atrac3": { + "source": "iana" + }, + "audio/basic": { + "source": "iana", + "compressible": false, + "extensions": ["au","snd"] + }, + "audio/bv16": { + "source": "iana" + }, + "audio/bv32": { + "source": "iana" + }, + "audio/clearmode": { + "source": "iana" + }, + "audio/cn": { + "source": "iana" + }, + "audio/dat12": { + "source": "iana" + }, + "audio/dls": { + "source": "iana" + }, + "audio/dsr-es201108": { + "source": "iana" + }, + "audio/dsr-es202050": { + "source": "iana" + }, + "audio/dsr-es202211": { + "source": "iana" + }, + "audio/dsr-es202212": { + "source": "iana" + }, + "audio/dv": { + "source": "iana" + }, + "audio/dvi4": { + "source": "iana" + }, + "audio/eac3": { + "source": "iana" + }, + "audio/encaprtp": { + "source": "iana" + }, + "audio/evrc": { + "source": "iana" + }, + "audio/evrc-qcp": { + "source": "iana" + }, + "audio/evrc0": { + "source": "iana" + }, + "audio/evrc1": { + "source": "iana" + }, + "audio/evrcb": { + "source": "iana" + }, + "audio/evrcb0": { + "source": "iana" + }, + "audio/evrcb1": { + "source": "iana" + }, + "audio/evrcnw": { + "source": "iana" + }, + "audio/evrcnw0": { + "source": "iana" + }, + "audio/evrcnw1": { + "source": "iana" + }, + "audio/evrcwb": { + "source": "iana" + }, + "audio/evrcwb0": { + "source": "iana" + }, + "audio/evrcwb1": { + "source": "iana" + }, + "audio/evs": { + "source": "iana" + }, + "audio/fwdred": { + "source": "iana" + }, + "audio/g711-0": { + "source": "iana" + }, + "audio/g719": { + "source": "iana" + }, + "audio/g722": { + "source": "iana" + }, + "audio/g7221": { + "source": "iana" + }, + "audio/g723": { + "source": "iana" + }, + "audio/g726-16": { + "source": "iana" + }, + "audio/g726-24": { + "source": "iana" + }, + "audio/g726-32": { + "source": "iana" + }, + "audio/g726-40": { + "source": "iana" + }, + "audio/g728": { + "source": "iana" + }, + "audio/g729": { + "source": "iana" + }, + "audio/g7291": { + "source": "iana" + }, + "audio/g729d": { + "source": "iana" + }, + "audio/g729e": { + "source": "iana" + }, + "audio/gsm": { + "source": "iana" + }, + "audio/gsm-efr": { + "source": "iana" + }, + "audio/gsm-hr-08": { + "source": "iana" + }, + "audio/ilbc": { + "source": "iana" + }, + "audio/ip-mr_v2.5": { + "source": "iana" + }, + "audio/isac": { + "source": "apache" + }, + "audio/l16": { + "source": "iana" + }, + "audio/l20": { + "source": "iana" + }, + "audio/l24": { + "source": "iana", + "compressible": false + }, + "audio/l8": { + "source": "iana" + }, + "audio/lpc": { + "source": "iana" + }, + "audio/midi": { + "source": "apache", + "extensions": ["mid","midi","kar","rmi"] + }, + "audio/mobile-xmf": { + "source": "iana" + }, + "audio/mp3": { + "compressible": false, + "extensions": ["mp3"] + }, + "audio/mp4": { + "source": "iana", + "compressible": false, + "extensions": ["m4a","mp4a"] + }, + "audio/mp4a-latm": { + "source": "iana" + }, + "audio/mpa": { + "source": "iana" + }, + "audio/mpa-robust": { + "source": "iana" + }, + "audio/mpeg": { + "source": "iana", + "compressible": false, + "extensions": ["mpga","mp2","mp2a","mp3","m2a","m3a"] + }, + "audio/mpeg4-generic": { + "source": "iana" + }, + "audio/musepack": { + "source": "apache" + }, + "audio/ogg": { + "source": "iana", + "compressible": false, + "extensions": ["oga","ogg","spx"] + }, + "audio/opus": { + "source": "iana" + }, + "audio/parityfec": { + "source": "iana" + }, + "audio/pcma": { + "source": "iana" + }, + "audio/pcma-wb": { + "source": "iana" + }, + "audio/pcmu": { + "source": "iana" + }, + "audio/pcmu-wb": { + "source": "iana" + }, + "audio/prs.sid": { + "source": "iana" + }, + "audio/qcelp": { + "source": "iana" + }, + "audio/raptorfec": { + "source": "iana" + }, + "audio/red": { + "source": "iana" + }, + "audio/rtp-enc-aescm128": { + "source": "iana" + }, + "audio/rtp-midi": { + "source": "iana" + }, + "audio/rtploopback": { + "source": "iana" + }, + "audio/rtx": { + "source": "iana" + }, + "audio/s3m": { + "source": "apache", + "extensions": ["s3m"] + }, + "audio/silk": { + "source": "apache", + "extensions": ["sil"] + }, + "audio/smv": { + "source": "iana" + }, + "audio/smv-qcp": { + "source": "iana" + }, + "audio/smv0": { + "source": "iana" + }, + "audio/sp-midi": { + "source": "iana" + }, + "audio/speex": { + "source": "iana" + }, + "audio/t140c": { + "source": "iana" + }, + "audio/t38": { + "source": "iana" + }, + "audio/telephone-event": { + "source": "iana" + }, + "audio/tone": { + "source": "iana" + }, + "audio/uemclip": { + "source": "iana" + }, + "audio/ulpfec": { + "source": "iana" + }, + "audio/vdvi": { + "source": "iana" + }, + "audio/vmr-wb": { + "source": "iana" + }, + "audio/vnd.3gpp.iufp": { + "source": "iana" + }, + "audio/vnd.4sb": { + "source": "iana" + }, + "audio/vnd.audiokoz": { + "source": "iana" + }, + "audio/vnd.celp": { + "source": "iana" + }, + "audio/vnd.cisco.nse": { + "source": "iana" + }, + "audio/vnd.cmles.radio-events": { + "source": "iana" + }, + "audio/vnd.cns.anp1": { + "source": "iana" + }, + "audio/vnd.cns.inf1": { + "source": "iana" + }, + "audio/vnd.dece.audio": { + "source": "iana", + "extensions": ["uva","uvva"] + }, + "audio/vnd.digital-winds": { + "source": "iana", + "extensions": ["eol"] + }, + "audio/vnd.dlna.adts": { + "source": "iana" + }, + "audio/vnd.dolby.heaac.1": { + "source": "iana" + }, + "audio/vnd.dolby.heaac.2": { + "source": "iana" + }, + "audio/vnd.dolby.mlp": { + "source": "iana" + }, + "audio/vnd.dolby.mps": { + "source": "iana" + }, + "audio/vnd.dolby.pl2": { + "source": "iana" + }, + "audio/vnd.dolby.pl2x": { + "source": "iana" + }, + "audio/vnd.dolby.pl2z": { + "source": "iana" + }, + "audio/vnd.dolby.pulse.1": { + "source": "iana" + }, + "audio/vnd.dra": { + "source": "iana", + "extensions": ["dra"] + }, + "audio/vnd.dts": { + "source": "iana", + "extensions": ["dts"] + }, + "audio/vnd.dts.hd": { + "source": "iana", + "extensions": ["dtshd"] + }, + "audio/vnd.dvb.file": { + "source": "iana" + }, + "audio/vnd.everad.plj": { + "source": "iana" + }, + "audio/vnd.hns.audio": { + "source": "iana" + }, + "audio/vnd.lucent.voice": { + "source": "iana", + "extensions": ["lvp"] + }, + "audio/vnd.ms-playready.media.pya": { + "source": "iana", + "extensions": ["pya"] + }, + "audio/vnd.nokia.mobile-xmf": { + "source": "iana" + }, + "audio/vnd.nortel.vbk": { + "source": "iana" + }, + "audio/vnd.nuera.ecelp4800": { + "source": "iana", + "extensions": ["ecelp4800"] + }, + "audio/vnd.nuera.ecelp7470": { + "source": "iana", + "extensions": ["ecelp7470"] + }, + "audio/vnd.nuera.ecelp9600": { + "source": "iana", + "extensions": ["ecelp9600"] + }, + "audio/vnd.octel.sbc": { + "source": "iana" + }, + "audio/vnd.qcelp": { + "source": "iana" + }, + "audio/vnd.rhetorex.32kadpcm": { + "source": "iana" + }, + "audio/vnd.rip": { + "source": "iana", + "extensions": ["rip"] + }, + "audio/vnd.rn-realaudio": { + "compressible": false + }, + "audio/vnd.sealedmedia.softseal.mpeg": { + "source": "iana" + }, + "audio/vnd.vmx.cvsd": { + "source": "iana" + }, + "audio/vnd.wave": { + "compressible": false + }, + "audio/vorbis": { + "source": "iana", + "compressible": false + }, + "audio/vorbis-config": { + "source": "iana" + }, + "audio/wav": { + "compressible": false, + "extensions": ["wav"] + }, + "audio/wave": { + "compressible": false, + "extensions": ["wav"] + }, + "audio/webm": { + "source": "apache", + "compressible": false, + "extensions": ["weba"] + }, + "audio/x-aac": { + "source": "apache", + "compressible": false, + "extensions": ["aac"] + }, + "audio/x-aiff": { + "source": "apache", + "extensions": ["aif","aiff","aifc"] + }, + "audio/x-caf": { + "source": "apache", + "compressible": false, + "extensions": ["caf"] + }, + "audio/x-flac": { + "source": "apache", + "extensions": ["flac"] + }, + "audio/x-m4a": { + "source": "nginx", + "extensions": ["m4a"] + }, + "audio/x-matroska": { + "source": "apache", + "extensions": ["mka"] + }, + "audio/x-mpegurl": { + "source": "apache", + "extensions": ["m3u"] + }, + "audio/x-ms-wax": { + "source": "apache", + "extensions": ["wax"] + }, + "audio/x-ms-wma": { + "source": "apache", + "extensions": ["wma"] + }, + "audio/x-pn-realaudio": { + "source": "apache", + "extensions": ["ram","ra"] + }, + "audio/x-pn-realaudio-plugin": { + "source": "apache", + "extensions": ["rmp"] + }, + "audio/x-realaudio": { + "source": "nginx", + "extensions": ["ra"] + }, + "audio/x-tta": { + "source": "apache" + }, + "audio/x-wav": { + "source": "apache", + "extensions": ["wav"] + }, + "audio/xm": { + "source": "apache", + "extensions": ["xm"] + }, + "chemical/x-cdx": { + "source": "apache", + "extensions": ["cdx"] + }, + "chemical/x-cif": { + "source": "apache", + "extensions": ["cif"] + }, + "chemical/x-cmdf": { + "source": "apache", + "extensions": ["cmdf"] + }, + "chemical/x-cml": { + "source": "apache", + "extensions": ["cml"] + }, + "chemical/x-csml": { + "source": "apache", + "extensions": ["csml"] + }, + "chemical/x-pdb": { + "source": "apache" + }, + "chemical/x-xyz": { + "source": "apache", + "extensions": ["xyz"] + }, + "font/opentype": { + "compressible": true, + "extensions": ["otf"] + }, + "image/bmp": { + "source": "iana", + "compressible": true, + "extensions": ["bmp"] + }, + "image/cgm": { + "source": "iana", + "extensions": ["cgm"] + }, + "image/dicom-rle": { + "source": "iana" + }, + "image/emf": { + "source": "iana" + }, + "image/fits": { + "source": "iana" + }, + "image/g3fax": { + "source": "iana", + "extensions": ["g3"] + }, + "image/gif": { + "source": "iana", + "compressible": false, + "extensions": ["gif"] + }, + "image/ief": { + "source": "iana", + "extensions": ["ief"] + }, + "image/jls": { + "source": "iana" + }, + "image/jp2": { + "source": "iana" + }, + "image/jpeg": { + "source": "iana", + "compressible": false, + "extensions": ["jpeg","jpg","jpe"] + }, + "image/jpm": { + "source": "iana" + }, + "image/jpx": { + "source": "iana" + }, + "image/ktx": { + "source": "iana", + "extensions": ["ktx"] + }, + "image/naplps": { + "source": "iana" + }, + "image/pjpeg": { + "compressible": false + }, + "image/png": { + "source": "iana", + "compressible": false, + "extensions": ["png"] + }, + "image/prs.btif": { + "source": "iana", + "extensions": ["btif"] + }, + "image/prs.pti": { + "source": "iana" + }, + "image/pwg-raster": { + "source": "iana" + }, + "image/sgi": { + "source": "apache", + "extensions": ["sgi"] + }, + "image/svg+xml": { + "source": "iana", + "compressible": true, + "extensions": ["svg","svgz"] + }, + "image/t38": { + "source": "iana" + }, + "image/tiff": { + "source": "iana", + "compressible": false, + "extensions": ["tiff","tif"] + }, + "image/tiff-fx": { + "source": "iana" + }, + "image/vnd.adobe.photoshop": { + "source": "iana", + "compressible": true, + "extensions": ["psd"] + }, + "image/vnd.airzip.accelerator.azv": { + "source": "iana" + }, + "image/vnd.cns.inf2": { + "source": "iana" + }, + "image/vnd.dece.graphic": { + "source": "iana", + "extensions": ["uvi","uvvi","uvg","uvvg"] + }, + "image/vnd.djvu": { + "source": "iana", + "extensions": ["djvu","djv"] + }, + "image/vnd.dvb.subtitle": { + "source": "iana", + "extensions": ["sub"] + }, + "image/vnd.dwg": { + "source": "iana", + "extensions": ["dwg"] + }, + "image/vnd.dxf": { + "source": "iana", + "extensions": ["dxf"] + }, + "image/vnd.fastbidsheet": { + "source": "iana", + "extensions": ["fbs"] + }, + "image/vnd.fpx": { + "source": "iana", + "extensions": ["fpx"] + }, + "image/vnd.fst": { + "source": "iana", + "extensions": ["fst"] + }, + "image/vnd.fujixerox.edmics-mmr": { + "source": "iana", + "extensions": ["mmr"] + }, + "image/vnd.fujixerox.edmics-rlc": { + "source": "iana", + "extensions": ["rlc"] + }, + "image/vnd.globalgraphics.pgb": { + "source": "iana" + }, + "image/vnd.microsoft.icon": { + "source": "iana" + }, + "image/vnd.mix": { + "source": "iana" + }, + "image/vnd.mozilla.apng": { + "source": "iana" + }, + "image/vnd.ms-modi": { + "source": "iana", + "extensions": ["mdi"] + }, + "image/vnd.ms-photo": { + "source": "apache", + "extensions": ["wdp"] + }, + "image/vnd.net-fpx": { + "source": "iana", + "extensions": ["npx"] + }, + "image/vnd.radiance": { + "source": "iana" + }, + "image/vnd.sealed.png": { + "source": "iana" + }, + "image/vnd.sealedmedia.softseal.gif": { + "source": "iana" + }, + "image/vnd.sealedmedia.softseal.jpg": { + "source": "iana" + }, + "image/vnd.svf": { + "source": "iana" + }, + "image/vnd.tencent.tap": { + "source": "iana" + }, + "image/vnd.valve.source.texture": { + "source": "iana" + }, + "image/vnd.wap.wbmp": { + "source": "iana", + "extensions": ["wbmp"] + }, + "image/vnd.xiff": { + "source": "iana", + "extensions": ["xif"] + }, + "image/vnd.zbrush.pcx": { + "source": "iana" + }, + "image/webp": { + "source": "apache", + "extensions": ["webp"] + }, + "image/wmf": { + "source": "iana" + }, + "image/x-3ds": { + "source": "apache", + "extensions": ["3ds"] + }, + "image/x-cmu-raster": { + "source": "apache", + "extensions": ["ras"] + }, + "image/x-cmx": { + "source": "apache", + "extensions": ["cmx"] + }, + "image/x-freehand": { + "source": "apache", + "extensions": ["fh","fhc","fh4","fh5","fh7"] + }, + "image/x-icon": { + "source": "apache", + "compressible": true, + "extensions": ["ico"] + }, + "image/x-jng": { + "source": "nginx", + "extensions": ["jng"] + }, + "image/x-mrsid-image": { + "source": "apache", + "extensions": ["sid"] + }, + "image/x-ms-bmp": { + "source": "nginx", + "compressible": true, + "extensions": ["bmp"] + }, + "image/x-pcx": { + "source": "apache", + "extensions": ["pcx"] + }, + "image/x-pict": { + "source": "apache", + "extensions": ["pic","pct"] + }, + "image/x-portable-anymap": { + "source": "apache", + "extensions": ["pnm"] + }, + "image/x-portable-bitmap": { + "source": "apache", + "extensions": ["pbm"] + }, + "image/x-portable-graymap": { + "source": "apache", + "extensions": ["pgm"] + }, + "image/x-portable-pixmap": { + "source": "apache", + "extensions": ["ppm"] + }, + "image/x-rgb": { + "source": "apache", + "extensions": ["rgb"] + }, + "image/x-tga": { + "source": "apache", + "extensions": ["tga"] + }, + "image/x-xbitmap": { + "source": "apache", + "extensions": ["xbm"] + }, + "image/x-xcf": { + "compressible": false + }, + "image/x-xpixmap": { + "source": "apache", + "extensions": ["xpm"] + }, + "image/x-xwindowdump": { + "source": "apache", + "extensions": ["xwd"] + }, + "message/cpim": { + "source": "iana" + }, + "message/delivery-status": { + "source": "iana" + }, + "message/disposition-notification": { + "source": "iana" + }, + "message/external-body": { + "source": "iana" + }, + "message/feedback-report": { + "source": "iana" + }, + "message/global": { + "source": "iana" + }, + "message/global-delivery-status": { + "source": "iana" + }, + "message/global-disposition-notification": { + "source": "iana" + }, + "message/global-headers": { + "source": "iana" + }, + "message/http": { + "source": "iana", + "compressible": false + }, + "message/imdn+xml": { + "source": "iana", + "compressible": true + }, + "message/news": { + "source": "iana" + }, + "message/partial": { + "source": "iana", + "compressible": false + }, + "message/rfc822": { + "source": "iana", + "compressible": true, + "extensions": ["eml","mime"] + }, + "message/s-http": { + "source": "iana" + }, + "message/sip": { + "source": "iana" + }, + "message/sipfrag": { + "source": "iana" + }, + "message/tracking-status": { + "source": "iana" + }, + "message/vnd.si.simp": { + "source": "iana" + }, + "message/vnd.wfa.wsc": { + "source": "iana" + }, + "model/gltf+json": { + "source": "iana", + "compressible": true + }, + "model/iges": { + "source": "iana", + "compressible": false, + "extensions": ["igs","iges"] + }, + "model/mesh": { + "source": "iana", + "compressible": false, + "extensions": ["msh","mesh","silo"] + }, + "model/vnd.collada+xml": { + "source": "iana", + "extensions": ["dae"] + }, + "model/vnd.dwf": { + "source": "iana", + "extensions": ["dwf"] + }, + "model/vnd.flatland.3dml": { + "source": "iana" + }, + "model/vnd.gdl": { + "source": "iana", + "extensions": ["gdl"] + }, + "model/vnd.gs-gdl": { + "source": "apache" + }, + "model/vnd.gs.gdl": { + "source": "iana" + }, + "model/vnd.gtw": { + "source": "iana", + "extensions": ["gtw"] + }, + "model/vnd.moml+xml": { + "source": "iana" + }, + "model/vnd.mts": { + "source": "iana", + "extensions": ["mts"] + }, + "model/vnd.opengex": { + "source": "iana" + }, + "model/vnd.parasolid.transmit.binary": { + "source": "iana" + }, + "model/vnd.parasolid.transmit.text": { + "source": "iana" + }, + "model/vnd.rosette.annotated-data-model": { + "source": "iana" + }, + "model/vnd.valve.source.compiled-map": { + "source": "iana" + }, + "model/vnd.vtu": { + "source": "iana", + "extensions": ["vtu"] + }, + "model/vrml": { + "source": "iana", + "compressible": false, + "extensions": ["wrl","vrml"] + }, + "model/x3d+binary": { + "source": "apache", + "compressible": false, + "extensions": ["x3db","x3dbz"] + }, + "model/x3d+fastinfoset": { + "source": "iana" + }, + "model/x3d+vrml": { + "source": "apache", + "compressible": false, + "extensions": ["x3dv","x3dvz"] + }, + "model/x3d+xml": { + "source": "iana", + "compressible": true, + "extensions": ["x3d","x3dz"] + }, + "model/x3d-vrml": { + "source": "iana" + }, + "multipart/alternative": { + "source": "iana", + "compressible": false + }, + "multipart/appledouble": { + "source": "iana" + }, + "multipart/byteranges": { + "source": "iana" + }, + "multipart/digest": { + "source": "iana" + }, + "multipart/encrypted": { + "source": "iana", + "compressible": false + }, + "multipart/form-data": { + "source": "iana", + "compressible": false + }, + "multipart/header-set": { + "source": "iana" + }, + "multipart/mixed": { + "source": "iana", + "compressible": false + }, + "multipart/parallel": { + "source": "iana" + }, + "multipart/related": { + "source": "iana", + "compressible": false + }, + "multipart/report": { + "source": "iana" + }, + "multipart/signed": { + "source": "iana", + "compressible": false + }, + "multipart/voice-message": { + "source": "iana" + }, + "multipart/x-mixed-replace": { + "source": "iana" + }, + "text/1d-interleaved-parityfec": { + "source": "iana" + }, + "text/cache-manifest": { + "source": "iana", + "compressible": true, + "extensions": ["appcache","manifest"] + }, + "text/calendar": { + "source": "iana", + "extensions": ["ics","ifb"] + }, + "text/calender": { + "compressible": true + }, + "text/cmd": { + "compressible": true + }, + "text/coffeescript": { + "extensions": ["coffee","litcoffee"] + }, + "text/css": { + "source": "iana", + "compressible": true, + "extensions": ["css"] + }, + "text/csv": { + "source": "iana", + "compressible": true, + "extensions": ["csv"] + }, + "text/csv-schema": { + "source": "iana" + }, + "text/directory": { + "source": "iana" + }, + "text/dns": { + "source": "iana" + }, + "text/ecmascript": { + "source": "iana" + }, + "text/encaprtp": { + "source": "iana" + }, + "text/enriched": { + "source": "iana" + }, + "text/fwdred": { + "source": "iana" + }, + "text/grammar-ref-list": { + "source": "iana" + }, + "text/hjson": { + "extensions": ["hjson"] + }, + "text/html": { + "source": "iana", + "compressible": true, + "extensions": ["html","htm","shtml"] + }, + "text/jade": { + "extensions": ["jade"] + }, + "text/javascript": { + "source": "iana", + "compressible": true + }, + "text/jcr-cnd": { + "source": "iana" + }, + "text/jsx": { + "compressible": true, + "extensions": ["jsx"] + }, + "text/less": { + "extensions": ["less"] + }, + "text/markdown": { + "source": "iana" + }, + "text/mathml": { + "source": "nginx", + "extensions": ["mml"] + }, + "text/mizar": { + "source": "iana" + }, + "text/n3": { + "source": "iana", + "compressible": true, + "extensions": ["n3"] + }, + "text/parameters": { + "source": "iana" + }, + "text/parityfec": { + "source": "iana" + }, + "text/plain": { + "source": "iana", + "compressible": true, + "extensions": ["txt","text","conf","def","list","log","in","ini"] + }, + "text/provenance-notation": { + "source": "iana" + }, + "text/prs.fallenstein.rst": { + "source": "iana" + }, + "text/prs.lines.tag": { + "source": "iana", + "extensions": ["dsc"] + }, + "text/prs.prop.logic": { + "source": "iana" + }, + "text/raptorfec": { + "source": "iana" + }, + "text/red": { + "source": "iana" + }, + "text/rfc822-headers": { + "source": "iana" + }, + "text/richtext": { + "source": "iana", + "compressible": true, + "extensions": ["rtx"] + }, + "text/rtf": { + "source": "iana", + "compressible": true, + "extensions": ["rtf"] + }, + "text/rtp-enc-aescm128": { + "source": "iana" + }, + "text/rtploopback": { + "source": "iana" + }, + "text/rtx": { + "source": "iana" + }, + "text/sgml": { + "source": "iana", + "extensions": ["sgml","sgm"] + }, + "text/slim": { + "extensions": ["slim","slm"] + }, + "text/stylus": { + "extensions": ["stylus","styl"] + }, + "text/t140": { + "source": "iana" + }, + "text/tab-separated-values": { + "source": "iana", + "compressible": true, + "extensions": ["tsv"] + }, + "text/troff": { + "source": "iana", + "extensions": ["t","tr","roff","man","me","ms"] + }, + "text/turtle": { + "source": "iana", + "extensions": ["ttl"] + }, + "text/ulpfec": { + "source": "iana" + }, + "text/uri-list": { + "source": "iana", + "compressible": true, + "extensions": ["uri","uris","urls"] + }, + "text/vcard": { + "source": "iana", + "compressible": true, + "extensions": ["vcard"] + }, + "text/vnd.a": { + "source": "iana" + }, + "text/vnd.abc": { + "source": "iana" + }, + "text/vnd.ascii-art": { + "source": "iana" + }, + "text/vnd.curl": { + "source": "iana", + "extensions": ["curl"] + }, + "text/vnd.curl.dcurl": { + "source": "apache", + "extensions": ["dcurl"] + }, + "text/vnd.curl.mcurl": { + "source": "apache", + "extensions": ["mcurl"] + }, + "text/vnd.curl.scurl": { + "source": "apache", + "extensions": ["scurl"] + }, + "text/vnd.debian.copyright": { + "source": "iana" + }, + "text/vnd.dmclientscript": { + "source": "iana" + }, + "text/vnd.dvb.subtitle": { + "source": "iana", + "extensions": ["sub"] + }, + "text/vnd.esmertec.theme-descriptor": { + "source": "iana" + }, + "text/vnd.fly": { + "source": "iana", + "extensions": ["fly"] + }, + "text/vnd.fmi.flexstor": { + "source": "iana", + "extensions": ["flx"] + }, + "text/vnd.graphviz": { + "source": "iana", + "extensions": ["gv"] + }, + "text/vnd.in3d.3dml": { + "source": "iana", + "extensions": ["3dml"] + }, + "text/vnd.in3d.spot": { + "source": "iana", + "extensions": ["spot"] + }, + "text/vnd.iptc.newsml": { + "source": "iana" + }, + "text/vnd.iptc.nitf": { + "source": "iana" + }, + "text/vnd.latex-z": { + "source": "iana" + }, + "text/vnd.motorola.reflex": { + "source": "iana" + }, + "text/vnd.ms-mediapackage": { + "source": "iana" + }, + "text/vnd.net2phone.commcenter.command": { + "source": "iana" + }, + "text/vnd.radisys.msml-basic-layout": { + "source": "iana" + }, + "text/vnd.si.uricatalogue": { + "source": "iana" + }, + "text/vnd.sun.j2me.app-descriptor": { + "source": "iana", + "extensions": ["jad"] + }, + "text/vnd.trolltech.linguist": { + "source": "iana" + }, + "text/vnd.wap.si": { + "source": "iana" + }, + "text/vnd.wap.sl": { + "source": "iana" + }, + "text/vnd.wap.wml": { + "source": "iana", + "extensions": ["wml"] + }, + "text/vnd.wap.wmlscript": { + "source": "iana", + "extensions": ["wmls"] + }, + "text/vtt": { + "charset": "UTF-8", + "compressible": true, + "extensions": ["vtt"] + }, + "text/x-asm": { + "source": "apache", + "extensions": ["s","asm"] + }, + "text/x-c": { + "source": "apache", + "extensions": ["c","cc","cxx","cpp","h","hh","dic"] + }, + "text/x-component": { + "source": "nginx", + "extensions": ["htc"] + }, + "text/x-fortran": { + "source": "apache", + "extensions": ["f","for","f77","f90"] + }, + "text/x-gwt-rpc": { + "compressible": true + }, + "text/x-handlebars-template": { + "extensions": ["hbs"] + }, + "text/x-java-source": { + "source": "apache", + "extensions": ["java"] + }, + "text/x-jquery-tmpl": { + "compressible": true + }, + "text/x-lua": { + "extensions": ["lua"] + }, + "text/x-markdown": { + "compressible": true, + "extensions": ["markdown","md","mkd"] + }, + "text/x-nfo": { + "source": "apache", + "extensions": ["nfo"] + }, + "text/x-opml": { + "source": "apache", + "extensions": ["opml"] + }, + "text/x-pascal": { + "source": "apache", + "extensions": ["p","pas"] + }, + "text/x-processing": { + "compressible": true, + "extensions": ["pde"] + }, + "text/x-sass": { + "extensions": ["sass"] + }, + "text/x-scss": { + "extensions": ["scss"] + }, + "text/x-setext": { + "source": "apache", + "extensions": ["etx"] + }, + "text/x-sfv": { + "source": "apache", + "extensions": ["sfv"] + }, + "text/x-suse-ymp": { + "compressible": true, + "extensions": ["ymp"] + }, + "text/x-uuencode": { + "source": "apache", + "extensions": ["uu"] + }, + "text/x-vcalendar": { + "source": "apache", + "extensions": ["vcs"] + }, + "text/x-vcard": { + "source": "apache", + "extensions": ["vcf"] + }, + "text/xml": { + "source": "iana", + "compressible": true, + "extensions": ["xml"] + }, + "text/xml-external-parsed-entity": { + "source": "iana" + }, + "text/yaml": { + "extensions": ["yaml","yml"] + }, + "video/1d-interleaved-parityfec": { + "source": "apache" + }, + "video/3gpp": { + "source": "apache", + "extensions": ["3gp","3gpp"] + }, + "video/3gpp-tt": { + "source": "apache" + }, + "video/3gpp2": { + "source": "apache", + "extensions": ["3g2"] + }, + "video/bmpeg": { + "source": "apache" + }, + "video/bt656": { + "source": "apache" + }, + "video/celb": { + "source": "apache" + }, + "video/dv": { + "source": "apache" + }, + "video/encaprtp": { + "source": "apache" + }, + "video/h261": { + "source": "apache", + "extensions": ["h261"] + }, + "video/h263": { + "source": "apache", + "extensions": ["h263"] + }, + "video/h263-1998": { + "source": "apache" + }, + "video/h263-2000": { + "source": "apache" + }, + "video/h264": { + "source": "apache", + "extensions": ["h264"] + }, + "video/h264-rcdo": { + "source": "apache" + }, + "video/h264-svc": { + "source": "apache" + }, + "video/h265": { + "source": "apache" + }, + "video/iso.segment": { + "source": "apache" + }, + "video/jpeg": { + "source": "apache", + "extensions": ["jpgv"] + }, + "video/jpeg2000": { + "source": "apache" + }, + "video/jpm": { + "source": "apache", + "extensions": ["jpm","jpgm"] + }, + "video/mj2": { + "source": "apache", + "extensions": ["mj2","mjp2"] + }, + "video/mp1s": { + "source": "apache" + }, + "video/mp2p": { + "source": "apache" + }, + "video/mp2t": { + "source": "apache", + "extensions": ["ts"] + }, + "video/mp4": { + "source": "apache", + "compressible": false, + "extensions": ["mp4","mp4v","mpg4"] + }, + "video/mp4v-es": { + "source": "apache" + }, + "video/mpeg": { + "source": "apache", + "compressible": false, + "extensions": ["mpeg","mpg","mpe","m1v","m2v"] + }, + "video/mpeg4-generic": { + "source": "apache" + }, + "video/mpv": { + "source": "apache" + }, + "video/nv": { + "source": "apache" + }, + "video/ogg": { + "source": "apache", + "compressible": false, + "extensions": ["ogv"] + }, + "video/parityfec": { + "source": "apache" + }, + "video/pointer": { + "source": "apache" + }, + "video/quicktime": { + "source": "apache", + "compressible": false, + "extensions": ["qt","mov"] + }, + "video/raptorfec": { + "source": "apache" + }, + "video/raw": { + "source": "apache" + }, + "video/rtp-enc-aescm128": { + "source": "apache" + }, + "video/rtploopback": { + "source": "apache" + }, + "video/rtx": { + "source": "apache" + }, + "video/smpte292m": { + "source": "apache" + }, + "video/ulpfec": { + "source": "apache" + }, + "video/vc1": { + "source": "apache" + }, + "video/vnd.cctv": { + "source": "apache" + }, + "video/vnd.dece.hd": { + "source": "apache", + "extensions": ["uvh","uvvh"] + }, + "video/vnd.dece.mobile": { + "source": "apache", + "extensions": ["uvm","uvvm"] + }, + "video/vnd.dece.mp4": { + "source": "apache" + }, + "video/vnd.dece.pd": { + "source": "apache", + "extensions": ["uvp","uvvp"] + }, + "video/vnd.dece.sd": { + "source": "apache", + "extensions": ["uvs","uvvs"] + }, + "video/vnd.dece.video": { + "source": "apache", + "extensions": ["uvv","uvvv"] + }, + "video/vnd.directv.mpeg": { + "source": "apache" + }, + "video/vnd.directv.mpeg-tts": { + "source": "apache" + }, + "video/vnd.dlna.mpeg-tts": { + "source": "apache" + }, + "video/vnd.dvb.file": { + "source": "apache", + "extensions": ["dvb"] + }, + "video/vnd.fvt": { + "source": "apache", + "extensions": ["fvt"] + }, + "video/vnd.hns.video": { + "source": "apache" + }, + "video/vnd.iptvforum.1dparityfec-1010": { + "source": "apache" + }, + "video/vnd.iptvforum.1dparityfec-2005": { + "source": "apache" + }, + "video/vnd.iptvforum.2dparityfec-1010": { + "source": "apache" + }, + "video/vnd.iptvforum.2dparityfec-2005": { + "source": "apache" + }, + "video/vnd.iptvforum.ttsavc": { + "source": "apache" + }, + "video/vnd.iptvforum.ttsmpeg2": { + "source": "apache" + }, + "video/vnd.motorola.video": { + "source": "apache" + }, + "video/vnd.motorola.videop": { + "source": "apache" + }, + "video/vnd.mpegurl": { + "source": "apache", + "extensions": ["mxu","m4u"] + }, + "video/vnd.ms-playready.media.pyv": { + "source": "apache", + "extensions": ["pyv"] + }, + "video/vnd.nokia.interleaved-multimedia": { + "source": "apache" + }, + "video/vnd.nokia.videovoip": { + "source": "apache" + }, + "video/vnd.objectvideo": { + "source": "apache" + }, + "video/vnd.radgamettools.bink": { + "source": "apache" + }, + "video/vnd.radgamettools.smacker": { + "source": "apache" + }, + "video/vnd.sealed.mpeg1": { + "source": "apache" + }, + "video/vnd.sealed.mpeg4": { + "source": "apache" + }, + "video/vnd.sealed.swf": { + "source": "apache" + }, + "video/vnd.sealedmedia.softseal.mov": { + "source": "apache" + }, + "video/vnd.uvvu.mp4": { + "source": "apache", + "extensions": ["uvu","uvvu"] + }, + "video/vnd.vivo": { + "source": "apache", + "extensions": ["viv"] + }, + "video/vp8": { + "source": "apache" + }, + "video/webm": { + "source": "apache", + "compressible": false, + "extensions": ["webm"] + }, + "video/x-f4v": { + "source": "apache", + "extensions": ["f4v"] + }, + "video/x-fli": { + "source": "apache", + "extensions": ["fli"] + }, + "video/x-flv": { + "source": "apache", + "compressible": false, + "extensions": ["flv"] + }, + "video/x-m4v": { + "source": "apache", + "extensions": ["m4v"] + }, + "video/x-matroska": { + "source": "apache", + "compressible": false, + "extensions": ["mkv","mk3d","mks"] + }, + "video/x-mng": { + "source": "apache", + "extensions": ["mng"] + }, + "video/x-ms-asf": { + "source": "apache", + "extensions": ["asf","asx"] + }, + "video/x-ms-vob": { + "source": "apache", + "extensions": ["vob"] + }, + "video/x-ms-wm": { + "source": "apache", + "extensions": ["wm"] + }, + "video/x-ms-wmv": { + "source": "apache", + "compressible": false, + "extensions": ["wmv"] + }, + "video/x-ms-wmx": { + "source": "apache", + "extensions": ["wmx"] + }, + "video/x-ms-wvx": { + "source": "apache", + "extensions": ["wvx"] + }, + "video/x-msvideo": { + "source": "apache", + "extensions": ["avi"] + }, + "video/x-sgi-movie": { + "source": "apache", + "extensions": ["movie"] + }, + "video/x-smv": { + "source": "apache", + "extensions": ["smv"] + }, + "x-conference/x-cooltalk": { + "source": "apache", + "extensions": ["ice"] + }, + "x-shader/x-fragment": { + "compressible": true + }, + "x-shader/x-vertex": { + "compressible": true + } +} diff --git a/node_modules/express/node_modules/accepts/node_modules/mime-types/node_modules/mime-db/index.js b/node_modules/express/node_modules/accepts/node_modules/mime-types/node_modules/mime-db/index.js new file mode 100644 index 0000000..551031f --- /dev/null +++ b/node_modules/express/node_modules/accepts/node_modules/mime-types/node_modules/mime-db/index.js @@ -0,0 +1,11 @@ +/*! + * mime-db + * Copyright(c) 2014 Jonathan Ong + * MIT Licensed + */ + +/** + * Module exports. + */ + +module.exports = require('./db.json') diff --git a/node_modules/express/node_modules/accepts/node_modules/mime-types/node_modules/mime-db/package.json b/node_modules/express/node_modules/accepts/node_modules/mime-types/node_modules/mime-db/package.json new file mode 100644 index 0000000..a468393 --- /dev/null +++ b/node_modules/express/node_modules/accepts/node_modules/mime-types/node_modules/mime-db/package.json @@ -0,0 +1,99 @@ +{ + "name": "mime-db", + "description": "Media Type Database", + "version": "1.24.0", + "contributors": [ + { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "Jonathan Ong", + "email": "me@jongleberry.com", + "url": "http://jongleberry.com" + }, + { + "name": "Robert Kieffer", + "email": "robert@broofa.com", + "url": "http://github.com/broofa" + } + ], + "license": "MIT", + "keywords": [ + "mime", + "db", + "type", + "types", + "database", + "charset", + "charsets" + ], + "repository": { + "type": "git", + "url": "git+https://github.com/jshttp/mime-db.git" + }, + "devDependencies": { + "bluebird": "3.4.6", + "co": "4.6.0", + "cogent": "1.0.1", + "csv-parse": "1.1.7", + "gnode": "0.1.2", + "istanbul": "0.4.5", + "mocha": "1.21.5", + "raw-body": "2.1.7", + "stream-to-array": "2.3.0" + }, + "files": [ + "HISTORY.md", + "LICENSE", + "README.md", + "db.json", + "index.js" + ], + "engines": { + "node": ">= 0.6" + }, + "scripts": { + "build": "node scripts/build", + "fetch": "gnode scripts/fetch-apache && gnode scripts/fetch-iana && gnode scripts/fetch-nginx", + "test": "mocha --reporter spec --bail --check-leaks test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot --check-leaks test/", + "test-travis": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter spec --check-leaks test/", + "update": "npm run fetch && npm run build" + }, + "gitHead": "9dd00b34556a8cdd6f3385f09d4989298c4b86e1", + "bugs": { + "url": "https://github.com/jshttp/mime-db/issues" + }, + "homepage": "https://github.com/jshttp/mime-db#readme", + "_id": "mime-db@1.24.0", + "_shasum": "e2d13f939f0016c6e4e9ad25a8652f126c467f0c", + "_from": "mime-db@>=1.24.0 <1.25.0", + "_npmVersion": "2.15.9", + "_nodeVersion": "4.5.0", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "dist": { + "shasum": "e2d13f939f0016c6e4e9ad25a8652f126c467f0c", + "tarball": "https://registry.npmjs.org/mime-db/-/mime-db-1.24.0.tgz" + }, + "maintainers": [ + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "jongleberry", + "email": "jonathanrichardong@gmail.com" + } + ], + "_npmOperationalInternal": { + "host": "packages-16-east.internal.npmjs.com", + "tmp": "tmp/mime-db-1.24.0.tgz_1474198792761_0.7161959335207939" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/mime-db/-/mime-db-1.24.0.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/express/node_modules/accepts/node_modules/mime-types/package.json b/node_modules/express/node_modules/accepts/node_modules/mime-types/package.json new file mode 100644 index 0000000..0ca4603 --- /dev/null +++ b/node_modules/express/node_modules/accepts/node_modules/mime-types/package.json @@ -0,0 +1,94 @@ +{ + "name": "mime-types", + "description": "The ultimate javascript content-type utility.", + "version": "2.1.12", + "contributors": [ + { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "Jeremiah Senkpiel", + "email": "fishrock123@rocketmail.com", + "url": "https://searchbeam.jit.su" + }, + { + "name": "Jonathan Ong", + "email": "me@jongleberry.com", + "url": "http://jongleberry.com" + } + ], + "license": "MIT", + "keywords": [ + "mime", + "types" + ], + "repository": { + "type": "git", + "url": "git+https://github.com/jshttp/mime-types.git" + }, + "dependencies": { + "mime-db": "~1.24.0" + }, + "devDependencies": { + "eslint": "3.5.0", + "eslint-config-standard": "6.0.1", + "eslint-plugin-promise": "2.0.1", + "eslint-plugin-standard": "2.0.0", + "istanbul": "0.4.5", + "mocha": "1.21.5" + }, + "files": [ + "HISTORY.md", + "LICENSE", + "index.js" + ], + "engines": { + "node": ">= 0.6" + }, + "scripts": { + "lint": "eslint **/*.js", + "test": "mocha --reporter spec test/test.js", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot test/test.js", + "test-travis": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter dot test/test.js" + }, + "gitHead": "7193a9094e2efe31da93988350bb0b32ab18b1ea", + "bugs": { + "url": "https://github.com/jshttp/mime-types/issues" + }, + "homepage": "https://github.com/jshttp/mime-types#readme", + "_id": "mime-types@2.1.12", + "_shasum": "152ba256777020dd4663f54c2e7bc26381e71729", + "_from": "mime-types@>=2.1.11 <2.2.0", + "_npmVersion": "2.15.9", + "_nodeVersion": "4.5.0", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "dist": { + "shasum": "152ba256777020dd4663f54c2e7bc26381e71729", + "tarball": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.12.tgz" + }, + "maintainers": [ + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "fishrock123", + "email": "fishrock123@rocketmail.com" + }, + { + "name": "jongleberry", + "email": "jonathanrichardong@gmail.com" + } + ], + "_npmOperationalInternal": { + "host": "packages-12-west.internal.npmjs.com", + "tmp": "tmp/mime-types-2.1.12.tgz_1474237415119_0.03028594213537872" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/mime-types/-/mime-types-2.1.12.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/express/node_modules/accepts/node_modules/negotiator/HISTORY.md b/node_modules/express/node_modules/accepts/node_modules/negotiator/HISTORY.md new file mode 100644 index 0000000..10b6917 --- /dev/null +++ b/node_modules/express/node_modules/accepts/node_modules/negotiator/HISTORY.md @@ -0,0 +1,98 @@ +0.6.1 / 2016-05-02 +================== + + * perf: improve `Accept` parsing speed + * perf: improve `Accept-Charset` parsing speed + * perf: improve `Accept-Encoding` parsing speed + * perf: improve `Accept-Language` parsing speed + +0.6.0 / 2015-09-29 +================== + + * Fix including type extensions in parameters in `Accept` parsing + * Fix parsing `Accept` parameters with quoted equals + * Fix parsing `Accept` parameters with quoted semicolons + * Lazy-load modules from main entry point + * perf: delay type concatenation until needed + * perf: enable strict mode + * perf: hoist regular expressions + * perf: remove closures getting spec properties + * perf: remove a closure from media type parsing + * perf: remove property delete from media type parsing + +0.5.3 / 2015-05-10 +================== + + * Fix media type parameter matching to be case-insensitive + +0.5.2 / 2015-05-06 +================== + + * Fix comparing media types with quoted values + * Fix splitting media types with quoted commas + +0.5.1 / 2015-02-14 +================== + + * Fix preference sorting to be stable for long acceptable lists + +0.5.0 / 2014-12-18 +================== + + * Fix list return order when large accepted list + * Fix missing identity encoding when q=0 exists + * Remove dynamic building of Negotiator class + +0.4.9 / 2014-10-14 +================== + + * Fix error when media type has invalid parameter + +0.4.8 / 2014-09-28 +================== + + * Fix all negotiations to be case-insensitive + * Stable sort preferences of same quality according to client order + * Support Node.js 0.6 + +0.4.7 / 2014-06-24 +================== + + * Handle invalid provided languages + * Handle invalid provided media types + +0.4.6 / 2014-06-11 +================== + + * Order by specificity when quality is the same + +0.4.5 / 2014-05-29 +================== + + * Fix regression in empty header handling + +0.4.4 / 2014-05-29 +================== + + * Fix behaviors when headers are not present + +0.4.3 / 2014-04-16 +================== + + * Handle slashes on media params correctly + +0.4.2 / 2014-02-28 +================== + + * Fix media type sorting + * Handle media types params strictly + +0.4.1 / 2014-01-16 +================== + + * Use most specific matches + +0.4.0 / 2014-01-09 +================== + + * Remove preferred prefix from methods diff --git a/node_modules/express/node_modules/accepts/node_modules/negotiator/LICENSE b/node_modules/express/node_modules/accepts/node_modules/negotiator/LICENSE new file mode 100644 index 0000000..ea6b9e2 --- /dev/null +++ b/node_modules/express/node_modules/accepts/node_modules/negotiator/LICENSE @@ -0,0 +1,24 @@ +(The MIT License) + +Copyright (c) 2012-2014 Federico Romero +Copyright (c) 2012-2014 Isaac Z. Schlueter +Copyright (c) 2014-2015 Douglas Christopher Wilson + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/express/node_modules/accepts/node_modules/negotiator/README.md b/node_modules/express/node_modules/accepts/node_modules/negotiator/README.md new file mode 100644 index 0000000..04a67ff --- /dev/null +++ b/node_modules/express/node_modules/accepts/node_modules/negotiator/README.md @@ -0,0 +1,203 @@ +# negotiator + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Node.js Version][node-version-image]][node-version-url] +[![Build Status][travis-image]][travis-url] +[![Test Coverage][coveralls-image]][coveralls-url] + +An HTTP content negotiator for Node.js + +## Installation + +```sh +$ npm install negotiator +``` + +## API + +```js +var Negotiator = require('negotiator') +``` + +### Accept Negotiation + +```js +availableMediaTypes = ['text/html', 'text/plain', 'application/json'] + +// The negotiator constructor receives a request object +negotiator = new Negotiator(request) + +// Let's say Accept header is 'text/html, application/*;q=0.2, image/jpeg;q=0.8' + +negotiator.mediaTypes() +// -> ['text/html', 'image/jpeg', 'application/*'] + +negotiator.mediaTypes(availableMediaTypes) +// -> ['text/html', 'application/json'] + +negotiator.mediaType(availableMediaTypes) +// -> 'text/html' +``` + +You can check a working example at `examples/accept.js`. + +#### Methods + +##### mediaType() + +Returns the most preferred media type from the client. + +##### mediaType(availableMediaType) + +Returns the most preferred media type from a list of available media types. + +##### mediaTypes() + +Returns an array of preferred media types ordered by the client preference. + +##### mediaTypes(availableMediaTypes) + +Returns an array of preferred media types ordered by priority from a list of +available media types. + +### Accept-Language Negotiation + +```js +negotiator = new Negotiator(request) + +availableLanguages = ['en', 'es', 'fr'] + +// Let's say Accept-Language header is 'en;q=0.8, es, pt' + +negotiator.languages() +// -> ['es', 'pt', 'en'] + +negotiator.languages(availableLanguages) +// -> ['es', 'en'] + +language = negotiator.language(availableLanguages) +// -> 'es' +``` + +You can check a working example at `examples/language.js`. + +#### Methods + +##### language() + +Returns the most preferred language from the client. + +##### language(availableLanguages) + +Returns the most preferred language from a list of available languages. + +##### languages() + +Returns an array of preferred languages ordered by the client preference. + +##### languages(availableLanguages) + +Returns an array of preferred languages ordered by priority from a list of +available languages. + +### Accept-Charset Negotiation + +```js +availableCharsets = ['utf-8', 'iso-8859-1', 'iso-8859-5'] + +negotiator = new Negotiator(request) + +// Let's say Accept-Charset header is 'utf-8, iso-8859-1;q=0.8, utf-7;q=0.2' + +negotiator.charsets() +// -> ['utf-8', 'iso-8859-1', 'utf-7'] + +negotiator.charsets(availableCharsets) +// -> ['utf-8', 'iso-8859-1'] + +negotiator.charset(availableCharsets) +// -> 'utf-8' +``` + +You can check a working example at `examples/charset.js`. + +#### Methods + +##### charset() + +Returns the most preferred charset from the client. + +##### charset(availableCharsets) + +Returns the most preferred charset from a list of available charsets. + +##### charsets() + +Returns an array of preferred charsets ordered by the client preference. + +##### charsets(availableCharsets) + +Returns an array of preferred charsets ordered by priority from a list of +available charsets. + +### Accept-Encoding Negotiation + +```js +availableEncodings = ['identity', 'gzip'] + +negotiator = new Negotiator(request) + +// Let's say Accept-Encoding header is 'gzip, compress;q=0.2, identity;q=0.5' + +negotiator.encodings() +// -> ['gzip', 'identity', 'compress'] + +negotiator.encodings(availableEncodings) +// -> ['gzip', 'identity'] + +negotiator.encoding(availableEncodings) +// -> 'gzip' +``` + +You can check a working example at `examples/encoding.js`. + +#### Methods + +##### encoding() + +Returns the most preferred encoding from the client. + +##### encoding(availableEncodings) + +Returns the most preferred encoding from a list of available encodings. + +##### encodings() + +Returns an array of preferred encodings ordered by the client preference. + +##### encodings(availableEncodings) + +Returns an array of preferred encodings ordered by priority from a list of +available encodings. + +## See Also + +The [accepts](https://npmjs.org/package/accepts#readme) module builds on +this module and provides an alternative interface, mime type validation, +and more. + +## License + +[MIT](LICENSE) + +[npm-image]: https://img.shields.io/npm/v/negotiator.svg +[npm-url]: https://npmjs.org/package/negotiator +[node-version-image]: https://img.shields.io/node/v/negotiator.svg +[node-version-url]: https://nodejs.org/en/download/ +[travis-image]: https://img.shields.io/travis/jshttp/negotiator/master.svg +[travis-url]: https://travis-ci.org/jshttp/negotiator +[coveralls-image]: https://img.shields.io/coveralls/jshttp/negotiator/master.svg +[coveralls-url]: https://coveralls.io/r/jshttp/negotiator?branch=master +[downloads-image]: https://img.shields.io/npm/dm/negotiator.svg +[downloads-url]: https://npmjs.org/package/negotiator diff --git a/node_modules/express/node_modules/accepts/node_modules/negotiator/index.js b/node_modules/express/node_modules/accepts/node_modules/negotiator/index.js new file mode 100644 index 0000000..8d4f6a2 --- /dev/null +++ b/node_modules/express/node_modules/accepts/node_modules/negotiator/index.js @@ -0,0 +1,124 @@ +/*! + * negotiator + * Copyright(c) 2012 Federico Romero + * Copyright(c) 2012-2014 Isaac Z. Schlueter + * Copyright(c) 2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict'; + +/** + * Cached loaded submodules. + * @private + */ + +var modules = Object.create(null); + +/** + * Module exports. + * @public + */ + +module.exports = Negotiator; +module.exports.Negotiator = Negotiator; + +/** + * Create a Negotiator instance from a request. + * @param {object} request + * @public + */ + +function Negotiator(request) { + if (!(this instanceof Negotiator)) { + return new Negotiator(request); + } + + this.request = request; +} + +Negotiator.prototype.charset = function charset(available) { + var set = this.charsets(available); + return set && set[0]; +}; + +Negotiator.prototype.charsets = function charsets(available) { + var preferredCharsets = loadModule('charset').preferredCharsets; + return preferredCharsets(this.request.headers['accept-charset'], available); +}; + +Negotiator.prototype.encoding = function encoding(available) { + var set = this.encodings(available); + return set && set[0]; +}; + +Negotiator.prototype.encodings = function encodings(available) { + var preferredEncodings = loadModule('encoding').preferredEncodings; + return preferredEncodings(this.request.headers['accept-encoding'], available); +}; + +Negotiator.prototype.language = function language(available) { + var set = this.languages(available); + return set && set[0]; +}; + +Negotiator.prototype.languages = function languages(available) { + var preferredLanguages = loadModule('language').preferredLanguages; + return preferredLanguages(this.request.headers['accept-language'], available); +}; + +Negotiator.prototype.mediaType = function mediaType(available) { + var set = this.mediaTypes(available); + return set && set[0]; +}; + +Negotiator.prototype.mediaTypes = function mediaTypes(available) { + var preferredMediaTypes = loadModule('mediaType').preferredMediaTypes; + return preferredMediaTypes(this.request.headers.accept, available); +}; + +// Backwards compatibility +Negotiator.prototype.preferredCharset = Negotiator.prototype.charset; +Negotiator.prototype.preferredCharsets = Negotiator.prototype.charsets; +Negotiator.prototype.preferredEncoding = Negotiator.prototype.encoding; +Negotiator.prototype.preferredEncodings = Negotiator.prototype.encodings; +Negotiator.prototype.preferredLanguage = Negotiator.prototype.language; +Negotiator.prototype.preferredLanguages = Negotiator.prototype.languages; +Negotiator.prototype.preferredMediaType = Negotiator.prototype.mediaType; +Negotiator.prototype.preferredMediaTypes = Negotiator.prototype.mediaTypes; + +/** + * Load the given module. + * @private + */ + +function loadModule(moduleName) { + var module = modules[moduleName]; + + if (module !== undefined) { + return module; + } + + // This uses a switch for static require analysis + switch (moduleName) { + case 'charset': + module = require('./lib/charset'); + break; + case 'encoding': + module = require('./lib/encoding'); + break; + case 'language': + module = require('./lib/language'); + break; + case 'mediaType': + module = require('./lib/mediaType'); + break; + default: + throw new Error('Cannot find module \'' + moduleName + '\''); + } + + // Store to prevent invoking require() + modules[moduleName] = module; + + return module; +} diff --git a/node_modules/express/node_modules/accepts/node_modules/negotiator/lib/charset.js b/node_modules/express/node_modules/accepts/node_modules/negotiator/lib/charset.js new file mode 100644 index 0000000..ac4217b --- /dev/null +++ b/node_modules/express/node_modules/accepts/node_modules/negotiator/lib/charset.js @@ -0,0 +1,169 @@ +/** + * negotiator + * Copyright(c) 2012 Isaac Z. Schlueter + * Copyright(c) 2014 Federico Romero + * Copyright(c) 2014-2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict'; + +/** + * Module exports. + * @public + */ + +module.exports = preferredCharsets; +module.exports.preferredCharsets = preferredCharsets; + +/** + * Module variables. + * @private + */ + +var simpleCharsetRegExp = /^\s*([^\s;]+)\s*(?:;(.*))?$/; + +/** + * Parse the Accept-Charset header. + * @private + */ + +function parseAcceptCharset(accept) { + var accepts = accept.split(','); + + for (var i = 0, j = 0; i < accepts.length; i++) { + var charset = parseCharset(accepts[i].trim(), i); + + if (charset) { + accepts[j++] = charset; + } + } + + // trim accepts + accepts.length = j; + + return accepts; +} + +/** + * Parse a charset from the Accept-Charset header. + * @private + */ + +function parseCharset(str, i) { + var match = simpleCharsetRegExp.exec(str); + if (!match) return null; + + var charset = match[1]; + var q = 1; + if (match[2]) { + var params = match[2].split(';') + for (var i = 0; i < params.length; i ++) { + var p = params[i].trim().split('='); + if (p[0] === 'q') { + q = parseFloat(p[1]); + break; + } + } + } + + return { + charset: charset, + q: q, + i: i + }; +} + +/** + * Get the priority of a charset. + * @private + */ + +function getCharsetPriority(charset, accepted, index) { + var priority = {o: -1, q: 0, s: 0}; + + for (var i = 0; i < accepted.length; i++) { + var spec = specify(charset, accepted[i], index); + + if (spec && (priority.s - spec.s || priority.q - spec.q || priority.o - spec.o) < 0) { + priority = spec; + } + } + + return priority; +} + +/** + * Get the specificity of the charset. + * @private + */ + +function specify(charset, spec, index) { + var s = 0; + if(spec.charset.toLowerCase() === charset.toLowerCase()){ + s |= 1; + } else if (spec.charset !== '*' ) { + return null + } + + return { + i: index, + o: spec.i, + q: spec.q, + s: s + } +} + +/** + * Get the preferred charsets from an Accept-Charset header. + * @public + */ + +function preferredCharsets(accept, provided) { + // RFC 2616 sec 14.2: no header = * + var accepts = parseAcceptCharset(accept === undefined ? '*' : accept || ''); + + if (!provided) { + // sorted list of all charsets + return accepts + .filter(isQuality) + .sort(compareSpecs) + .map(getFullCharset); + } + + var priorities = provided.map(function getPriority(type, index) { + return getCharsetPriority(type, accepts, index); + }); + + // sorted list of accepted charsets + return priorities.filter(isQuality).sort(compareSpecs).map(function getCharset(priority) { + return provided[priorities.indexOf(priority)]; + }); +} + +/** + * Compare two specs. + * @private + */ + +function compareSpecs(a, b) { + return (b.q - a.q) || (b.s - a.s) || (a.o - b.o) || (a.i - b.i) || 0; +} + +/** + * Get full charset string. + * @private + */ + +function getFullCharset(spec) { + return spec.charset; +} + +/** + * Check if a spec has any quality. + * @private + */ + +function isQuality(spec) { + return spec.q > 0; +} diff --git a/node_modules/express/node_modules/accepts/node_modules/negotiator/lib/encoding.js b/node_modules/express/node_modules/accepts/node_modules/negotiator/lib/encoding.js new file mode 100644 index 0000000..70ac3de --- /dev/null +++ b/node_modules/express/node_modules/accepts/node_modules/negotiator/lib/encoding.js @@ -0,0 +1,184 @@ +/** + * negotiator + * Copyright(c) 2012 Isaac Z. Schlueter + * Copyright(c) 2014 Federico Romero + * Copyright(c) 2014-2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict'; + +/** + * Module exports. + * @public + */ + +module.exports = preferredEncodings; +module.exports.preferredEncodings = preferredEncodings; + +/** + * Module variables. + * @private + */ + +var simpleEncodingRegExp = /^\s*([^\s;]+)\s*(?:;(.*))?$/; + +/** + * Parse the Accept-Encoding header. + * @private + */ + +function parseAcceptEncoding(accept) { + var accepts = accept.split(','); + var hasIdentity = false; + var minQuality = 1; + + for (var i = 0, j = 0; i < accepts.length; i++) { + var encoding = parseEncoding(accepts[i].trim(), i); + + if (encoding) { + accepts[j++] = encoding; + hasIdentity = hasIdentity || specify('identity', encoding); + minQuality = Math.min(minQuality, encoding.q || 1); + } + } + + if (!hasIdentity) { + /* + * If identity doesn't explicitly appear in the accept-encoding header, + * it's added to the list of acceptable encoding with the lowest q + */ + accepts[j++] = { + encoding: 'identity', + q: minQuality, + i: i + }; + } + + // trim accepts + accepts.length = j; + + return accepts; +} + +/** + * Parse an encoding from the Accept-Encoding header. + * @private + */ + +function parseEncoding(str, i) { + var match = simpleEncodingRegExp.exec(str); + if (!match) return null; + + var encoding = match[1]; + var q = 1; + if (match[2]) { + var params = match[2].split(';'); + for (var i = 0; i < params.length; i ++) { + var p = params[i].trim().split('='); + if (p[0] === 'q') { + q = parseFloat(p[1]); + break; + } + } + } + + return { + encoding: encoding, + q: q, + i: i + }; +} + +/** + * Get the priority of an encoding. + * @private + */ + +function getEncodingPriority(encoding, accepted, index) { + var priority = {o: -1, q: 0, s: 0}; + + for (var i = 0; i < accepted.length; i++) { + var spec = specify(encoding, accepted[i], index); + + if (spec && (priority.s - spec.s || priority.q - spec.q || priority.o - spec.o) < 0) { + priority = spec; + } + } + + return priority; +} + +/** + * Get the specificity of the encoding. + * @private + */ + +function specify(encoding, spec, index) { + var s = 0; + if(spec.encoding.toLowerCase() === encoding.toLowerCase()){ + s |= 1; + } else if (spec.encoding !== '*' ) { + return null + } + + return { + i: index, + o: spec.i, + q: spec.q, + s: s + } +}; + +/** + * Get the preferred encodings from an Accept-Encoding header. + * @public + */ + +function preferredEncodings(accept, provided) { + var accepts = parseAcceptEncoding(accept || ''); + + if (!provided) { + // sorted list of all encodings + return accepts + .filter(isQuality) + .sort(compareSpecs) + .map(getFullEncoding); + } + + var priorities = provided.map(function getPriority(type, index) { + return getEncodingPriority(type, accepts, index); + }); + + // sorted list of accepted encodings + return priorities.filter(isQuality).sort(compareSpecs).map(function getEncoding(priority) { + return provided[priorities.indexOf(priority)]; + }); +} + +/** + * Compare two specs. + * @private + */ + +function compareSpecs(a, b) { + return (b.q - a.q) || (b.s - a.s) || (a.o - b.o) || (a.i - b.i) || 0; +} + +/** + * Get full encoding string. + * @private + */ + +function getFullEncoding(spec) { + return spec.encoding; +} + +/** + * Check if a spec has any quality. + * @private + */ + +function isQuality(spec) { + return spec.q > 0; +} diff --git a/node_modules/express/node_modules/accepts/node_modules/negotiator/lib/language.js b/node_modules/express/node_modules/accepts/node_modules/negotiator/lib/language.js new file mode 100644 index 0000000..1bd2d0e --- /dev/null +++ b/node_modules/express/node_modules/accepts/node_modules/negotiator/lib/language.js @@ -0,0 +1,179 @@ +/** + * negotiator + * Copyright(c) 2012 Isaac Z. Schlueter + * Copyright(c) 2014 Federico Romero + * Copyright(c) 2014-2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict'; + +/** + * Module exports. + * @public + */ + +module.exports = preferredLanguages; +module.exports.preferredLanguages = preferredLanguages; + +/** + * Module variables. + * @private + */ + +var simpleLanguageRegExp = /^\s*([^\s\-;]+)(?:-([^\s;]+))?\s*(?:;(.*))?$/; + +/** + * Parse the Accept-Language header. + * @private + */ + +function parseAcceptLanguage(accept) { + var accepts = accept.split(','); + + for (var i = 0, j = 0; i < accepts.length; i++) { + var langauge = parseLanguage(accepts[i].trim(), i); + + if (langauge) { + accepts[j++] = langauge; + } + } + + // trim accepts + accepts.length = j; + + return accepts; +} + +/** + * Parse a language from the Accept-Language header. + * @private + */ + +function parseLanguage(str, i) { + var match = simpleLanguageRegExp.exec(str); + if (!match) return null; + + var prefix = match[1], + suffix = match[2], + full = prefix; + + if (suffix) full += "-" + suffix; + + var q = 1; + if (match[3]) { + var params = match[3].split(';') + for (var i = 0; i < params.length; i ++) { + var p = params[i].split('='); + if (p[0] === 'q') q = parseFloat(p[1]); + } + } + + return { + prefix: prefix, + suffix: suffix, + q: q, + i: i, + full: full + }; +} + +/** + * Get the priority of a language. + * @private + */ + +function getLanguagePriority(language, accepted, index) { + var priority = {o: -1, q: 0, s: 0}; + + for (var i = 0; i < accepted.length; i++) { + var spec = specify(language, accepted[i], index); + + if (spec && (priority.s - spec.s || priority.q - spec.q || priority.o - spec.o) < 0) { + priority = spec; + } + } + + return priority; +} + +/** + * Get the specificity of the language. + * @private + */ + +function specify(language, spec, index) { + var p = parseLanguage(language) + if (!p) return null; + var s = 0; + if(spec.full.toLowerCase() === p.full.toLowerCase()){ + s |= 4; + } else if (spec.prefix.toLowerCase() === p.full.toLowerCase()) { + s |= 2; + } else if (spec.full.toLowerCase() === p.prefix.toLowerCase()) { + s |= 1; + } else if (spec.full !== '*' ) { + return null + } + + return { + i: index, + o: spec.i, + q: spec.q, + s: s + } +}; + +/** + * Get the preferred languages from an Accept-Language header. + * @public + */ + +function preferredLanguages(accept, provided) { + // RFC 2616 sec 14.4: no header = * + var accepts = parseAcceptLanguage(accept === undefined ? '*' : accept || ''); + + if (!provided) { + // sorted list of all languages + return accepts + .filter(isQuality) + .sort(compareSpecs) + .map(getFullLanguage); + } + + var priorities = provided.map(function getPriority(type, index) { + return getLanguagePriority(type, accepts, index); + }); + + // sorted list of accepted languages + return priorities.filter(isQuality).sort(compareSpecs).map(function getLanguage(priority) { + return provided[priorities.indexOf(priority)]; + }); +} + +/** + * Compare two specs. + * @private + */ + +function compareSpecs(a, b) { + return (b.q - a.q) || (b.s - a.s) || (a.o - b.o) || (a.i - b.i) || 0; +} + +/** + * Get full language string. + * @private + */ + +function getFullLanguage(spec) { + return spec.full; +} + +/** + * Check if a spec has any quality. + * @private + */ + +function isQuality(spec) { + return spec.q > 0; +} diff --git a/node_modules/express/node_modules/accepts/node_modules/negotiator/lib/mediaType.js b/node_modules/express/node_modules/accepts/node_modules/negotiator/lib/mediaType.js new file mode 100644 index 0000000..67309dd --- /dev/null +++ b/node_modules/express/node_modules/accepts/node_modules/negotiator/lib/mediaType.js @@ -0,0 +1,294 @@ +/** + * negotiator + * Copyright(c) 2012 Isaac Z. Schlueter + * Copyright(c) 2014 Federico Romero + * Copyright(c) 2014-2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict'; + +/** + * Module exports. + * @public + */ + +module.exports = preferredMediaTypes; +module.exports.preferredMediaTypes = preferredMediaTypes; + +/** + * Module variables. + * @private + */ + +var simpleMediaTypeRegExp = /^\s*([^\s\/;]+)\/([^;\s]+)\s*(?:;(.*))?$/; + +/** + * Parse the Accept header. + * @private + */ + +function parseAccept(accept) { + var accepts = splitMediaTypes(accept); + + for (var i = 0, j = 0; i < accepts.length; i++) { + var mediaType = parseMediaType(accepts[i].trim(), i); + + if (mediaType) { + accepts[j++] = mediaType; + } + } + + // trim accepts + accepts.length = j; + + return accepts; +} + +/** + * Parse a media type from the Accept header. + * @private + */ + +function parseMediaType(str, i) { + var match = simpleMediaTypeRegExp.exec(str); + if (!match) return null; + + var params = Object.create(null); + var q = 1; + var subtype = match[2]; + var type = match[1]; + + if (match[3]) { + var kvps = splitParameters(match[3]).map(splitKeyValuePair); + + for (var j = 0; j < kvps.length; j++) { + var pair = kvps[j]; + var key = pair[0].toLowerCase(); + var val = pair[1]; + + // get the value, unwrapping quotes + var value = val && val[0] === '"' && val[val.length - 1] === '"' + ? val.substr(1, val.length - 2) + : val; + + if (key === 'q') { + q = parseFloat(value); + break; + } + + // store parameter + params[key] = value; + } + } + + return { + type: type, + subtype: subtype, + params: params, + q: q, + i: i + }; +} + +/** + * Get the priority of a media type. + * @private + */ + +function getMediaTypePriority(type, accepted, index) { + var priority = {o: -1, q: 0, s: 0}; + + for (var i = 0; i < accepted.length; i++) { + var spec = specify(type, accepted[i], index); + + if (spec && (priority.s - spec.s || priority.q - spec.q || priority.o - spec.o) < 0) { + priority = spec; + } + } + + return priority; +} + +/** + * Get the specificity of the media type. + * @private + */ + +function specify(type, spec, index) { + var p = parseMediaType(type); + var s = 0; + + if (!p) { + return null; + } + + if(spec.type.toLowerCase() == p.type.toLowerCase()) { + s |= 4 + } else if(spec.type != '*') { + return null; + } + + if(spec.subtype.toLowerCase() == p.subtype.toLowerCase()) { + s |= 2 + } else if(spec.subtype != '*') { + return null; + } + + var keys = Object.keys(spec.params); + if (keys.length > 0) { + if (keys.every(function (k) { + return spec.params[k] == '*' || (spec.params[k] || '').toLowerCase() == (p.params[k] || '').toLowerCase(); + })) { + s |= 1 + } else { + return null + } + } + + return { + i: index, + o: spec.i, + q: spec.q, + s: s, + } +} + +/** + * Get the preferred media types from an Accept header. + * @public + */ + +function preferredMediaTypes(accept, provided) { + // RFC 2616 sec 14.2: no header = */* + var accepts = parseAccept(accept === undefined ? '*/*' : accept || ''); + + if (!provided) { + // sorted list of all types + return accepts + .filter(isQuality) + .sort(compareSpecs) + .map(getFullType); + } + + var priorities = provided.map(function getPriority(type, index) { + return getMediaTypePriority(type, accepts, index); + }); + + // sorted list of accepted types + return priorities.filter(isQuality).sort(compareSpecs).map(function getType(priority) { + return provided[priorities.indexOf(priority)]; + }); +} + +/** + * Compare two specs. + * @private + */ + +function compareSpecs(a, b) { + return (b.q - a.q) || (b.s - a.s) || (a.o - b.o) || (a.i - b.i) || 0; +} + +/** + * Get full type string. + * @private + */ + +function getFullType(spec) { + return spec.type + '/' + spec.subtype; +} + +/** + * Check if a spec has any quality. + * @private + */ + +function isQuality(spec) { + return spec.q > 0; +} + +/** + * Count the number of quotes in a string. + * @private + */ + +function quoteCount(string) { + var count = 0; + var index = 0; + + while ((index = string.indexOf('"', index)) !== -1) { + count++; + index++; + } + + return count; +} + +/** + * Split a key value pair. + * @private + */ + +function splitKeyValuePair(str) { + var index = str.indexOf('='); + var key; + var val; + + if (index === -1) { + key = str; + } else { + key = str.substr(0, index); + val = str.substr(index + 1); + } + + return [key, val]; +} + +/** + * Split an Accept header into media types. + * @private + */ + +function splitMediaTypes(accept) { + var accepts = accept.split(','); + + for (var i = 1, j = 0; i < accepts.length; i++) { + if (quoteCount(accepts[j]) % 2 == 0) { + accepts[++j] = accepts[i]; + } else { + accepts[j] += ',' + accepts[i]; + } + } + + // trim accepts + accepts.length = j + 1; + + return accepts; +} + +/** + * Split a string of parameters. + * @private + */ + +function splitParameters(str) { + var parameters = str.split(';'); + + for (var i = 1, j = 0; i < parameters.length; i++) { + if (quoteCount(parameters[j]) % 2 == 0) { + parameters[++j] = parameters[i]; + } else { + parameters[j] += ';' + parameters[i]; + } + } + + // trim parameters + parameters.length = j + 1; + + for (var i = 0; i < parameters.length; i++) { + parameters[i] = parameters[i].trim(); + } + + return parameters; +} diff --git a/node_modules/express/node_modules/accepts/node_modules/negotiator/package.json b/node_modules/express/node_modules/accepts/node_modules/negotiator/package.json new file mode 100644 index 0000000..7952cec --- /dev/null +++ b/node_modules/express/node_modules/accepts/node_modules/negotiator/package.json @@ -0,0 +1,91 @@ +{ + "name": "negotiator", + "description": "HTTP content negotiation", + "version": "0.6.1", + "contributors": [ + { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "Federico Romero", + "email": "federico.romero@outboxlabs.com" + }, + { + "name": "Isaac Z. Schlueter", + "email": "i@izs.me", + "url": "http://blog.izs.me/" + } + ], + "license": "MIT", + "keywords": [ + "http", + "content negotiation", + "accept", + "accept-language", + "accept-encoding", + "accept-charset" + ], + "repository": { + "type": "git", + "url": "git+https://github.com/jshttp/negotiator.git" + }, + "devDependencies": { + "istanbul": "0.4.3", + "mocha": "~1.21.5" + }, + "files": [ + "lib/", + "HISTORY.md", + "LICENSE", + "index.js", + "README.md" + ], + "engines": { + "node": ">= 0.6" + }, + "scripts": { + "test": "mocha --reporter spec --check-leaks --bail test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot --check-leaks test/", + "test-travis": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter spec --check-leaks test/" + }, + "gitHead": "751c381c32707f238143cd65d78520e16f4ef9e5", + "bugs": { + "url": "https://github.com/jshttp/negotiator/issues" + }, + "homepage": "https://github.com/jshttp/negotiator#readme", + "_id": "negotiator@0.6.1", + "_shasum": "2b327184e8992101177b28563fb5e7102acd0ca9", + "_from": "negotiator@0.6.1", + "_npmVersion": "2.15.1", + "_nodeVersion": "4.4.3", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "dist": { + "shasum": "2b327184e8992101177b28563fb5e7102acd0ca9", + "tarball": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.1.tgz" + }, + "maintainers": [ + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "federomero", + "email": "federomero@gmail.com" + }, + { + "name": "jongleberry", + "email": "jonathanrichardong@gmail.com" + } + ], + "_npmOperationalInternal": { + "host": "packages-16-east.internal.npmjs.com", + "tmp": "tmp/negotiator-0.6.1.tgz_1462250848695_0.027451182017102838" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/negotiator/-/negotiator-0.6.1.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/express/node_modules/accepts/package.json b/node_modules/express/node_modules/accepts/package.json new file mode 100644 index 0000000..ad1ec27 --- /dev/null +++ b/node_modules/express/node_modules/accepts/package.json @@ -0,0 +1,79 @@ +{ + "name": "accepts", + "description": "Higher-level content negotiation", + "version": "1.3.3", + "contributors": [ + { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "Jonathan Ong", + "email": "me@jongleberry.com", + "url": "http://jongleberry.com" + } + ], + "license": "MIT", + "repository": { + "type": "git", + "url": "git+https://github.com/jshttp/accepts.git" + }, + "dependencies": { + "mime-types": "~2.1.11", + "negotiator": "0.6.1" + }, + "devDependencies": { + "istanbul": "0.4.3", + "mocha": "~1.21.5" + }, + "files": [ + "LICENSE", + "HISTORY.md", + "index.js" + ], + "engines": { + "node": ">= 0.6" + }, + "scripts": { + "test": "mocha --reporter spec --check-leaks --bail test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot --check-leaks test/", + "test-travis": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter spec --check-leaks test/" + }, + "keywords": [ + "content", + "negotiation", + "accept", + "accepts" + ], + "gitHead": "3e925b1e65ed7da2798849683d49814680dfa426", + "bugs": { + "url": "https://github.com/jshttp/accepts/issues" + }, + "homepage": "https://github.com/jshttp/accepts#readme", + "_id": "accepts@1.3.3", + "_shasum": "c3ca7434938648c3e0d9c1e328dd68b622c284ca", + "_from": "accepts@>=1.3.3 <1.4.0", + "_npmVersion": "2.15.1", + "_nodeVersion": "4.4.3", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "dist": { + "shasum": "c3ca7434938648c3e0d9c1e328dd68b622c284ca", + "tarball": "https://registry.npmjs.org/accepts/-/accepts-1.3.3.tgz" + }, + "maintainers": [ + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + } + ], + "_npmOperationalInternal": { + "host": "packages-16-east.internal.npmjs.com", + "tmp": "tmp/accepts-1.3.3.tgz_1462251932032_0.7092335098423064" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/accepts/-/accepts-1.3.3.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/express/node_modules/array-flatten/LICENSE b/node_modules/express/node_modules/array-flatten/LICENSE new file mode 100644 index 0000000..983fbe8 --- /dev/null +++ b/node_modules/express/node_modules/array-flatten/LICENSE @@ -0,0 +1,21 @@ +The MIT License (MIT) + +Copyright (c) 2014 Blake Embrey (hello@blakeembrey.com) + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. diff --git a/node_modules/express/node_modules/array-flatten/README.md b/node_modules/express/node_modules/array-flatten/README.md new file mode 100644 index 0000000..91fa5b6 --- /dev/null +++ b/node_modules/express/node_modules/array-flatten/README.md @@ -0,0 +1,43 @@ +# Array Flatten + +[![NPM version][npm-image]][npm-url] +[![NPM downloads][downloads-image]][downloads-url] +[![Build status][travis-image]][travis-url] +[![Test coverage][coveralls-image]][coveralls-url] + +> Flatten an array of nested arrays into a single flat array. Accepts an optional depth. + +## Installation + +``` +npm install array-flatten --save +``` + +## Usage + +```javascript +var flatten = require('array-flatten') + +flatten([1, [2, [3, [4, [5], 6], 7], 8], 9]) +//=> [1, 2, 3, 4, 5, 6, 7, 8, 9] + +flatten([1, [2, [3, [4, [5], 6], 7], 8], 9], 2) +//=> [1, 2, 3, [4, [5], 6], 7, 8, 9] + +(function () { + flatten(arguments) //=> [1, 2, 3] +})(1, [2, 3]) +``` + +## License + +MIT + +[npm-image]: https://img.shields.io/npm/v/array-flatten.svg?style=flat +[npm-url]: https://npmjs.org/package/array-flatten +[downloads-image]: https://img.shields.io/npm/dm/array-flatten.svg?style=flat +[downloads-url]: https://npmjs.org/package/array-flatten +[travis-image]: https://img.shields.io/travis/blakeembrey/array-flatten.svg?style=flat +[travis-url]: https://travis-ci.org/blakeembrey/array-flatten +[coveralls-image]: https://img.shields.io/coveralls/blakeembrey/array-flatten.svg?style=flat +[coveralls-url]: https://coveralls.io/r/blakeembrey/array-flatten?branch=master diff --git a/node_modules/express/node_modules/array-flatten/array-flatten.js b/node_modules/express/node_modules/array-flatten/array-flatten.js new file mode 100644 index 0000000..089117b --- /dev/null +++ b/node_modules/express/node_modules/array-flatten/array-flatten.js @@ -0,0 +1,64 @@ +'use strict' + +/** + * Expose `arrayFlatten`. + */ +module.exports = arrayFlatten + +/** + * Recursive flatten function with depth. + * + * @param {Array} array + * @param {Array} result + * @param {Number} depth + * @return {Array} + */ +function flattenWithDepth (array, result, depth) { + for (var i = 0; i < array.length; i++) { + var value = array[i] + + if (depth > 0 && Array.isArray(value)) { + flattenWithDepth(value, result, depth - 1) + } else { + result.push(value) + } + } + + return result +} + +/** + * Recursive flatten function. Omitting depth is slightly faster. + * + * @param {Array} array + * @param {Array} result + * @return {Array} + */ +function flattenForever (array, result) { + for (var i = 0; i < array.length; i++) { + var value = array[i] + + if (Array.isArray(value)) { + flattenForever(value, result) + } else { + result.push(value) + } + } + + return result +} + +/** + * Flatten an array, with the ability to define a depth. + * + * @param {Array} array + * @param {Number} depth + * @return {Array} + */ +function arrayFlatten (array, depth) { + if (depth == null) { + return flattenForever(array, []) + } + + return flattenWithDepth(array, [], depth) +} diff --git a/node_modules/express/node_modules/array-flatten/package.json b/node_modules/express/node_modules/array-flatten/package.json new file mode 100644 index 0000000..807c768 --- /dev/null +++ b/node_modules/express/node_modules/array-flatten/package.json @@ -0,0 +1,62 @@ +{ + "name": "array-flatten", + "version": "1.1.1", + "description": "Flatten an array of nested arrays into a single flat array", + "main": "array-flatten.js", + "files": [ + "array-flatten.js", + "LICENSE" + ], + "scripts": { + "test": "istanbul cover _mocha -- -R spec" + }, + "repository": { + "type": "git", + "url": "git://github.com/blakeembrey/array-flatten.git" + }, + "keywords": [ + "array", + "flatten", + "arguments", + "depth" + ], + "author": { + "name": "Blake Embrey", + "email": "hello@blakeembrey.com", + "url": "http://blakeembrey.me" + }, + "license": "MIT", + "bugs": { + "url": "https://github.com/blakeembrey/array-flatten/issues" + }, + "homepage": "https://github.com/blakeembrey/array-flatten", + "devDependencies": { + "istanbul": "^0.3.13", + "mocha": "^2.2.4", + "pre-commit": "^1.0.7", + "standard": "^3.7.3" + }, + "gitHead": "1963a9189229d408e1e8f585a00c8be9edbd1803", + "_id": "array-flatten@1.1.1", + "_shasum": "9a5f699051b1e7073328f2a008968b64ea2955d2", + "_from": "array-flatten@1.1.1", + "_npmVersion": "2.11.3", + "_nodeVersion": "2.3.3", + "_npmUser": { + "name": "blakeembrey", + "email": "hello@blakeembrey.com" + }, + "maintainers": [ + { + "name": "blakeembrey", + "email": "hello@blakeembrey.com" + } + ], + "dist": { + "shasum": "9a5f699051b1e7073328f2a008968b64ea2955d2", + "tarball": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/express/node_modules/content-disposition/HISTORY.md b/node_modules/express/node_modules/content-disposition/HISTORY.md new file mode 100644 index 0000000..76d494c --- /dev/null +++ b/node_modules/express/node_modules/content-disposition/HISTORY.md @@ -0,0 +1,45 @@ +0.5.1 / 2016-01-17 +================== + + * perf: enable strict mode + +0.5.0 / 2014-10-11 +================== + + * Add `parse` function + +0.4.0 / 2014-09-21 +================== + + * Expand non-Unicode `filename` to the full ISO-8859-1 charset + +0.3.0 / 2014-09-20 +================== + + * Add `fallback` option + * Add `type` option + +0.2.0 / 2014-09-19 +================== + + * Reduce ambiguity of file names with hex escape in buggy browsers + +0.1.2 / 2014-09-19 +================== + + * Fix periodic invalid Unicode filename header + +0.1.1 / 2014-09-19 +================== + + * Fix invalid characters appearing in `filename*` parameter + +0.1.0 / 2014-09-18 +================== + + * Make the `filename` argument optional + +0.0.0 / 2014-09-18 +================== + + * Initial release diff --git a/node_modules/express/node_modules/content-disposition/LICENSE b/node_modules/express/node_modules/content-disposition/LICENSE new file mode 100644 index 0000000..b7dce6c --- /dev/null +++ b/node_modules/express/node_modules/content-disposition/LICENSE @@ -0,0 +1,22 @@ +(The MIT License) + +Copyright (c) 2014 Douglas Christopher Wilson + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/express/node_modules/content-disposition/README.md b/node_modules/express/node_modules/content-disposition/README.md new file mode 100644 index 0000000..5cebce4 --- /dev/null +++ b/node_modules/express/node_modules/content-disposition/README.md @@ -0,0 +1,141 @@ +# content-disposition + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Node.js Version][node-version-image]][node-version-url] +[![Build Status][travis-image]][travis-url] +[![Test Coverage][coveralls-image]][coveralls-url] + +Create and parse HTTP `Content-Disposition` header + +## Installation + +```sh +$ npm install content-disposition +``` + +## API + +```js +var contentDisposition = require('content-disposition') +``` + +### contentDisposition(filename, options) + +Create an attachment `Content-Disposition` header value using the given file name, +if supplied. The `filename` is optional and if no file name is desired, but you +want to specify `options`, set `filename` to `undefined`. + +```js +res.setHeader('Content-Disposition', contentDisposition('∫ maths.pdf')) +``` + +**note** HTTP headers are of the ISO-8859-1 character set. If you are writing this +header through a means different from `setHeader` in Node.js, you'll want to specify +the `'binary'` encoding in Node.js. + +#### Options + +`contentDisposition` accepts these properties in the options object. + +##### fallback + +If the `filename` option is outside ISO-8859-1, then the file name is actually +stored in a supplemental field for clients that support Unicode file names and +a ISO-8859-1 version of the file name is automatically generated. + +This specifies the ISO-8859-1 file name to override the automatic generation or +disables the generation all together, defaults to `true`. + + - A string will specify the ISO-8859-1 file name to use in place of automatic + generation. + - `false` will disable including a ISO-8859-1 file name and only include the + Unicode version (unless the file name is already ISO-8859-1). + - `true` will enable automatic generation if the file name is outside ISO-8859-1. + +If the `filename` option is ISO-8859-1 and this option is specified and has a +different value, then the `filename` option is encoded in the extended field +and this set as the fallback field, even though they are both ISO-8859-1. + +##### type + +Specifies the disposition type, defaults to `"attachment"`. This can also be +`"inline"`, or any other value (all values except inline are treated like +`attachment`, but can convey additional information if both parties agree to +it). The type is normalized to lower-case. + +### contentDisposition.parse(string) + +```js +var disposition = contentDisposition.parse('attachment; filename="EURO rates.txt"; filename*=UTF-8\'\'%e2%82%ac%20rates.txt'); +``` + +Parse a `Content-Disposition` header string. This automatically handles extended +("Unicode") parameters by decoding them and providing them under the standard +parameter name. This will return an object with the following properties (examples +are shown for the string `'attachment; filename="EURO rates.txt"; filename*=UTF-8\'\'%e2%82%ac%20rates.txt'`): + + - `type`: The disposition type (always lower case). Example: `'attachment'` + + - `parameters`: An object of the parameters in the disposition (name of parameter + always lower case and extended versions replace non-extended versions). Example: + `{filename: "€ rates.txt"}` + +## Examples + +### Send a file for download + +```js +var contentDisposition = require('content-disposition') +var destroy = require('destroy') +var http = require('http') +var onFinished = require('on-finished') + +var filePath = '/path/to/public/plans.pdf' + +http.createServer(function onRequest(req, res) { + // set headers + res.setHeader('Content-Type', 'application/pdf') + res.setHeader('Content-Disposition', contentDisposition(filePath)) + + // send file + var stream = fs.createReadStream(filePath) + stream.pipe(res) + onFinished(res, function (err) { + destroy(stream) + }) +}) +``` + +## Testing + +```sh +$ npm test +``` + +## References + +- [RFC 2616: Hypertext Transfer Protocol -- HTTP/1.1][rfc-2616] +- [RFC 5987: Character Set and Language Encoding for Hypertext Transfer Protocol (HTTP) Header Field Parameters][rfc-5987] +- [RFC 6266: Use of the Content-Disposition Header Field in the Hypertext Transfer Protocol (HTTP)][rfc-6266] +- [Test Cases for HTTP Content-Disposition header field (RFC 6266) and the Encodings defined in RFCs 2047, 2231 and 5987][tc-2231] + +[rfc-2616]: https://tools.ietf.org/html/rfc2616 +[rfc-5987]: https://tools.ietf.org/html/rfc5987 +[rfc-6266]: https://tools.ietf.org/html/rfc6266 +[tc-2231]: http://greenbytes.de/tech/tc2231/ + +## License + +[MIT](LICENSE) + +[npm-image]: https://img.shields.io/npm/v/content-disposition.svg?style=flat +[npm-url]: https://npmjs.org/package/content-disposition +[node-version-image]: https://img.shields.io/node/v/content-disposition.svg?style=flat +[node-version-url]: http://nodejs.org/download/ +[travis-image]: https://img.shields.io/travis/jshttp/content-disposition.svg?style=flat +[travis-url]: https://travis-ci.org/jshttp/content-disposition +[coveralls-image]: https://img.shields.io/coveralls/jshttp/content-disposition.svg?style=flat +[coveralls-url]: https://coveralls.io/r/jshttp/content-disposition?branch=master +[downloads-image]: https://img.shields.io/npm/dm/content-disposition.svg?style=flat +[downloads-url]: https://npmjs.org/package/content-disposition diff --git a/node_modules/express/node_modules/content-disposition/index.js b/node_modules/express/node_modules/content-disposition/index.js new file mode 100644 index 0000000..4a352dc --- /dev/null +++ b/node_modules/express/node_modules/content-disposition/index.js @@ -0,0 +1,445 @@ +/*! + * content-disposition + * Copyright(c) 2014 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module exports. + */ + +module.exports = contentDisposition +module.exports.parse = parse + +/** + * Module dependencies. + */ + +var basename = require('path').basename + +/** + * RegExp to match non attr-char, *after* encodeURIComponent (i.e. not including "%") + */ + +var encodeUriAttrCharRegExp = /[\x00-\x20"'\(\)*,\/:;<=>?@\[\\\]\{\}\x7f]/g + +/** + * RegExp to match percent encoding escape. + */ + +var hexEscapeRegExp = /%[0-9A-Fa-f]{2}/ +var hexEscapeReplaceRegExp = /%([0-9A-Fa-f]{2})/g + +/** + * RegExp to match non-latin1 characters. + */ + +var nonLatin1RegExp = /[^\x20-\x7e\xa0-\xff]/g + +/** + * RegExp to match quoted-pair in RFC 2616 + * + * quoted-pair = "\" CHAR + * CHAR = + */ + +var qescRegExp = /\\([\u0000-\u007f])/g; + +/** + * RegExp to match chars that must be quoted-pair in RFC 2616 + */ + +var quoteRegExp = /([\\"])/g + +/** + * RegExp for various RFC 2616 grammar + * + * parameter = token "=" ( token | quoted-string ) + * token = 1* + * separators = "(" | ")" | "<" | ">" | "@" + * | "," | ";" | ":" | "\" | <"> + * | "/" | "[" | "]" | "?" | "=" + * | "{" | "}" | SP | HT + * quoted-string = ( <"> *(qdtext | quoted-pair ) <"> ) + * qdtext = > + * quoted-pair = "\" CHAR + * CHAR = + * TEXT = + * LWS = [CRLF] 1*( SP | HT ) + * CRLF = CR LF + * CR = + * LF = + * SP = + * HT = + * CTL = + * OCTET = + */ + +var paramRegExp = /; *([!#$%&'\*\+\-\.0-9A-Z\^_`a-z\|~]+) *= *("(?:[ !\x23-\x5b\x5d-\x7e\x80-\xff]|\\[\x20-\x7e])*"|[!#$%&'\*\+\-\.0-9A-Z\^_`a-z\|~]+) */g +var textRegExp = /^[\x20-\x7e\x80-\xff]+$/ +var tokenRegExp = /^[!#$%&'\*\+\-\.0-9A-Z\^_`a-z\|~]+$/ + +/** + * RegExp for various RFC 5987 grammar + * + * ext-value = charset "'" [ language ] "'" value-chars + * charset = "UTF-8" / "ISO-8859-1" / mime-charset + * mime-charset = 1*mime-charsetc + * mime-charsetc = ALPHA / DIGIT + * / "!" / "#" / "$" / "%" / "&" + * / "+" / "-" / "^" / "_" / "`" + * / "{" / "}" / "~" + * language = ( 2*3ALPHA [ extlang ] ) + * / 4ALPHA + * / 5*8ALPHA + * extlang = *3( "-" 3ALPHA ) + * value-chars = *( pct-encoded / attr-char ) + * pct-encoded = "%" HEXDIG HEXDIG + * attr-char = ALPHA / DIGIT + * / "!" / "#" / "$" / "&" / "+" / "-" / "." + * / "^" / "_" / "`" / "|" / "~" + */ + +var extValueRegExp = /^([A-Za-z0-9!#$%&+\-^_`{}~]+)'(?:[A-Za-z]{2,3}(?:-[A-Za-z]{3}){0,3}|[A-Za-z]{4,8}|)'((?:%[0-9A-Fa-f]{2}|[A-Za-z0-9!#$&+\-\.^_`|~])+)$/ + +/** + * RegExp for various RFC 6266 grammar + * + * disposition-type = "inline" | "attachment" | disp-ext-type + * disp-ext-type = token + * disposition-parm = filename-parm | disp-ext-parm + * filename-parm = "filename" "=" value + * | "filename*" "=" ext-value + * disp-ext-parm = token "=" value + * | ext-token "=" ext-value + * ext-token = + */ + +var dispositionTypeRegExp = /^([!#$%&'\*\+\-\.0-9A-Z\^_`a-z\|~]+) *(?:$|;)/ + +/** + * Create an attachment Content-Disposition header. + * + * @param {string} [filename] + * @param {object} [options] + * @param {string} [options.type=attachment] + * @param {string|boolean} [options.fallback=true] + * @return {string} + * @api public + */ + +function contentDisposition(filename, options) { + var opts = options || {} + + // get type + var type = opts.type || 'attachment' + + // get parameters + var params = createparams(filename, opts.fallback) + + // format into string + return format(new ContentDisposition(type, params)) +} + +/** + * Create parameters object from filename and fallback. + * + * @param {string} [filename] + * @param {string|boolean} [fallback=true] + * @return {object} + * @api private + */ + +function createparams(filename, fallback) { + if (filename === undefined) { + return + } + + var params = {} + + if (typeof filename !== 'string') { + throw new TypeError('filename must be a string') + } + + // fallback defaults to true + if (fallback === undefined) { + fallback = true + } + + if (typeof fallback !== 'string' && typeof fallback !== 'boolean') { + throw new TypeError('fallback must be a string or boolean') + } + + if (typeof fallback === 'string' && nonLatin1RegExp.test(fallback)) { + throw new TypeError('fallback must be ISO-8859-1 string') + } + + // restrict to file base name + var name = basename(filename) + + // determine if name is suitable for quoted string + var isQuotedString = textRegExp.test(name) + + // generate fallback name + var fallbackName = typeof fallback !== 'string' + ? fallback && getlatin1(name) + : basename(fallback) + var hasFallback = typeof fallbackName === 'string' && fallbackName !== name + + // set extended filename parameter + if (hasFallback || !isQuotedString || hexEscapeRegExp.test(name)) { + params['filename*'] = name + } + + // set filename parameter + if (isQuotedString || hasFallback) { + params.filename = hasFallback + ? fallbackName + : name + } + + return params +} + +/** + * Format object to Content-Disposition header. + * + * @param {object} obj + * @param {string} obj.type + * @param {object} [obj.parameters] + * @return {string} + * @api private + */ + +function format(obj) { + var parameters = obj.parameters + var type = obj.type + + if (!type || typeof type !== 'string' || !tokenRegExp.test(type)) { + throw new TypeError('invalid type') + } + + // start with normalized type + var string = String(type).toLowerCase() + + // append parameters + if (parameters && typeof parameters === 'object') { + var param + var params = Object.keys(parameters).sort() + + for (var i = 0; i < params.length; i++) { + param = params[i] + + var val = param.substr(-1) === '*' + ? ustring(parameters[param]) + : qstring(parameters[param]) + + string += '; ' + param + '=' + val + } + } + + return string +} + +/** + * Decode a RFC 6987 field value (gracefully). + * + * @param {string} str + * @return {string} + * @api private + */ + +function decodefield(str) { + var match = extValueRegExp.exec(str) + + if (!match) { + throw new TypeError('invalid extended field value') + } + + var charset = match[1].toLowerCase() + var encoded = match[2] + var value + + // to binary string + var binary = encoded.replace(hexEscapeReplaceRegExp, pdecode) + + switch (charset) { + case 'iso-8859-1': + value = getlatin1(binary) + break + case 'utf-8': + value = new Buffer(binary, 'binary').toString('utf8') + break + default: + throw new TypeError('unsupported charset in extended field') + } + + return value +} + +/** + * Get ISO-8859-1 version of string. + * + * @param {string} val + * @return {string} + * @api private + */ + +function getlatin1(val) { + // simple Unicode -> ISO-8859-1 transformation + return String(val).replace(nonLatin1RegExp, '?') +} + +/** + * Parse Content-Disposition header string. + * + * @param {string} string + * @return {object} + * @api private + */ + +function parse(string) { + if (!string || typeof string !== 'string') { + throw new TypeError('argument string is required') + } + + var match = dispositionTypeRegExp.exec(string) + + if (!match) { + throw new TypeError('invalid type format') + } + + // normalize type + var index = match[0].length + var type = match[1].toLowerCase() + + var key + var names = [] + var params = {} + var value + + // calculate index to start at + index = paramRegExp.lastIndex = match[0].substr(-1) === ';' + ? index - 1 + : index + + // match parameters + while (match = paramRegExp.exec(string)) { + if (match.index !== index) { + throw new TypeError('invalid parameter format') + } + + index += match[0].length + key = match[1].toLowerCase() + value = match[2] + + if (names.indexOf(key) !== -1) { + throw new TypeError('invalid duplicate parameter') + } + + names.push(key) + + if (key.indexOf('*') + 1 === key.length) { + // decode extended value + key = key.slice(0, -1) + value = decodefield(value) + + // overwrite existing value + params[key] = value + continue + } + + if (typeof params[key] === 'string') { + continue + } + + if (value[0] === '"') { + // remove quotes and escapes + value = value + .substr(1, value.length - 2) + .replace(qescRegExp, '$1') + } + + params[key] = value + } + + if (index !== -1 && index !== string.length) { + throw new TypeError('invalid parameter format') + } + + return new ContentDisposition(type, params) +} + +/** + * Percent decode a single character. + * + * @param {string} str + * @param {string} hex + * @return {string} + * @api private + */ + +function pdecode(str, hex) { + return String.fromCharCode(parseInt(hex, 16)) +} + +/** + * Percent encode a single character. + * + * @param {string} char + * @return {string} + * @api private + */ + +function pencode(char) { + var hex = String(char) + .charCodeAt(0) + .toString(16) + .toUpperCase() + return hex.length === 1 + ? '%0' + hex + : '%' + hex +} + +/** + * Quote a string for HTTP. + * + * @param {string} val + * @return {string} + * @api private + */ + +function qstring(val) { + var str = String(val) + + return '"' + str.replace(quoteRegExp, '\\$1') + '"' +} + +/** + * Encode a Unicode string for HTTP (RFC 5987). + * + * @param {string} val + * @return {string} + * @api private + */ + +function ustring(val) { + var str = String(val) + + // percent encode as UTF-8 + var encoded = encodeURIComponent(str) + .replace(encodeUriAttrCharRegExp, pencode) + + return 'UTF-8\'\'' + encoded +} + +/** + * Class for parsed Content-Disposition header for v8 optimization + */ + +function ContentDisposition(type, parameters) { + this.type = type + this.parameters = parameters +} diff --git a/node_modules/express/node_modules/content-disposition/package.json b/node_modules/express/node_modules/content-disposition/package.json new file mode 100644 index 0000000..82b468d --- /dev/null +++ b/node_modules/express/node_modules/content-disposition/package.json @@ -0,0 +1,66 @@ +{ + "name": "content-disposition", + "description": "Create and parse Content-Disposition header", + "version": "0.5.1", + "contributors": [ + { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + } + ], + "license": "MIT", + "keywords": [ + "content-disposition", + "http", + "rfc6266", + "res" + ], + "repository": { + "type": "git", + "url": "git+https://github.com/jshttp/content-disposition.git" + }, + "devDependencies": { + "istanbul": "0.4.2", + "mocha": "1.21.5" + }, + "files": [ + "LICENSE", + "HISTORY.md", + "README.md", + "index.js" + ], + "engines": { + "node": ">= 0.6" + }, + "scripts": { + "test": "mocha --reporter spec --bail --check-leaks test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot --check-leaks test/", + "test-travis": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter spec --check-leaks test/" + }, + "gitHead": "7b391db3af5629d4c698f1de21802940bb9f22a5", + "bugs": { + "url": "https://github.com/jshttp/content-disposition/issues" + }, + "homepage": "https://github.com/jshttp/content-disposition", + "_id": "content-disposition@0.5.1", + "_shasum": "87476c6a67c8daa87e32e87616df883ba7fb071b", + "_from": "content-disposition@0.5.1", + "_npmVersion": "1.4.28", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "maintainers": [ + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + } + ], + "dist": { + "shasum": "87476c6a67c8daa87e32e87616df883ba7fb071b", + "tarball": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.1.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/content-disposition/-/content-disposition-0.5.1.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/express/node_modules/content-type/HISTORY.md b/node_modules/express/node_modules/content-type/HISTORY.md new file mode 100644 index 0000000..01652ff --- /dev/null +++ b/node_modules/express/node_modules/content-type/HISTORY.md @@ -0,0 +1,14 @@ +1.0.2 / 2016-05-09 +================== + + * perf: enable strict mode + +1.0.1 / 2015-02-13 +================== + + * Improve missing `Content-Type` header error message + +1.0.0 / 2015-02-01 +================== + + * Initial implementation, derived from `media-typer@0.3.0` diff --git a/node_modules/express/node_modules/content-type/LICENSE b/node_modules/express/node_modules/content-type/LICENSE new file mode 100644 index 0000000..34b1a2d --- /dev/null +++ b/node_modules/express/node_modules/content-type/LICENSE @@ -0,0 +1,22 @@ +(The MIT License) + +Copyright (c) 2015 Douglas Christopher Wilson + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/express/node_modules/content-type/README.md b/node_modules/express/node_modules/content-type/README.md new file mode 100644 index 0000000..3ed6741 --- /dev/null +++ b/node_modules/express/node_modules/content-type/README.md @@ -0,0 +1,92 @@ +# content-type + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Node.js Version][node-version-image]][node-version-url] +[![Build Status][travis-image]][travis-url] +[![Test Coverage][coveralls-image]][coveralls-url] + +Create and parse HTTP Content-Type header according to RFC 7231 + +## Installation + +```sh +$ npm install content-type +``` + +## API + +```js +var contentType = require('content-type') +``` + +### contentType.parse(string) + +```js +var obj = contentType.parse('image/svg+xml; charset=utf-8') +``` + +Parse a content type string. This will return an object with the following +properties (examples are shown for the string `'image/svg+xml; charset=utf-8'`): + + - `type`: The media type (the type and subtype, always lower case). + Example: `'image/svg+xml'` + + - `parameters`: An object of the parameters in the media type (name of parameter + always lower case). Example: `{charset: 'utf-8'}` + +Throws a `TypeError` if the string is missing or invalid. + +### contentType.parse(req) + +```js +var obj = contentType.parse(req) +``` + +Parse the `content-type` header from the given `req`. Short-cut for +`contentType.parse(req.headers['content-type'])`. + +Throws a `TypeError` if the `Content-Type` header is missing or invalid. + +### contentType.parse(res) + +```js +var obj = contentType.parse(res) +``` + +Parse the `content-type` header set on the given `res`. Short-cut for +`contentType.parse(res.getHeader('content-type'))`. + +Throws a `TypeError` if the `Content-Type` header is missing or invalid. + +### contentType.format(obj) + +```js +var str = contentType.format({type: 'image/svg+xml'}) +``` + +Format an object into a content type string. This will return a string of the +content type for the given object with the following properties (examples are +shown that produce the string `'image/svg+xml; charset=utf-8'`): + + - `type`: The media type (will be lower-cased). Example: `'image/svg+xml'` + + - `parameters`: An object of the parameters in the media type (name of the + parameter will be lower-cased). Example: `{charset: 'utf-8'}` + +Throws a `TypeError` if the object contains an invalid type or parameter names. + +## License + +[MIT](LICENSE) + +[npm-image]: https://img.shields.io/npm/v/content-type.svg +[npm-url]: https://npmjs.org/package/content-type +[node-version-image]: https://img.shields.io/node/v/content-type.svg +[node-version-url]: http://nodejs.org/download/ +[travis-image]: https://img.shields.io/travis/jshttp/content-type/master.svg +[travis-url]: https://travis-ci.org/jshttp/content-type +[coveralls-image]: https://img.shields.io/coveralls/jshttp/content-type/master.svg +[coveralls-url]: https://coveralls.io/r/jshttp/content-type +[downloads-image]: https://img.shields.io/npm/dm/content-type.svg +[downloads-url]: https://npmjs.org/package/content-type diff --git a/node_modules/express/node_modules/content-type/index.js b/node_modules/express/node_modules/content-type/index.js new file mode 100644 index 0000000..61ba6b5 --- /dev/null +++ b/node_modules/express/node_modules/content-type/index.js @@ -0,0 +1,216 @@ +/*! + * content-type + * Copyright(c) 2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * RegExp to match *( ";" parameter ) in RFC 7231 sec 3.1.1.1 + * + * parameter = token "=" ( token / quoted-string ) + * token = 1*tchar + * tchar = "!" / "#" / "$" / "%" / "&" / "'" / "*" + * / "+" / "-" / "." / "^" / "_" / "`" / "|" / "~" + * / DIGIT / ALPHA + * ; any VCHAR, except delimiters + * quoted-string = DQUOTE *( qdtext / quoted-pair ) DQUOTE + * qdtext = HTAB / SP / %x21 / %x23-5B / %x5D-7E / obs-text + * obs-text = %x80-FF + * quoted-pair = "\" ( HTAB / SP / VCHAR / obs-text ) + */ +var paramRegExp = /; *([!#$%&'\*\+\-\.\^_`\|~0-9A-Za-z]+) *= *("(?:[\u000b\u0020\u0021\u0023-\u005b\u005d-\u007e\u0080-\u00ff]|\\[\u000b\u0020-\u00ff])*"|[!#$%&'\*\+\-\.\^_`\|~0-9A-Za-z]+) */g +var textRegExp = /^[\u000b\u0020-\u007e\u0080-\u00ff]+$/ +var tokenRegExp = /^[!#$%&'\*\+\-\.\^_`\|~0-9A-Za-z]+$/ + +/** + * RegExp to match quoted-pair in RFC 7230 sec 3.2.6 + * + * quoted-pair = "\" ( HTAB / SP / VCHAR / obs-text ) + * obs-text = %x80-FF + */ +var qescRegExp = /\\([\u000b\u0020-\u00ff])/g + +/** + * RegExp to match chars that must be quoted-pair in RFC 7230 sec 3.2.6 + */ +var quoteRegExp = /([\\"])/g + +/** + * RegExp to match type in RFC 6838 + * + * media-type = type "/" subtype + * type = token + * subtype = token + */ +var typeRegExp = /^[!#$%&'\*\+\-\.\^_`\|~0-9A-Za-z]+\/[!#$%&'\*\+\-\.\^_`\|~0-9A-Za-z]+$/ + +/** + * Module exports. + * @public + */ + +exports.format = format +exports.parse = parse + +/** + * Format object to media type. + * + * @param {object} obj + * @return {string} + * @public + */ + +function format(obj) { + if (!obj || typeof obj !== 'object') { + throw new TypeError('argument obj is required') + } + + var parameters = obj.parameters + var type = obj.type + + if (!type || !typeRegExp.test(type)) { + throw new TypeError('invalid type') + } + + var string = type + + // append parameters + if (parameters && typeof parameters === 'object') { + var param + var params = Object.keys(parameters).sort() + + for (var i = 0; i < params.length; i++) { + param = params[i] + + if (!tokenRegExp.test(param)) { + throw new TypeError('invalid parameter name') + } + + string += '; ' + param + '=' + qstring(parameters[param]) + } + } + + return string +} + +/** + * Parse media type to object. + * + * @param {string|object} string + * @return {Object} + * @public + */ + +function parse(string) { + if (!string) { + throw new TypeError('argument string is required') + } + + if (typeof string === 'object') { + // support req/res-like objects as argument + string = getcontenttype(string) + + if (typeof string !== 'string') { + throw new TypeError('content-type header is missing from object'); + } + } + + if (typeof string !== 'string') { + throw new TypeError('argument string is required to be a string') + } + + var index = string.indexOf(';') + var type = index !== -1 + ? string.substr(0, index).trim() + : string.trim() + + if (!typeRegExp.test(type)) { + throw new TypeError('invalid media type') + } + + var key + var match + var obj = new ContentType(type.toLowerCase()) + var value + + paramRegExp.lastIndex = index + + while (match = paramRegExp.exec(string)) { + if (match.index !== index) { + throw new TypeError('invalid parameter format') + } + + index += match[0].length + key = match[1].toLowerCase() + value = match[2] + + if (value[0] === '"') { + // remove quotes and escapes + value = value + .substr(1, value.length - 2) + .replace(qescRegExp, '$1') + } + + obj.parameters[key] = value + } + + if (index !== -1 && index !== string.length) { + throw new TypeError('invalid parameter format') + } + + return obj +} + +/** + * Get content-type from req/res objects. + * + * @param {object} + * @return {Object} + * @private + */ + +function getcontenttype(obj) { + if (typeof obj.getHeader === 'function') { + // res-like + return obj.getHeader('content-type') + } + + if (typeof obj.headers === 'object') { + // req-like + return obj.headers && obj.headers['content-type'] + } +} + +/** + * Quote a string if necessary. + * + * @param {string} val + * @return {string} + * @private + */ + +function qstring(val) { + var str = String(val) + + // no need to quote tokens + if (tokenRegExp.test(str)) { + return str + } + + if (str.length > 0 && !textRegExp.test(str)) { + throw new TypeError('invalid parameter value') + } + + return '"' + str.replace(quoteRegExp, '\\$1') + '"' +} + +/** + * Class to represent a content type. + * @private + */ +function ContentType(type) { + this.parameters = Object.create(null) + this.type = type +} diff --git a/node_modules/express/node_modules/content-type/package.json b/node_modules/express/node_modules/content-type/package.json new file mode 100644 index 0000000..aaa2211 --- /dev/null +++ b/node_modules/express/node_modules/content-type/package.json @@ -0,0 +1,70 @@ +{ + "name": "content-type", + "description": "Create and parse HTTP Content-Type header", + "version": "1.0.2", + "author": { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + }, + "license": "MIT", + "keywords": [ + "content-type", + "http", + "req", + "res", + "rfc7231" + ], + "repository": { + "type": "git", + "url": "git+https://github.com/jshttp/content-type.git" + }, + "devDependencies": { + "istanbul": "0.4.3", + "mocha": "~1.21.5" + }, + "files": [ + "LICENSE", + "HISTORY.md", + "README.md", + "index.js" + ], + "engines": { + "node": ">= 0.6" + }, + "scripts": { + "test": "mocha --reporter spec --check-leaks --bail test/", + "test-ci": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter spec --check-leaks test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot --check-leaks test/" + }, + "gitHead": "8118763adfbbac80cf1254191889330aec8b8be7", + "bugs": { + "url": "https://github.com/jshttp/content-type/issues" + }, + "homepage": "https://github.com/jshttp/content-type#readme", + "_id": "content-type@1.0.2", + "_shasum": "b7d113aee7a8dd27bd21133c4dc2529df1721eed", + "_from": "content-type@>=1.0.2 <1.1.0", + "_npmVersion": "2.15.1", + "_nodeVersion": "4.4.3", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "dist": { + "shasum": "b7d113aee7a8dd27bd21133c4dc2529df1721eed", + "tarball": "https://registry.npmjs.org/content-type/-/content-type-1.0.2.tgz" + }, + "maintainers": [ + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + } + ], + "_npmOperationalInternal": { + "host": "packages-12-west.internal.npmjs.com", + "tmp": "tmp/content-type-1.0.2.tgz_1462852785748_0.5491233412176371" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/content-type/-/content-type-1.0.2.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/express/node_modules/cookie-signature/.npmignore b/node_modules/express/node_modules/cookie-signature/.npmignore new file mode 100644 index 0000000..f1250e5 --- /dev/null +++ b/node_modules/express/node_modules/cookie-signature/.npmignore @@ -0,0 +1,4 @@ +support +test +examples +*.sock diff --git a/node_modules/express/node_modules/cookie-signature/History.md b/node_modules/express/node_modules/cookie-signature/History.md new file mode 100644 index 0000000..78513cc --- /dev/null +++ b/node_modules/express/node_modules/cookie-signature/History.md @@ -0,0 +1,38 @@ +1.0.6 / 2015-02-03 +================== + +* use `npm test` instead of `make test` to run tests +* clearer assertion messages when checking input + + +1.0.5 / 2014-09-05 +================== + +* add license to package.json + +1.0.4 / 2014-06-25 +================== + + * corrected avoidance of timing attacks (thanks @tenbits!) + +1.0.3 / 2014-01-28 +================== + + * [incorrect] fix for timing attacks + +1.0.2 / 2014-01-28 +================== + + * fix missing repository warning + * fix typo in test + +1.0.1 / 2013-04-15 +================== + + * Revert "Changed underlying HMAC algo. to sha512." + * Revert "Fix for timing attacks on MAC verification." + +0.0.1 / 2010-01-03 +================== + + * Initial release diff --git a/node_modules/express/node_modules/cookie-signature/Readme.md b/node_modules/express/node_modules/cookie-signature/Readme.md new file mode 100644 index 0000000..2559e84 --- /dev/null +++ b/node_modules/express/node_modules/cookie-signature/Readme.md @@ -0,0 +1,42 @@ + +# cookie-signature + + Sign and unsign cookies. + +## Example + +```js +var cookie = require('cookie-signature'); + +var val = cookie.sign('hello', 'tobiiscool'); +val.should.equal('hello.DGDUkGlIkCzPz+C0B064FNgHdEjox7ch8tOBGslZ5QI'); + +var val = cookie.sign('hello', 'tobiiscool'); +cookie.unsign(val, 'tobiiscool').should.equal('hello'); +cookie.unsign(val, 'luna').should.be.false; +``` + +## License + +(The MIT License) + +Copyright (c) 2012 LearnBoost <tj@learnboost.com> + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. \ No newline at end of file diff --git a/node_modules/express/node_modules/cookie-signature/index.js b/node_modules/express/node_modules/cookie-signature/index.js new file mode 100644 index 0000000..b8c9463 --- /dev/null +++ b/node_modules/express/node_modules/cookie-signature/index.js @@ -0,0 +1,51 @@ +/** + * Module dependencies. + */ + +var crypto = require('crypto'); + +/** + * Sign the given `val` with `secret`. + * + * @param {String} val + * @param {String} secret + * @return {String} + * @api private + */ + +exports.sign = function(val, secret){ + if ('string' != typeof val) throw new TypeError("Cookie value must be provided as a string."); + if ('string' != typeof secret) throw new TypeError("Secret string must be provided."); + return val + '.' + crypto + .createHmac('sha256', secret) + .update(val) + .digest('base64') + .replace(/\=+$/, ''); +}; + +/** + * Unsign and decode the given `val` with `secret`, + * returning `false` if the signature is invalid. + * + * @param {String} val + * @param {String} secret + * @return {String|Boolean} + * @api private + */ + +exports.unsign = function(val, secret){ + if ('string' != typeof val) throw new TypeError("Signed cookie string must be provided."); + if ('string' != typeof secret) throw new TypeError("Secret string must be provided."); + var str = val.slice(0, val.lastIndexOf('.')) + , mac = exports.sign(str, secret); + + return sha1(mac) == sha1(val) ? str : false; +}; + +/** + * Private + */ + +function sha1(str){ + return crypto.createHash('sha1').update(str).digest('hex'); +} diff --git a/node_modules/express/node_modules/cookie-signature/package.json b/node_modules/express/node_modules/cookie-signature/package.json new file mode 100644 index 0000000..33c95c0 --- /dev/null +++ b/node_modules/express/node_modules/cookie-signature/package.json @@ -0,0 +1,59 @@ +{ + "name": "cookie-signature", + "version": "1.0.6", + "description": "Sign and unsign cookies", + "keywords": [ + "cookie", + "sign", + "unsign" + ], + "author": { + "name": "TJ Holowaychuk", + "email": "tj@learnboost.com" + }, + "license": "MIT", + "repository": { + "type": "git", + "url": "git+https://github.com/visionmedia/node-cookie-signature.git" + }, + "dependencies": {}, + "devDependencies": { + "mocha": "*", + "should": "*" + }, + "scripts": { + "test": "mocha --require should --reporter spec" + }, + "main": "index", + "gitHead": "391b56cf44d88c493491b7e3fc53208cfb976d2a", + "bugs": { + "url": "https://github.com/visionmedia/node-cookie-signature/issues" + }, + "homepage": "https://github.com/visionmedia/node-cookie-signature", + "_id": "cookie-signature@1.0.6", + "_shasum": "e303a882b342cc3ee8ca513a79999734dab3ae2c", + "_from": "cookie-signature@1.0.6", + "_npmVersion": "2.3.0", + "_nodeVersion": "0.10.36", + "_npmUser": { + "name": "natevw", + "email": "natevw@yahoo.com" + }, + "maintainers": [ + { + "name": "tjholowaychuk", + "email": "tj@vision-media.ca" + }, + { + "name": "natevw", + "email": "natevw@yahoo.com" + } + ], + "dist": { + "shasum": "e303a882b342cc3ee8ca513a79999734dab3ae2c", + "tarball": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/express/node_modules/cookie/HISTORY.md b/node_modules/express/node_modules/cookie/HISTORY.md new file mode 100644 index 0000000..5bd6485 --- /dev/null +++ b/node_modules/express/node_modules/cookie/HISTORY.md @@ -0,0 +1,118 @@ +0.3.1 / 2016-05-26 +================== + + * Fix `sameSite: true` to work with draft-7 clients + - `true` now sends `SameSite=Strict` instead of `SameSite` + +0.3.0 / 2016-05-26 +================== + + * Add `sameSite` option + - Replaces `firstPartyOnly` option, never implemented by browsers + * Improve error message when `encode` is not a function + * Improve error message when `expires` is not a `Date` + +0.2.4 / 2016-05-20 +================== + + * perf: enable strict mode + * perf: use for loop in parse + * perf: use string concatination for serialization + +0.2.3 / 2015-10-25 +================== + + * Fix cookie `Max-Age` to never be a floating point number + +0.2.2 / 2015-09-17 +================== + + * Fix regression when setting empty cookie value + - Ease the new restriction, which is just basic header-level validation + * Fix typo in invalid value errors + +0.2.1 / 2015-09-17 +================== + + * Throw on invalid values provided to `serialize` + - Ensures the resulting string is a valid HTTP header value + +0.2.0 / 2015-08-13 +================== + + * Add `firstPartyOnly` option + * Throw better error for invalid argument to parse + * perf: hoist regular expression + +0.1.5 / 2015-09-17 +================== + + * Fix regression when setting empty cookie value + - Ease the new restriction, which is just basic header-level validation + * Fix typo in invalid value errors + +0.1.4 / 2015-09-17 +================== + + * Throw better error for invalid argument to parse + * Throw on invalid values provided to `serialize` + - Ensures the resulting string is a valid HTTP header value + +0.1.3 / 2015-05-19 +================== + + * Reduce the scope of try-catch deopt + * Remove argument reassignments + +0.1.2 / 2014-04-16 +================== + + * Remove unnecessary files from npm package + +0.1.1 / 2014-02-23 +================== + + * Fix bad parse when cookie value contained a comma + * Fix support for `maxAge` of `0` + +0.1.0 / 2013-05-01 +================== + + * Add `decode` option + * Add `encode` option + +0.0.6 / 2013-04-08 +================== + + * Ignore cookie parts missing `=` + +0.0.5 / 2012-10-29 +================== + + * Return raw cookie value if value unescape errors + +0.0.4 / 2012-06-21 +================== + + * Use encode/decodeURIComponent for cookie encoding/decoding + - Improve server/client interoperability + +0.0.3 / 2012-06-06 +================== + + * Only escape special characters per the cookie RFC + +0.0.2 / 2012-06-01 +================== + + * Fix `maxAge` option to not throw error + +0.0.1 / 2012-05-28 +================== + + * Add more tests + +0.0.0 / 2012-05-28 +================== + + * Initial release diff --git a/node_modules/express/node_modules/cookie/LICENSE b/node_modules/express/node_modules/cookie/LICENSE new file mode 100644 index 0000000..058b6b4 --- /dev/null +++ b/node_modules/express/node_modules/cookie/LICENSE @@ -0,0 +1,24 @@ +(The MIT License) + +Copyright (c) 2012-2014 Roman Shtylman +Copyright (c) 2015 Douglas Christopher Wilson + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + diff --git a/node_modules/express/node_modules/cookie/README.md b/node_modules/express/node_modules/cookie/README.md new file mode 100644 index 0000000..db0d078 --- /dev/null +++ b/node_modules/express/node_modules/cookie/README.md @@ -0,0 +1,220 @@ +# cookie + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Node.js Version][node-version-image]][node-version-url] +[![Build Status][travis-image]][travis-url] +[![Test Coverage][coveralls-image]][coveralls-url] + +Basic HTTP cookie parser and serializer for HTTP servers. + +## Installation + +```sh +$ npm install cookie +``` + +## API + +```js +var cookie = require('cookie'); +``` + +### cookie.parse(str, options) + +Parse an HTTP `Cookie` header string and returning an object of all cookie name-value pairs. +The `str` argument is the string representing a `Cookie` header value and `options` is an +optional object containing additional parsing options. + +```js +var cookies = cookie.parse('foo=bar; equation=E%3Dmc%5E2'); +// { foo: 'bar', equation: 'E=mc^2' } +``` + +#### Options + +`cookie.parse` accepts these properties in the options object. + +##### decode + +Specifies a function that will be used to decode a cookie's value. Since the value of a cookie +has a limited character set (and must be a simple string), this function can be used to decode +a previously-encoded cookie value into a JavaScript string or other object. + +The default function is the global `decodeURIComponent`, which will decode any URL-encoded +sequences into their byte representations. + +**note** if an error is thrown from this function, the original, non-decoded cookie value will +be returned as the cookie's value. + +### cookie.serialize(name, value, options) + +Serialize a cookie name-value pair into a `Set-Cookie` header string. The `name` argument is the +name for the cookie, the `value` argument is the value to set the cookie to, and the `options` +argument is an optional object containing additional serialization options. + +```js +var setCookie = cookie.serialize('foo', 'bar'); +// foo=bar +``` + +#### Options + +`cookie.serialize` accepts these properties in the options object. + +##### domain + +Specifies the value for the [`Domain` `Set-Cookie` attribute][rfc-6266-5.2.3]. By default, no +domain is set, and most clients will consider the cookie to apply to only the current domain. + +##### encode + +Specifies a function that will be used to encode a cookie's value. Since value of a cookie +has a limited character set (and must be a simple string), this function can be used to encode +a value into a string suited for a cookie's value. + +The default function is the global `ecodeURIComponent`, which will encode a JavaScript string +into UTF-8 byte sequences and then URL-encode any that fall outside of the cookie range. + +##### expires + +Specifies the `Date` object to be the value for the [`Expires` `Set-Cookie` attribute][rfc-6266-5.2.1]. +By default, no expiration is set, and most clients will consider this a "non-persistent cookie" and +will delete it on a condition like exiting a web browser application. + +**note** the [cookie storage model specification][rfc-6266-5.3] states that if both `expires` and +`magAge` are set, then `maxAge` takes precedence, but it is possiblke not all clients by obey this, +so if both are set, they should point to the same date and time. + +##### httpOnly + +Specifies the `boolean` value for the [`HttpOnly` `Set-Cookie` attribute][rfc-6266-5.2.6]. When truthy, +the `HttpOnly` attribute is set, otherwise it is not. By default, the `HttpOnly` attribute is not set. + +**note** be careful when setting this to `true`, as compliant clients will not allow client-side +JavaScript to see the cookie in `document.cookie`. + +##### maxAge + +Specifies the `number` (in seconds) to be the value for the [`Max-Age` `Set-Cookie` attribute][rfc-6266-5.2.2]. +The given number will be converted to an integer by rounding down. By default, no maximum age is set. + +**note** the [cookie storage model specification][rfc-6266-5.3] states that if both `expires` and +`magAge` are set, then `maxAge` takes precedence, but it is possiblke not all clients by obey this, +so if both are set, they should point to the same date and time. + +##### path + +Specifies the value for the [`Path` `Set-Cookie` attribute][rfc-6266-5.2.4]. By default, the path +is considered the ["default path"][rfc-6266-5.1.4]. By default, no maximum age is set, and most +clients will consider this a "non-persistent cookie" and will delete it on a condition like exiting +a web browser application. + +##### sameSite + +Specifies the `boolean` or `string` to be the value for the [`SameSite` `Set-Cookie` attribute][draft-west-first-party-cookies-07]. + + - `true` will set the `SameSite` attribute to `Strict` for strict same site enforcement. + - `false` will not set the `SameSite` attribute. + - `'lax'` will set the `SameSite` attribute to `Lax` for lax same site enforcement. + - `'strict'` will set the `SameSite` attribute to `Strict` for strict same site enforcement. + +More information about the different enforcement levels can be found in the specification +https://tools.ietf.org/html/draft-west-first-party-cookies-07#section-4.1.1 + +**note** This is an attribute that has not yet been fully standardized, and may change in the future. +This also means many clients may ignore this attribute until they understand it. + +##### secure + +Specifies the `boolean` value for the [`Secure` `Set-Cookie` attribute][rfc-6266-5.2.5]. When truthy, +the `Secure` attribute is set, otherwise it is not. By default, the `Secure` attribute is not set. + +**note** be careful when setting this to `true`, as compliant clients will not send the cookie back to +the server in the future if the browser does not have an HTTPS connection. + +## Example + +The following example uses this module in conjunction with the Node.js core HTTP server +to prompt a user for their name and display it back on future visits. + +```js +var cookie = require('cookie'); +var escapeHtml = require('escape-html'); +var http = require('http'); +var url = require('url'); + +function onRequest(req, res) { + // Parse the query string + var query = url.parse(req.url, true, true).query; + + if (query && query.name) { + // Set a new cookie with the name + res.setHeader('Set-Cookie', cookie.serialize('name', String(query.name), { + httpOnly: true, + maxAge: 60 * 60 * 24 * 7 // 1 week + })); + + // Redirect back after setting cookie + res.statusCode = 302; + res.setHeader('Location', req.headers.referer || '/'); + res.end(); + return; + } + + // Parse the cookies on the request + var cookies = cookie.parse(req.headers.cookie || ''); + + // Get the visitor name set in the cookie + var name = cookies.name; + + res.setHeader('Content-Type', 'text/html; charset=UTF-8'); + + if (name) { + res.write('

Welcome back, ' + escapeHtml(name) + '!

'); + } else { + res.write('

Hello, new visitor!

'); + } + + res.write(''); + res.write(' '); + res.end(' values + * + * @param {string} str + * @param {object} [options] + * @return {object} + * @public + */ + +function parse(str, options) { + if (typeof str !== 'string') { + throw new TypeError('argument str must be a string'); + } + + var obj = {} + var opt = options || {}; + var pairs = str.split(pairSplitRegExp); + var dec = opt.decode || decode; + + for (var i = 0; i < pairs.length; i++) { + var pair = pairs[i]; + var eq_idx = pair.indexOf('='); + + // skip things that don't look like key=value + if (eq_idx < 0) { + continue; + } + + var key = pair.substr(0, eq_idx).trim() + var val = pair.substr(++eq_idx, pair.length).trim(); + + // quoted values + if ('"' == val[0]) { + val = val.slice(1, -1); + } + + // only assign once + if (undefined == obj[key]) { + obj[key] = tryDecode(val, dec); + } + } + + return obj; +} + +/** + * Serialize data into a cookie header. + * + * Serialize the a name value pair into a cookie string suitable for + * http headers. An optional options object specified cookie parameters. + * + * serialize('foo', 'bar', { httpOnly: true }) + * => "foo=bar; httpOnly" + * + * @param {string} name + * @param {string} val + * @param {object} [options] + * @return {string} + * @public + */ + +function serialize(name, val, options) { + var opt = options || {}; + var enc = opt.encode || encode; + + if (typeof enc !== 'function') { + throw new TypeError('option encode is invalid'); + } + + if (!fieldContentRegExp.test(name)) { + throw new TypeError('argument name is invalid'); + } + + var value = enc(val); + + if (value && !fieldContentRegExp.test(value)) { + throw new TypeError('argument val is invalid'); + } + + var str = name + '=' + value; + + if (null != opt.maxAge) { + var maxAge = opt.maxAge - 0; + if (isNaN(maxAge)) throw new Error('maxAge should be a Number'); + str += '; Max-Age=' + Math.floor(maxAge); + } + + if (opt.domain) { + if (!fieldContentRegExp.test(opt.domain)) { + throw new TypeError('option domain is invalid'); + } + + str += '; Domain=' + opt.domain; + } + + if (opt.path) { + if (!fieldContentRegExp.test(opt.path)) { + throw new TypeError('option path is invalid'); + } + + str += '; Path=' + opt.path; + } + + if (opt.expires) { + if (typeof opt.expires.toUTCString !== 'function') { + throw new TypeError('option expires is invalid'); + } + + str += '; Expires=' + opt.expires.toUTCString(); + } + + if (opt.httpOnly) { + str += '; HttpOnly'; + } + + if (opt.secure) { + str += '; Secure'; + } + + if (opt.sameSite) { + var sameSite = typeof opt.sameSite === 'string' + ? opt.sameSite.toLowerCase() : opt.sameSite; + + switch (sameSite) { + case true: + str += '; SameSite=Strict'; + break; + case 'lax': + str += '; SameSite=Lax'; + break; + case 'strict': + str += '; SameSite=Strict'; + break; + default: + throw new TypeError('option sameSite is invalid'); + } + } + + return str; +} + +/** + * Try decoding a string using a decoding function. + * + * @param {string} str + * @param {function} decode + * @private + */ + +function tryDecode(str, decode) { + try { + return decode(str); + } catch (e) { + return str; + } +} diff --git a/node_modules/express/node_modules/cookie/package.json b/node_modules/express/node_modules/cookie/package.json new file mode 100644 index 0000000..4a084e0 --- /dev/null +++ b/node_modules/express/node_modules/cookie/package.json @@ -0,0 +1,72 @@ +{ + "name": "cookie", + "description": "HTTP server cookie parsing and serialization", + "version": "0.3.1", + "author": { + "name": "Roman Shtylman", + "email": "shtylman@gmail.com" + }, + "contributors": [ + { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + } + ], + "license": "MIT", + "keywords": [ + "cookie", + "cookies" + ], + "repository": { + "type": "git", + "url": "git+https://github.com/jshttp/cookie.git" + }, + "devDependencies": { + "istanbul": "0.4.3", + "mocha": "1.21.5" + }, + "files": [ + "HISTORY.md", + "LICENSE", + "README.md", + "index.js" + ], + "engines": { + "node": ">= 0.6" + }, + "scripts": { + "test": "mocha --reporter spec --bail --check-leaks test/", + "test-ci": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter spec --check-leaks test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot --check-leaks test/" + }, + "gitHead": "e3c77d497d66c8b8d4b677b8954c1b192a09f0b3", + "bugs": { + "url": "https://github.com/jshttp/cookie/issues" + }, + "homepage": "https://github.com/jshttp/cookie", + "_id": "cookie@0.3.1", + "_shasum": "e7e0a1f9ef43b4c8ba925c5c5a96e806d16873bb", + "_from": "cookie@0.3.1", + "_npmVersion": "1.4.28", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "maintainers": [ + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + } + ], + "dist": { + "shasum": "e7e0a1f9ef43b4c8ba925c5c5a96e806d16873bb", + "tarball": "https://registry.npmjs.org/cookie/-/cookie-0.3.1.tgz" + }, + "_npmOperationalInternal": { + "host": "packages-12-west.internal.npmjs.com", + "tmp": "tmp/cookie-0.3.1.tgz_1464323556714_0.6435900838114321" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/cookie/-/cookie-0.3.1.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/express/node_modules/debug/.jshintrc b/node_modules/express/node_modules/debug/.jshintrc new file mode 100644 index 0000000..299877f --- /dev/null +++ b/node_modules/express/node_modules/debug/.jshintrc @@ -0,0 +1,3 @@ +{ + "laxbreak": true +} diff --git a/node_modules/express/node_modules/debug/.npmignore b/node_modules/express/node_modules/debug/.npmignore new file mode 100644 index 0000000..7e6163d --- /dev/null +++ b/node_modules/express/node_modules/debug/.npmignore @@ -0,0 +1,6 @@ +support +test +examples +example +*.sock +dist diff --git a/node_modules/express/node_modules/debug/History.md b/node_modules/express/node_modules/debug/History.md new file mode 100644 index 0000000..854c971 --- /dev/null +++ b/node_modules/express/node_modules/debug/History.md @@ -0,0 +1,195 @@ + +2.2.0 / 2015-05-09 +================== + + * package: update "ms" to v0.7.1 (#202, @dougwilson) + * README: add logging to file example (#193, @DanielOchoa) + * README: fixed a typo (#191, @amir-s) + * browser: expose `storage` (#190, @stephenmathieson) + * Makefile: add a `distclean` target (#189, @stephenmathieson) + +2.1.3 / 2015-03-13 +================== + + * Updated stdout/stderr example (#186) + * Updated example/stdout.js to match debug current behaviour + * Renamed example/stderr.js to stdout.js + * Update Readme.md (#184) + * replace high intensity foreground color for bold (#182, #183) + +2.1.2 / 2015-03-01 +================== + + * dist: recompile + * update "ms" to v0.7.0 + * package: update "browserify" to v9.0.3 + * component: fix "ms.js" repo location + * changed bower package name + * updated documentation about using debug in a browser + * fix: security error on safari (#167, #168, @yields) + +2.1.1 / 2014-12-29 +================== + + * browser: use `typeof` to check for `console` existence + * browser: check for `console.log` truthiness (fix IE 8/9) + * browser: add support for Chrome apps + * Readme: added Windows usage remarks + * Add `bower.json` to properly support bower install + +2.1.0 / 2014-10-15 +================== + + * node: implement `DEBUG_FD` env variable support + * package: update "browserify" to v6.1.0 + * package: add "license" field to package.json (#135, @panuhorsmalahti) + +2.0.0 / 2014-09-01 +================== + + * package: update "browserify" to v5.11.0 + * node: use stderr rather than stdout for logging (#29, @stephenmathieson) + +1.0.4 / 2014-07-15 +================== + + * dist: recompile + * example: remove `console.info()` log usage + * example: add "Content-Type" UTF-8 header to browser example + * browser: place %c marker after the space character + * browser: reset the "content" color via `color: inherit` + * browser: add colors support for Firefox >= v31 + * debug: prefer an instance `log()` function over the global one (#119) + * Readme: update documentation about styled console logs for FF v31 (#116, @wryk) + +1.0.3 / 2014-07-09 +================== + + * Add support for multiple wildcards in namespaces (#122, @seegno) + * browser: fix lint + +1.0.2 / 2014-06-10 +================== + + * browser: update color palette (#113, @gscottolson) + * common: make console logging function configurable (#108, @timoxley) + * node: fix %o colors on old node <= 0.8.x + * Makefile: find node path using shell/which (#109, @timoxley) + +1.0.1 / 2014-06-06 +================== + + * browser: use `removeItem()` to clear localStorage + * browser, node: don't set DEBUG if namespaces is undefined (#107, @leedm777) + * package: add "contributors" section + * node: fix comment typo + * README: list authors + +1.0.0 / 2014-06-04 +================== + + * make ms diff be global, not be scope + * debug: ignore empty strings in enable() + * node: make DEBUG_COLORS able to disable coloring + * *: export the `colors` array + * npmignore: don't publish the `dist` dir + * Makefile: refactor to use browserify + * package: add "browserify" as a dev dependency + * Readme: add Web Inspector Colors section + * node: reset terminal color for the debug content + * node: map "%o" to `util.inspect()` + * browser: map "%j" to `JSON.stringify()` + * debug: add custom "formatters" + * debug: use "ms" module for humanizing the diff + * Readme: add "bash" syntax highlighting + * browser: add Firebug color support + * browser: add colors for WebKit browsers + * node: apply log to `console` + * rewrite: abstract common logic for Node & browsers + * add .jshintrc file + +0.8.1 / 2014-04-14 +================== + + * package: re-add the "component" section + +0.8.0 / 2014-03-30 +================== + + * add `enable()` method for nodejs. Closes #27 + * change from stderr to stdout + * remove unnecessary index.js file + +0.7.4 / 2013-11-13 +================== + + * remove "browserify" key from package.json (fixes something in browserify) + +0.7.3 / 2013-10-30 +================== + + * fix: catch localStorage security error when cookies are blocked (Chrome) + * add debug(err) support. Closes #46 + * add .browser prop to package.json. Closes #42 + +0.7.2 / 2013-02-06 +================== + + * fix package.json + * fix: Mobile Safari (private mode) is broken with debug + * fix: Use unicode to send escape character to shell instead of octal to work with strict mode javascript + +0.7.1 / 2013-02-05 +================== + + * add repository URL to package.json + * add DEBUG_COLORED to force colored output + * add browserify support + * fix component. Closes #24 + +0.7.0 / 2012-05-04 +================== + + * Added .component to package.json + * Added debug.component.js build + +0.6.0 / 2012-03-16 +================== + + * Added support for "-" prefix in DEBUG [Vinay Pulim] + * Added `.enabled` flag to the node version [TooTallNate] + +0.5.0 / 2012-02-02 +================== + + * Added: humanize diffs. Closes #8 + * Added `debug.disable()` to the CS variant + * Removed padding. Closes #10 + * Fixed: persist client-side variant again. Closes #9 + +0.4.0 / 2012-02-01 +================== + + * Added browser variant support for older browsers [TooTallNate] + * Added `debug.enable('project:*')` to browser variant [TooTallNate] + * Added padding to diff (moved it to the right) + +0.3.0 / 2012-01-26 +================== + + * Added millisecond diff when isatty, otherwise UTC string + +0.2.0 / 2012-01-22 +================== + + * Added wildcard support + +0.1.0 / 2011-12-02 +================== + + * Added: remove colors unless stderr isatty [TooTallNate] + +0.0.1 / 2010-01-03 +================== + + * Initial release diff --git a/node_modules/express/node_modules/debug/Makefile b/node_modules/express/node_modules/debug/Makefile new file mode 100644 index 0000000..5cf4a59 --- /dev/null +++ b/node_modules/express/node_modules/debug/Makefile @@ -0,0 +1,36 @@ + +# get Makefile directory name: http://stackoverflow.com/a/5982798/376773 +THIS_MAKEFILE_PATH:=$(word $(words $(MAKEFILE_LIST)),$(MAKEFILE_LIST)) +THIS_DIR:=$(shell cd $(dir $(THIS_MAKEFILE_PATH));pwd) + +# BIN directory +BIN := $(THIS_DIR)/node_modules/.bin + +# applications +NODE ?= $(shell which node) +NPM ?= $(NODE) $(shell which npm) +BROWSERIFY ?= $(NODE) $(BIN)/browserify + +all: dist/debug.js + +install: node_modules + +clean: + @rm -rf dist + +dist: + @mkdir -p $@ + +dist/debug.js: node_modules browser.js debug.js dist + @$(BROWSERIFY) \ + --standalone debug \ + . > $@ + +distclean: clean + @rm -rf node_modules + +node_modules: package.json + @NODE_ENV= $(NPM) install + @touch node_modules + +.PHONY: all install clean distclean diff --git a/node_modules/express/node_modules/debug/Readme.md b/node_modules/express/node_modules/debug/Readme.md new file mode 100644 index 0000000..b4f45e3 --- /dev/null +++ b/node_modules/express/node_modules/debug/Readme.md @@ -0,0 +1,188 @@ +# debug + + tiny node.js debugging utility modelled after node core's debugging technique. + +## Installation + +```bash +$ npm install debug +``` + +## Usage + + With `debug` you simply invoke the exported function to generate your debug function, passing it a name which will determine if a noop function is returned, or a decorated `console.error`, so all of the `console` format string goodies you're used to work fine. A unique color is selected per-function for visibility. + +Example _app.js_: + +```js +var debug = require('debug')('http') + , http = require('http') + , name = 'My App'; + +// fake app + +debug('booting %s', name); + +http.createServer(function(req, res){ + debug(req.method + ' ' + req.url); + res.end('hello\n'); +}).listen(3000, function(){ + debug('listening'); +}); + +// fake worker of some kind + +require('./worker'); +``` + +Example _worker.js_: + +```js +var debug = require('debug')('worker'); + +setInterval(function(){ + debug('doing some work'); +}, 1000); +``` + + The __DEBUG__ environment variable is then used to enable these based on space or comma-delimited names. Here are some examples: + + ![debug http and worker](http://f.cl.ly/items/18471z1H402O24072r1J/Screenshot.png) + + ![debug worker](http://f.cl.ly/items/1X413v1a3M0d3C2c1E0i/Screenshot.png) + +#### Windows note + + On Windows the environment variable is set using the `set` command. + + ```cmd + set DEBUG=*,-not_this + ``` + +Then, run the program to be debugged as usual. + +## Millisecond diff + + When actively developing an application it can be useful to see when the time spent between one `debug()` call and the next. Suppose for example you invoke `debug()` before requesting a resource, and after as well, the "+NNNms" will show you how much time was spent between calls. + + ![](http://f.cl.ly/items/2i3h1d3t121M2Z1A3Q0N/Screenshot.png) + + When stdout is not a TTY, `Date#toUTCString()` is used, making it more useful for logging the debug information as shown below: + + ![](http://f.cl.ly/items/112H3i0e0o0P0a2Q2r11/Screenshot.png) + +## Conventions + + If you're using this in one or more of your libraries, you _should_ use the name of your library so that developers may toggle debugging as desired without guessing names. If you have more than one debuggers you _should_ prefix them with your library name and use ":" to separate features. For example "bodyParser" from Connect would then be "connect:bodyParser". + +## Wildcards + + The `*` character may be used as a wildcard. Suppose for example your library has debuggers named "connect:bodyParser", "connect:compress", "connect:session", instead of listing all three with `DEBUG=connect:bodyParser,connect:compress,connect:session`, you may simply do `DEBUG=connect:*`, or to run everything using this module simply use `DEBUG=*`. + + You can also exclude specific debuggers by prefixing them with a "-" character. For example, `DEBUG=*,-connect:*` would include all debuggers except those starting with "connect:". + +## Browser support + + Debug works in the browser as well, currently persisted by `localStorage`. Consider the situation shown below where you have `worker:a` and `worker:b`, and wish to debug both. Somewhere in the code on your page, include: + +```js +window.myDebug = require("debug"); +``` + + ("debug" is a global object in the browser so we give this object a different name.) When your page is open in the browser, type the following in the console: + +```js +myDebug.enable("worker:*") +``` + + Refresh the page. Debug output will continue to be sent to the console until it is disabled by typing `myDebug.disable()` in the console. + +```js +a = debug('worker:a'); +b = debug('worker:b'); + +setInterval(function(){ + a('doing some work'); +}, 1000); + +setInterval(function(){ + b('doing some work'); +}, 1200); +``` + +#### Web Inspector Colors + + Colors are also enabled on "Web Inspectors" that understand the `%c` formatting + option. These are WebKit web inspectors, Firefox ([since version + 31](https://hacks.mozilla.org/2014/05/editable-box-model-multiple-selection-sublime-text-keys-much-more-firefox-developer-tools-episode-31/)) + and the Firebug plugin for Firefox (any version). + + Colored output looks something like: + + ![](https://cloud.githubusercontent.com/assets/71256/3139768/b98c5fd8-e8ef-11e3-862a-f7253b6f47c6.png) + +### stderr vs stdout + +You can set an alternative logging method per-namespace by overriding the `log` method on a per-namespace or globally: + +Example _stdout.js_: + +```js +var debug = require('debug'); +var error = debug('app:error'); + +// by default stderr is used +error('goes to stderr!'); + +var log = debug('app:log'); +// set this namespace to log via console.log +log.log = console.log.bind(console); // don't forget to bind to console! +log('goes to stdout'); +error('still goes to stderr!'); + +// set all output to go via console.info +// overrides all per-namespace log settings +debug.log = console.info.bind(console); +error('now goes to stdout via console.info'); +log('still goes to stdout, but via console.info now'); +``` + +### Save debug output to a file + +You can save all debug statements to a file by piping them. + +Example: + +```bash +$ DEBUG_FD=3 node your-app.js 3> whatever.log +``` + +## Authors + + - TJ Holowaychuk + - Nathan Rajlich + +## License + +(The MIT License) + +Copyright (c) 2014 TJ Holowaychuk <tj@vision-media.ca> + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/express/node_modules/debug/bower.json b/node_modules/express/node_modules/debug/bower.json new file mode 100644 index 0000000..6af573f --- /dev/null +++ b/node_modules/express/node_modules/debug/bower.json @@ -0,0 +1,28 @@ +{ + "name": "visionmedia-debug", + "main": "dist/debug.js", + "version": "2.2.0", + "homepage": "https://github.com/visionmedia/debug", + "authors": [ + "TJ Holowaychuk " + ], + "description": "visionmedia-debug", + "moduleType": [ + "amd", + "es6", + "globals", + "node" + ], + "keywords": [ + "visionmedia", + "debug" + ], + "license": "MIT", + "ignore": [ + "**/.*", + "node_modules", + "bower_components", + "test", + "tests" + ] +} diff --git a/node_modules/express/node_modules/debug/browser.js b/node_modules/express/node_modules/debug/browser.js new file mode 100644 index 0000000..7c76452 --- /dev/null +++ b/node_modules/express/node_modules/debug/browser.js @@ -0,0 +1,168 @@ + +/** + * This is the web browser implementation of `debug()`. + * + * Expose `debug()` as the module. + */ + +exports = module.exports = require('./debug'); +exports.log = log; +exports.formatArgs = formatArgs; +exports.save = save; +exports.load = load; +exports.useColors = useColors; +exports.storage = 'undefined' != typeof chrome + && 'undefined' != typeof chrome.storage + ? chrome.storage.local + : localstorage(); + +/** + * Colors. + */ + +exports.colors = [ + 'lightseagreen', + 'forestgreen', + 'goldenrod', + 'dodgerblue', + 'darkorchid', + 'crimson' +]; + +/** + * Currently only WebKit-based Web Inspectors, Firefox >= v31, + * and the Firebug extension (any Firefox version) are known + * to support "%c" CSS customizations. + * + * TODO: add a `localStorage` variable to explicitly enable/disable colors + */ + +function useColors() { + // is webkit? http://stackoverflow.com/a/16459606/376773 + return ('WebkitAppearance' in document.documentElement.style) || + // is firebug? http://stackoverflow.com/a/398120/376773 + (window.console && (console.firebug || (console.exception && console.table))) || + // is firefox >= v31? + // https://developer.mozilla.org/en-US/docs/Tools/Web_Console#Styling_messages + (navigator.userAgent.toLowerCase().match(/firefox\/(\d+)/) && parseInt(RegExp.$1, 10) >= 31); +} + +/** + * Map %j to `JSON.stringify()`, since no Web Inspectors do that by default. + */ + +exports.formatters.j = function(v) { + return JSON.stringify(v); +}; + + +/** + * Colorize log arguments if enabled. + * + * @api public + */ + +function formatArgs() { + var args = arguments; + var useColors = this.useColors; + + args[0] = (useColors ? '%c' : '') + + this.namespace + + (useColors ? ' %c' : ' ') + + args[0] + + (useColors ? '%c ' : ' ') + + '+' + exports.humanize(this.diff); + + if (!useColors) return args; + + var c = 'color: ' + this.color; + args = [args[0], c, 'color: inherit'].concat(Array.prototype.slice.call(args, 1)); + + // the final "%c" is somewhat tricky, because there could be other + // arguments passed either before or after the %c, so we need to + // figure out the correct index to insert the CSS into + var index = 0; + var lastC = 0; + args[0].replace(/%[a-z%]/g, function(match) { + if ('%%' === match) return; + index++; + if ('%c' === match) { + // we only are interested in the *last* %c + // (the user may have provided their own) + lastC = index; + } + }); + + args.splice(lastC, 0, c); + return args; +} + +/** + * Invokes `console.log()` when available. + * No-op when `console.log` is not a "function". + * + * @api public + */ + +function log() { + // this hackery is required for IE8/9, where + // the `console.log` function doesn't have 'apply' + return 'object' === typeof console + && console.log + && Function.prototype.apply.call(console.log, console, arguments); +} + +/** + * Save `namespaces`. + * + * @param {String} namespaces + * @api private + */ + +function save(namespaces) { + try { + if (null == namespaces) { + exports.storage.removeItem('debug'); + } else { + exports.storage.debug = namespaces; + } + } catch(e) {} +} + +/** + * Load `namespaces`. + * + * @return {String} returns the previously persisted debug modes + * @api private + */ + +function load() { + var r; + try { + r = exports.storage.debug; + } catch(e) {} + return r; +} + +/** + * Enable namespaces listed in `localStorage.debug` initially. + */ + +exports.enable(load()); + +/** + * Localstorage attempts to return the localstorage. + * + * This is necessary because safari throws + * when a user disables cookies/localstorage + * and you attempt to access it. + * + * @return {LocalStorage} + * @api private + */ + +function localstorage(){ + try { + return window.localStorage; + } catch (e) {} +} diff --git a/node_modules/express/node_modules/debug/component.json b/node_modules/express/node_modules/debug/component.json new file mode 100644 index 0000000..ca10637 --- /dev/null +++ b/node_modules/express/node_modules/debug/component.json @@ -0,0 +1,19 @@ +{ + "name": "debug", + "repo": "visionmedia/debug", + "description": "small debugging utility", + "version": "2.2.0", + "keywords": [ + "debug", + "log", + "debugger" + ], + "main": "browser.js", + "scripts": [ + "browser.js", + "debug.js" + ], + "dependencies": { + "rauchg/ms.js": "0.7.1" + } +} diff --git a/node_modules/express/node_modules/debug/debug.js b/node_modules/express/node_modules/debug/debug.js new file mode 100644 index 0000000..7571a86 --- /dev/null +++ b/node_modules/express/node_modules/debug/debug.js @@ -0,0 +1,197 @@ + +/** + * This is the common logic for both the Node.js and web browser + * implementations of `debug()`. + * + * Expose `debug()` as the module. + */ + +exports = module.exports = debug; +exports.coerce = coerce; +exports.disable = disable; +exports.enable = enable; +exports.enabled = enabled; +exports.humanize = require('ms'); + +/** + * The currently active debug mode names, and names to skip. + */ + +exports.names = []; +exports.skips = []; + +/** + * Map of special "%n" handling functions, for the debug "format" argument. + * + * Valid key names are a single, lowercased letter, i.e. "n". + */ + +exports.formatters = {}; + +/** + * Previously assigned color. + */ + +var prevColor = 0; + +/** + * Previous log timestamp. + */ + +var prevTime; + +/** + * Select a color. + * + * @return {Number} + * @api private + */ + +function selectColor() { + return exports.colors[prevColor++ % exports.colors.length]; +} + +/** + * Create a debugger with the given `namespace`. + * + * @param {String} namespace + * @return {Function} + * @api public + */ + +function debug(namespace) { + + // define the `disabled` version + function disabled() { + } + disabled.enabled = false; + + // define the `enabled` version + function enabled() { + + var self = enabled; + + // set `diff` timestamp + var curr = +new Date(); + var ms = curr - (prevTime || curr); + self.diff = ms; + self.prev = prevTime; + self.curr = curr; + prevTime = curr; + + // add the `color` if not set + if (null == self.useColors) self.useColors = exports.useColors(); + if (null == self.color && self.useColors) self.color = selectColor(); + + var args = Array.prototype.slice.call(arguments); + + args[0] = exports.coerce(args[0]); + + if ('string' !== typeof args[0]) { + // anything else let's inspect with %o + args = ['%o'].concat(args); + } + + // apply any `formatters` transformations + var index = 0; + args[0] = args[0].replace(/%([a-z%])/g, function(match, format) { + // if we encounter an escaped % then don't increase the array index + if (match === '%%') return match; + index++; + var formatter = exports.formatters[format]; + if ('function' === typeof formatter) { + var val = args[index]; + match = formatter.call(self, val); + + // now we need to remove `args[index]` since it's inlined in the `format` + args.splice(index, 1); + index--; + } + return match; + }); + + if ('function' === typeof exports.formatArgs) { + args = exports.formatArgs.apply(self, args); + } + var logFn = enabled.log || exports.log || console.log.bind(console); + logFn.apply(self, args); + } + enabled.enabled = true; + + var fn = exports.enabled(namespace) ? enabled : disabled; + + fn.namespace = namespace; + + return fn; +} + +/** + * Enables a debug mode by namespaces. This can include modes + * separated by a colon and wildcards. + * + * @param {String} namespaces + * @api public + */ + +function enable(namespaces) { + exports.save(namespaces); + + var split = (namespaces || '').split(/[\s,]+/); + var len = split.length; + + for (var i = 0; i < len; i++) { + if (!split[i]) continue; // ignore empty strings + namespaces = split[i].replace(/\*/g, '.*?'); + if (namespaces[0] === '-') { + exports.skips.push(new RegExp('^' + namespaces.substr(1) + '$')); + } else { + exports.names.push(new RegExp('^' + namespaces + '$')); + } + } +} + +/** + * Disable debug output. + * + * @api public + */ + +function disable() { + exports.enable(''); +} + +/** + * Returns true if the given mode name is enabled, false otherwise. + * + * @param {String} name + * @return {Boolean} + * @api public + */ + +function enabled(name) { + var i, len; + for (i = 0, len = exports.skips.length; i < len; i++) { + if (exports.skips[i].test(name)) { + return false; + } + } + for (i = 0, len = exports.names.length; i < len; i++) { + if (exports.names[i].test(name)) { + return true; + } + } + return false; +} + +/** + * Coerce `val`. + * + * @param {Mixed} val + * @return {Mixed} + * @api private + */ + +function coerce(val) { + if (val instanceof Error) return val.stack || val.message; + return val; +} diff --git a/node_modules/express/node_modules/debug/node.js b/node_modules/express/node_modules/debug/node.js new file mode 100644 index 0000000..1d392a8 --- /dev/null +++ b/node_modules/express/node_modules/debug/node.js @@ -0,0 +1,209 @@ + +/** + * Module dependencies. + */ + +var tty = require('tty'); +var util = require('util'); + +/** + * This is the Node.js implementation of `debug()`. + * + * Expose `debug()` as the module. + */ + +exports = module.exports = require('./debug'); +exports.log = log; +exports.formatArgs = formatArgs; +exports.save = save; +exports.load = load; +exports.useColors = useColors; + +/** + * Colors. + */ + +exports.colors = [6, 2, 3, 4, 5, 1]; + +/** + * The file descriptor to write the `debug()` calls to. + * Set the `DEBUG_FD` env variable to override with another value. i.e.: + * + * $ DEBUG_FD=3 node script.js 3>debug.log + */ + +var fd = parseInt(process.env.DEBUG_FD, 10) || 2; +var stream = 1 === fd ? process.stdout : + 2 === fd ? process.stderr : + createWritableStdioStream(fd); + +/** + * Is stdout a TTY? Colored output is enabled when `true`. + */ + +function useColors() { + var debugColors = (process.env.DEBUG_COLORS || '').trim().toLowerCase(); + if (0 === debugColors.length) { + return tty.isatty(fd); + } else { + return '0' !== debugColors + && 'no' !== debugColors + && 'false' !== debugColors + && 'disabled' !== debugColors; + } +} + +/** + * Map %o to `util.inspect()`, since Node doesn't do that out of the box. + */ + +var inspect = (4 === util.inspect.length ? + // node <= 0.8.x + function (v, colors) { + return util.inspect(v, void 0, void 0, colors); + } : + // node > 0.8.x + function (v, colors) { + return util.inspect(v, { colors: colors }); + } +); + +exports.formatters.o = function(v) { + return inspect(v, this.useColors) + .replace(/\s*\n\s*/g, ' '); +}; + +/** + * Adds ANSI color escape codes if enabled. + * + * @api public + */ + +function formatArgs() { + var args = arguments; + var useColors = this.useColors; + var name = this.namespace; + + if (useColors) { + var c = this.color; + + args[0] = ' \u001b[3' + c + ';1m' + name + ' ' + + '\u001b[0m' + + args[0] + '\u001b[3' + c + 'm' + + ' +' + exports.humanize(this.diff) + '\u001b[0m'; + } else { + args[0] = new Date().toUTCString() + + ' ' + name + ' ' + args[0]; + } + return args; +} + +/** + * Invokes `console.error()` with the specified arguments. + */ + +function log() { + return stream.write(util.format.apply(this, arguments) + '\n'); +} + +/** + * Save `namespaces`. + * + * @param {String} namespaces + * @api private + */ + +function save(namespaces) { + if (null == namespaces) { + // If you set a process.env field to null or undefined, it gets cast to the + // string 'null' or 'undefined'. Just delete instead. + delete process.env.DEBUG; + } else { + process.env.DEBUG = namespaces; + } +} + +/** + * Load `namespaces`. + * + * @return {String} returns the previously persisted debug modes + * @api private + */ + +function load() { + return process.env.DEBUG; +} + +/** + * Copied from `node/src/node.js`. + * + * XXX: It's lame that node doesn't expose this API out-of-the-box. It also + * relies on the undocumented `tty_wrap.guessHandleType()` which is also lame. + */ + +function createWritableStdioStream (fd) { + var stream; + var tty_wrap = process.binding('tty_wrap'); + + // Note stream._type is used for test-module-load-list.js + + switch (tty_wrap.guessHandleType(fd)) { + case 'TTY': + stream = new tty.WriteStream(fd); + stream._type = 'tty'; + + // Hack to have stream not keep the event loop alive. + // See https://github.com/joyent/node/issues/1726 + if (stream._handle && stream._handle.unref) { + stream._handle.unref(); + } + break; + + case 'FILE': + var fs = require('fs'); + stream = new fs.SyncWriteStream(fd, { autoClose: false }); + stream._type = 'fs'; + break; + + case 'PIPE': + case 'TCP': + var net = require('net'); + stream = new net.Socket({ + fd: fd, + readable: false, + writable: true + }); + + // FIXME Should probably have an option in net.Socket to create a + // stream from an existing fd which is writable only. But for now + // we'll just add this hack and set the `readable` member to false. + // Test: ./node test/fixtures/echo.js < /etc/passwd + stream.readable = false; + stream.read = null; + stream._type = 'pipe'; + + // FIXME Hack to have stream not keep the event loop alive. + // See https://github.com/joyent/node/issues/1726 + if (stream._handle && stream._handle.unref) { + stream._handle.unref(); + } + break; + + default: + // Probably an error on in uv_guess_handle() + throw new Error('Implement me. Unknown stream file type!'); + } + + // For supporting legacy API we put the FD here. + stream.fd = fd; + + stream._isStdio = true; + + return stream; +} + +/** + * Enable namespaces listed in `process.env.DEBUG` initially. + */ + +exports.enable(load()); diff --git a/node_modules/express/node_modules/debug/node_modules/ms/.npmignore b/node_modules/express/node_modules/debug/node_modules/ms/.npmignore new file mode 100644 index 0000000..d1aa0ce --- /dev/null +++ b/node_modules/express/node_modules/debug/node_modules/ms/.npmignore @@ -0,0 +1,5 @@ +node_modules +test +History.md +Makefile +component.json diff --git a/node_modules/express/node_modules/debug/node_modules/ms/History.md b/node_modules/express/node_modules/debug/node_modules/ms/History.md new file mode 100644 index 0000000..32fdfc1 --- /dev/null +++ b/node_modules/express/node_modules/debug/node_modules/ms/History.md @@ -0,0 +1,66 @@ + +0.7.1 / 2015-04-20 +================== + + * prevent extraordinary long inputs (@evilpacket) + * Fixed broken readme link + +0.7.0 / 2014-11-24 +================== + + * add time abbreviations, updated tests and readme for the new units + * fix example in the readme. + * add LICENSE file + +0.6.2 / 2013-12-05 +================== + + * Adding repository section to package.json to suppress warning from NPM. + +0.6.1 / 2013-05-10 +================== + + * fix singularization [visionmedia] + +0.6.0 / 2013-03-15 +================== + + * fix minutes + +0.5.1 / 2013-02-24 +================== + + * add component namespace + +0.5.0 / 2012-11-09 +================== + + * add short formatting as default and .long option + * add .license property to component.json + * add version to component.json + +0.4.0 / 2012-10-22 +================== + + * add rounding to fix crazy decimals + +0.3.0 / 2012-09-07 +================== + + * fix `ms()` [visionmedia] + +0.2.0 / 2012-09-03 +================== + + * add component.json [visionmedia] + * add days support [visionmedia] + * add hours support [visionmedia] + * add minutes support [visionmedia] + * add seconds support [visionmedia] + * add ms string support [visionmedia] + * refactor tests to facilitate ms(number) [visionmedia] + +0.1.0 / 2012-03-07 +================== + + * Initial release diff --git a/node_modules/express/node_modules/debug/node_modules/ms/LICENSE b/node_modules/express/node_modules/debug/node_modules/ms/LICENSE new file mode 100644 index 0000000..6c07561 --- /dev/null +++ b/node_modules/express/node_modules/debug/node_modules/ms/LICENSE @@ -0,0 +1,20 @@ +(The MIT License) + +Copyright (c) 2014 Guillermo Rauch + +Permission is hereby granted, free of charge, to any person obtaining a copy of +this software and associated documentation files (the "Software"), to deal in +the Software without restriction, including without limitation the rights to +use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of +the Software, and to permit persons to whom the Software is furnished to do so, +subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS +FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR +COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER +IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN +CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/express/node_modules/debug/node_modules/ms/README.md b/node_modules/express/node_modules/debug/node_modules/ms/README.md new file mode 100644 index 0000000..9b4fd03 --- /dev/null +++ b/node_modules/express/node_modules/debug/node_modules/ms/README.md @@ -0,0 +1,35 @@ +# ms.js: miliseconds conversion utility + +```js +ms('2 days') // 172800000 +ms('1d') // 86400000 +ms('10h') // 36000000 +ms('2.5 hrs') // 9000000 +ms('2h') // 7200000 +ms('1m') // 60000 +ms('5s') // 5000 +ms('100') // 100 +``` + +```js +ms(60000) // "1m" +ms(2 * 60000) // "2m" +ms(ms('10 hours')) // "10h" +``` + +```js +ms(60000, { long: true }) // "1 minute" +ms(2 * 60000, { long: true }) // "2 minutes" +ms(ms('10 hours'), { long: true }) // "10 hours" +``` + +- Node/Browser compatible. Published as [`ms`](https://www.npmjs.org/package/ms) in [NPM](http://nodejs.org/download). +- If a number is supplied to `ms`, a string with a unit is returned. +- If a string that contains the number is supplied, it returns it as +a number (e.g: it returns `100` for `'100'`). +- If you pass a string with a number and a valid unit, the number of +equivalent ms is returned. + +## License + +MIT diff --git a/node_modules/express/node_modules/debug/node_modules/ms/index.js b/node_modules/express/node_modules/debug/node_modules/ms/index.js new file mode 100644 index 0000000..4f92771 --- /dev/null +++ b/node_modules/express/node_modules/debug/node_modules/ms/index.js @@ -0,0 +1,125 @@ +/** + * Helpers. + */ + +var s = 1000; +var m = s * 60; +var h = m * 60; +var d = h * 24; +var y = d * 365.25; + +/** + * Parse or format the given `val`. + * + * Options: + * + * - `long` verbose formatting [false] + * + * @param {String|Number} val + * @param {Object} options + * @return {String|Number} + * @api public + */ + +module.exports = function(val, options){ + options = options || {}; + if ('string' == typeof val) return parse(val); + return options.long + ? long(val) + : short(val); +}; + +/** + * Parse the given `str` and return milliseconds. + * + * @param {String} str + * @return {Number} + * @api private + */ + +function parse(str) { + str = '' + str; + if (str.length > 10000) return; + var match = /^((?:\d+)?\.?\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|years?|yrs?|y)?$/i.exec(str); + if (!match) return; + var n = parseFloat(match[1]); + var type = (match[2] || 'ms').toLowerCase(); + switch (type) { + case 'years': + case 'year': + case 'yrs': + case 'yr': + case 'y': + return n * y; + case 'days': + case 'day': + case 'd': + return n * d; + case 'hours': + case 'hour': + case 'hrs': + case 'hr': + case 'h': + return n * h; + case 'minutes': + case 'minute': + case 'mins': + case 'min': + case 'm': + return n * m; + case 'seconds': + case 'second': + case 'secs': + case 'sec': + case 's': + return n * s; + case 'milliseconds': + case 'millisecond': + case 'msecs': + case 'msec': + case 'ms': + return n; + } +} + +/** + * Short format for `ms`. + * + * @param {Number} ms + * @return {String} + * @api private + */ + +function short(ms) { + if (ms >= d) return Math.round(ms / d) + 'd'; + if (ms >= h) return Math.round(ms / h) + 'h'; + if (ms >= m) return Math.round(ms / m) + 'm'; + if (ms >= s) return Math.round(ms / s) + 's'; + return ms + 'ms'; +} + +/** + * Long format for `ms`. + * + * @param {Number} ms + * @return {String} + * @api private + */ + +function long(ms) { + return plural(ms, d, 'day') + || plural(ms, h, 'hour') + || plural(ms, m, 'minute') + || plural(ms, s, 'second') + || ms + ' ms'; +} + +/** + * Pluralization helper. + */ + +function plural(ms, n, name) { + if (ms < n) return; + if (ms < n * 1.5) return Math.floor(ms / n) + ' ' + name; + return Math.ceil(ms / n) + ' ' + name + 's'; +} diff --git a/node_modules/express/node_modules/debug/node_modules/ms/package.json b/node_modules/express/node_modules/debug/node_modules/ms/package.json new file mode 100644 index 0000000..64818de --- /dev/null +++ b/node_modules/express/node_modules/debug/node_modules/ms/package.json @@ -0,0 +1,48 @@ +{ + "name": "ms", + "version": "0.7.1", + "description": "Tiny ms conversion utility", + "repository": { + "type": "git", + "url": "git://github.com/guille/ms.js.git" + }, + "main": "./index", + "devDependencies": { + "mocha": "*", + "expect.js": "*", + "serve": "*" + }, + "component": { + "scripts": { + "ms/index.js": "index.js" + } + }, + "gitHead": "713dcf26d9e6fd9dbc95affe7eff9783b7f1b909", + "bugs": { + "url": "https://github.com/guille/ms.js/issues" + }, + "homepage": "https://github.com/guille/ms.js", + "_id": "ms@0.7.1", + "scripts": {}, + "_shasum": "9cd13c03adbff25b65effde7ce864ee952017098", + "_from": "ms@0.7.1", + "_npmVersion": "2.7.5", + "_nodeVersion": "0.12.2", + "_npmUser": { + "name": "rauchg", + "email": "rauchg@gmail.com" + }, + "maintainers": [ + { + "name": "rauchg", + "email": "rauchg@gmail.com" + } + ], + "dist": { + "shasum": "9cd13c03adbff25b65effde7ce864ee952017098", + "tarball": "https://registry.npmjs.org/ms/-/ms-0.7.1.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/ms/-/ms-0.7.1.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/express/node_modules/debug/package.json b/node_modules/express/node_modules/debug/package.json new file mode 100644 index 0000000..5228b80 --- /dev/null +++ b/node_modules/express/node_modules/debug/package.json @@ -0,0 +1,73 @@ +{ + "name": "debug", + "version": "2.2.0", + "repository": { + "type": "git", + "url": "git://github.com/visionmedia/debug.git" + }, + "description": "small debugging utility", + "keywords": [ + "debug", + "log", + "debugger" + ], + "author": { + "name": "TJ Holowaychuk", + "email": "tj@vision-media.ca" + }, + "contributors": [ + { + "name": "Nathan Rajlich", + "email": "nathan@tootallnate.net", + "url": "http://n8.io" + } + ], + "license": "MIT", + "dependencies": { + "ms": "0.7.1" + }, + "devDependencies": { + "browserify": "9.0.3", + "mocha": "*" + }, + "main": "./node.js", + "browser": "./browser.js", + "component": { + "scripts": { + "debug/index.js": "browser.js", + "debug/debug.js": "debug.js" + } + }, + "gitHead": "b38458422b5aa8aa6d286b10dfe427e8a67e2b35", + "bugs": { + "url": "https://github.com/visionmedia/debug/issues" + }, + "homepage": "https://github.com/visionmedia/debug", + "_id": "debug@2.2.0", + "scripts": {}, + "_shasum": "f87057e995b1a1f6ae6a4960664137bc56f039da", + "_from": "debug@>=2.2.0 <2.3.0", + "_npmVersion": "2.7.4", + "_nodeVersion": "0.12.2", + "_npmUser": { + "name": "tootallnate", + "email": "nathan@tootallnate.net" + }, + "maintainers": [ + { + "name": "tjholowaychuk", + "email": "tj@vision-media.ca" + }, + { + "name": "tootallnate", + "email": "nathan@tootallnate.net" + } + ], + "dist": { + "shasum": "f87057e995b1a1f6ae6a4960664137bc56f039da", + "tarball": "https://registry.npmjs.org/debug/-/debug-2.2.0.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/debug/-/debug-2.2.0.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/express/node_modules/depd/History.md b/node_modules/express/node_modules/depd/History.md new file mode 100644 index 0000000..ace1171 --- /dev/null +++ b/node_modules/express/node_modules/depd/History.md @@ -0,0 +1,84 @@ +1.1.0 / 2015-09-14 +================== + + * Enable strict mode in more places + * Support io.js 3.x + * Support io.js 2.x + * Support web browser loading + - Requires bundler like Browserify or webpack + +1.0.1 / 2015-04-07 +================== + + * Fix `TypeError`s when under `'use strict'` code + * Fix useless type name on auto-generated messages + * Support io.js 1.x + * Support Node.js 0.12 + +1.0.0 / 2014-09-17 +================== + + * No changes + +0.4.5 / 2014-09-09 +================== + + * Improve call speed to functions using the function wrapper + * Support Node.js 0.6 + +0.4.4 / 2014-07-27 +================== + + * Work-around v8 generating empty stack traces + +0.4.3 / 2014-07-26 +================== + + * Fix exception when global `Error.stackTraceLimit` is too low + +0.4.2 / 2014-07-19 +================== + + * Correct call site for wrapped functions and properties + +0.4.1 / 2014-07-19 +================== + + * Improve automatic message generation for function properties + +0.4.0 / 2014-07-19 +================== + + * Add `TRACE_DEPRECATION` environment variable + * Remove non-standard grey color from color output + * Support `--no-deprecation` argument + * Support `--trace-deprecation` argument + * Support `deprecate.property(fn, prop, message)` + +0.3.0 / 2014-06-16 +================== + + * Add `NO_DEPRECATION` environment variable + +0.2.0 / 2014-06-15 +================== + + * Add `deprecate.property(obj, prop, message)` + * Remove `supports-color` dependency for node.js 0.8 + +0.1.0 / 2014-06-15 +================== + + * Add `deprecate.function(fn, message)` + * Add `process.on('deprecation', fn)` emitter + * Automatically generate message when omitted from `deprecate()` + +0.0.1 / 2014-06-15 +================== + + * Fix warning for dynamic calls at singe call site + +0.0.0 / 2014-06-15 +================== + + * Initial implementation diff --git a/node_modules/express/node_modules/depd/LICENSE b/node_modules/express/node_modules/depd/LICENSE new file mode 100644 index 0000000..142ede3 --- /dev/null +++ b/node_modules/express/node_modules/depd/LICENSE @@ -0,0 +1,22 @@ +(The MIT License) + +Copyright (c) 2014-2015 Douglas Christopher Wilson + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/express/node_modules/depd/Readme.md b/node_modules/express/node_modules/depd/Readme.md new file mode 100644 index 0000000..09bb979 --- /dev/null +++ b/node_modules/express/node_modules/depd/Readme.md @@ -0,0 +1,281 @@ +# depd + +[![NPM Version][npm-version-image]][npm-url] +[![NPM Downloads][npm-downloads-image]][npm-url] +[![Node.js Version][node-image]][node-url] +[![Linux Build][travis-image]][travis-url] +[![Windows Build][appveyor-image]][appveyor-url] +[![Coverage Status][coveralls-image]][coveralls-url] +[![Gratipay][gratipay-image]][gratipay-url] + +Deprecate all the things + +> With great modules comes great responsibility; mark things deprecated! + +## Install + +This module is installed directly using `npm`: + +```sh +$ npm install depd +``` + +This module can also be bundled with systems like +[Browserify](http://browserify.org/) or [webpack](https://webpack.github.io/), +though by default this module will alter it's API to no longer display or +track deprecations. + +## API + +```js +var deprecate = require('depd')('my-module') +``` + +This library allows you to display deprecation messages to your users. +This library goes above and beyond with deprecation warnings by +introspection of the call stack (but only the bits that it is interested +in). + +Instead of just warning on the first invocation of a deprecated +function and never again, this module will warn on the first invocation +of a deprecated function per unique call site, making it ideal to alert +users of all deprecated uses across the code base, rather than just +whatever happens to execute first. + +The deprecation warnings from this module also include the file and line +information for the call into the module that the deprecated function was +in. + +**NOTE** this library has a similar interface to the `debug` module, and +this module uses the calling file to get the boundary for the call stacks, +so you should always create a new `deprecate` object in each file and not +within some central file. + +### depd(namespace) + +Create a new deprecate function that uses the given namespace name in the +messages and will display the call site prior to the stack entering the +file this function was called from. It is highly suggested you use the +name of your module as the namespace. + +### deprecate(message) + +Call this function from deprecated code to display a deprecation message. +This message will appear once per unique caller site. Caller site is the +first call site in the stack in a different file from the caller of this +function. + +If the message is omitted, a message is generated for you based on the site +of the `deprecate()` call and will display the name of the function called, +similar to the name displayed in a stack trace. + +### deprecate.function(fn, message) + +Call this function to wrap a given function in a deprecation message on any +call to the function. An optional message can be supplied to provide a custom +message. + +### deprecate.property(obj, prop, message) + +Call this function to wrap a given property on object in a deprecation message +on any accessing or setting of the property. An optional message can be supplied +to provide a custom message. + +The method must be called on the object where the property belongs (not +inherited from the prototype). + +If the property is a data descriptor, it will be converted to an accessor +descriptor in order to display the deprecation message. + +### process.on('deprecation', fn) + +This module will allow easy capturing of deprecation errors by emitting the +errors as the type "deprecation" on the global `process`. If there are no +listeners for this type, the errors are written to STDERR as normal, but if +there are any listeners, nothing will be written to STDERR and instead only +emitted. From there, you can write the errors in a different format or to a +logging source. + +The error represents the deprecation and is emitted only once with the same +rules as writing to STDERR. The error has the following properties: + + - `message` - This is the message given by the library + - `name` - This is always `'DeprecationError'` + - `namespace` - This is the namespace the deprecation came from + - `stack` - This is the stack of the call to the deprecated thing + +Example `error.stack` output: + +``` +DeprecationError: my-cool-module deprecated oldfunction + at Object. ([eval]-wrapper:6:22) + at Module._compile (module.js:456:26) + at evalScript (node.js:532:25) + at startup (node.js:80:7) + at node.js:902:3 +``` + +### process.env.NO_DEPRECATION + +As a user of modules that are deprecated, the environment variable `NO_DEPRECATION` +is provided as a quick solution to silencing deprecation warnings from being +output. The format of this is similar to that of `DEBUG`: + +```sh +$ NO_DEPRECATION=my-module,othermod node app.js +``` + +This will suppress deprecations from being output for "my-module" and "othermod". +The value is a list of comma-separated namespaces. To suppress every warning +across all namespaces, use the value `*` for a namespace. + +Providing the argument `--no-deprecation` to the `node` executable will suppress +all deprecations (only available in Node.js 0.8 or higher). + +**NOTE** This will not suppress the deperecations given to any "deprecation" +event listeners, just the output to STDERR. + +### process.env.TRACE_DEPRECATION + +As a user of modules that are deprecated, the environment variable `TRACE_DEPRECATION` +is provided as a solution to getting more detailed location information in deprecation +warnings by including the entire stack trace. The format of this is the same as +`NO_DEPRECATION`: + +```sh +$ TRACE_DEPRECATION=my-module,othermod node app.js +``` + +This will include stack traces for deprecations being output for "my-module" and +"othermod". The value is a list of comma-separated namespaces. To trace every +warning across all namespaces, use the value `*` for a namespace. + +Providing the argument `--trace-deprecation` to the `node` executable will trace +all deprecations (only available in Node.js 0.8 or higher). + +**NOTE** This will not trace the deperecations silenced by `NO_DEPRECATION`. + +## Display + +![message](files/message.png) + +When a user calls a function in your library that you mark deprecated, they +will see the following written to STDERR (in the given colors, similar colors +and layout to the `debug` module): + +``` +bright cyan bright yellow +| | reset cyan +| | | | +▼ ▼ ▼ ▼ +my-cool-module deprecated oldfunction [eval]-wrapper:6:22 +▲ ▲ ▲ ▲ +| | | | +namespace | | location of mycoolmod.oldfunction() call + | deprecation message + the word "deprecated" +``` + +If the user redirects their STDERR to a file or somewhere that does not support +colors, they see (similar layout to the `debug` module): + +``` +Sun, 15 Jun 2014 05:21:37 GMT my-cool-module deprecated oldfunction at [eval]-wrapper:6:22 +▲ ▲ ▲ ▲ ▲ +| | | | | +timestamp of message namespace | | location of mycoolmod.oldfunction() call + | deprecation message + the word "deprecated" +``` + +## Examples + +### Deprecating all calls to a function + +This will display a deprecated message about "oldfunction" being deprecated +from "my-module" on STDERR. + +```js +var deprecate = require('depd')('my-cool-module') + +// message automatically derived from function name +// Object.oldfunction +exports.oldfunction = deprecate.function(function oldfunction() { + // all calls to function are deprecated +}) + +// specific message +exports.oldfunction = deprecate.function(function () { + // all calls to function are deprecated +}, 'oldfunction') +``` + +### Conditionally deprecating a function call + +This will display a deprecated message about "weirdfunction" being deprecated +from "my-module" on STDERR when called with less than 2 arguments. + +```js +var deprecate = require('depd')('my-cool-module') + +exports.weirdfunction = function () { + if (arguments.length < 2) { + // calls with 0 or 1 args are deprecated + deprecate('weirdfunction args < 2') + } +} +``` + +When calling `deprecate` as a function, the warning is counted per call site +within your own module, so you can display different deprecations depending +on different situations and the users will still get all the warnings: + +```js +var deprecate = require('depd')('my-cool-module') + +exports.weirdfunction = function () { + if (arguments.length < 2) { + // calls with 0 or 1 args are deprecated + deprecate('weirdfunction args < 2') + } else if (typeof arguments[0] !== 'string') { + // calls with non-string first argument are deprecated + deprecate('weirdfunction non-string first arg') + } +} +``` + +### Deprecating property access + +This will display a deprecated message about "oldprop" being deprecated +from "my-module" on STDERR when accessed. A deprecation will be displayed +when setting the value and when getting the value. + +```js +var deprecate = require('depd')('my-cool-module') + +exports.oldprop = 'something' + +// message automatically derives from property name +deprecate.property(exports, 'oldprop') + +// explicit message +deprecate.property(exports, 'oldprop', 'oldprop >= 0.10') +``` + +## License + +[MIT](LICENSE) + +[npm-version-image]: https://img.shields.io/npm/v/depd.svg +[npm-downloads-image]: https://img.shields.io/npm/dm/depd.svg +[npm-url]: https://npmjs.org/package/depd +[travis-image]: https://img.shields.io/travis/dougwilson/nodejs-depd/master.svg?label=linux +[travis-url]: https://travis-ci.org/dougwilson/nodejs-depd +[appveyor-image]: https://img.shields.io/appveyor/ci/dougwilson/nodejs-depd/master.svg?label=windows +[appveyor-url]: https://ci.appveyor.com/project/dougwilson/nodejs-depd +[coveralls-image]: https://img.shields.io/coveralls/dougwilson/nodejs-depd/master.svg +[coveralls-url]: https://coveralls.io/r/dougwilson/nodejs-depd?branch=master +[node-image]: https://img.shields.io/node/v/depd.svg +[node-url]: http://nodejs.org/download/ +[gratipay-image]: https://img.shields.io/gratipay/dougwilson.svg +[gratipay-url]: https://www.gratipay.com/dougwilson/ diff --git a/node_modules/express/node_modules/depd/index.js b/node_modules/express/node_modules/depd/index.js new file mode 100644 index 0000000..fddcae8 --- /dev/null +++ b/node_modules/express/node_modules/depd/index.js @@ -0,0 +1,521 @@ +/*! + * depd + * Copyright(c) 2014-2015 Douglas Christopher Wilson + * MIT Licensed + */ + +/** + * Module dependencies. + */ + +var callSiteToString = require('./lib/compat').callSiteToString +var eventListenerCount = require('./lib/compat').eventListenerCount +var relative = require('path').relative + +/** + * Module exports. + */ + +module.exports = depd + +/** + * Get the path to base files on. + */ + +var basePath = process.cwd() + +/** + * Determine if namespace is contained in the string. + */ + +function containsNamespace(str, namespace) { + var val = str.split(/[ ,]+/) + + namespace = String(namespace).toLowerCase() + + for (var i = 0 ; i < val.length; i++) { + if (!(str = val[i])) continue; + + // namespace contained + if (str === '*' || str.toLowerCase() === namespace) { + return true + } + } + + return false +} + +/** + * Convert a data descriptor to accessor descriptor. + */ + +function convertDataDescriptorToAccessor(obj, prop, message) { + var descriptor = Object.getOwnPropertyDescriptor(obj, prop) + var value = descriptor.value + + descriptor.get = function getter() { return value } + + if (descriptor.writable) { + descriptor.set = function setter(val) { return value = val } + } + + delete descriptor.value + delete descriptor.writable + + Object.defineProperty(obj, prop, descriptor) + + return descriptor +} + +/** + * Create arguments string to keep arity. + */ + +function createArgumentsString(arity) { + var str = '' + + for (var i = 0; i < arity; i++) { + str += ', arg' + i + } + + return str.substr(2) +} + +/** + * Create stack string from stack. + */ + +function createStackString(stack) { + var str = this.name + ': ' + this.namespace + + if (this.message) { + str += ' deprecated ' + this.message + } + + for (var i = 0; i < stack.length; i++) { + str += '\n at ' + callSiteToString(stack[i]) + } + + return str +} + +/** + * Create deprecate for namespace in caller. + */ + +function depd(namespace) { + if (!namespace) { + throw new TypeError('argument namespace is required') + } + + var stack = getStack() + var site = callSiteLocation(stack[1]) + var file = site[0] + + function deprecate(message) { + // call to self as log + log.call(deprecate, message) + } + + deprecate._file = file + deprecate._ignored = isignored(namespace) + deprecate._namespace = namespace + deprecate._traced = istraced(namespace) + deprecate._warned = Object.create(null) + + deprecate.function = wrapfunction + deprecate.property = wrapproperty + + return deprecate +} + +/** + * Determine if namespace is ignored. + */ + +function isignored(namespace) { + /* istanbul ignore next: tested in a child processs */ + if (process.noDeprecation) { + // --no-deprecation support + return true + } + + var str = process.env.NO_DEPRECATION || '' + + // namespace ignored + return containsNamespace(str, namespace) +} + +/** + * Determine if namespace is traced. + */ + +function istraced(namespace) { + /* istanbul ignore next: tested in a child processs */ + if (process.traceDeprecation) { + // --trace-deprecation support + return true + } + + var str = process.env.TRACE_DEPRECATION || '' + + // namespace traced + return containsNamespace(str, namespace) +} + +/** + * Display deprecation message. + */ + +function log(message, site) { + var haslisteners = eventListenerCount(process, 'deprecation') !== 0 + + // abort early if no destination + if (!haslisteners && this._ignored) { + return + } + + var caller + var callFile + var callSite + var i = 0 + var seen = false + var stack = getStack() + var file = this._file + + if (site) { + // provided site + callSite = callSiteLocation(stack[1]) + callSite.name = site.name + file = callSite[0] + } else { + // get call site + i = 2 + site = callSiteLocation(stack[i]) + callSite = site + } + + // get caller of deprecated thing in relation to file + for (; i < stack.length; i++) { + caller = callSiteLocation(stack[i]) + callFile = caller[0] + + if (callFile === file) { + seen = true + } else if (callFile === this._file) { + file = this._file + } else if (seen) { + break + } + } + + var key = caller + ? site.join(':') + '__' + caller.join(':') + : undefined + + if (key !== undefined && key in this._warned) { + // already warned + return + } + + this._warned[key] = true + + // generate automatic message from call site + if (!message) { + message = callSite === site || !callSite.name + ? defaultMessage(site) + : defaultMessage(callSite) + } + + // emit deprecation if listeners exist + if (haslisteners) { + var err = DeprecationError(this._namespace, message, stack.slice(i)) + process.emit('deprecation', err) + return + } + + // format and write message + var format = process.stderr.isTTY + ? formatColor + : formatPlain + var msg = format.call(this, message, caller, stack.slice(i)) + process.stderr.write(msg + '\n', 'utf8') + + return +} + +/** + * Get call site location as array. + */ + +function callSiteLocation(callSite) { + var file = callSite.getFileName() || '' + var line = callSite.getLineNumber() + var colm = callSite.getColumnNumber() + + if (callSite.isEval()) { + file = callSite.getEvalOrigin() + ', ' + file + } + + var site = [file, line, colm] + + site.callSite = callSite + site.name = callSite.getFunctionName() + + return site +} + +/** + * Generate a default message from the site. + */ + +function defaultMessage(site) { + var callSite = site.callSite + var funcName = site.name + + // make useful anonymous name + if (!funcName) { + funcName = '' + } + + var context = callSite.getThis() + var typeName = context && callSite.getTypeName() + + // ignore useless type name + if (typeName === 'Object') { + typeName = undefined + } + + // make useful type name + if (typeName === 'Function') { + typeName = context.name || typeName + } + + return typeName && callSite.getMethodName() + ? typeName + '.' + funcName + : funcName +} + +/** + * Format deprecation message without color. + */ + +function formatPlain(msg, caller, stack) { + var timestamp = new Date().toUTCString() + + var formatted = timestamp + + ' ' + this._namespace + + ' deprecated ' + msg + + // add stack trace + if (this._traced) { + for (var i = 0; i < stack.length; i++) { + formatted += '\n at ' + callSiteToString(stack[i]) + } + + return formatted + } + + if (caller) { + formatted += ' at ' + formatLocation(caller) + } + + return formatted +} + +/** + * Format deprecation message with color. + */ + +function formatColor(msg, caller, stack) { + var formatted = '\x1b[36;1m' + this._namespace + '\x1b[22;39m' // bold cyan + + ' \x1b[33;1mdeprecated\x1b[22;39m' // bold yellow + + ' \x1b[0m' + msg + '\x1b[39m' // reset + + // add stack trace + if (this._traced) { + for (var i = 0; i < stack.length; i++) { + formatted += '\n \x1b[36mat ' + callSiteToString(stack[i]) + '\x1b[39m' // cyan + } + + return formatted + } + + if (caller) { + formatted += ' \x1b[36m' + formatLocation(caller) + '\x1b[39m' // cyan + } + + return formatted +} + +/** + * Format call site location. + */ + +function formatLocation(callSite) { + return relative(basePath, callSite[0]) + + ':' + callSite[1] + + ':' + callSite[2] +} + +/** + * Get the stack as array of call sites. + */ + +function getStack() { + var limit = Error.stackTraceLimit + var obj = {} + var prep = Error.prepareStackTrace + + Error.prepareStackTrace = prepareObjectStackTrace + Error.stackTraceLimit = Math.max(10, limit) + + // capture the stack + Error.captureStackTrace(obj) + + // slice this function off the top + var stack = obj.stack.slice(1) + + Error.prepareStackTrace = prep + Error.stackTraceLimit = limit + + return stack +} + +/** + * Capture call site stack from v8. + */ + +function prepareObjectStackTrace(obj, stack) { + return stack +} + +/** + * Return a wrapped function in a deprecation message. + */ + +function wrapfunction(fn, message) { + if (typeof fn !== 'function') { + throw new TypeError('argument fn must be a function') + } + + var args = createArgumentsString(fn.length) + var deprecate = this + var stack = getStack() + var site = callSiteLocation(stack[1]) + + site.name = fn.name + + var deprecatedfn = eval('(function (' + args + ') {\n' + + '"use strict"\n' + + 'log.call(deprecate, message, site)\n' + + 'return fn.apply(this, arguments)\n' + + '})') + + return deprecatedfn +} + +/** + * Wrap property in a deprecation message. + */ + +function wrapproperty(obj, prop, message) { + if (!obj || (typeof obj !== 'object' && typeof obj !== 'function')) { + throw new TypeError('argument obj must be object') + } + + var descriptor = Object.getOwnPropertyDescriptor(obj, prop) + + if (!descriptor) { + throw new TypeError('must call property on owner object') + } + + if (!descriptor.configurable) { + throw new TypeError('property must be configurable') + } + + var deprecate = this + var stack = getStack() + var site = callSiteLocation(stack[1]) + + // set site name + site.name = prop + + // convert data descriptor + if ('value' in descriptor) { + descriptor = convertDataDescriptorToAccessor(obj, prop, message) + } + + var get = descriptor.get + var set = descriptor.set + + // wrap getter + if (typeof get === 'function') { + descriptor.get = function getter() { + log.call(deprecate, message, site) + return get.apply(this, arguments) + } + } + + // wrap setter + if (typeof set === 'function') { + descriptor.set = function setter() { + log.call(deprecate, message, site) + return set.apply(this, arguments) + } + } + + Object.defineProperty(obj, prop, descriptor) +} + +/** + * Create DeprecationError for deprecation + */ + +function DeprecationError(namespace, message, stack) { + var error = new Error() + var stackString + + Object.defineProperty(error, 'constructor', { + value: DeprecationError + }) + + Object.defineProperty(error, 'message', { + configurable: true, + enumerable: false, + value: message, + writable: true + }) + + Object.defineProperty(error, 'name', { + enumerable: false, + configurable: true, + value: 'DeprecationError', + writable: true + }) + + Object.defineProperty(error, 'namespace', { + configurable: true, + enumerable: false, + value: namespace, + writable: true + }) + + Object.defineProperty(error, 'stack', { + configurable: true, + enumerable: false, + get: function () { + if (stackString !== undefined) { + return stackString + } + + // prepare stack trace + return stackString = createStackString.call(this, stack) + }, + set: function setter(val) { + stackString = val + } + }) + + return error +} diff --git a/node_modules/express/node_modules/depd/lib/browser/index.js b/node_modules/express/node_modules/depd/lib/browser/index.js new file mode 100644 index 0000000..f464e05 --- /dev/null +++ b/node_modules/express/node_modules/depd/lib/browser/index.js @@ -0,0 +1,79 @@ +/*! + * depd + * Copyright(c) 2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module exports. + * @public + */ + +module.exports = depd + +/** + * Create deprecate for namespace in caller. + */ + +function depd(namespace) { + if (!namespace) { + throw new TypeError('argument namespace is required') + } + + function deprecate(message) { + // no-op in browser + } + + deprecate._file = undefined + deprecate._ignored = true + deprecate._namespace = namespace + deprecate._traced = false + deprecate._warned = Object.create(null) + + deprecate.function = wrapfunction + deprecate.property = wrapproperty + + return deprecate +} + +/** + * Return a wrapped function in a deprecation message. + * + * This is a no-op version of the wrapper, which does nothing but call + * validation. + */ + +function wrapfunction(fn, message) { + if (typeof fn !== 'function') { + throw new TypeError('argument fn must be a function') + } + + return fn +} + +/** + * Wrap property in a deprecation message. + * + * This is a no-op version of the wrapper, which does nothing but call + * validation. + */ + +function wrapproperty(obj, prop, message) { + if (!obj || (typeof obj !== 'object' && typeof obj !== 'function')) { + throw new TypeError('argument obj must be object') + } + + var descriptor = Object.getOwnPropertyDescriptor(obj, prop) + + if (!descriptor) { + throw new TypeError('must call property on owner object') + } + + if (!descriptor.configurable) { + throw new TypeError('property must be configurable') + } + + return +} diff --git a/node_modules/express/node_modules/depd/lib/compat/buffer-concat.js b/node_modules/express/node_modules/depd/lib/compat/buffer-concat.js new file mode 100644 index 0000000..4b73381 --- /dev/null +++ b/node_modules/express/node_modules/depd/lib/compat/buffer-concat.js @@ -0,0 +1,35 @@ +/*! + * depd + * Copyright(c) 2014 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module exports. + */ + +module.exports = bufferConcat + +/** + * Concatenate an array of Buffers. + */ + +function bufferConcat(bufs) { + var length = 0 + + for (var i = 0, len = bufs.length; i < len; i++) { + length += bufs[i].length + } + + var buf = new Buffer(length) + var pos = 0 + + for (var i = 0, len = bufs.length; i < len; i++) { + bufs[i].copy(buf, pos) + pos += bufs[i].length + } + + return buf +} diff --git a/node_modules/express/node_modules/depd/lib/compat/callsite-tostring.js b/node_modules/express/node_modules/depd/lib/compat/callsite-tostring.js new file mode 100644 index 0000000..9ecef34 --- /dev/null +++ b/node_modules/express/node_modules/depd/lib/compat/callsite-tostring.js @@ -0,0 +1,103 @@ +/*! + * depd + * Copyright(c) 2014 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module exports. + */ + +module.exports = callSiteToString + +/** + * Format a CallSite file location to a string. + */ + +function callSiteFileLocation(callSite) { + var fileName + var fileLocation = '' + + if (callSite.isNative()) { + fileLocation = 'native' + } else if (callSite.isEval()) { + fileName = callSite.getScriptNameOrSourceURL() + if (!fileName) { + fileLocation = callSite.getEvalOrigin() + } + } else { + fileName = callSite.getFileName() + } + + if (fileName) { + fileLocation += fileName + + var lineNumber = callSite.getLineNumber() + if (lineNumber != null) { + fileLocation += ':' + lineNumber + + var columnNumber = callSite.getColumnNumber() + if (columnNumber) { + fileLocation += ':' + columnNumber + } + } + } + + return fileLocation || 'unknown source' +} + +/** + * Format a CallSite to a string. + */ + +function callSiteToString(callSite) { + var addSuffix = true + var fileLocation = callSiteFileLocation(callSite) + var functionName = callSite.getFunctionName() + var isConstructor = callSite.isConstructor() + var isMethodCall = !(callSite.isToplevel() || isConstructor) + var line = '' + + if (isMethodCall) { + var methodName = callSite.getMethodName() + var typeName = getConstructorName(callSite) + + if (functionName) { + if (typeName && functionName.indexOf(typeName) !== 0) { + line += typeName + '.' + } + + line += functionName + + if (methodName && functionName.lastIndexOf('.' + methodName) !== functionName.length - methodName.length - 1) { + line += ' [as ' + methodName + ']' + } + } else { + line += typeName + '.' + (methodName || '') + } + } else if (isConstructor) { + line += 'new ' + (functionName || '') + } else if (functionName) { + line += functionName + } else { + addSuffix = false + line += fileLocation + } + + if (addSuffix) { + line += ' (' + fileLocation + ')' + } + + return line +} + +/** + * Get constructor name of reviver. + */ + +function getConstructorName(obj) { + var receiver = obj.receiver + return (receiver.constructor && receiver.constructor.name) || null +} diff --git a/node_modules/express/node_modules/depd/lib/compat/event-listener-count.js b/node_modules/express/node_modules/depd/lib/compat/event-listener-count.js new file mode 100644 index 0000000..a05fceb --- /dev/null +++ b/node_modules/express/node_modules/depd/lib/compat/event-listener-count.js @@ -0,0 +1,22 @@ +/*! + * depd + * Copyright(c) 2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module exports. + * @public + */ + +module.exports = eventListenerCount + +/** + * Get the count of listeners on an event emitter of a specific type. + */ + +function eventListenerCount(emitter, type) { + return emitter.listeners(type).length +} diff --git a/node_modules/express/node_modules/depd/lib/compat/index.js b/node_modules/express/node_modules/depd/lib/compat/index.js new file mode 100644 index 0000000..aa3c1de --- /dev/null +++ b/node_modules/express/node_modules/depd/lib/compat/index.js @@ -0,0 +1,84 @@ +/*! + * depd + * Copyright(c) 2014-2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module dependencies. + * @private + */ + +var Buffer = require('buffer') +var EventEmitter = require('events').EventEmitter + +/** + * Module exports. + * @public + */ + +lazyProperty(module.exports, 'bufferConcat', function bufferConcat() { + return Buffer.concat || require('./buffer-concat') +}) + +lazyProperty(module.exports, 'callSiteToString', function callSiteToString() { + var limit = Error.stackTraceLimit + var obj = {} + var prep = Error.prepareStackTrace + + function prepareObjectStackTrace(obj, stack) { + return stack + } + + Error.prepareStackTrace = prepareObjectStackTrace + Error.stackTraceLimit = 2 + + // capture the stack + Error.captureStackTrace(obj) + + // slice the stack + var stack = obj.stack.slice() + + Error.prepareStackTrace = prep + Error.stackTraceLimit = limit + + return stack[0].toString ? toString : require('./callsite-tostring') +}) + +lazyProperty(module.exports, 'eventListenerCount', function eventListenerCount() { + return EventEmitter.listenerCount || require('./event-listener-count') +}) + +/** + * Define a lazy property. + */ + +function lazyProperty(obj, prop, getter) { + function get() { + var val = getter() + + Object.defineProperty(obj, prop, { + configurable: true, + enumerable: true, + value: val + }) + + return val + } + + Object.defineProperty(obj, prop, { + configurable: true, + enumerable: true, + get: get + }) +} + +/** + * Call toString() on the obj + */ + +function toString(obj) { + return obj.toString() +} diff --git a/node_modules/express/node_modules/depd/package.json b/node_modules/express/node_modules/depd/package.json new file mode 100644 index 0000000..57bfc94 --- /dev/null +++ b/node_modules/express/node_modules/depd/package.json @@ -0,0 +1,67 @@ +{ + "name": "depd", + "description": "Deprecate all the things", + "version": "1.1.0", + "author": { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + }, + "license": "MIT", + "keywords": [ + "deprecate", + "deprecated" + ], + "repository": { + "type": "git", + "url": "git+https://github.com/dougwilson/nodejs-depd.git" + }, + "browser": "lib/browser/index.js", + "devDependencies": { + "benchmark": "1.0.0", + "beautify-benchmark": "0.2.4", + "istanbul": "0.3.5", + "mocha": "~1.21.5" + }, + "files": [ + "lib/", + "History.md", + "LICENSE", + "index.js", + "Readme.md" + ], + "engines": { + "node": ">= 0.6" + }, + "scripts": { + "bench": "node benchmark/index.js", + "test": "mocha --reporter spec --bail test/", + "test-ci": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter spec --no-exit test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot test/" + }, + "gitHead": "78c659de20283e3a6bee92bda455e6daff01686a", + "bugs": { + "url": "https://github.com/dougwilson/nodejs-depd/issues" + }, + "homepage": "https://github.com/dougwilson/nodejs-depd", + "_id": "depd@1.1.0", + "_shasum": "e1bd82c6aab6ced965b97b88b17ed3e528ca18c3", + "_from": "depd@>=1.1.0 <1.2.0", + "_npmVersion": "1.4.28", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "maintainers": [ + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + } + ], + "dist": { + "shasum": "e1bd82c6aab6ced965b97b88b17ed3e528ca18c3", + "tarball": "https://registry.npmjs.org/depd/-/depd-1.1.0.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/depd/-/depd-1.1.0.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/express/node_modules/encodeurl/HISTORY.md b/node_modules/express/node_modules/encodeurl/HISTORY.md new file mode 100644 index 0000000..06d34a5 --- /dev/null +++ b/node_modules/express/node_modules/encodeurl/HISTORY.md @@ -0,0 +1,9 @@ +1.0.1 / 2016-06-09 +================== + + * Fix encoding unpaired surrogates at start/end of string + +1.0.0 / 2016-06-08 +================== + + * Initial release diff --git a/node_modules/express/node_modules/encodeurl/LICENSE b/node_modules/express/node_modules/encodeurl/LICENSE new file mode 100644 index 0000000..8812229 --- /dev/null +++ b/node_modules/express/node_modules/encodeurl/LICENSE @@ -0,0 +1,22 @@ +(The MIT License) + +Copyright (c) 2016 Douglas Christopher Wilson + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/express/node_modules/encodeurl/README.md b/node_modules/express/node_modules/encodeurl/README.md new file mode 100644 index 0000000..b086133 --- /dev/null +++ b/node_modules/express/node_modules/encodeurl/README.md @@ -0,0 +1,124 @@ +# encodeurl + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Node.js Version][node-version-image]][node-version-url] +[![Build Status][travis-image]][travis-url] +[![Test Coverage][coveralls-image]][coveralls-url] + +Encode a URL to a percent-encoded form, excluding already-encoded sequences + +## Installation + +```sh +$ npm install encodeurl +``` + +## API + +```js +var encodeUrl = require('encodeurl') +``` + +### encodeUrl(url) + +Encode a URL to a percent-encoded form, excluding already-encoded sequences. + +This function will take an already-encoded URL and encode all the non-URL +code points (as UTF-8 byte sequences). This function will not encode the +"%" character unless it is not part of a valid sequence (`%20` will be +left as-is, but `%foo` will be encoded as `%25foo`). + +This encode is meant to be "safe" and does not throw errors. It will try as +hard as it can to properly encode the given URL, including replacing any raw, +unpaired surrogate pairs with the Unicode replacement character prior to +encoding. + +This function is _similar_ to the intrinsic function `encodeURI`, except it +will not encode the `%` character if that is part of a valid sequence, will +not encode `[` and `]` (for IPv6 hostnames) and will replace raw, unpaired +surrogate pairs with the Unicode replacement character (instead of throwing). + +## Examples + +### Encode a URL containing user-controled data + +```js +var encodeUrl = require('encodeurl') +var escapeHtml = require('escape-html') + +http.createServer(function onRequest (req, res) { + // get encoded form of inbound url + var url = encodeUrl(req.url) + + // create html message + var body = '

Location ' + escapeHtml(url) + ' not found

' + + // send a 404 + res.statusCode = 404 + res.setHeader('Content-Type', 'text/html; charset=UTF-8') + res.setHeader('Content-Length', String(Buffer.byteLength(body, 'utf-8'))) + res.end(body, 'utf-8') +}) +``` + +### Encode a URL for use in a header field + +```js +var encodeUrl = require('encodeurl') +var escapeHtml = require('escape-html') +var url = require('url') + +http.createServer(function onRequest (req, res) { + // parse inbound url + var href = url.parse(req) + + // set new host for redirect + href.host = 'localhost' + href.protocol = 'https:' + href.slashes = true + + // create location header + var location = encodeUrl(url.format(href)) + + // create html message + var body = '

Redirecting to new site: ' + escapeHtml(location) + '

' + + // send a 301 + res.statusCode = 301 + res.setHeader('Content-Type', 'text/html; charset=UTF-8') + res.setHeader('Content-Length', String(Buffer.byteLength(body, 'utf-8'))) + res.setHeader('Location', location) + res.end(body, 'utf-8') +}) +``` + +## Testing + +```sh +$ npm test +$ npm run lint +``` + +## References + +- [RFC 3986: Uniform Resource Identifier (URI): Generic Syntax][rfc-3986] +- [WHATWG URL Living Standard][whatwg-url] + +[rfc-3986]: https://tools.ietf.org/html/rfc3986 +[whatwg-url]: https://url.spec.whatwg.org/ + +## License + +[MIT](LICENSE) + +[npm-image]: https://img.shields.io/npm/v/encodeurl.svg +[npm-url]: https://npmjs.org/package/encodeurl +[node-version-image]: https://img.shields.io/node/v/encodeurl.svg +[node-version-url]: https://nodejs.org/en/download +[travis-image]: https://img.shields.io/travis/pillarjs/encodeurl.svg +[travis-url]: https://travis-ci.org/pillarjs/encodeurl +[coveralls-image]: https://img.shields.io/coveralls/pillarjs/encodeurl.svg +[coveralls-url]: https://coveralls.io/r/pillarjs/encodeurl?branch=master +[downloads-image]: https://img.shields.io/npm/dm/encodeurl.svg +[downloads-url]: https://npmjs.org/package/encodeurl diff --git a/node_modules/express/node_modules/encodeurl/index.js b/node_modules/express/node_modules/encodeurl/index.js new file mode 100644 index 0000000..ae77cc9 --- /dev/null +++ b/node_modules/express/node_modules/encodeurl/index.js @@ -0,0 +1,60 @@ +/*! + * encodeurl + * Copyright(c) 2016 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module exports. + * @public + */ + +module.exports = encodeUrl + +/** + * RegExp to match non-URL code points, *after* encoding (i.e. not including "%") + * and including invalid escape sequences. + * @private + */ + +var ENCODE_CHARS_REGEXP = /(?:[^\x21\x25\x26-\x3B\x3D\x3F-\x5B\x5D\x5F\x61-\x7A\x7E]|%(?:[^0-9A-Fa-f]|[0-9A-Fa-f][^0-9A-Fa-f]))+/g + +/** + * RegExp to match unmatched surrogate pair. + * @private + */ + +var UNMATCHED_SURROGATE_PAIR_REGEXP = /(^|[^\uD800-\uDBFF])[\uDC00-\uDFFF]|[\uD800-\uDBFF]([^\uDC00-\uDFFF]|$)/g + +/** + * String to replace unmatched surrogate pair with. + * @private + */ + +var UNMATCHED_SURROGATE_PAIR_REPLACE = '$1\uFFFD$2' + +/** + * Encode a URL to a percent-encoded form, excluding already-encoded sequences. + * + * This function will take an already-encoded URL and encode all the non-URL + * code points. This function will not encode the "%" character unless it is + * not part of a valid sequence (`%20` will be left as-is, but `%foo` will + * be encoded as `%25foo`). + * + * This encode is meant to be "safe" and does not throw errors. It will try as + * hard as it can to properly encode the given URL, including replacing any raw, + * unpaired surrogate pairs with the Unicode replacement character prior to + * encoding. + * + * @param {string} url + * @return {string} + * @public + */ + +function encodeUrl (url) { + return String(url) + .replace(UNMATCHED_SURROGATE_PAIR_REGEXP, UNMATCHED_SURROGATE_PAIR_REPLACE) + .replace(ENCODE_CHARS_REGEXP, encodeURI) +} diff --git a/node_modules/express/node_modules/encodeurl/package.json b/node_modules/express/node_modules/encodeurl/package.json new file mode 100644 index 0000000..563fef2 --- /dev/null +++ b/node_modules/express/node_modules/encodeurl/package.json @@ -0,0 +1,75 @@ +{ + "name": "encodeurl", + "description": "Encode a URL to a percent-encoded form, excluding already-encoded sequences", + "version": "1.0.1", + "contributors": [ + { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + } + ], + "license": "MIT", + "keywords": [ + "encode", + "encodeurl", + "url" + ], + "repository": { + "type": "git", + "url": "git+https://github.com/pillarjs/encodeurl.git" + }, + "devDependencies": { + "eslint": "2.11.1", + "eslint-config-standard": "5.3.1", + "eslint-plugin-promise": "1.3.2", + "eslint-plugin-standard": "1.3.2", + "istanbul": "0.4.3", + "mocha": "2.5.3" + }, + "files": [ + "LICENSE", + "HISTORY.md", + "README.md", + "index.js" + ], + "engines": { + "node": ">= 0.8" + }, + "scripts": { + "lint": "eslint **/*.js", + "test": "mocha --reporter spec --bail --check-leaks test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot --check-leaks test/", + "test-travis": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter spec --check-leaks test/" + }, + "gitHead": "39ed0c235fed4cea7d012038fd6bb0480561d226", + "bugs": { + "url": "https://github.com/pillarjs/encodeurl/issues" + }, + "homepage": "https://github.com/pillarjs/encodeurl#readme", + "_id": "encodeurl@1.0.1", + "_shasum": "79e3d58655346909fe6f0f45a5de68103b294d20", + "_from": "encodeurl@>=1.0.1 <1.1.0", + "_npmVersion": "2.15.1", + "_nodeVersion": "4.4.3", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "dist": { + "shasum": "79e3d58655346909fe6f0f45a5de68103b294d20", + "tarball": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.1.tgz" + }, + "maintainers": [ + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + } + ], + "_npmOperationalInternal": { + "host": "packages-12-west.internal.npmjs.com", + "tmp": "tmp/encodeurl-1.0.1.tgz_1465519736251_0.09314409433864057" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/encodeurl/-/encodeurl-1.0.1.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/express/node_modules/escape-html/LICENSE b/node_modules/express/node_modules/escape-html/LICENSE new file mode 100644 index 0000000..2e70de9 --- /dev/null +++ b/node_modules/express/node_modules/escape-html/LICENSE @@ -0,0 +1,24 @@ +(The MIT License) + +Copyright (c) 2012-2013 TJ Holowaychuk +Copyright (c) 2015 Andreas Lubbe +Copyright (c) 2015 Tiancheng "Timothy" Gu + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/express/node_modules/escape-html/Readme.md b/node_modules/express/node_modules/escape-html/Readme.md new file mode 100644 index 0000000..653d9ea --- /dev/null +++ b/node_modules/express/node_modules/escape-html/Readme.md @@ -0,0 +1,43 @@ + +# escape-html + + Escape string for use in HTML + +## Example + +```js +var escape = require('escape-html'); +var html = escape('foo & bar'); +// -> foo & bar +``` + +## Benchmark + +``` +$ npm run-script bench + +> escape-html@1.0.3 bench nodejs-escape-html +> node benchmark/index.js + + + http_parser@1.0 + node@0.10.33 + v8@3.14.5.9 + ares@1.9.0-DEV + uv@0.10.29 + zlib@1.2.3 + modules@11 + openssl@1.0.1j + + 1 test completed. + 2 tests completed. + 3 tests completed. + + no special characters x 19,435,271 ops/sec ±0.85% (187 runs sampled) + single special character x 6,132,421 ops/sec ±0.67% (194 runs sampled) + many special characters x 3,175,826 ops/sec ±0.65% (193 runs sampled) +``` + +## License + + MIT \ No newline at end of file diff --git a/node_modules/express/node_modules/escape-html/index.js b/node_modules/express/node_modules/escape-html/index.js new file mode 100644 index 0000000..bf9e226 --- /dev/null +++ b/node_modules/express/node_modules/escape-html/index.js @@ -0,0 +1,78 @@ +/*! + * escape-html + * Copyright(c) 2012-2013 TJ Holowaychuk + * Copyright(c) 2015 Andreas Lubbe + * Copyright(c) 2015 Tiancheng "Timothy" Gu + * MIT Licensed + */ + +'use strict'; + +/** + * Module variables. + * @private + */ + +var matchHtmlRegExp = /["'&<>]/; + +/** + * Module exports. + * @public + */ + +module.exports = escapeHtml; + +/** + * Escape special characters in the given string of html. + * + * @param {string} string The string to escape for inserting into HTML + * @return {string} + * @public + */ + +function escapeHtml(string) { + var str = '' + string; + var match = matchHtmlRegExp.exec(str); + + if (!match) { + return str; + } + + var escape; + var html = ''; + var index = 0; + var lastIndex = 0; + + for (index = match.index; index < str.length; index++) { + switch (str.charCodeAt(index)) { + case 34: // " + escape = '"'; + break; + case 38: // & + escape = '&'; + break; + case 39: // ' + escape = '''; + break; + case 60: // < + escape = '<'; + break; + case 62: // > + escape = '>'; + break; + default: + continue; + } + + if (lastIndex !== index) { + html += str.substring(lastIndex, index); + } + + lastIndex = index + 1; + html += escape; + } + + return lastIndex !== index + ? html + str.substring(lastIndex, index) + : html; +} diff --git a/node_modules/express/node_modules/escape-html/package.json b/node_modules/express/node_modules/escape-html/package.json new file mode 100644 index 0000000..c88a5be --- /dev/null +++ b/node_modules/express/node_modules/escape-html/package.json @@ -0,0 +1,57 @@ +{ + "name": "escape-html", + "description": "Escape string for use in HTML", + "version": "1.0.3", + "license": "MIT", + "keywords": [ + "escape", + "html", + "utility" + ], + "repository": { + "type": "git", + "url": "git+https://github.com/component/escape-html.git" + }, + "devDependencies": { + "benchmark": "1.0.0", + "beautify-benchmark": "0.2.4" + }, + "files": [ + "LICENSE", + "Readme.md", + "index.js" + ], + "scripts": { + "bench": "node benchmark/index.js" + }, + "gitHead": "7ac2ea3977fcac3d4c5be8d2a037812820c65f28", + "bugs": { + "url": "https://github.com/component/escape-html/issues" + }, + "homepage": "https://github.com/component/escape-html", + "_id": "escape-html@1.0.3", + "_shasum": "0258eae4d3d0c0974de1c169188ef0051d1d1988", + "_from": "escape-html@>=1.0.3 <1.1.0", + "_npmVersion": "1.4.28", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "maintainers": [ + { + "name": "tjholowaychuk", + "email": "tj@vision-media.ca" + }, + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + } + ], + "dist": { + "shasum": "0258eae4d3d0c0974de1c169188ef0051d1d1988", + "tarball": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/express/node_modules/etag/HISTORY.md b/node_modules/express/node_modules/etag/HISTORY.md new file mode 100644 index 0000000..bd0f26d --- /dev/null +++ b/node_modules/express/node_modules/etag/HISTORY.md @@ -0,0 +1,71 @@ +1.7.0 / 2015-06-08 +================== + + * Always include entity length in ETags for hash length extensions + * Generate non-Stats ETags using MD5 only (no longer CRC32) + * Improve stat performance by removing hashing + * Remove base64 padding in ETags to shorten + * Use MD5 instead of MD4 in weak ETags over 1KB + +1.6.0 / 2015-05-10 +================== + + * Improve support for JXcore + * Remove requirement of `atime` in the stats object + * Support "fake" stats objects in environments without `fs` + +1.5.1 / 2014-11-19 +================== + + * deps: crc@3.2.1 + - Minor fixes + +1.5.0 / 2014-10-14 +================== + + * Improve string performance + * Slightly improve speed for weak ETags over 1KB + +1.4.0 / 2014-09-21 +================== + + * Support "fake" stats objects + * Support Node.js 0.6 + +1.3.1 / 2014-09-14 +================== + + * Use the (new and improved) `crc` for crc32 + +1.3.0 / 2014-08-29 +================== + + * Default strings to strong ETags + * Improve speed for weak ETags over 1KB + +1.2.1 / 2014-08-29 +================== + + * Use the (much faster) `buffer-crc32` for crc32 + +1.2.0 / 2014-08-24 +================== + + * Add support for file stat objects + +1.1.0 / 2014-08-24 +================== + + * Add fast-path for empty entity + * Add weak ETag generation + * Shrink size of generated ETags + +1.0.1 / 2014-08-24 +================== + + * Fix behavior of string containing Unicode + +1.0.0 / 2014-05-18 +================== + + * Initial release diff --git a/node_modules/express/node_modules/etag/LICENSE b/node_modules/express/node_modules/etag/LICENSE new file mode 100644 index 0000000..142ede3 --- /dev/null +++ b/node_modules/express/node_modules/etag/LICENSE @@ -0,0 +1,22 @@ +(The MIT License) + +Copyright (c) 2014-2015 Douglas Christopher Wilson + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/express/node_modules/etag/README.md b/node_modules/express/node_modules/etag/README.md new file mode 100644 index 0000000..8da9e05 --- /dev/null +++ b/node_modules/express/node_modules/etag/README.md @@ -0,0 +1,165 @@ +# etag + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Node.js Version][node-version-image]][node-version-url] +[![Build Status][travis-image]][travis-url] +[![Test Coverage][coveralls-image]][coveralls-url] + +Create simple ETags + +## Installation + +```sh +$ npm install etag +``` + +## API + +```js +var etag = require('etag') +``` + +### etag(entity, [options]) + +Generate a strong ETag for the given entity. This should be the complete +body of the entity. Strings, `Buffer`s, and `fs.Stats` are accepted. By +default, a strong ETag is generated except for `fs.Stats`, which will +generate a weak ETag (this can be overwritten by `options.weak`). + +```js +res.setHeader('ETag', etag(body)) +``` + +#### Options + +`etag` accepts these properties in the options object. + +##### weak + +Specifies if the generated ETag will include the weak validator mark (that +is, the leading `W/`). The actual entity tag is the same. The default value +is `false`, unless the `entity` is `fs.Stats`, in which case it is `true`. + +## Testing + +```sh +$ npm test +``` + +## Benchmark + +```bash +$ npm run-script bench + +> etag@1.6.0 bench nodejs-etag +> node benchmark/index.js + + http_parser@1.0 + node@0.10.33 + v8@3.14.5.9 + ares@1.9.0-DEV + uv@0.10.29 + zlib@1.2.3 + modules@11 + openssl@1.0.1j + +> node benchmark/body0-100b.js + + 100B body + + 1 test completed. + 2 tests completed. + 3 tests completed. + 4 tests completed. + +* buffer - strong x 289,198 ops/sec ±1.09% (190 runs sampled) +* buffer - weak x 287,838 ops/sec ±0.91% (189 runs sampled) +* string - strong x 284,586 ops/sec ±1.05% (192 runs sampled) +* string - weak x 287,439 ops/sec ±0.82% (192 runs sampled) + +> node benchmark/body1-1kb.js + + 1KB body + + 1 test completed. + 2 tests completed. + 3 tests completed. + 4 tests completed. + +* buffer - strong x 212,423 ops/sec ±0.75% (193 runs sampled) +* buffer - weak x 211,871 ops/sec ±0.74% (194 runs sampled) + string - strong x 205,291 ops/sec ±0.86% (194 runs sampled) + string - weak x 208,463 ops/sec ±0.79% (192 runs sampled) + +> node benchmark/body2-5kb.js + + 5KB body + + 1 test completed. + 2 tests completed. + 3 tests completed. + 4 tests completed. + +* buffer - strong x 92,901 ops/sec ±0.58% (195 runs sampled) +* buffer - weak x 93,045 ops/sec ±0.65% (192 runs sampled) + string - strong x 89,621 ops/sec ±0.68% (194 runs sampled) + string - weak x 90,070 ops/sec ±0.70% (196 runs sampled) + +> node benchmark/body3-10kb.js + + 10KB body + + 1 test completed. + 2 tests completed. + 3 tests completed. + 4 tests completed. + +* buffer - strong x 54,220 ops/sec ±0.85% (192 runs sampled) +* buffer - weak x 54,069 ops/sec ±0.83% (191 runs sampled) + string - strong x 53,078 ops/sec ±0.53% (194 runs sampled) + string - weak x 53,849 ops/sec ±0.47% (197 runs sampled) + +> node benchmark/body4-100kb.js + + 100KB body + + 1 test completed. + 2 tests completed. + 3 tests completed. + 4 tests completed. + +* buffer - strong x 6,673 ops/sec ±0.15% (197 runs sampled) +* buffer - weak x 6,716 ops/sec ±0.12% (198 runs sampled) + string - strong x 6,357 ops/sec ±0.14% (197 runs sampled) + string - weak x 6,344 ops/sec ±0.21% (197 runs sampled) + +> node benchmark/stats.js + + stats + + 1 test completed. + 2 tests completed. + 3 tests completed. + 4 tests completed. + +* real - strong x 1,671,989 ops/sec ±0.13% (197 runs sampled) +* real - weak x 1,681,297 ops/sec ±0.12% (198 runs sampled) + fake - strong x 927,063 ops/sec ±0.14% (198 runs sampled) + fake - weak x 914,461 ops/sec ±0.41% (191 runs sampled) +``` + +## License + +[MIT](LICENSE) + +[npm-image]: https://img.shields.io/npm/v/etag.svg +[npm-url]: https://npmjs.org/package/etag +[node-version-image]: https://img.shields.io/node/v/etag.svg +[node-version-url]: http://nodejs.org/download/ +[travis-image]: https://img.shields.io/travis/jshttp/etag/master.svg +[travis-url]: https://travis-ci.org/jshttp/etag +[coveralls-image]: https://img.shields.io/coveralls/jshttp/etag/master.svg +[coveralls-url]: https://coveralls.io/r/jshttp/etag?branch=master +[downloads-image]: https://img.shields.io/npm/dm/etag.svg +[downloads-url]: https://npmjs.org/package/etag diff --git a/node_modules/express/node_modules/etag/index.js b/node_modules/express/node_modules/etag/index.js new file mode 100644 index 0000000..b582c84 --- /dev/null +++ b/node_modules/express/node_modules/etag/index.js @@ -0,0 +1,132 @@ +/*! + * etag + * Copyright(c) 2014-2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module exports. + * @public + */ + +module.exports = etag + +/** + * Module dependencies. + * @private + */ + +var crypto = require('crypto') +var Stats = require('fs').Stats + +/** + * Module variables. + * @private + */ + +var base64PadCharRegExp = /=+$/ +var toString = Object.prototype.toString + +/** + * Generate an entity tag. + * + * @param {Buffer|string} entity + * @return {string} + * @private + */ + +function entitytag(entity) { + if (entity.length === 0) { + // fast-path empty + return '"0-1B2M2Y8AsgTpgAmY7PhCfg"' + } + + // compute hash of entity + var hash = crypto + .createHash('md5') + .update(entity, 'utf8') + .digest('base64') + .replace(base64PadCharRegExp, '') + + // compute length of entity + var len = typeof entity === 'string' + ? Buffer.byteLength(entity, 'utf8') + : entity.length + + return '"' + len.toString(16) + '-' + hash + '"' +} + +/** + * Create a simple ETag. + * + * @param {string|Buffer|Stats} entity + * @param {object} [options] + * @param {boolean} [options.weak] + * @return {String} + * @public + */ + +function etag(entity, options) { + if (entity == null) { + throw new TypeError('argument entity is required') + } + + // support fs.Stats object + var isStats = isstats(entity) + var weak = options && typeof options.weak === 'boolean' + ? options.weak + : isStats + + // validate argument + if (!isStats && typeof entity !== 'string' && !Buffer.isBuffer(entity)) { + throw new TypeError('argument entity must be string, Buffer, or fs.Stats') + } + + // generate entity tag + var tag = isStats + ? stattag(entity) + : entitytag(entity) + + return weak + ? 'W/' + tag + : tag +} + +/** + * Determine if object is a Stats object. + * + * @param {object} obj + * @return {boolean} + * @api private + */ + +function isstats(obj) { + // genuine fs.Stats + if (typeof Stats === 'function' && obj instanceof Stats) { + return true + } + + // quack quack + return obj && typeof obj === 'object' + && 'ctime' in obj && toString.call(obj.ctime) === '[object Date]' + && 'mtime' in obj && toString.call(obj.mtime) === '[object Date]' + && 'ino' in obj && typeof obj.ino === 'number' + && 'size' in obj && typeof obj.size === 'number' +} + +/** + * Generate a tag for a stat. + * + * @param {object} stat + * @return {string} + * @private + */ + +function stattag(stat) { + var mtime = stat.mtime.getTime().toString(16) + var size = stat.size.toString(16) + + return '"' + size + '-' + mtime + '"' +} diff --git a/node_modules/express/node_modules/etag/package.json b/node_modules/express/node_modules/etag/package.json new file mode 100644 index 0000000..fadce32 --- /dev/null +++ b/node_modules/express/node_modules/etag/package.json @@ -0,0 +1,73 @@ +{ + "name": "etag", + "description": "Create simple ETags", + "version": "1.7.0", + "contributors": [ + { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "David Björklund", + "email": "david.bjorklund@gmail.com" + } + ], + "license": "MIT", + "keywords": [ + "etag", + "http", + "res" + ], + "repository": { + "type": "git", + "url": "git+https://github.com/jshttp/etag.git" + }, + "devDependencies": { + "benchmark": "1.0.0", + "beautify-benchmark": "0.2.4", + "istanbul": "0.3.14", + "mocha": "~1.21.4", + "seedrandom": "2.3.11" + }, + "files": [ + "LICENSE", + "HISTORY.md", + "README.md", + "index.js" + ], + "engines": { + "node": ">= 0.6" + }, + "scripts": { + "bench": "node benchmark/index.js", + "test": "mocha --reporter spec --bail --check-leaks test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot --check-leaks test/", + "test-travis": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter spec --check-leaks test/" + }, + "gitHead": "a511f5c8c930fd9546dbd88acb080f96bc788cfc", + "bugs": { + "url": "https://github.com/jshttp/etag/issues" + }, + "homepage": "https://github.com/jshttp/etag", + "_id": "etag@1.7.0", + "_shasum": "03d30b5f67dd6e632d2945d30d6652731a34d5d8", + "_from": "etag@>=1.7.0 <1.8.0", + "_npmVersion": "1.4.28", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "maintainers": [ + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + } + ], + "dist": { + "shasum": "03d30b5f67dd6e632d2945d30d6652731a34d5d8", + "tarball": "https://registry.npmjs.org/etag/-/etag-1.7.0.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/etag/-/etag-1.7.0.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/express/node_modules/finalhandler/HISTORY.md b/node_modules/express/node_modules/finalhandler/HISTORY.md new file mode 100644 index 0000000..e7e144c --- /dev/null +++ b/node_modules/express/node_modules/finalhandler/HISTORY.md @@ -0,0 +1,108 @@ +0.5.0 / 2016-06-15 +================== + + * Change invalid or non-numeric status code to 500 + * Overwrite status message to match set status code + * Prefer `err.statusCode` if `err.status` is invalid + * Set response headers from `err.headers` object + * Use `statuses` instead of `http` module for status messages + - Includes all defined status messages + +0.4.1 / 2015-12-02 +================== + + * deps: escape-html@~1.0.3 + - perf: enable strict mode + - perf: optimize string replacement + - perf: use faster string coercion + +0.4.0 / 2015-06-14 +================== + + * Fix a false-positive when unpiping in Node.js 0.8 + * Support `statusCode` property on `Error` objects + * Use `unpipe` module for unpiping requests + * deps: escape-html@1.0.2 + * deps: on-finished@~2.3.0 + - Add defined behavior for HTTP `CONNECT` requests + - Add defined behavior for HTTP `Upgrade` requests + - deps: ee-first@1.1.1 + * perf: enable strict mode + * perf: remove argument reassignment + +0.3.6 / 2015-05-11 +================== + + * deps: debug@~2.2.0 + - deps: ms@0.7.1 + +0.3.5 / 2015-04-22 +================== + + * deps: on-finished@~2.2.1 + - Fix `isFinished(req)` when data buffered + +0.3.4 / 2015-03-15 +================== + + * deps: debug@~2.1.3 + - Fix high intensity foreground color for bold + - deps: ms@0.7.0 + +0.3.3 / 2015-01-01 +================== + + * deps: debug@~2.1.1 + * deps: on-finished@~2.2.0 + +0.3.2 / 2014-10-22 +================== + + * deps: on-finished@~2.1.1 + - Fix handling of pipelined requests + +0.3.1 / 2014-10-16 +================== + + * deps: debug@~2.1.0 + - Implement `DEBUG_FD` env variable support + +0.3.0 / 2014-09-17 +================== + + * Terminate in progress response only on error + * Use `on-finished` to determine request status + +0.2.0 / 2014-09-03 +================== + + * Set `X-Content-Type-Options: nosniff` header + * deps: debug@~2.0.0 + +0.1.0 / 2014-07-16 +================== + + * Respond after request fully read + - prevents hung responses and socket hang ups + * deps: debug@1.0.4 + +0.0.3 / 2014-07-11 +================== + + * deps: debug@1.0.3 + - Add support for multiple wildcards in namespaces + +0.0.2 / 2014-06-19 +================== + + * Handle invalid status codes + +0.0.1 / 2014-06-05 +================== + + * deps: debug@1.0.2 + +0.0.0 / 2014-06-05 +================== + + * Extracted from connect/express diff --git a/node_modules/express/node_modules/finalhandler/LICENSE b/node_modules/express/node_modules/finalhandler/LICENSE new file mode 100644 index 0000000..b60a5ad --- /dev/null +++ b/node_modules/express/node_modules/finalhandler/LICENSE @@ -0,0 +1,22 @@ +(The MIT License) + +Copyright (c) 2014-2015 Douglas Christopher Wilson + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/express/node_modules/finalhandler/README.md b/node_modules/express/node_modules/finalhandler/README.md new file mode 100644 index 0000000..58bf720 --- /dev/null +++ b/node_modules/express/node_modules/finalhandler/README.md @@ -0,0 +1,142 @@ +# finalhandler + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Node.js Version][node-image]][node-url] +[![Build Status][travis-image]][travis-url] +[![Test Coverage][coveralls-image]][coveralls-url] + +Node.js function to invoke as the final step to respond to HTTP request. + +## Installation + +```sh +$ npm install finalhandler +``` + +## API + +```js +var finalhandler = require('finalhandler') +``` + +### finalhandler(req, res, [options]) + +Returns function to be invoked as the final step for the given `req` and `res`. +This function is to be invoked as `fn(err)`. If `err` is falsy, the handler will +write out a 404 response to the `res`. If it is truthy, an error response will +be written out to the `res`. + +When an error is written, the following information is added to the response: + + * The `res.statusCode` is set from `err.status` (or `err.statusCode`). If + this value is outside the 4xx or 5xx range, it will be set to 500. + * The `res.statusMessage` is set according to the status code. + * The body will be the HTML of the status code message if `env` is + `'production'`, otherwise will be `err.stack`. + * Any headers specified in an `err.headers` object. + +The final handler will also unpipe anything from `req` when it is invoked. + +#### options.env + +By default, the environment is determined by `NODE_ENV` variable, but it can be +overridden by this option. + +#### options.onerror + +Provide a function to be called with the `err` when it exists. Can be used for +writing errors to a central location without excessive function generation. Called +as `onerror(err, req, res)`. + +## Examples + +### always 404 + +```js +var finalhandler = require('finalhandler') +var http = require('http') + +var server = http.createServer(function (req, res) { + var done = finalhandler(req, res) + done() +}) + +server.listen(3000) +``` + +### perform simple action + +```js +var finalhandler = require('finalhandler') +var fs = require('fs') +var http = require('http') + +var server = http.createServer(function (req, res) { + var done = finalhandler(req, res) + + fs.readFile('index.html', function (err, buf) { + if (err) return done(err) + res.setHeader('Content-Type', 'text/html') + res.end(buf) + }) +}) + +server.listen(3000) +``` + +### use with middleware-style functions + +```js +var finalhandler = require('finalhandler') +var http = require('http') +var serveStatic = require('serve-static') + +var serve = serveStatic('public') + +var server = http.createServer(function (req, res) { + var done = finalhandler(req, res) + serve(req, res, done) +}) + +server.listen(3000) +``` + +### keep log of all errors + +```js +var finalhandler = require('finalhandler') +var fs = require('fs') +var http = require('http') + +var server = http.createServer(function (req, res) { + var done = finalhandler(req, res, {onerror: logerror}) + + fs.readFile('index.html', function (err, buf) { + if (err) return done(err) + res.setHeader('Content-Type', 'text/html') + res.end(buf) + }) +}) + +server.listen(3000) + +function logerror(err) { + console.error(err.stack || err.toString()) +} +``` + +## License + +[MIT](LICENSE) + +[npm-image]: https://img.shields.io/npm/v/finalhandler.svg +[npm-url]: https://npmjs.org/package/finalhandler +[node-image]: https://img.shields.io/node/v/finalhandler.svg +[node-url]: https://nodejs.org/en/download +[travis-image]: https://img.shields.io/travis/pillarjs/finalhandler.svg +[travis-url]: https://travis-ci.org/pillarjs/finalhandler +[coveralls-image]: https://img.shields.io/coveralls/pillarjs/finalhandler.svg +[coveralls-url]: https://coveralls.io/r/pillarjs/finalhandler?branch=master +[downloads-image]: https://img.shields.io/npm/dm/finalhandler.svg +[downloads-url]: https://npmjs.org/package/finalhandler diff --git a/node_modules/express/node_modules/finalhandler/index.js b/node_modules/express/node_modules/finalhandler/index.js new file mode 100644 index 0000000..884d802 --- /dev/null +++ b/node_modules/express/node_modules/finalhandler/index.js @@ -0,0 +1,189 @@ +/*! + * finalhandler + * Copyright(c) 2014-2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module dependencies. + * @private + */ + +var debug = require('debug')('finalhandler') +var escapeHtml = require('escape-html') +var onFinished = require('on-finished') +var statuses = require('statuses') +var unpipe = require('unpipe') + +/** + * Module variables. + * @private + */ + +/* istanbul ignore next */ +var defer = typeof setImmediate === 'function' + ? setImmediate + : function (fn) { process.nextTick(fn.bind.apply(fn, arguments)) } +var isFinished = onFinished.isFinished + +/** + * Module exports. + * @public + */ + +module.exports = finalhandler + +/** + * Create a function to handle the final response. + * + * @param {Request} req + * @param {Response} res + * @param {Object} [options] + * @return {Function} + * @public + */ + +function finalhandler (req, res, options) { + var opts = options || {} + + // get environment + var env = opts.env || process.env.NODE_ENV || 'development' + + // get error callback + var onerror = opts.onerror + + return function (err) { + var headers = Object.create(null) + var status + + // ignore 404 on in-flight response + if (!err && res._header) { + debug('cannot 404 after headers sent') + return + } + + // unhandled error + if (err) { + // respect status code from error + status = getErrorStatusCode(err) || res.statusCode + + // default status code to 500 if outside valid range + if (typeof status !== 'number' || status < 400 || status > 599) { + status = 500 + } + + // respect err.headers + if (err.headers && (err.status === status || err.statusCode === status)) { + var keys = Object.keys(err.headers) + for (var i = 0; i < keys.length; i++) { + var key = keys[i] + headers[key] = err.headers[key] + } + } + + // production gets a basic error message + var msg = env === 'production' + ? statuses[status] + : err.stack || err.toString() + msg = escapeHtml(msg) + .replace(/\n/g, '
') + .replace(/\x20{2}/g, '  ') + '\n' + } else { + status = 404 + msg = 'Cannot ' + escapeHtml(req.method) + ' ' + escapeHtml(req.originalUrl || req.url) + '\n' + } + + debug('default %s', status) + + // schedule onerror callback + if (err && onerror) { + defer(onerror, err, req, res) + } + + // cannot actually respond + if (res._header) { + debug('cannot %d after headers sent', status) + req.socket.destroy() + return + } + + // send response + send(req, res, status, headers, msg) + } +} + +/** + * Get status code from Error object. + * + * @param {Error} err + * @return {number} + * @private + */ + +function getErrorStatusCode (err) { + // check err.status + if (typeof err.status === 'number' && err.status >= 400 && err.status < 600) { + return err.status + } + + // check err.statusCode + if (typeof err.statusCode === 'number' && err.statusCode >= 400 && err.statusCode < 600) { + return err.statusCode + } + + return undefined +} + +/** + * Send response. + * + * @param {IncomingMessage} req + * @param {OutgoingMessage} res + * @param {number} status + * @param {object} headers + * @param {string} body + * @private + */ + +function send (req, res, status, headers, body) { + function write () { + // response status + res.statusCode = status + res.statusMessage = statuses[status] + + // response headers + var keys = Object.keys(headers) + for (var i = 0; i < keys.length; i++) { + var key = keys[i] + res.setHeader(key, headers[key]) + } + + // security header for content sniffing + res.setHeader('X-Content-Type-Options', 'nosniff') + + // standard headers + res.setHeader('Content-Type', 'text/html; charset=utf-8') + res.setHeader('Content-Length', Buffer.byteLength(body, 'utf8')) + + if (req.method === 'HEAD') { + res.end() + return + } + + res.end(body, 'utf8') + } + + if (isFinished(req)) { + write() + return + } + + // unpipe everything from the request + unpipe(req) + + // flush the request + onFinished(req, write) + req.resume() +} diff --git a/node_modules/express/node_modules/finalhandler/node_modules/statuses/HISTORY.md b/node_modules/express/node_modules/finalhandler/node_modules/statuses/HISTORY.md new file mode 100644 index 0000000..b175575 --- /dev/null +++ b/node_modules/express/node_modules/finalhandler/node_modules/statuses/HISTORY.md @@ -0,0 +1,50 @@ +1.3.0 / 2016-05-17 +================== + + * Add `421 Misdirected Request` + * perf: enable strict mode + +1.2.1 / 2015-02-01 +================== + + * Fix message for status 451 + - `451 Unavailable For Legal Reasons` + +1.2.0 / 2014-09-28 +================== + + * Add `208 Already Repored` + * Add `226 IM Used` + * Add `306 (Unused)` + * Add `415 Unable For Legal Reasons` + * Add `508 Loop Detected` + +1.1.1 / 2014-09-24 +================== + + * Add missing 308 to `codes.json` + +1.1.0 / 2014-09-21 +================== + + * Add `codes.json` for universal support + +1.0.4 / 2014-08-20 +================== + + * Package cleanup + +1.0.3 / 2014-06-08 +================== + + * Add 308 to `.redirect` category + +1.0.2 / 2014-03-13 +================== + + * Add `.retry` category + +1.0.1 / 2014-03-12 +================== + + * Initial release diff --git a/node_modules/express/node_modules/finalhandler/node_modules/statuses/LICENSE b/node_modules/express/node_modules/finalhandler/node_modules/statuses/LICENSE new file mode 100644 index 0000000..82af4df --- /dev/null +++ b/node_modules/express/node_modules/finalhandler/node_modules/statuses/LICENSE @@ -0,0 +1,23 @@ + +The MIT License (MIT) + +Copyright (c) 2014 Jonathan Ong me@jongleberry.com +Copyright (c) 2016 Douglas Christopher Wilson doug@somethingdoug.com + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. diff --git a/node_modules/express/node_modules/finalhandler/node_modules/statuses/README.md b/node_modules/express/node_modules/finalhandler/node_modules/statuses/README.md new file mode 100644 index 0000000..1a699da --- /dev/null +++ b/node_modules/express/node_modules/finalhandler/node_modules/statuses/README.md @@ -0,0 +1,114 @@ +# Statuses + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Node.js Version][node-version-image]][node-version-url] +[![Build Status][travis-image]][travis-url] +[![Test Coverage][coveralls-image]][coveralls-url] + +HTTP status utility for node. + +## API + +```js +var status = require('statuses') +``` + +### var code = status(Integer || String) + +If `Integer` or `String` is a valid HTTP code or status message, then the appropriate `code` will be returned. Otherwise, an error will be thrown. + +```js +status(403) // => 403 +status('403') // => 403 +status('forbidden') // => 403 +status('Forbidden') // => 403 +status(306) // throws, as it's not supported by node.js +``` + +### status.codes + +Returns an array of all the status codes as `Integer`s. + +### var msg = status[code] + +Map of `code` to `status message`. `undefined` for invalid `code`s. + +```js +status[404] // => 'Not Found' +``` + +### var code = status[msg] + +Map of `status message` to `code`. `msg` can either be title-cased or lower-cased. `undefined` for invalid `status message`s. + +```js +status['not found'] // => 404 +status['Not Found'] // => 404 +``` + +### status.redirect[code] + +Returns `true` if a status code is a valid redirect status. + +```js +status.redirect[200] // => undefined +status.redirect[301] // => true +``` + +### status.empty[code] + +Returns `true` if a status code expects an empty body. + +```js +status.empty[200] // => undefined +status.empty[204] // => true +status.empty[304] // => true +``` + +### status.retry[code] + +Returns `true` if you should retry the rest. + +```js +status.retry[501] // => undefined +status.retry[503] // => true +``` + +### statuses/codes.json + +```js +var codes = require('statuses/codes.json') +``` + +This is a JSON file of the status codes +taken from `require('http').STATUS_CODES`. +This is saved so that codes are consistent even in older node.js versions. +For example, `308` will be added in v0.12. + +## Adding Status Codes + +The status codes are primarily sourced from http://www.iana.org/assignments/http-status-codes/http-status-codes-1.csv. +Additionally, custom codes are added from http://en.wikipedia.org/wiki/List_of_HTTP_status_codes. +These are added manually in the `lib/*.json` files. +If you would like to add a status code, add it to the appropriate JSON file. + +To rebuild `codes.json`, run the following: + +```bash +# update src/iana.json +npm run fetch +# build codes.json +npm run build +``` + +[npm-image]: https://img.shields.io/npm/v/statuses.svg +[npm-url]: https://npmjs.org/package/statuses +[node-version-image]: https://img.shields.io/badge/node.js-%3E%3D_0.6-brightgreen.svg +[node-version-url]: https://nodejs.org/en/download +[travis-image]: https://img.shields.io/travis/jshttp/statuses.svg +[travis-url]: https://travis-ci.org/jshttp/statuses +[coveralls-image]: https://img.shields.io/coveralls/jshttp/statuses.svg +[coveralls-url]: https://coveralls.io/r/jshttp/statuses?branch=master +[downloads-image]: https://img.shields.io/npm/dm/statuses.svg +[downloads-url]: https://npmjs.org/package/statuses diff --git a/node_modules/express/node_modules/finalhandler/node_modules/statuses/codes.json b/node_modules/express/node_modules/finalhandler/node_modules/statuses/codes.json new file mode 100644 index 0000000..e765123 --- /dev/null +++ b/node_modules/express/node_modules/finalhandler/node_modules/statuses/codes.json @@ -0,0 +1,65 @@ +{ + "100": "Continue", + "101": "Switching Protocols", + "102": "Processing", + "200": "OK", + "201": "Created", + "202": "Accepted", + "203": "Non-Authoritative Information", + "204": "No Content", + "205": "Reset Content", + "206": "Partial Content", + "207": "Multi-Status", + "208": "Already Reported", + "226": "IM Used", + "300": "Multiple Choices", + "301": "Moved Permanently", + "302": "Found", + "303": "See Other", + "304": "Not Modified", + "305": "Use Proxy", + "306": "(Unused)", + "307": "Temporary Redirect", + "308": "Permanent Redirect", + "400": "Bad Request", + "401": "Unauthorized", + "402": "Payment Required", + "403": "Forbidden", + "404": "Not Found", + "405": "Method Not Allowed", + "406": "Not Acceptable", + "407": "Proxy Authentication Required", + "408": "Request Timeout", + "409": "Conflict", + "410": "Gone", + "411": "Length Required", + "412": "Precondition Failed", + "413": "Payload Too Large", + "414": "URI Too Long", + "415": "Unsupported Media Type", + "416": "Range Not Satisfiable", + "417": "Expectation Failed", + "418": "I'm a teapot", + "421": "Misdirected Request", + "422": "Unprocessable Entity", + "423": "Locked", + "424": "Failed Dependency", + "425": "Unordered Collection", + "426": "Upgrade Required", + "428": "Precondition Required", + "429": "Too Many Requests", + "431": "Request Header Fields Too Large", + "451": "Unavailable For Legal Reasons", + "500": "Internal Server Error", + "501": "Not Implemented", + "502": "Bad Gateway", + "503": "Service Unavailable", + "504": "Gateway Timeout", + "505": "HTTP Version Not Supported", + "506": "Variant Also Negotiates", + "507": "Insufficient Storage", + "508": "Loop Detected", + "509": "Bandwidth Limit Exceeded", + "510": "Not Extended", + "511": "Network Authentication Required" +} \ No newline at end of file diff --git a/node_modules/express/node_modules/finalhandler/node_modules/statuses/index.js b/node_modules/express/node_modules/finalhandler/node_modules/statuses/index.js new file mode 100644 index 0000000..c2b555a --- /dev/null +++ b/node_modules/express/node_modules/finalhandler/node_modules/statuses/index.js @@ -0,0 +1,110 @@ +/*! + * statuses + * Copyright(c) 2014 Jonathan Ong + * Copyright(c) 2016 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module dependencies. + * @private + */ + +var codes = require('./codes.json') + +/** + * Module exports. + * @public + */ + +module.exports = status + +// array of status codes +status.codes = populateStatusesMap(status, codes) + +// status codes for redirects +status.redirect = { + 300: true, + 301: true, + 302: true, + 303: true, + 305: true, + 307: true, + 308: true +} + +// status codes for empty bodies +status.empty = { + 204: true, + 205: true, + 304: true +} + +// status codes for when you should retry the request +status.retry = { + 502: true, + 503: true, + 504: true +} + +/** + * Populate the statuses map for given codes. + * @private + */ + +function populateStatusesMap (statuses, codes) { + var arr = [] + + Object.keys(codes).forEach(function forEachCode (code) { + var message = codes[code] + var status = Number(code) + + // Populate properties + statuses[status] = message + statuses[message] = status + statuses[message.toLowerCase()] = status + + // Add to array + arr.push(status) + }) + + return arr +} + +/** + * Get the status code. + * + * Given a number, this will throw if it is not a known status + * code, otherwise the code will be returned. Given a string, + * the string will be parsed for a number and return the code + * if valid, otherwise will lookup the code assuming this is + * the status message. + * + * @param {string|number} code + * @returns {string} + * @public + */ + +function status (code) { + if (typeof code === 'number') { + if (!status[code]) throw new Error('invalid status code: ' + code) + return code + } + + if (typeof code !== 'string') { + throw new TypeError('code must be a number or string') + } + + // '403' + var n = parseInt(code, 10) + if (!isNaN(n)) { + if (!status[n]) throw new Error('invalid status code: ' + n) + return n + } + + n = status[code.toLowerCase()] + if (!n) throw new Error('invalid status message: "' + code + '"') + return n +} diff --git a/node_modules/express/node_modules/finalhandler/node_modules/statuses/package.json b/node_modules/express/node_modules/finalhandler/node_modules/statuses/package.json new file mode 100644 index 0000000..52e1ae3 --- /dev/null +++ b/node_modules/express/node_modules/finalhandler/node_modules/statuses/package.json @@ -0,0 +1,104 @@ +{ + "name": "statuses", + "description": "HTTP status utility", + "version": "1.3.0", + "contributors": [ + { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "Jonathan Ong", + "email": "me@jongleberry.com", + "url": "http://jongleberry.com" + } + ], + "repository": { + "type": "git", + "url": "git+https://github.com/jshttp/statuses.git" + }, + "license": "MIT", + "keywords": [ + "http", + "status", + "code" + ], + "files": [ + "HISTORY.md", + "index.js", + "codes.json", + "LICENSE" + ], + "devDependencies": { + "csv-parse": "1.0.1", + "eslint": "2.10.2", + "eslint-config-standard": "5.3.1", + "eslint-plugin-promise": "1.1.0", + "eslint-plugin-standard": "1.3.2", + "istanbul": "0.4.3", + "mocha": "1.21.5", + "stream-to-array": "2.2.0" + }, + "engines": { + "node": ">= 0.6" + }, + "scripts": { + "build": "node scripts/build.js", + "fetch": "node scripts/fetch.js", + "lint": "eslint **/*.js", + "test": "mocha --reporter spec --check-leaks --bail test/", + "test-ci": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter spec --check-leaks test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot --check-leaks test/", + "update": "npm run fetch && npm run build" + }, + "gitHead": "b3e31e8c32dd8107e898b44b8c0b2dfff3cba495", + "bugs": { + "url": "https://github.com/jshttp/statuses/issues" + }, + "homepage": "https://github.com/jshttp/statuses", + "_id": "statuses@1.3.0", + "_shasum": "8e55758cb20e7682c1f4fce8dcab30bf01d1e07a", + "_from": "statuses@>=1.3.0 <1.4.0", + "_npmVersion": "1.4.28", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "maintainers": [ + { + "name": "defunctzombie", + "email": "shtylman@gmail.com" + }, + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "fishrock123", + "email": "fishrock123@rocketmail.com" + }, + { + "name": "jongleberry", + "email": "jonathanrichardong@gmail.com" + }, + { + "name": "mscdex", + "email": "mscdex@mscdex.net" + }, + { + "name": "tjholowaychuk", + "email": "tj@vision-media.ca" + } + ], + "dist": { + "shasum": "8e55758cb20e7682c1f4fce8dcab30bf01d1e07a", + "tarball": "https://registry.npmjs.org/statuses/-/statuses-1.3.0.tgz" + }, + "_npmOperationalInternal": { + "host": "packages-12-west.internal.npmjs.com", + "tmp": "tmp/statuses-1.3.0.tgz_1463517875633_0.19560232176445425" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/statuses/-/statuses-1.3.0.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/express/node_modules/finalhandler/node_modules/unpipe/HISTORY.md b/node_modules/express/node_modules/finalhandler/node_modules/unpipe/HISTORY.md new file mode 100644 index 0000000..85e0f8d --- /dev/null +++ b/node_modules/express/node_modules/finalhandler/node_modules/unpipe/HISTORY.md @@ -0,0 +1,4 @@ +1.0.0 / 2015-06-14 +================== + + * Initial release diff --git a/node_modules/express/node_modules/finalhandler/node_modules/unpipe/LICENSE b/node_modules/express/node_modules/finalhandler/node_modules/unpipe/LICENSE new file mode 100644 index 0000000..aed0138 --- /dev/null +++ b/node_modules/express/node_modules/finalhandler/node_modules/unpipe/LICENSE @@ -0,0 +1,22 @@ +(The MIT License) + +Copyright (c) 2015 Douglas Christopher Wilson + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/express/node_modules/finalhandler/node_modules/unpipe/README.md b/node_modules/express/node_modules/finalhandler/node_modules/unpipe/README.md new file mode 100644 index 0000000..e536ad2 --- /dev/null +++ b/node_modules/express/node_modules/finalhandler/node_modules/unpipe/README.md @@ -0,0 +1,43 @@ +# unpipe + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Node.js Version][node-image]][node-url] +[![Build Status][travis-image]][travis-url] +[![Test Coverage][coveralls-image]][coveralls-url] + +Unpipe a stream from all destinations. + +## Installation + +```sh +$ npm install unpipe +``` + +## API + +```js +var unpipe = require('unpipe') +``` + +### unpipe(stream) + +Unpipes all destinations from a given stream. With stream 2+, this is +equivalent to `stream.unpipe()`. When used with streams 1 style streams +(typically Node.js 0.8 and below), this module attempts to undo the +actions done in `stream.pipe(dest)`. + +## License + +[MIT](LICENSE) + +[npm-image]: https://img.shields.io/npm/v/unpipe.svg +[npm-url]: https://npmjs.org/package/unpipe +[node-image]: https://img.shields.io/node/v/unpipe.svg +[node-url]: http://nodejs.org/download/ +[travis-image]: https://img.shields.io/travis/stream-utils/unpipe.svg +[travis-url]: https://travis-ci.org/stream-utils/unpipe +[coveralls-image]: https://img.shields.io/coveralls/stream-utils/unpipe.svg +[coveralls-url]: https://coveralls.io/r/stream-utils/unpipe?branch=master +[downloads-image]: https://img.shields.io/npm/dm/unpipe.svg +[downloads-url]: https://npmjs.org/package/unpipe diff --git a/node_modules/express/node_modules/finalhandler/node_modules/unpipe/index.js b/node_modules/express/node_modules/finalhandler/node_modules/unpipe/index.js new file mode 100644 index 0000000..15c3d97 --- /dev/null +++ b/node_modules/express/node_modules/finalhandler/node_modules/unpipe/index.js @@ -0,0 +1,69 @@ +/*! + * unpipe + * Copyright(c) 2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module exports. + * @public + */ + +module.exports = unpipe + +/** + * Determine if there are Node.js pipe-like data listeners. + * @private + */ + +function hasPipeDataListeners(stream) { + var listeners = stream.listeners('data') + + for (var i = 0; i < listeners.length; i++) { + if (listeners[i].name === 'ondata') { + return true + } + } + + return false +} + +/** + * Unpipe a stream from all destinations. + * + * @param {object} stream + * @public + */ + +function unpipe(stream) { + if (!stream) { + throw new TypeError('argument stream is required') + } + + if (typeof stream.unpipe === 'function') { + // new-style + stream.unpipe() + return + } + + // Node.js 0.8 hack + if (!hasPipeDataListeners(stream)) { + return + } + + var listener + var listeners = stream.listeners('close') + + for (var i = 0; i < listeners.length; i++) { + listener = listeners[i] + + if (listener.name !== 'cleanup' && listener.name !== 'onclose') { + continue + } + + // invoke the listener + listener.call(stream) + } +} diff --git a/node_modules/express/node_modules/finalhandler/node_modules/unpipe/package.json b/node_modules/express/node_modules/finalhandler/node_modules/unpipe/package.json new file mode 100644 index 0000000..6fd79bc --- /dev/null +++ b/node_modules/express/node_modules/finalhandler/node_modules/unpipe/package.json @@ -0,0 +1,59 @@ +{ + "name": "unpipe", + "description": "Unpipe a stream from all destinations", + "version": "1.0.0", + "author": { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + }, + "license": "MIT", + "repository": { + "type": "git", + "url": "git+https://github.com/stream-utils/unpipe.git" + }, + "devDependencies": { + "istanbul": "0.3.15", + "mocha": "2.2.5", + "readable-stream": "1.1.13" + }, + "files": [ + "HISTORY.md", + "LICENSE", + "README.md", + "index.js" + ], + "engines": { + "node": ">= 0.8" + }, + "scripts": { + "test": "mocha --reporter spec --bail --check-leaks test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot --check-leaks test/", + "test-travis": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter spec --check-leaks test/" + }, + "gitHead": "d2df901c06487430e78dca62b6edb8bb2fc5e99d", + "bugs": { + "url": "https://github.com/stream-utils/unpipe/issues" + }, + "homepage": "https://github.com/stream-utils/unpipe", + "_id": "unpipe@1.0.0", + "_shasum": "b2bf4ee8514aae6165b4817829d21b2ef49904ec", + "_from": "unpipe@>=1.0.0 <1.1.0", + "_npmVersion": "1.4.28", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "maintainers": [ + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + } + ], + "dist": { + "shasum": "b2bf4ee8514aae6165b4817829d21b2ef49904ec", + "tarball": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/express/node_modules/finalhandler/package.json b/node_modules/express/node_modules/finalhandler/package.json new file mode 100644 index 0000000..9dbfa43 --- /dev/null +++ b/node_modules/express/node_modules/finalhandler/package.json @@ -0,0 +1,75 @@ +{ + "name": "finalhandler", + "description": "Node.js final http responder", + "version": "0.5.0", + "author": { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + }, + "license": "MIT", + "repository": { + "type": "git", + "url": "git+https://github.com/pillarjs/finalhandler.git" + }, + "dependencies": { + "debug": "~2.2.0", + "escape-html": "~1.0.3", + "on-finished": "~2.3.0", + "statuses": "~1.3.0", + "unpipe": "~1.0.0" + }, + "devDependencies": { + "eslint": "2.12.0", + "eslint-config-standard": "5.3.1", + "eslint-plugin-promise": "1.3.2", + "eslint-plugin-standard": "1.3.2", + "istanbul": "0.4.3", + "mocha": "2.5.3", + "readable-stream": "2.1.2", + "supertest": "1.1.0" + }, + "files": [ + "LICENSE", + "HISTORY.md", + "index.js" + ], + "engines": { + "node": ">= 0.8" + }, + "scripts": { + "lint": "eslint **/*.js", + "test": "mocha --reporter spec --bail --check-leaks test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot --check-leaks test/", + "test-travis": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter spec --check-leaks test/" + }, + "gitHead": "15cc543eb87dd0e2f29e931d86816a6eb348c573", + "bugs": { + "url": "https://github.com/pillarjs/finalhandler/issues" + }, + "homepage": "https://github.com/pillarjs/finalhandler", + "_id": "finalhandler@0.5.0", + "_shasum": "e9508abece9b6dba871a6942a1d7911b91911ac7", + "_from": "finalhandler@0.5.0", + "_npmVersion": "1.4.28", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "maintainers": [ + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + } + ], + "dist": { + "shasum": "e9508abece9b6dba871a6942a1d7911b91911ac7", + "tarball": "https://registry.npmjs.org/finalhandler/-/finalhandler-0.5.0.tgz" + }, + "_npmOperationalInternal": { + "host": "packages-12-west.internal.npmjs.com", + "tmp": "tmp/finalhandler-0.5.0.tgz_1466028655505_0.19758180482313037" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/finalhandler/-/finalhandler-0.5.0.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/express/node_modules/fresh/HISTORY.md b/node_modules/express/node_modules/fresh/HISTORY.md new file mode 100644 index 0000000..3c95fbb --- /dev/null +++ b/node_modules/express/node_modules/fresh/HISTORY.md @@ -0,0 +1,38 @@ +0.3.0 / 2015-05-12 +================== + + * Add weak `ETag` matching support + +0.2.4 / 2014-09-07 +================== + + * Support Node.js 0.6 + +0.2.3 / 2014-09-07 +================== + + * Move repository to jshttp + +0.2.2 / 2014-02-19 +================== + + * Revert "Fix for blank page on Safari reload" + +0.2.1 / 2014-01-29 +================== + + * Fix for blank page on Safari reload + +0.2.0 / 2013-08-11 +================== + + * Return stale for `Cache-Control: no-cache` + +0.1.0 / 2012-06-15 +================== + * Add `If-None-Match: *` support + +0.0.1 / 2012-06-10 +================== + + * Initial release diff --git a/node_modules/express/node_modules/fresh/LICENSE b/node_modules/express/node_modules/fresh/LICENSE new file mode 100644 index 0000000..f527394 --- /dev/null +++ b/node_modules/express/node_modules/fresh/LICENSE @@ -0,0 +1,22 @@ +(The MIT License) + +Copyright (c) 2012 TJ Holowaychuk + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/express/node_modules/fresh/README.md b/node_modules/express/node_modules/fresh/README.md new file mode 100644 index 0000000..0813e30 --- /dev/null +++ b/node_modules/express/node_modules/fresh/README.md @@ -0,0 +1,58 @@ +# fresh + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Node.js Version][node-version-image]][node-version-url] +[![Build Status][travis-image]][travis-url] +[![Test Coverage][coveralls-image]][coveralls-url] + +HTTP response freshness testing + +## Installation + +``` +$ npm install fresh +``` + +## API + +```js +var fresh = require('fresh') +``` + +### fresh(req, res) + + Check freshness of `req` and `res` headers. + + When the cache is "fresh" __true__ is returned, + otherwise __false__ is returned to indicate that + the cache is now stale. + +## Example + +```js +var req = { 'if-none-match': 'tobi' }; +var res = { 'etag': 'luna' }; +fresh(req, res); +// => false + +var req = { 'if-none-match': 'tobi' }; +var res = { 'etag': 'tobi' }; +fresh(req, res); +// => true +``` + +## License + +[MIT](LICENSE) + +[npm-image]: https://img.shields.io/npm/v/fresh.svg +[npm-url]: https://npmjs.org/package/fresh +[node-version-image]: https://img.shields.io/node/v/fresh.svg +[node-version-url]: http://nodejs.org/download/ +[travis-image]: https://img.shields.io/travis/jshttp/fresh/master.svg +[travis-url]: https://travis-ci.org/jshttp/fresh +[coveralls-image]: https://img.shields.io/coveralls/jshttp/fresh/master.svg +[coveralls-url]: https://coveralls.io/r/jshttp/fresh?branch=master +[downloads-image]: https://img.shields.io/npm/dm/fresh.svg +[downloads-url]: https://npmjs.org/package/fresh diff --git a/node_modules/express/node_modules/fresh/index.js b/node_modules/express/node_modules/fresh/index.js new file mode 100644 index 0000000..a900873 --- /dev/null +++ b/node_modules/express/node_modules/fresh/index.js @@ -0,0 +1,57 @@ + +/** + * Expose `fresh()`. + */ + +module.exports = fresh; + +/** + * Check freshness of `req` and `res` headers. + * + * When the cache is "fresh" __true__ is returned, + * otherwise __false__ is returned to indicate that + * the cache is now stale. + * + * @param {Object} req + * @param {Object} res + * @return {Boolean} + * @api public + */ + +function fresh(req, res) { + // defaults + var etagMatches = true; + var notModified = true; + + // fields + var modifiedSince = req['if-modified-since']; + var noneMatch = req['if-none-match']; + var lastModified = res['last-modified']; + var etag = res['etag']; + var cc = req['cache-control']; + + // unconditional request + if (!modifiedSince && !noneMatch) return false; + + // check for no-cache cache request directive + if (cc && cc.indexOf('no-cache') !== -1) return false; + + // parse if-none-match + if (noneMatch) noneMatch = noneMatch.split(/ *, */); + + // if-none-match + if (noneMatch) { + etagMatches = noneMatch.some(function (match) { + return match === '*' || match === etag || match === 'W/' + etag; + }); + } + + // if-modified-since + if (modifiedSince) { + modifiedSince = new Date(modifiedSince); + lastModified = new Date(lastModified); + notModified = lastModified <= modifiedSince; + } + + return !! (etagMatches && notModified); +} diff --git a/node_modules/express/node_modules/fresh/package.json b/node_modules/express/node_modules/fresh/package.json new file mode 100644 index 0000000..a7c7724 --- /dev/null +++ b/node_modules/express/node_modules/fresh/package.json @@ -0,0 +1,87 @@ +{ + "name": "fresh", + "description": "HTTP response freshness testing", + "version": "0.3.0", + "author": { + "name": "TJ Holowaychuk", + "email": "tj@vision-media.ca", + "url": "http://tjholowaychuk.com" + }, + "contributors": [ + { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "Jonathan Ong", + "email": "me@jongleberry.com", + "url": "http://jongleberry.com" + } + ], + "license": "MIT", + "keywords": [ + "fresh", + "http", + "conditional", + "cache" + ], + "repository": { + "type": "git", + "url": "git+https://github.com/jshttp/fresh.git" + }, + "devDependencies": { + "istanbul": "0.3.9", + "mocha": "1.21.5" + }, + "files": [ + "HISTORY.md", + "LICENSE", + "index.js" + ], + "engines": { + "node": ">= 0.6" + }, + "scripts": { + "test": "mocha --reporter spec --bail --check-leaks test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot --check-leaks test/", + "test-travis": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter spec --check-leaks test/" + }, + "gitHead": "14616c9748368ca08cd6a955dd88ab659b778634", + "bugs": { + "url": "https://github.com/jshttp/fresh/issues" + }, + "homepage": "https://github.com/jshttp/fresh", + "_id": "fresh@0.3.0", + "_shasum": "651f838e22424e7566de161d8358caa199f83d4f", + "_from": "fresh@0.3.0", + "_npmVersion": "1.4.28", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "maintainers": [ + { + "name": "tjholowaychuk", + "email": "tj@vision-media.ca" + }, + { + "name": "jonathanong", + "email": "jonathanrichardong@gmail.com" + }, + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "jongleberry", + "email": "jonathanrichardong@gmail.com" + } + ], + "dist": { + "shasum": "651f838e22424e7566de161d8358caa199f83d4f", + "tarball": "https://registry.npmjs.org/fresh/-/fresh-0.3.0.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/fresh/-/fresh-0.3.0.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/express/node_modules/merge-descriptors/HISTORY.md b/node_modules/express/node_modules/merge-descriptors/HISTORY.md new file mode 100644 index 0000000..486771f --- /dev/null +++ b/node_modules/express/node_modules/merge-descriptors/HISTORY.md @@ -0,0 +1,21 @@ +1.0.1 / 2016-01-17 +================== + + * perf: enable strict mode + +1.0.0 / 2015-03-01 +================== + + * Add option to only add new descriptors + * Add simple argument validation + * Add jsdoc to source file + +0.0.2 / 2013-12-14 +================== + + * Move repository to `component` organization + +0.0.1 / 2013-10-29 +================== + + * Initial release diff --git a/node_modules/express/node_modules/merge-descriptors/LICENSE b/node_modules/express/node_modules/merge-descriptors/LICENSE new file mode 100644 index 0000000..274bfd8 --- /dev/null +++ b/node_modules/express/node_modules/merge-descriptors/LICENSE @@ -0,0 +1,23 @@ +(The MIT License) + +Copyright (c) 2013 Jonathan Ong +Copyright (c) 2015 Douglas Christopher Wilson + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/express/node_modules/merge-descriptors/README.md b/node_modules/express/node_modules/merge-descriptors/README.md new file mode 100644 index 0000000..d593c0e --- /dev/null +++ b/node_modules/express/node_modules/merge-descriptors/README.md @@ -0,0 +1,48 @@ +# Merge Descriptors + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Build Status][travis-image]][travis-url] +[![Test Coverage][coveralls-image]][coveralls-url] + +Merge objects using descriptors. + +```js +var thing = { + get name() { + return 'jon' + } +} + +var animal = { + +} + +merge(animal, thing) + +animal.name === 'jon' +``` + +## API + +### merge(destination, source) + +Redefines `destination`'s descriptors with `source`'s. + +### merge(destination, source, false) + +Defines `source`'s descriptors on `destination` if `destination` does not have +a descriptor by the same name. + +## License + +[MIT](LICENSE) + +[npm-image]: https://img.shields.io/npm/v/merge-descriptors.svg +[npm-url]: https://npmjs.org/package/merge-descriptors +[travis-image]: https://img.shields.io/travis/component/merge-descriptors/master.svg +[travis-url]: https://travis-ci.org/component/merge-descriptors +[coveralls-image]: https://img.shields.io/coveralls/component/merge-descriptors/master.svg +[coveralls-url]: https://coveralls.io/r/component/merge-descriptors?branch=master +[downloads-image]: https://img.shields.io/npm/dm/merge-descriptors.svg +[downloads-url]: https://npmjs.org/package/merge-descriptors diff --git a/node_modules/express/node_modules/merge-descriptors/index.js b/node_modules/express/node_modules/merge-descriptors/index.js new file mode 100644 index 0000000..573b132 --- /dev/null +++ b/node_modules/express/node_modules/merge-descriptors/index.js @@ -0,0 +1,60 @@ +/*! + * merge-descriptors + * Copyright(c) 2014 Jonathan Ong + * Copyright(c) 2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module exports. + * @public + */ + +module.exports = merge + +/** + * Module variables. + * @private + */ + +var hasOwnProperty = Object.prototype.hasOwnProperty + +/** + * Merge the property descriptors of `src` into `dest` + * + * @param {object} dest Object to add descriptors to + * @param {object} src Object to clone descriptors from + * @param {boolean} [redefine=true] Redefine `dest` properties with `src` properties + * @returns {object} Reference to dest + * @public + */ + +function merge(dest, src, redefine) { + if (!dest) { + throw new TypeError('argument dest is required') + } + + if (!src) { + throw new TypeError('argument src is required') + } + + if (redefine === undefined) { + // Default to true + redefine = true + } + + Object.getOwnPropertyNames(src).forEach(function forEachOwnPropertyName(name) { + if (!redefine && hasOwnProperty.call(dest, name)) { + // Skip desriptor + return + } + + // Copy descriptor + var descriptor = Object.getOwnPropertyDescriptor(src, name) + Object.defineProperty(dest, name, descriptor) + }) + + return dest +} diff --git a/node_modules/express/node_modules/merge-descriptors/package.json b/node_modules/express/node_modules/merge-descriptors/package.json new file mode 100644 index 0000000..998fec5 --- /dev/null +++ b/node_modules/express/node_modules/merge-descriptors/package.json @@ -0,0 +1,138 @@ +{ + "name": "merge-descriptors", + "description": "Merge objects using descriptors", + "version": "1.0.1", + "author": { + "name": "Jonathan Ong", + "email": "me@jongleberry.com", + "url": "http://jongleberry.com" + }, + "contributors": [ + { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "Mike Grabowski", + "email": "grabbou@gmail.com" + } + ], + "license": "MIT", + "repository": { + "type": "git", + "url": "git+https://github.com/component/merge-descriptors.git" + }, + "devDependencies": { + "istanbul": "0.4.1", + "mocha": "1.21.5" + }, + "files": [ + "HISTORY.md", + "LICENSE", + "README.md", + "index.js" + ], + "scripts": { + "test": "mocha --reporter spec --bail --check-leaks test/", + "test-ci": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter spec --check-leaks test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot --check-leaks test/" + }, + "gitHead": "f26c49c3b423b0b2ac31f6e32a84e1632f2d7ac2", + "bugs": { + "url": "https://github.com/component/merge-descriptors/issues" + }, + "homepage": "https://github.com/component/merge-descriptors", + "_id": "merge-descriptors@1.0.1", + "_shasum": "b00aaa556dd8b44568150ec9d1b953f3f90cbb61", + "_from": "merge-descriptors@1.0.1", + "_npmVersion": "1.4.28", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "maintainers": [ + { + "name": "anthonyshort", + "email": "antshort@gmail.com" + }, + { + "name": "clintwood", + "email": "clint@anotherway.co.za" + }, + { + "name": "dfcreative", + "email": "df.creative@gmail.com" + }, + { + "name": "dominicbarnes", + "email": "dominic@dbarnes.info" + }, + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "ianstormtaylor", + "email": "ian@ianstormtaylor.com" + }, + { + "name": "jonathanong", + "email": "jonathanrichardong@gmail.com" + }, + { + "name": "jongleberry", + "email": "jonathanrichardong@gmail.com" + }, + { + "name": "juliangruber", + "email": "julian@juliangruber.com" + }, + { + "name": "mattmueller", + "email": "mattmuelle@gmail.com" + }, + { + "name": "queckezz", + "email": "fabian.eichenberger@gmail.com" + }, + { + "name": "stephenmathieson", + "email": "me@stephenmathieson.com" + }, + { + "name": "thehydroimpulse", + "email": "dnfagnan@gmail.com" + }, + { + "name": "timaschew", + "email": "timaschew@gmail.com" + }, + { + "name": "timoxley", + "email": "secoif@gmail.com" + }, + { + "name": "tjholowaychuk", + "email": "tj@vision-media.ca" + }, + { + "name": "tootallnate", + "email": "nathan@tootallnate.net" + }, + { + "name": "trevorgerhardt", + "email": "trevorgerhardt@gmail.com" + }, + { + "name": "yields", + "email": "yields@icloud.com" + } + ], + "dist": { + "shasum": "b00aaa556dd8b44568150ec9d1b953f3f90cbb61", + "tarball": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/express/node_modules/methods/HISTORY.md b/node_modules/express/node_modules/methods/HISTORY.md new file mode 100644 index 0000000..c0ecf07 --- /dev/null +++ b/node_modules/express/node_modules/methods/HISTORY.md @@ -0,0 +1,29 @@ +1.1.2 / 2016-01-17 +================== + + * perf: enable strict mode + +1.1.1 / 2014-12-30 +================== + + * Improve `browserify` support + +1.1.0 / 2014-07-05 +================== + + * Add `CONNECT` method + +1.0.1 / 2014-06-02 +================== + + * Fix module to work with harmony transform + +1.0.0 / 2014-05-08 +================== + + * Add `PURGE` method + +0.1.0 / 2013-10-28 +================== + + * Add `http.METHODS` support diff --git a/node_modules/express/node_modules/methods/LICENSE b/node_modules/express/node_modules/methods/LICENSE new file mode 100644 index 0000000..220dc1a --- /dev/null +++ b/node_modules/express/node_modules/methods/LICENSE @@ -0,0 +1,24 @@ +(The MIT License) + +Copyright (c) 2013-2014 TJ Holowaychuk +Copyright (c) 2015-2016 Douglas Christopher Wilson + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + diff --git a/node_modules/express/node_modules/methods/README.md b/node_modules/express/node_modules/methods/README.md new file mode 100644 index 0000000..672a32b --- /dev/null +++ b/node_modules/express/node_modules/methods/README.md @@ -0,0 +1,51 @@ +# Methods + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Node.js Version][node-version-image]][node-version-url] +[![Build Status][travis-image]][travis-url] +[![Test Coverage][coveralls-image]][coveralls-url] + +HTTP verbs that Node.js core's HTTP parser supports. + +This module provides an export that is just like `http.METHODS` from Node.js core, +with the following differences: + + * All method names are lower-cased. + * Contains a fallback list of methods for Node.js versions that do not have a + `http.METHODS` export (0.10 and lower). + * Provides the fallback list when using tools like `browserify` without pulling + in the `http` shim module. + +## Install + +```bash +$ npm install methods +``` + +## API + +```js +var methods = require('methods') +``` + +### methods + +This is an array of lower-cased method names that Node.js supports. If Node.js +provides the `http.METHODS` export, then this is the same array lower-cased, +otherwise it is a snapshot of the verbs from Node.js 0.10. + +## License + +[MIT](LICENSE) + +[npm-image]: https://img.shields.io/npm/v/methods.svg?style=flat +[npm-url]: https://npmjs.org/package/methods +[node-version-image]: https://img.shields.io/node/v/methods.svg?style=flat +[node-version-url]: https://nodejs.org/en/download/ +[travis-image]: https://img.shields.io/travis/jshttp/methods.svg?style=flat +[travis-url]: https://travis-ci.org/jshttp/methods +[coveralls-image]: https://img.shields.io/coveralls/jshttp/methods.svg?style=flat +[coveralls-url]: https://coveralls.io/r/jshttp/methods?branch=master +[downloads-image]: https://img.shields.io/npm/dm/methods.svg?style=flat +[downloads-url]: https://npmjs.org/package/methods diff --git a/node_modules/express/node_modules/methods/index.js b/node_modules/express/node_modules/methods/index.js new file mode 100644 index 0000000..667a50b --- /dev/null +++ b/node_modules/express/node_modules/methods/index.js @@ -0,0 +1,69 @@ +/*! + * methods + * Copyright(c) 2013-2014 TJ Holowaychuk + * Copyright(c) 2015-2016 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict'; + +/** + * Module dependencies. + * @private + */ + +var http = require('http'); + +/** + * Module exports. + * @public + */ + +module.exports = getCurrentNodeMethods() || getBasicNodeMethods(); + +/** + * Get the current Node.js methods. + * @private + */ + +function getCurrentNodeMethods() { + return http.METHODS && http.METHODS.map(function lowerCaseMethod(method) { + return method.toLowerCase(); + }); +} + +/** + * Get the "basic" Node.js methods, a snapshot from Node.js 0.10. + * @private + */ + +function getBasicNodeMethods() { + return [ + 'get', + 'post', + 'put', + 'head', + 'delete', + 'options', + 'trace', + 'copy', + 'lock', + 'mkcol', + 'move', + 'purge', + 'propfind', + 'proppatch', + 'unlock', + 'report', + 'mkactivity', + 'checkout', + 'merge', + 'm-search', + 'notify', + 'subscribe', + 'unsubscribe', + 'patch', + 'search', + 'connect' + ]; +} diff --git a/node_modules/express/node_modules/methods/package.json b/node_modules/express/node_modules/methods/package.json new file mode 100644 index 0000000..dc53ac0 --- /dev/null +++ b/node_modules/express/node_modules/methods/package.json @@ -0,0 +1,88 @@ +{ + "name": "methods", + "description": "HTTP methods that node supports", + "version": "1.1.2", + "contributors": [ + { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "Jonathan Ong", + "email": "me@jongleberry.com", + "url": "http://jongleberry.com" + }, + { + "name": "TJ Holowaychuk", + "email": "tj@vision-media.ca", + "url": "http://tjholowaychuk.com" + } + ], + "license": "MIT", + "repository": { + "type": "git", + "url": "git+https://github.com/jshttp/methods.git" + }, + "devDependencies": { + "istanbul": "0.4.1", + "mocha": "1.21.5" + }, + "files": [ + "index.js", + "HISTORY.md", + "LICENSE" + ], + "engines": { + "node": ">= 0.6" + }, + "scripts": { + "test": "mocha --reporter spec --bail --check-leaks test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot --check-leaks test/", + "test-travis": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter spec --check-leaks test/" + }, + "browser": { + "http": false + }, + "keywords": [ + "http", + "methods" + ], + "gitHead": "25d257d913f1b94bd2d73581521ff72c81469140", + "bugs": { + "url": "https://github.com/jshttp/methods/issues" + }, + "homepage": "https://github.com/jshttp/methods", + "_id": "methods@1.1.2", + "_shasum": "5529a4d67654134edcc5266656835b0f851afcee", + "_from": "methods@>=1.1.2 <1.2.0", + "_npmVersion": "1.4.28", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "maintainers": [ + { + "name": "tjholowaychuk", + "email": "tj@vision-media.ca" + }, + { + "name": "jonathanong", + "email": "jonathanrichardong@gmail.com" + }, + { + "name": "jongleberry", + "email": "jonathanrichardong@gmail.com" + }, + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + } + ], + "dist": { + "shasum": "5529a4d67654134edcc5266656835b0f851afcee", + "tarball": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/methods/-/methods-1.1.2.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/express/node_modules/on-finished/HISTORY.md b/node_modules/express/node_modules/on-finished/HISTORY.md new file mode 100644 index 0000000..98ff0e9 --- /dev/null +++ b/node_modules/express/node_modules/on-finished/HISTORY.md @@ -0,0 +1,88 @@ +2.3.0 / 2015-05-26 +================== + + * Add defined behavior for HTTP `CONNECT` requests + * Add defined behavior for HTTP `Upgrade` requests + * deps: ee-first@1.1.1 + +2.2.1 / 2015-04-22 +================== + + * Fix `isFinished(req)` when data buffered + +2.2.0 / 2014-12-22 +================== + + * Add message object to callback arguments + +2.1.1 / 2014-10-22 +================== + + * Fix handling of pipelined requests + +2.1.0 / 2014-08-16 +================== + + * Check if `socket` is detached + * Return `undefined` for `isFinished` if state unknown + +2.0.0 / 2014-08-16 +================== + + * Add `isFinished` function + * Move to `jshttp` organization + * Remove support for plain socket argument + * Rename to `on-finished` + * Support both `req` and `res` as arguments + * deps: ee-first@1.0.5 + +1.2.2 / 2014-06-10 +================== + + * Reduce listeners added to emitters + - avoids "event emitter leak" warnings when used multiple times on same request + +1.2.1 / 2014-06-08 +================== + + * Fix returned value when already finished + +1.2.0 / 2014-06-05 +================== + + * Call callback when called on already-finished socket + +1.1.4 / 2014-05-27 +================== + + * Support node.js 0.8 + +1.1.3 / 2014-04-30 +================== + + * Make sure errors passed as instanceof `Error` + +1.1.2 / 2014-04-18 +================== + + * Default the `socket` to passed-in object + +1.1.1 / 2014-01-16 +================== + + * Rename module to `finished` + +1.1.0 / 2013-12-25 +================== + + * Call callback when called on already-errored socket + +1.0.1 / 2013-12-20 +================== + + * Actually pass the error to the callback + +1.0.0 / 2013-12-20 +================== + + * Initial release diff --git a/node_modules/express/node_modules/on-finished/LICENSE b/node_modules/express/node_modules/on-finished/LICENSE new file mode 100644 index 0000000..5931fd2 --- /dev/null +++ b/node_modules/express/node_modules/on-finished/LICENSE @@ -0,0 +1,23 @@ +(The MIT License) + +Copyright (c) 2013 Jonathan Ong +Copyright (c) 2014 Douglas Christopher Wilson + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/express/node_modules/on-finished/README.md b/node_modules/express/node_modules/on-finished/README.md new file mode 100644 index 0000000..a0e1157 --- /dev/null +++ b/node_modules/express/node_modules/on-finished/README.md @@ -0,0 +1,154 @@ +# on-finished + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Node.js Version][node-version-image]][node-version-url] +[![Build Status][travis-image]][travis-url] +[![Test Coverage][coveralls-image]][coveralls-url] + +Execute a callback when a HTTP request closes, finishes, or errors. + +## Install + +```sh +$ npm install on-finished +``` + +## API + +```js +var onFinished = require('on-finished') +``` + +### onFinished(res, listener) + +Attach a listener to listen for the response to finish. The listener will +be invoked only once when the response finished. If the response finished +to an error, the first argument will contain the error. If the response +has already finished, the listener will be invoked. + +Listening to the end of a response would be used to close things associated +with the response, like open files. + +Listener is invoked as `listener(err, res)`. + +```js +onFinished(res, function (err, res) { + // clean up open fds, etc. + // err contains the error is request error'd +}) +``` + +### onFinished(req, listener) + +Attach a listener to listen for the request to finish. The listener will +be invoked only once when the request finished. If the request finished +to an error, the first argument will contain the error. If the request +has already finished, the listener will be invoked. + +Listening to the end of a request would be used to know when to continue +after reading the data. + +Listener is invoked as `listener(err, req)`. + +```js +var data = '' + +req.setEncoding('utf8') +res.on('data', function (str) { + data += str +}) + +onFinished(req, function (err, req) { + // data is read unless there is err +}) +``` + +### onFinished.isFinished(res) + +Determine if `res` is already finished. This would be useful to check and +not even start certain operations if the response has already finished. + +### onFinished.isFinished(req) + +Determine if `req` is already finished. This would be useful to check and +not even start certain operations if the request has already finished. + +## Special Node.js requests + +### HTTP CONNECT method + +The meaning of the `CONNECT` method from RFC 7231, section 4.3.6: + +> The CONNECT method requests that the recipient establish a tunnel to +> the destination origin server identified by the request-target and, +> if successful, thereafter restrict its behavior to blind forwarding +> of packets, in both directions, until the tunnel is closed. Tunnels +> are commonly used to create an end-to-end virtual connection, through +> one or more proxies, which can then be secured using TLS (Transport +> Layer Security, [RFC5246]). + +In Node.js, these request objects come from the `'connect'` event on +the HTTP server. + +When this module is used on a HTTP `CONNECT` request, the request is +considered "finished" immediately, **due to limitations in the Node.js +interface**. This means if the `CONNECT` request contains a request entity, +the request will be considered "finished" even before it has been read. + +There is no such thing as a response object to a `CONNECT` request in +Node.js, so there is no support for for one. + +### HTTP Upgrade request + +The meaning of the `Upgrade` header from RFC 7230, section 6.1: + +> The "Upgrade" header field is intended to provide a simple mechanism +> for transitioning from HTTP/1.1 to some other protocol on the same +> connection. + +In Node.js, these request objects come from the `'upgrade'` event on +the HTTP server. + +When this module is used on a HTTP request with an `Upgrade` header, the +request is considered "finished" immediately, **due to limitations in the +Node.js interface**. This means if the `Upgrade` request contains a request +entity, the request will be considered "finished" even before it has been +read. + +There is no such thing as a response object to a `Upgrade` request in +Node.js, so there is no support for for one. + +## Example + +The following code ensures that file descriptors are always closed +once the response finishes. + +```js +var destroy = require('destroy') +var http = require('http') +var onFinished = require('on-finished') + +http.createServer(function onRequest(req, res) { + var stream = fs.createReadStream('package.json') + stream.pipe(res) + onFinished(res, function (err) { + destroy(stream) + }) +}) +``` + +## License + +[MIT](LICENSE) + +[npm-image]: https://img.shields.io/npm/v/on-finished.svg +[npm-url]: https://npmjs.org/package/on-finished +[node-version-image]: https://img.shields.io/node/v/on-finished.svg +[node-version-url]: http://nodejs.org/download/ +[travis-image]: https://img.shields.io/travis/jshttp/on-finished/master.svg +[travis-url]: https://travis-ci.org/jshttp/on-finished +[coveralls-image]: https://img.shields.io/coveralls/jshttp/on-finished/master.svg +[coveralls-url]: https://coveralls.io/r/jshttp/on-finished?branch=master +[downloads-image]: https://img.shields.io/npm/dm/on-finished.svg +[downloads-url]: https://npmjs.org/package/on-finished diff --git a/node_modules/express/node_modules/on-finished/index.js b/node_modules/express/node_modules/on-finished/index.js new file mode 100644 index 0000000..9abd98f --- /dev/null +++ b/node_modules/express/node_modules/on-finished/index.js @@ -0,0 +1,196 @@ +/*! + * on-finished + * Copyright(c) 2013 Jonathan Ong + * Copyright(c) 2014 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module exports. + * @public + */ + +module.exports = onFinished +module.exports.isFinished = isFinished + +/** + * Module dependencies. + * @private + */ + +var first = require('ee-first') + +/** + * Variables. + * @private + */ + +/* istanbul ignore next */ +var defer = typeof setImmediate === 'function' + ? setImmediate + : function(fn){ process.nextTick(fn.bind.apply(fn, arguments)) } + +/** + * Invoke callback when the response has finished, useful for + * cleaning up resources afterwards. + * + * @param {object} msg + * @param {function} listener + * @return {object} + * @public + */ + +function onFinished(msg, listener) { + if (isFinished(msg) !== false) { + defer(listener, null, msg) + return msg + } + + // attach the listener to the message + attachListener(msg, listener) + + return msg +} + +/** + * Determine if message is already finished. + * + * @param {object} msg + * @return {boolean} + * @public + */ + +function isFinished(msg) { + var socket = msg.socket + + if (typeof msg.finished === 'boolean') { + // OutgoingMessage + return Boolean(msg.finished || (socket && !socket.writable)) + } + + if (typeof msg.complete === 'boolean') { + // IncomingMessage + return Boolean(msg.upgrade || !socket || !socket.readable || (msg.complete && !msg.readable)) + } + + // don't know + return undefined +} + +/** + * Attach a finished listener to the message. + * + * @param {object} msg + * @param {function} callback + * @private + */ + +function attachFinishedListener(msg, callback) { + var eeMsg + var eeSocket + var finished = false + + function onFinish(error) { + eeMsg.cancel() + eeSocket.cancel() + + finished = true + callback(error) + } + + // finished on first message event + eeMsg = eeSocket = first([[msg, 'end', 'finish']], onFinish) + + function onSocket(socket) { + // remove listener + msg.removeListener('socket', onSocket) + + if (finished) return + if (eeMsg !== eeSocket) return + + // finished on first socket event + eeSocket = first([[socket, 'error', 'close']], onFinish) + } + + if (msg.socket) { + // socket already assigned + onSocket(msg.socket) + return + } + + // wait for socket to be assigned + msg.on('socket', onSocket) + + if (msg.socket === undefined) { + // node.js 0.8 patch + patchAssignSocket(msg, onSocket) + } +} + +/** + * Attach the listener to the message. + * + * @param {object} msg + * @return {function} + * @private + */ + +function attachListener(msg, listener) { + var attached = msg.__onFinished + + // create a private single listener with queue + if (!attached || !attached.queue) { + attached = msg.__onFinished = createListener(msg) + attachFinishedListener(msg, attached) + } + + attached.queue.push(listener) +} + +/** + * Create listener on message. + * + * @param {object} msg + * @return {function} + * @private + */ + +function createListener(msg) { + function listener(err) { + if (msg.__onFinished === listener) msg.__onFinished = null + if (!listener.queue) return + + var queue = listener.queue + listener.queue = null + + for (var i = 0; i < queue.length; i++) { + queue[i](err, msg) + } + } + + listener.queue = [] + + return listener +} + +/** + * Patch ServerResponse.prototype.assignSocket for node.js 0.8. + * + * @param {ServerResponse} res + * @param {function} callback + * @private + */ + +function patchAssignSocket(res, callback) { + var assignSocket = res.assignSocket + + if (typeof assignSocket !== 'function') return + + // res.on('socket', callback) is broken in 0.8 + res.assignSocket = function _assignSocket(socket) { + assignSocket.call(this, socket) + callback(socket) + } +} diff --git a/node_modules/express/node_modules/on-finished/node_modules/ee-first/LICENSE b/node_modules/express/node_modules/on-finished/node_modules/ee-first/LICENSE new file mode 100644 index 0000000..a7ae8ee --- /dev/null +++ b/node_modules/express/node_modules/on-finished/node_modules/ee-first/LICENSE @@ -0,0 +1,22 @@ + +The MIT License (MIT) + +Copyright (c) 2014 Jonathan Ong me@jongleberry.com + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. diff --git a/node_modules/express/node_modules/on-finished/node_modules/ee-first/README.md b/node_modules/express/node_modules/on-finished/node_modules/ee-first/README.md new file mode 100644 index 0000000..cbd2478 --- /dev/null +++ b/node_modules/express/node_modules/on-finished/node_modules/ee-first/README.md @@ -0,0 +1,80 @@ +# EE First + +[![NPM version][npm-image]][npm-url] +[![Build status][travis-image]][travis-url] +[![Test coverage][coveralls-image]][coveralls-url] +[![License][license-image]][license-url] +[![Downloads][downloads-image]][downloads-url] +[![Gittip][gittip-image]][gittip-url] + +Get the first event in a set of event emitters and event pairs, +then clean up after itself. + +## Install + +```sh +$ npm install ee-first +``` + +## API + +```js +var first = require('ee-first') +``` + +### first(arr, listener) + +Invoke `listener` on the first event from the list specified in `arr`. `arr` is +an array of arrays, with each array in the format `[ee, ...event]`. `listener` +will be called only once, the first time any of the given events are emitted. If +`error` is one of the listened events, then if that fires first, the `listener` +will be given the `err` argument. + +The `listener` is invoked as `listener(err, ee, event, args)`, where `err` is the +first argument emitted from an `error` event, if applicable; `ee` is the event +emitter that fired; `event` is the string event name that fired; and `args` is an +array of the arguments that were emitted on the event. + +```js +var ee1 = new EventEmitter() +var ee2 = new EventEmitter() + +first([ + [ee1, 'close', 'end', 'error'], + [ee2, 'error'] +], function (err, ee, event, args) { + // listener invoked +}) +``` + +#### .cancel() + +The group of listeners can be cancelled before being invoked and have all the event +listeners removed from the underlying event emitters. + +```js +var thunk = first([ + [ee1, 'close', 'end', 'error'], + [ee2, 'error'] +], function (err, ee, event, args) { + // listener invoked +}) + +// cancel and clean up +thunk.cancel() +``` + +[npm-image]: https://img.shields.io/npm/v/ee-first.svg?style=flat-square +[npm-url]: https://npmjs.org/package/ee-first +[github-tag]: http://img.shields.io/github/tag/jonathanong/ee-first.svg?style=flat-square +[github-url]: https://github.com/jonathanong/ee-first/tags +[travis-image]: https://img.shields.io/travis/jonathanong/ee-first.svg?style=flat-square +[travis-url]: https://travis-ci.org/jonathanong/ee-first +[coveralls-image]: https://img.shields.io/coveralls/jonathanong/ee-first.svg?style=flat-square +[coveralls-url]: https://coveralls.io/r/jonathanong/ee-first?branch=master +[license-image]: http://img.shields.io/npm/l/ee-first.svg?style=flat-square +[license-url]: LICENSE.md +[downloads-image]: http://img.shields.io/npm/dm/ee-first.svg?style=flat-square +[downloads-url]: https://npmjs.org/package/ee-first +[gittip-image]: https://img.shields.io/gittip/jonathanong.svg?style=flat-square +[gittip-url]: https://www.gittip.com/jonathanong/ diff --git a/node_modules/express/node_modules/on-finished/node_modules/ee-first/index.js b/node_modules/express/node_modules/on-finished/node_modules/ee-first/index.js new file mode 100644 index 0000000..501287c --- /dev/null +++ b/node_modules/express/node_modules/on-finished/node_modules/ee-first/index.js @@ -0,0 +1,95 @@ +/*! + * ee-first + * Copyright(c) 2014 Jonathan Ong + * MIT Licensed + */ + +'use strict' + +/** + * Module exports. + * @public + */ + +module.exports = first + +/** + * Get the first event in a set of event emitters and event pairs. + * + * @param {array} stuff + * @param {function} done + * @public + */ + +function first(stuff, done) { + if (!Array.isArray(stuff)) + throw new TypeError('arg must be an array of [ee, events...] arrays') + + var cleanups = [] + + for (var i = 0; i < stuff.length; i++) { + var arr = stuff[i] + + if (!Array.isArray(arr) || arr.length < 2) + throw new TypeError('each array member must be [ee, events...]') + + var ee = arr[0] + + for (var j = 1; j < arr.length; j++) { + var event = arr[j] + var fn = listener(event, callback) + + // listen to the event + ee.on(event, fn) + // push this listener to the list of cleanups + cleanups.push({ + ee: ee, + event: event, + fn: fn, + }) + } + } + + function callback() { + cleanup() + done.apply(null, arguments) + } + + function cleanup() { + var x + for (var i = 0; i < cleanups.length; i++) { + x = cleanups[i] + x.ee.removeListener(x.event, x.fn) + } + } + + function thunk(fn) { + done = fn + } + + thunk.cancel = cleanup + + return thunk +} + +/** + * Create the event listener. + * @private + */ + +function listener(event, done) { + return function onevent(arg1) { + var args = new Array(arguments.length) + var ee = this + var err = event === 'error' + ? arg1 + : null + + // copy args to prevent arguments escaping scope + for (var i = 0; i < args.length; i++) { + args[i] = arguments[i] + } + + done(err, ee, event, args) + } +} diff --git a/node_modules/express/node_modules/on-finished/node_modules/ee-first/package.json b/node_modules/express/node_modules/on-finished/node_modules/ee-first/package.json new file mode 100644 index 0000000..1320c1c --- /dev/null +++ b/node_modules/express/node_modules/on-finished/node_modules/ee-first/package.json @@ -0,0 +1,64 @@ +{ + "name": "ee-first", + "description": "return the first event in a set of ee/event pairs", + "version": "1.1.1", + "author": { + "name": "Jonathan Ong", + "email": "me@jongleberry.com", + "url": "http://jongleberry.com" + }, + "contributors": [ + { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + } + ], + "license": "MIT", + "repository": { + "type": "git", + "url": "git+https://github.com/jonathanong/ee-first.git" + }, + "devDependencies": { + "istanbul": "0.3.9", + "mocha": "2.2.5" + }, + "files": [ + "index.js", + "LICENSE" + ], + "scripts": { + "test": "mocha --reporter spec --bail --check-leaks test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot --check-leaks test/", + "test-travis": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter spec --check-leaks test/" + }, + "gitHead": "512e0ce4cc3643f603708f965a97b61b1a9c0441", + "bugs": { + "url": "https://github.com/jonathanong/ee-first/issues" + }, + "homepage": "https://github.com/jonathanong/ee-first", + "_id": "ee-first@1.1.1", + "_shasum": "590c61156b0ae2f4f0255732a158b266bc56b21d", + "_from": "ee-first@1.1.1", + "_npmVersion": "1.4.28", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "maintainers": [ + { + "name": "jongleberry", + "email": "jonathanrichardong@gmail.com" + }, + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + } + ], + "dist": { + "shasum": "590c61156b0ae2f4f0255732a158b266bc56b21d", + "tarball": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/express/node_modules/on-finished/package.json b/node_modules/express/node_modules/on-finished/package.json new file mode 100644 index 0000000..39e63f6 --- /dev/null +++ b/node_modules/express/node_modules/on-finished/package.json @@ -0,0 +1,71 @@ +{ + "name": "on-finished", + "description": "Execute a callback when a request closes, finishes, or errors", + "version": "2.3.0", + "contributors": [ + { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "Jonathan Ong", + "email": "me@jongleberry.com", + "url": "http://jongleberry.com" + } + ], + "license": "MIT", + "repository": { + "type": "git", + "url": "git+https://github.com/jshttp/on-finished.git" + }, + "dependencies": { + "ee-first": "1.1.1" + }, + "devDependencies": { + "istanbul": "0.3.9", + "mocha": "2.2.5" + }, + "engines": { + "node": ">= 0.8" + }, + "files": [ + "HISTORY.md", + "LICENSE", + "index.js" + ], + "scripts": { + "test": "mocha --reporter spec --bail --check-leaks test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot --check-leaks test/", + "test-travis": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter spec --check-leaks test/" + }, + "gitHead": "34babcb58126a416fcf5205768204f2e12699dda", + "bugs": { + "url": "https://github.com/jshttp/on-finished/issues" + }, + "homepage": "https://github.com/jshttp/on-finished", + "_id": "on-finished@2.3.0", + "_shasum": "20f1336481b083cd75337992a16971aa2d906947", + "_from": "on-finished@>=2.3.0 <2.4.0", + "_npmVersion": "1.4.28", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "maintainers": [ + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "jongleberry", + "email": "jonathanrichardong@gmail.com" + } + ], + "dist": { + "shasum": "20f1336481b083cd75337992a16971aa2d906947", + "tarball": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/express/node_modules/parseurl/HISTORY.md b/node_modules/express/node_modules/parseurl/HISTORY.md new file mode 100644 index 0000000..395041e --- /dev/null +++ b/node_modules/express/node_modules/parseurl/HISTORY.md @@ -0,0 +1,47 @@ +1.3.1 / 2016-01-17 +================== + + * perf: enable strict mode + +1.3.0 / 2014-08-09 +================== + + * Add `parseurl.original` for parsing `req.originalUrl` with fallback + * Return `undefined` if `req.url` is `undefined` + +1.2.0 / 2014-07-21 +================== + + * Cache URLs based on original value + * Remove no-longer-needed URL mis-parse work-around + * Simplify the "fast-path" `RegExp` + +1.1.3 / 2014-07-08 +================== + + * Fix typo + +1.1.2 / 2014-07-08 +================== + + * Seriously fix Node.js 0.8 compatibility + +1.1.1 / 2014-07-08 +================== + + * Fix Node.js 0.8 compatibility + +1.1.0 / 2014-07-08 +================== + + * Incorporate URL href-only parse fast-path + +1.0.1 / 2014-03-08 +================== + + * Add missing `require` + +1.0.0 / 2014-03-08 +================== + + * Genesis from `connect` diff --git a/node_modules/express/node_modules/parseurl/LICENSE b/node_modules/express/node_modules/parseurl/LICENSE new file mode 100644 index 0000000..ec7dfe7 --- /dev/null +++ b/node_modules/express/node_modules/parseurl/LICENSE @@ -0,0 +1,24 @@ + +(The MIT License) + +Copyright (c) 2014 Jonathan Ong +Copyright (c) 2014 Douglas Christopher Wilson + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/express/node_modules/parseurl/README.md b/node_modules/express/node_modules/parseurl/README.md new file mode 100644 index 0000000..f4796eb --- /dev/null +++ b/node_modules/express/node_modules/parseurl/README.md @@ -0,0 +1,120 @@ +# parseurl + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Node.js Version][node-version-image]][node-version-url] +[![Build Status][travis-image]][travis-url] +[![Test Coverage][coveralls-image]][coveralls-url] + +Parse a URL with memoization. + +## Install + +```bash +$ npm install parseurl +``` + +## API + +```js +var parseurl = require('parseurl') +``` + +### parseurl(req) + +Parse the URL of the given request object (looks at the `req.url` property) +and return the result. The result is the same as `url.parse` in Node.js core. +Calling this function multiple times on the same `req` where `req.url` does +not change will return a cached parsed object, rather than parsing again. + +### parseurl.original(req) + +Parse the original URL of the given request object and return the result. +This works by trying to parse `req.originalUrl` if it is a string, otherwise +parses `req.url`. The result is the same as `url.parse` in Node.js core. +Calling this function multiple times on the same `req` where `req.originalUrl` +does not change will return a cached parsed object, rather than parsing again. + +## Benchmark + +```bash +$ npm run-script bench + +> parseurl@1.3.1 bench nodejs-parseurl +> node benchmark/index.js + +> node benchmark/fullurl.js + + Parsing URL "http://localhost:8888/foo/bar?user=tj&pet=fluffy" + + 1 test completed. + 2 tests completed. + 3 tests completed. + + fasturl x 1,290,780 ops/sec ±0.46% (195 runs sampled) + nativeurl x 56,401 ops/sec ±0.22% (196 runs sampled) + parseurl x 55,231 ops/sec ±0.22% (194 runs sampled) + +> node benchmark/pathquery.js + + Parsing URL "/foo/bar?user=tj&pet=fluffy" + + 1 test completed. + 2 tests completed. + 3 tests completed. + + fasturl x 1,986,668 ops/sec ±0.27% (190 runs sampled) + nativeurl x 98,740 ops/sec ±0.21% (195 runs sampled) + parseurl x 2,628,171 ops/sec ±0.36% (195 runs sampled) + +> node benchmark/samerequest.js + + Parsing URL "/foo/bar?user=tj&pet=fluffy" on same request object + + 1 test completed. + 2 tests completed. + 3 tests completed. + + fasturl x 2,184,468 ops/sec ±0.40% (194 runs sampled) + nativeurl x 99,437 ops/sec ±0.71% (194 runs sampled) + parseurl x 10,498,005 ops/sec ±0.61% (186 runs sampled) + +> node benchmark/simplepath.js + + Parsing URL "/foo/bar" + + 1 test completed. + 2 tests completed. + 3 tests completed. + + fasturl x 4,535,825 ops/sec ±0.27% (191 runs sampled) + nativeurl x 98,769 ops/sec ±0.54% (191 runs sampled) + parseurl x 4,164,865 ops/sec ±0.34% (192 runs sampled) + +> node benchmark/slash.js + + Parsing URL "/" + + 1 test completed. + 2 tests completed. + 3 tests completed. + + fasturl x 4,908,405 ops/sec ±0.42% (191 runs sampled) + nativeurl x 100,945 ops/sec ±0.59% (188 runs sampled) + parseurl x 4,333,208 ops/sec ±0.27% (194 runs sampled) +``` + +## License + + [MIT](LICENSE) + +[npm-image]: https://img.shields.io/npm/v/parseurl.svg +[npm-url]: https://npmjs.org/package/parseurl +[node-version-image]: https://img.shields.io/node/v/parseurl.svg +[node-version-url]: http://nodejs.org/download/ +[travis-image]: https://img.shields.io/travis/pillarjs/parseurl/master.svg +[travis-url]: https://travis-ci.org/pillarjs/parseurl +[coveralls-image]: https://img.shields.io/coveralls/pillarjs/parseurl/master.svg +[coveralls-url]: https://coveralls.io/r/pillarjs/parseurl?branch=master +[downloads-image]: https://img.shields.io/npm/dm/parseurl.svg +[downloads-url]: https://npmjs.org/package/parseurl diff --git a/node_modules/express/node_modules/parseurl/index.js b/node_modules/express/node_modules/parseurl/index.js new file mode 100644 index 0000000..56cc6ec --- /dev/null +++ b/node_modules/express/node_modules/parseurl/index.js @@ -0,0 +1,138 @@ +/*! + * parseurl + * Copyright(c) 2014 Jonathan Ong + * Copyright(c) 2014 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module dependencies. + */ + +var url = require('url') +var parse = url.parse +var Url = url.Url + +/** + * Pattern for a simple path case. + * See: https://github.com/joyent/node/pull/7878 + */ + +var simplePathRegExp = /^(\/\/?(?!\/)[^\?#\s]*)(\?[^#\s]*)?$/ + +/** + * Exports. + */ + +module.exports = parseurl +module.exports.original = originalurl + +/** + * Parse the `req` url with memoization. + * + * @param {ServerRequest} req + * @return {Object} + * @api public + */ + +function parseurl(req) { + var url = req.url + + if (url === undefined) { + // URL is undefined + return undefined + } + + var parsed = req._parsedUrl + + if (fresh(url, parsed)) { + // Return cached URL parse + return parsed + } + + // Parse the URL + parsed = fastparse(url) + parsed._raw = url + + return req._parsedUrl = parsed +}; + +/** + * Parse the `req` original url with fallback and memoization. + * + * @param {ServerRequest} req + * @return {Object} + * @api public + */ + +function originalurl(req) { + var url = req.originalUrl + + if (typeof url !== 'string') { + // Fallback + return parseurl(req) + } + + var parsed = req._parsedOriginalUrl + + if (fresh(url, parsed)) { + // Return cached URL parse + return parsed + } + + // Parse the URL + parsed = fastparse(url) + parsed._raw = url + + return req._parsedOriginalUrl = parsed +}; + +/** + * Parse the `str` url with fast-path short-cut. + * + * @param {string} str + * @return {Object} + * @api private + */ + +function fastparse(str) { + // Try fast path regexp + // See: https://github.com/joyent/node/pull/7878 + var simplePath = typeof str === 'string' && simplePathRegExp.exec(str) + + // Construct simple URL + if (simplePath) { + var pathname = simplePath[1] + var search = simplePath[2] || null + var url = Url !== undefined + ? new Url() + : {} + url.path = str + url.href = str + url.pathname = pathname + url.search = search + url.query = search && search.substr(1) + + return url + } + + return parse(str) +} + +/** + * Determine if parsed is still fresh for url. + * + * @param {string} url + * @param {object} parsedUrl + * @return {boolean} + * @api private + */ + +function fresh(url, parsedUrl) { + return typeof parsedUrl === 'object' + && parsedUrl !== null + && (Url === undefined || parsedUrl instanceof Url) + && parsedUrl._raw === url +} diff --git a/node_modules/express/node_modules/parseurl/package.json b/node_modules/express/node_modules/parseurl/package.json new file mode 100644 index 0000000..35e6d20 --- /dev/null +++ b/node_modules/express/node_modules/parseurl/package.json @@ -0,0 +1,89 @@ +{ + "name": "parseurl", + "description": "parse a url with memoization", + "version": "1.3.1", + "author": { + "name": "Jonathan Ong", + "email": "me@jongleberry.com", + "url": "http://jongleberry.com" + }, + "contributors": [ + { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + } + ], + "repository": { + "type": "git", + "url": "git+https://github.com/pillarjs/parseurl.git" + }, + "license": "MIT", + "devDependencies": { + "benchmark": "2.0.0", + "beautify-benchmark": "0.2.4", + "fast-url-parser": "1.1.3", + "istanbul": "0.4.2", + "mocha": "~1.21.5" + }, + "files": [ + "LICENSE", + "HISTORY.md", + "README.md", + "index.js" + ], + "engines": { + "node": ">= 0.8" + }, + "scripts": { + "bench": "node benchmark/index.js", + "test": "mocha --check-leaks --bail --reporter spec test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --check-leaks --reporter dot test/", + "test-travis": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --check-leaks --reporter spec test/" + }, + "gitHead": "6d22d376d75b927ab2b5347ce3a1d6735133dd43", + "bugs": { + "url": "https://github.com/pillarjs/parseurl/issues" + }, + "homepage": "https://github.com/pillarjs/parseurl", + "_id": "parseurl@1.3.1", + "_shasum": "c8ab8c9223ba34888aa64a297b28853bec18da56", + "_from": "parseurl@>=1.3.1 <1.4.0", + "_npmVersion": "1.4.28", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "maintainers": [ + { + "name": "jongleberry", + "email": "jonathanrichardong@gmail.com" + }, + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "tjholowaychuk", + "email": "tj@vision-media.ca" + }, + { + "name": "mscdex", + "email": "mscdex@mscdex.net" + }, + { + "name": "fishrock123", + "email": "fishrock123@rocketmail.com" + }, + { + "name": "defunctzombie", + "email": "shtylman@gmail.com" + } + ], + "dist": { + "shasum": "c8ab8c9223ba34888aa64a297b28853bec18da56", + "tarball": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.1.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/parseurl/-/parseurl-1.3.1.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/express/node_modules/path-to-regexp/History.md b/node_modules/express/node_modules/path-to-regexp/History.md new file mode 100644 index 0000000..7f65878 --- /dev/null +++ b/node_modules/express/node_modules/path-to-regexp/History.md @@ -0,0 +1,36 @@ +0.1.7 / 2015-07-28 +================== + + * Fixed regression with escaped round brackets and matching groups. + +0.1.6 / 2015-06-19 +================== + + * Replace `index` feature by outputting all parameters, unnamed and named. + +0.1.5 / 2015-05-08 +================== + + * Add an index property for position in match result. + +0.1.4 / 2015-03-05 +================== + + * Add license information + +0.1.3 / 2014-07-06 +================== + + * Better array support + * Improved support for trailing slash in non-ending mode + +0.1.0 / 2014-03-06 +================== + + * add options.end + +0.0.2 / 2013-02-10 +================== + + * Update to match current express + * add .license property to component.json diff --git a/node_modules/express/node_modules/path-to-regexp/LICENSE b/node_modules/express/node_modules/path-to-regexp/LICENSE new file mode 100644 index 0000000..983fbe8 --- /dev/null +++ b/node_modules/express/node_modules/path-to-regexp/LICENSE @@ -0,0 +1,21 @@ +The MIT License (MIT) + +Copyright (c) 2014 Blake Embrey (hello@blakeembrey.com) + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. diff --git a/node_modules/express/node_modules/path-to-regexp/Readme.md b/node_modules/express/node_modules/path-to-regexp/Readme.md new file mode 100644 index 0000000..95452a6 --- /dev/null +++ b/node_modules/express/node_modules/path-to-regexp/Readme.md @@ -0,0 +1,35 @@ +# Path-to-RegExp + +Turn an Express-style path string such as `/user/:name` into a regular expression. + +**Note:** This is a legacy branch. You should upgrade to `1.x`. + +## Usage + +```javascript +var pathToRegexp = require('path-to-regexp'); +``` + +### pathToRegexp(path, keys, options) + + - **path** A string in the express format, an array of such strings, or a regular expression + - **keys** An array to be populated with the keys present in the url. Once the function completes, this will be an array of strings. + - **options** + - **options.sensitive** Defaults to false, set this to true to make routes case sensitive + - **options.strict** Defaults to false, set this to true to make the trailing slash matter. + - **options.end** Defaults to true, set this to false to only match the prefix of the URL. + +```javascript +var keys = []; +var exp = pathToRegexp('/foo/:bar', keys); +//keys = ['bar'] +//exp = /^\/foo\/(?:([^\/]+?))\/?$/i +``` + +## Live Demo + +You can see a live demo of this library in use at [express-route-tester](http://forbeslindesay.github.com/express-route-tester/). + +## License + + MIT diff --git a/node_modules/express/node_modules/path-to-regexp/index.js b/node_modules/express/node_modules/path-to-regexp/index.js new file mode 100644 index 0000000..500d1da --- /dev/null +++ b/node_modules/express/node_modules/path-to-regexp/index.js @@ -0,0 +1,129 @@ +/** + * Expose `pathtoRegexp`. + */ + +module.exports = pathtoRegexp; + +/** + * Match matching groups in a regular expression. + */ +var MATCHING_GROUP_REGEXP = /\((?!\?)/g; + +/** + * Normalize the given path string, + * returning a regular expression. + * + * An empty array should be passed, + * which will contain the placeholder + * key names. For example "/user/:id" will + * then contain ["id"]. + * + * @param {String|RegExp|Array} path + * @param {Array} keys + * @param {Object} options + * @return {RegExp} + * @api private + */ + +function pathtoRegexp(path, keys, options) { + options = options || {}; + keys = keys || []; + var strict = options.strict; + var end = options.end !== false; + var flags = options.sensitive ? '' : 'i'; + var extraOffset = 0; + var keysOffset = keys.length; + var i = 0; + var name = 0; + var m; + + if (path instanceof RegExp) { + while (m = MATCHING_GROUP_REGEXP.exec(path.source)) { + keys.push({ + name: name++, + optional: false, + offset: m.index + }); + } + + return path; + } + + if (Array.isArray(path)) { + // Map array parts into regexps and return their source. We also pass + // the same keys and options instance into every generation to get + // consistent matching groups before we join the sources together. + path = path.map(function (value) { + return pathtoRegexp(value, keys, options).source; + }); + + return new RegExp('(?:' + path.join('|') + ')', flags); + } + + path = ('^' + path + (strict ? '' : path[path.length - 1] === '/' ? '?' : '/?')) + .replace(/\/\(/g, '/(?:') + .replace(/([\/\.])/g, '\\$1') + .replace(/(\\\/)?(\\\.)?:(\w+)(\(.*?\))?(\*)?(\?)?/g, function (match, slash, format, key, capture, star, optional, offset) { + slash = slash || ''; + format = format || ''; + capture = capture || '([^\\/' + format + ']+?)'; + optional = optional || ''; + + keys.push({ + name: key, + optional: !!optional, + offset: offset + extraOffset + }); + + var result = '' + + (optional ? '' : slash) + + '(?:' + + format + (optional ? slash : '') + capture + + (star ? '((?:[\\/' + format + '].+?)?)' : '') + + ')' + + optional; + + extraOffset += result.length - match.length; + + return result; + }) + .replace(/\*/g, function (star, index) { + var len = keys.length + + while (len-- > keysOffset && keys[len].offset > index) { + keys[len].offset += 3; // Replacement length minus asterisk length. + } + + return '(.*)'; + }); + + // This is a workaround for handling unnamed matching groups. + while (m = MATCHING_GROUP_REGEXP.exec(path)) { + var escapeCount = 0; + var index = m.index; + + while (path.charAt(--index) === '\\') { + escapeCount++; + } + + // It's possible to escape the bracket. + if (escapeCount % 2 === 1) { + continue; + } + + if (keysOffset + i === keys.length || keys[keysOffset + i].offset > m.index) { + keys.splice(keysOffset + i, 0, { + name: name++, // Unnamed matching groups must be consistently linear. + optional: false, + offset: m.index + }); + } + + i++; + } + + // If the path is non-ending, match until the end or a slash. + path += (end ? '$' : (path[path.length - 1] === '/' ? '' : '(?=\\/|$)')); + + return new RegExp(path, flags); +}; diff --git a/node_modules/express/node_modules/path-to-regexp/package.json b/node_modules/express/node_modules/path-to-regexp/package.json new file mode 100644 index 0000000..390983d --- /dev/null +++ b/node_modules/express/node_modules/path-to-regexp/package.json @@ -0,0 +1,184 @@ +{ + "name": "path-to-regexp", + "description": "Express style path to RegExp utility", + "version": "0.1.7", + "files": [ + "index.js", + "LICENSE" + ], + "scripts": { + "test": "istanbul cover _mocha -- -R spec" + }, + "keywords": [ + "express", + "regexp" + ], + "component": { + "scripts": { + "path-to-regexp": "index.js" + } + }, + "license": "MIT", + "repository": { + "type": "git", + "url": "git+https://github.com/component/path-to-regexp.git" + }, + "devDependencies": { + "mocha": "^1.17.1", + "istanbul": "^0.2.6" + }, + "gitHead": "039118d6c3c186d3f176c73935ca887a32a33d93", + "bugs": { + "url": "https://github.com/component/path-to-regexp/issues" + }, + "homepage": "https://github.com/component/path-to-regexp#readme", + "_id": "path-to-regexp@0.1.7", + "_shasum": "df604178005f522f15eb4490e7247a1bfaa67f8c", + "_from": "path-to-regexp@0.1.7", + "_npmVersion": "2.13.2", + "_nodeVersion": "2.3.3", + "_npmUser": { + "name": "blakeembrey", + "email": "hello@blakeembrey.com" + }, + "maintainers": [ + { + "name": "tjholowaychuk", + "email": "tj@vision-media.ca" + }, + { + "name": "hughsk", + "email": "hughskennedy@gmail.com" + }, + { + "name": "timaschew", + "email": "timaschew@gmail.com" + }, + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "jongleberry", + "email": "jonathanrichardong@gmail.com" + }, + { + "name": "dominicbarnes", + "email": "dominic@dbarnes.info" + }, + { + "name": "tootallnate", + "email": "nathan@tootallnate.net" + }, + { + "name": "rauchg", + "email": "rauchg@gmail.com" + }, + { + "name": "retrofox", + "email": "rdsuarez@gmail.com" + }, + { + "name": "coreh", + "email": "thecoreh@gmail.com" + }, + { + "name": "forbeslindesay", + "email": "forbes@lindesay.co.uk" + }, + { + "name": "kelonye", + "email": "kelonyemitchel@gmail.com" + }, + { + "name": "mattmueller", + "email": "mattmuelle@gmail.com" + }, + { + "name": "yields", + "email": "yields@icloud.com" + }, + { + "name": "anthonyshort", + "email": "antshort@gmail.com" + }, + { + "name": "ianstormtaylor", + "email": "ian@ianstormtaylor.com" + }, + { + "name": "cristiandouce", + "email": "cristian@gravityonmars.com" + }, + { + "name": "swatinem", + "email": "arpad.borsos@googlemail.com" + }, + { + "name": "stagas", + "email": "gstagas@gmail.com" + }, + { + "name": "amasad", + "email": "amjad.masad@gmail.com" + }, + { + "name": "juliangruber", + "email": "julian@juliangruber.com" + }, + { + "name": "calvinfo", + "email": "calvin@calv.info" + }, + { + "name": "blakeembrey", + "email": "hello@blakeembrey.com" + }, + { + "name": "timoxley", + "email": "secoif@gmail.com" + }, + { + "name": "jonathanong", + "email": "jonathanrichardong@gmail.com" + }, + { + "name": "queckezz", + "email": "fabian.eichenberger@gmail.com" + }, + { + "name": "nami-doc", + "email": "vendethiel@hotmail.fr" + }, + { + "name": "clintwood", + "email": "clint@anotherway.co.za" + }, + { + "name": "thehydroimpulse", + "email": "dnfagnan@gmail.com" + }, + { + "name": "stephenmathieson", + "email": "me@stephenmathieson.com" + }, + { + "name": "trevorgerhardt", + "email": "trevorgerhardt@gmail.com" + }, + { + "name": "dfcreative", + "email": "df.creative@gmail.com" + }, + { + "name": "defunctzombie", + "email": "shtylman@gmail.com" + } + ], + "dist": { + "shasum": "df604178005f522f15eb4490e7247a1bfaa67f8c", + "tarball": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz" +} diff --git a/node_modules/express/node_modules/proxy-addr/HISTORY.md b/node_modules/express/node_modules/proxy-addr/HISTORY.md new file mode 100644 index 0000000..a7389db --- /dev/null +++ b/node_modules/express/node_modules/proxy-addr/HISTORY.md @@ -0,0 +1,99 @@ +1.1.2 / 2016-05-29 +================== + + * deps: ipaddr.js@1.1.1 + - Fix IPv6-mapped IPv4 validation edge cases + +1.1.1 / 2016-05-03 +================== + + * Fix regression matching mixed versions against multiple subnets + +1.1.0 / 2016-05-01 +================== + + * Fix accepting various invalid netmasks + - IPv4 netmasks must be contingous + - IPv6 addresses cannot be used as a netmask + * deps: ipaddr.js@1.1.0 + +1.0.10 / 2015-12-09 +=================== + + * deps: ipaddr.js@1.0.5 + - Fix regression in `isValid` with non-string arguments + +1.0.9 / 2015-12-01 +================== + + * deps: ipaddr.js@1.0.4 + - Fix accepting some invalid IPv6 addresses + - Reject CIDRs with negative or overlong masks + * perf: enable strict mode + +1.0.8 / 2015-05-10 +================== + + * deps: ipaddr.js@1.0.1 + +1.0.7 / 2015-03-16 +================== + + * deps: ipaddr.js@0.1.9 + - Fix OOM on certain inputs to `isValid` + +1.0.6 / 2015-02-01 +================== + + * deps: ipaddr.js@0.1.8 + +1.0.5 / 2015-01-08 +================== + + * deps: ipaddr.js@0.1.6 + +1.0.4 / 2014-11-23 +================== + + * deps: ipaddr.js@0.1.5 + - Fix edge cases with `isValid` + +1.0.3 / 2014-09-21 +================== + + * Use `forwarded` npm module + +1.0.2 / 2014-09-18 +================== + + * Fix a global leak when multiple subnets are trusted + * Support Node.js 0.6 + * deps: ipaddr.js@0.1.3 + +1.0.1 / 2014-06-03 +================== + + * Fix links in npm package + +1.0.0 / 2014-05-08 +================== + + * Add `trust` argument to determine proxy trust on + * Accepts custom function + * Accepts IPv4/IPv6 address(es) + * Accepts subnets + * Accepts pre-defined names + * Add optional `trust` argument to `proxyaddr.all` to + stop at first untrusted + * Add `proxyaddr.compile` to pre-compile `trust` function + to make subsequent calls faster + +0.0.1 / 2014-05-04 +================== + + * Fix bad npm publish + +0.0.0 / 2014-05-04 +================== + + * Initial release diff --git a/node_modules/express/node_modules/proxy-addr/LICENSE b/node_modules/express/node_modules/proxy-addr/LICENSE new file mode 100644 index 0000000..cab251c --- /dev/null +++ b/node_modules/express/node_modules/proxy-addr/LICENSE @@ -0,0 +1,22 @@ +(The MIT License) + +Copyright (c) 2014-2016 Douglas Christopher Wilson + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/express/node_modules/proxy-addr/README.md b/node_modules/express/node_modules/proxy-addr/README.md new file mode 100644 index 0000000..1bffc76 --- /dev/null +++ b/node_modules/express/node_modules/proxy-addr/README.md @@ -0,0 +1,136 @@ +# proxy-addr + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Node.js Version][node-version-image]][node-version-url] +[![Build Status][travis-image]][travis-url] +[![Test Coverage][coveralls-image]][coveralls-url] + +Determine address of proxied request + +## Install + +```sh +$ npm install proxy-addr +``` + +## API + +```js +var proxyaddr = require('proxy-addr') +``` + +### proxyaddr(req, trust) + +Return the address of the request, using the given `trust` parameter. + +The `trust` argument is a function that returns `true` if you trust +the address, `false` if you don't. The closest untrusted address is +returned. + +```js +proxyaddr(req, function(addr){ return addr === '127.0.0.1' }) +proxyaddr(req, function(addr, i){ return i < 1 }) +``` + +The `trust` arugment may also be a single IP address string or an +array of trusted addresses, as plain IP addresses, CIDR-formatted +strings, or IP/netmask strings. + +```js +proxyaddr(req, '127.0.0.1') +proxyaddr(req, ['127.0.0.0/8', '10.0.0.0/8']) +proxyaddr(req, ['127.0.0.0/255.0.0.0', '192.168.0.0/255.255.0.0']) +``` + +This module also supports IPv6. Your IPv6 addresses will be normalized +automatically (i.e. `fe80::00ed:1` equals `fe80:0:0:0:0:0:ed:1`). + +```js +proxyaddr(req, '::1') +proxyaddr(req, ['::1/128', 'fe80::/10']) +``` + +This module will automatically work with IPv4-mapped IPv6 addresses +as well to support node.js in IPv6-only mode. This means that you do +not have to specify both `::ffff:a00:1` and `10.0.0.1`. + +As a convenience, this module also takes certain pre-defined names +in addition to IP addresses, which expand into IP addresses: + +```js +proxyaddr(req, 'loopback') +proxyaddr(req, ['loopback', 'fc00:ac:1ab5:fff::1/64']) +``` + + * `loopback`: IPv4 and IPv6 loopback addresses (like `::1` and + `127.0.0.1`). + * `linklocal`: IPv4 and IPv6 link-local addresses (like + `fe80::1:1:1:1` and `169.254.0.1`). + * `uniquelocal`: IPv4 private addresses and IPv6 unique-local + addresses (like `fc00:ac:1ab5:fff::1` and `192.168.0.1`). + +When `trust` is specified as a function, it will be called for each +address to determine if it is a trusted address. The function is +given two arguments: `addr` and `i`, where `addr` is a string of +the address to check and `i` is a number that represents the distance +from the socket address. + +### proxyaddr.all(req, [trust]) + +Return all the addresses of the request, optionally stopping at the +first untrusted. This array is ordered from closest to furthest +(i.e. `arr[0] === req.connection.remoteAddress`). + +```js +proxyaddr.all(req) +``` + +The optional `trust` argument takes the same arguments as `trust` +does in `proxyaddr(req, trust)`. + +```js +proxyaddr.all(req, 'loopback') +``` + +### proxyaddr.compile(val) + +Compiles argument `val` into a `trust` function. This function takes +the same arguments as `trust` does in `proxyaddr(req, trust)` and +returns a function suitable for `proxyaddr(req, trust)`. + +```js +var trust = proxyaddr.compile('localhost') +var addr = proxyaddr(req, trust) +``` + +This function is meant to be optimized for use against every request. +It is recommend to compile a trust function up-front for the trusted +configuration and pass that to `proxyaddr(req, trust)` for each request. + +## Testing + +```sh +$ npm test +``` + +## Benchmarks + +```sh +$ npm run-script bench +``` + +## License + +[MIT](LICENSE) + +[npm-image]: https://img.shields.io/npm/v/proxy-addr.svg +[npm-url]: https://npmjs.org/package/proxy-addr +[node-version-image]: https://img.shields.io/node/v/proxy-addr.svg +[node-version-url]: http://nodejs.org/download/ +[travis-image]: https://img.shields.io/travis/jshttp/proxy-addr/master.svg +[travis-url]: https://travis-ci.org/jshttp/proxy-addr +[coveralls-image]: https://img.shields.io/coveralls/jshttp/proxy-addr/master.svg +[coveralls-url]: https://coveralls.io/r/jshttp/proxy-addr?branch=master +[downloads-image]: https://img.shields.io/npm/dm/proxy-addr.svg +[downloads-url]: https://npmjs.org/package/proxy-addr diff --git a/node_modules/express/node_modules/proxy-addr/index.js b/node_modules/express/node_modules/proxy-addr/index.js new file mode 100644 index 0000000..0b3cf0b --- /dev/null +++ b/node_modules/express/node_modules/proxy-addr/index.js @@ -0,0 +1,321 @@ +/*! + * proxy-addr + * Copyright(c) 2014-2016 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module exports. + */ + +module.exports = proxyaddr; +module.exports.all = alladdrs; +module.exports.compile = compile; + +/** + * Module dependencies. + */ + +var forwarded = require('forwarded'); +var ipaddr = require('ipaddr.js'); + +/** + * Variables. + */ + +var digitre = /^[0-9]+$/; +var isip = ipaddr.isValid; +var parseip = ipaddr.parse; + +/** + * Pre-defined IP ranges. + */ + +var ipranges = { + linklocal: ['169.254.0.0/16', 'fe80::/10'], + loopback: ['127.0.0.1/8', '::1/128'], + uniquelocal: ['10.0.0.0/8', '172.16.0.0/12', '192.168.0.0/16', 'fc00::/7'] +}; + +/** + * Get all addresses in the request, optionally stopping + * at the first untrusted. + * + * @param {Object} request + * @param {Function|Array|String} [trust] + * @api public + */ + +function alladdrs(req, trust) { + // get addresses + var addrs = forwarded(req); + + if (!trust) { + // Return all addresses + return addrs; + } + + if (typeof trust !== 'function') { + trust = compile(trust); + } + + for (var i = 0; i < addrs.length - 1; i++) { + if (trust(addrs[i], i)) continue; + + addrs.length = i + 1; + } + + return addrs; +} + +/** + * Compile argument into trust function. + * + * @param {Array|String} val + * @api private + */ + +function compile(val) { + if (!val) { + throw new TypeError('argument is required'); + } + + var trust = typeof val === 'string' + ? [val] + : val; + + if (!Array.isArray(trust)) { + throw new TypeError('unsupported trust argument'); + } + + for (var i = 0; i < trust.length; i++) { + val = trust[i]; + + if (!ipranges.hasOwnProperty(val)) { + continue; + } + + // Splice in pre-defined range + val = ipranges[val]; + trust.splice.apply(trust, [i, 1].concat(val)); + i += val.length - 1; + } + + return compileTrust(compileRangeSubnets(trust)); +} + +/** + * Compile `arr` elements into range subnets. + * + * @param {Array} arr + * @api private + */ + +function compileRangeSubnets(arr) { + var rangeSubnets = new Array(arr.length); + + for (var i = 0; i < arr.length; i++) { + rangeSubnets[i] = parseipNotation(arr[i]); + } + + return rangeSubnets; +} + +/** + * Compile range subnet array into trust function. + * + * @param {Array} rangeSubnets + * @api private + */ + +function compileTrust(rangeSubnets) { + // Return optimized function based on length + var len = rangeSubnets.length; + return len === 0 + ? trustNone + : len === 1 + ? trustSingle(rangeSubnets[0]) + : trustMulti(rangeSubnets); +} + +/** + * Parse IP notation string into range subnet. + * + * @param {String} note + * @api private + */ + +function parseipNotation(note) { + var pos = note.lastIndexOf('/'); + var str = pos !== -1 + ? note.substring(0, pos) + : note; + + if (!isip(str)) { + throw new TypeError('invalid IP address: ' + str); + } + + var ip = parseip(str); + + if (pos === -1 && ip.kind() === 'ipv6' && ip.isIPv4MappedAddress()) { + // Store as IPv4 + ip = ip.toIPv4Address(); + } + + var max = ip.kind() === 'ipv6' + ? 128 + : 32; + + var range = pos !== -1 + ? note.substring(pos + 1, note.length) + : null; + + if (range === null) { + range = max; + } else if (digitre.test(range)) { + range = parseInt(range, 10); + } else if (ip.kind() === 'ipv4' && isip(range)) { + range = parseNetmask(range); + } else { + range = null; + } + + if (range <= 0 || range > max) { + throw new TypeError('invalid range on address: ' + note); + } + + return [ip, range]; +} + +/** + * Parse netmask string into CIDR range. + * + * @param {String} netmask + * @api private + */ + +function parseNetmask(netmask) { + var ip = parseip(netmask); + var kind = ip.kind(); + + return kind === 'ipv4' + ? ip.prefixLengthFromSubnetMask() + : null; +} + +/** + * Determine address of proxied request. + * + * @param {Object} request + * @param {Function|Array|String} trust + * @api public + */ + +function proxyaddr(req, trust) { + if (!req) { + throw new TypeError('req argument is required'); + } + + if (!trust) { + throw new TypeError('trust argument is required'); + } + + var addrs = alladdrs(req, trust); + var addr = addrs[addrs.length - 1]; + + return addr; +} + +/** + * Static trust function to trust nothing. + * + * @api private + */ + +function trustNone() { + return false; +} + +/** + * Compile trust function for multiple subnets. + * + * @param {Array} subnets + * @api private + */ + +function trustMulti(subnets) { + return function trust(addr) { + if (!isip(addr)) return false; + + var ip = parseip(addr); + var ipconv; + var kind = ip.kind(); + + for (var i = 0; i < subnets.length; i++) { + var subnet = subnets[i]; + var subnetip = subnet[0]; + var subnetkind = subnetip.kind(); + var subnetrange = subnet[1]; + var trusted = ip; + + if (kind !== subnetkind) { + if (subnetkind === 'ipv4' && !ip.isIPv4MappedAddress()) { + // Incompatible IP addresses + continue; + } + + if (!ipconv) { + // Convert IP to match subnet IP kind + ipconv = subnetkind === 'ipv4' + ? ip.toIPv4Address() + : ip.toIPv4MappedAddress(); + } + + trusted = ipconv; + } + + if (trusted.match(subnetip, subnetrange)) { + return true; + } + } + + return false; + }; +} + +/** + * Compile trust function for single subnet. + * + * @param {Object} subnet + * @api private + */ + +function trustSingle(subnet) { + var subnetip = subnet[0]; + var subnetkind = subnetip.kind(); + var subnetisipv4 = subnetkind === 'ipv4'; + var subnetrange = subnet[1]; + + return function trust(addr) { + if (!isip(addr)) return false; + + var ip = parseip(addr); + var kind = ip.kind(); + + if (kind !== subnetkind) { + if (subnetisipv4 && !ip.isIPv4MappedAddress()) { + // Incompatible IP addresses + return false; + } + + // Convert IP to match subnet IP kind + ip = subnetisipv4 + ? ip.toIPv4Address() + : ip.toIPv4MappedAddress(); + } + + return ip.match(subnetip, subnetrange); + }; +} diff --git a/node_modules/express/node_modules/proxy-addr/node_modules/forwarded/HISTORY.md b/node_modules/express/node_modules/proxy-addr/node_modules/forwarded/HISTORY.md new file mode 100644 index 0000000..97fa1d1 --- /dev/null +++ b/node_modules/express/node_modules/proxy-addr/node_modules/forwarded/HISTORY.md @@ -0,0 +1,4 @@ +0.1.0 / 2014-09-21 +================== + + * Initial release diff --git a/node_modules/express/node_modules/proxy-addr/node_modules/forwarded/LICENSE b/node_modules/express/node_modules/proxy-addr/node_modules/forwarded/LICENSE new file mode 100644 index 0000000..b7dce6c --- /dev/null +++ b/node_modules/express/node_modules/proxy-addr/node_modules/forwarded/LICENSE @@ -0,0 +1,22 @@ +(The MIT License) + +Copyright (c) 2014 Douglas Christopher Wilson + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/express/node_modules/proxy-addr/node_modules/forwarded/README.md b/node_modules/express/node_modules/proxy-addr/node_modules/forwarded/README.md new file mode 100644 index 0000000..2b4988f --- /dev/null +++ b/node_modules/express/node_modules/proxy-addr/node_modules/forwarded/README.md @@ -0,0 +1,53 @@ +# forwarded + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Node.js Version][node-version-image]][node-version-url] +[![Build Status][travis-image]][travis-url] +[![Test Coverage][coveralls-image]][coveralls-url] + +Parse HTTP X-Forwarded-For header + +## Installation + +```sh +$ npm install forwarded +``` + +## API + +```js +var forwarded = require('forwarded') +``` + +### forwarded(req) + +```js +var addresses = forwarded(req) +``` + +Parse the `X-Forwarded-For` header from the request. Returns an array +of the addresses, including the socket address for the `req`. In reverse +order (i.e. index `0` is the socket address and the last index is the +furthest address, typically the end-user). + +## Testing + +```sh +$ npm test +``` + +## License + +[MIT](LICENSE) + +[npm-image]: https://img.shields.io/npm/v/forwarded.svg?style=flat +[npm-url]: https://npmjs.org/package/forwarded +[node-version-image]: https://img.shields.io/node/v/forwarded.svg?style=flat +[node-version-url]: http://nodejs.org/download/ +[travis-image]: https://img.shields.io/travis/jshttp/forwarded.svg?style=flat +[travis-url]: https://travis-ci.org/jshttp/forwarded +[coveralls-image]: https://img.shields.io/coveralls/jshttp/forwarded.svg?style=flat +[coveralls-url]: https://coveralls.io/r/jshttp/forwarded?branch=master +[downloads-image]: https://img.shields.io/npm/dm/forwarded.svg?style=flat +[downloads-url]: https://npmjs.org/package/forwarded diff --git a/node_modules/express/node_modules/proxy-addr/node_modules/forwarded/index.js b/node_modules/express/node_modules/proxy-addr/node_modules/forwarded/index.js new file mode 100644 index 0000000..2f5c340 --- /dev/null +++ b/node_modules/express/node_modules/proxy-addr/node_modules/forwarded/index.js @@ -0,0 +1,35 @@ +/*! + * forwarded + * Copyright(c) 2014 Douglas Christopher Wilson + * MIT Licensed + */ + +/** + * Module exports. + */ + +module.exports = forwarded + +/** + * Get all addresses in the request, using the `X-Forwarded-For` header. + * + * @param {Object} req + * @api public + */ + +function forwarded(req) { + if (!req) { + throw new TypeError('argument req is required') + } + + // simple header parsing + var proxyAddrs = (req.headers['x-forwarded-for'] || '') + .split(/ *, */) + .filter(Boolean) + .reverse() + var socketAddr = req.connection.remoteAddress + var addrs = [socketAddr].concat(proxyAddrs) + + // return all addresses + return addrs +} diff --git a/node_modules/express/node_modules/proxy-addr/node_modules/forwarded/package.json b/node_modules/express/node_modules/proxy-addr/node_modules/forwarded/package.json new file mode 100644 index 0000000..7df8932 --- /dev/null +++ b/node_modules/express/node_modules/proxy-addr/node_modules/forwarded/package.json @@ -0,0 +1,65 @@ +{ + "name": "forwarded", + "description": "Parse HTTP X-Forwarded-For header", + "version": "0.1.0", + "contributors": [ + { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + } + ], + "license": "MIT", + "keywords": [ + "x-forwarded-for", + "http", + "req" + ], + "repository": { + "type": "git", + "url": "git+https://github.com/jshttp/forwarded.git" + }, + "devDependencies": { + "istanbul": "0.3.2", + "mocha": "~1.21.4" + }, + "files": [ + "LICENSE", + "HISTORY.md", + "README.md", + "index.js" + ], + "engines": { + "node": ">= 0.6" + }, + "scripts": { + "test": "mocha --reporter spec --bail --check-leaks test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot --check-leaks test/", + "test-travis": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter spec --check-leaks test/" + }, + "gitHead": "e9a9faeb3cfaadf40eb57d144fff26bca9b818e8", + "bugs": { + "url": "https://github.com/jshttp/forwarded/issues" + }, + "homepage": "https://github.com/jshttp/forwarded", + "_id": "forwarded@0.1.0", + "_shasum": "19ef9874c4ae1c297bcf078fde63a09b66a84363", + "_from": "forwarded@>=0.1.0 <0.2.0", + "_npmVersion": "1.4.21", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "maintainers": [ + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + } + ], + "dist": { + "shasum": "19ef9874c4ae1c297bcf078fde63a09b66a84363", + "tarball": "https://registry.npmjs.org/forwarded/-/forwarded-0.1.0.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/forwarded/-/forwarded-0.1.0.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/express/node_modules/proxy-addr/node_modules/ipaddr.js/.npmignore b/node_modules/express/node_modules/proxy-addr/node_modules/ipaddr.js/.npmignore new file mode 100644 index 0000000..7a1537b --- /dev/null +++ b/node_modules/express/node_modules/proxy-addr/node_modules/ipaddr.js/.npmignore @@ -0,0 +1,2 @@ +.idea +node_modules diff --git a/node_modules/express/node_modules/proxy-addr/node_modules/ipaddr.js/.travis.yml b/node_modules/express/node_modules/proxy-addr/node_modules/ipaddr.js/.travis.yml new file mode 100644 index 0000000..aa3d14a --- /dev/null +++ b/node_modules/express/node_modules/proxy-addr/node_modules/ipaddr.js/.travis.yml @@ -0,0 +1,10 @@ +language: node_js + +node_js: + - "0.10" + - "0.11" + - "0.12" + - "4.0" + - "4.1" + - "4.2" + - "5" diff --git a/node_modules/express/node_modules/proxy-addr/node_modules/ipaddr.js/Cakefile b/node_modules/express/node_modules/proxy-addr/node_modules/ipaddr.js/Cakefile new file mode 100644 index 0000000..7fd355a --- /dev/null +++ b/node_modules/express/node_modules/proxy-addr/node_modules/ipaddr.js/Cakefile @@ -0,0 +1,18 @@ +fs = require 'fs' +CoffeeScript = require 'coffee-script' +nodeunit = require 'nodeunit' +UglifyJS = require 'uglify-js' + +task 'build', 'build the JavaScript files from CoffeeScript source', build = (cb) -> + source = fs.readFileSync 'src/ipaddr.coffee' + fs.writeFileSync 'lib/ipaddr.js', CoffeeScript.compile source.toString() + + invoke 'test' + invoke 'compress' + +task 'test', 'run the bundled tests', (cb) -> + nodeunit.reporters.default.run ['test'] + +task 'compress', 'uglify the resulting javascript', (cb) -> + result = UglifyJS.minify('lib/ipaddr.js') + fs.writeFileSync('ipaddr.min.js', result.code) diff --git a/node_modules/express/node_modules/proxy-addr/node_modules/ipaddr.js/LICENSE b/node_modules/express/node_modules/proxy-addr/node_modules/ipaddr.js/LICENSE new file mode 100644 index 0000000..3493f0d --- /dev/null +++ b/node_modules/express/node_modules/proxy-addr/node_modules/ipaddr.js/LICENSE @@ -0,0 +1,19 @@ +Copyright (C) 2011 Peter Zotov + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. \ No newline at end of file diff --git a/node_modules/express/node_modules/proxy-addr/node_modules/ipaddr.js/README.md b/node_modules/express/node_modules/proxy-addr/node_modules/ipaddr.js/README.md new file mode 100644 index 0000000..bfcb1c9 --- /dev/null +++ b/node_modules/express/node_modules/proxy-addr/node_modules/ipaddr.js/README.md @@ -0,0 +1,209 @@ +# ipaddr.js — an IPv6 and IPv4 address manipulation library [![Build Status](https://travis-ci.org/whitequark/ipaddr.js.svg)](https://travis-ci.org/whitequark/ipaddr.js) + +ipaddr.js is a small (1.9K minified and gzipped) library for manipulating +IP addresses in JavaScript environments. It runs on both CommonJS runtimes +(e.g. [nodejs]) and in a web browser. + +ipaddr.js allows you to verify and parse string representation of an IP +address, match it against a CIDR range or range list, determine if it falls +into some reserved ranges (examples include loopback and private ranges), +and convert between IPv4 and IPv4-mapped IPv6 addresses. + +[nodejs]: http://nodejs.org + +## Installation + +`npm install ipaddr.js` + +or + +`bower install ipaddr.js` + +## API + +ipaddr.js defines one object in the global scope: `ipaddr`. In CommonJS, +it is exported from the module: + +```js +var ipaddr = require('ipaddr.js'); +``` + +The API consists of several global methods and two classes: ipaddr.IPv6 and ipaddr.IPv4. + +### Global methods + +There are three global methods defined: `ipaddr.isValid`, `ipaddr.parse` and +`ipaddr.process`. All of them receive a string as a single parameter. + +The `ipaddr.isValid` method returns `true` if the address is a valid IPv4 or +IPv6 address, and `false` otherwise. It does not throw any exceptions. + +The `ipaddr.parse` method returns an object representing the IP address, +or throws an `Error` if the passed string is not a valid representation of an +IP address. + +The `ipaddr.process` method works just like the `ipaddr.parse` one, but it +automatically converts IPv4-mapped IPv6 addresses to their IPv4 couterparts +before returning. It is useful when you have a Node.js instance listening +on an IPv6 socket, and the `net.ivp6.bindv6only` sysctl parameter (or its +equivalent on non-Linux OS) is set to 0. In this case, you can accept IPv4 +connections on your IPv6-only socket, but the remote address will be mangled. +Use `ipaddr.process` method to automatically demangle it. + +### Object representation + +Parsing methods return an object which descends from `ipaddr.IPv6` or +`ipaddr.IPv4`. These objects share some properties, but most of them differ. + +#### Shared properties + +One can determine the type of address by calling `addr.kind()`. It will return +either `"ipv6"` or `"ipv4"`. + +An address can be converted back to its string representation with `addr.toString()`. +Note that this method: + * does not return the original string used to create the object (in fact, there is + no way of getting that string) + * returns a compact representation (when it is applicable) + +A `match(range, bits)` method can be used to check if the address falls into a +certain CIDR range. +Note that an address can be (obviously) matched only against an address of the same type. + +For example: + +```js +var addr = ipaddr.parse("2001:db8:1234::1"); +var range = ipaddr.parse("2001:db8::"); + +addr.match(range, 32); // => true +``` + +Alternatively, `match` can also be called as `match([range, bits])`. In this way, +it can be used together with the `parseCIDR(string)` method, which parses an IP +address together with a CIDR range. + +For example: + +```js +var addr = ipaddr.parse("2001:db8:1234::1"); + +addr.match(ipaddr.parseCIDR("2001:db8::/32")); // => true +``` + +A `range()` method returns one of predefined names for several special ranges defined +by IP protocols. The exact names (and their respective CIDR ranges) can be looked up +in the source: [IPv6 ranges] and [IPv4 ranges]. Some common ones include `"unicast"` +(the default one) and `"reserved"`. + +You can match against your own range list by using +`ipaddr.subnetMatch(address, rangeList, defaultName)` method. It can work with both +IPv6 and IPv4 addresses, and accepts a name-to-subnet map as the range list. For example: + +```js +var rangeList = { + documentationOnly: [ ipaddr.parse('2001:db8::'), 32 ], + tunnelProviders: [ + [ ipaddr.parse('2001:470::'), 32 ], // he.net + [ ipaddr.parse('2001:5c0::'), 32 ] // freenet6 + ] +}; +ipaddr.subnetMatch(ipaddr.parse('2001:470:8:66::1'), rangeList, 'unknown'); // => "he.net" +``` + +The addresses can be converted to their byte representation with `toByteArray()`. +(Actually, JavaScript mostly does not know about byte buffers. They are emulated with +arrays of numbers, each in range of 0..255.) + +```js +var bytes = ipaddr.parse('2a00:1450:8007::68').toByteArray(); // ipv6.google.com +bytes // => [42, 0x00, 0x14, 0x50, 0x80, 0x07, 0x00, , 0x00, 0x68 ] +``` + +The `ipaddr.IPv4` and `ipaddr.IPv6` objects have some methods defined, too. All of them +have the same interface for both protocols, and are similar to global methods. + +`ipaddr.IPvX.isValid(string)` can be used to check if the string is a valid address +for particular protocol, and `ipaddr.IPvX.parse(string)` is the error-throwing parser. + +[IPv6 ranges]: https://github.com/whitequark/ipaddr.js/blob/master/src/ipaddr.coffee#L186 +[IPv4 ranges]: https://github.com/whitequark/ipaddr.js/blob/master/src/ipaddr.coffee#L71 + +#### IPv6 properties + +Sometimes you will want to convert IPv6 not to a compact string representation (with +the `::` substitution); the `toNormalizedString()` method will return an address where +all zeroes are explicit. + +For example: + +```js +var addr = ipaddr.parse("2001:0db8::0001"); +addr.toString(); // => "2001:db8::1" +addr.toNormalizedString(); // => "2001:db8:0:0:0:0:0:1" +``` + +The `isIPv4MappedAddress()` method will return `true` if this address is an IPv4-mapped +one, and `toIPv4Address()` will return an IPv4 object address. + +To access the underlying binary representation of the address, use `addr.parts`. + +```js +var addr = ipaddr.parse("2001:db8:10::1234:DEAD"); +addr.parts // => [0x2001, 0xdb8, 0x10, 0, 0, 0, 0x1234, 0xdead] +``` + +#### IPv4 properties + +`toIPv4MappedAddress()` will return a corresponding IPv4-mapped IPv6 address. + +To access the underlying representation of the address, use `addr.octets`. + +```js +var addr = ipaddr.parse("192.168.1.1"); +addr.octets // => [192, 168, 1, 1] +``` + +`prefixLengthFromSubnetMask()` will return a CIDR prefix length for a valid IPv4 netmask or +false if the netmask is not valid. + +```js +ipaddr.IPv4.parse('255.255.255.240').prefixLengthFromSubnetMask() == 28 +ipaddr.IPv4.parse('255.192.164.0').prefixLengthFromSubnetMask() == null +``` + +#### Conversion + +IPv4 and IPv6 can be converted bidirectionally to and from network byte order (MSB) byte arrays. + +The `fromByteArray()` method will take an array and create an appropriate IPv4 or IPv6 object +if the input satisfies the requirements. For IPv4 it has to be an array of four 8-bit values, +while for IPv6 it has to be an array of sixteen 8-bit values. + +For example: +```js +var addr = ipaddr.fromByteArray([0x7f, 0, 0, 1]); +addr.toString(); // => "127.0.0.1" +``` + +or + +```js +var addr = ipaddr.fromByteArray([0x20, 1, 0xd, 0xb8, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1]) +addr.toString(); // => "2001:db8::1" +``` + +Both objects also offer a `toByteArray()` method, which returns an array in network byte order (MSB). + +For example: +```js +var addr = ipaddr.parse("127.0.0.1"); +addr.toByteArray(); // => [0x7f, 0, 0, 1] +``` + +or + +```js +var addr = ipaddr.parse("2001:db8::1"); +addr.toByteArray(); // => [0x20, 1, 0xd, 0xb8, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1] +``` diff --git a/node_modules/express/node_modules/proxy-addr/node_modules/ipaddr.js/bower.json b/node_modules/express/node_modules/proxy-addr/node_modules/ipaddr.js/bower.json new file mode 100644 index 0000000..e494f97 --- /dev/null +++ b/node_modules/express/node_modules/proxy-addr/node_modules/ipaddr.js/bower.json @@ -0,0 +1,29 @@ +{ + "name": "ipaddr.js", + "version": "1.1.1", + "homepage": "https://github.com/whitequark/ipaddr.js", + "authors": [ + "whitequark " + ], + "description": "IP address manipulation library in JavaScript (CoffeeScript, actually)", + "main": "lib/ipaddr.js", + "moduleType": [ + "globals", + "node" + ], + "keywords": [ + "javscript", + "ip", + "address", + "ipv4", + "ipv6" + ], + "license": "MIT", + "ignore": [ + "**/.*", + "node_modules", + "bower_components", + "test", + "tests" + ] +} diff --git a/node_modules/express/node_modules/proxy-addr/node_modules/ipaddr.js/ipaddr.min.js b/node_modules/express/node_modules/proxy-addr/node_modules/ipaddr.js/ipaddr.min.js new file mode 100644 index 0000000..ffa32ff --- /dev/null +++ b/node_modules/express/node_modules/proxy-addr/node_modules/ipaddr.js/ipaddr.min.js @@ -0,0 +1 @@ +(function(){var r,t,n,e,i,o,a,s;t={},s=this,"undefined"!=typeof module&&null!==module&&module.exports?module.exports=t:s.ipaddr=t,a=function(r,t,n,e){var i,o;if(r.length!==t.length)throw new Error("ipaddr: cannot match CIDR for objects with different lengths");for(i=0;e>0;){if(o=n-e,0>o&&(o=0),r[i]>>o!==t[i]>>o)return!1;e-=n,i+=1}return!0},t.subnetMatch=function(r,t,n){var e,i,o,a,s;null==n&&(n="unicast");for(e in t)for(i=t[e],!i[0]||i[0]instanceof Array||(i=[i]),a=0,s=i.length;s>a;a++)if(o=i[a],r.match.apply(r,o))return e;return n},t.IPv4=function(){function r(r){var t,n,e;if(4!==r.length)throw new Error("ipaddr: ipv4 octet count should be 4");for(n=0,e=r.length;e>n;n++)if(t=r[n],!(t>=0&&255>=t))throw new Error("ipaddr: ipv4 octet should fit in 8 bits");this.octets=r}return r.prototype.kind=function(){return"ipv4"},r.prototype.toString=function(){return this.octets.join(".")},r.prototype.toByteArray=function(){return this.octets.slice(0)},r.prototype.match=function(r,t){var n;if(void 0===t&&(n=r,r=n[0],t=n[1]),"ipv4"!==r.kind())throw new Error("ipaddr: cannot match ipv4 address with non-ipv4 one");return a(this.octets,r.octets,8,t)},r.prototype.SpecialRanges={unspecified:[[new r([0,0,0,0]),8]],broadcast:[[new r([255,255,255,255]),32]],multicast:[[new r([224,0,0,0]),4]],linkLocal:[[new r([169,254,0,0]),16]],loopback:[[new r([127,0,0,0]),8]],"private":[[new r([10,0,0,0]),8],[new r([172,16,0,0]),12],[new r([192,168,0,0]),16]],reserved:[[new r([192,0,0,0]),24],[new r([192,0,2,0]),24],[new r([192,88,99,0]),24],[new r([198,51,100,0]),24],[new r([203,0,113,0]),24],[new r([240,0,0,0]),4]]},r.prototype.range=function(){return t.subnetMatch(this,this.SpecialRanges)},r.prototype.toIPv4MappedAddress=function(){return t.IPv6.parse("::ffff:"+this.toString())},r.prototype.prefixLengthFromSubnetMask=function(){var r,t,n,e,i,o,a;for(o={0:8,128:7,192:6,224:5,240:4,248:3,252:2,254:1,255:0},r=0,e=!1,t=a=3;a>=0;t=a+=-1){if(n=this.octets[t],!(n in o))return null;if(i=o[n],e&&0!==i)return null;8!==i&&(e=!0),r+=i}return 32-r},r}(),n="(0?\\d+|0x[a-f0-9]+)",e={fourOctet:new RegExp("^"+n+"\\."+n+"\\."+n+"\\."+n+"$","i"),longValue:new RegExp("^"+n+"$","i")},t.IPv4.parser=function(r){var t,n,i,o,a;if(n=function(r){return"0"===r[0]&&"x"!==r[1]?parseInt(r,8):parseInt(r)},t=r.match(e.fourOctet))return function(){var r,e,o,a;for(o=t.slice(1,6),a=[],r=0,e=o.length;e>r;r++)i=o[r],a.push(n(i));return a}();if(t=r.match(e.longValue)){if(a=n(t[1]),a>4294967295||0>a)throw new Error("ipaddr: address outside defined range");return function(){var r,t;for(t=[],o=r=0;24>=r;o=r+=8)t.push(a>>o&255);return t}().reverse()}return null},t.IPv6=function(){function r(r){var t,n,e,i,o,a;if(16===r.length)for(this.parts=[],t=e=0;14>=e;t=e+=2)this.parts.push(r[t]<<8|r[t+1]);else{if(8!==r.length)throw new Error("ipaddr: ipv6 part count should be 8 or 16");this.parts=r}for(a=this.parts,i=0,o=a.length;o>i;i++)if(n=a[i],!(n>=0&&65535>=n))throw new Error("ipaddr: ipv6 part should fit in 16 bits")}return r.prototype.kind=function(){return"ipv6"},r.prototype.toString=function(){var r,t,n,e,i,o,a;for(i=function(){var r,n,e,i;for(e=this.parts,i=[],r=0,n=e.length;n>r;r++)t=e[r],i.push(t.toString(16));return i}.call(this),r=[],n=function(t){return r.push(t)},e=0,o=0,a=i.length;a>o;o++)switch(t=i[o],e){case 0:n("0"===t?"":t),e=1;break;case 1:"0"===t?e=2:n(t);break;case 2:"0"!==t&&(n(""),n(t),e=3);break;case 3:n(t)}return 2===e&&(n(""),n("")),r.join(":")},r.prototype.toByteArray=function(){var r,t,n,e,i;for(r=[],i=this.parts,n=0,e=i.length;e>n;n++)t=i[n],r.push(t>>8),r.push(255&t);return r},r.prototype.toNormalizedString=function(){var r;return function(){var t,n,e,i;for(e=this.parts,i=[],t=0,n=e.length;n>t;t++)r=e[t],i.push(r.toString(16));return i}.call(this).join(":")},r.prototype.match=function(r,t){var n;if(void 0===t&&(n=r,r=n[0],t=n[1]),"ipv6"!==r.kind())throw new Error("ipaddr: cannot match ipv6 address with non-ipv6 one");return a(this.parts,r.parts,16,t)},r.prototype.SpecialRanges={unspecified:[new r([0,0,0,0,0,0,0,0]),128],linkLocal:[new r([65152,0,0,0,0,0,0,0]),10],multicast:[new r([65280,0,0,0,0,0,0,0]),8],loopback:[new r([0,0,0,0,0,0,0,1]),128],uniqueLocal:[new r([64512,0,0,0,0,0,0,0]),7],ipv4Mapped:[new r([0,0,0,0,0,65535,0,0]),96],rfc6145:[new r([0,0,0,0,65535,0,0,0]),96],rfc6052:[new r([100,65435,0,0,0,0,0,0]),96],"6to4":[new r([8194,0,0,0,0,0,0,0]),16],teredo:[new r([8193,0,0,0,0,0,0,0]),32],reserved:[[new r([8193,3512,0,0,0,0,0,0]),32]]},r.prototype.range=function(){return t.subnetMatch(this,this.SpecialRanges)},r.prototype.isIPv4MappedAddress=function(){return"ipv4Mapped"===this.range()},r.prototype.toIPv4Address=function(){var r,n,e;if(!this.isIPv4MappedAddress())throw new Error("ipaddr: trying to convert a generic ipv6 address to ipv4");return e=this.parts.slice(-2),r=e[0],n=e[1],new t.IPv4([r>>8,255&r,n>>8,255&n])},r}(),i="(?:[0-9a-f]+::?)+",o={"native":new RegExp("^(::)?("+i+")?([0-9a-f]+)?(::)?$","i"),transitional:new RegExp("^((?:"+i+")|(?:::)(?:"+i+")?)"+(""+n+"\\."+n+"\\."+n+"\\."+n+"$"),"i")},r=function(r,t){var n,e,i,o,a;if(r.indexOf("::")!==r.lastIndexOf("::"))return null;for(n=0,e=-1;(e=r.indexOf(":",e+1))>=0;)n++;if("::"===r.substr(0,2)&&n--,"::"===r.substr(-2,2)&&n--,n>t)return null;for(a=t-n,o=":";a--;)o+="0:";return r=r.replace("::",o),":"===r[0]&&(r=r.slice(1)),":"===r[r.length-1]&&(r=r.slice(0,-1)),function(){var t,n,e,o;for(e=r.split(":"),o=[],t=0,n=e.length;n>t;t++)i=e[t],o.push(parseInt(i,16));return o}()},t.IPv6.parser=function(t){var n,e,i,a,s,p;if(t.match(o["native"]))return r(t,8);if((n=t.match(o.transitional))&&(a=r(n[1].slice(0,-1),6))){for(i=[parseInt(n[2]),parseInt(n[3]),parseInt(n[4]),parseInt(n[5])],s=0,p=i.length;p>s;s++)if(e=i[s],!(e>=0&&255>=e))return null;return a.push(i[0]<<8|i[1]),a.push(i[2]<<8|i[3]),a}return null},t.IPv4.isIPv4=t.IPv6.isIPv6=function(r){return null!==this.parser(r)},t.IPv4.isValid=function(r){var t;try{return new this(this.parser(r)),!0}catch(n){return t=n,!1}},t.IPv6.isValid=function(r){var t;if("string"==typeof r&&-1===r.indexOf(":"))return!1;try{return new this(this.parser(r)),!0}catch(n){return t=n,!1}},t.IPv4.parse=t.IPv6.parse=function(r){var t;if(t=this.parser(r),null===t)throw new Error("ipaddr: string is not formatted like ip address");return new this(t)},t.IPv4.parseCIDR=function(r){var t,n;if((n=r.match(/^(.+)\/(\d+)$/))&&(t=parseInt(n[2]),t>=0&&32>=t))return[this.parse(n[1]),t];throw new Error("ipaddr: string is not formatted like an IPv4 CIDR range")},t.IPv6.parseCIDR=function(r){var t,n;if((n=r.match(/^(.+)\/(\d+)$/))&&(t=parseInt(n[2]),t>=0&&128>=t))return[this.parse(n[1]),t];throw new Error("ipaddr: string is not formatted like an IPv6 CIDR range")},t.isValid=function(r){return t.IPv6.isValid(r)||t.IPv4.isValid(r)},t.parse=function(r){if(t.IPv6.isValid(r))return t.IPv6.parse(r);if(t.IPv4.isValid(r))return t.IPv4.parse(r);throw new Error("ipaddr: the address has neither IPv6 nor IPv4 format")},t.parseCIDR=function(r){var n;try{return t.IPv6.parseCIDR(r)}catch(e){n=e;try{return t.IPv4.parseCIDR(r)}catch(e){throw n=e,new Error("ipaddr: the address has neither IPv6 nor IPv4 CIDR format")}}},t.fromByteArray=function(r){var n;if(n=r.length,4===n)return new t.IPv4(r);if(16===n)return new t.IPv6(r);throw new Error("ipaddr: the binary input is neither an IPv6 nor IPv4 address")},t.process=function(r){var t;return t=this.parse(r),"ipv6"===t.kind()&&t.isIPv4MappedAddress()?t.toIPv4Address():t}}).call(this); \ No newline at end of file diff --git a/node_modules/express/node_modules/proxy-addr/node_modules/ipaddr.js/lib/ipaddr.js b/node_modules/express/node_modules/proxy-addr/node_modules/ipaddr.js/lib/ipaddr.js new file mode 100644 index 0000000..36774e7 --- /dev/null +++ b/node_modules/express/node_modules/proxy-addr/node_modules/ipaddr.js/lib/ipaddr.js @@ -0,0 +1,526 @@ +(function() { + var expandIPv6, ipaddr, ipv4Part, ipv4Regexes, ipv6Part, ipv6Regexes, matchCIDR, root; + + ipaddr = {}; + + root = this; + + if ((typeof module !== "undefined" && module !== null) && module.exports) { + module.exports = ipaddr; + } else { + root['ipaddr'] = ipaddr; + } + + matchCIDR = function(first, second, partSize, cidrBits) { + var part, shift; + if (first.length !== second.length) { + throw new Error("ipaddr: cannot match CIDR for objects with different lengths"); + } + part = 0; + while (cidrBits > 0) { + shift = partSize - cidrBits; + if (shift < 0) { + shift = 0; + } + if (first[part] >> shift !== second[part] >> shift) { + return false; + } + cidrBits -= partSize; + part += 1; + } + return true; + }; + + ipaddr.subnetMatch = function(address, rangeList, defaultName) { + var rangeName, rangeSubnets, subnet, _i, _len; + if (defaultName == null) { + defaultName = 'unicast'; + } + for (rangeName in rangeList) { + rangeSubnets = rangeList[rangeName]; + if (rangeSubnets[0] && !(rangeSubnets[0] instanceof Array)) { + rangeSubnets = [rangeSubnets]; + } + for (_i = 0, _len = rangeSubnets.length; _i < _len; _i++) { + subnet = rangeSubnets[_i]; + if (address.match.apply(address, subnet)) { + return rangeName; + } + } + } + return defaultName; + }; + + ipaddr.IPv4 = (function() { + function IPv4(octets) { + var octet, _i, _len; + if (octets.length !== 4) { + throw new Error("ipaddr: ipv4 octet count should be 4"); + } + for (_i = 0, _len = octets.length; _i < _len; _i++) { + octet = octets[_i]; + if (!((0 <= octet && octet <= 255))) { + throw new Error("ipaddr: ipv4 octet should fit in 8 bits"); + } + } + this.octets = octets; + } + + IPv4.prototype.kind = function() { + return 'ipv4'; + }; + + IPv4.prototype.toString = function() { + return this.octets.join("."); + }; + + IPv4.prototype.toByteArray = function() { + return this.octets.slice(0); + }; + + IPv4.prototype.match = function(other, cidrRange) { + var _ref; + if (cidrRange === void 0) { + _ref = other, other = _ref[0], cidrRange = _ref[1]; + } + if (other.kind() !== 'ipv4') { + throw new Error("ipaddr: cannot match ipv4 address with non-ipv4 one"); + } + return matchCIDR(this.octets, other.octets, 8, cidrRange); + }; + + IPv4.prototype.SpecialRanges = { + unspecified: [[new IPv4([0, 0, 0, 0]), 8]], + broadcast: [[new IPv4([255, 255, 255, 255]), 32]], + multicast: [[new IPv4([224, 0, 0, 0]), 4]], + linkLocal: [[new IPv4([169, 254, 0, 0]), 16]], + loopback: [[new IPv4([127, 0, 0, 0]), 8]], + "private": [[new IPv4([10, 0, 0, 0]), 8], [new IPv4([172, 16, 0, 0]), 12], [new IPv4([192, 168, 0, 0]), 16]], + reserved: [[new IPv4([192, 0, 0, 0]), 24], [new IPv4([192, 0, 2, 0]), 24], [new IPv4([192, 88, 99, 0]), 24], [new IPv4([198, 51, 100, 0]), 24], [new IPv4([203, 0, 113, 0]), 24], [new IPv4([240, 0, 0, 0]), 4]] + }; + + IPv4.prototype.range = function() { + return ipaddr.subnetMatch(this, this.SpecialRanges); + }; + + IPv4.prototype.toIPv4MappedAddress = function() { + return ipaddr.IPv6.parse("::ffff:" + (this.toString())); + }; + + IPv4.prototype.prefixLengthFromSubnetMask = function() { + var cidr, i, octet, stop, zeros, zerotable, _i; + zerotable = { + 0: 8, + 128: 7, + 192: 6, + 224: 5, + 240: 4, + 248: 3, + 252: 2, + 254: 1, + 255: 0 + }; + cidr = 0; + stop = false; + for (i = _i = 3; _i >= 0; i = _i += -1) { + octet = this.octets[i]; + if (octet in zerotable) { + zeros = zerotable[octet]; + if (stop && zeros !== 0) { + return null; + } + if (zeros !== 8) { + stop = true; + } + cidr += zeros; + } else { + return null; + } + } + return 32 - cidr; + }; + + return IPv4; + + })(); + + ipv4Part = "(0?\\d+|0x[a-f0-9]+)"; + + ipv4Regexes = { + fourOctet: new RegExp("^" + ipv4Part + "\\." + ipv4Part + "\\." + ipv4Part + "\\." + ipv4Part + "$", 'i'), + longValue: new RegExp("^" + ipv4Part + "$", 'i') + }; + + ipaddr.IPv4.parser = function(string) { + var match, parseIntAuto, part, shift, value; + parseIntAuto = function(string) { + if (string[0] === "0" && string[1] !== "x") { + return parseInt(string, 8); + } else { + return parseInt(string); + } + }; + if (match = string.match(ipv4Regexes.fourOctet)) { + return (function() { + var _i, _len, _ref, _results; + _ref = match.slice(1, 6); + _results = []; + for (_i = 0, _len = _ref.length; _i < _len; _i++) { + part = _ref[_i]; + _results.push(parseIntAuto(part)); + } + return _results; + })(); + } else if (match = string.match(ipv4Regexes.longValue)) { + value = parseIntAuto(match[1]); + if (value > 0xffffffff || value < 0) { + throw new Error("ipaddr: address outside defined range"); + } + return ((function() { + var _i, _results; + _results = []; + for (shift = _i = 0; _i <= 24; shift = _i += 8) { + _results.push((value >> shift) & 0xff); + } + return _results; + })()).reverse(); + } else { + return null; + } + }; + + ipaddr.IPv6 = (function() { + function IPv6(parts) { + var i, part, _i, _j, _len, _ref; + if (parts.length === 16) { + this.parts = []; + for (i = _i = 0; _i <= 14; i = _i += 2) { + this.parts.push((parts[i] << 8) | parts[i + 1]); + } + } else if (parts.length === 8) { + this.parts = parts; + } else { + throw new Error("ipaddr: ipv6 part count should be 8 or 16"); + } + _ref = this.parts; + for (_j = 0, _len = _ref.length; _j < _len; _j++) { + part = _ref[_j]; + if (!((0 <= part && part <= 0xffff))) { + throw new Error("ipaddr: ipv6 part should fit in 16 bits"); + } + } + } + + IPv6.prototype.kind = function() { + return 'ipv6'; + }; + + IPv6.prototype.toString = function() { + var compactStringParts, part, pushPart, state, stringParts, _i, _len; + stringParts = (function() { + var _i, _len, _ref, _results; + _ref = this.parts; + _results = []; + for (_i = 0, _len = _ref.length; _i < _len; _i++) { + part = _ref[_i]; + _results.push(part.toString(16)); + } + return _results; + }).call(this); + compactStringParts = []; + pushPart = function(part) { + return compactStringParts.push(part); + }; + state = 0; + for (_i = 0, _len = stringParts.length; _i < _len; _i++) { + part = stringParts[_i]; + switch (state) { + case 0: + if (part === '0') { + pushPart(''); + } else { + pushPart(part); + } + state = 1; + break; + case 1: + if (part === '0') { + state = 2; + } else { + pushPart(part); + } + break; + case 2: + if (part !== '0') { + pushPart(''); + pushPart(part); + state = 3; + } + break; + case 3: + pushPart(part); + } + } + if (state === 2) { + pushPart(''); + pushPart(''); + } + return compactStringParts.join(":"); + }; + + IPv6.prototype.toByteArray = function() { + var bytes, part, _i, _len, _ref; + bytes = []; + _ref = this.parts; + for (_i = 0, _len = _ref.length; _i < _len; _i++) { + part = _ref[_i]; + bytes.push(part >> 8); + bytes.push(part & 0xff); + } + return bytes; + }; + + IPv6.prototype.toNormalizedString = function() { + var part; + return ((function() { + var _i, _len, _ref, _results; + _ref = this.parts; + _results = []; + for (_i = 0, _len = _ref.length; _i < _len; _i++) { + part = _ref[_i]; + _results.push(part.toString(16)); + } + return _results; + }).call(this)).join(":"); + }; + + IPv6.prototype.match = function(other, cidrRange) { + var _ref; + if (cidrRange === void 0) { + _ref = other, other = _ref[0], cidrRange = _ref[1]; + } + if (other.kind() !== 'ipv6') { + throw new Error("ipaddr: cannot match ipv6 address with non-ipv6 one"); + } + return matchCIDR(this.parts, other.parts, 16, cidrRange); + }; + + IPv6.prototype.SpecialRanges = { + unspecified: [new IPv6([0, 0, 0, 0, 0, 0, 0, 0]), 128], + linkLocal: [new IPv6([0xfe80, 0, 0, 0, 0, 0, 0, 0]), 10], + multicast: [new IPv6([0xff00, 0, 0, 0, 0, 0, 0, 0]), 8], + loopback: [new IPv6([0, 0, 0, 0, 0, 0, 0, 1]), 128], + uniqueLocal: [new IPv6([0xfc00, 0, 0, 0, 0, 0, 0, 0]), 7], + ipv4Mapped: [new IPv6([0, 0, 0, 0, 0, 0xffff, 0, 0]), 96], + rfc6145: [new IPv6([0, 0, 0, 0, 0xffff, 0, 0, 0]), 96], + rfc6052: [new IPv6([0x64, 0xff9b, 0, 0, 0, 0, 0, 0]), 96], + '6to4': [new IPv6([0x2002, 0, 0, 0, 0, 0, 0, 0]), 16], + teredo: [new IPv6([0x2001, 0, 0, 0, 0, 0, 0, 0]), 32], + reserved: [[new IPv6([0x2001, 0xdb8, 0, 0, 0, 0, 0, 0]), 32]] + }; + + IPv6.prototype.range = function() { + return ipaddr.subnetMatch(this, this.SpecialRanges); + }; + + IPv6.prototype.isIPv4MappedAddress = function() { + return this.range() === 'ipv4Mapped'; + }; + + IPv6.prototype.toIPv4Address = function() { + var high, low, _ref; + if (!this.isIPv4MappedAddress()) { + throw new Error("ipaddr: trying to convert a generic ipv6 address to ipv4"); + } + _ref = this.parts.slice(-2), high = _ref[0], low = _ref[1]; + return new ipaddr.IPv4([high >> 8, high & 0xff, low >> 8, low & 0xff]); + }; + + return IPv6; + + })(); + + ipv6Part = "(?:[0-9a-f]+::?)+"; + + ipv6Regexes = { + "native": new RegExp("^(::)?(" + ipv6Part + ")?([0-9a-f]+)?(::)?$", 'i'), + transitional: new RegExp(("^((?:" + ipv6Part + ")|(?:::)(?:" + ipv6Part + ")?)") + ("" + ipv4Part + "\\." + ipv4Part + "\\." + ipv4Part + "\\." + ipv4Part + "$"), 'i') + }; + + expandIPv6 = function(string, parts) { + var colonCount, lastColon, part, replacement, replacementCount; + if (string.indexOf('::') !== string.lastIndexOf('::')) { + return null; + } + colonCount = 0; + lastColon = -1; + while ((lastColon = string.indexOf(':', lastColon + 1)) >= 0) { + colonCount++; + } + if (string.substr(0, 2) === '::') { + colonCount--; + } + if (string.substr(-2, 2) === '::') { + colonCount--; + } + if (colonCount > parts) { + return null; + } + replacementCount = parts - colonCount; + replacement = ':'; + while (replacementCount--) { + replacement += '0:'; + } + string = string.replace('::', replacement); + if (string[0] === ':') { + string = string.slice(1); + } + if (string[string.length - 1] === ':') { + string = string.slice(0, -1); + } + return (function() { + var _i, _len, _ref, _results; + _ref = string.split(":"); + _results = []; + for (_i = 0, _len = _ref.length; _i < _len; _i++) { + part = _ref[_i]; + _results.push(parseInt(part, 16)); + } + return _results; + })(); + }; + + ipaddr.IPv6.parser = function(string) { + var match, octet, octets, parts, _i, _len; + if (string.match(ipv6Regexes['native'])) { + return expandIPv6(string, 8); + } else if (match = string.match(ipv6Regexes['transitional'])) { + parts = expandIPv6(match[1].slice(0, -1), 6); + if (parts) { + octets = [parseInt(match[2]), parseInt(match[3]), parseInt(match[4]), parseInt(match[5])]; + for (_i = 0, _len = octets.length; _i < _len; _i++) { + octet = octets[_i]; + if (!((0 <= octet && octet <= 255))) { + return null; + } + } + parts.push(octets[0] << 8 | octets[1]); + parts.push(octets[2] << 8 | octets[3]); + return parts; + } + } + return null; + }; + + ipaddr.IPv4.isIPv4 = ipaddr.IPv6.isIPv6 = function(string) { + return this.parser(string) !== null; + }; + + ipaddr.IPv4.isValid = function(string) { + var e; + try { + new this(this.parser(string)); + return true; + } catch (_error) { + e = _error; + return false; + } + }; + + ipaddr.IPv6.isValid = function(string) { + var e; + if (typeof string === "string" && string.indexOf(":") === -1) { + return false; + } + try { + new this(this.parser(string)); + return true; + } catch (_error) { + e = _error; + return false; + } + }; + + ipaddr.IPv4.parse = ipaddr.IPv6.parse = function(string) { + var parts; + parts = this.parser(string); + if (parts === null) { + throw new Error("ipaddr: string is not formatted like ip address"); + } + return new this(parts); + }; + + ipaddr.IPv4.parseCIDR = function(string) { + var maskLength, match; + if (match = string.match(/^(.+)\/(\d+)$/)) { + maskLength = parseInt(match[2]); + if (maskLength >= 0 && maskLength <= 32) { + return [this.parse(match[1]), maskLength]; + } + } + throw new Error("ipaddr: string is not formatted like an IPv4 CIDR range"); + }; + + ipaddr.IPv6.parseCIDR = function(string) { + var maskLength, match; + if (match = string.match(/^(.+)\/(\d+)$/)) { + maskLength = parseInt(match[2]); + if (maskLength >= 0 && maskLength <= 128) { + return [this.parse(match[1]), maskLength]; + } + } + throw new Error("ipaddr: string is not formatted like an IPv6 CIDR range"); + }; + + ipaddr.isValid = function(string) { + return ipaddr.IPv6.isValid(string) || ipaddr.IPv4.isValid(string); + }; + + ipaddr.parse = function(string) { + if (ipaddr.IPv6.isValid(string)) { + return ipaddr.IPv6.parse(string); + } else if (ipaddr.IPv4.isValid(string)) { + return ipaddr.IPv4.parse(string); + } else { + throw new Error("ipaddr: the address has neither IPv6 nor IPv4 format"); + } + }; + + ipaddr.parseCIDR = function(string) { + var e; + try { + return ipaddr.IPv6.parseCIDR(string); + } catch (_error) { + e = _error; + try { + return ipaddr.IPv4.parseCIDR(string); + } catch (_error) { + e = _error; + throw new Error("ipaddr: the address has neither IPv6 nor IPv4 CIDR format"); + } + } + }; + + ipaddr.fromByteArray = function(bytes) { + var length; + length = bytes.length; + if (length === 4) { + return new ipaddr.IPv4(bytes); + } else if (length === 16) { + return new ipaddr.IPv6(bytes); + } else { + throw new Error("ipaddr: the binary input is neither an IPv6 nor IPv4 address"); + } + }; + + ipaddr.process = function(string) { + var addr; + addr = this.parse(string); + if (addr.kind() === 'ipv6' && addr.isIPv4MappedAddress()) { + return addr.toIPv4Address(); + } else { + return addr; + } + }; + +}).call(this); diff --git a/node_modules/express/node_modules/proxy-addr/node_modules/ipaddr.js/package.json b/node_modules/express/node_modules/proxy-addr/node_modules/ipaddr.js/package.json new file mode 100644 index 0000000..d1e779a --- /dev/null +++ b/node_modules/express/node_modules/proxy-addr/node_modules/ipaddr.js/package.json @@ -0,0 +1,64 @@ +{ + "name": "ipaddr.js", + "description": "A library for manipulating IPv4 and IPv6 addresses in JavaScript.", + "version": "1.1.1", + "author": { + "name": "whitequark", + "email": "whitequark@whitequark.org" + }, + "directories": { + "lib": "./lib" + }, + "dependencies": {}, + "devDependencies": { + "coffee-script": "~1.6", + "nodeunit": ">=0.8.2 <0.8.7", + "uglify-js": "latest" + }, + "scripts": { + "test": "cake build test" + }, + "keywords": [ + "ip", + "ipv4", + "ipv6" + ], + "repository": { + "type": "git", + "url": "git://github.com/whitequark/ipaddr.js.git" + }, + "main": "./lib/ipaddr", + "engines": { + "node": ">= 0.10" + }, + "license": "MIT", + "gitHead": "dbc7d98bc0d8fff68a894be0c60721566807e2fc", + "bugs": { + "url": "https://github.com/whitequark/ipaddr.js/issues" + }, + "_id": "ipaddr.js@1.1.1", + "_shasum": "c791d95f52b29c1247d5df80ada39b8a73647230", + "_from": "ipaddr.js@1.1.1", + "_npmVersion": "1.4.21", + "_npmUser": { + "name": "whitequark", + "email": "whitequark@whitequark.org" + }, + "maintainers": [ + { + "name": "whitequark", + "email": "whitequark@whitequark.org" + } + ], + "dist": { + "shasum": "c791d95f52b29c1247d5df80ada39b8a73647230", + "tarball": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.1.1.tgz" + }, + "_npmOperationalInternal": { + "host": "packages-12-west.internal.npmjs.com", + "tmp": "tmp/ipaddr.js-1.1.1.tgz_1464074293475_0.6683731523808092" + }, + "_resolved": "http://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.1.1.tgz", + "readme": "ERROR: No README data found!", + "homepage": "https://github.com/whitequark/ipaddr.js#readme" +} diff --git a/node_modules/express/node_modules/proxy-addr/node_modules/ipaddr.js/src/ipaddr.coffee b/node_modules/express/node_modules/proxy-addr/node_modules/ipaddr.js/src/ipaddr.coffee new file mode 100644 index 0000000..d2abf91 --- /dev/null +++ b/node_modules/express/node_modules/proxy-addr/node_modules/ipaddr.js/src/ipaddr.coffee @@ -0,0 +1,450 @@ +# Define the main object +ipaddr = {} + +root = this + +# Export for both the CommonJS and browser-like environment +if module? && module.exports + module.exports = ipaddr +else + root['ipaddr'] = ipaddr + +# A generic CIDR (Classless Inter-Domain Routing) RFC1518 range matcher. +matchCIDR = (first, second, partSize, cidrBits) -> + if first.length != second.length + throw new Error "ipaddr: cannot match CIDR for objects with different lengths" + + part = 0 + while cidrBits > 0 + shift = partSize - cidrBits + shift = 0 if shift < 0 + + if first[part] >> shift != second[part] >> shift + return false + + cidrBits -= partSize + part += 1 + + return true + +# An utility function to ease named range matching. See examples below. +ipaddr.subnetMatch = (address, rangeList, defaultName='unicast') -> + for rangeName, rangeSubnets of rangeList + # ECMA5 Array.isArray isn't available everywhere + if rangeSubnets[0] && !(rangeSubnets[0] instanceof Array) + rangeSubnets = [ rangeSubnets ] + + for subnet in rangeSubnets + return rangeName if address.match.apply(address, subnet) + + return defaultName + +# An IPv4 address (RFC791). +class ipaddr.IPv4 + # Constructs a new IPv4 address from an array of four octets + # in network order (MSB first) + # Verifies the input. + constructor: (octets) -> + if octets.length != 4 + throw new Error "ipaddr: ipv4 octet count should be 4" + + for octet in octets + if !(0 <= octet <= 255) + throw new Error "ipaddr: ipv4 octet should fit in 8 bits" + + @octets = octets + + # The 'kind' method exists on both IPv4 and IPv6 classes. + kind: -> + return 'ipv4' + + # Returns the address in convenient, decimal-dotted format. + toString: -> + return @octets.join "." + + # Returns an array of byte-sized values in network order (MSB first) + toByteArray: -> + return @octets.slice(0) # octets.clone + + # Checks if this address matches other one within given CIDR range. + match: (other, cidrRange) -> + if cidrRange == undefined + [other, cidrRange] = other + + if other.kind() != 'ipv4' + throw new Error "ipaddr: cannot match ipv4 address with non-ipv4 one" + + return matchCIDR(this.octets, other.octets, 8, cidrRange) + + # Special IPv4 address ranges. + SpecialRanges: + unspecified: [ + [ new IPv4([0, 0, 0, 0]), 8 ] + ] + broadcast: [ + [ new IPv4([255, 255, 255, 255]), 32 ] + ] + multicast: [ # RFC3171 + [ new IPv4([224, 0, 0, 0]), 4 ] + ] + linkLocal: [ # RFC3927 + [ new IPv4([169, 254, 0, 0]), 16 ] + ] + loopback: [ # RFC5735 + [ new IPv4([127, 0, 0, 0]), 8 ] + ] + private: [ # RFC1918 + [ new IPv4([10, 0, 0, 0]), 8 ] + [ new IPv4([172, 16, 0, 0]), 12 ] + [ new IPv4([192, 168, 0, 0]), 16 ] + ] + reserved: [ # Reserved and testing-only ranges; RFCs 5735, 5737, 2544, 1700 + [ new IPv4([192, 0, 0, 0]), 24 ] + [ new IPv4([192, 0, 2, 0]), 24 ] + [ new IPv4([192, 88, 99, 0]), 24 ] + [ new IPv4([198, 51, 100, 0]), 24 ] + [ new IPv4([203, 0, 113, 0]), 24 ] + [ new IPv4([240, 0, 0, 0]), 4 ] + ] + + # Checks if the address corresponds to one of the special ranges. + range: -> + return ipaddr.subnetMatch(this, @SpecialRanges) + + # Convrets this IPv4 address to an IPv4-mapped IPv6 address. + toIPv4MappedAddress: -> + return ipaddr.IPv6.parse "::ffff:#{@toString()}" + + # returns a number of leading ones in IPv4 address, making sure that + # the rest is a solid sequence of 0's (valid netmask) + # returns either the CIDR length or null if mask is not valid + prefixLengthFromSubnetMask: -> + # number of zeroes in octet + zerotable = + 0: 8 + 128: 7 + 192: 6 + 224: 5 + 240: 4 + 248: 3 + 252: 2 + 254: 1 + 255: 0 + + cidr = 0 + # non-zero encountered stop scanning for zeroes + stop = false + for i in [3..0] by -1 + octet = @octets[i] + if octet of zerotable + zeros = zerotable[octet] + if stop and zeros != 0 + return null + unless zeros == 8 + stop = true + cidr += zeros + else + return null + return 32 - cidr + +# A list of regular expressions that match arbitrary IPv4 addresses, +# for which a number of weird notations exist. +# Note that an address like 0010.0xa5.1.1 is considered legal. +ipv4Part = "(0?\\d+|0x[a-f0-9]+)" +ipv4Regexes = + fourOctet: new RegExp "^#{ipv4Part}\\.#{ipv4Part}\\.#{ipv4Part}\\.#{ipv4Part}$", 'i' + longValue: new RegExp "^#{ipv4Part}$", 'i' + +# Classful variants (like a.b, where a is an octet, and b is a 24-bit +# value representing last three octets; this corresponds to a class C +# address) are omitted due to classless nature of modern Internet. +ipaddr.IPv4.parser = (string) -> + parseIntAuto = (string) -> + if string[0] == "0" && string[1] != "x" + parseInt(string, 8) + else + parseInt(string) + + # parseInt recognizes all that octal & hexadecimal weirdness for us + if match = string.match(ipv4Regexes.fourOctet) + return (parseIntAuto(part) for part in match[1..5]) + else if match = string.match(ipv4Regexes.longValue) + value = parseIntAuto(match[1]) + if value > 0xffffffff || value < 0 + throw new Error "ipaddr: address outside defined range" + return ((value >> shift) & 0xff for shift in [0..24] by 8).reverse() + else + return null + +# An IPv6 address (RFC2460) +class ipaddr.IPv6 + # Constructs an IPv6 address from an array of eight 16-bit parts + # or sixteen 8-bit parts in network order (MSB first). + # Throws an error if the input is invalid. + constructor: (parts) -> + if parts.length == 16 + @parts = [] + for i in [0..14] by 2 + @parts.push((parts[i] << 8) | parts[i + 1]) + else if parts.length == 8 + @parts = parts + else + throw new Error "ipaddr: ipv6 part count should be 8 or 16" + + for part in @parts + if !(0 <= part <= 0xffff) + throw new Error "ipaddr: ipv6 part should fit in 16 bits" + + # The 'kind' method exists on both IPv4 and IPv6 classes. + kind: -> + return 'ipv6' + + # Returns the address in compact, human-readable format like + # 2001:db8:8:66::1 + toString: -> + stringParts = (part.toString(16) for part in @parts) + + compactStringParts = [] + pushPart = (part) -> compactStringParts.push part + + state = 0 + for part in stringParts + switch state + when 0 + if part == '0' + pushPart('') + else + pushPart(part) + + state = 1 + when 1 + if part == '0' + state = 2 + else + pushPart(part) + when 2 + unless part == '0' + pushPart('') + pushPart(part) + state = 3 + when 3 + pushPart(part) + + if state == 2 + pushPart('') + pushPart('') + + return compactStringParts.join ":" + + # Returns an array of byte-sized values in network order (MSB first) + toByteArray: -> + bytes = [] + for part in @parts + bytes.push(part >> 8) + bytes.push(part & 0xff) + + return bytes + + # Returns the address in expanded format with all zeroes included, like + # 2001:db8:8:66:0:0:0:1 + toNormalizedString: -> + return (part.toString(16) for part in @parts).join ":" + + # Checks if this address matches other one within given CIDR range. + match: (other, cidrRange) -> + if cidrRange == undefined + [other, cidrRange] = other + + if other.kind() != 'ipv6' + throw new Error "ipaddr: cannot match ipv6 address with non-ipv6 one" + + return matchCIDR(this.parts, other.parts, 16, cidrRange) + + # Special IPv6 ranges + SpecialRanges: + unspecified: [ new IPv6([0, 0, 0, 0, 0, 0, 0, 0]), 128 ] # RFC4291, here and after + linkLocal: [ new IPv6([0xfe80, 0, 0, 0, 0, 0, 0, 0]), 10 ] + multicast: [ new IPv6([0xff00, 0, 0, 0, 0, 0, 0, 0]), 8 ] + loopback: [ new IPv6([0, 0, 0, 0, 0, 0, 0, 1]), 128 ] + uniqueLocal: [ new IPv6([0xfc00, 0, 0, 0, 0, 0, 0, 0]), 7 ] + ipv4Mapped: [ new IPv6([0, 0, 0, 0, 0, 0xffff, 0, 0]), 96 ] + rfc6145: [ new IPv6([0, 0, 0, 0, 0xffff, 0, 0, 0]), 96 ] # RFC6145 + rfc6052: [ new IPv6([0x64, 0xff9b, 0, 0, 0, 0, 0, 0]), 96 ] # RFC6052 + '6to4': [ new IPv6([0x2002, 0, 0, 0, 0, 0, 0, 0]), 16 ] # RFC3056 + teredo: [ new IPv6([0x2001, 0, 0, 0, 0, 0, 0, 0]), 32 ] # RFC6052, RFC6146 + reserved: [ + [ new IPv6([ 0x2001, 0xdb8, 0, 0, 0, 0, 0, 0]), 32 ] # RFC4291 + ] + + # Checks if the address corresponds to one of the special ranges. + range: -> + return ipaddr.subnetMatch(this, @SpecialRanges) + + # Checks if this address is an IPv4-mapped IPv6 address. + isIPv4MappedAddress: -> + return @range() == 'ipv4Mapped' + + # Converts this address to IPv4 address if it is an IPv4-mapped IPv6 address. + # Throws an error otherwise. + toIPv4Address: -> + unless @isIPv4MappedAddress() + throw new Error "ipaddr: trying to convert a generic ipv6 address to ipv4" + + [high, low] = @parts[-2..-1] + + return new ipaddr.IPv4([high >> 8, high & 0xff, low >> 8, low & 0xff]) + +# IPv6-matching regular expressions. +# For IPv6, the task is simpler: it is enough to match the colon-delimited +# hexadecimal IPv6 and a transitional variant with dotted-decimal IPv4 at +# the end. +ipv6Part = "(?:[0-9a-f]+::?)+" +ipv6Regexes = + native: new RegExp "^(::)?(#{ipv6Part})?([0-9a-f]+)?(::)?$", 'i' + transitional: new RegExp "^((?:#{ipv6Part})|(?:::)(?:#{ipv6Part})?)" + + "#{ipv4Part}\\.#{ipv4Part}\\.#{ipv4Part}\\.#{ipv4Part}$", 'i' + +# Expand :: in an IPv6 address or address part consisting of `parts` groups. +expandIPv6 = (string, parts) -> + # More than one '::' means invalid adddress + if string.indexOf('::') != string.lastIndexOf('::') + return null + + # How many parts do we already have? + colonCount = 0 + lastColon = -1 + while (lastColon = string.indexOf(':', lastColon + 1)) >= 0 + colonCount++ + + # 0::0 is two parts more than :: + colonCount-- if string.substr(0, 2) == '::' + colonCount-- if string.substr(-2, 2) == '::' + + # The following loop would hang if colonCount > parts + if colonCount > parts + return null + + # replacement = ':' + '0:' * (parts - colonCount) + replacementCount = parts - colonCount + replacement = ':' + while replacementCount-- + replacement += '0:' + + # Insert the missing zeroes + string = string.replace('::', replacement) + + # Trim any garbage which may be hanging around if :: was at the edge in + # the source string + string = string[1..-1] if string[0] == ':' + string = string[0..-2] if string[string.length-1] == ':' + + return (parseInt(part, 16) for part in string.split(":")) + +# Parse an IPv6 address. +ipaddr.IPv6.parser = (string) -> + if string.match(ipv6Regexes['native']) + return expandIPv6(string, 8) + + else if match = string.match(ipv6Regexes['transitional']) + parts = expandIPv6(match[1][0..-2], 6) + if parts + octets = [parseInt(match[2]), parseInt(match[3]), + parseInt(match[4]), parseInt(match[5])] + for octet in octets + if !(0 <= octet <= 255) + return null + + parts.push(octets[0] << 8 | octets[1]) + parts.push(octets[2] << 8 | octets[3]) + return parts + + return null + +# Checks if a given string is formatted like IPv4/IPv6 address. +ipaddr.IPv4.isIPv4 = ipaddr.IPv6.isIPv6 = (string) -> + return @parser(string) != null + +# Checks if a given string is a valid IPv4/IPv6 address. +ipaddr.IPv4.isValid = (string) -> + try + new this(@parser(string)) + return true + catch e + return false + +ipaddr.IPv6.isValid = (string) -> + # Since IPv6.isValid is always called first, this shortcut + # provides a substantial performance gain. + if typeof string == "string" and string.indexOf(":") == -1 + return false + + try + new this(@parser(string)) + return true + catch e + return false + +# Tries to parse and validate a string with IPv4/IPv6 address. +# Throws an error if it fails. +ipaddr.IPv4.parse = ipaddr.IPv6.parse = (string) -> + parts = @parser(string) + if parts == null + throw new Error "ipaddr: string is not formatted like ip address" + + return new this(parts) + +ipaddr.IPv4.parseCIDR = (string) -> + if match = string.match(/^(.+)\/(\d+)$/) + maskLength = parseInt(match[2]) + if maskLength >= 0 and maskLength <= 32 + return [@parse(match[1]), maskLength] + + throw new Error "ipaddr: string is not formatted like an IPv4 CIDR range" + +ipaddr.IPv6.parseCIDR = (string) -> + if match = string.match(/^(.+)\/(\d+)$/) + maskLength = parseInt(match[2]) + if maskLength >= 0 and maskLength <= 128 + return [@parse(match[1]), maskLength] + + throw new Error "ipaddr: string is not formatted like an IPv6 CIDR range" + +# Checks if the address is valid IP address +ipaddr.isValid = (string) -> + return ipaddr.IPv6.isValid(string) || ipaddr.IPv4.isValid(string) + +# Try to parse an address and throw an error if it is impossible +ipaddr.parse = (string) -> + if ipaddr.IPv6.isValid(string) + return ipaddr.IPv6.parse(string) + else if ipaddr.IPv4.isValid(string) + return ipaddr.IPv4.parse(string) + else + throw new Error "ipaddr: the address has neither IPv6 nor IPv4 format" + +ipaddr.parseCIDR = (string) -> + try + return ipaddr.IPv6.parseCIDR(string) + catch e + try + return ipaddr.IPv4.parseCIDR(string) + catch e + throw new Error "ipaddr: the address has neither IPv6 nor IPv4 CIDR format" + +# Try to parse an array in network order (MSB first) for IPv4 and IPv6 +ipaddr.fromByteArray = (bytes) -> + length = bytes.length + if length == 4 + return new ipaddr.IPv4(bytes) + else if length == 16 + return new ipaddr.IPv6(bytes) + else + throw new Error "ipaddr: the binary input is neither an IPv6 nor IPv4 address" + +# Parse an address and return plain IPv4 address if it is an IPv4-mapped address +ipaddr.process = (string) -> + addr = @parse(string) + if addr.kind() == 'ipv6' && addr.isIPv4MappedAddress() + return addr.toIPv4Address() + else + return addr diff --git a/node_modules/express/node_modules/proxy-addr/node_modules/ipaddr.js/test/ipaddr.test.coffee b/node_modules/express/node_modules/proxy-addr/node_modules/ipaddr.js/test/ipaddr.test.coffee new file mode 100644 index 0000000..5f07526 --- /dev/null +++ b/node_modules/express/node_modules/proxy-addr/node_modules/ipaddr.js/test/ipaddr.test.coffee @@ -0,0 +1,339 @@ +ipaddr = require '../lib/ipaddr' + +module.exports = + 'should define main classes': (test) -> + test.ok(ipaddr.IPv4?, 'defines IPv4 class') + test.ok(ipaddr.IPv6?, 'defines IPv6 class') + test.done() + + 'can construct IPv4 from octets': (test) -> + test.doesNotThrow -> + new ipaddr.IPv4([192, 168, 1, 2]) + test.done() + + 'refuses to construct invalid IPv4': (test) -> + test.throws -> + new ipaddr.IPv4([300, 1, 2, 3]) + test.throws -> + new ipaddr.IPv4([8, 8, 8]) + test.done() + + 'converts IPv4 to string correctly': (test) -> + addr = new ipaddr.IPv4([192, 168, 1, 1]) + test.equal(addr.toString(), '192.168.1.1') + test.done() + + 'returns correct kind for IPv4': (test) -> + addr = new ipaddr.IPv4([1, 2, 3, 4]) + test.equal(addr.kind(), 'ipv4') + test.done() + + 'allows to access IPv4 octets': (test) -> + addr = new ipaddr.IPv4([42, 0, 0, 0]) + test.equal(addr.octets[0], 42) + test.done() + + 'checks IPv4 address format': (test) -> + test.equal(ipaddr.IPv4.isIPv4('192.168.007.0xa'), true) + test.equal(ipaddr.IPv4.isIPv4('1024.0.0.1'), true) + test.equal(ipaddr.IPv4.isIPv4('8.0xa.wtf.6'), false) + test.done() + + 'validates IPv4 addresses': (test) -> + test.equal(ipaddr.IPv4.isValid('192.168.007.0xa'), true) + test.equal(ipaddr.IPv4.isValid('1024.0.0.1'), false) + test.equal(ipaddr.IPv4.isValid('8.0xa.wtf.6'), false) + test.done() + + 'parses IPv4 in several weird formats': (test) -> + test.deepEqual(ipaddr.IPv4.parse('192.168.1.1').octets, [192, 168, 1, 1]) + test.deepEqual(ipaddr.IPv4.parse('0xc0.168.1.1').octets, [192, 168, 1, 1]) + test.deepEqual(ipaddr.IPv4.parse('192.0250.1.1').octets, [192, 168, 1, 1]) + test.deepEqual(ipaddr.IPv4.parse('0xc0a80101').octets, [192, 168, 1, 1]) + test.deepEqual(ipaddr.IPv4.parse('030052000401').octets, [192, 168, 1, 1]) + test.deepEqual(ipaddr.IPv4.parse('3232235777').octets, [192, 168, 1, 1]) + test.done() + + 'barfs at invalid IPv4': (test) -> + test.throws -> + ipaddr.IPv4.parse('10.0.0.wtf') + test.done() + + 'matches IPv4 CIDR correctly': (test) -> + addr = new ipaddr.IPv4([10, 5, 0, 1]) + test.equal(addr.match(ipaddr.IPv4.parse('0.0.0.0'), 0), true) + test.equal(addr.match(ipaddr.IPv4.parse('11.0.0.0'), 8), false) + test.equal(addr.match(ipaddr.IPv4.parse('10.0.0.0'), 8), true) + test.equal(addr.match(ipaddr.IPv4.parse('10.0.0.1'), 8), true) + test.equal(addr.match(ipaddr.IPv4.parse('10.0.0.10'), 8), true) + test.equal(addr.match(ipaddr.IPv4.parse('10.5.5.0'), 16), true) + test.equal(addr.match(ipaddr.IPv4.parse('10.4.5.0'), 16), false) + test.equal(addr.match(ipaddr.IPv4.parse('10.4.5.0'), 15), true) + test.equal(addr.match(ipaddr.IPv4.parse('10.5.0.2'), 32), false) + test.equal(addr.match(addr, 32), true) + test.done() + + 'parses IPv4 CIDR correctly': (test) -> + addr = new ipaddr.IPv4([10, 5, 0, 1]) + test.equal(addr.match(ipaddr.IPv4.parseCIDR('0.0.0.0/0')), true) + test.equal(addr.match(ipaddr.IPv4.parseCIDR('11.0.0.0/8')), false) + test.equal(addr.match(ipaddr.IPv4.parseCIDR('10.0.0.0/8')), true) + test.equal(addr.match(ipaddr.IPv4.parseCIDR('10.0.0.1/8')), true) + test.equal(addr.match(ipaddr.IPv4.parseCIDR('10.0.0.10/8')), true) + test.equal(addr.match(ipaddr.IPv4.parseCIDR('10.5.5.0/16')), true) + test.equal(addr.match(ipaddr.IPv4.parseCIDR('10.4.5.0/16')), false) + test.equal(addr.match(ipaddr.IPv4.parseCIDR('10.4.5.0/15')), true) + test.equal(addr.match(ipaddr.IPv4.parseCIDR('10.5.0.2/32')), false) + test.equal(addr.match(ipaddr.IPv4.parseCIDR('10.5.0.1/32')), true) + test.throws -> + ipaddr.IPv4.parseCIDR('10.5.0.1') + test.throws -> + ipaddr.IPv4.parseCIDR('0.0.0.0/-1') + test.throws -> + ipaddr.IPv4.parseCIDR('0.0.0.0/33') + test.done() + + 'detects reserved IPv4 networks': (test) -> + test.equal(ipaddr.IPv4.parse('0.0.0.0').range(), 'unspecified') + test.equal(ipaddr.IPv4.parse('0.1.0.0').range(), 'unspecified') + test.equal(ipaddr.IPv4.parse('10.1.0.1').range(), 'private') + test.equal(ipaddr.IPv4.parse('192.168.2.1').range(), 'private') + test.equal(ipaddr.IPv4.parse('224.100.0.1').range(), 'multicast') + test.equal(ipaddr.IPv4.parse('169.254.15.0').range(), 'linkLocal') + test.equal(ipaddr.IPv4.parse('127.1.1.1').range(), 'loopback') + test.equal(ipaddr.IPv4.parse('255.255.255.255').range(), 'broadcast') + test.equal(ipaddr.IPv4.parse('240.1.2.3').range(), 'reserved') + test.equal(ipaddr.IPv4.parse('8.8.8.8').range(), 'unicast') + test.done() + + 'can construct IPv6 from 16bit parts': (test) -> + test.doesNotThrow -> + new ipaddr.IPv6([0x2001, 0xdb8, 0xf53a, 0, 0, 0, 0, 1]) + test.done() + + 'can construct IPv6 from 8bit parts': (test) -> + test.doesNotThrow -> + new ipaddr.IPv6([0x20, 0x01, 0xd, 0xb8, 0xf5, 0x3a, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1]) + test.deepEqual(new ipaddr.IPv6([0x20, 0x01, 0xd, 0xb8, 0xf5, 0x3a, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1]), + new ipaddr.IPv6([0x2001, 0xdb8, 0xf53a, 0, 0, 0, 0, 1])) + test.done() + + 'refuses to construct invalid IPv6': (test) -> + test.throws -> + new ipaddr.IPv6([0xfffff, 0, 0, 0, 0, 0, 0, 1]) + test.throws -> + new ipaddr.IPv6([0xfffff, 0, 0, 0, 0, 0, 1]) + test.throws -> + new ipaddr.IPv6([0xffff, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1]) + test.done() + + 'converts IPv6 to string correctly': (test) -> + addr = new ipaddr.IPv6([0x2001, 0xdb8, 0xf53a, 0, 0, 0, 0, 1]) + test.equal(addr.toNormalizedString(), '2001:db8:f53a:0:0:0:0:1') + test.equal(addr.toString(), '2001:db8:f53a::1') + test.equal(new ipaddr.IPv6([0, 0, 0, 0, 0, 0, 0, 1]).toString(), '::1') + test.equal(new ipaddr.IPv6([0x2001, 0xdb8, 0, 0, 0, 0, 0, 0]).toString(), '2001:db8::') + test.done() + + 'returns correct kind for IPv6': (test) -> + addr = new ipaddr.IPv6([0x2001, 0xdb8, 0xf53a, 0, 0, 0, 0, 1]) + test.equal(addr.kind(), 'ipv6') + test.done() + + 'allows to access IPv6 address parts': (test) -> + addr = new ipaddr.IPv6([0x2001, 0xdb8, 0xf53a, 0, 0, 42, 0, 1]) + test.equal(addr.parts[5], 42) + test.done() + + 'checks IPv6 address format': (test) -> + test.equal(ipaddr.IPv6.isIPv6('2001:db8:F53A::1'), true) + test.equal(ipaddr.IPv6.isIPv6('200001::1'), true) + test.equal(ipaddr.IPv6.isIPv6('::ffff:192.168.1.1'), true) + test.equal(ipaddr.IPv6.isIPv6('::ffff:300.168.1.1'), false) + test.equal(ipaddr.IPv6.isIPv6('::ffff:300.168.1.1:0'), false) + test.equal(ipaddr.IPv6.isIPv6('fe80::wtf'), false) + test.done() + + 'validates IPv6 addresses': (test) -> + test.equal(ipaddr.IPv6.isValid('2001:db8:F53A::1'), true) + test.equal(ipaddr.IPv6.isValid('200001::1'), false) + test.equal(ipaddr.IPv6.isValid('::ffff:192.168.1.1'), true) + test.equal(ipaddr.IPv6.isValid('::ffff:300.168.1.1'), false) + test.equal(ipaddr.IPv6.isValid('::ffff:300.168.1.1:0'), false) + test.equal(ipaddr.IPv6.isValid('::ffff:222.1.41.9000'), false) + test.equal(ipaddr.IPv6.isValid('2001:db8::F53A::1'), false) + test.equal(ipaddr.IPv6.isValid('fe80::wtf'), false) + test.equal(ipaddr.IPv6.isValid('2002::2:'), false) + test.equal(ipaddr.IPv6.isValid(undefined), false) + test.done() + + 'parses IPv6 in different formats': (test) -> + test.deepEqual(ipaddr.IPv6.parse('2001:db8:F53A:0:0:0:0:1').parts, [0x2001, 0xdb8, 0xf53a, 0, 0, 0, 0, 1]) + test.deepEqual(ipaddr.IPv6.parse('fe80::10').parts, [0xfe80, 0, 0, 0, 0, 0, 0, 0x10]) + test.deepEqual(ipaddr.IPv6.parse('2001:db8:F53A::').parts, [0x2001, 0xdb8, 0xf53a, 0, 0, 0, 0, 0]) + test.deepEqual(ipaddr.IPv6.parse('::1').parts, [0, 0, 0, 0, 0, 0, 0, 1]) + test.deepEqual(ipaddr.IPv6.parse('::').parts, [0, 0, 0, 0, 0, 0, 0, 0]) + test.done() + + 'barfs at invalid IPv6': (test) -> + test.throws -> + ipaddr.IPv6.parse('fe80::0::1') + test.done() + + 'matches IPv6 CIDR correctly': (test) -> + addr = ipaddr.IPv6.parse('2001:db8:f53a::1') + test.equal(addr.match(ipaddr.IPv6.parse('::'), 0), true) + test.equal(addr.match(ipaddr.IPv6.parse('2001:db8:f53a::1:1'), 64), true) + test.equal(addr.match(ipaddr.IPv6.parse('2001:db8:f53b::1:1'), 48), false) + test.equal(addr.match(ipaddr.IPv6.parse('2001:db8:f531::1:1'), 44), true) + test.equal(addr.match(ipaddr.IPv6.parse('2001:db8:f500::1'), 40), true) + test.equal(addr.match(ipaddr.IPv6.parse('2001:db9:f500::1'), 40), false) + test.equal(addr.match(addr, 128), true) + test.done() + + 'parses IPv6 CIDR correctly': (test) -> + addr = ipaddr.IPv6.parse('2001:db8:f53a::1') + test.equal(addr.match(ipaddr.IPv6.parseCIDR('::/0')), true) + test.equal(addr.match(ipaddr.IPv6.parseCIDR('2001:db8:f53a::1:1/64')), true) + test.equal(addr.match(ipaddr.IPv6.parseCIDR('2001:db8:f53b::1:1/48')), false) + test.equal(addr.match(ipaddr.IPv6.parseCIDR('2001:db8:f531::1:1/44')), true) + test.equal(addr.match(ipaddr.IPv6.parseCIDR('2001:db8:f500::1/40')), true) + test.equal(addr.match(ipaddr.IPv6.parseCIDR('2001:db9:f500::1/40')), false) + test.equal(addr.match(ipaddr.IPv6.parseCIDR('2001:db8:f53a::1/128')), true) + test.throws -> + ipaddr.IPv6.parseCIDR('2001:db8:f53a::1') + test.throws -> + ipaddr.IPv6.parseCIDR('2001:db8:f53a::1/-1') + test.throws -> + ipaddr.IPv6.parseCIDR('2001:db8:f53a::1/129') + test.done() + + 'converts between IPv4-mapped IPv6 addresses and IPv4 addresses': (test) -> + addr = ipaddr.IPv4.parse('77.88.21.11') + mapped = addr.toIPv4MappedAddress() + test.deepEqual(mapped.parts, [0, 0, 0, 0, 0, 0xffff, 0x4d58, 0x150b]) + test.deepEqual(mapped.toIPv4Address().octets, addr.octets) + test.done() + + 'refuses to convert non-IPv4-mapped IPv6 address to IPv4 address': (test) -> + test.throws -> + ipaddr.IPv6.parse('2001:db8::1').toIPv4Address() + test.done() + + 'detects reserved IPv6 networks': (test) -> + test.equal(ipaddr.IPv6.parse('::').range(), 'unspecified') + test.equal(ipaddr.IPv6.parse('fe80::1234:5678:abcd:0123').range(), 'linkLocal') + test.equal(ipaddr.IPv6.parse('ff00::1234').range(), 'multicast') + test.equal(ipaddr.IPv6.parse('::1').range(), 'loopback') + test.equal(ipaddr.IPv6.parse('fc00::').range(), 'uniqueLocal') + test.equal(ipaddr.IPv6.parse('::ffff:192.168.1.10').range(), 'ipv4Mapped') + test.equal(ipaddr.IPv6.parse('::ffff:0:192.168.1.10').range(), 'rfc6145') + test.equal(ipaddr.IPv6.parse('64:ff9b::1234').range(), 'rfc6052') + test.equal(ipaddr.IPv6.parse('2002:1f63:45e8::1').range(), '6to4') + test.equal(ipaddr.IPv6.parse('2001::4242').range(), 'teredo') + test.equal(ipaddr.IPv6.parse('2001:db8::3210').range(), 'reserved') + test.equal(ipaddr.IPv6.parse('2001:470:8:66::1').range(), 'unicast') + test.done() + + 'is able to determine IP address type': (test) -> + test.equal(ipaddr.parse('8.8.8.8').kind(), 'ipv4') + test.equal(ipaddr.parse('2001:db8:3312::1').kind(), 'ipv6') + test.done() + + 'throws an error if tried to parse an invalid address': (test) -> + test.throws -> + ipaddr.parse('::some.nonsense') + test.done() + + 'correctly processes IPv4-mapped addresses': (test) -> + test.equal(ipaddr.process('8.8.8.8').kind(), 'ipv4') + test.equal(ipaddr.process('2001:db8:3312::1').kind(), 'ipv6') + test.equal(ipaddr.process('::ffff:192.168.1.1').kind(), 'ipv4') + test.done() + + 'correctly converts IPv6 and IPv4 addresses to byte arrays': (test) -> + test.deepEqual(ipaddr.parse('1.2.3.4').toByteArray(), + [0x1, 0x2, 0x3, 0x4]); + # Fuck yeah. The first byte of Google's IPv6 address is 42. 42! + test.deepEqual(ipaddr.parse('2a00:1450:8007::68').toByteArray(), + [42, 0x00, 0x14, 0x50, 0x80, 0x07, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x68 ]) + test.done() + + 'correctly parses 1 as an IPv4 address': (test) -> + test.equal(ipaddr.IPv6.isValid('1'), false) + test.equal(ipaddr.IPv4.isValid('1'), true) + test.deepEqual(new ipaddr.IPv4([0, 0, 0, 1]), ipaddr.parse('1')) + test.done() + + 'correctly detects IPv4 and IPv6 CIDR addresses': (test) -> + test.deepEqual([ipaddr.IPv6.parse('fc00::'), 64], + ipaddr.parseCIDR('fc00::/64')) + test.deepEqual([ipaddr.IPv4.parse('1.2.3.4'), 5], + ipaddr.parseCIDR('1.2.3.4/5')) + test.done() + + 'does not consider a very large or very small number a valid IP address': (test) -> + test.equal(ipaddr.isValid('4999999999'), false) + test.equal(ipaddr.isValid('-1'), false) + test.done() + + 'does not hang on ::8:8:8:8:8:8:8:8:8': (test) -> + test.equal(ipaddr.IPv6.isValid('::8:8:8:8:8:8:8:8:8'), false) + test.done() + + 'subnetMatch does not fail on empty range': (test) -> + ipaddr.subnetMatch(new ipaddr.IPv4([1,2,3,4]), {}, false) + ipaddr.subnetMatch(new ipaddr.IPv4([1,2,3,4]), {subnet: []}, false) + test.done() + + 'subnetMatch returns default subnet on empty range': (test) -> + test.equal(ipaddr.subnetMatch(new ipaddr.IPv4([1,2,3,4]), {}, false), false) + test.equal(ipaddr.subnetMatch(new ipaddr.IPv4([1,2,3,4]), {subnet: []}, false), false) + test.done() + + 'is able to determine IP address type from byte array input': (test) -> + test.equal(ipaddr.fromByteArray([0x7f, 0, 0, 1]).kind(), 'ipv4') + test.equal(ipaddr.fromByteArray([0x20, 0x01, 0xd, 0xb8, 0xf5, 0x3a, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1]).kind(), 'ipv6') + test.throws -> + ipaddr.fromByteArray([1]) + test.done() + + 'prefixLengthFromSubnetMask returns proper CIDR notation for standard IPv4 masks': (test) -> + test.equal(ipaddr.IPv4.parse('255.255.255.255').prefixLengthFromSubnetMask(), 32) + test.equal(ipaddr.IPv4.parse('255.255.255.254').prefixLengthFromSubnetMask(), 31) + test.equal(ipaddr.IPv4.parse('255.255.255.252').prefixLengthFromSubnetMask(), 30) + test.equal(ipaddr.IPv4.parse('255.255.255.248').prefixLengthFromSubnetMask(), 29) + test.equal(ipaddr.IPv4.parse('255.255.255.240').prefixLengthFromSubnetMask(), 28) + test.equal(ipaddr.IPv4.parse('255.255.255.224').prefixLengthFromSubnetMask(), 27) + test.equal(ipaddr.IPv4.parse('255.255.255.192').prefixLengthFromSubnetMask(), 26) + test.equal(ipaddr.IPv4.parse('255.255.255.128').prefixLengthFromSubnetMask(), 25) + test.equal(ipaddr.IPv4.parse('255.255.255.0').prefixLengthFromSubnetMask(), 24) + test.equal(ipaddr.IPv4.parse('255.255.254.0').prefixLengthFromSubnetMask(), 23) + test.equal(ipaddr.IPv4.parse('255.255.252.0').prefixLengthFromSubnetMask(), 22) + test.equal(ipaddr.IPv4.parse('255.255.248.0').prefixLengthFromSubnetMask(), 21) + test.equal(ipaddr.IPv4.parse('255.255.240.0').prefixLengthFromSubnetMask(), 20) + test.equal(ipaddr.IPv4.parse('255.255.224.0').prefixLengthFromSubnetMask(), 19) + test.equal(ipaddr.IPv4.parse('255.255.192.0').prefixLengthFromSubnetMask(), 18) + test.equal(ipaddr.IPv4.parse('255.255.128.0').prefixLengthFromSubnetMask(), 17) + test.equal(ipaddr.IPv4.parse('255.255.0.0').prefixLengthFromSubnetMask(), 16) + test.equal(ipaddr.IPv4.parse('255.254.0.0').prefixLengthFromSubnetMask(), 15) + test.equal(ipaddr.IPv4.parse('255.252.0.0').prefixLengthFromSubnetMask(), 14) + test.equal(ipaddr.IPv4.parse('255.248.0.0').prefixLengthFromSubnetMask(), 13) + test.equal(ipaddr.IPv4.parse('255.240.0.0').prefixLengthFromSubnetMask(), 12) + test.equal(ipaddr.IPv4.parse('255.224.0.0').prefixLengthFromSubnetMask(), 11) + test.equal(ipaddr.IPv4.parse('255.192.0.0').prefixLengthFromSubnetMask(), 10) + test.equal(ipaddr.IPv4.parse('255.128.0.0').prefixLengthFromSubnetMask(), 9) + test.equal(ipaddr.IPv4.parse('255.0.0.0').prefixLengthFromSubnetMask(), 8) + test.equal(ipaddr.IPv4.parse('254.0.0.0').prefixLengthFromSubnetMask(), 7) + test.equal(ipaddr.IPv4.parse('252.0.0.0').prefixLengthFromSubnetMask(), 6) + test.equal(ipaddr.IPv4.parse('248.0.0.0').prefixLengthFromSubnetMask(), 5) + test.equal(ipaddr.IPv4.parse('240.0.0.0').prefixLengthFromSubnetMask(), 4) + test.equal(ipaddr.IPv4.parse('224.0.0.0').prefixLengthFromSubnetMask(), 3) + test.equal(ipaddr.IPv4.parse('192.0.0.0').prefixLengthFromSubnetMask(), 2) + test.equal(ipaddr.IPv4.parse('128.0.0.0').prefixLengthFromSubnetMask(), 1) + test.equal(ipaddr.IPv4.parse('0.0.0.0').prefixLengthFromSubnetMask(), 0) + # negative cases + test.equal(ipaddr.IPv4.parse('192.168.255.0').prefixLengthFromSubnetMask(), null) + test.equal(ipaddr.IPv4.parse('255.0.255.0').prefixLengthFromSubnetMask(), null) + test.done() + diff --git a/node_modules/express/node_modules/proxy-addr/package.json b/node_modules/express/node_modules/proxy-addr/package.json new file mode 100644 index 0000000..5bfb83a --- /dev/null +++ b/node_modules/express/node_modules/proxy-addr/package.json @@ -0,0 +1,75 @@ +{ + "name": "proxy-addr", + "description": "Determine address of proxied request", + "version": "1.1.2", + "author": { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + }, + "license": "MIT", + "keywords": [ + "ip", + "proxy", + "x-forwarded-for" + ], + "repository": { + "type": "git", + "url": "git+https://github.com/jshttp/proxy-addr.git" + }, + "dependencies": { + "forwarded": "~0.1.0", + "ipaddr.js": "1.1.1" + }, + "devDependencies": { + "benchmark": "2.1.0", + "beautify-benchmark": "0.2.4", + "istanbul": "0.4.3", + "mocha": "~1.21.5" + }, + "files": [ + "LICENSE", + "HISTORY.md", + "README.md", + "index.js" + ], + "engines": { + "node": ">= 0.6" + }, + "scripts": { + "bench": "node benchmark/index.js", + "test": "mocha --reporter spec --bail --check-leaks test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot --check-leaks test/", + "test-travis": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter spec --check-leaks test/" + }, + "gitHead": "28c34525632884a6d5e69a9165d7420b3f972d8b", + "bugs": { + "url": "https://github.com/jshttp/proxy-addr/issues" + }, + "homepage": "https://github.com/jshttp/proxy-addr#readme", + "_id": "proxy-addr@1.1.2", + "_shasum": "b4cc5f22610d9535824c123aef9d3cf73c40ba37", + "_from": "proxy-addr@>=1.1.2 <1.2.0", + "_npmVersion": "2.15.1", + "_nodeVersion": "4.4.3", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "dist": { + "shasum": "b4cc5f22610d9535824c123aef9d3cf73c40ba37", + "tarball": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-1.1.2.tgz" + }, + "maintainers": [ + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + } + ], + "_npmOperationalInternal": { + "host": "packages-12-west.internal.npmjs.com", + "tmp": "tmp/proxy-addr-1.1.2.tgz_1464573376704_0.6896329398732632" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/proxy-addr/-/proxy-addr-1.1.2.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/express/node_modules/qs/.eslintignore b/node_modules/express/node_modules/qs/.eslintignore new file mode 100644 index 0000000..1521c8b --- /dev/null +++ b/node_modules/express/node_modules/qs/.eslintignore @@ -0,0 +1 @@ +dist diff --git a/node_modules/express/node_modules/qs/.eslintrc b/node_modules/express/node_modules/qs/.eslintrc new file mode 100644 index 0000000..1faac27 --- /dev/null +++ b/node_modules/express/node_modules/qs/.eslintrc @@ -0,0 +1,19 @@ +{ + "root": true, + + "extends": "@ljharb", + + "rules": { + "complexity": [2, 22], + "consistent-return": [1], + "id-length": [2, { "min": 1, "max": 25, "properties": "never" }], + "indent": [2, 4], + "max-params": [2, 9], + "max-statements": [2, 36], + "no-extra-parens": [1], + "no-continue": [1], + "no-magic-numbers": 0, + "no-restricted-syntax": [2, "BreakStatement", "DebuggerStatement", "ForInStatement", "LabeledStatement", "WithStatement"], + "operator-linebreak": 1 + } +} diff --git a/node_modules/express/node_modules/qs/.jscs.json b/node_modules/express/node_modules/qs/.jscs.json new file mode 100644 index 0000000..3d099c4 --- /dev/null +++ b/node_modules/express/node_modules/qs/.jscs.json @@ -0,0 +1,176 @@ +{ + "es3": true, + + "additionalRules": [], + + "requireSemicolons": true, + + "disallowMultipleSpaces": true, + + "disallowIdentifierNames": [], + + "requireCurlyBraces": { + "allExcept": [], + "keywords": ["if", "else", "for", "while", "do", "try", "catch"] + }, + + "requireSpaceAfterKeywords": ["if", "else", "for", "while", "do", "switch", "return", "try", "catch", "function"], + + "disallowSpaceAfterKeywords": [], + + "disallowSpaceBeforeComma": true, + "disallowSpaceAfterComma": false, + "disallowSpaceBeforeSemicolon": true, + + "disallowNodeTypes": [ + "DebuggerStatement", + "ForInStatement", + "LabeledStatement", + "SwitchCase", + "SwitchStatement", + "WithStatement" + ], + + "requireObjectKeysOnNewLine": { "allExcept": ["sameLine"] }, + + "requireSpacesInAnonymousFunctionExpression": { "beforeOpeningRoundBrace": true, "beforeOpeningCurlyBrace": true }, + "requireSpacesInNamedFunctionExpression": { "beforeOpeningCurlyBrace": true }, + "disallowSpacesInNamedFunctionExpression": { "beforeOpeningRoundBrace": true }, + "requireSpacesInFunctionDeclaration": { "beforeOpeningCurlyBrace": true }, + "disallowSpacesInFunctionDeclaration": { "beforeOpeningRoundBrace": true }, + + "requireSpaceBetweenArguments": true, + + "disallowSpacesInsideParentheses": true, + + "disallowSpacesInsideArrayBrackets": true, + + "disallowQuotedKeysInObjects": { "allExcept": ["reserved"] }, + + "disallowSpaceAfterObjectKeys": true, + + "requireCommaBeforeLineBreak": true, + + "disallowSpaceAfterPrefixUnaryOperators": ["++", "--", "+", "-", "~", "!"], + "requireSpaceAfterPrefixUnaryOperators": [], + + "disallowSpaceBeforePostfixUnaryOperators": ["++", "--"], + "requireSpaceBeforePostfixUnaryOperators": [], + + "disallowSpaceBeforeBinaryOperators": [], + "requireSpaceBeforeBinaryOperators": ["+", "-", "/", "*", "=", "==", "===", "!=", "!=="], + + "requireSpaceAfterBinaryOperators": ["+", "-", "/", "*", "=", "==", "===", "!=", "!=="], + "disallowSpaceAfterBinaryOperators": [], + + "disallowImplicitTypeConversion": ["binary", "string"], + + "disallowKeywords": ["with", "eval"], + + "requireKeywordsOnNewLine": [], + "disallowKeywordsOnNewLine": ["else"], + + "requireLineFeedAtFileEnd": true, + + "disallowTrailingWhitespace": true, + + "disallowTrailingComma": true, + + "excludeFiles": ["node_modules/**", "vendor/**"], + + "disallowMultipleLineStrings": true, + + "requireDotNotation": { "allExcept": ["keywords"] }, + + "requireParenthesesAroundIIFE": true, + + "validateLineBreaks": "LF", + + "validateQuoteMarks": { + "escape": true, + "mark": "'" + }, + + "disallowOperatorBeforeLineBreak": [], + + "requireSpaceBeforeKeywords": [ + "do", + "for", + "if", + "else", + "switch", + "case", + "try", + "catch", + "finally", + "while", + "with", + "return" + ], + + "validateAlignedFunctionParameters": { + "lineBreakAfterOpeningBraces": true, + "lineBreakBeforeClosingBraces": true + }, + + "requirePaddingNewLinesBeforeExport": true, + + "validateNewlineAfterArrayElements": { + "maximum": 1 + }, + + "requirePaddingNewLinesAfterUseStrict": true, + + "disallowArrowFunctions": true, + + "disallowMultiLineTernary": true, + + "validateOrderInObjectKeys": "asc-insensitive", + + "disallowIdenticalDestructuringNames": true, + + "disallowNestedTernaries": { "maxLevel": 1 }, + + "requireSpaceAfterComma": { "allExcept": ["trailing"] }, + "requireAlignedMultilineParams": false, + + "requireSpacesInGenerator": { + "afterStar": true + }, + + "disallowSpacesInGenerator": { + "beforeStar": true + }, + + "disallowVar": false, + + "requireArrayDestructuring": false, + + "requireEnhancedObjectLiterals": false, + + "requireObjectDestructuring": false, + + "requireEarlyReturn": false, + + "requireCapitalizedConstructorsNew": { + "allExcept": ["Function", "String", "Object", "Symbol", "Number", "Date", "RegExp", "Error", "Boolean", "Array"] + }, + + "requireImportAlphabetized": false, + + "requireSpaceBeforeObjectValues": true, + "requireSpaceBeforeDestructuredValues": true, + + "disallowSpacesInsideTemplateStringPlaceholders": true, + + "disallowArrayDestructuringReturn": false, + + "requireNewlineBeforeSingleStatementsInIf": false, + + "disallowUnusedVariables": true, + + "requireSpacesInsideImportedObjectBraces": true, + + "requireUseStrict": true +} + diff --git a/node_modules/express/node_modules/qs/CHANGELOG.md b/node_modules/express/node_modules/qs/CHANGELOG.md new file mode 100644 index 0000000..e318a05 --- /dev/null +++ b/node_modules/express/node_modules/qs/CHANGELOG.md @@ -0,0 +1,120 @@ +## [**6.2.0**](https://github.com/ljharb/qs/issues?milestone=36&state=closed) +- [New] pass Buffers to the encoder/decoder directly (#161) +- [New] add "encoder" and "decoder" options, for custom param encoding/decoding (#160) +- [Fix] fix compacting of nested sparse arrays (#150) + +## [**6.1.0**](https://github.com/ljharb/qs/issues?milestone=35&state=closed) +- [New] allowDots option for `stringify` (#151) +- [Fix] "sort" option should work at a depth of 3 or more (#151) +- [Fix] Restore `dist` directory; will be removed in v7 (#148) + +## [**6.0.2**](https://github.com/ljharb/qs/issues?milestone=33&state=closed) +- Revert ES6 requirement and restore support for node down to v0.8. + +## [**6.0.1**](https://github.com/ljharb/qs/issues?milestone=32&state=closed) +- [**#127**](https://github.com/ljharb/qs/pull/127) Fix engines definition in package.json + +## [**6.0.0**](https://github.com/ljharb/qs/issues?milestone=31&state=closed) +- [**#124**](https://github.com/ljharb/qs/issues/124) Use ES6 and drop support for node < v4 + +## [**5.2.0**](https://github.com/ljharb/qs/issues?milestone=30&state=closed) +- [**#64**](https://github.com/ljharb/qs/issues/64) Add option to sort object keys in the query string + +## [**5.1.0**](https://github.com/ljharb/qs/issues?milestone=29&state=closed) +- [**#117**](https://github.com/ljharb/qs/issues/117) make URI encoding stringified results optional +- [**#106**](https://github.com/ljharb/qs/issues/106) Add flag `skipNulls` to optionally skip null values in stringify + +## [**5.0.0**](https://github.com/ljharb/qs/issues?milestone=28&state=closed) +- [**#114**](https://github.com/ljharb/qs/issues/114) default allowDots to false +- [**#100**](https://github.com/ljharb/qs/issues/100) include dist to npm + +## [**4.0.0**](https://github.com/ljharb/qs/issues?milestone=26&state=closed) +- [**#98**](https://github.com/ljharb/qs/issues/98) make returning plain objects and allowing prototype overwriting properties optional + +## [**3.1.0**](https://github.com/ljharb/qs/issues?milestone=24&state=closed) +- [**#89**](https://github.com/ljharb/qs/issues/89) Add option to disable "Transform dot notation to bracket notation" + +## [**3.0.0**](https://github.com/ljharb/qs/issues?milestone=23&state=closed) +- [**#80**](https://github.com/ljharb/qs/issues/80) qs.parse silently drops properties +- [**#77**](https://github.com/ljharb/qs/issues/77) Perf boost +- [**#60**](https://github.com/ljharb/qs/issues/60) Add explicit option to disable array parsing +- [**#74**](https://github.com/ljharb/qs/issues/74) Bad parse when turning array into object +- [**#81**](https://github.com/ljharb/qs/issues/81) Add a `filter` option +- [**#68**](https://github.com/ljharb/qs/issues/68) Fixed issue with recursion and passing strings into objects. +- [**#66**](https://github.com/ljharb/qs/issues/66) Add mixed array and object dot notation support Closes: #47 +- [**#76**](https://github.com/ljharb/qs/issues/76) RFC 3986 +- [**#85**](https://github.com/ljharb/qs/issues/85) No equal sign +- [**#84**](https://github.com/ljharb/qs/issues/84) update license attribute + +## [**2.4.1**](https://github.com/ljharb/qs/issues?milestone=20&state=closed) +- [**#73**](https://github.com/ljharb/qs/issues/73) Property 'hasOwnProperty' of object # is not a function + +## [**2.4.0**](https://github.com/ljharb/qs/issues?milestone=19&state=closed) +- [**#70**](https://github.com/ljharb/qs/issues/70) Add arrayFormat option + +## [**2.3.3**](https://github.com/ljharb/qs/issues?milestone=18&state=closed) +- [**#59**](https://github.com/ljharb/qs/issues/59) make sure array indexes are >= 0, closes #57 +- [**#58**](https://github.com/ljharb/qs/issues/58) make qs usable for browser loader + +## [**2.3.2**](https://github.com/ljharb/qs/issues?milestone=17&state=closed) +- [**#55**](https://github.com/ljharb/qs/issues/55) allow merging a string into an object + +## [**2.3.1**](https://github.com/ljharb/qs/issues?milestone=16&state=closed) +- [**#52**](https://github.com/ljharb/qs/issues/52) Return "undefined" and "false" instead of throwing "TypeError". + +## [**2.3.0**](https://github.com/ljharb/qs/issues?milestone=15&state=closed) +- [**#50**](https://github.com/ljharb/qs/issues/50) add option to omit array indices, closes #46 + +## [**2.2.5**](https://github.com/ljharb/qs/issues?milestone=14&state=closed) +- [**#39**](https://github.com/ljharb/qs/issues/39) Is there an alternative to Buffer.isBuffer? +- [**#49**](https://github.com/ljharb/qs/issues/49) refactor utils.merge, fixes #45 +- [**#41**](https://github.com/ljharb/qs/issues/41) avoid browserifying Buffer, for #39 + +## [**2.2.4**](https://github.com/ljharb/qs/issues?milestone=13&state=closed) +- [**#38**](https://github.com/ljharb/qs/issues/38) how to handle object keys beginning with a number + +## [**2.2.3**](https://github.com/ljharb/qs/issues?milestone=12&state=closed) +- [**#37**](https://github.com/ljharb/qs/issues/37) parser discards first empty value in array +- [**#36**](https://github.com/ljharb/qs/issues/36) Update to lab 4.x + +## [**2.2.2**](https://github.com/ljharb/qs/issues?milestone=11&state=closed) +- [**#33**](https://github.com/ljharb/qs/issues/33) Error when plain object in a value +- [**#34**](https://github.com/ljharb/qs/issues/34) use Object.prototype.hasOwnProperty.call instead of obj.hasOwnProperty +- [**#24**](https://github.com/ljharb/qs/issues/24) Changelog? Semver? + +## [**2.2.1**](https://github.com/ljharb/qs/issues?milestone=10&state=closed) +- [**#32**](https://github.com/ljharb/qs/issues/32) account for circular references properly, closes #31 +- [**#31**](https://github.com/ljharb/qs/issues/31) qs.parse stackoverflow on circular objects + +## [**2.2.0**](https://github.com/ljharb/qs/issues?milestone=9&state=closed) +- [**#26**](https://github.com/ljharb/qs/issues/26) Don't use Buffer global if it's not present +- [**#30**](https://github.com/ljharb/qs/issues/30) Bug when merging non-object values into arrays +- [**#29**](https://github.com/ljharb/qs/issues/29) Don't call Utils.clone at the top of Utils.merge +- [**#23**](https://github.com/ljharb/qs/issues/23) Ability to not limit parameters? + +## [**2.1.0**](https://github.com/ljharb/qs/issues?milestone=8&state=closed) +- [**#22**](https://github.com/ljharb/qs/issues/22) Enable using a RegExp as delimiter + +## [**2.0.0**](https://github.com/ljharb/qs/issues?milestone=7&state=closed) +- [**#18**](https://github.com/ljharb/qs/issues/18) Why is there arrayLimit? +- [**#20**](https://github.com/ljharb/qs/issues/20) Configurable parametersLimit +- [**#21**](https://github.com/ljharb/qs/issues/21) make all limits optional, for #18, for #20 + +## [**1.2.2**](https://github.com/ljharb/qs/issues?milestone=6&state=closed) +- [**#19**](https://github.com/ljharb/qs/issues/19) Don't overwrite null values + +## [**1.2.1**](https://github.com/ljharb/qs/issues?milestone=5&state=closed) +- [**#16**](https://github.com/ljharb/qs/issues/16) ignore non-string delimiters +- [**#15**](https://github.com/ljharb/qs/issues/15) Close code block + +## [**1.2.0**](https://github.com/ljharb/qs/issues?milestone=4&state=closed) +- [**#12**](https://github.com/ljharb/qs/issues/12) Add optional delim argument +- [**#13**](https://github.com/ljharb/qs/issues/13) fix #11: flattened keys in array are now correctly parsed + +## [**1.1.0**](https://github.com/ljharb/qs/issues?milestone=3&state=closed) +- [**#7**](https://github.com/ljharb/qs/issues/7) Empty values of a POST array disappear after being submitted +- [**#9**](https://github.com/ljharb/qs/issues/9) Should not omit equals signs (=) when value is null +- [**#6**](https://github.com/ljharb/qs/issues/6) Minor grammar fix in README + +## [**1.0.2**](https://github.com/ljharb/qs/issues?milestone=2&state=closed) +- [**#5**](https://github.com/ljharb/qs/issues/5) array holes incorrectly copied into object on large index diff --git a/node_modules/express/node_modules/qs/CONTRIBUTING.md b/node_modules/express/node_modules/qs/CONTRIBUTING.md new file mode 100644 index 0000000..8928361 --- /dev/null +++ b/node_modules/express/node_modules/qs/CONTRIBUTING.md @@ -0,0 +1 @@ +Please view our [hapijs contributing guide](https://github.com/hapijs/hapi/blob/master/CONTRIBUTING.md). diff --git a/node_modules/express/node_modules/qs/LICENSE b/node_modules/express/node_modules/qs/LICENSE new file mode 100644 index 0000000..d456948 --- /dev/null +++ b/node_modules/express/node_modules/qs/LICENSE @@ -0,0 +1,28 @@ +Copyright (c) 2014 Nathan LaFreniere and other contributors. +All rights reserved. + +Redistribution and use in source and binary forms, with or without +modification, are permitted provided that the following conditions are met: + * Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. + * Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. + * The names of any contributors may not be used to endorse or promote + products derived from this software without specific prior written + permission. + +THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND +ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED +WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE +DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDERS AND CONTRIBUTORS BE LIABLE FOR ANY +DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES +(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; +LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND +ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT +(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS +SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + + * * * + +The complete list of contributors can be found at: https://github.com/hapijs/qs/graphs/contributors diff --git a/node_modules/express/node_modules/qs/dist/qs.js b/node_modules/express/node_modules/qs/dist/qs.js new file mode 100644 index 0000000..4cc6f30 --- /dev/null +++ b/node_modules/express/node_modules/qs/dist/qs.js @@ -0,0 +1,487 @@ +(function(f){if(typeof exports==="object"&&typeof module!=="undefined"){module.exports=f()}else if(typeof define==="function"&&define.amd){define([],f)}else{var g;if(typeof window!=="undefined"){g=window}else if(typeof global!=="undefined"){g=global}else if(typeof self!=="undefined"){g=self}else{g=this}g.Qs = f()}})(function(){var define,module,exports;return (function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o= 0 && + (options.parseArrays && index <= options.arrayLimit) + ) { + obj = []; + obj[index] = parseObject(chain, val, options); + } else { + obj[cleanRoot] = parseObject(chain, val, options); + } + } + + return obj; +}; + +var parseKeys = function parseKeys(givenKey, val, options) { + if (!givenKey) { + return; + } + + // Transform dot notation to bracket notation + var key = options.allowDots ? givenKey.replace(/\.([^\.\[]+)/g, '[$1]') : givenKey; + + // The regex chunks + + var parent = /^([^\[\]]*)/; + var child = /(\[[^\[\]]*\])/g; + + // Get the parent + + var segment = parent.exec(key); + + // Stash the parent if it exists + + var keys = []; + if (segment[1]) { + // If we aren't using plain objects, optionally prefix keys + // that would overwrite object prototype properties + if (!options.plainObjects && Object.prototype.hasOwnProperty(segment[1])) { + if (!options.allowPrototypes) { + return; + } + } + + keys.push(segment[1]); + } + + // Loop through children appending to the array until we hit depth + + var i = 0; + while ((segment = child.exec(key)) !== null && i < options.depth) { + i += 1; + if (!options.plainObjects && Object.prototype.hasOwnProperty(segment[1].replace(/\[|\]/g, ''))) { + if (!options.allowPrototypes) { + continue; + } + } + keys.push(segment[1]); + } + + // If there's a remainder, just add whatever is left + + if (segment) { + keys.push('[' + key.slice(segment.index) + ']'); + } + + return parseObject(keys, val, options); +}; + +module.exports = function (str, opts) { + var options = opts || {}; + + if (options.decoder !== null && options.decoder !== undefined && typeof options.decoder !== 'function') { + throw new TypeError('Decoder has to be a function.'); + } + + options.delimiter = typeof options.delimiter === 'string' || Utils.isRegExp(options.delimiter) ? options.delimiter : defaults.delimiter; + options.depth = typeof options.depth === 'number' ? options.depth : defaults.depth; + options.arrayLimit = typeof options.arrayLimit === 'number' ? options.arrayLimit : defaults.arrayLimit; + options.parseArrays = options.parseArrays !== false; + options.decoder = typeof options.decoder === 'function' ? options.decoder : defaults.decoder; + options.allowDots = typeof options.allowDots === 'boolean' ? options.allowDots : defaults.allowDots; + options.plainObjects = typeof options.plainObjects === 'boolean' ? options.plainObjects : defaults.plainObjects; + options.allowPrototypes = typeof options.allowPrototypes === 'boolean' ? options.allowPrototypes : defaults.allowPrototypes; + options.parameterLimit = typeof options.parameterLimit === 'number' ? options.parameterLimit : defaults.parameterLimit; + options.strictNullHandling = typeof options.strictNullHandling === 'boolean' ? options.strictNullHandling : defaults.strictNullHandling; + + if (str === '' || str === null || typeof str === 'undefined') { + return options.plainObjects ? Object.create(null) : {}; + } + + var tempObj = typeof str === 'string' ? parseValues(str, options) : str; + var obj = options.plainObjects ? Object.create(null) : {}; + + // Iterate over the keys and setup the new object + + var keys = Object.keys(tempObj); + for (var i = 0; i < keys.length; ++i) { + var key = keys[i]; + var newObj = parseKeys(key, tempObj[key], options); + obj = Utils.merge(obj, newObj, options); + } + + return Utils.compact(obj); +}; + +},{"./utils":4}],3:[function(require,module,exports){ +'use strict'; + +var Utils = require('./utils'); + +var arrayPrefixGenerators = { + brackets: function brackets(prefix) { + return prefix + '[]'; + }, + indices: function indices(prefix, key) { + return prefix + '[' + key + ']'; + }, + repeat: function repeat(prefix) { + return prefix; + } +}; + +var defaults = { + delimiter: '&', + strictNullHandling: false, + skipNulls: false, + encode: true, + encoder: Utils.encode +}; + +var stringify = function stringify(object, prefix, generateArrayPrefix, strictNullHandling, skipNulls, encoder, filter, sort, allowDots) { + var obj = object; + if (typeof filter === 'function') { + obj = filter(prefix, obj); + } else if (obj instanceof Date) { + obj = obj.toISOString(); + } else if (obj === null) { + if (strictNullHandling) { + return encoder ? encoder(prefix) : prefix; + } + + obj = ''; + } + + if (typeof obj === 'string' || typeof obj === 'number' || typeof obj === 'boolean' || Utils.isBuffer(obj)) { + if (encoder) { + return [encoder(prefix) + '=' + encoder(obj)]; + } + return [prefix + '=' + String(obj)]; + } + + var values = []; + + if (typeof obj === 'undefined') { + return values; + } + + var objKeys; + if (Array.isArray(filter)) { + objKeys = filter; + } else { + var keys = Object.keys(obj); + objKeys = sort ? keys.sort(sort) : keys; + } + + for (var i = 0; i < objKeys.length; ++i) { + var key = objKeys[i]; + + if (skipNulls && obj[key] === null) { + continue; + } + + if (Array.isArray(obj)) { + values = values.concat(stringify(obj[key], generateArrayPrefix(prefix, key), generateArrayPrefix, strictNullHandling, skipNulls, encoder, filter, sort, allowDots)); + } else { + values = values.concat(stringify(obj[key], prefix + (allowDots ? '.' + key : '[' + key + ']'), generateArrayPrefix, strictNullHandling, skipNulls, encoder, filter, sort, allowDots)); + } + } + + return values; +}; + +module.exports = function (object, opts) { + var obj = object; + var options = opts || {}; + var delimiter = typeof options.delimiter === 'undefined' ? defaults.delimiter : options.delimiter; + var strictNullHandling = typeof options.strictNullHandling === 'boolean' ? options.strictNullHandling : defaults.strictNullHandling; + var skipNulls = typeof options.skipNulls === 'boolean' ? options.skipNulls : defaults.skipNulls; + var encode = typeof options.encode === 'boolean' ? options.encode : defaults.encode; + var encoder = encode ? (typeof options.encoder === 'function' ? options.encoder : defaults.encoder) : null; + var sort = typeof options.sort === 'function' ? options.sort : null; + var allowDots = typeof options.allowDots === 'undefined' ? false : options.allowDots; + var objKeys; + var filter; + + if (options.encoder !== null && options.encoder !== undefined && typeof options.encoder !== 'function') { + throw new TypeError('Encoder has to be a function.'); + } + + if (typeof options.filter === 'function') { + filter = options.filter; + obj = filter('', obj); + } else if (Array.isArray(options.filter)) { + objKeys = filter = options.filter; + } + + var keys = []; + + if (typeof obj !== 'object' || obj === null) { + return ''; + } + + var arrayFormat; + if (options.arrayFormat in arrayPrefixGenerators) { + arrayFormat = options.arrayFormat; + } else if ('indices' in options) { + arrayFormat = options.indices ? 'indices' : 'repeat'; + } else { + arrayFormat = 'indices'; + } + + var generateArrayPrefix = arrayPrefixGenerators[arrayFormat]; + + if (!objKeys) { + objKeys = Object.keys(obj); + } + + if (sort) { + objKeys.sort(sort); + } + + for (var i = 0; i < objKeys.length; ++i) { + var key = objKeys[i]; + + if (skipNulls && obj[key] === null) { + continue; + } + + keys = keys.concat(stringify(obj[key], key, generateArrayPrefix, strictNullHandling, skipNulls, encoder, filter, sort, allowDots)); + } + + return keys.join(delimiter); +}; + +},{"./utils":4}],4:[function(require,module,exports){ +'use strict'; + +var hexTable = (function () { + var array = new Array(256); + for (var i = 0; i < 256; ++i) { + array[i] = '%' + ((i < 16 ? '0' : '') + i.toString(16)).toUpperCase(); + } + + return array; +}()); + +exports.arrayToObject = function (source, options) { + var obj = options.plainObjects ? Object.create(null) : {}; + for (var i = 0; i < source.length; ++i) { + if (typeof source[i] !== 'undefined') { + obj[i] = source[i]; + } + } + + return obj; +}; + +exports.merge = function (target, source, options) { + if (!source) { + return target; + } + + if (typeof source !== 'object') { + if (Array.isArray(target)) { + target.push(source); + } else if (typeof target === 'object') { + target[source] = true; + } else { + return [target, source]; + } + + return target; + } + + if (typeof target !== 'object') { + return [target].concat(source); + } + + var mergeTarget = target; + if (Array.isArray(target) && !Array.isArray(source)) { + mergeTarget = exports.arrayToObject(target, options); + } + + return Object.keys(source).reduce(function (acc, key) { + var value = source[key]; + + if (Object.prototype.hasOwnProperty.call(acc, key)) { + acc[key] = exports.merge(acc[key], value, options); + } else { + acc[key] = value; + } + return acc; + }, mergeTarget); +}; + +exports.decode = function (str) { + try { + return decodeURIComponent(str.replace(/\+/g, ' ')); + } catch (e) { + return str; + } +}; + +exports.encode = function (str) { + // This code was originally written by Brian White (mscdex) for the io.js core querystring library. + // It has been adapted here for stricter adherence to RFC 3986 + if (str.length === 0) { + return str; + } + + var string = typeof str === 'string' ? str : String(str); + + var out = ''; + for (var i = 0; i < string.length; ++i) { + var c = string.charCodeAt(i); + + if ( + c === 0x2D || // - + c === 0x2E || // . + c === 0x5F || // _ + c === 0x7E || // ~ + (c >= 0x30 && c <= 0x39) || // 0-9 + (c >= 0x41 && c <= 0x5A) || // a-z + (c >= 0x61 && c <= 0x7A) // A-Z + ) { + out += string.charAt(i); + continue; + } + + if (c < 0x80) { + out = out + hexTable[c]; + continue; + } + + if (c < 0x800) { + out = out + (hexTable[0xC0 | (c >> 6)] + hexTable[0x80 | (c & 0x3F)]); + continue; + } + + if (c < 0xD800 || c >= 0xE000) { + out = out + (hexTable[0xE0 | (c >> 12)] + hexTable[0x80 | ((c >> 6) & 0x3F)] + hexTable[0x80 | (c & 0x3F)]); + continue; + } + + i += 1; + c = 0x10000 + (((c & 0x3FF) << 10) | (string.charCodeAt(i) & 0x3FF)); + out += hexTable[0xF0 | (c >> 18)] + hexTable[0x80 | ((c >> 12) & 0x3F)] + hexTable[0x80 | ((c >> 6) & 0x3F)] + hexTable[0x80 | (c & 0x3F)]; + } + + return out; +}; + +exports.compact = function (obj, references) { + if (typeof obj !== 'object' || obj === null) { + return obj; + } + + var refs = references || []; + var lookup = refs.indexOf(obj); + if (lookup !== -1) { + return refs[lookup]; + } + + refs.push(obj); + + if (Array.isArray(obj)) { + var compacted = []; + + for (var i = 0; i < obj.length; ++i) { + if (obj[i] && typeof obj[i] === 'object') { + compacted.push(exports.compact(obj[i], refs)); + } else if (typeof obj[i] !== 'undefined') { + compacted.push(obj[i]); + } + } + + return compacted; + } + + var keys = Object.keys(obj); + for (var j = 0; j < keys.length; ++j) { + var key = keys[j]; + obj[key] = exports.compact(obj[key], refs); + } + + return obj; +}; + +exports.isRegExp = function (obj) { + return Object.prototype.toString.call(obj) === '[object RegExp]'; +}; + +exports.isBuffer = function (obj) { + if (obj === null || typeof obj === 'undefined') { + return false; + } + + return !!(obj.constructor && obj.constructor.isBuffer && obj.constructor.isBuffer(obj)); +}; + +},{}]},{},[1])(1) +}); \ No newline at end of file diff --git a/node_modules/express/node_modules/qs/lib/index.js b/node_modules/express/node_modules/qs/lib/index.js new file mode 100644 index 0000000..1901959 --- /dev/null +++ b/node_modules/express/node_modules/qs/lib/index.js @@ -0,0 +1,9 @@ +'use strict'; + +var Stringify = require('./stringify'); +var Parse = require('./parse'); + +module.exports = { + stringify: Stringify, + parse: Parse +}; diff --git a/node_modules/express/node_modules/qs/lib/parse.js b/node_modules/express/node_modules/qs/lib/parse.js new file mode 100644 index 0000000..bf70fd8 --- /dev/null +++ b/node_modules/express/node_modules/qs/lib/parse.js @@ -0,0 +1,167 @@ +'use strict'; + +var Utils = require('./utils'); + +var defaults = { + delimiter: '&', + depth: 5, + arrayLimit: 20, + parameterLimit: 1000, + strictNullHandling: false, + plainObjects: false, + allowPrototypes: false, + allowDots: false, + decoder: Utils.decode +}; + +var parseValues = function parseValues(str, options) { + var obj = {}; + var parts = str.split(options.delimiter, options.parameterLimit === Infinity ? undefined : options.parameterLimit); + + for (var i = 0; i < parts.length; ++i) { + var part = parts[i]; + var pos = part.indexOf(']=') === -1 ? part.indexOf('=') : part.indexOf(']=') + 1; + + if (pos === -1) { + obj[options.decoder(part)] = ''; + + if (options.strictNullHandling) { + obj[options.decoder(part)] = null; + } + } else { + var key = options.decoder(part.slice(0, pos)); + var val = options.decoder(part.slice(pos + 1)); + + if (Object.prototype.hasOwnProperty.call(obj, key)) { + obj[key] = [].concat(obj[key]).concat(val); + } else { + obj[key] = val; + } + } + } + + return obj; +}; + +var parseObject = function parseObject(chain, val, options) { + if (!chain.length) { + return val; + } + + var root = chain.shift(); + + var obj; + if (root === '[]') { + obj = []; + obj = obj.concat(parseObject(chain, val, options)); + } else { + obj = options.plainObjects ? Object.create(null) : {}; + var cleanRoot = root[0] === '[' && root[root.length - 1] === ']' ? root.slice(1, root.length - 1) : root; + var index = parseInt(cleanRoot, 10); + if ( + !isNaN(index) && + root !== cleanRoot && + String(index) === cleanRoot && + index >= 0 && + (options.parseArrays && index <= options.arrayLimit) + ) { + obj = []; + obj[index] = parseObject(chain, val, options); + } else { + obj[cleanRoot] = parseObject(chain, val, options); + } + } + + return obj; +}; + +var parseKeys = function parseKeys(givenKey, val, options) { + if (!givenKey) { + return; + } + + // Transform dot notation to bracket notation + var key = options.allowDots ? givenKey.replace(/\.([^\.\[]+)/g, '[$1]') : givenKey; + + // The regex chunks + + var parent = /^([^\[\]]*)/; + var child = /(\[[^\[\]]*\])/g; + + // Get the parent + + var segment = parent.exec(key); + + // Stash the parent if it exists + + var keys = []; + if (segment[1]) { + // If we aren't using plain objects, optionally prefix keys + // that would overwrite object prototype properties + if (!options.plainObjects && Object.prototype.hasOwnProperty(segment[1])) { + if (!options.allowPrototypes) { + return; + } + } + + keys.push(segment[1]); + } + + // Loop through children appending to the array until we hit depth + + var i = 0; + while ((segment = child.exec(key)) !== null && i < options.depth) { + i += 1; + if (!options.plainObjects && Object.prototype.hasOwnProperty(segment[1].replace(/\[|\]/g, ''))) { + if (!options.allowPrototypes) { + continue; + } + } + keys.push(segment[1]); + } + + // If there's a remainder, just add whatever is left + + if (segment) { + keys.push('[' + key.slice(segment.index) + ']'); + } + + return parseObject(keys, val, options); +}; + +module.exports = function (str, opts) { + var options = opts || {}; + + if (options.decoder !== null && options.decoder !== undefined && typeof options.decoder !== 'function') { + throw new TypeError('Decoder has to be a function.'); + } + + options.delimiter = typeof options.delimiter === 'string' || Utils.isRegExp(options.delimiter) ? options.delimiter : defaults.delimiter; + options.depth = typeof options.depth === 'number' ? options.depth : defaults.depth; + options.arrayLimit = typeof options.arrayLimit === 'number' ? options.arrayLimit : defaults.arrayLimit; + options.parseArrays = options.parseArrays !== false; + options.decoder = typeof options.decoder === 'function' ? options.decoder : defaults.decoder; + options.allowDots = typeof options.allowDots === 'boolean' ? options.allowDots : defaults.allowDots; + options.plainObjects = typeof options.plainObjects === 'boolean' ? options.plainObjects : defaults.plainObjects; + options.allowPrototypes = typeof options.allowPrototypes === 'boolean' ? options.allowPrototypes : defaults.allowPrototypes; + options.parameterLimit = typeof options.parameterLimit === 'number' ? options.parameterLimit : defaults.parameterLimit; + options.strictNullHandling = typeof options.strictNullHandling === 'boolean' ? options.strictNullHandling : defaults.strictNullHandling; + + if (str === '' || str === null || typeof str === 'undefined') { + return options.plainObjects ? Object.create(null) : {}; + } + + var tempObj = typeof str === 'string' ? parseValues(str, options) : str; + var obj = options.plainObjects ? Object.create(null) : {}; + + // Iterate over the keys and setup the new object + + var keys = Object.keys(tempObj); + for (var i = 0; i < keys.length; ++i) { + var key = keys[i]; + var newObj = parseKeys(key, tempObj[key], options); + obj = Utils.merge(obj, newObj, options); + } + + return Utils.compact(obj); +}; diff --git a/node_modules/express/node_modules/qs/lib/stringify.js b/node_modules/express/node_modules/qs/lib/stringify.js new file mode 100644 index 0000000..6e1c9a2 --- /dev/null +++ b/node_modules/express/node_modules/qs/lib/stringify.js @@ -0,0 +1,137 @@ +'use strict'; + +var Utils = require('./utils'); + +var arrayPrefixGenerators = { + brackets: function brackets(prefix) { + return prefix + '[]'; + }, + indices: function indices(prefix, key) { + return prefix + '[' + key + ']'; + }, + repeat: function repeat(prefix) { + return prefix; + } +}; + +var defaults = { + delimiter: '&', + strictNullHandling: false, + skipNulls: false, + encode: true, + encoder: Utils.encode +}; + +var stringify = function stringify(object, prefix, generateArrayPrefix, strictNullHandling, skipNulls, encoder, filter, sort, allowDots) { + var obj = object; + if (typeof filter === 'function') { + obj = filter(prefix, obj); + } else if (obj instanceof Date) { + obj = obj.toISOString(); + } else if (obj === null) { + if (strictNullHandling) { + return encoder ? encoder(prefix) : prefix; + } + + obj = ''; + } + + if (typeof obj === 'string' || typeof obj === 'number' || typeof obj === 'boolean' || Utils.isBuffer(obj)) { + if (encoder) { + return [encoder(prefix) + '=' + encoder(obj)]; + } + return [prefix + '=' + String(obj)]; + } + + var values = []; + + if (typeof obj === 'undefined') { + return values; + } + + var objKeys; + if (Array.isArray(filter)) { + objKeys = filter; + } else { + var keys = Object.keys(obj); + objKeys = sort ? keys.sort(sort) : keys; + } + + for (var i = 0; i < objKeys.length; ++i) { + var key = objKeys[i]; + + if (skipNulls && obj[key] === null) { + continue; + } + + if (Array.isArray(obj)) { + values = values.concat(stringify(obj[key], generateArrayPrefix(prefix, key), generateArrayPrefix, strictNullHandling, skipNulls, encoder, filter, sort, allowDots)); + } else { + values = values.concat(stringify(obj[key], prefix + (allowDots ? '.' + key : '[' + key + ']'), generateArrayPrefix, strictNullHandling, skipNulls, encoder, filter, sort, allowDots)); + } + } + + return values; +}; + +module.exports = function (object, opts) { + var obj = object; + var options = opts || {}; + var delimiter = typeof options.delimiter === 'undefined' ? defaults.delimiter : options.delimiter; + var strictNullHandling = typeof options.strictNullHandling === 'boolean' ? options.strictNullHandling : defaults.strictNullHandling; + var skipNulls = typeof options.skipNulls === 'boolean' ? options.skipNulls : defaults.skipNulls; + var encode = typeof options.encode === 'boolean' ? options.encode : defaults.encode; + var encoder = encode ? (typeof options.encoder === 'function' ? options.encoder : defaults.encoder) : null; + var sort = typeof options.sort === 'function' ? options.sort : null; + var allowDots = typeof options.allowDots === 'undefined' ? false : options.allowDots; + var objKeys; + var filter; + + if (options.encoder !== null && options.encoder !== undefined && typeof options.encoder !== 'function') { + throw new TypeError('Encoder has to be a function.'); + } + + if (typeof options.filter === 'function') { + filter = options.filter; + obj = filter('', obj); + } else if (Array.isArray(options.filter)) { + objKeys = filter = options.filter; + } + + var keys = []; + + if (typeof obj !== 'object' || obj === null) { + return ''; + } + + var arrayFormat; + if (options.arrayFormat in arrayPrefixGenerators) { + arrayFormat = options.arrayFormat; + } else if ('indices' in options) { + arrayFormat = options.indices ? 'indices' : 'repeat'; + } else { + arrayFormat = 'indices'; + } + + var generateArrayPrefix = arrayPrefixGenerators[arrayFormat]; + + if (!objKeys) { + objKeys = Object.keys(obj); + } + + if (sort) { + objKeys.sort(sort); + } + + for (var i = 0; i < objKeys.length; ++i) { + var key = objKeys[i]; + + if (skipNulls && obj[key] === null) { + continue; + } + + keys = keys.concat(stringify(obj[key], key, generateArrayPrefix, strictNullHandling, skipNulls, encoder, filter, sort, allowDots)); + } + + return keys.join(delimiter); +}; diff --git a/node_modules/express/node_modules/qs/lib/utils.js b/node_modules/express/node_modules/qs/lib/utils.js new file mode 100644 index 0000000..2c5c8ee --- /dev/null +++ b/node_modules/express/node_modules/qs/lib/utils.js @@ -0,0 +1,164 @@ +'use strict'; + +var hexTable = (function () { + var array = new Array(256); + for (var i = 0; i < 256; ++i) { + array[i] = '%' + ((i < 16 ? '0' : '') + i.toString(16)).toUpperCase(); + } + + return array; +}()); + +exports.arrayToObject = function (source, options) { + var obj = options.plainObjects ? Object.create(null) : {}; + for (var i = 0; i < source.length; ++i) { + if (typeof source[i] !== 'undefined') { + obj[i] = source[i]; + } + } + + return obj; +}; + +exports.merge = function (target, source, options) { + if (!source) { + return target; + } + + if (typeof source !== 'object') { + if (Array.isArray(target)) { + target.push(source); + } else if (typeof target === 'object') { + target[source] = true; + } else { + return [target, source]; + } + + return target; + } + + if (typeof target !== 'object') { + return [target].concat(source); + } + + var mergeTarget = target; + if (Array.isArray(target) && !Array.isArray(source)) { + mergeTarget = exports.arrayToObject(target, options); + } + + return Object.keys(source).reduce(function (acc, key) { + var value = source[key]; + + if (Object.prototype.hasOwnProperty.call(acc, key)) { + acc[key] = exports.merge(acc[key], value, options); + } else { + acc[key] = value; + } + return acc; + }, mergeTarget); +}; + +exports.decode = function (str) { + try { + return decodeURIComponent(str.replace(/\+/g, ' ')); + } catch (e) { + return str; + } +}; + +exports.encode = function (str) { + // This code was originally written by Brian White (mscdex) for the io.js core querystring library. + // It has been adapted here for stricter adherence to RFC 3986 + if (str.length === 0) { + return str; + } + + var string = typeof str === 'string' ? str : String(str); + + var out = ''; + for (var i = 0; i < string.length; ++i) { + var c = string.charCodeAt(i); + + if ( + c === 0x2D || // - + c === 0x2E || // . + c === 0x5F || // _ + c === 0x7E || // ~ + (c >= 0x30 && c <= 0x39) || // 0-9 + (c >= 0x41 && c <= 0x5A) || // a-z + (c >= 0x61 && c <= 0x7A) // A-Z + ) { + out += string.charAt(i); + continue; + } + + if (c < 0x80) { + out = out + hexTable[c]; + continue; + } + + if (c < 0x800) { + out = out + (hexTable[0xC0 | (c >> 6)] + hexTable[0x80 | (c & 0x3F)]); + continue; + } + + if (c < 0xD800 || c >= 0xE000) { + out = out + (hexTable[0xE0 | (c >> 12)] + hexTable[0x80 | ((c >> 6) & 0x3F)] + hexTable[0x80 | (c & 0x3F)]); + continue; + } + + i += 1; + c = 0x10000 + (((c & 0x3FF) << 10) | (string.charCodeAt(i) & 0x3FF)); + out += hexTable[0xF0 | (c >> 18)] + hexTable[0x80 | ((c >> 12) & 0x3F)] + hexTable[0x80 | ((c >> 6) & 0x3F)] + hexTable[0x80 | (c & 0x3F)]; + } + + return out; +}; + +exports.compact = function (obj, references) { + if (typeof obj !== 'object' || obj === null) { + return obj; + } + + var refs = references || []; + var lookup = refs.indexOf(obj); + if (lookup !== -1) { + return refs[lookup]; + } + + refs.push(obj); + + if (Array.isArray(obj)) { + var compacted = []; + + for (var i = 0; i < obj.length; ++i) { + if (obj[i] && typeof obj[i] === 'object') { + compacted.push(exports.compact(obj[i], refs)); + } else if (typeof obj[i] !== 'undefined') { + compacted.push(obj[i]); + } + } + + return compacted; + } + + var keys = Object.keys(obj); + for (var j = 0; j < keys.length; ++j) { + var key = keys[j]; + obj[key] = exports.compact(obj[key], refs); + } + + return obj; +}; + +exports.isRegExp = function (obj) { + return Object.prototype.toString.call(obj) === '[object RegExp]'; +}; + +exports.isBuffer = function (obj) { + if (obj === null || typeof obj === 'undefined') { + return false; + } + + return !!(obj.constructor && obj.constructor.isBuffer && obj.constructor.isBuffer(obj)); +}; diff --git a/node_modules/express/node_modules/qs/package.json b/node_modules/express/node_modules/qs/package.json new file mode 100644 index 0000000..debabac --- /dev/null +++ b/node_modules/express/node_modules/qs/package.json @@ -0,0 +1,86 @@ +{ + "name": "qs", + "description": "A querystring parser that supports nesting and arrays, with a depth limit", + "homepage": "https://github.com/ljharb/qs", + "version": "6.2.0", + "repository": { + "type": "git", + "url": "git+https://github.com/ljharb/qs.git" + }, + "main": "lib/index.js", + "contributors": [ + { + "name": "Jordan Harband", + "email": "ljharb@gmail.com", + "url": "http://ljharb.codes" + } + ], + "keywords": [ + "querystring", + "qs" + ], + "engines": { + "node": ">=0.6" + }, + "dependencies": {}, + "devDependencies": { + "browserify": "^13.0.1", + "tape": "^4.5.1", + "covert": "^1.1.0", + "mkdirp": "^0.5.1", + "eslint": "^2.9.0", + "@ljharb/eslint-config": "^4.0.0", + "parallelshell": "^2.0.0", + "iconv-lite": "^0.4.13", + "evalmd": "^0.0.17" + }, + "scripts": { + "pretest": "parallelshell 'npm run --silent readme' 'npm run --silent lint'", + "test": "npm run --silent coverage", + "tests-only": "node test", + "readme": "evalmd README.md", + "lint": "eslint lib/*.js text/*.js", + "coverage": "covert test", + "dist": "mkdirp dist && browserify --standalone Qs lib/index.js > dist/qs.js", + "prepublish": "npm run dist" + }, + "license": "BSD-3-Clause", + "gitHead": "d67d315b606c6bb809fedcbeebbbdb7f863852aa", + "bugs": { + "url": "https://github.com/ljharb/qs/issues" + }, + "_id": "qs@6.2.0", + "_shasum": "3b7848c03c2dece69a9522b0fae8c4126d745f3b", + "_from": "qs@6.2.0", + "_npmVersion": "3.8.6", + "_nodeVersion": "6.1.0", + "_npmUser": { + "name": "ljharb", + "email": "ljharb@gmail.com" + }, + "dist": { + "shasum": "3b7848c03c2dece69a9522b0fae8c4126d745f3b", + "tarball": "https://registry.npmjs.org/qs/-/qs-6.2.0.tgz" + }, + "maintainers": [ + { + "name": "hueniverse", + "email": "eran@hammer.io" + }, + { + "name": "ljharb", + "email": "ljharb@gmail.com" + }, + { + "name": "nlf", + "email": "quitlahok@gmail.com" + } + ], + "_npmOperationalInternal": { + "host": "packages-12-west.internal.npmjs.com", + "tmp": "tmp/qs-6.2.0.tgz_1462749349998_0.03372702235355973" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/qs/-/qs-6.2.0.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/express/node_modules/qs/test/index.js b/node_modules/express/node_modules/qs/test/index.js new file mode 100644 index 0000000..b6a7d95 --- /dev/null +++ b/node_modules/express/node_modules/qs/test/index.js @@ -0,0 +1,5 @@ +require('./parse'); + +require('./stringify'); + +require('./utils'); diff --git a/node_modules/express/node_modules/qs/test/parse.js b/node_modules/express/node_modules/qs/test/parse.js new file mode 100644 index 0000000..1b79daf --- /dev/null +++ b/node_modules/express/node_modules/qs/test/parse.js @@ -0,0 +1,423 @@ +'use strict'; + +var test = require('tape'); +var qs = require('../'); +var iconv = require('iconv-lite'); + +test('parse()', function (t) { + t.test('parses a simple string', function (st) { + st.deepEqual(qs.parse('0=foo'), { '0': 'foo' }); + st.deepEqual(qs.parse('foo=c++'), { foo: 'c ' }); + st.deepEqual(qs.parse('a[>=]=23'), { a: { '>=': '23' } }); + st.deepEqual(qs.parse('a[<=>]==23'), { a: { '<=>': '=23' } }); + st.deepEqual(qs.parse('a[==]=23'), { a: { '==': '23' } }); + st.deepEqual(qs.parse('foo', { strictNullHandling: true }), { foo: null }); + st.deepEqual(qs.parse('foo'), { foo: '' }); + st.deepEqual(qs.parse('foo='), { foo: '' }); + st.deepEqual(qs.parse('foo=bar'), { foo: 'bar' }); + st.deepEqual(qs.parse(' foo = bar = baz '), { ' foo ': ' bar = baz ' }); + st.deepEqual(qs.parse('foo=bar=baz'), { foo: 'bar=baz' }); + st.deepEqual(qs.parse('foo=bar&bar=baz'), { foo: 'bar', bar: 'baz' }); + st.deepEqual(qs.parse('foo2=bar2&baz2='), { foo2: 'bar2', baz2: '' }); + st.deepEqual(qs.parse('foo=bar&baz', { strictNullHandling: true }), { foo: 'bar', baz: null }); + st.deepEqual(qs.parse('foo=bar&baz'), { foo: 'bar', baz: '' }); + st.deepEqual(qs.parse('cht=p3&chd=t:60,40&chs=250x100&chl=Hello|World'), { + cht: 'p3', + chd: 't:60,40', + chs: '250x100', + chl: 'Hello|World' + }); + st.end(); + }); + + t.test('allows enabling dot notation', function (st) { + st.deepEqual(qs.parse('a.b=c'), { 'a.b': 'c' }); + st.deepEqual(qs.parse('a.b=c', { allowDots: true }), { a: { b: 'c' } }); + st.end(); + }); + + t.deepEqual(qs.parse('a[b]=c'), { a: { b: 'c' } }, 'parses a single nested string'); + t.deepEqual(qs.parse('a[b][c]=d'), { a: { b: { c: 'd' } } }, 'parses a double nested string'); + t.deepEqual( + qs.parse('a[b][c][d][e][f][g][h]=i'), + { a: { b: { c: { d: { e: { f: { '[g][h]': 'i' } } } } } } }, + 'defaults to a depth of 5' + ); + + t.test('only parses one level when depth = 1', function (st) { + st.deepEqual(qs.parse('a[b][c]=d', { depth: 1 }), { a: { b: { '[c]': 'd' } } }); + st.deepEqual(qs.parse('a[b][c][d]=e', { depth: 1 }), { a: { b: { '[c][d]': 'e' } } }); + st.end(); + }); + + t.deepEqual(qs.parse('a=b&a=c'), { a: ['b', 'c'] }, 'parses a simple array'); + + t.test('parses an explicit array', function (st) { + st.deepEqual(qs.parse('a[]=b'), { a: ['b'] }); + st.deepEqual(qs.parse('a[]=b&a[]=c'), { a: ['b', 'c'] }); + st.deepEqual(qs.parse('a[]=b&a[]=c&a[]=d'), { a: ['b', 'c', 'd'] }); + st.end(); + }); + + t.test('parses a mix of simple and explicit arrays', function (st) { + st.deepEqual(qs.parse('a=b&a[]=c'), { a: ['b', 'c'] }); + st.deepEqual(qs.parse('a[]=b&a=c'), { a: ['b', 'c'] }); + st.deepEqual(qs.parse('a[0]=b&a=c'), { a: ['b', 'c'] }); + st.deepEqual(qs.parse('a=b&a[0]=c'), { a: ['b', 'c'] }); + st.deepEqual(qs.parse('a[1]=b&a=c'), { a: ['b', 'c'] }); + st.deepEqual(qs.parse('a=b&a[1]=c'), { a: ['b', 'c'] }); + st.end(); + }); + + t.test('parses a nested array', function (st) { + st.deepEqual(qs.parse('a[b][]=c&a[b][]=d'), { a: { b: ['c', 'd'] } }); + st.deepEqual(qs.parse('a[>=]=25'), { a: { '>=': '25' } }); + st.end(); + }); + + t.test('allows to specify array indices', function (st) { + st.deepEqual(qs.parse('a[1]=c&a[0]=b&a[2]=d'), { a: ['b', 'c', 'd'] }); + st.deepEqual(qs.parse('a[1]=c&a[0]=b'), { a: ['b', 'c'] }); + st.deepEqual(qs.parse('a[1]=c'), { a: ['c'] }); + st.end(); + }); + + t.test('limits specific array indices to 20', function (st) { + st.deepEqual(qs.parse('a[20]=a'), { a: ['a'] }); + st.deepEqual(qs.parse('a[21]=a'), { a: { '21': 'a' } }); + st.end(); + }); + + t.deepEqual(qs.parse('a[12b]=c'), { a: { '12b': 'c' } }, 'supports keys that begin with a number'); + + t.test('supports encoded = signs', function (st) { + st.deepEqual(qs.parse('he%3Dllo=th%3Dere'), { 'he=llo': 'th=ere' }); + st.end(); + }); + + t.test('is ok with url encoded strings', function (st) { + st.deepEqual(qs.parse('a[b%20c]=d'), { a: { 'b c': 'd' } }); + st.deepEqual(qs.parse('a[b]=c%20d'), { a: { b: 'c d' } }); + st.end(); + }); + + t.test('allows brackets in the value', function (st) { + st.deepEqual(qs.parse('pets=["tobi"]'), { pets: '["tobi"]' }); + st.deepEqual(qs.parse('operators=[">=", "<="]'), { operators: '[">=", "<="]' }); + st.end(); + }); + + t.test('allows empty values', function (st) { + st.deepEqual(qs.parse(''), {}); + st.deepEqual(qs.parse(null), {}); + st.deepEqual(qs.parse(undefined), {}); + st.end(); + }); + + t.test('transforms arrays to objects', function (st) { + st.deepEqual(qs.parse('foo[0]=bar&foo[bad]=baz'), { foo: { '0': 'bar', bad: 'baz' } }); + st.deepEqual(qs.parse('foo[bad]=baz&foo[0]=bar'), { foo: { bad: 'baz', '0': 'bar' } }); + st.deepEqual(qs.parse('foo[bad]=baz&foo[]=bar'), { foo: { bad: 'baz', '0': 'bar' } }); + st.deepEqual(qs.parse('foo[]=bar&foo[bad]=baz'), { foo: { '0': 'bar', bad: 'baz' } }); + st.deepEqual(qs.parse('foo[bad]=baz&foo[]=bar&foo[]=foo'), { foo: { bad: 'baz', '0': 'bar', '1': 'foo' } }); + st.deepEqual(qs.parse('foo[0][a]=a&foo[0][b]=b&foo[1][a]=aa&foo[1][b]=bb'), { foo: [{ a: 'a', b: 'b' }, { a: 'aa', b: 'bb' }] }); + st.deepEqual(qs.parse('a[]=b&a[t]=u&a[hasOwnProperty]=c'), { a: { '0': 'b', t: 'u', c: true } }); + st.deepEqual(qs.parse('a[]=b&a[hasOwnProperty]=c&a[x]=y'), { a: { '0': 'b', '1': 'c', x: 'y' } }); + st.end(); + }); + + t.test('transforms arrays to objects (dot notation)', function (st) { + st.deepEqual(qs.parse('foo[0].baz=bar&fool.bad=baz', { allowDots: true }), { foo: [{ baz: 'bar' }], fool: { bad: 'baz' } }); + st.deepEqual(qs.parse('foo[0].baz=bar&fool.bad.boo=baz', { allowDots: true }), { foo: [{ baz: 'bar' }], fool: { bad: { boo: 'baz' } } }); + st.deepEqual(qs.parse('foo[0][0].baz=bar&fool.bad=baz', { allowDots: true }), { foo: [[{ baz: 'bar' }]], fool: { bad: 'baz' } }); + st.deepEqual(qs.parse('foo[0].baz[0]=15&foo[0].bar=2', { allowDots: true }), { foo: [{ baz: ['15'], bar: '2' }] }); + st.deepEqual(qs.parse('foo[0].baz[0]=15&foo[0].baz[1]=16&foo[0].bar=2', { allowDots: true }), { foo: [{ baz: ['15', '16'], bar: '2' }] }); + st.deepEqual(qs.parse('foo.bad=baz&foo[0]=bar', { allowDots: true }), { foo: { bad: 'baz', '0': 'bar' } }); + st.deepEqual(qs.parse('foo.bad=baz&foo[]=bar', { allowDots: true }), { foo: { bad: 'baz', '0': 'bar' } }); + st.deepEqual(qs.parse('foo[]=bar&foo.bad=baz', { allowDots: true }), { foo: { '0': 'bar', bad: 'baz' } }); + st.deepEqual(qs.parse('foo.bad=baz&foo[]=bar&foo[]=foo', { allowDots: true }), { foo: { bad: 'baz', '0': 'bar', '1': 'foo' } }); + st.deepEqual(qs.parse('foo[0].a=a&foo[0].b=b&foo[1].a=aa&foo[1].b=bb', { allowDots: true }), { foo: [{ a: 'a', b: 'b' }, { a: 'aa', b: 'bb' }] }); + st.end(); + }); + + t.deepEqual(qs.parse('a[b]=c&a=d'), { a: { b: 'c', d: true } }, 'can add keys to objects'); + + t.test('correctly prunes undefined values when converting an array to an object', function (st) { + st.deepEqual(qs.parse('a[2]=b&a[99999999]=c'), { a: { '2': 'b', '99999999': 'c' } }); + st.end(); + }); + + t.test('supports malformed uri characters', function (st) { + st.deepEqual(qs.parse('{%:%}', { strictNullHandling: true }), { '{%:%}': null }); + st.deepEqual(qs.parse('{%:%}='), { '{%:%}': '' }); + st.deepEqual(qs.parse('foo=%:%}'), { foo: '%:%}' }); + st.end(); + }); + + t.test('doesn\'t produce empty keys', function (st) { + st.deepEqual(qs.parse('_r=1&'), { '_r': '1' }); + st.end(); + }); + + t.test('cannot access Object prototype', function (st) { + qs.parse('constructor[prototype][bad]=bad'); + qs.parse('bad[constructor][prototype][bad]=bad'); + st.equal(typeof Object.prototype.bad, 'undefined'); + st.end(); + }); + + t.test('parses arrays of objects', function (st) { + st.deepEqual(qs.parse('a[][b]=c'), { a: [{ b: 'c' }] }); + st.deepEqual(qs.parse('a[0][b]=c'), { a: [{ b: 'c' }] }); + st.end(); + }); + + t.test('allows for empty strings in arrays', function (st) { + st.deepEqual(qs.parse('a[]=b&a[]=&a[]=c'), { a: ['b', '', 'c'] }); + st.deepEqual(qs.parse('a[0]=b&a[1]&a[2]=c&a[19]=', { strictNullHandling: true }), { a: ['b', null, 'c', ''] }); + st.deepEqual(qs.parse('a[0]=b&a[1]=&a[2]=c&a[19]', { strictNullHandling: true }), { a: ['b', '', 'c', null] }); + st.deepEqual(qs.parse('a[]=&a[]=b&a[]=c'), { a: ['', 'b', 'c'] }); + st.end(); + }); + + t.test('compacts sparse arrays', function (st) { + st.deepEqual(qs.parse('a[10]=1&a[2]=2'), { a: ['2', '1'] }); + st.deepEqual(qs.parse('a[1][b][2][c]=1'), { a: [{ b: [{ c: '1' }] }] }); + st.deepEqual(qs.parse('a[1][2][3][c]=1'), { a: [[[{ c: '1' }]]] }); + st.deepEqual(qs.parse('a[1][2][3][c][1]=1'), { a: [[[{ c: ['1'] }]]] }); + st.end(); + }); + + t.test('parses semi-parsed strings', function (st) { + st.deepEqual(qs.parse({ 'a[b]': 'c' }), { a: { b: 'c' } }); + st.deepEqual(qs.parse({ 'a[b]': 'c', 'a[d]': 'e' }), { a: { b: 'c', d: 'e' } }); + st.end(); + }); + + t.test('parses buffers correctly', function (st) { + var b = new Buffer('test'); + st.deepEqual(qs.parse({ a: b }), { a: b }); + st.end(); + }); + + t.test('continues parsing when no parent is found', function (st) { + st.deepEqual(qs.parse('[]=&a=b'), { '0': '', a: 'b' }); + st.deepEqual(qs.parse('[]&a=b', { strictNullHandling: true }), { '0': null, a: 'b' }); + st.deepEqual(qs.parse('[foo]=bar'), { foo: 'bar' }); + st.end(); + }); + + t.test('does not error when parsing a very long array', function (st) { + var str = 'a[]=a'; + while (Buffer.byteLength(str) < 128 * 1024) { + str = str + '&' + str; + } + + st.doesNotThrow(function () { qs.parse(str); }); + + st.end(); + }); + + t.test('should not throw when a native prototype has an enumerable property', { parallel: false }, function (st) { + Object.prototype.crash = ''; + Array.prototype.crash = ''; + st.doesNotThrow(qs.parse.bind(null, 'a=b')); + st.deepEqual(qs.parse('a=b'), { a: 'b' }); + st.doesNotThrow(qs.parse.bind(null, 'a[][b]=c')); + st.deepEqual(qs.parse('a[][b]=c'), { a: [{ b: 'c' }] }); + delete Object.prototype.crash; + delete Array.prototype.crash; + st.end(); + }); + + t.test('parses a string with an alternative string delimiter', function (st) { + st.deepEqual(qs.parse('a=b;c=d', { delimiter: ';' }), { a: 'b', c: 'd' }); + st.end(); + }); + + t.test('parses a string with an alternative RegExp delimiter', function (st) { + st.deepEqual(qs.parse('a=b; c=d', { delimiter: /[;,] */ }), { a: 'b', c: 'd' }); + st.end(); + }); + + t.test('does not use non-splittable objects as delimiters', function (st) { + st.deepEqual(qs.parse('a=b&c=d', { delimiter: true }), { a: 'b', c: 'd' }); + st.end(); + }); + + t.test('allows overriding parameter limit', function (st) { + st.deepEqual(qs.parse('a=b&c=d', { parameterLimit: 1 }), { a: 'b' }); + st.end(); + }); + + t.test('allows setting the parameter limit to Infinity', function (st) { + st.deepEqual(qs.parse('a=b&c=d', { parameterLimit: Infinity }), { a: 'b', c: 'd' }); + st.end(); + }); + + t.test('allows overriding array limit', function (st) { + st.deepEqual(qs.parse('a[0]=b', { arrayLimit: -1 }), { a: { '0': 'b' } }); + st.deepEqual(qs.parse('a[-1]=b', { arrayLimit: -1 }), { a: { '-1': 'b' } }); + st.deepEqual(qs.parse('a[0]=b&a[1]=c', { arrayLimit: 0 }), { a: { '0': 'b', '1': 'c' } }); + st.end(); + }); + + t.test('allows disabling array parsing', function (st) { + st.deepEqual(qs.parse('a[0]=b&a[1]=c', { parseArrays: false }), { a: { '0': 'b', '1': 'c' } }); + st.end(); + }); + + t.test('parses an object', function (st) { + var input = { + 'user[name]': { 'pop[bob]': 3 }, + 'user[email]': null + }; + + var expected = { + user: { + name: { 'pop[bob]': 3 }, + email: null + } + }; + + var result = qs.parse(input); + + st.deepEqual(result, expected); + st.end(); + }); + + t.test('parses an object in dot notation', function (st) { + var input = { + 'user.name': { 'pop[bob]': 3 }, + 'user.email.': null + }; + + var expected = { + user: { + name: { 'pop[bob]': 3 }, + email: null + } + }; + + var result = qs.parse(input, { allowDots: true }); + + st.deepEqual(result, expected); + st.end(); + }); + + t.test('parses an object and not child values', function (st) { + var input = { + 'user[name]': { 'pop[bob]': { 'test': 3 } }, + 'user[email]': null + }; + + var expected = { + user: { + name: { 'pop[bob]': { 'test': 3 } }, + email: null + } + }; + + var result = qs.parse(input); + + st.deepEqual(result, expected); + st.end(); + }); + + t.test('does not blow up when Buffer global is missing', function (st) { + var tempBuffer = global.Buffer; + delete global.Buffer; + var result = qs.parse('a=b&c=d'); + global.Buffer = tempBuffer; + st.deepEqual(result, { a: 'b', c: 'd' }); + st.end(); + }); + + t.test('does not crash when parsing circular references', function (st) { + var a = {}; + a.b = a; + + var parsed; + + st.doesNotThrow(function () { + parsed = qs.parse({ 'foo[bar]': 'baz', 'foo[baz]': a }); + }); + + st.equal('foo' in parsed, true, 'parsed has "foo" property'); + st.equal('bar' in parsed.foo, true); + st.equal('baz' in parsed.foo, true); + st.equal(parsed.foo.bar, 'baz'); + st.deepEqual(parsed.foo.baz, a); + st.end(); + }); + + t.test('parses plain objects correctly', function (st) { + var a = Object.create(null); + a.b = 'c'; + + st.deepEqual(qs.parse(a), { b: 'c' }); + var result = qs.parse({ a: a }); + st.equal('a' in result, true, 'result has "a" property'); + st.deepEqual(result.a, a); + st.end(); + }); + + t.test('parses dates correctly', function (st) { + var now = new Date(); + st.deepEqual(qs.parse({ a: now }), { a: now }); + st.end(); + }); + + t.test('parses regular expressions correctly', function (st) { + var re = /^test$/; + st.deepEqual(qs.parse({ a: re }), { a: re }); + st.end(); + }); + + t.test('can allow overwriting prototype properties', function (st) { + st.deepEqual(qs.parse('a[hasOwnProperty]=b', { allowPrototypes: true }), { a: { hasOwnProperty: 'b' } }, { prototype: false }); + st.deepEqual(qs.parse('hasOwnProperty=b', { allowPrototypes: true }), { hasOwnProperty: 'b' }, { prototype: false }); + st.end(); + }); + + t.test('can return plain objects', function (st) { + var expected = Object.create(null); + expected.a = Object.create(null); + expected.a.b = 'c'; + expected.a.hasOwnProperty = 'd'; + st.deepEqual(qs.parse('a[b]=c&a[hasOwnProperty]=d', { plainObjects: true }), expected); + st.deepEqual(qs.parse(null, { plainObjects: true }), Object.create(null)); + var expectedArray = Object.create(null); + expectedArray.a = Object.create(null); + expectedArray.a['0'] = 'b'; + expectedArray.a.c = 'd'; + st.deepEqual(qs.parse('a[]=b&a[c]=d', { plainObjects: true }), expectedArray); + st.end(); + }); + + t.test('can parse with custom encoding', function (st) { + st.deepEqual(qs.parse('%8c%a7=%91%e5%8d%e3%95%7b', { + decoder: function (str) { + var reg = /\%([0-9A-F]{2})/ig; + var result = []; + var parts; + var last = 0; + while (parts = reg.exec(str)) { + result.push(parseInt(parts[1], 16)); + last = parts.index + parts[0].length; + } + return iconv.decode(new Buffer(result), 'shift_jis').toString(); + } + }), { 県: '大阪府' }); + st.end(); + }); + + t.test('throws error with wrong decoder', function (st) { + st.throws(function () { + qs.parse({}, { + decoder: 'string' + }); + }, new TypeError('Decoder has to be a function.')); + st.end(); + }); +}); diff --git a/node_modules/express/node_modules/qs/test/stringify.js b/node_modules/express/node_modules/qs/test/stringify.js new file mode 100644 index 0000000..699397e --- /dev/null +++ b/node_modules/express/node_modules/qs/test/stringify.js @@ -0,0 +1,305 @@ +'use strict'; + +var test = require('tape'); +var qs = require('../'); +var iconv = require('iconv-lite'); + +test('stringify()', function (t) { + t.test('stringifies a querystring object', function (st) { + st.equal(qs.stringify({ a: 'b' }), 'a=b'); + st.equal(qs.stringify({ a: 1 }), 'a=1'); + st.equal(qs.stringify({ a: 1, b: 2 }), 'a=1&b=2'); + st.equal(qs.stringify({ a: 'A_Z' }), 'a=A_Z'); + st.equal(qs.stringify({ a: '€' }), 'a=%E2%82%AC'); + st.equal(qs.stringify({ a: '' }), 'a=%EE%80%80'); + st.equal(qs.stringify({ a: 'א' }), 'a=%D7%90'); + st.equal(qs.stringify({ a: '𐐷' }), 'a=%F0%90%90%B7'); + st.end(); + }); + + t.test('stringifies a nested object', function (st) { + st.equal(qs.stringify({ a: { b: 'c' } }), 'a%5Bb%5D=c'); + st.equal(qs.stringify({ a: { b: { c: { d: 'e' } } } }), 'a%5Bb%5D%5Bc%5D%5Bd%5D=e'); + st.end(); + }); + + t.test('stringifies a nested object with dots notation', function (st) { + st.equal(qs.stringify({ a: { b: 'c' } }, { allowDots: true }), 'a.b=c'); + st.equal(qs.stringify({ a: { b: { c: { d: 'e' } } } }, { allowDots: true }), 'a.b.c.d=e'); + st.end(); + }); + + t.test('stringifies an array value', function (st) { + st.equal(qs.stringify({ a: ['b', 'c', 'd'] }), 'a%5B0%5D=b&a%5B1%5D=c&a%5B2%5D=d'); + st.end(); + }); + + t.test('omits nulls when asked', function (st) { + st.equal(qs.stringify({ a: 'b', c: null }, { skipNulls: true }), 'a=b'); + st.end(); + }); + + + t.test('omits nested nulls when asked', function (st) { + st.equal(qs.stringify({ a: { b: 'c', d: null } }, { skipNulls: true }), 'a%5Bb%5D=c'); + st.end(); + }); + + t.test('omits array indices when asked', function (st) { + st.equal(qs.stringify({ a: ['b', 'c', 'd'] }, { indices: false }), 'a=b&a=c&a=d'); + st.end(); + }); + + t.test('stringifies a nested array value', function (st) { + st.equal(qs.stringify({ a: { b: ['c', 'd'] } }), 'a%5Bb%5D%5B0%5D=c&a%5Bb%5D%5B1%5D=d'); + st.end(); + }); + + t.test('stringifies a nested array value with dots notation', function (st) { + st.equal(qs.stringify({ a: { b: ['c', 'd'] } }, { allowDots: true, encode: false }), 'a.b[0]=c&a.b[1]=d'); + st.end(); + }); + + t.test('stringifies an object inside an array', function (st) { + st.equal(qs.stringify({ a: [{ b: 'c' }] }), 'a%5B0%5D%5Bb%5D=c'); + st.equal(qs.stringify({ a: [{ b: { c: [1] } }] }), 'a%5B0%5D%5Bb%5D%5Bc%5D%5B0%5D=1'); + st.end(); + }); + + t.test('stringifies an array with mixed objects and primitives', function (st) { + st.equal(qs.stringify({ a: [{ b: 1 }, 2, 3] }, { encode: false }), 'a[0][b]=1&a[1]=2&a[2]=3'); + st.end(); + }); + + t.test('stringifies an object inside an array with dots notation', function (st) { + st.equal(qs.stringify({ a: [{ b: 'c' }] }, { allowDots: true, encode: false }), 'a[0].b=c'); + st.equal(qs.stringify({ a: [{ b: { c: [1] } }] }, { allowDots: true, encode: false }), 'a[0].b.c[0]=1'); + st.end(); + }); + + t.test('does not omit object keys when indices = false', function (st) { + st.equal(qs.stringify({ a: [{ b: 'c' }] }, { indices: false }), 'a%5Bb%5D=c'); + st.end(); + }); + + t.test('uses indices notation for arrays when indices=true', function (st) { + st.equal(qs.stringify({ a: ['b', 'c'] }, { indices: true }), 'a%5B0%5D=b&a%5B1%5D=c'); + st.end(); + }); + + t.test('uses indices notation for arrays when no arrayFormat is specified', function (st) { + st.equal(qs.stringify({ a: ['b', 'c'] }), 'a%5B0%5D=b&a%5B1%5D=c'); + st.end(); + }); + + t.test('uses indices notation for arrays when no arrayFormat=indices', function (st) { + st.equal(qs.stringify({ a: ['b', 'c'] }, { arrayFormat: 'indices' }), 'a%5B0%5D=b&a%5B1%5D=c'); + st.end(); + }); + + t.test('uses repeat notation for arrays when no arrayFormat=repeat', function (st) { + st.equal(qs.stringify({ a: ['b', 'c'] }, { arrayFormat: 'repeat' }), 'a=b&a=c'); + st.end(); + }); + + t.test('uses brackets notation for arrays when no arrayFormat=brackets', function (st) { + st.equal(qs.stringify({ a: ['b', 'c'] }, { arrayFormat: 'brackets' }), 'a%5B%5D=b&a%5B%5D=c'); + st.end(); + }); + + t.test('stringifies a complicated object', function (st) { + st.equal(qs.stringify({ a: { b: 'c', d: 'e' } }), 'a%5Bb%5D=c&a%5Bd%5D=e'); + st.end(); + }); + + t.test('stringifies an empty value', function (st) { + st.equal(qs.stringify({ a: '' }), 'a='); + st.equal(qs.stringify({ a: null }, { strictNullHandling: true }), 'a'); + + st.equal(qs.stringify({ a: '', b: '' }), 'a=&b='); + st.equal(qs.stringify({ a: null, b: '' }, { strictNullHandling: true }), 'a&b='); + + st.equal(qs.stringify({ a: { b: '' } }), 'a%5Bb%5D='); + st.equal(qs.stringify({ a: { b: null } }, { strictNullHandling: true }), 'a%5Bb%5D'); + st.equal(qs.stringify({ a: { b: null } }, { strictNullHandling: false }), 'a%5Bb%5D='); + + st.end(); + }); + + t.test('stringifies an empty object', function (st) { + var obj = Object.create(null); + obj.a = 'b'; + st.equal(qs.stringify(obj), 'a=b'); + st.end(); + }); + + t.test('returns an empty string for invalid input', function (st) { + st.equal(qs.stringify(undefined), ''); + st.equal(qs.stringify(false), ''); + st.equal(qs.stringify(null), ''); + st.equal(qs.stringify(''), ''); + st.end(); + }); + + t.test('stringifies an object with an empty object as a child', function (st) { + var obj = { + a: Object.create(null) + }; + + obj.a.b = 'c'; + st.equal(qs.stringify(obj), 'a%5Bb%5D=c'); + st.end(); + }); + + t.test('drops keys with a value of undefined', function (st) { + st.equal(qs.stringify({ a: undefined }), ''); + + st.equal(qs.stringify({ a: { b: undefined, c: null } }, { strictNullHandling: true }), 'a%5Bc%5D'); + st.equal(qs.stringify({ a: { b: undefined, c: null } }, { strictNullHandling: false }), 'a%5Bc%5D='); + st.equal(qs.stringify({ a: { b: undefined, c: '' } }), 'a%5Bc%5D='); + st.end(); + }); + + t.test('url encodes values', function (st) { + st.equal(qs.stringify({ a: 'b c' }), 'a=b%20c'); + st.end(); + }); + + t.test('stringifies a date', function (st) { + var now = new Date(); + var str = 'a=' + encodeURIComponent(now.toISOString()); + st.equal(qs.stringify({ a: now }), str); + st.end(); + }); + + t.test('stringifies the weird object from qs', function (st) { + st.equal(qs.stringify({ 'my weird field': '~q1!2"\'w$5&7/z8)?' }), 'my%20weird%20field=~q1%212%22%27w%245%267%2Fz8%29%3F'); + st.end(); + }); + + t.test('skips properties that are part of the object prototype', function (st) { + Object.prototype.crash = 'test'; + st.equal(qs.stringify({ a: 'b' }), 'a=b'); + st.equal(qs.stringify({ a: { b: 'c' } }), 'a%5Bb%5D=c'); + delete Object.prototype.crash; + st.end(); + }); + + t.test('stringifies boolean values', function (st) { + st.equal(qs.stringify({ a: true }), 'a=true'); + st.equal(qs.stringify({ a: { b: true } }), 'a%5Bb%5D=true'); + st.equal(qs.stringify({ b: false }), 'b=false'); + st.equal(qs.stringify({ b: { c: false } }), 'b%5Bc%5D=false'); + st.end(); + }); + + t.test('stringifies buffer values', function (st) { + st.equal(qs.stringify({ a: new Buffer('test') }), 'a=test'); + st.equal(qs.stringify({ a: { b: new Buffer('test') } }), 'a%5Bb%5D=test'); + st.end(); + }); + + t.test('stringifies an object using an alternative delimiter', function (st) { + st.equal(qs.stringify({ a: 'b', c: 'd' }, { delimiter: ';' }), 'a=b;c=d'); + st.end(); + }); + + t.test('doesn\'t blow up when Buffer global is missing', function (st) { + var tempBuffer = global.Buffer; + delete global.Buffer; + var result = qs.stringify({ a: 'b', c: 'd' }); + global.Buffer = tempBuffer; + st.equal(result, 'a=b&c=d'); + st.end(); + }); + + t.test('selects properties when filter=array', function (st) { + st.equal(qs.stringify({ a: 'b' }, { filter: ['a'] }), 'a=b'); + st.equal(qs.stringify({ a: 1 }, { filter: [] }), ''); + st.equal(qs.stringify({ a: { b: [1, 2, 3, 4], c: 'd' }, c: 'f' }, { filter: ['a', 'b', 0, 2] }), 'a%5Bb%5D%5B0%5D=1&a%5Bb%5D%5B2%5D=3'); + st.end(); + }); + + t.test('supports custom representations when filter=function', function (st) { + var calls = 0; + var obj = { a: 'b', c: 'd', e: { f: new Date(1257894000000) } }; + var filterFunc = function (prefix, value) { + calls++; + if (calls === 1) { + st.equal(prefix, '', 'prefix is empty'); + st.equal(value, obj); + } else if (prefix === 'c') { + return; + } else if (value instanceof Date) { + st.equal(prefix, 'e[f]'); + return value.getTime(); + } + return value; + }; + + st.equal(qs.stringify(obj, { filter: filterFunc }), 'a=b&e%5Bf%5D=1257894000000'); + st.equal(calls, 5); + st.end(); + }); + + t.test('can disable uri encoding', function (st) { + st.equal(qs.stringify({ a: 'b' }, { encode: false }), 'a=b'); + st.equal(qs.stringify({ a: { b: 'c' } }, { encode: false }), 'a[b]=c'); + st.equal(qs.stringify({ a: 'b', c: null }, { strictNullHandling: true, encode: false }), 'a=b&c'); + st.end(); + }); + + t.test('can sort the keys', function (st) { + var sort = function (a, b) { return a.localeCompare(b); }; + st.equal(qs.stringify({ a: 'c', z: 'y', b: 'f' }, { sort: sort }), 'a=c&b=f&z=y'); + st.equal(qs.stringify({ a: 'c', z: { j: 'a', i: 'b' }, b: 'f' }, { sort: sort }), 'a=c&b=f&z%5Bi%5D=b&z%5Bj%5D=a'); + st.end(); + }); + + t.test('can sort the keys at depth 3 or more too', function (st) { + var sort = function (a, b) { return a.localeCompare(b); }; + st.equal(qs.stringify({ a: 'a', z: { zj: {zjb: 'zjb', zja: 'zja'}, zi: {zib: 'zib', zia: 'zia'} }, b: 'b' }, { sort: sort, encode: false }), 'a=a&b=b&z[zi][zia]=zia&z[zi][zib]=zib&z[zj][zja]=zja&z[zj][zjb]=zjb'); + st.equal(qs.stringify({ a: 'a', z: { zj: {zjb: 'zjb', zja: 'zja'}, zi: {zib: 'zib', zia: 'zia'} }, b: 'b' }, { sort: null, encode: false }), 'a=a&z[zj][zjb]=zjb&z[zj][zja]=zja&z[zi][zib]=zib&z[zi][zia]=zia&b=b'); + st.end(); + }); + + t.test('can stringify with custom encoding', function (st) { + st.equal(qs.stringify({ 県: '大阪府', '': ''}, { + encoder: function (str) { + if (str.length === 0) { + return ''; + } + var buf = iconv.encode(str, 'shiftjis'); + var result = []; + for (var i=0; i < buf.length; ++i) { + result.push(buf.readUInt8(i).toString(16)); + } + return '%' + result.join('%'); + } + }), '%8c%a7=%91%e5%8d%e3%95%7b&='); + st.end(); + }); + + t.test('throws error with wrong encoder', function (st) { + st.throws(function () { + qs.stringify({}, { + encoder: 'string' + }); + }, new TypeError('Encoder has to be a function.')); + st.end(); + }); + + t.test('can use custom encoder for a buffer object', { + skip: typeof Buffer === 'undefined' + }, function (st) { + st.equal(qs.stringify({ a: new Buffer([1]) }, { + encoder: function (buffer) { + if (typeof buffer === 'string') { + return buffer; + } + return String.fromCharCode(buffer.readUInt8(0) + 97); + } + }), 'a=b'); + st.end(); + }); +}); diff --git a/node_modules/express/node_modules/qs/test/utils.js b/node_modules/express/node_modules/qs/test/utils.js new file mode 100644 index 0000000..4a8d824 --- /dev/null +++ b/node_modules/express/node_modules/qs/test/utils.js @@ -0,0 +1,9 @@ +'use strict'; + +var test = require('tape'); +var utils = require('../lib/utils'); + +test('merge()', function (t) { + t.deepEqual(utils.merge({ a: 'b' }, { a: 'c' }), { a: ['b', 'c'] }, 'merges two objects with the same key'); + t.end(); +}); diff --git a/node_modules/express/node_modules/range-parser/HISTORY.md b/node_modules/express/node_modules/range-parser/HISTORY.md new file mode 100644 index 0000000..5e01eef --- /dev/null +++ b/node_modules/express/node_modules/range-parser/HISTORY.md @@ -0,0 +1,51 @@ +1.2.0 / 2016-06-01 +================== + + * Add `combine` option to combine overlapping ranges + +1.1.0 / 2016-05-13 +================== + + * Fix incorrectly returning -1 when there is at least one valid range + * perf: remove internal function + +1.0.3 / 2015-10-29 +================== + + * perf: enable strict mode + +1.0.2 / 2014-09-08 +================== + + * Support Node.js 0.6 + +1.0.1 / 2014-09-07 +================== + + * Move repository to jshttp + +1.0.0 / 2013-12-11 +================== + + * Add repository to package.json + * Add MIT license + +0.0.4 / 2012-06-17 +================== + + * Change ret -1 for unsatisfiable and -2 when invalid + +0.0.3 / 2012-06-17 +================== + + * Fix last-byte-pos default to len - 1 + +0.0.2 / 2012-06-14 +================== + + * Add `.type` + +0.0.1 / 2012-06-11 +================== + + * Initial release diff --git a/node_modules/express/node_modules/range-parser/LICENSE b/node_modules/express/node_modules/range-parser/LICENSE new file mode 100644 index 0000000..3599954 --- /dev/null +++ b/node_modules/express/node_modules/range-parser/LICENSE @@ -0,0 +1,23 @@ +(The MIT License) + +Copyright (c) 2012-2014 TJ Holowaychuk +Copyright (c) 2015-2016 Douglas Christopher Wilson [ +// { start: 0, end: 10 }, +// { start: 50, end: 60 } +// ] +``` + +## License + +[MIT](LICENSE) + +[npm-image]: https://img.shields.io/npm/v/range-parser.svg +[npm-url]: https://npmjs.org/package/range-parser +[node-version-image]: https://img.shields.io/node/v/range-parser.svg +[node-version-url]: https://nodejs.org/endownload +[travis-image]: https://img.shields.io/travis/jshttp/range-parser.svg +[travis-url]: https://travis-ci.org/jshttp/range-parser +[coveralls-image]: https://img.shields.io/coveralls/jshttp/range-parser.svg +[coveralls-url]: https://coveralls.io/r/jshttp/range-parser +[downloads-image]: https://img.shields.io/npm/dm/range-parser.svg +[downloads-url]: https://npmjs.org/package/range-parser diff --git a/node_modules/express/node_modules/range-parser/index.js b/node_modules/express/node_modules/range-parser/index.js new file mode 100644 index 0000000..83b2eb6 --- /dev/null +++ b/node_modules/express/node_modules/range-parser/index.js @@ -0,0 +1,158 @@ +/*! + * range-parser + * Copyright(c) 2012-2014 TJ Holowaychuk + * Copyright(c) 2015-2016 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module exports. + * @public + */ + +module.exports = rangeParser + +/** + * Parse "Range" header `str` relative to the given file `size`. + * + * @param {Number} size + * @param {String} str + * @param {Object} [options] + * @return {Array} + * @public + */ + +function rangeParser (size, str, options) { + var index = str.indexOf('=') + + if (index === -1) { + return -2 + } + + // split the range string + var arr = str.slice(index + 1).split(',') + var ranges = [] + + // add ranges type + ranges.type = str.slice(0, index) + + // parse all ranges + for (var i = 0; i < arr.length; i++) { + var range = arr[i].split('-') + var start = parseInt(range[0], 10) + var end = parseInt(range[1], 10) + + // -nnn + if (isNaN(start)) { + start = size - end + end = size - 1 + // nnn- + } else if (isNaN(end)) { + end = size - 1 + } + + // limit last-byte-pos to current length + if (end > size - 1) { + end = size - 1 + } + + // invalid or unsatisifiable + if (isNaN(start) || isNaN(end) || start > end || start < 0) { + continue + } + + // add range + ranges.push({ + start: start, + end: end + }) + } + + if (ranges.length < 1) { + // unsatisifiable + return -1 + } + + return options && options.combine + ? combineRanges(ranges) + : ranges +} + +/** + * Combine overlapping & adjacent ranges. + * @private + */ + +function combineRanges (ranges) { + var ordered = ranges.map(mapWithIndex).sort(sortByRangeStart) + + for (var j = 0, i = 1; i < ordered.length; i++) { + var range = ordered[i] + var current = ordered[j] + + if (range.start > current.end + 1) { + // next range + ordered[++j] = range + } else if (range.end > current.end) { + // extend range + current.end = range.end + current.index = Math.min(current.index, range.index) + } + } + + // trim ordered array + ordered.length = j + 1 + + // generate combined range + var combined = ordered.sort(sortByRangeIndex).map(mapWithoutIndex) + + // copy ranges type + combined.type = ranges.type + + return combined +} + +/** + * Map function to add index value to ranges. + * @private + */ + +function mapWithIndex (range, index) { + return { + start: range.start, + end: range.end, + index: index + } +} + +/** + * Map function to remove index value from ranges. + * @private + */ + +function mapWithoutIndex (range) { + return { + start: range.start, + end: range.end + } +} + +/** + * Sort function to sort ranges by index. + * @private + */ + +function sortByRangeIndex (a, b) { + return a.index - b.index +} + +/** + * Sort function to sort ranges by start position. + * @private + */ + +function sortByRangeStart (a, b) { + return a.start - b.start +} diff --git a/node_modules/express/node_modules/range-parser/package.json b/node_modules/express/node_modules/range-parser/package.json new file mode 100644 index 0000000..f876b01 --- /dev/null +++ b/node_modules/express/node_modules/range-parser/package.json @@ -0,0 +1,99 @@ +{ + "name": "range-parser", + "author": { + "name": "TJ Holowaychuk", + "email": "tj@vision-media.ca", + "url": "http://tjholowaychuk.com" + }, + "description": "Range header field string parser", + "version": "1.2.0", + "contributors": [ + { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "James Wyatt Cready", + "email": "wyatt.cready@lanetix.com" + }, + { + "name": "Jonathan Ong", + "email": "me@jongleberry.com", + "url": "http://jongleberry.com" + } + ], + "license": "MIT", + "keywords": [ + "range", + "parser", + "http" + ], + "repository": { + "type": "git", + "url": "git+https://github.com/jshttp/range-parser.git" + }, + "devDependencies": { + "eslint": "2.11.1", + "eslint-config-standard": "5.3.1", + "eslint-plugin-promise": "1.1.0", + "eslint-plugin-standard": "1.3.2", + "istanbul": "0.4.3", + "mocha": "1.21.5" + }, + "files": [ + "HISTORY.md", + "LICENSE", + "index.js" + ], + "engines": { + "node": ">= 0.6" + }, + "scripts": { + "lint": "eslint **/*.js", + "test": "mocha --reporter spec", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot", + "test-travis": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter dot" + }, + "gitHead": "0665aca31639d799dee1d35fb10970799559ec48", + "bugs": { + "url": "https://github.com/jshttp/range-parser/issues" + }, + "homepage": "https://github.com/jshttp/range-parser", + "_id": "range-parser@1.2.0", + "_shasum": "f49be6b487894ddc40dcc94a322f611092e00d5e", + "_from": "range-parser@>=1.2.0 <1.3.0", + "_npmVersion": "1.4.28", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "maintainers": [ + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "jonathanong", + "email": "jonathanrichardong@gmail.com" + }, + { + "name": "jongleberry", + "email": "jonathanrichardong@gmail.com" + }, + { + "name": "tjholowaychuk", + "email": "tj@vision-media.ca" + } + ], + "dist": { + "shasum": "f49be6b487894ddc40dcc94a322f611092e00d5e", + "tarball": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.0.tgz" + }, + "_npmOperationalInternal": { + "host": "packages-16-east.internal.npmjs.com", + "tmp": "tmp/range-parser-1.2.0.tgz_1464803293097_0.6830497414339334" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/range-parser/-/range-parser-1.2.0.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/express/node_modules/send/HISTORY.md b/node_modules/express/node_modules/send/HISTORY.md new file mode 100644 index 0000000..f30e345 --- /dev/null +++ b/node_modules/express/node_modules/send/HISTORY.md @@ -0,0 +1,346 @@ +0.14.1 / 2016-06-09 +=================== + + * Fix redirect error when `path` contains raw non-URL characters + * Fix redirect when `path` starts with multiple forward slashes + +0.14.0 / 2016-06-06 +=================== + + * Add `acceptRanges` option + * Add `cacheControl` option + * Attempt to combine multiple ranges into single range + * Correctly inherit from `Stream` class + * Fix `Content-Range` header in 416 responses when using `start`/`end` options + * Fix `Content-Range` header missing from default 416 responses + * Ignore non-byte `Range` headers + * deps: http-errors@~1.5.0 + - Add `HttpError` export, for `err instanceof createError.HttpError` + - Support new code `421 Misdirected Request` + - Use `setprototypeof` module to replace `__proto__` setting + - deps: inherits@2.0.1 + - deps: statuses@'>= 1.3.0 < 2' + - perf: enable strict mode + * deps: range-parser@~1.2.0 + - Fix incorrectly returning -1 when there is at least one valid range + - perf: remove internal function + * deps: statuses@~1.3.0 + - Add `421 Misdirected Request` + - perf: enable strict mode + * perf: remove argument reassignment + +0.13.2 / 2016-03-05 +=================== + + * Fix invalid `Content-Type` header when `send.mime.default_type` unset + +0.13.1 / 2016-01-16 +=================== + + * deps: depd@~1.1.0 + - Support web browser loading + - perf: enable strict mode + * deps: destroy@~1.0.4 + - perf: enable strict mode + * deps: escape-html@~1.0.3 + - perf: enable strict mode + - perf: optimize string replacement + - perf: use faster string coercion + * deps: range-parser@~1.0.3 + - perf: enable strict mode + +0.13.0 / 2015-06-16 +=================== + + * Allow Node.js HTTP server to set `Date` response header + * Fix incorrectly removing `Content-Location` on 304 response + * Improve the default redirect response headers + * Send appropriate headers on default error response + * Use `http-errors` for standard emitted errors + * Use `statuses` instead of `http` module for status messages + * deps: escape-html@1.0.2 + * deps: etag@~1.7.0 + - Improve stat performance by removing hashing + * deps: fresh@0.3.0 + - Add weak `ETag` matching support + * deps: on-finished@~2.3.0 + - Add defined behavior for HTTP `CONNECT` requests + - Add defined behavior for HTTP `Upgrade` requests + - deps: ee-first@1.1.1 + * perf: enable strict mode + * perf: remove unnecessary array allocations + +0.12.3 / 2015-05-13 +=================== + + * deps: debug@~2.2.0 + - deps: ms@0.7.1 + * deps: depd@~1.0.1 + * deps: etag@~1.6.0 + - Improve support for JXcore + - Support "fake" stats objects in environments without `fs` + * deps: ms@0.7.1 + - Prevent extraordinarily long inputs + * deps: on-finished@~2.2.1 + +0.12.2 / 2015-03-13 +=================== + + * Throw errors early for invalid `extensions` or `index` options + * deps: debug@~2.1.3 + - Fix high intensity foreground color for bold + - deps: ms@0.7.0 + +0.12.1 / 2015-02-17 +=================== + + * Fix regression sending zero-length files + +0.12.0 / 2015-02-16 +=================== + + * Always read the stat size from the file + * Fix mutating passed-in `options` + * deps: mime@1.3.4 + +0.11.1 / 2015-01-20 +=================== + + * Fix `root` path disclosure + +0.11.0 / 2015-01-05 +=================== + + * deps: debug@~2.1.1 + * deps: etag@~1.5.1 + - deps: crc@3.2.1 + * deps: ms@0.7.0 + - Add `milliseconds` + - Add `msecs` + - Add `secs` + - Add `mins` + - Add `hrs` + - Add `yrs` + * deps: on-finished@~2.2.0 + +0.10.1 / 2014-10-22 +=================== + + * deps: on-finished@~2.1.1 + - Fix handling of pipelined requests + +0.10.0 / 2014-10-15 +=================== + + * deps: debug@~2.1.0 + - Implement `DEBUG_FD` env variable support + * deps: depd@~1.0.0 + * deps: etag@~1.5.0 + - Improve string performance + - Slightly improve speed for weak ETags over 1KB + +0.9.3 / 2014-09-24 +================== + + * deps: etag@~1.4.0 + - Support "fake" stats objects + +0.9.2 / 2014-09-15 +================== + + * deps: depd@0.4.5 + * deps: etag@~1.3.1 + * deps: range-parser@~1.0.2 + +0.9.1 / 2014-09-07 +================== + + * deps: fresh@0.2.4 + +0.9.0 / 2014-09-07 +================== + + * Add `lastModified` option + * Use `etag` to generate `ETag` header + * deps: debug@~2.0.0 + +0.8.5 / 2014-09-04 +================== + + * Fix malicious path detection for empty string path + +0.8.4 / 2014-09-04 +================== + + * Fix a path traversal issue when using `root` + +0.8.3 / 2014-08-16 +================== + + * deps: destroy@1.0.3 + - renamed from dethroy + * deps: on-finished@2.1.0 + +0.8.2 / 2014-08-14 +================== + + * Work around `fd` leak in Node.js 0.10 for `fs.ReadStream` + * deps: dethroy@1.0.2 + +0.8.1 / 2014-08-05 +================== + + * Fix `extensions` behavior when file already has extension + +0.8.0 / 2014-08-05 +================== + + * Add `extensions` option + +0.7.4 / 2014-08-04 +================== + + * Fix serving index files without root dir + +0.7.3 / 2014-07-29 +================== + + * Fix incorrect 403 on Windows and Node.js 0.11 + +0.7.2 / 2014-07-27 +================== + + * deps: depd@0.4.4 + - Work-around v8 generating empty stack traces + +0.7.1 / 2014-07-26 +================== + + * deps: depd@0.4.3 + - Fix exception when global `Error.stackTraceLimit` is too low + +0.7.0 / 2014-07-20 +================== + + * Deprecate `hidden` option; use `dotfiles` option + * Add `dotfiles` option + * deps: debug@1.0.4 + * deps: depd@0.4.2 + - Add `TRACE_DEPRECATION` environment variable + - Remove non-standard grey color from color output + - Support `--no-deprecation` argument + - Support `--trace-deprecation` argument + +0.6.0 / 2014-07-11 +================== + + * Deprecate `from` option; use `root` option + * Deprecate `send.etag()` -- use `etag` in `options` + * Deprecate `send.hidden()` -- use `hidden` in `options` + * Deprecate `send.index()` -- use `index` in `options` + * Deprecate `send.maxage()` -- use `maxAge` in `options` + * Deprecate `send.root()` -- use `root` in `options` + * Cap `maxAge` value to 1 year + * deps: debug@1.0.3 + - Add support for multiple wildcards in namespaces + +0.5.0 / 2014-06-28 +================== + + * Accept string for `maxAge` (converted by `ms`) + * Add `headers` event + * Include link in default redirect response + * Use `EventEmitter.listenerCount` to count listeners + +0.4.3 / 2014-06-11 +================== + + * Do not throw un-catchable error on file open race condition + * Use `escape-html` for HTML escaping + * deps: debug@1.0.2 + - fix some debugging output colors on node.js 0.8 + * deps: finished@1.2.2 + * deps: fresh@0.2.2 + +0.4.2 / 2014-06-09 +================== + + * fix "event emitter leak" warnings + * deps: debug@1.0.1 + * deps: finished@1.2.1 + +0.4.1 / 2014-06-02 +================== + + * Send `max-age` in `Cache-Control` in correct format + +0.4.0 / 2014-05-27 +================== + + * Calculate ETag with md5 for reduced collisions + * Fix wrong behavior when index file matches directory + * Ignore stream errors after request ends + - Goodbye `EBADF, read` + * Skip directories in index file search + * deps: debug@0.8.1 + +0.3.0 / 2014-04-24 +================== + + * Fix sending files with dots without root set + * Coerce option types + * Accept API options in options object + * Set etags to "weak" + * Include file path in etag + * Make "Can't set headers after they are sent." catchable + * Send full entity-body for multi range requests + * Default directory access to 403 when index disabled + * Support multiple index paths + * Support "If-Range" header + * Control whether to generate etags + * deps: mime@1.2.11 + +0.2.0 / 2014-01-29 +================== + + * update range-parser and fresh + +0.1.4 / 2013-08-11 +================== + + * update fresh + +0.1.3 / 2013-07-08 +================== + + * Revert "Fix fd leak" + +0.1.2 / 2013-07-03 +================== + + * Fix fd leak + +0.1.0 / 2012-08-25 +================== + + * add options parameter to send() that is passed to fs.createReadStream() [kanongil] + +0.0.4 / 2012-08-16 +================== + + * allow custom "Accept-Ranges" definition + +0.0.3 / 2012-07-16 +================== + + * fix normalization of the root directory. Closes #3 + +0.0.2 / 2012-07-09 +================== + + * add passing of req explicitly for now (YUCK) + +0.0.1 / 2010-01-03 +================== + + * Initial release diff --git a/node_modules/express/node_modules/send/LICENSE b/node_modules/express/node_modules/send/LICENSE new file mode 100644 index 0000000..4aa69e8 --- /dev/null +++ b/node_modules/express/node_modules/send/LICENSE @@ -0,0 +1,23 @@ +(The MIT License) + +Copyright (c) 2012 TJ Holowaychuk +Copyright (c) 2014-2016 Douglas Christopher Wilson + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/express/node_modules/send/README.md b/node_modules/express/node_modules/send/README.md new file mode 100644 index 0000000..4167926 --- /dev/null +++ b/node_modules/express/node_modules/send/README.md @@ -0,0 +1,247 @@ +# send + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Linux Build][travis-image]][travis-url] +[![Windows Build][appveyor-image]][appveyor-url] +[![Test Coverage][coveralls-image]][coveralls-url] +[![Gratipay][gratipay-image]][gratipay-url] + +Send is a library for streaming files from the file system as a http response +supporting partial responses (Ranges), conditional-GET negotiation, high test +coverage, and granular events which may be leveraged to take appropriate actions +in your application or framework. + +Looking to serve up entire folders mapped to URLs? Try [serve-static](https://www.npmjs.org/package/serve-static). + +## Installation + +```bash +$ npm install send +``` + +## API + +```js +var send = require('send') +``` + +### send(req, path, [options]) + +Create a new `SendStream` for the given path to send to a `res`. The `req` is +the Node.js HTTP request and the `path` is a urlencoded path to send (urlencoded, +not the actual file-system path). + +#### Options + +##### acceptRanges + +Enable or disable accepting ranged requests, defaults to true. +Disabling this will not send `Accept-Ranges` and ignore the contents +of the `Range` request header. + +##### cacheControl + +Enable or disable setting `Cache-Control` response header, defaults to +true. Disabling this will ignore the `maxAge` option. + +##### dotfiles + +Set how "dotfiles" are treated when encountered. A dotfile is a file +or directory that begins with a dot ("."). Note this check is done on +the path itself without checking if the path actually exists on the +disk. If `root` is specified, only the dotfiles above the root are +checked (i.e. the root itself can be within a dotfile when when set +to "deny"). + + - `'allow'` No special treatment for dotfiles. + - `'deny'` Send a 403 for any request for a dotfile. + - `'ignore'` Pretend like the dotfile does not exist and 404. + +The default value is _similar_ to `'ignore'`, with the exception that +this default will not ignore the files within a directory that begins +with a dot, for backward-compatibility. + +##### end + +Byte offset at which the stream ends, defaults to the length of the file +minus 1. The end is inclusive in the stream, meaning `end: 3` will include +the 4th byte in the stream. + +##### etag + +Enable or disable etag generation, defaults to true. + +##### extensions + +If a given file doesn't exist, try appending one of the given extensions, +in the given order. By default, this is disabled (set to `false`). An +example value that will serve extension-less HTML files: `['html', 'htm']`. +This is skipped if the requested file already has an extension. + +##### index + +By default send supports "index.html" files, to disable this +set `false` or to supply a new index pass a string or an array +in preferred order. + +##### lastModified + +Enable or disable `Last-Modified` header, defaults to true. Uses the file +system's last modified value. + +##### maxAge + +Provide a max-age in milliseconds for http caching, defaults to 0. +This can also be a string accepted by the +[ms](https://www.npmjs.org/package/ms#readme) module. + +##### root + +Serve files relative to `path`. + +##### start + +Byte offset at which the stream starts, defaults to 0. The start is inclusive, +meaning `start: 2` will include the 3rd byte in the stream. + +#### Events + +The `SendStream` is an event emitter and will emit the following events: + + - `error` an error occurred `(err)` + - `directory` a directory was requested + - `file` a file was requested `(path, stat)` + - `headers` the headers are about to be set on a file `(res, path, stat)` + - `stream` file streaming has started `(stream)` + - `end` streaming has completed + +#### .pipe + +The `pipe` method is used to pipe the response into the Node.js HTTP response +object, typically `send(req, path, options).pipe(res)`. + +### .mime + +The `mime` export is the global instance of of the +[`mime` npm module](https://www.npmjs.com/package/mime). + +This is used to configure the MIME types that are associated with file extensions +as well as other options for how to resolve the MIME type of a file (like the +default type to use for an unknown file extension). + +## Error-handling + +By default when no `error` listeners are present an automatic response will be +made, otherwise you have full control over the response, aka you may show a 5xx +page etc. + +## Caching + +It does _not_ perform internal caching, you should use a reverse proxy cache +such as Varnish for this, or those fancy things called CDNs. If your +application is small enough that it would benefit from single-node memory +caching, it's small enough that it does not need caching at all ;). + +## Debugging + +To enable `debug()` instrumentation output export __DEBUG__: + +``` +$ DEBUG=send node app +``` + +## Running tests + +``` +$ npm install +$ npm test +``` + +## Examples + +### Small example + +```js +var http = require('http') +var parseUrl = require('parseurl') +var send = require('send') + +var app = http.createServer(function onRequest (req, res) { + send(req, parseUrl(req).pathname).pipe(res) +}).listen(3000) +``` + +### Custom file types + +```js +var http = require('http') +var parseUrl = require('parseurl') +var send = require('send') + +// Default unknown types to text/plain +send.mime.default_type = 'text/plain' + +// Add a custom type +send.mime.define({ + 'application/x-my-type': ['x-mt', 'x-mtt'] +}) + +var app = http.createServer(function onRequest (req, res) { + send(req, parseUrl(req).pathname).pipe(res) +}).listen(3000) +``` + +### Serving from a root directory with custom error-handling + +```js +var http = require('http') +var parseUrl = require('parseurl') +var send = require('send') + +var app = http.createServer(function onRequest (req, res) { + // your custom error-handling logic: + function error (err) { + res.statusCode = err.status || 500 + res.end(err.message) + } + + // your custom headers + function headers (res, path, stat) { + // serve all files for download + res.setHeader('Content-Disposition', 'attachment') + } + + // your custom directory handling logic: + function redirect () { + res.statusCode = 301 + res.setHeader('Location', req.url + '/') + res.end('Redirecting to ' + req.url + '/') + } + + // transfer arbitrary files from within + // /www/example.com/public/* + send(req, parseUrl(req).pathname, {root: '/www/example.com/public'}) + .on('error', error) + .on('directory', redirect) + .on('headers', headers) + .pipe(res); +}).listen(3000) +``` + +## License + +[MIT](LICENSE) + +[npm-image]: https://img.shields.io/npm/v/send.svg +[npm-url]: https://npmjs.org/package/send +[travis-image]: https://img.shields.io/travis/pillarjs/send/master.svg?label=linux +[travis-url]: https://travis-ci.org/pillarjs/send +[appveyor-image]: https://img.shields.io/appveyor/ci/dougwilson/send/master.svg?label=windows +[appveyor-url]: https://ci.appveyor.com/project/dougwilson/send +[coveralls-image]: https://img.shields.io/coveralls/pillarjs/send/master.svg +[coveralls-url]: https://coveralls.io/r/pillarjs/send?branch=master +[downloads-image]: https://img.shields.io/npm/dm/send.svg +[downloads-url]: https://npmjs.org/package/send +[gratipay-image]: https://img.shields.io/gratipay/dougwilson.svg +[gratipay-url]: https://www.gratipay.com/dougwilson/ diff --git a/node_modules/express/node_modules/send/index.js b/node_modules/express/node_modules/send/index.js new file mode 100644 index 0000000..81ec0b3 --- /dev/null +++ b/node_modules/express/node_modules/send/index.js @@ -0,0 +1,948 @@ +/*! + * send + * Copyright(c) 2012 TJ Holowaychuk + * Copyright(c) 2014-2016 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module dependencies. + * @private + */ + +var createError = require('http-errors') +var debug = require('debug')('send') +var deprecate = require('depd')('send') +var destroy = require('destroy') +var encodeUrl = require('encodeurl') +var escapeHtml = require('escape-html') +var etag = require('etag') +var EventEmitter = require('events').EventEmitter +var fresh = require('fresh') +var fs = require('fs') +var mime = require('mime') +var ms = require('ms') +var onFinished = require('on-finished') +var parseRange = require('range-parser') +var path = require('path') +var statuses = require('statuses') +var Stream = require('stream') +var util = require('util') + +/** + * Path function references. + * @private + */ + +var extname = path.extname +var join = path.join +var normalize = path.normalize +var resolve = path.resolve +var sep = path.sep + +/** + * Regular expression for identifying a bytes Range header. + * @private + */ + +var BYTES_RANGE_REGEXP = /^ *bytes=/ + +/** + * Maximum value allowed for the max age. + * @private + */ + +var MAX_MAXAGE = 60 * 60 * 24 * 365 * 1000 // 1 year + +/** + * Regular expression to match a path with a directory up component. + * @private + */ + +var UP_PATH_REGEXP = /(?:^|[\\\/])\.\.(?:[\\\/]|$)/ + +/** + * Module exports. + * @public + */ + +module.exports = send +module.exports.mime = mime + +/** + * Shim EventEmitter.listenerCount for node.js < 0.10 + */ + +/* istanbul ignore next */ +var listenerCount = EventEmitter.listenerCount || + function (emitter, type) { return emitter.listeners(type).length } + +/** + * Return a `SendStream` for `req` and `path`. + * + * @param {object} req + * @param {string} path + * @param {object} [options] + * @return {SendStream} + * @public + */ + +function send (req, path, options) { + return new SendStream(req, path, options) +} + +/** + * Initialize a `SendStream` with the given `path`. + * + * @param {Request} req + * @param {String} path + * @param {object} [options] + * @private + */ + +function SendStream (req, path, options) { + Stream.call(this) + + var opts = options || {} + + this.options = opts + this.path = path + this.req = req + + this._acceptRanges = opts.acceptRanges !== undefined + ? Boolean(opts.acceptRanges) + : true + + this._cacheControl = opts.cacheControl !== undefined + ? Boolean(opts.cacheControl) + : true + + this._etag = opts.etag !== undefined + ? Boolean(opts.etag) + : true + + this._dotfiles = opts.dotfiles !== undefined + ? opts.dotfiles + : 'ignore' + + if (this._dotfiles !== 'ignore' && this._dotfiles !== 'allow' && this._dotfiles !== 'deny') { + throw new TypeError('dotfiles option must be "allow", "deny", or "ignore"') + } + + this._hidden = Boolean(opts.hidden) + + if (opts.hidden !== undefined) { + deprecate('hidden: use dotfiles: \'' + (this._hidden ? 'allow' : 'ignore') + '\' instead') + } + + // legacy support + if (opts.dotfiles === undefined) { + this._dotfiles = undefined + } + + this._extensions = opts.extensions !== undefined + ? normalizeList(opts.extensions, 'extensions option') + : [] + + this._index = opts.index !== undefined + ? normalizeList(opts.index, 'index option') + : ['index.html'] + + this._lastModified = opts.lastModified !== undefined + ? Boolean(opts.lastModified) + : true + + this._maxage = opts.maxAge || opts.maxage + this._maxage = typeof this._maxage === 'string' + ? ms(this._maxage) + : Number(this._maxage) + this._maxage = !isNaN(this._maxage) + ? Math.min(Math.max(0, this._maxage), MAX_MAXAGE) + : 0 + + this._root = opts.root + ? resolve(opts.root) + : null + + if (!this._root && opts.from) { + this.from(opts.from) + } +} + +/** + * Inherits from `Stream`. + */ + +util.inherits(SendStream, Stream) + +/** + * Enable or disable etag generation. + * + * @param {Boolean} val + * @return {SendStream} + * @api public + */ + +SendStream.prototype.etag = deprecate.function(function etag (val) { + this._etag = Boolean(val) + debug('etag %s', this._etag) + return this +}, 'send.etag: pass etag as option') + +/** + * Enable or disable "hidden" (dot) files. + * + * @param {Boolean} path + * @return {SendStream} + * @api public + */ + +SendStream.prototype.hidden = deprecate.function(function hidden (val) { + this._hidden = Boolean(val) + this._dotfiles = undefined + debug('hidden %s', this._hidden) + return this +}, 'send.hidden: use dotfiles option') + +/** + * Set index `paths`, set to a falsy + * value to disable index support. + * + * @param {String|Boolean|Array} paths + * @return {SendStream} + * @api public + */ + +SendStream.prototype.index = deprecate.function(function index (paths) { + var index = !paths ? [] : normalizeList(paths, 'paths argument') + debug('index %o', paths) + this._index = index + return this +}, 'send.index: pass index as option') + +/** + * Set root `path`. + * + * @param {String} path + * @return {SendStream} + * @api public + */ + +SendStream.prototype.root = function root (path) { + this._root = resolve(String(path)) + debug('root %s', this._root) + return this +} + +SendStream.prototype.from = deprecate.function(SendStream.prototype.root, + 'send.from: pass root as option') + +SendStream.prototype.root = deprecate.function(SendStream.prototype.root, + 'send.root: pass root as option') + +/** + * Set max-age to `maxAge`. + * + * @param {Number} maxAge + * @return {SendStream} + * @api public + */ + +SendStream.prototype.maxage = deprecate.function(function maxage (maxAge) { + this._maxage = typeof maxAge === 'string' + ? ms(maxAge) + : Number(maxAge) + this._maxage = !isNaN(this._maxage) + ? Math.min(Math.max(0, this._maxage), MAX_MAXAGE) + : 0 + debug('max-age %d', this._maxage) + return this +}, 'send.maxage: pass maxAge as option') + +/** + * Emit error with `status`. + * + * @param {number} status + * @param {Error} [error] + * @private + */ + +SendStream.prototype.error = function error (status, error) { + // emit if listeners instead of responding + if (listenerCount(this, 'error') !== 0) { + return this.emit('error', createError(error, status, { + expose: false + })) + } + + var res = this.res + var msg = statuses[status] + + // clear existing headers + clearHeaders(res) + + // add error headers + if (error && error.headers) { + setHeaders(res, error.headers) + } + + // send basic response + res.statusCode = status + res.setHeader('Content-Type', 'text/plain; charset=UTF-8') + res.setHeader('Content-Length', Buffer.byteLength(msg)) + res.setHeader('X-Content-Type-Options', 'nosniff') + res.end(msg) +} + +/** + * Check if the pathname ends with "/". + * + * @return {Boolean} + * @api private + */ + +SendStream.prototype.hasTrailingSlash = function hasTrailingSlash () { + return this.path[this.path.length - 1] === '/' +} + +/** + * Check if this is a conditional GET request. + * + * @return {Boolean} + * @api private + */ + +SendStream.prototype.isConditionalGET = function isConditionalGET () { + return this.req.headers['if-none-match'] || + this.req.headers['if-modified-since'] +} + +/** + * Strip content-* header fields. + * + * @private + */ + +SendStream.prototype.removeContentHeaderFields = function removeContentHeaderFields () { + var res = this.res + var headers = Object.keys(res._headers || {}) + + for (var i = 0; i < headers.length; i++) { + var header = headers[i] + if (header.substr(0, 8) === 'content-' && header !== 'content-location') { + res.removeHeader(header) + } + } +} + +/** + * Respond with 304 not modified. + * + * @api private + */ + +SendStream.prototype.notModified = function notModified () { + var res = this.res + debug('not modified') + this.removeContentHeaderFields() + res.statusCode = 304 + res.end() +} + +/** + * Raise error that headers already sent. + * + * @api private + */ + +SendStream.prototype.headersAlreadySent = function headersAlreadySent () { + var err = new Error('Can\'t set headers after they are sent.') + debug('headers already sent') + this.error(500, err) +} + +/** + * Check if the request is cacheable, aka + * responded with 2xx or 304 (see RFC 2616 section 14.2{5,6}). + * + * @return {Boolean} + * @api private + */ + +SendStream.prototype.isCachable = function isCachable () { + var statusCode = this.res.statusCode + return (statusCode >= 200 && statusCode < 300) || + statusCode === 304 +} + +/** + * Handle stat() error. + * + * @param {Error} error + * @private + */ + +SendStream.prototype.onStatError = function onStatError (error) { + switch (error.code) { + case 'ENAMETOOLONG': + case 'ENOENT': + case 'ENOTDIR': + this.error(404, error) + break + default: + this.error(500, error) + break + } +} + +/** + * Check if the cache is fresh. + * + * @return {Boolean} + * @api private + */ + +SendStream.prototype.isFresh = function isFresh () { + return fresh(this.req.headers, this.res._headers) +} + +/** + * Check if the range is fresh. + * + * @return {Boolean} + * @api private + */ + +SendStream.prototype.isRangeFresh = function isRangeFresh () { + var ifRange = this.req.headers['if-range'] + + if (!ifRange) { + return true + } + + return ~ifRange.indexOf('"') + ? ~ifRange.indexOf(this.res._headers['etag']) + : Date.parse(this.res._headers['last-modified']) <= Date.parse(ifRange) +} + +/** + * Redirect to path. + * + * @param {string} path + * @private + */ + +SendStream.prototype.redirect = function redirect (path) { + if (listenerCount(this, 'directory') !== 0) { + this.emit('directory') + return + } + + if (this.hasTrailingSlash()) { + this.error(403) + return + } + + var loc = encodeUrl(collapseLeadingSlashes(path + '/')) + var msg = 'Redirecting to ' + escapeHtml(loc) + '\n' + var res = this.res + + // redirect + res.statusCode = 301 + res.setHeader('Content-Type', 'text/html; charset=UTF-8') + res.setHeader('Content-Length', Buffer.byteLength(msg)) + res.setHeader('X-Content-Type-Options', 'nosniff') + res.setHeader('Location', loc) + res.end(msg) +} + +/** + * Pipe to `res. + * + * @param {Stream} res + * @return {Stream} res + * @api public + */ + +SendStream.prototype.pipe = function pipe (res) { + // root path + var root = this._root + + // references + this.res = res + + // decode the path + var path = decode(this.path) + if (path === -1) { + this.error(400) + return res + } + + // null byte(s) + if (~path.indexOf('\0')) { + this.error(400) + return res + } + + var parts + if (root !== null) { + // malicious path + if (UP_PATH_REGEXP.test(normalize('.' + sep + path))) { + debug('malicious path "%s"', path) + this.error(403) + return res + } + + // join / normalize from optional root dir + path = normalize(join(root, path)) + root = normalize(root + sep) + + // explode path parts + parts = path.substr(root.length).split(sep) + } else { + // ".." is malicious without "root" + if (UP_PATH_REGEXP.test(path)) { + debug('malicious path "%s"', path) + this.error(403) + return res + } + + // explode path parts + parts = normalize(path).split(sep) + + // resolve the path + path = resolve(path) + } + + // dotfile handling + if (containsDotFile(parts)) { + var access = this._dotfiles + + // legacy support + if (access === undefined) { + access = parts[parts.length - 1][0] === '.' + ? (this._hidden ? 'allow' : 'ignore') + : 'allow' + } + + debug('%s dotfile "%s"', access, path) + switch (access) { + case 'allow': + break + case 'deny': + this.error(403) + return res + case 'ignore': + default: + this.error(404) + return res + } + } + + // index file support + if (this._index.length && this.path[this.path.length - 1] === '/') { + this.sendIndex(path) + return res + } + + this.sendFile(path) + return res +} + +/** + * Transfer `path`. + * + * @param {String} path + * @api public + */ + +SendStream.prototype.send = function send (path, stat) { + var len = stat.size + var options = this.options + var opts = {} + var res = this.res + var req = this.req + var ranges = req.headers.range + var offset = options.start || 0 + + if (res._header) { + // impossible to send now + this.headersAlreadySent() + return + } + + debug('pipe "%s"', path) + + // set header fields + this.setHeader(path, stat) + + // set content-type + this.type(path) + + // conditional GET support + if (this.isConditionalGET() && this.isCachable() && this.isFresh()) { + this.notModified() + return + } + + // adjust len to start/end options + len = Math.max(0, len - offset) + if (options.end !== undefined) { + var bytes = options.end - offset + 1 + if (len > bytes) len = bytes + } + + // Range support + if (this._acceptRanges && BYTES_RANGE_REGEXP.test(ranges)) { + // parse + ranges = parseRange(len, ranges, { + combine: true + }) + + // If-Range support + if (!this.isRangeFresh()) { + debug('range stale') + ranges = -2 + } + + // unsatisfiable + if (ranges === -1) { + debug('range unsatisfiable') + + // Content-Range + res.setHeader('Content-Range', contentRange('bytes', len)) + + // 416 Requested Range Not Satisfiable + return this.error(416, { + headers: {'Content-Range': res.getHeader('Content-Range')} + }) + } + + // valid (syntactically invalid/multiple ranges are treated as a regular response) + if (ranges !== -2 && ranges.length === 1) { + debug('range %j', ranges) + + // Content-Range + res.statusCode = 206 + res.setHeader('Content-Range', contentRange('bytes', len, ranges[0])) + + // adjust for requested range + offset += ranges[0].start + len = ranges[0].end - ranges[0].start + 1 + } + } + + // clone options + for (var prop in options) { + opts[prop] = options[prop] + } + + // set read options + opts.start = offset + opts.end = Math.max(offset, offset + len - 1) + + // content-length + res.setHeader('Content-Length', len) + + // HEAD support + if (req.method === 'HEAD') { + res.end() + return + } + + this.stream(path, opts) +} + +/** + * Transfer file for `path`. + * + * @param {String} path + * @api private + */ +SendStream.prototype.sendFile = function sendFile (path) { + var i = 0 + var self = this + + debug('stat "%s"', path) + fs.stat(path, function onstat (err, stat) { + if (err && err.code === 'ENOENT' && !extname(path) && path[path.length - 1] !== sep) { + // not found, check extensions + return next(err) + } + if (err) return self.onStatError(err) + if (stat.isDirectory()) return self.redirect(self.path) + self.emit('file', path, stat) + self.send(path, stat) + }) + + function next (err) { + if (self._extensions.length <= i) { + return err + ? self.onStatError(err) + : self.error(404) + } + + var p = path + '.' + self._extensions[i++] + + debug('stat "%s"', p) + fs.stat(p, function (err, stat) { + if (err) return next(err) + if (stat.isDirectory()) return next() + self.emit('file', p, stat) + self.send(p, stat) + }) + } +} + +/** + * Transfer index for `path`. + * + * @param {String} path + * @api private + */ +SendStream.prototype.sendIndex = function sendIndex (path) { + var i = -1 + var self = this + + function next (err) { + if (++i >= self._index.length) { + if (err) return self.onStatError(err) + return self.error(404) + } + + var p = join(path, self._index[i]) + + debug('stat "%s"', p) + fs.stat(p, function (err, stat) { + if (err) return next(err) + if (stat.isDirectory()) return next() + self.emit('file', p, stat) + self.send(p, stat) + }) + } + + next() +} + +/** + * Stream `path` to the response. + * + * @param {String} path + * @param {Object} options + * @api private + */ + +SendStream.prototype.stream = function stream (path, options) { + // TODO: this is all lame, refactor meeee + var finished = false + var self = this + var res = this.res + + // pipe + var stream = fs.createReadStream(path, options) + this.emit('stream', stream) + stream.pipe(res) + + // response finished, done with the fd + onFinished(res, function onfinished () { + finished = true + destroy(stream) + }) + + // error handling code-smell + stream.on('error', function onerror (err) { + // request already finished + if (finished) return + + // clean up stream + finished = true + destroy(stream) + + // error + self.onStatError(err) + }) + + // end + stream.on('end', function onend () { + self.emit('end') + }) +} + +/** + * Set content-type based on `path` + * if it hasn't been explicitly set. + * + * @param {String} path + * @api private + */ + +SendStream.prototype.type = function type (path) { + var res = this.res + + if (res.getHeader('Content-Type')) return + + var type = mime.lookup(path) + + if (!type) { + debug('no content-type') + return + } + + var charset = mime.charsets.lookup(type) + + debug('content-type %s', type) + res.setHeader('Content-Type', type + (charset ? '; charset=' + charset : '')) +} + +/** + * Set response header fields, most + * fields may be pre-defined. + * + * @param {String} path + * @param {Object} stat + * @api private + */ + +SendStream.prototype.setHeader = function setHeader (path, stat) { + var res = this.res + + this.emit('headers', res, path, stat) + + if (this._acceptRanges && !res.getHeader('Accept-Ranges')) { + debug('accept ranges') + res.setHeader('Accept-Ranges', 'bytes') + } + + if (this._cacheControl && !res.getHeader('Cache-Control')) { + var cacheControl = 'public, max-age=' + Math.floor(this._maxage / 1000) + debug('cache-control %s', cacheControl) + res.setHeader('Cache-Control', cacheControl) + } + + if (this._lastModified && !res.getHeader('Last-Modified')) { + var modified = stat.mtime.toUTCString() + debug('modified %s', modified) + res.setHeader('Last-Modified', modified) + } + + if (this._etag && !res.getHeader('ETag')) { + var val = etag(stat) + debug('etag %s', val) + res.setHeader('ETag', val) + } +} + +/** + * Clear all headers from a response. + * + * @param {object} res + * @private + */ + +function clearHeaders (res) { + res._headers = {} + res._headerNames = {} +} + +/** + * Collapse all leading slashes into a single slash + * + * @param {string} str + * @private + */ +function collapseLeadingSlashes (str) { + for (var i = 0; i < str.length; i++) { + if (str[i] !== '/') { + break + } + } + + return i > 1 + ? '/' + str.substr(i) + : str +} + +/** + * Determine if path parts contain a dotfile. + * + * @api private + */ + +function containsDotFile (parts) { + for (var i = 0; i < parts.length; i++) { + if (parts[i][0] === '.') { + return true + } + } + + return false +} + +/** + * Create a Content-Range header. + * + * @param {string} type + * @param {number} size + * @param {array} [range] + */ + +function contentRange (type, size, range) { + return type + ' ' + (range ? range.start + '-' + range.end : '*') + '/' + size +} + +/** + * decodeURIComponent. + * + * Allows V8 to only deoptimize this fn instead of all + * of send(). + * + * @param {String} path + * @api private + */ + +function decode (path) { + try { + return decodeURIComponent(path) + } catch (err) { + return -1 + } +} + +/** + * Normalize the index option into an array. + * + * @param {boolean|string|array} val + * @param {string} name + * @private + */ + +function normalizeList (val, name) { + var list = [].concat(val || []) + + for (var i = 0; i < list.length; i++) { + if (typeof list[i] !== 'string') { + throw new TypeError(name + ' must be array of strings or false') + } + } + + return list +} + +/** + * Set an object of headers on a response. + * + * @param {object} res + * @param {object} headers + * @private + */ + +function setHeaders (res, headers) { + var keys = Object.keys(headers) + + for (var i = 0; i < keys.length; i++) { + var key = keys[i] + res.setHeader(key, headers[key]) + } +} diff --git a/node_modules/express/node_modules/send/node_modules/.bin/mime b/node_modules/express/node_modules/send/node_modules/.bin/mime new file mode 100644 index 0000000..0dbddf0 --- /dev/null +++ b/node_modules/express/node_modules/send/node_modules/.bin/mime @@ -0,0 +1,15 @@ +#!/bin/sh +basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')") + +case `uname` in + *CYGWIN*) basedir=`cygpath -w "$basedir"`;; +esac + +if [ -x "$basedir/node" ]; then + "$basedir/node" "$basedir/../mime/cli.js" "$@" + ret=$? +else + node "$basedir/../mime/cli.js" "$@" + ret=$? +fi +exit $ret diff --git a/node_modules/express/node_modules/send/node_modules/.bin/mime.cmd b/node_modules/express/node_modules/send/node_modules/.bin/mime.cmd new file mode 100644 index 0000000..8169562 --- /dev/null +++ b/node_modules/express/node_modules/send/node_modules/.bin/mime.cmd @@ -0,0 +1,7 @@ +@IF EXIST "%~dp0\node.exe" ( + "%~dp0\node.exe" "%~dp0\..\mime\cli.js" %* +) ELSE ( + @SETLOCAL + @SET PATHEXT=%PATHEXT:;.JS;=;% + node "%~dp0\..\mime\cli.js" %* +) \ No newline at end of file diff --git a/node_modules/express/node_modules/send/node_modules/destroy/LICENSE b/node_modules/express/node_modules/send/node_modules/destroy/LICENSE new file mode 100644 index 0000000..a7ae8ee --- /dev/null +++ b/node_modules/express/node_modules/send/node_modules/destroy/LICENSE @@ -0,0 +1,22 @@ + +The MIT License (MIT) + +Copyright (c) 2014 Jonathan Ong me@jongleberry.com + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. diff --git a/node_modules/express/node_modules/send/node_modules/destroy/README.md b/node_modules/express/node_modules/send/node_modules/destroy/README.md new file mode 100644 index 0000000..6474bc3 --- /dev/null +++ b/node_modules/express/node_modules/send/node_modules/destroy/README.md @@ -0,0 +1,60 @@ +# Destroy + +[![NPM version][npm-image]][npm-url] +[![Build status][travis-image]][travis-url] +[![Test coverage][coveralls-image]][coveralls-url] +[![License][license-image]][license-url] +[![Downloads][downloads-image]][downloads-url] +[![Gittip][gittip-image]][gittip-url] + +Destroy a stream. + +This module is meant to ensure a stream gets destroyed, handling different APIs +and Node.js bugs. + +## API + +```js +var destroy = require('destroy') +``` + +### destroy(stream) + +Destroy the given stream. In most cases, this is identical to a simple +`stream.destroy()` call. The rules are as follows for a given stream: + + 1. If the `stream` is an instance of `ReadStream`, then call `stream.destroy()` + and add a listener to the `open` event to call `stream.close()` if it is + fired. This is for a Node.js bug that will leak a file descriptor if + `.destroy()` is called before `open`. + 2. If the `stream` is not an instance of `Stream`, then nothing happens. + 3. If the `stream` has a `.destroy()` method, then call it. + +The function returns the `stream` passed in as the argument. + +## Example + +```js +var destroy = require('destroy') + +var fs = require('fs') +var stream = fs.createReadStream('package.json') + +// ... and later +destroy(stream) +``` + +[npm-image]: https://img.shields.io/npm/v/destroy.svg?style=flat-square +[npm-url]: https://npmjs.org/package/destroy +[github-tag]: http://img.shields.io/github/tag/stream-utils/destroy.svg?style=flat-square +[github-url]: https://github.com/stream-utils/destroy/tags +[travis-image]: https://img.shields.io/travis/stream-utils/destroy.svg?style=flat-square +[travis-url]: https://travis-ci.org/stream-utils/destroy +[coveralls-image]: https://img.shields.io/coveralls/stream-utils/destroy.svg?style=flat-square +[coveralls-url]: https://coveralls.io/r/stream-utils/destroy?branch=master +[license-image]: http://img.shields.io/npm/l/destroy.svg?style=flat-square +[license-url]: LICENSE.md +[downloads-image]: http://img.shields.io/npm/dm/destroy.svg?style=flat-square +[downloads-url]: https://npmjs.org/package/destroy +[gittip-image]: https://img.shields.io/gittip/jonathanong.svg?style=flat-square +[gittip-url]: https://www.gittip.com/jonathanong/ diff --git a/node_modules/express/node_modules/send/node_modules/destroy/index.js b/node_modules/express/node_modules/send/node_modules/destroy/index.js new file mode 100644 index 0000000..6da2d26 --- /dev/null +++ b/node_modules/express/node_modules/send/node_modules/destroy/index.js @@ -0,0 +1,75 @@ +/*! + * destroy + * Copyright(c) 2014 Jonathan Ong + * MIT Licensed + */ + +'use strict' + +/** + * Module dependencies. + * @private + */ + +var ReadStream = require('fs').ReadStream +var Stream = require('stream') + +/** + * Module exports. + * @public + */ + +module.exports = destroy + +/** + * Destroy a stream. + * + * @param {object} stream + * @public + */ + +function destroy(stream) { + if (stream instanceof ReadStream) { + return destroyReadStream(stream) + } + + if (!(stream instanceof Stream)) { + return stream + } + + if (typeof stream.destroy === 'function') { + stream.destroy() + } + + return stream +} + +/** + * Destroy a ReadStream. + * + * @param {object} stream + * @private + */ + +function destroyReadStream(stream) { + stream.destroy() + + if (typeof stream.close === 'function') { + // node.js core bug work-around + stream.on('open', onOpenClose) + } + + return stream +} + +/** + * On open handler to close stream. + * @private + */ + +function onOpenClose() { + if (typeof this.fd === 'number') { + // actually close down the fd + this.close() + } +} diff --git a/node_modules/express/node_modules/send/node_modules/destroy/package.json b/node_modules/express/node_modules/send/node_modules/destroy/package.json new file mode 100644 index 0000000..9b27a5a --- /dev/null +++ b/node_modules/express/node_modules/send/node_modules/destroy/package.json @@ -0,0 +1,72 @@ +{ + "name": "destroy", + "description": "destroy a stream if possible", + "version": "1.0.4", + "author": { + "name": "Jonathan Ong", + "email": "me@jongleberry.com", + "url": "http://jongleberry.com" + }, + "contributors": [ + { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + } + ], + "license": "MIT", + "repository": { + "type": "git", + "url": "git+https://github.com/stream-utils/destroy.git" + }, + "devDependencies": { + "istanbul": "0.4.2", + "mocha": "2.3.4" + }, + "scripts": { + "test": "mocha --reporter spec", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot", + "test-travis": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter dot" + }, + "files": [ + "index.js", + "LICENSE" + ], + "keywords": [ + "stream", + "streams", + "destroy", + "cleanup", + "leak", + "fd" + ], + "gitHead": "86edea01456f5fa1027f6a47250c34c713cbcc3b", + "bugs": { + "url": "https://github.com/stream-utils/destroy/issues" + }, + "homepage": "https://github.com/stream-utils/destroy", + "_id": "destroy@1.0.4", + "_shasum": "978857442c44749e4206613e37946205826abd80", + "_from": "destroy@>=1.0.4 <1.1.0", + "_npmVersion": "1.4.28", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "maintainers": [ + { + "name": "jongleberry", + "email": "jonathanrichardong@gmail.com" + }, + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + } + ], + "dist": { + "shasum": "978857442c44749e4206613e37946205826abd80", + "tarball": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/express/node_modules/send/node_modules/http-errors/HISTORY.md b/node_modules/express/node_modules/send/node_modules/http-errors/HISTORY.md new file mode 100644 index 0000000..0dfb7ac --- /dev/null +++ b/node_modules/express/node_modules/send/node_modules/http-errors/HISTORY.md @@ -0,0 +1,95 @@ +2016-05-18 / 1.5.0 +================== + + * Support new code `421 Misdirected Request` + * Use `setprototypeof` module to replace `__proto__` setting + * deps: statuses@'>= 1.3.0 < 2' + - Add `421 Misdirected Request` + - perf: enable strict mode + * perf: enable strict mode + +2016-01-28 / 1.4.0 +================== + + * Add `HttpError` export, for `err instanceof createError.HttpError` + * deps: inherits@2.0.1 + * deps: statuses@'>= 1.2.1 < 2' + - Fix message for status 451 + - Remove incorrect nginx status code + +2015-02-02 / 1.3.1 +================== + + * Fix regression where status can be overwritten in `createError` `props` + +2015-02-01 / 1.3.0 +================== + + * Construct errors using defined constructors from `createError` + * Fix error names that are not identifiers + - `createError["I'mateapot"]` is now `createError.ImATeapot` + * Set a meaningful `name` property on constructed errors + +2014-12-09 / 1.2.8 +================== + + * Fix stack trace from exported function + * Remove `arguments.callee` usage + +2014-10-14 / 1.2.7 +================== + + * Remove duplicate line + +2014-10-02 / 1.2.6 +================== + + * Fix `expose` to be `true` for `ClientError` constructor + +2014-09-28 / 1.2.5 +================== + + * deps: statuses@1 + +2014-09-21 / 1.2.4 +================== + + * Fix dependency version to work with old `npm`s + +2014-09-21 / 1.2.3 +================== + + * deps: statuses@~1.1.0 + +2014-09-21 / 1.2.2 +================== + + * Fix publish error + +2014-09-21 / 1.2.1 +================== + + * Support Node.js 0.6 + * Use `inherits` instead of `util` + +2014-09-09 / 1.2.0 +================== + + * Fix the way inheriting functions + * Support `expose` being provided in properties argument + +2014-09-08 / 1.1.0 +================== + + * Default status to 500 + * Support provided `error` to extend + +2014-09-08 / 1.0.1 +================== + + * Fix accepting string message + +2014-09-08 / 1.0.0 +================== + + * Initial release diff --git a/node_modules/express/node_modules/send/node_modules/http-errors/LICENSE b/node_modules/express/node_modules/send/node_modules/http-errors/LICENSE new file mode 100644 index 0000000..82af4df --- /dev/null +++ b/node_modules/express/node_modules/send/node_modules/http-errors/LICENSE @@ -0,0 +1,23 @@ + +The MIT License (MIT) + +Copyright (c) 2014 Jonathan Ong me@jongleberry.com +Copyright (c) 2016 Douglas Christopher Wilson doug@somethingdoug.com + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. diff --git a/node_modules/express/node_modules/send/node_modules/http-errors/README.md b/node_modules/express/node_modules/send/node_modules/http-errors/README.md new file mode 100644 index 0000000..be80f9b --- /dev/null +++ b/node_modules/express/node_modules/send/node_modules/http-errors/README.md @@ -0,0 +1,112 @@ +# http-errors + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Node.js Version][node-version-image]][node-version-url] +[![Build Status][travis-image]][travis-url] +[![Test Coverage][coveralls-image]][coveralls-url] + +Create HTTP errors for Express, Koa, Connect, etc. with ease. + +## Example + +```js +var createError = require('http-errors'); + +app.use(function (req, res, next) { + if (!req.user) return next(createError(401, 'Please login to view this page.')); + next(); +}) +``` + +## API + +This is the current API, currently extracted from Koa and subject to change. + +All errors inherit from JavaScript `Error` and the exported `createError.HttpError`. + +### Error Properties + +- `expose` - can be used to signal if `message` should be sent to the client, defaulting to `false` when `status` >= 500 +- `message` +- `status` and `statusCode` - the status code of the error, defaulting to `500` + +### createError([status], [message], [properties]) + +```js +var err = createError(404, 'This video does not exist!'); +``` + +- `status: 500` - the status code as a number +- `message` - the message of the error, defaulting to node's text for that status code. +- `properties` - custom properties to attach to the object + +### new createError\[code || name\](\[msg]\)) + +```js +var err = new createError.NotFound(); +``` + +- `code` - the status code as a number +- `name` - the name of the error as a "bumpy case", i.e. `NotFound` or `InternalServerError`. + +#### List of all constructors + +|Status Code|Constructor Name | +|-----------|-----------------------------| +|400 |BadRequest | +|401 |Unauthorized | +|402 |PaymentRequired | +|403 |Forbidden | +|404 |NotFound | +|405 |MethodNotAllowed | +|406 |NotAcceptable | +|407 |ProxyAuthenticationRequired | +|408 |RequestTimeout | +|409 |Conflict | +|410 |Gone | +|411 |LengthRequired | +|412 |PreconditionFailed | +|413 |PayloadTooLarge | +|414 |URITooLong | +|415 |UnsupportedMediaType | +|416 |RangeNotSatisfiable | +|417 |ExpectationFailed | +|418 |ImATeapot | +|421 |MisdirectedRequest | +|422 |UnprocessableEntity | +|423 |Locked | +|424 |FailedDependency | +|425 |UnorderedCollection | +|426 |UpgradeRequired | +|428 |PreconditionRequired | +|429 |TooManyRequests | +|431 |RequestHeaderFieldsTooLarge | +|451 |UnavailableForLegalReasons | +|500 |InternalServerError | +|501 |NotImplemented | +|502 |BadGateway | +|503 |ServiceUnavailable | +|504 |GatewayTimeout | +|505 |HTTPVersionNotSupported | +|506 |VariantAlsoNegotiates | +|507 |InsufficientStorage | +|508 |LoopDetected | +|509 |BandwidthLimitExceeded | +|510 |NotExtended | +|511 |NetworkAuthenticationRequired| + +## License + +[MIT](LICENSE) + +[npm-image]: https://img.shields.io/npm/v/http-errors.svg?style=flat +[npm-url]: https://npmjs.org/package/http-errors +[node-version-image]: https://img.shields.io/node/v/http-errors.svg?style=flat +[node-version-url]: https://nodejs.org/en/download/ +[travis-image]: https://img.shields.io/travis/jshttp/http-errors.svg?style=flat +[travis-url]: https://travis-ci.org/jshttp/http-errors +[coveralls-image]: https://img.shields.io/coveralls/jshttp/http-errors.svg?style=flat +[coveralls-url]: https://coveralls.io/r/jshttp/http-errors +[downloads-image]: https://img.shields.io/npm/dm/http-errors.svg?style=flat +[downloads-url]: https://npmjs.org/package/http-errors diff --git a/node_modules/express/node_modules/send/node_modules/http-errors/index.js b/node_modules/express/node_modules/send/node_modules/http-errors/index.js new file mode 100644 index 0000000..6130db8 --- /dev/null +++ b/node_modules/express/node_modules/send/node_modules/http-errors/index.js @@ -0,0 +1,223 @@ +/*! + * http-errors + * Copyright(c) 2014 Jonathan Ong + * Copyright(c) 2016 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module dependencies. + * @private + */ + +var setPrototypeOf = require('setprototypeof') +var statuses = require('statuses') +var inherits = require('inherits') + +/** + * Module exports. + * @public + */ + +module.exports = createError +module.exports.HttpError = createHttpErrorConstructor() + +// Populate exports for all constructors +populateConstructorExports(module.exports, statuses.codes, module.exports.HttpError) + +/** + * Create a new HTTP Error. + * + * @returns {Error} + * @public + */ + +function createError () { + // so much arity going on ~_~ + var err + var msg + var status = 500 + var props = {} + for (var i = 0; i < arguments.length; i++) { + var arg = arguments[i] + if (arg instanceof Error) { + err = arg + status = err.status || err.statusCode || status + continue + } + switch (typeof arg) { + case 'string': + msg = arg + break + case 'number': + status = arg + break + case 'object': + props = arg + break + } + } + + if (typeof status !== 'number' || !statuses[status]) { + status = 500 + } + + // constructor + var HttpError = createError[status] + + if (!err) { + // create error + err = HttpError + ? new HttpError(msg) + : new Error(msg || statuses[status]) + Error.captureStackTrace(err, createError) + } + + if (!HttpError || !(err instanceof HttpError)) { + // add properties to generic error + err.expose = status < 500 + err.status = err.statusCode = status + } + + for (var key in props) { + if (key !== 'status' && key !== 'statusCode') { + err[key] = props[key] + } + } + + return err +} + +/** + * Create HTTP error abstract base class. + * @private + */ + +function createHttpErrorConstructor () { + function HttpError () { + throw new TypeError('cannot construct abstract class') + } + + inherits(HttpError, Error) + + return HttpError +} + +/** + * Create a constructor for a client error. + * @private + */ + +function createClientErrorConstructor (HttpError, name, code) { + var className = name.match(/Error$/) ? name : name + 'Error' + + function ClientError (message) { + // create the error object + var err = new Error(message != null ? message : statuses[code]) + + // capture a stack trace to the construction point + Error.captureStackTrace(err, ClientError) + + // adjust the [[Prototype]] + setPrototypeOf(err, ClientError.prototype) + + // redefine the error name + Object.defineProperty(err, 'name', { + enumerable: false, + configurable: true, + value: className, + writable: true + }) + + return err + } + + inherits(ClientError, HttpError) + + ClientError.prototype.status = code + ClientError.prototype.statusCode = code + ClientError.prototype.expose = true + + return ClientError +} + +/** + * Create a constructor for a server error. + * @private + */ + +function createServerErrorConstructor (HttpError, name, code) { + var className = name.match(/Error$/) ? name : name + 'Error' + + function ServerError (message) { + // create the error object + var err = new Error(message != null ? message : statuses[code]) + + // capture a stack trace to the construction point + Error.captureStackTrace(err, ServerError) + + // adjust the [[Prototype]] + setPrototypeOf(err, ServerError.prototype) + + // redefine the error name + Object.defineProperty(err, 'name', { + enumerable: false, + configurable: true, + value: className, + writable: true + }) + + return err + } + + inherits(ServerError, HttpError) + + ServerError.prototype.status = code + ServerError.prototype.statusCode = code + ServerError.prototype.expose = false + + return ServerError +} + +/** + * Populate the exports object with constructors for every error class. + * @private + */ + +function populateConstructorExports (exports, codes, HttpError) { + codes.forEach(function forEachCode (code) { + var CodeError + var name = toIdentifier(statuses[code]) + + switch (String(code).charAt(0)) { + case '4': + CodeError = createClientErrorConstructor(HttpError, name, code) + break + case '5': + CodeError = createServerErrorConstructor(HttpError, name, code) + break + } + + if (CodeError) { + // export the constructor + exports[code] = CodeError + exports[name] = CodeError + } + }) + + // backwards-compatibility + exports["I'mateapot"] = exports.ImATeapot +} + +/** + * Convert a string of words to a JavaScript identifier. + * @private + */ + +function toIdentifier (str) { + return str.split(' ').map(function (token) { + return token.slice(0, 1).toUpperCase() + token.slice(1) + }).join('').replace(/[^ _0-9a-z]/gi, '') +} diff --git a/node_modules/express/node_modules/send/node_modules/http-errors/node_modules/inherits/LICENSE b/node_modules/express/node_modules/send/node_modules/http-errors/node_modules/inherits/LICENSE new file mode 100644 index 0000000..dea3013 --- /dev/null +++ b/node_modules/express/node_modules/send/node_modules/http-errors/node_modules/inherits/LICENSE @@ -0,0 +1,16 @@ +The ISC License + +Copyright (c) Isaac Z. Schlueter + +Permission to use, copy, modify, and/or distribute this software for any +purpose with or without fee is hereby granted, provided that the above +copyright notice and this permission notice appear in all copies. + +THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH +REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND +FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, +INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM +LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR +OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR +PERFORMANCE OF THIS SOFTWARE. + diff --git a/node_modules/express/node_modules/send/node_modules/http-errors/node_modules/inherits/README.md b/node_modules/express/node_modules/send/node_modules/http-errors/node_modules/inherits/README.md new file mode 100644 index 0000000..b1c5665 --- /dev/null +++ b/node_modules/express/node_modules/send/node_modules/http-errors/node_modules/inherits/README.md @@ -0,0 +1,42 @@ +Browser-friendly inheritance fully compatible with standard node.js +[inherits](http://nodejs.org/api/util.html#util_util_inherits_constructor_superconstructor). + +This package exports standard `inherits` from node.js `util` module in +node environment, but also provides alternative browser-friendly +implementation through [browser +field](https://gist.github.com/shtylman/4339901). Alternative +implementation is a literal copy of standard one located in standalone +module to avoid requiring of `util`. It also has a shim for old +browsers with no `Object.create` support. + +While keeping you sure you are using standard `inherits` +implementation in node.js environment, it allows bundlers such as +[browserify](https://github.com/substack/node-browserify) to not +include full `util` package to your client code if all you need is +just `inherits` function. It worth, because browser shim for `util` +package is large and `inherits` is often the single function you need +from it. + +It's recommended to use this package instead of +`require('util').inherits` for any code that has chances to be used +not only in node.js but in browser too. + +## usage + +```js +var inherits = require('inherits'); +// then use exactly as the standard one +``` + +## note on version ~1.0 + +Version ~1.0 had completely different motivation and is not compatible +neither with 2.0 nor with standard node.js `inherits`. + +If you are using version ~1.0 and planning to switch to ~2.0, be +careful: + +* new version uses `super_` instead of `super` for referencing + superclass +* new version overwrites current prototype while old one preserves any + existing fields on it diff --git a/node_modules/express/node_modules/send/node_modules/http-errors/node_modules/inherits/inherits.js b/node_modules/express/node_modules/send/node_modules/http-errors/node_modules/inherits/inherits.js new file mode 100644 index 0000000..29f5e24 --- /dev/null +++ b/node_modules/express/node_modules/send/node_modules/http-errors/node_modules/inherits/inherits.js @@ -0,0 +1 @@ +module.exports = require('util').inherits diff --git a/node_modules/express/node_modules/send/node_modules/http-errors/node_modules/inherits/inherits_browser.js b/node_modules/express/node_modules/send/node_modules/http-errors/node_modules/inherits/inherits_browser.js new file mode 100644 index 0000000..c1e78a7 --- /dev/null +++ b/node_modules/express/node_modules/send/node_modules/http-errors/node_modules/inherits/inherits_browser.js @@ -0,0 +1,23 @@ +if (typeof Object.create === 'function') { + // implementation from standard node.js 'util' module + module.exports = function inherits(ctor, superCtor) { + ctor.super_ = superCtor + ctor.prototype = Object.create(superCtor.prototype, { + constructor: { + value: ctor, + enumerable: false, + writable: true, + configurable: true + } + }); + }; +} else { + // old school shim for old browsers + module.exports = function inherits(ctor, superCtor) { + ctor.super_ = superCtor + var TempCtor = function () {} + TempCtor.prototype = superCtor.prototype + ctor.prototype = new TempCtor() + ctor.prototype.constructor = ctor + } +} diff --git a/node_modules/express/node_modules/send/node_modules/http-errors/node_modules/inherits/package.json b/node_modules/express/node_modules/send/node_modules/http-errors/node_modules/inherits/package.json new file mode 100644 index 0000000..546e984 --- /dev/null +++ b/node_modules/express/node_modules/send/node_modules/http-errors/node_modules/inherits/package.json @@ -0,0 +1,50 @@ +{ + "name": "inherits", + "description": "Browser-friendly inheritance fully compatible with standard node.js inherits()", + "version": "2.0.1", + "keywords": [ + "inheritance", + "class", + "klass", + "oop", + "object-oriented", + "inherits", + "browser", + "browserify" + ], + "main": "./inherits.js", + "browser": "./inherits_browser.js", + "repository": { + "type": "git", + "url": "git://github.com/isaacs/inherits.git" + }, + "license": "ISC", + "scripts": { + "test": "node test" + }, + "bugs": { + "url": "https://github.com/isaacs/inherits/issues" + }, + "_id": "inherits@2.0.1", + "dist": { + "shasum": "b17d08d326b4423e568eff719f91b0b1cbdf69f1", + "tarball": "https://registry.npmjs.org/inherits/-/inherits-2.0.1.tgz" + }, + "_from": "inherits@2.0.1", + "_npmVersion": "1.3.8", + "_npmUser": { + "name": "isaacs", + "email": "i@izs.me" + }, + "maintainers": [ + { + "name": "isaacs", + "email": "i@izs.me" + } + ], + "directories": {}, + "_shasum": "b17d08d326b4423e568eff719f91b0b1cbdf69f1", + "_resolved": "http://registry.npmjs.org/inherits/-/inherits-2.0.1.tgz", + "readme": "ERROR: No README data found!", + "homepage": "https://github.com/isaacs/inherits#readme" +} diff --git a/node_modules/express/node_modules/send/node_modules/http-errors/node_modules/inherits/test.js b/node_modules/express/node_modules/send/node_modules/http-errors/node_modules/inherits/test.js new file mode 100644 index 0000000..fc53012 --- /dev/null +++ b/node_modules/express/node_modules/send/node_modules/http-errors/node_modules/inherits/test.js @@ -0,0 +1,25 @@ +var inherits = require('./inherits.js') +var assert = require('assert') + +function test(c) { + assert(c.constructor === Child) + assert(c.constructor.super_ === Parent) + assert(Object.getPrototypeOf(c) === Child.prototype) + assert(Object.getPrototypeOf(Object.getPrototypeOf(c)) === Parent.prototype) + assert(c instanceof Child) + assert(c instanceof Parent) +} + +function Child() { + Parent.call(this) + test(this) +} + +function Parent() {} + +inherits(Child, Parent) + +var c = new Child +test(c) + +console.log('ok') diff --git a/node_modules/express/node_modules/send/node_modules/http-errors/node_modules/setprototypeof/LICENSE b/node_modules/express/node_modules/send/node_modules/http-errors/node_modules/setprototypeof/LICENSE new file mode 100644 index 0000000..61afa2f --- /dev/null +++ b/node_modules/express/node_modules/send/node_modules/http-errors/node_modules/setprototypeof/LICENSE @@ -0,0 +1,13 @@ +Copyright (c) 2015, Wes Todd + +Permission to use, copy, modify, and/or distribute this software for any +purpose with or without fee is hereby granted, provided that the above +copyright notice and this permission notice appear in all copies. + +THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES +WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF +MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY +SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES +WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION +OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN +CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. diff --git a/node_modules/express/node_modules/send/node_modules/http-errors/node_modules/setprototypeof/README.md b/node_modules/express/node_modules/send/node_modules/http-errors/node_modules/setprototypeof/README.md new file mode 100644 index 0000000..01d7947 --- /dev/null +++ b/node_modules/express/node_modules/send/node_modules/http-errors/node_modules/setprototypeof/README.md @@ -0,0 +1,21 @@ +# Polyfill for `Object.setPrototypeOf` + +A simple cross platform implementation to set the prototype of an instianted object. Supports all modern browsers and at least back to IE8. + +## Usage: + +``` +$ npm install --save setprototypeof +``` + +```javascript +var setPrototypeOf = require('setprototypeof'); + +var obj = {}; +setPrototypeOf(obj, { + foo: function() { + return 'bar'; + } +}); +obj.foo(); // bar +``` diff --git a/node_modules/express/node_modules/send/node_modules/http-errors/node_modules/setprototypeof/index.js b/node_modules/express/node_modules/send/node_modules/http-errors/node_modules/setprototypeof/index.js new file mode 100644 index 0000000..086a879 --- /dev/null +++ b/node_modules/express/node_modules/send/node_modules/http-errors/node_modules/setprototypeof/index.js @@ -0,0 +1,11 @@ +module.exports = Object.setPrototypeOf || ({__proto__:[]} instanceof Array ? setProtoOf : mixinProperties); + +function setProtoOf(obj, proto) { + obj.__proto__ = proto; +} + +function mixinProperties(obj, proto) { + for (var prop in proto) { + obj[prop] = proto[prop]; + } +} diff --git a/node_modules/express/node_modules/send/node_modules/http-errors/node_modules/setprototypeof/package.json b/node_modules/express/node_modules/send/node_modules/http-errors/node_modules/setprototypeof/package.json new file mode 100644 index 0000000..62b8a11 --- /dev/null +++ b/node_modules/express/node_modules/send/node_modules/http-errors/node_modules/setprototypeof/package.json @@ -0,0 +1,53 @@ +{ + "name": "setprototypeof", + "version": "1.0.1", + "description": "A small polyfill for Object.setprototypeof", + "main": "index.js", + "scripts": { + "test": "echo \"Error: no test specified\" && exit 1" + }, + "repository": { + "type": "git", + "url": "git+https://github.com/wesleytodd/setprototypeof.git" + }, + "keywords": [ + "polyfill", + "object", + "setprototypeof" + ], + "author": { + "name": "Wes Todd" + }, + "license": "ISC", + "bugs": { + "url": "https://github.com/wesleytodd/setprototypeof/issues" + }, + "homepage": "https://github.com/wesleytodd/setprototypeof", + "gitHead": "1e3d0cde6b7f4a9fba10cd28e62b200c9d8f899f", + "_id": "setprototypeof@1.0.1", + "_shasum": "52009b27888c4dc48f591949c0a8275834c1ca7e", + "_from": "setprototypeof@1.0.1", + "_npmVersion": "3.3.6", + "_nodeVersion": "5.0.0", + "_npmUser": { + "name": "wesleytodd", + "email": "wes@wesleytodd.com" + }, + "dist": { + "shasum": "52009b27888c4dc48f591949c0a8275834c1ca7e", + "tarball": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.0.1.tgz" + }, + "maintainers": [ + { + "name": "wesleytodd", + "email": "wes@wesleytodd.com" + } + ], + "_npmOperationalInternal": { + "host": "packages-5-east.internal.npmjs.com", + "tmp": "tmp/setprototypeof-1.0.1.tgz_1454803015119_0.7522649802267551" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/setprototypeof/-/setprototypeof-1.0.1.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/express/node_modules/send/node_modules/http-errors/package.json b/node_modules/express/node_modules/send/node_modules/http-errors/package.json new file mode 100644 index 0000000..4bbc546 --- /dev/null +++ b/node_modules/express/node_modules/send/node_modules/http-errors/package.json @@ -0,0 +1,96 @@ +{ + "name": "http-errors", + "description": "Create HTTP error objects", + "version": "1.5.0", + "author": { + "name": "Jonathan Ong", + "email": "me@jongleberry.com", + "url": "http://jongleberry.com" + }, + "contributors": [ + { + "name": "Alan Plum", + "email": "me@pluma.io" + }, + { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + } + ], + "license": "MIT", + "repository": { + "type": "git", + "url": "git+https://github.com/jshttp/http-errors.git" + }, + "dependencies": { + "inherits": "2.0.1", + "setprototypeof": "1.0.1", + "statuses": ">= 1.3.0 < 2" + }, + "devDependencies": { + "eslint": "2.10.2", + "eslint-config-standard": "5.3.1", + "eslint-plugin-promise": "1.1.0", + "eslint-plugin-standard": "1.3.2", + "istanbul": "0.4.3", + "mocha": "1.21.5" + }, + "engines": { + "node": ">= 0.6" + }, + "scripts": { + "lint": "eslint **/*.js", + "test": "mocha --reporter spec --bail", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot", + "test-travis": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter dot" + }, + "keywords": [ + "http", + "error" + ], + "files": [ + "index.js", + "HISTORY.md", + "LICENSE", + "README.md" + ], + "gitHead": "1a826d7ac31dde16931b9c566041697939ebd0e0", + "bugs": { + "url": "https://github.com/jshttp/http-errors/issues" + }, + "homepage": "https://github.com/jshttp/http-errors#readme", + "_id": "http-errors@1.5.0", + "_shasum": "b1cb3d8260fd8e2386cad3189045943372d48211", + "_from": "http-errors@>=1.5.0 <1.6.0", + "_npmVersion": "2.15.1", + "_nodeVersion": "4.4.3", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "dist": { + "shasum": "b1cb3d8260fd8e2386cad3189045943372d48211", + "tarball": "https://registry.npmjs.org/http-errors/-/http-errors-1.5.0.tgz" + }, + "maintainers": [ + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "egeste", + "email": "npm@egeste.net" + }, + { + "name": "jongleberry", + "email": "jonathanrichardong@gmail.com" + } + ], + "_npmOperationalInternal": { + "host": "packages-16-east.internal.npmjs.com", + "tmp": "tmp/http-errors-1.5.0.tgz_1463621678183_0.44013352948240936" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/http-errors/-/http-errors-1.5.0.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/express/node_modules/send/node_modules/mime/.npmignore b/node_modules/express/node_modules/send/node_modules/mime/.npmignore new file mode 100644 index 0000000..e69de29 diff --git a/node_modules/express/node_modules/send/node_modules/mime/LICENSE b/node_modules/express/node_modules/send/node_modules/mime/LICENSE new file mode 100644 index 0000000..451fc45 --- /dev/null +++ b/node_modules/express/node_modules/send/node_modules/mime/LICENSE @@ -0,0 +1,19 @@ +Copyright (c) 2010 Benjamin Thomas, Robert Kieffer + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. diff --git a/node_modules/express/node_modules/send/node_modules/mime/README.md b/node_modules/express/node_modules/send/node_modules/mime/README.md new file mode 100644 index 0000000..506fbe5 --- /dev/null +++ b/node_modules/express/node_modules/send/node_modules/mime/README.md @@ -0,0 +1,90 @@ +# mime + +Comprehensive MIME type mapping API based on mime-db module. + +## Install + +Install with [npm](http://github.com/isaacs/npm): + + npm install mime + +## Contributing / Testing + + npm run test + +## Command Line + + mime [path_string] + +E.g. + + > mime scripts/jquery.js + application/javascript + +## API - Queries + +### mime.lookup(path) +Get the mime type associated with a file, if no mime type is found `application/octet-stream` is returned. Performs a case-insensitive lookup using the extension in `path` (the substring after the last '/' or '.'). E.g. + +```js +var mime = require('mime'); + +mime.lookup('/path/to/file.txt'); // => 'text/plain' +mime.lookup('file.txt'); // => 'text/plain' +mime.lookup('.TXT'); // => 'text/plain' +mime.lookup('htm'); // => 'text/html' +``` + +### mime.default_type +Sets the mime type returned when `mime.lookup` fails to find the extension searched for. (Default is `application/octet-stream`.) + +### mime.extension(type) +Get the default extension for `type` + +```js +mime.extension('text/html'); // => 'html' +mime.extension('application/octet-stream'); // => 'bin' +``` + +### mime.charsets.lookup() + +Map mime-type to charset + +```js +mime.charsets.lookup('text/plain'); // => 'UTF-8' +``` + +(The logic for charset lookups is pretty rudimentary. Feel free to suggest improvements.) + +## API - Defining Custom Types + +Custom type mappings can be added on a per-project basis via the following APIs. + +### mime.define() + +Add custom mime/extension mappings + +```js +mime.define({ + 'text/x-some-format': ['x-sf', 'x-sft', 'x-sfml'], + 'application/x-my-type': ['x-mt', 'x-mtt'], + // etc ... +}); + +mime.lookup('x-sft'); // => 'text/x-some-format' +``` + +The first entry in the extensions array is returned by `mime.extension()`. E.g. + +```js +mime.extension('text/x-some-format'); // => 'x-sf' +``` + +### mime.load(filepath) + +Load mappings from an Apache ".types" format file + +```js +mime.load('./my_project.types'); +``` +The .types file format is simple - See the `types` dir for examples. diff --git a/node_modules/express/node_modules/send/node_modules/mime/build/build.js b/node_modules/express/node_modules/send/node_modules/mime/build/build.js new file mode 100644 index 0000000..ed5313e --- /dev/null +++ b/node_modules/express/node_modules/send/node_modules/mime/build/build.js @@ -0,0 +1,11 @@ +var db = require('mime-db'); + +var mapByType = {}; +Object.keys(db).forEach(function(key) { + var extensions = db[key].extensions; + if (extensions) { + mapByType[key] = extensions; + } +}); + +console.log(JSON.stringify(mapByType)); diff --git a/node_modules/express/node_modules/send/node_modules/mime/build/test.js b/node_modules/express/node_modules/send/node_modules/mime/build/test.js new file mode 100644 index 0000000..58b9ba7 --- /dev/null +++ b/node_modules/express/node_modules/send/node_modules/mime/build/test.js @@ -0,0 +1,57 @@ +/** + * Usage: node test.js + */ + +var mime = require('../mime'); +var assert = require('assert'); +var path = require('path'); + +// +// Test mime lookups +// + +assert.equal('text/plain', mime.lookup('text.txt')); // normal file +assert.equal('text/plain', mime.lookup('TEXT.TXT')); // uppercase +assert.equal('text/plain', mime.lookup('dir/text.txt')); // dir + file +assert.equal('text/plain', mime.lookup('.text.txt')); // hidden file +assert.equal('text/plain', mime.lookup('.txt')); // nameless +assert.equal('text/plain', mime.lookup('txt')); // extension-only +assert.equal('text/plain', mime.lookup('/txt')); // extension-less () +assert.equal('text/plain', mime.lookup('\\txt')); // Windows, extension-less +assert.equal('application/octet-stream', mime.lookup('text.nope')); // unrecognized +assert.equal('fallback', mime.lookup('text.fallback', 'fallback')); // alternate default + +// +// Test extensions +// + +assert.equal('txt', mime.extension(mime.types.text)); +assert.equal('html', mime.extension(mime.types.htm)); +assert.equal('bin', mime.extension('application/octet-stream')); +assert.equal('bin', mime.extension('application/octet-stream ')); +assert.equal('html', mime.extension(' text/html; charset=UTF-8')); +assert.equal('html', mime.extension('text/html; charset=UTF-8 ')); +assert.equal('html', mime.extension('text/html; charset=UTF-8')); +assert.equal('html', mime.extension('text/html ; charset=UTF-8')); +assert.equal('html', mime.extension('text/html;charset=UTF-8')); +assert.equal('html', mime.extension('text/Html;charset=UTF-8')); +assert.equal(undefined, mime.extension('unrecognized')); + +// +// Test node.types lookups +// + +assert.equal('application/font-woff', mime.lookup('file.woff')); +assert.equal('application/octet-stream', mime.lookup('file.buffer')); +assert.equal('audio/mp4', mime.lookup('file.m4a')); +assert.equal('font/opentype', mime.lookup('file.otf')); + +// +// Test charsets +// + +assert.equal('UTF-8', mime.charsets.lookup('text/plain')); +assert.equal(undefined, mime.charsets.lookup(mime.types.js)); +assert.equal('fallback', mime.charsets.lookup('application/octet-stream', 'fallback')); + +console.log('\nAll tests passed'); diff --git a/node_modules/express/node_modules/send/node_modules/mime/cli.js b/node_modules/express/node_modules/send/node_modules/mime/cli.js new file mode 100644 index 0000000..20b1ffe --- /dev/null +++ b/node_modules/express/node_modules/send/node_modules/mime/cli.js @@ -0,0 +1,8 @@ +#!/usr/bin/env node + +var mime = require('./mime.js'); +var file = process.argv[2]; +var type = mime.lookup(file); + +process.stdout.write(type + '\n'); + diff --git a/node_modules/express/node_modules/send/node_modules/mime/mime.js b/node_modules/express/node_modules/send/node_modules/mime/mime.js new file mode 100644 index 0000000..341b6a5 --- /dev/null +++ b/node_modules/express/node_modules/send/node_modules/mime/mime.js @@ -0,0 +1,108 @@ +var path = require('path'); +var fs = require('fs'); + +function Mime() { + // Map of extension -> mime type + this.types = Object.create(null); + + // Map of mime type -> extension + this.extensions = Object.create(null); +} + +/** + * Define mimetype -> extension mappings. Each key is a mime-type that maps + * to an array of extensions associated with the type. The first extension is + * used as the default extension for the type. + * + * e.g. mime.define({'audio/ogg', ['oga', 'ogg', 'spx']}); + * + * @param map (Object) type definitions + */ +Mime.prototype.define = function (map) { + for (var type in map) { + var exts = map[type]; + for (var i = 0; i < exts.length; i++) { + if (process.env.DEBUG_MIME && this.types[exts]) { + console.warn(this._loading.replace(/.*\//, ''), 'changes "' + exts[i] + '" extension type from ' + + this.types[exts] + ' to ' + type); + } + + this.types[exts[i]] = type; + } + + // Default extension is the first one we encounter + if (!this.extensions[type]) { + this.extensions[type] = exts[0]; + } + } +}; + +/** + * Load an Apache2-style ".types" file + * + * This may be called multiple times (it's expected). Where files declare + * overlapping types/extensions, the last file wins. + * + * @param file (String) path of file to load. + */ +Mime.prototype.load = function(file) { + this._loading = file; + // Read file and split into lines + var map = {}, + content = fs.readFileSync(file, 'ascii'), + lines = content.split(/[\r\n]+/); + + lines.forEach(function(line) { + // Clean up whitespace/comments, and split into fields + var fields = line.replace(/\s*#.*|^\s*|\s*$/g, '').split(/\s+/); + map[fields.shift()] = fields; + }); + + this.define(map); + + this._loading = null; +}; + +/** + * Lookup a mime type based on extension + */ +Mime.prototype.lookup = function(path, fallback) { + var ext = path.replace(/.*[\.\/\\]/, '').toLowerCase(); + + return this.types[ext] || fallback || this.default_type; +}; + +/** + * Return file extension associated with a mime type + */ +Mime.prototype.extension = function(mimeType) { + var type = mimeType.match(/^\s*([^;\s]*)(?:;|\s|$)/)[1].toLowerCase(); + return this.extensions[type]; +}; + +// Default instance +var mime = new Mime(); + +// Define built-in types +mime.define(require('./types.json')); + +// Default type +mime.default_type = mime.lookup('bin'); + +// +// Additional API specific to the default instance +// + +mime.Mime = Mime; + +/** + * Lookup a charset based on mime type. + */ +mime.charsets = { + lookup: function(mimeType, fallback) { + // Assume text types are utf8 + return (/^text\//).test(mimeType) ? 'UTF-8' : fallback; + } +}; + +module.exports = mime; diff --git a/node_modules/express/node_modules/send/node_modules/mime/package.json b/node_modules/express/node_modules/send/node_modules/mime/package.json new file mode 100644 index 0000000..204d2ea --- /dev/null +++ b/node_modules/express/node_modules/send/node_modules/mime/package.json @@ -0,0 +1,73 @@ +{ + "author": { + "name": "Robert Kieffer", + "email": "robert@broofa.com", + "url": "http://github.com/broofa" + }, + "scripts": { + "prepublish": "node build/build.js > types.json", + "test": "node build/test.js" + }, + "bin": { + "mime": "cli.js" + }, + "contributors": [ + { + "name": "Benjamin Thomas", + "email": "benjamin@benjaminthomas.org", + "url": "http://github.com/bentomas" + } + ], + "description": "A comprehensive library for mime-type mapping", + "licenses": [ + { + "type": "MIT", + "url": "https://raw.github.com/broofa/node-mime/master/LICENSE" + } + ], + "dependencies": {}, + "devDependencies": { + "mime-db": "^1.2.0" + }, + "keywords": [ + "util", + "mime" + ], + "main": "mime.js", + "name": "mime", + "repository": { + "url": "git+https://github.com/broofa/node-mime.git", + "type": "git" + }, + "version": "1.3.4", + "gitHead": "1628f6e0187095009dcef4805c3a49706f137974", + "bugs": { + "url": "https://github.com/broofa/node-mime/issues" + }, + "homepage": "https://github.com/broofa/node-mime", + "_id": "mime@1.3.4", + "_shasum": "115f9e3b6b3daf2959983cb38f149a2d40eb5d53", + "_from": "mime@1.3.4", + "_npmVersion": "1.4.28", + "_npmUser": { + "name": "broofa", + "email": "robert@broofa.com" + }, + "maintainers": [ + { + "name": "broofa", + "email": "robert@broofa.com" + }, + { + "name": "bentomas", + "email": "benjamin@benjaminthomas.org" + } + ], + "dist": { + "shasum": "115f9e3b6b3daf2959983cb38f149a2d40eb5d53", + "tarball": "https://registry.npmjs.org/mime/-/mime-1.3.4.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/mime/-/mime-1.3.4.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/express/node_modules/send/node_modules/mime/types.json b/node_modules/express/node_modules/send/node_modules/mime/types.json new file mode 100644 index 0000000..c674b1c --- /dev/null +++ b/node_modules/express/node_modules/send/node_modules/mime/types.json @@ -0,0 +1 @@ +{"application/andrew-inset":["ez"],"application/applixware":["aw"],"application/atom+xml":["atom"],"application/atomcat+xml":["atomcat"],"application/atomsvc+xml":["atomsvc"],"application/ccxml+xml":["ccxml"],"application/cdmi-capability":["cdmia"],"application/cdmi-container":["cdmic"],"application/cdmi-domain":["cdmid"],"application/cdmi-object":["cdmio"],"application/cdmi-queue":["cdmiq"],"application/cu-seeme":["cu"],"application/dash+xml":["mdp"],"application/davmount+xml":["davmount"],"application/docbook+xml":["dbk"],"application/dssc+der":["dssc"],"application/dssc+xml":["xdssc"],"application/ecmascript":["ecma"],"application/emma+xml":["emma"],"application/epub+zip":["epub"],"application/exi":["exi"],"application/font-tdpfr":["pfr"],"application/font-woff":["woff"],"application/font-woff2":["woff2"],"application/gml+xml":["gml"],"application/gpx+xml":["gpx"],"application/gxf":["gxf"],"application/hyperstudio":["stk"],"application/inkml+xml":["ink","inkml"],"application/ipfix":["ipfix"],"application/java-archive":["jar"],"application/java-serialized-object":["ser"],"application/java-vm":["class"],"application/javascript":["js"],"application/json":["json","map"],"application/json5":["json5"],"application/jsonml+json":["jsonml"],"application/lost+xml":["lostxml"],"application/mac-binhex40":["hqx"],"application/mac-compactpro":["cpt"],"application/mads+xml":["mads"],"application/marc":["mrc"],"application/marcxml+xml":["mrcx"],"application/mathematica":["ma","nb","mb"],"application/mathml+xml":["mathml"],"application/mbox":["mbox"],"application/mediaservercontrol+xml":["mscml"],"application/metalink+xml":["metalink"],"application/metalink4+xml":["meta4"],"application/mets+xml":["mets"],"application/mods+xml":["mods"],"application/mp21":["m21","mp21"],"application/mp4":["mp4s","m4p"],"application/msword":["doc","dot"],"application/mxf":["mxf"],"application/octet-stream":["bin","dms","lrf","mar","so","dist","distz","pkg","bpk","dump","elc","deploy","buffer"],"application/oda":["oda"],"application/oebps-package+xml":["opf"],"application/ogg":["ogx"],"application/omdoc+xml":["omdoc"],"application/onenote":["onetoc","onetoc2","onetmp","onepkg"],"application/oxps":["oxps"],"application/patch-ops-error+xml":["xer"],"application/pdf":["pdf"],"application/pgp-encrypted":["pgp"],"application/pgp-signature":["asc","sig"],"application/pics-rules":["prf"],"application/pkcs10":["p10"],"application/pkcs7-mime":["p7m","p7c"],"application/pkcs7-signature":["p7s"],"application/pkcs8":["p8"],"application/pkix-attr-cert":["ac"],"application/pkix-cert":["cer"],"application/pkix-crl":["crl"],"application/pkix-pkipath":["pkipath"],"application/pkixcmp":["pki"],"application/pls+xml":["pls"],"application/postscript":["ai","eps","ps"],"application/prs.cww":["cww"],"application/pskc+xml":["pskcxml"],"application/rdf+xml":["rdf"],"application/reginfo+xml":["rif"],"application/relax-ng-compact-syntax":["rnc"],"application/resource-lists+xml":["rl"],"application/resource-lists-diff+xml":["rld"],"application/rls-services+xml":["rs"],"application/rpki-ghostbusters":["gbr"],"application/rpki-manifest":["mft"],"application/rpki-roa":["roa"],"application/rsd+xml":["rsd"],"application/rss+xml":["rss"],"application/rtf":["rtf"],"application/sbml+xml":["sbml"],"application/scvp-cv-request":["scq"],"application/scvp-cv-response":["scs"],"application/scvp-vp-request":["spq"],"application/scvp-vp-response":["spp"],"application/sdp":["sdp"],"application/set-payment-initiation":["setpay"],"application/set-registration-initiation":["setreg"],"application/shf+xml":["shf"],"application/smil+xml":["smi","smil"],"application/sparql-query":["rq"],"application/sparql-results+xml":["srx"],"application/srgs":["gram"],"application/srgs+xml":["grxml"],"application/sru+xml":["sru"],"application/ssdl+xml":["ssdl"],"application/ssml+xml":["ssml"],"application/tei+xml":["tei","teicorpus"],"application/thraud+xml":["tfi"],"application/timestamped-data":["tsd"],"application/vnd.3gpp.pic-bw-large":["plb"],"application/vnd.3gpp.pic-bw-small":["psb"],"application/vnd.3gpp.pic-bw-var":["pvb"],"application/vnd.3gpp2.tcap":["tcap"],"application/vnd.3m.post-it-notes":["pwn"],"application/vnd.accpac.simply.aso":["aso"],"application/vnd.accpac.simply.imp":["imp"],"application/vnd.acucobol":["acu"],"application/vnd.acucorp":["atc","acutc"],"application/vnd.adobe.air-application-installer-package+zip":["air"],"application/vnd.adobe.formscentral.fcdt":["fcdt"],"application/vnd.adobe.fxp":["fxp","fxpl"],"application/vnd.adobe.xdp+xml":["xdp"],"application/vnd.adobe.xfdf":["xfdf"],"application/vnd.ahead.space":["ahead"],"application/vnd.airzip.filesecure.azf":["azf"],"application/vnd.airzip.filesecure.azs":["azs"],"application/vnd.amazon.ebook":["azw"],"application/vnd.americandynamics.acc":["acc"],"application/vnd.amiga.ami":["ami"],"application/vnd.android.package-archive":["apk"],"application/vnd.anser-web-certificate-issue-initiation":["cii"],"application/vnd.anser-web-funds-transfer-initiation":["fti"],"application/vnd.antix.game-component":["atx"],"application/vnd.apple.installer+xml":["mpkg"],"application/vnd.apple.mpegurl":["m3u8"],"application/vnd.aristanetworks.swi":["swi"],"application/vnd.astraea-software.iota":["iota"],"application/vnd.audiograph":["aep"],"application/vnd.blueice.multipass":["mpm"],"application/vnd.bmi":["bmi"],"application/vnd.businessobjects":["rep"],"application/vnd.chemdraw+xml":["cdxml"],"application/vnd.chipnuts.karaoke-mmd":["mmd"],"application/vnd.cinderella":["cdy"],"application/vnd.claymore":["cla"],"application/vnd.cloanto.rp9":["rp9"],"application/vnd.clonk.c4group":["c4g","c4d","c4f","c4p","c4u"],"application/vnd.cluetrust.cartomobile-config":["c11amc"],"application/vnd.cluetrust.cartomobile-config-pkg":["c11amz"],"application/vnd.commonspace":["csp"],"application/vnd.contact.cmsg":["cdbcmsg"],"application/vnd.cosmocaller":["cmc"],"application/vnd.crick.clicker":["clkx"],"application/vnd.crick.clicker.keyboard":["clkk"],"application/vnd.crick.clicker.palette":["clkp"],"application/vnd.crick.clicker.template":["clkt"],"application/vnd.crick.clicker.wordbank":["clkw"],"application/vnd.criticaltools.wbs+xml":["wbs"],"application/vnd.ctc-posml":["pml"],"application/vnd.cups-ppd":["ppd"],"application/vnd.curl.car":["car"],"application/vnd.curl.pcurl":["pcurl"],"application/vnd.dart":["dart"],"application/vnd.data-vision.rdz":["rdz"],"application/vnd.dece.data":["uvf","uvvf","uvd","uvvd"],"application/vnd.dece.ttml+xml":["uvt","uvvt"],"application/vnd.dece.unspecified":["uvx","uvvx"],"application/vnd.dece.zip":["uvz","uvvz"],"application/vnd.denovo.fcselayout-link":["fe_launch"],"application/vnd.dna":["dna"],"application/vnd.dolby.mlp":["mlp"],"application/vnd.dpgraph":["dpg"],"application/vnd.dreamfactory":["dfac"],"application/vnd.ds-keypoint":["kpxx"],"application/vnd.dvb.ait":["ait"],"application/vnd.dvb.service":["svc"],"application/vnd.dynageo":["geo"],"application/vnd.ecowin.chart":["mag"],"application/vnd.enliven":["nml"],"application/vnd.epson.esf":["esf"],"application/vnd.epson.msf":["msf"],"application/vnd.epson.quickanime":["qam"],"application/vnd.epson.salt":["slt"],"application/vnd.epson.ssf":["ssf"],"application/vnd.eszigno3+xml":["es3","et3"],"application/vnd.ezpix-album":["ez2"],"application/vnd.ezpix-package":["ez3"],"application/vnd.fdf":["fdf"],"application/vnd.fdsn.mseed":["mseed"],"application/vnd.fdsn.seed":["seed","dataless"],"application/vnd.flographit":["gph"],"application/vnd.fluxtime.clip":["ftc"],"application/vnd.framemaker":["fm","frame","maker","book"],"application/vnd.frogans.fnc":["fnc"],"application/vnd.frogans.ltf":["ltf"],"application/vnd.fsc.weblaunch":["fsc"],"application/vnd.fujitsu.oasys":["oas"],"application/vnd.fujitsu.oasys2":["oa2"],"application/vnd.fujitsu.oasys3":["oa3"],"application/vnd.fujitsu.oasysgp":["fg5"],"application/vnd.fujitsu.oasysprs":["bh2"],"application/vnd.fujixerox.ddd":["ddd"],"application/vnd.fujixerox.docuworks":["xdw"],"application/vnd.fujixerox.docuworks.binder":["xbd"],"application/vnd.fuzzysheet":["fzs"],"application/vnd.genomatix.tuxedo":["txd"],"application/vnd.geogebra.file":["ggb"],"application/vnd.geogebra.tool":["ggt"],"application/vnd.geometry-explorer":["gex","gre"],"application/vnd.geonext":["gxt"],"application/vnd.geoplan":["g2w"],"application/vnd.geospace":["g3w"],"application/vnd.gmx":["gmx"],"application/vnd.google-earth.kml+xml":["kml"],"application/vnd.google-earth.kmz":["kmz"],"application/vnd.grafeq":["gqf","gqs"],"application/vnd.groove-account":["gac"],"application/vnd.groove-help":["ghf"],"application/vnd.groove-identity-message":["gim"],"application/vnd.groove-injector":["grv"],"application/vnd.groove-tool-message":["gtm"],"application/vnd.groove-tool-template":["tpl"],"application/vnd.groove-vcard":["vcg"],"application/vnd.hal+xml":["hal"],"application/vnd.handheld-entertainment+xml":["zmm"],"application/vnd.hbci":["hbci"],"application/vnd.hhe.lesson-player":["les"],"application/vnd.hp-hpgl":["hpgl"],"application/vnd.hp-hpid":["hpid"],"application/vnd.hp-hps":["hps"],"application/vnd.hp-jlyt":["jlt"],"application/vnd.hp-pcl":["pcl"],"application/vnd.hp-pclxl":["pclxl"],"application/vnd.ibm.minipay":["mpy"],"application/vnd.ibm.modcap":["afp","listafp","list3820"],"application/vnd.ibm.rights-management":["irm"],"application/vnd.ibm.secure-container":["sc"],"application/vnd.iccprofile":["icc","icm"],"application/vnd.igloader":["igl"],"application/vnd.immervision-ivp":["ivp"],"application/vnd.immervision-ivu":["ivu"],"application/vnd.insors.igm":["igm"],"application/vnd.intercon.formnet":["xpw","xpx"],"application/vnd.intergeo":["i2g"],"application/vnd.intu.qbo":["qbo"],"application/vnd.intu.qfx":["qfx"],"application/vnd.ipunplugged.rcprofile":["rcprofile"],"application/vnd.irepository.package+xml":["irp"],"application/vnd.is-xpr":["xpr"],"application/vnd.isac.fcs":["fcs"],"application/vnd.jam":["jam"],"application/vnd.jcp.javame.midlet-rms":["rms"],"application/vnd.jisp":["jisp"],"application/vnd.joost.joda-archive":["joda"],"application/vnd.kahootz":["ktz","ktr"],"application/vnd.kde.karbon":["karbon"],"application/vnd.kde.kchart":["chrt"],"application/vnd.kde.kformula":["kfo"],"application/vnd.kde.kivio":["flw"],"application/vnd.kde.kontour":["kon"],"application/vnd.kde.kpresenter":["kpr","kpt"],"application/vnd.kde.kspread":["ksp"],"application/vnd.kde.kword":["kwd","kwt"],"application/vnd.kenameaapp":["htke"],"application/vnd.kidspiration":["kia"],"application/vnd.kinar":["kne","knp"],"application/vnd.koan":["skp","skd","skt","skm"],"application/vnd.kodak-descriptor":["sse"],"application/vnd.las.las+xml":["lasxml"],"application/vnd.llamagraphics.life-balance.desktop":["lbd"],"application/vnd.llamagraphics.life-balance.exchange+xml":["lbe"],"application/vnd.lotus-1-2-3":["123"],"application/vnd.lotus-approach":["apr"],"application/vnd.lotus-freelance":["pre"],"application/vnd.lotus-notes":["nsf"],"application/vnd.lotus-organizer":["org"],"application/vnd.lotus-screencam":["scm"],"application/vnd.lotus-wordpro":["lwp"],"application/vnd.macports.portpkg":["portpkg"],"application/vnd.mcd":["mcd"],"application/vnd.medcalcdata":["mc1"],"application/vnd.mediastation.cdkey":["cdkey"],"application/vnd.mfer":["mwf"],"application/vnd.mfmp":["mfm"],"application/vnd.micrografx.flo":["flo"],"application/vnd.micrografx.igx":["igx"],"application/vnd.mif":["mif"],"application/vnd.mobius.daf":["daf"],"application/vnd.mobius.dis":["dis"],"application/vnd.mobius.mbk":["mbk"],"application/vnd.mobius.mqy":["mqy"],"application/vnd.mobius.msl":["msl"],"application/vnd.mobius.plc":["plc"],"application/vnd.mobius.txf":["txf"],"application/vnd.mophun.application":["mpn"],"application/vnd.mophun.certificate":["mpc"],"application/vnd.mozilla.xul+xml":["xul"],"application/vnd.ms-artgalry":["cil"],"application/vnd.ms-cab-compressed":["cab"],"application/vnd.ms-excel":["xls","xlm","xla","xlc","xlt","xlw"],"application/vnd.ms-excel.addin.macroenabled.12":["xlam"],"application/vnd.ms-excel.sheet.binary.macroenabled.12":["xlsb"],"application/vnd.ms-excel.sheet.macroenabled.12":["xlsm"],"application/vnd.ms-excel.template.macroenabled.12":["xltm"],"application/vnd.ms-fontobject":["eot"],"application/vnd.ms-htmlhelp":["chm"],"application/vnd.ms-ims":["ims"],"application/vnd.ms-lrm":["lrm"],"application/vnd.ms-officetheme":["thmx"],"application/vnd.ms-pki.seccat":["cat"],"application/vnd.ms-pki.stl":["stl"],"application/vnd.ms-powerpoint":["ppt","pps","pot"],"application/vnd.ms-powerpoint.addin.macroenabled.12":["ppam"],"application/vnd.ms-powerpoint.presentation.macroenabled.12":["pptm"],"application/vnd.ms-powerpoint.slide.macroenabled.12":["sldm"],"application/vnd.ms-powerpoint.slideshow.macroenabled.12":["ppsm"],"application/vnd.ms-powerpoint.template.macroenabled.12":["potm"],"application/vnd.ms-project":["mpp","mpt"],"application/vnd.ms-word.document.macroenabled.12":["docm"],"application/vnd.ms-word.template.macroenabled.12":["dotm"],"application/vnd.ms-works":["wps","wks","wcm","wdb"],"application/vnd.ms-wpl":["wpl"],"application/vnd.ms-xpsdocument":["xps"],"application/vnd.mseq":["mseq"],"application/vnd.musician":["mus"],"application/vnd.muvee.style":["msty"],"application/vnd.mynfc":["taglet"],"application/vnd.neurolanguage.nlu":["nlu"],"application/vnd.nitf":["ntf","nitf"],"application/vnd.noblenet-directory":["nnd"],"application/vnd.noblenet-sealer":["nns"],"application/vnd.noblenet-web":["nnw"],"application/vnd.nokia.n-gage.data":["ngdat"],"application/vnd.nokia.radio-preset":["rpst"],"application/vnd.nokia.radio-presets":["rpss"],"application/vnd.novadigm.edm":["edm"],"application/vnd.novadigm.edx":["edx"],"application/vnd.novadigm.ext":["ext"],"application/vnd.oasis.opendocument.chart":["odc"],"application/vnd.oasis.opendocument.chart-template":["otc"],"application/vnd.oasis.opendocument.database":["odb"],"application/vnd.oasis.opendocument.formula":["odf"],"application/vnd.oasis.opendocument.formula-template":["odft"],"application/vnd.oasis.opendocument.graphics":["odg"],"application/vnd.oasis.opendocument.graphics-template":["otg"],"application/vnd.oasis.opendocument.image":["odi"],"application/vnd.oasis.opendocument.image-template":["oti"],"application/vnd.oasis.opendocument.presentation":["odp"],"application/vnd.oasis.opendocument.presentation-template":["otp"],"application/vnd.oasis.opendocument.spreadsheet":["ods"],"application/vnd.oasis.opendocument.spreadsheet-template":["ots"],"application/vnd.oasis.opendocument.text":["odt"],"application/vnd.oasis.opendocument.text-master":["odm"],"application/vnd.oasis.opendocument.text-template":["ott"],"application/vnd.oasis.opendocument.text-web":["oth"],"application/vnd.olpc-sugar":["xo"],"application/vnd.oma.dd2+xml":["dd2"],"application/vnd.openofficeorg.extension":["oxt"],"application/vnd.openxmlformats-officedocument.presentationml.presentation":["pptx"],"application/vnd.openxmlformats-officedocument.presentationml.slide":["sldx"],"application/vnd.openxmlformats-officedocument.presentationml.slideshow":["ppsx"],"application/vnd.openxmlformats-officedocument.presentationml.template":["potx"],"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet":["xlsx"],"application/vnd.openxmlformats-officedocument.spreadsheetml.template":["xltx"],"application/vnd.openxmlformats-officedocument.wordprocessingml.document":["docx"],"application/vnd.openxmlformats-officedocument.wordprocessingml.template":["dotx"],"application/vnd.osgeo.mapguide.package":["mgp"],"application/vnd.osgi.dp":["dp"],"application/vnd.osgi.subsystem":["esa"],"application/vnd.palm":["pdb","pqa","oprc"],"application/vnd.pawaafile":["paw"],"application/vnd.pg.format":["str"],"application/vnd.pg.osasli":["ei6"],"application/vnd.picsel":["efif"],"application/vnd.pmi.widget":["wg"],"application/vnd.pocketlearn":["plf"],"application/vnd.powerbuilder6":["pbd"],"application/vnd.previewsystems.box":["box"],"application/vnd.proteus.magazine":["mgz"],"application/vnd.publishare-delta-tree":["qps"],"application/vnd.pvi.ptid1":["ptid"],"application/vnd.quark.quarkxpress":["qxd","qxt","qwd","qwt","qxl","qxb"],"application/vnd.realvnc.bed":["bed"],"application/vnd.recordare.musicxml":["mxl"],"application/vnd.recordare.musicxml+xml":["musicxml"],"application/vnd.rig.cryptonote":["cryptonote"],"application/vnd.rim.cod":["cod"],"application/vnd.rn-realmedia":["rm"],"application/vnd.rn-realmedia-vbr":["rmvb"],"application/vnd.route66.link66+xml":["link66"],"application/vnd.sailingtracker.track":["st"],"application/vnd.seemail":["see"],"application/vnd.sema":["sema"],"application/vnd.semd":["semd"],"application/vnd.semf":["semf"],"application/vnd.shana.informed.formdata":["ifm"],"application/vnd.shana.informed.formtemplate":["itp"],"application/vnd.shana.informed.interchange":["iif"],"application/vnd.shana.informed.package":["ipk"],"application/vnd.simtech-mindmapper":["twd","twds"],"application/vnd.smaf":["mmf"],"application/vnd.smart.teacher":["teacher"],"application/vnd.solent.sdkm+xml":["sdkm","sdkd"],"application/vnd.spotfire.dxp":["dxp"],"application/vnd.spotfire.sfs":["sfs"],"application/vnd.stardivision.calc":["sdc"],"application/vnd.stardivision.draw":["sda"],"application/vnd.stardivision.impress":["sdd"],"application/vnd.stardivision.math":["smf"],"application/vnd.stardivision.writer":["sdw","vor"],"application/vnd.stardivision.writer-global":["sgl"],"application/vnd.stepmania.package":["smzip"],"application/vnd.stepmania.stepchart":["sm"],"application/vnd.sun.xml.calc":["sxc"],"application/vnd.sun.xml.calc.template":["stc"],"application/vnd.sun.xml.draw":["sxd"],"application/vnd.sun.xml.draw.template":["std"],"application/vnd.sun.xml.impress":["sxi"],"application/vnd.sun.xml.impress.template":["sti"],"application/vnd.sun.xml.math":["sxm"],"application/vnd.sun.xml.writer":["sxw"],"application/vnd.sun.xml.writer.global":["sxg"],"application/vnd.sun.xml.writer.template":["stw"],"application/vnd.sus-calendar":["sus","susp"],"application/vnd.svd":["svd"],"application/vnd.symbian.install":["sis","sisx"],"application/vnd.syncml+xml":["xsm"],"application/vnd.syncml.dm+wbxml":["bdm"],"application/vnd.syncml.dm+xml":["xdm"],"application/vnd.tao.intent-module-archive":["tao"],"application/vnd.tcpdump.pcap":["pcap","cap","dmp"],"application/vnd.tmobile-livetv":["tmo"],"application/vnd.trid.tpt":["tpt"],"application/vnd.triscape.mxs":["mxs"],"application/vnd.trueapp":["tra"],"application/vnd.ufdl":["ufd","ufdl"],"application/vnd.uiq.theme":["utz"],"application/vnd.umajin":["umj"],"application/vnd.unity":["unityweb"],"application/vnd.uoml+xml":["uoml"],"application/vnd.vcx":["vcx"],"application/vnd.visio":["vsd","vst","vss","vsw"],"application/vnd.visionary":["vis"],"application/vnd.vsf":["vsf"],"application/vnd.wap.wbxml":["wbxml"],"application/vnd.wap.wmlc":["wmlc"],"application/vnd.wap.wmlscriptc":["wmlsc"],"application/vnd.webturbo":["wtb"],"application/vnd.wolfram.player":["nbp"],"application/vnd.wordperfect":["wpd"],"application/vnd.wqd":["wqd"],"application/vnd.wt.stf":["stf"],"application/vnd.xara":["xar"],"application/vnd.xfdl":["xfdl"],"application/vnd.yamaha.hv-dic":["hvd"],"application/vnd.yamaha.hv-script":["hvs"],"application/vnd.yamaha.hv-voice":["hvp"],"application/vnd.yamaha.openscoreformat":["osf"],"application/vnd.yamaha.openscoreformat.osfpvg+xml":["osfpvg"],"application/vnd.yamaha.smaf-audio":["saf"],"application/vnd.yamaha.smaf-phrase":["spf"],"application/vnd.yellowriver-custom-menu":["cmp"],"application/vnd.zul":["zir","zirz"],"application/vnd.zzazz.deck+xml":["zaz"],"application/voicexml+xml":["vxml"],"application/widget":["wgt"],"application/winhlp":["hlp"],"application/wsdl+xml":["wsdl"],"application/wspolicy+xml":["wspolicy"],"application/x-7z-compressed":["7z"],"application/x-abiword":["abw"],"application/x-ace-compressed":["ace"],"application/x-apple-diskimage":["dmg"],"application/x-authorware-bin":["aab","x32","u32","vox"],"application/x-authorware-map":["aam"],"application/x-authorware-seg":["aas"],"application/x-bcpio":["bcpio"],"application/x-bittorrent":["torrent"],"application/x-blorb":["blb","blorb"],"application/x-bzip":["bz"],"application/x-bzip2":["bz2","boz"],"application/x-cbr":["cbr","cba","cbt","cbz","cb7"],"application/x-cdlink":["vcd"],"application/x-cfs-compressed":["cfs"],"application/x-chat":["chat"],"application/x-chess-pgn":["pgn"],"application/x-chrome-extension":["crx"],"application/x-conference":["nsc"],"application/x-cpio":["cpio"],"application/x-csh":["csh"],"application/x-debian-package":["deb","udeb"],"application/x-dgc-compressed":["dgc"],"application/x-director":["dir","dcr","dxr","cst","cct","cxt","w3d","fgd","swa"],"application/x-doom":["wad"],"application/x-dtbncx+xml":["ncx"],"application/x-dtbook+xml":["dtb"],"application/x-dtbresource+xml":["res"],"application/x-dvi":["dvi"],"application/x-envoy":["evy"],"application/x-eva":["eva"],"application/x-font-bdf":["bdf"],"application/x-font-ghostscript":["gsf"],"application/x-font-linux-psf":["psf"],"application/x-font-otf":["otf"],"application/x-font-pcf":["pcf"],"application/x-font-snf":["snf"],"application/x-font-ttf":["ttf","ttc"],"application/x-font-type1":["pfa","pfb","pfm","afm"],"application/x-freearc":["arc"],"application/x-futuresplash":["spl"],"application/x-gca-compressed":["gca"],"application/x-glulx":["ulx"],"application/x-gnumeric":["gnumeric"],"application/x-gramps-xml":["gramps"],"application/x-gtar":["gtar"],"application/x-hdf":["hdf"],"application/x-install-instructions":["install"],"application/x-iso9660-image":["iso"],"application/x-java-jnlp-file":["jnlp"],"application/x-latex":["latex"],"application/x-lua-bytecode":["luac"],"application/x-lzh-compressed":["lzh","lha"],"application/x-mie":["mie"],"application/x-mobipocket-ebook":["prc","mobi"],"application/x-ms-application":["application"],"application/x-ms-shortcut":["lnk"],"application/x-ms-wmd":["wmd"],"application/x-ms-wmz":["wmz"],"application/x-ms-xbap":["xbap"],"application/x-msaccess":["mdb"],"application/x-msbinder":["obd"],"application/x-mscardfile":["crd"],"application/x-msclip":["clp"],"application/x-msdownload":["exe","dll","com","bat","msi"],"application/x-msmediaview":["mvb","m13","m14"],"application/x-msmetafile":["wmf","wmz","emf","emz"],"application/x-msmoney":["mny"],"application/x-mspublisher":["pub"],"application/x-msschedule":["scd"],"application/x-msterminal":["trm"],"application/x-mswrite":["wri"],"application/x-netcdf":["nc","cdf"],"application/x-nzb":["nzb"],"application/x-pkcs12":["p12","pfx"],"application/x-pkcs7-certificates":["p7b","spc"],"application/x-pkcs7-certreqresp":["p7r"],"application/x-rar-compressed":["rar"],"application/x-research-info-systems":["ris"],"application/x-sh":["sh"],"application/x-shar":["shar"],"application/x-shockwave-flash":["swf"],"application/x-silverlight-app":["xap"],"application/x-sql":["sql"],"application/x-stuffit":["sit"],"application/x-stuffitx":["sitx"],"application/x-subrip":["srt"],"application/x-sv4cpio":["sv4cpio"],"application/x-sv4crc":["sv4crc"],"application/x-t3vm-image":["t3"],"application/x-tads":["gam"],"application/x-tar":["tar"],"application/x-tcl":["tcl"],"application/x-tex":["tex"],"application/x-tex-tfm":["tfm"],"application/x-texinfo":["texinfo","texi"],"application/x-tgif":["obj"],"application/x-ustar":["ustar"],"application/x-wais-source":["src"],"application/x-web-app-manifest+json":["webapp"],"application/x-x509-ca-cert":["der","crt"],"application/x-xfig":["fig"],"application/x-xliff+xml":["xlf"],"application/x-xpinstall":["xpi"],"application/x-xz":["xz"],"application/x-zmachine":["z1","z2","z3","z4","z5","z6","z7","z8"],"application/xaml+xml":["xaml"],"application/xcap-diff+xml":["xdf"],"application/xenc+xml":["xenc"],"application/xhtml+xml":["xhtml","xht"],"application/xml":["xml","xsl","xsd"],"application/xml-dtd":["dtd"],"application/xop+xml":["xop"],"application/xproc+xml":["xpl"],"application/xslt+xml":["xslt"],"application/xspf+xml":["xspf"],"application/xv+xml":["mxml","xhvml","xvml","xvm"],"application/yang":["yang"],"application/yin+xml":["yin"],"application/zip":["zip"],"audio/adpcm":["adp"],"audio/basic":["au","snd"],"audio/midi":["mid","midi","kar","rmi"],"audio/mp4":["mp4a","m4a"],"audio/mpeg":["mpga","mp2","mp2a","mp3","m2a","m3a"],"audio/ogg":["oga","ogg","spx"],"audio/s3m":["s3m"],"audio/silk":["sil"],"audio/vnd.dece.audio":["uva","uvva"],"audio/vnd.digital-winds":["eol"],"audio/vnd.dra":["dra"],"audio/vnd.dts":["dts"],"audio/vnd.dts.hd":["dtshd"],"audio/vnd.lucent.voice":["lvp"],"audio/vnd.ms-playready.media.pya":["pya"],"audio/vnd.nuera.ecelp4800":["ecelp4800"],"audio/vnd.nuera.ecelp7470":["ecelp7470"],"audio/vnd.nuera.ecelp9600":["ecelp9600"],"audio/vnd.rip":["rip"],"audio/webm":["weba"],"audio/x-aac":["aac"],"audio/x-aiff":["aif","aiff","aifc"],"audio/x-caf":["caf"],"audio/x-flac":["flac"],"audio/x-matroska":["mka"],"audio/x-mpegurl":["m3u"],"audio/x-ms-wax":["wax"],"audio/x-ms-wma":["wma"],"audio/x-pn-realaudio":["ram","ra"],"audio/x-pn-realaudio-plugin":["rmp"],"audio/x-wav":["wav"],"audio/xm":["xm"],"chemical/x-cdx":["cdx"],"chemical/x-cif":["cif"],"chemical/x-cmdf":["cmdf"],"chemical/x-cml":["cml"],"chemical/x-csml":["csml"],"chemical/x-xyz":["xyz"],"font/opentype":["otf"],"image/bmp":["bmp"],"image/cgm":["cgm"],"image/g3fax":["g3"],"image/gif":["gif"],"image/ief":["ief"],"image/jpeg":["jpeg","jpg","jpe"],"image/ktx":["ktx"],"image/png":["png"],"image/prs.btif":["btif"],"image/sgi":["sgi"],"image/svg+xml":["svg","svgz"],"image/tiff":["tiff","tif"],"image/vnd.adobe.photoshop":["psd"],"image/vnd.dece.graphic":["uvi","uvvi","uvg","uvvg"],"image/vnd.djvu":["djvu","djv"],"image/vnd.dvb.subtitle":["sub"],"image/vnd.dwg":["dwg"],"image/vnd.dxf":["dxf"],"image/vnd.fastbidsheet":["fbs"],"image/vnd.fpx":["fpx"],"image/vnd.fst":["fst"],"image/vnd.fujixerox.edmics-mmr":["mmr"],"image/vnd.fujixerox.edmics-rlc":["rlc"],"image/vnd.ms-modi":["mdi"],"image/vnd.ms-photo":["wdp"],"image/vnd.net-fpx":["npx"],"image/vnd.wap.wbmp":["wbmp"],"image/vnd.xiff":["xif"],"image/webp":["webp"],"image/x-3ds":["3ds"],"image/x-cmu-raster":["ras"],"image/x-cmx":["cmx"],"image/x-freehand":["fh","fhc","fh4","fh5","fh7"],"image/x-icon":["ico"],"image/x-mrsid-image":["sid"],"image/x-pcx":["pcx"],"image/x-pict":["pic","pct"],"image/x-portable-anymap":["pnm"],"image/x-portable-bitmap":["pbm"],"image/x-portable-graymap":["pgm"],"image/x-portable-pixmap":["ppm"],"image/x-rgb":["rgb"],"image/x-tga":["tga"],"image/x-xbitmap":["xbm"],"image/x-xpixmap":["xpm"],"image/x-xwindowdump":["xwd"],"message/rfc822":["eml","mime"],"model/iges":["igs","iges"],"model/mesh":["msh","mesh","silo"],"model/vnd.collada+xml":["dae"],"model/vnd.dwf":["dwf"],"model/vnd.gdl":["gdl"],"model/vnd.gtw":["gtw"],"model/vnd.mts":["mts"],"model/vnd.vtu":["vtu"],"model/vrml":["wrl","vrml"],"model/x3d+binary":["x3db","x3dbz"],"model/x3d+vrml":["x3dv","x3dvz"],"model/x3d+xml":["x3d","x3dz"],"text/cache-manifest":["appcache","manifest"],"text/calendar":["ics","ifb"],"text/coffeescript":["coffee"],"text/css":["css"],"text/csv":["csv"],"text/hjson":["hjson"],"text/html":["html","htm"],"text/jade":["jade"],"text/jsx":["jsx"],"text/less":["less"],"text/n3":["n3"],"text/plain":["txt","text","conf","def","list","log","in","ini"],"text/prs.lines.tag":["dsc"],"text/richtext":["rtx"],"text/sgml":["sgml","sgm"],"text/stylus":["stylus","styl"],"text/tab-separated-values":["tsv"],"text/troff":["t","tr","roff","man","me","ms"],"text/turtle":["ttl"],"text/uri-list":["uri","uris","urls"],"text/vcard":["vcard"],"text/vnd.curl":["curl"],"text/vnd.curl.dcurl":["dcurl"],"text/vnd.curl.mcurl":["mcurl"],"text/vnd.curl.scurl":["scurl"],"text/vnd.dvb.subtitle":["sub"],"text/vnd.fly":["fly"],"text/vnd.fmi.flexstor":["flx"],"text/vnd.graphviz":["gv"],"text/vnd.in3d.3dml":["3dml"],"text/vnd.in3d.spot":["spot"],"text/vnd.sun.j2me.app-descriptor":["jad"],"text/vnd.wap.wml":["wml"],"text/vnd.wap.wmlscript":["wmls"],"text/vtt":["vtt"],"text/x-asm":["s","asm"],"text/x-c":["c","cc","cxx","cpp","h","hh","dic"],"text/x-component":["htc"],"text/x-fortran":["f","for","f77","f90"],"text/x-handlebars-template":["hbs"],"text/x-java-source":["java"],"text/x-lua":["lua"],"text/x-markdown":["markdown","md","mkd"],"text/x-nfo":["nfo"],"text/x-opml":["opml"],"text/x-pascal":["p","pas"],"text/x-sass":["sass"],"text/x-scss":["scss"],"text/x-setext":["etx"],"text/x-sfv":["sfv"],"text/x-uuencode":["uu"],"text/x-vcalendar":["vcs"],"text/x-vcard":["vcf"],"text/yaml":["yaml","yml"],"video/3gpp":["3gp"],"video/3gpp2":["3g2"],"video/h261":["h261"],"video/h263":["h263"],"video/h264":["h264"],"video/jpeg":["jpgv"],"video/jpm":["jpm","jpgm"],"video/mj2":["mj2","mjp2"],"video/mp2t":["ts"],"video/mp4":["mp4","mp4v","mpg4"],"video/mpeg":["mpeg","mpg","mpe","m1v","m2v"],"video/ogg":["ogv"],"video/quicktime":["qt","mov"],"video/vnd.dece.hd":["uvh","uvvh"],"video/vnd.dece.mobile":["uvm","uvvm"],"video/vnd.dece.pd":["uvp","uvvp"],"video/vnd.dece.sd":["uvs","uvvs"],"video/vnd.dece.video":["uvv","uvvv"],"video/vnd.dvb.file":["dvb"],"video/vnd.fvt":["fvt"],"video/vnd.mpegurl":["mxu","m4u"],"video/vnd.ms-playready.media.pyv":["pyv"],"video/vnd.uvvu.mp4":["uvu","uvvu"],"video/vnd.vivo":["viv"],"video/webm":["webm"],"video/x-f4v":["f4v"],"video/x-fli":["fli"],"video/x-flv":["flv"],"video/x-m4v":["m4v"],"video/x-matroska":["mkv","mk3d","mks"],"video/x-mng":["mng"],"video/x-ms-asf":["asf","asx"],"video/x-ms-vob":["vob"],"video/x-ms-wm":["wm"],"video/x-ms-wmv":["wmv"],"video/x-ms-wmx":["wmx"],"video/x-ms-wvx":["wvx"],"video/x-msvideo":["avi"],"video/x-sgi-movie":["movie"],"video/x-smv":["smv"],"x-conference/x-cooltalk":["ice"]} diff --git a/node_modules/express/node_modules/send/node_modules/ms/.npmignore b/node_modules/express/node_modules/send/node_modules/ms/.npmignore new file mode 100644 index 0000000..d1aa0ce --- /dev/null +++ b/node_modules/express/node_modules/send/node_modules/ms/.npmignore @@ -0,0 +1,5 @@ +node_modules +test +History.md +Makefile +component.json diff --git a/node_modules/express/node_modules/send/node_modules/ms/History.md b/node_modules/express/node_modules/send/node_modules/ms/History.md new file mode 100644 index 0000000..32fdfc1 --- /dev/null +++ b/node_modules/express/node_modules/send/node_modules/ms/History.md @@ -0,0 +1,66 @@ + +0.7.1 / 2015-04-20 +================== + + * prevent extraordinary long inputs (@evilpacket) + * Fixed broken readme link + +0.7.0 / 2014-11-24 +================== + + * add time abbreviations, updated tests and readme for the new units + * fix example in the readme. + * add LICENSE file + +0.6.2 / 2013-12-05 +================== + + * Adding repository section to package.json to suppress warning from NPM. + +0.6.1 / 2013-05-10 +================== + + * fix singularization [visionmedia] + +0.6.0 / 2013-03-15 +================== + + * fix minutes + +0.5.1 / 2013-02-24 +================== + + * add component namespace + +0.5.0 / 2012-11-09 +================== + + * add short formatting as default and .long option + * add .license property to component.json + * add version to component.json + +0.4.0 / 2012-10-22 +================== + + * add rounding to fix crazy decimals + +0.3.0 / 2012-09-07 +================== + + * fix `ms()` [visionmedia] + +0.2.0 / 2012-09-03 +================== + + * add component.json [visionmedia] + * add days support [visionmedia] + * add hours support [visionmedia] + * add minutes support [visionmedia] + * add seconds support [visionmedia] + * add ms string support [visionmedia] + * refactor tests to facilitate ms(number) [visionmedia] + +0.1.0 / 2012-03-07 +================== + + * Initial release diff --git a/node_modules/express/node_modules/send/node_modules/ms/LICENSE b/node_modules/express/node_modules/send/node_modules/ms/LICENSE new file mode 100644 index 0000000..6c07561 --- /dev/null +++ b/node_modules/express/node_modules/send/node_modules/ms/LICENSE @@ -0,0 +1,20 @@ +(The MIT License) + +Copyright (c) 2014 Guillermo Rauch + +Permission is hereby granted, free of charge, to any person obtaining a copy of +this software and associated documentation files (the "Software"), to deal in +the Software without restriction, including without limitation the rights to +use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of +the Software, and to permit persons to whom the Software is furnished to do so, +subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS +FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR +COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER +IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN +CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/express/node_modules/send/node_modules/ms/README.md b/node_modules/express/node_modules/send/node_modules/ms/README.md new file mode 100644 index 0000000..9b4fd03 --- /dev/null +++ b/node_modules/express/node_modules/send/node_modules/ms/README.md @@ -0,0 +1,35 @@ +# ms.js: miliseconds conversion utility + +```js +ms('2 days') // 172800000 +ms('1d') // 86400000 +ms('10h') // 36000000 +ms('2.5 hrs') // 9000000 +ms('2h') // 7200000 +ms('1m') // 60000 +ms('5s') // 5000 +ms('100') // 100 +``` + +```js +ms(60000) // "1m" +ms(2 * 60000) // "2m" +ms(ms('10 hours')) // "10h" +``` + +```js +ms(60000, { long: true }) // "1 minute" +ms(2 * 60000, { long: true }) // "2 minutes" +ms(ms('10 hours'), { long: true }) // "10 hours" +``` + +- Node/Browser compatible. Published as [`ms`](https://www.npmjs.org/package/ms) in [NPM](http://nodejs.org/download). +- If a number is supplied to `ms`, a string with a unit is returned. +- If a string that contains the number is supplied, it returns it as +a number (e.g: it returns `100` for `'100'`). +- If you pass a string with a number and a valid unit, the number of +equivalent ms is returned. + +## License + +MIT diff --git a/node_modules/express/node_modules/send/node_modules/ms/index.js b/node_modules/express/node_modules/send/node_modules/ms/index.js new file mode 100644 index 0000000..4f92771 --- /dev/null +++ b/node_modules/express/node_modules/send/node_modules/ms/index.js @@ -0,0 +1,125 @@ +/** + * Helpers. + */ + +var s = 1000; +var m = s * 60; +var h = m * 60; +var d = h * 24; +var y = d * 365.25; + +/** + * Parse or format the given `val`. + * + * Options: + * + * - `long` verbose formatting [false] + * + * @param {String|Number} val + * @param {Object} options + * @return {String|Number} + * @api public + */ + +module.exports = function(val, options){ + options = options || {}; + if ('string' == typeof val) return parse(val); + return options.long + ? long(val) + : short(val); +}; + +/** + * Parse the given `str` and return milliseconds. + * + * @param {String} str + * @return {Number} + * @api private + */ + +function parse(str) { + str = '' + str; + if (str.length > 10000) return; + var match = /^((?:\d+)?\.?\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|years?|yrs?|y)?$/i.exec(str); + if (!match) return; + var n = parseFloat(match[1]); + var type = (match[2] || 'ms').toLowerCase(); + switch (type) { + case 'years': + case 'year': + case 'yrs': + case 'yr': + case 'y': + return n * y; + case 'days': + case 'day': + case 'd': + return n * d; + case 'hours': + case 'hour': + case 'hrs': + case 'hr': + case 'h': + return n * h; + case 'minutes': + case 'minute': + case 'mins': + case 'min': + case 'm': + return n * m; + case 'seconds': + case 'second': + case 'secs': + case 'sec': + case 's': + return n * s; + case 'milliseconds': + case 'millisecond': + case 'msecs': + case 'msec': + case 'ms': + return n; + } +} + +/** + * Short format for `ms`. + * + * @param {Number} ms + * @return {String} + * @api private + */ + +function short(ms) { + if (ms >= d) return Math.round(ms / d) + 'd'; + if (ms >= h) return Math.round(ms / h) + 'h'; + if (ms >= m) return Math.round(ms / m) + 'm'; + if (ms >= s) return Math.round(ms / s) + 's'; + return ms + 'ms'; +} + +/** + * Long format for `ms`. + * + * @param {Number} ms + * @return {String} + * @api private + */ + +function long(ms) { + return plural(ms, d, 'day') + || plural(ms, h, 'hour') + || plural(ms, m, 'minute') + || plural(ms, s, 'second') + || ms + ' ms'; +} + +/** + * Pluralization helper. + */ + +function plural(ms, n, name) { + if (ms < n) return; + if (ms < n * 1.5) return Math.floor(ms / n) + ' ' + name; + return Math.ceil(ms / n) + ' ' + name + 's'; +} diff --git a/node_modules/express/node_modules/send/node_modules/ms/package.json b/node_modules/express/node_modules/send/node_modules/ms/package.json new file mode 100644 index 0000000..64818de --- /dev/null +++ b/node_modules/express/node_modules/send/node_modules/ms/package.json @@ -0,0 +1,48 @@ +{ + "name": "ms", + "version": "0.7.1", + "description": "Tiny ms conversion utility", + "repository": { + "type": "git", + "url": "git://github.com/guille/ms.js.git" + }, + "main": "./index", + "devDependencies": { + "mocha": "*", + "expect.js": "*", + "serve": "*" + }, + "component": { + "scripts": { + "ms/index.js": "index.js" + } + }, + "gitHead": "713dcf26d9e6fd9dbc95affe7eff9783b7f1b909", + "bugs": { + "url": "https://github.com/guille/ms.js/issues" + }, + "homepage": "https://github.com/guille/ms.js", + "_id": "ms@0.7.1", + "scripts": {}, + "_shasum": "9cd13c03adbff25b65effde7ce864ee952017098", + "_from": "ms@0.7.1", + "_npmVersion": "2.7.5", + "_nodeVersion": "0.12.2", + "_npmUser": { + "name": "rauchg", + "email": "rauchg@gmail.com" + }, + "maintainers": [ + { + "name": "rauchg", + "email": "rauchg@gmail.com" + } + ], + "dist": { + "shasum": "9cd13c03adbff25b65effde7ce864ee952017098", + "tarball": "https://registry.npmjs.org/ms/-/ms-0.7.1.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/ms/-/ms-0.7.1.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/express/node_modules/send/node_modules/statuses/HISTORY.md b/node_modules/express/node_modules/send/node_modules/statuses/HISTORY.md new file mode 100644 index 0000000..b175575 --- /dev/null +++ b/node_modules/express/node_modules/send/node_modules/statuses/HISTORY.md @@ -0,0 +1,50 @@ +1.3.0 / 2016-05-17 +================== + + * Add `421 Misdirected Request` + * perf: enable strict mode + +1.2.1 / 2015-02-01 +================== + + * Fix message for status 451 + - `451 Unavailable For Legal Reasons` + +1.2.0 / 2014-09-28 +================== + + * Add `208 Already Repored` + * Add `226 IM Used` + * Add `306 (Unused)` + * Add `415 Unable For Legal Reasons` + * Add `508 Loop Detected` + +1.1.1 / 2014-09-24 +================== + + * Add missing 308 to `codes.json` + +1.1.0 / 2014-09-21 +================== + + * Add `codes.json` for universal support + +1.0.4 / 2014-08-20 +================== + + * Package cleanup + +1.0.3 / 2014-06-08 +================== + + * Add 308 to `.redirect` category + +1.0.2 / 2014-03-13 +================== + + * Add `.retry` category + +1.0.1 / 2014-03-12 +================== + + * Initial release diff --git a/node_modules/express/node_modules/send/node_modules/statuses/LICENSE b/node_modules/express/node_modules/send/node_modules/statuses/LICENSE new file mode 100644 index 0000000..82af4df --- /dev/null +++ b/node_modules/express/node_modules/send/node_modules/statuses/LICENSE @@ -0,0 +1,23 @@ + +The MIT License (MIT) + +Copyright (c) 2014 Jonathan Ong me@jongleberry.com +Copyright (c) 2016 Douglas Christopher Wilson doug@somethingdoug.com + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. diff --git a/node_modules/express/node_modules/send/node_modules/statuses/README.md b/node_modules/express/node_modules/send/node_modules/statuses/README.md new file mode 100644 index 0000000..1a699da --- /dev/null +++ b/node_modules/express/node_modules/send/node_modules/statuses/README.md @@ -0,0 +1,114 @@ +# Statuses + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Node.js Version][node-version-image]][node-version-url] +[![Build Status][travis-image]][travis-url] +[![Test Coverage][coveralls-image]][coveralls-url] + +HTTP status utility for node. + +## API + +```js +var status = require('statuses') +``` + +### var code = status(Integer || String) + +If `Integer` or `String` is a valid HTTP code or status message, then the appropriate `code` will be returned. Otherwise, an error will be thrown. + +```js +status(403) // => 403 +status('403') // => 403 +status('forbidden') // => 403 +status('Forbidden') // => 403 +status(306) // throws, as it's not supported by node.js +``` + +### status.codes + +Returns an array of all the status codes as `Integer`s. + +### var msg = status[code] + +Map of `code` to `status message`. `undefined` for invalid `code`s. + +```js +status[404] // => 'Not Found' +``` + +### var code = status[msg] + +Map of `status message` to `code`. `msg` can either be title-cased or lower-cased. `undefined` for invalid `status message`s. + +```js +status['not found'] // => 404 +status['Not Found'] // => 404 +``` + +### status.redirect[code] + +Returns `true` if a status code is a valid redirect status. + +```js +status.redirect[200] // => undefined +status.redirect[301] // => true +``` + +### status.empty[code] + +Returns `true` if a status code expects an empty body. + +```js +status.empty[200] // => undefined +status.empty[204] // => true +status.empty[304] // => true +``` + +### status.retry[code] + +Returns `true` if you should retry the rest. + +```js +status.retry[501] // => undefined +status.retry[503] // => true +``` + +### statuses/codes.json + +```js +var codes = require('statuses/codes.json') +``` + +This is a JSON file of the status codes +taken from `require('http').STATUS_CODES`. +This is saved so that codes are consistent even in older node.js versions. +For example, `308` will be added in v0.12. + +## Adding Status Codes + +The status codes are primarily sourced from http://www.iana.org/assignments/http-status-codes/http-status-codes-1.csv. +Additionally, custom codes are added from http://en.wikipedia.org/wiki/List_of_HTTP_status_codes. +These are added manually in the `lib/*.json` files. +If you would like to add a status code, add it to the appropriate JSON file. + +To rebuild `codes.json`, run the following: + +```bash +# update src/iana.json +npm run fetch +# build codes.json +npm run build +``` + +[npm-image]: https://img.shields.io/npm/v/statuses.svg +[npm-url]: https://npmjs.org/package/statuses +[node-version-image]: https://img.shields.io/badge/node.js-%3E%3D_0.6-brightgreen.svg +[node-version-url]: https://nodejs.org/en/download +[travis-image]: https://img.shields.io/travis/jshttp/statuses.svg +[travis-url]: https://travis-ci.org/jshttp/statuses +[coveralls-image]: https://img.shields.io/coveralls/jshttp/statuses.svg +[coveralls-url]: https://coveralls.io/r/jshttp/statuses?branch=master +[downloads-image]: https://img.shields.io/npm/dm/statuses.svg +[downloads-url]: https://npmjs.org/package/statuses diff --git a/node_modules/express/node_modules/send/node_modules/statuses/codes.json b/node_modules/express/node_modules/send/node_modules/statuses/codes.json new file mode 100644 index 0000000..e765123 --- /dev/null +++ b/node_modules/express/node_modules/send/node_modules/statuses/codes.json @@ -0,0 +1,65 @@ +{ + "100": "Continue", + "101": "Switching Protocols", + "102": "Processing", + "200": "OK", + "201": "Created", + "202": "Accepted", + "203": "Non-Authoritative Information", + "204": "No Content", + "205": "Reset Content", + "206": "Partial Content", + "207": "Multi-Status", + "208": "Already Reported", + "226": "IM Used", + "300": "Multiple Choices", + "301": "Moved Permanently", + "302": "Found", + "303": "See Other", + "304": "Not Modified", + "305": "Use Proxy", + "306": "(Unused)", + "307": "Temporary Redirect", + "308": "Permanent Redirect", + "400": "Bad Request", + "401": "Unauthorized", + "402": "Payment Required", + "403": "Forbidden", + "404": "Not Found", + "405": "Method Not Allowed", + "406": "Not Acceptable", + "407": "Proxy Authentication Required", + "408": "Request Timeout", + "409": "Conflict", + "410": "Gone", + "411": "Length Required", + "412": "Precondition Failed", + "413": "Payload Too Large", + "414": "URI Too Long", + "415": "Unsupported Media Type", + "416": "Range Not Satisfiable", + "417": "Expectation Failed", + "418": "I'm a teapot", + "421": "Misdirected Request", + "422": "Unprocessable Entity", + "423": "Locked", + "424": "Failed Dependency", + "425": "Unordered Collection", + "426": "Upgrade Required", + "428": "Precondition Required", + "429": "Too Many Requests", + "431": "Request Header Fields Too Large", + "451": "Unavailable For Legal Reasons", + "500": "Internal Server Error", + "501": "Not Implemented", + "502": "Bad Gateway", + "503": "Service Unavailable", + "504": "Gateway Timeout", + "505": "HTTP Version Not Supported", + "506": "Variant Also Negotiates", + "507": "Insufficient Storage", + "508": "Loop Detected", + "509": "Bandwidth Limit Exceeded", + "510": "Not Extended", + "511": "Network Authentication Required" +} \ No newline at end of file diff --git a/node_modules/express/node_modules/send/node_modules/statuses/index.js b/node_modules/express/node_modules/send/node_modules/statuses/index.js new file mode 100644 index 0000000..c2b555a --- /dev/null +++ b/node_modules/express/node_modules/send/node_modules/statuses/index.js @@ -0,0 +1,110 @@ +/*! + * statuses + * Copyright(c) 2014 Jonathan Ong + * Copyright(c) 2016 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module dependencies. + * @private + */ + +var codes = require('./codes.json') + +/** + * Module exports. + * @public + */ + +module.exports = status + +// array of status codes +status.codes = populateStatusesMap(status, codes) + +// status codes for redirects +status.redirect = { + 300: true, + 301: true, + 302: true, + 303: true, + 305: true, + 307: true, + 308: true +} + +// status codes for empty bodies +status.empty = { + 204: true, + 205: true, + 304: true +} + +// status codes for when you should retry the request +status.retry = { + 502: true, + 503: true, + 504: true +} + +/** + * Populate the statuses map for given codes. + * @private + */ + +function populateStatusesMap (statuses, codes) { + var arr = [] + + Object.keys(codes).forEach(function forEachCode (code) { + var message = codes[code] + var status = Number(code) + + // Populate properties + statuses[status] = message + statuses[message] = status + statuses[message.toLowerCase()] = status + + // Add to array + arr.push(status) + }) + + return arr +} + +/** + * Get the status code. + * + * Given a number, this will throw if it is not a known status + * code, otherwise the code will be returned. Given a string, + * the string will be parsed for a number and return the code + * if valid, otherwise will lookup the code assuming this is + * the status message. + * + * @param {string|number} code + * @returns {string} + * @public + */ + +function status (code) { + if (typeof code === 'number') { + if (!status[code]) throw new Error('invalid status code: ' + code) + return code + } + + if (typeof code !== 'string') { + throw new TypeError('code must be a number or string') + } + + // '403' + var n = parseInt(code, 10) + if (!isNaN(n)) { + if (!status[n]) throw new Error('invalid status code: ' + n) + return n + } + + n = status[code.toLowerCase()] + if (!n) throw new Error('invalid status message: "' + code + '"') + return n +} diff --git a/node_modules/express/node_modules/send/node_modules/statuses/package.json b/node_modules/express/node_modules/send/node_modules/statuses/package.json new file mode 100644 index 0000000..52e1ae3 --- /dev/null +++ b/node_modules/express/node_modules/send/node_modules/statuses/package.json @@ -0,0 +1,104 @@ +{ + "name": "statuses", + "description": "HTTP status utility", + "version": "1.3.0", + "contributors": [ + { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "Jonathan Ong", + "email": "me@jongleberry.com", + "url": "http://jongleberry.com" + } + ], + "repository": { + "type": "git", + "url": "git+https://github.com/jshttp/statuses.git" + }, + "license": "MIT", + "keywords": [ + "http", + "status", + "code" + ], + "files": [ + "HISTORY.md", + "index.js", + "codes.json", + "LICENSE" + ], + "devDependencies": { + "csv-parse": "1.0.1", + "eslint": "2.10.2", + "eslint-config-standard": "5.3.1", + "eslint-plugin-promise": "1.1.0", + "eslint-plugin-standard": "1.3.2", + "istanbul": "0.4.3", + "mocha": "1.21.5", + "stream-to-array": "2.2.0" + }, + "engines": { + "node": ">= 0.6" + }, + "scripts": { + "build": "node scripts/build.js", + "fetch": "node scripts/fetch.js", + "lint": "eslint **/*.js", + "test": "mocha --reporter spec --check-leaks --bail test/", + "test-ci": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter spec --check-leaks test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot --check-leaks test/", + "update": "npm run fetch && npm run build" + }, + "gitHead": "b3e31e8c32dd8107e898b44b8c0b2dfff3cba495", + "bugs": { + "url": "https://github.com/jshttp/statuses/issues" + }, + "homepage": "https://github.com/jshttp/statuses", + "_id": "statuses@1.3.0", + "_shasum": "8e55758cb20e7682c1f4fce8dcab30bf01d1e07a", + "_from": "statuses@>=1.3.0 <1.4.0", + "_npmVersion": "1.4.28", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "maintainers": [ + { + "name": "defunctzombie", + "email": "shtylman@gmail.com" + }, + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "fishrock123", + "email": "fishrock123@rocketmail.com" + }, + { + "name": "jongleberry", + "email": "jonathanrichardong@gmail.com" + }, + { + "name": "mscdex", + "email": "mscdex@mscdex.net" + }, + { + "name": "tjholowaychuk", + "email": "tj@vision-media.ca" + } + ], + "dist": { + "shasum": "8e55758cb20e7682c1f4fce8dcab30bf01d1e07a", + "tarball": "https://registry.npmjs.org/statuses/-/statuses-1.3.0.tgz" + }, + "_npmOperationalInternal": { + "host": "packages-12-west.internal.npmjs.com", + "tmp": "tmp/statuses-1.3.0.tgz_1463517875633_0.19560232176445425" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/statuses/-/statuses-1.3.0.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/express/node_modules/send/package.json b/node_modules/express/node_modules/send/package.json new file mode 100644 index 0000000..f7db725 --- /dev/null +++ b/node_modules/express/node_modules/send/package.json @@ -0,0 +1,96 @@ +{ + "name": "send", + "description": "Better streaming static file server with Range and conditional-GET support", + "version": "0.14.1", + "author": { + "name": "TJ Holowaychuk", + "email": "tj@vision-media.ca" + }, + "contributors": [ + { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + } + ], + "license": "MIT", + "repository": { + "type": "git", + "url": "git+https://github.com/pillarjs/send.git" + }, + "keywords": [ + "static", + "file", + "server" + ], + "dependencies": { + "debug": "~2.2.0", + "depd": "~1.1.0", + "destroy": "~1.0.4", + "encodeurl": "~1.0.1", + "escape-html": "~1.0.3", + "etag": "~1.7.0", + "fresh": "0.3.0", + "http-errors": "~1.5.0", + "mime": "1.3.4", + "ms": "0.7.1", + "on-finished": "~2.3.0", + "range-parser": "~1.2.0", + "statuses": "~1.3.0" + }, + "devDependencies": { + "after": "0.8.1", + "eslint": "2.11.1", + "eslint-config-standard": "5.3.1", + "eslint-plugin-promise": "1.3.1", + "eslint-plugin-standard": "1.3.2", + "istanbul": "0.4.3", + "mocha": "2.5.3", + "supertest": "1.1.0" + }, + "files": [ + "HISTORY.md", + "LICENSE", + "README.md", + "index.js" + ], + "engines": { + "node": ">= 0.8.0" + }, + "scripts": { + "lint": "eslint **/*.js", + "test": "mocha --check-leaks --reporter spec --bail", + "test-ci": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --check-leaks --reporter spec", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --check-leaks --reporter dot" + }, + "gitHead": "d6dd3b91bbb73ad89f1398fa227b200db9bff037", + "bugs": { + "url": "https://github.com/pillarjs/send/issues" + }, + "homepage": "https://github.com/pillarjs/send#readme", + "_id": "send@0.14.1", + "_shasum": "a954984325392f51532a7760760e459598c89f7a", + "_from": "send@0.14.1", + "_npmVersion": "2.15.1", + "_nodeVersion": "4.4.3", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "dist": { + "shasum": "a954984325392f51532a7760760e459598c89f7a", + "tarball": "https://registry.npmjs.org/send/-/send-0.14.1.tgz" + }, + "maintainers": [ + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + } + ], + "_npmOperationalInternal": { + "host": "packages-16-east.internal.npmjs.com", + "tmp": "tmp/send-0.14.1.tgz_1465535036412_0.3431496580597013" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/send/-/send-0.14.1.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/express/node_modules/serve-static/HISTORY.md b/node_modules/express/node_modules/serve-static/HISTORY.md new file mode 100644 index 0000000..0256dbb --- /dev/null +++ b/node_modules/express/node_modules/serve-static/HISTORY.md @@ -0,0 +1,332 @@ +1.11.1 / 2016-06-10 +=================== + + * Fix redirect error when `req.url` contains raw non-URL characters + * deps: send@0.14.1 + +1.11.0 / 2016-06-07 +=================== + + * Use status code 301 for redirects + * deps: send@0.14.0 + - Add `acceptRanges` option + - Add `cacheControl` option + - Attempt to combine multiple ranges into single range + - Correctly inherit from `Stream` class + - Fix `Content-Range` header in 416 responses when using `start`/`end` options + - Fix `Content-Range` header missing from default 416 responses + - Ignore non-byte `Range` headers + - deps: http-errors@~1.5.0 + - deps: range-parser@~1.2.0 + - deps: statuses@~1.3.0 + - perf: remove argument reassignment + +1.10.3 / 2016-05-30 +=================== + + * deps: send@0.13.2 + - Fix invalid `Content-Type` header when `send.mime.default_type` unset + +1.10.2 / 2016-01-19 +=================== + + * deps: parseurl@~1.3.1 + - perf: enable strict mode + +1.10.1 / 2016-01-16 +=================== + + * deps: escape-html@~1.0.3 + - perf: enable strict mode + - perf: optimize string replacement + - perf: use faster string coercion + * deps: send@0.13.1 + - deps: depd@~1.1.0 + - deps: destroy@~1.0.4 + - deps: escape-html@~1.0.3 + - deps: range-parser@~1.0.3 + +1.10.0 / 2015-06-17 +=================== + + * Add `fallthrough` option + - Allows declaring this middleware is the final destination + - Provides better integration with Express patterns + * Fix reading options from options prototype + * Improve the default redirect response headers + * deps: escape-html@1.0.2 + * deps: send@0.13.0 + - Allow Node.js HTTP server to set `Date` response header + - Fix incorrectly removing `Content-Location` on 304 response + - Improve the default redirect response headers + - Send appropriate headers on default error response + - Use `http-errors` for standard emitted errors + - Use `statuses` instead of `http` module for status messages + - deps: escape-html@1.0.2 + - deps: etag@~1.7.0 + - deps: fresh@0.3.0 + - deps: on-finished@~2.3.0 + - perf: enable strict mode + - perf: remove unnecessary array allocations + * perf: enable strict mode + * perf: remove argument reassignment + +1.9.3 / 2015-05-14 +================== + + * deps: send@0.12.3 + - deps: debug@~2.2.0 + - deps: depd@~1.0.1 + - deps: etag@~1.6.0 + - deps: ms@0.7.1 + - deps: on-finished@~2.2.1 + +1.9.2 / 2015-03-14 +================== + + * deps: send@0.12.2 + - Throw errors early for invalid `extensions` or `index` options + - deps: debug@~2.1.3 + +1.9.1 / 2015-02-17 +================== + + * deps: send@0.12.1 + - Fix regression sending zero-length files + +1.9.0 / 2015-02-16 +================== + + * deps: send@0.12.0 + - Always read the stat size from the file + - Fix mutating passed-in `options` + - deps: mime@1.3.4 + +1.8.1 / 2015-01-20 +================== + + * Fix redirect loop in Node.js 0.11.14 + * deps: send@0.11.1 + - Fix root path disclosure + +1.8.0 / 2015-01-05 +================== + + * deps: send@0.11.0 + - deps: debug@~2.1.1 + - deps: etag@~1.5.1 + - deps: ms@0.7.0 + - deps: on-finished@~2.2.0 + +1.7.2 / 2015-01-02 +================== + + * Fix potential open redirect when mounted at root + +1.7.1 / 2014-10-22 +================== + + * deps: send@0.10.1 + - deps: on-finished@~2.1.1 + +1.7.0 / 2014-10-15 +================== + + * deps: send@0.10.0 + - deps: debug@~2.1.0 + - deps: depd@~1.0.0 + - deps: etag@~1.5.0 + +1.6.5 / 2015-02-04 +================== + + * Fix potential open redirect when mounted at root + - Back-ported from v1.7.2 + +1.6.4 / 2014-10-08 +================== + + * Fix redirect loop when index file serving disabled + +1.6.3 / 2014-09-24 +================== + + * deps: send@0.9.3 + - deps: etag@~1.4.0 + +1.6.2 / 2014-09-15 +================== + + * deps: send@0.9.2 + - deps: depd@0.4.5 + - deps: etag@~1.3.1 + - deps: range-parser@~1.0.2 + +1.6.1 / 2014-09-07 +================== + + * deps: send@0.9.1 + - deps: fresh@0.2.4 + +1.6.0 / 2014-09-07 +================== + + * deps: send@0.9.0 + - Add `lastModified` option + - Use `etag` to generate `ETag` header + - deps: debug@~2.0.0 + +1.5.4 / 2014-09-04 +================== + + * deps: send@0.8.5 + - Fix a path traversal issue when using `root` + - Fix malicious path detection for empty string path + +1.5.3 / 2014-08-17 +================== + + * deps: send@0.8.3 + +1.5.2 / 2014-08-14 +================== + + * deps: send@0.8.2 + - Work around `fd` leak in Node.js 0.10 for `fs.ReadStream` + +1.5.1 / 2014-08-09 +================== + + * Fix parsing of weird `req.originalUrl` values + * deps: parseurl@~1.3.0 + * deps: utils-merge@1.0.0 + +1.5.0 / 2014-08-05 +================== + + * deps: send@0.8.1 + - Add `extensions` option + +1.4.4 / 2014-08-04 +================== + + * deps: send@0.7.4 + - Fix serving index files without root dir + +1.4.3 / 2014-07-29 +================== + + * deps: send@0.7.3 + - Fix incorrect 403 on Windows and Node.js 0.11 + +1.4.2 / 2014-07-27 +================== + + * deps: send@0.7.2 + - deps: depd@0.4.4 + +1.4.1 / 2014-07-26 +================== + + * deps: send@0.7.1 + - deps: depd@0.4.3 + +1.4.0 / 2014-07-21 +================== + + * deps: parseurl@~1.2.0 + - Cache URLs based on original value + - Remove no-longer-needed URL mis-parse work-around + - Simplify the "fast-path" `RegExp` + * deps: send@0.7.0 + - Add `dotfiles` option + - deps: debug@1.0.4 + - deps: depd@0.4.2 + +1.3.2 / 2014-07-11 +================== + + * deps: send@0.6.0 + - Cap `maxAge` value to 1 year + - deps: debug@1.0.3 + +1.3.1 / 2014-07-09 +================== + + * deps: parseurl@~1.1.3 + - faster parsing of href-only URLs + +1.3.0 / 2014-06-28 +================== + + * Add `setHeaders` option + * Include HTML link in redirect response + * deps: send@0.5.0 + - Accept string for `maxAge` (converted by `ms`) + +1.2.3 / 2014-06-11 +================== + + * deps: send@0.4.3 + - Do not throw un-catchable error on file open race condition + - Use `escape-html` for HTML escaping + - deps: debug@1.0.2 + - deps: finished@1.2.2 + - deps: fresh@0.2.2 + +1.2.2 / 2014-06-09 +================== + + * deps: send@0.4.2 + - fix "event emitter leak" warnings + - deps: debug@1.0.1 + - deps: finished@1.2.1 + +1.2.1 / 2014-06-02 +================== + + * use `escape-html` for escaping + * deps: send@0.4.1 + - Send `max-age` in `Cache-Control` in correct format + +1.2.0 / 2014-05-29 +================== + + * deps: send@0.4.0 + - Calculate ETag with md5 for reduced collisions + - Fix wrong behavior when index file matches directory + - Ignore stream errors after request ends + - Skip directories in index file search + - deps: debug@0.8.1 + +1.1.0 / 2014-04-24 +================== + + * Accept options directly to `send` module + * deps: send@0.3.0 + +1.0.4 / 2014-04-07 +================== + + * Resolve relative paths at middleware setup + * Use parseurl to parse the URL from request + +1.0.3 / 2014-03-20 +================== + + * Do not rely on connect-like environments + +1.0.2 / 2014-03-06 +================== + + * deps: send@0.2.0 + +1.0.1 / 2014-03-05 +================== + + * Add mime export for back-compat + +1.0.0 / 2014-03-05 +================== + + * Genesis from `connect` diff --git a/node_modules/express/node_modules/serve-static/LICENSE b/node_modules/express/node_modules/serve-static/LICENSE new file mode 100644 index 0000000..cbe62e8 --- /dev/null +++ b/node_modules/express/node_modules/serve-static/LICENSE @@ -0,0 +1,25 @@ +(The MIT License) + +Copyright (c) 2010 Sencha Inc. +Copyright (c) 2011 LearnBoost +Copyright (c) 2011 TJ Holowaychuk +Copyright (c) 2014-2016 Douglas Christopher Wilson + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/express/node_modules/serve-static/README.md b/node_modules/express/node_modules/serve-static/README.md new file mode 100644 index 0000000..3bd75f3 --- /dev/null +++ b/node_modules/express/node_modules/serve-static/README.md @@ -0,0 +1,245 @@ +# serve-static + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Linux Build][travis-image]][travis-url] +[![Windows Build][appveyor-image]][appveyor-url] +[![Test Coverage][coveralls-image]][coveralls-url] +[![Gratipay][gratipay-image]][gratipay-url] + +## Install + +```sh +$ npm install serve-static +``` + +## API + +```js +var serveStatic = require('serve-static') +``` + +### serveStatic(root, options) + +Create a new middleware function to serve files from within a given root +directory. The file to serve will be determined by combining `req.url` +with the provided root directory. When a file is not found, instead of +sending a 404 response, this module will instead call `next()` to move on +to the next middleware, allowing for stacking and fall-backs. + +#### Options + +##### acceptRanges + +Enable or disable accepting ranged requests, defaults to true. +Disabling this will not send `Accept-Ranges` and ignore the contents +of the `Range` request header. + +##### cacheControl + +Enable or disable setting `Cache-Control` response header, defaults to +true. Disabling this will ignore the `maxAge` option. + +##### dotfiles + + Set how "dotfiles" are treated when encountered. A dotfile is a file +or directory that begins with a dot ("."). Note this check is done on +the path itself without checking if the path actually exists on the +disk. If `root` is specified, only the dotfiles above the root are +checked (i.e. the root itself can be within a dotfile when set +to "deny"). + + - `'allow'` No special treatment for dotfiles. + - `'deny'` Deny a request for a dotfile and 403/`next()`. + - `'ignore'` Pretend like the dotfile does not exist and 404/`next()`. + +The default value is similar to `'ignore'`, with the exception that this +default will not ignore the files within a directory that begins with a dot. + +##### etag + +Enable or disable etag generation, defaults to true. + +##### extensions + +Set file extension fallbacks. When set, if a file is not found, the given +extensions will be added to the file name and search for. The first that +exists will be served. Example: `['html', 'htm']`. + +The default value is `false`. + +##### fallthrough + +Set the middleware to have client errors fall-through as just unhandled +requests, otherwise forward a client error. The difference is that client +errors like a bad request or a request to a non-existent file will cause +this middleware to simply `next()` to your next middleware when this value +is `true`. When this value is `false`, these errors (even 404s), will invoke +`next(err)`. + +Typically `true` is desired such that multiple physical directories can be +mapped to the same web address or for routes to fill in non-existent files. + +The value `false` can be used if this middleware is mounted at a path that +is designed to be strictly a single file system directory, which allows for +short-circuiting 404s for less overhead. This middleware will also reply to +all methods. + +The default value is `true`. + +##### index + +By default this module will send "index.html" files in response to a request +on a directory. To disable this set `false` or to supply a new index pass a +string or an array in preferred order. + +##### lastModified + +Enable or disable `Last-Modified` header, defaults to true. Uses the file +system's last modified value. + +##### maxAge + +Provide a max-age in milliseconds for http caching, defaults to 0. This +can also be a string accepted by the [ms](https://www.npmjs.org/package/ms#readme) +module. + +##### redirect + +Redirect to trailing "/" when the pathname is a dir. Defaults to `true`. + +##### setHeaders + +Function to set custom headers on response. Alterations to the headers need to +occur synchronously. The function is called as `fn(res, path, stat)`, where +the arguments are: + + - `res` the response object + - `path` the file path that is being sent + - `stat` the stat object of the file that is being sent + +## Examples + +### Serve files with vanilla node.js http server + +```js +var finalhandler = require('finalhandler') +var http = require('http') +var serveStatic = require('serve-static') + +// Serve up public/ftp folder +var serve = serveStatic('public/ftp', {'index': ['index.html', 'index.htm']}) + +// Create server +var server = http.createServer(function onRequest (req, res) { + serve(req, res, finalhandler(req, res)) +}) + +// Listen +server.listen(3000) +``` + +### Serve all files as downloads + +```js +var contentDisposition = require('content-disposition') +var finalhandler = require('finalhandler') +var http = require('http') +var serveStatic = require('serve-static') + +// Serve up public/ftp folder +var serve = serveStatic('public/ftp', { + 'index': false, + 'setHeaders': setHeaders +}) + +// Set header to force download +function setHeaders(res, path) { + res.setHeader('Content-Disposition', contentDisposition(path)) +} + +// Create server +var server = http.createServer(function onRequest (req, res) { + serve(req, res, finalhandler(req, res)) +}) + +// Listen +server.listen(3000) +``` + +### Serving using express + +#### Simple + +This is a simple example of using Express. + +```js +var express = require('express') +var serveStatic = require('serve-static') + +var app = express() + +app.use(serveStatic('public/ftp', {'index': ['default.html', 'default.htm']})) +app.listen(3000) +``` + +#### Multiple roots + +This example shows a simple way to search through multiple directories. +Files are look for in `public-optimized/` first, then `public/` second as +a fallback. + +```js +var express = require('express') +var serveStatic = require('serve-static') + +var app = express() + +app.use(serveStatic(__dirname + '/public-optimized')) +app.use(serveStatic(__dirname + '/public')) +app.listen(3000) +``` + +#### Different settings for paths + +This example shows how to set a different max age depending on the served +file type. In this example, HTML files are not cached, while everything else +is for 1 day. + +```js +var express = require('express') +var serveStatic = require('serve-static') + +var app = express() + +app.use(serveStatic(__dirname + '/public', { + maxAge: '1d', + setHeaders: setCustomCacheControl +})) + +app.listen(3000) + +function setCustomCacheControl (res, path) { + if (serveStatic.mime.lookup(path) === 'text/html') { + // Custom Cache-Control for HTML files + res.setHeader('Cache-Control', 'public, max-age=0') + } +} +``` + +## License + +[MIT](LICENSE) + +[npm-image]: https://img.shields.io/npm/v/serve-static.svg +[npm-url]: https://npmjs.org/package/serve-static +[travis-image]: https://img.shields.io/travis/expressjs/serve-static/master.svg?label=linux +[travis-url]: https://travis-ci.org/expressjs/serve-static +[appveyor-image]: https://img.shields.io/appveyor/ci/dougwilson/serve-static/master.svg?label=windows +[appveyor-url]: https://ci.appveyor.com/project/dougwilson/serve-static +[coveralls-image]: https://img.shields.io/coveralls/expressjs/serve-static/master.svg +[coveralls-url]: https://coveralls.io/r/expressjs/serve-static +[downloads-image]: https://img.shields.io/npm/dm/serve-static.svg +[downloads-url]: https://npmjs.org/package/serve-static +[gratipay-image]: https://img.shields.io/gratipay/dougwilson.svg +[gratipay-url]: https://gratipay.com/dougwilson/ diff --git a/node_modules/express/node_modules/serve-static/index.js b/node_modules/express/node_modules/serve-static/index.js new file mode 100644 index 0000000..83c5e4f --- /dev/null +++ b/node_modules/express/node_modules/serve-static/index.js @@ -0,0 +1,188 @@ +/*! + * serve-static + * Copyright(c) 2010 Sencha Inc. + * Copyright(c) 2011 TJ Holowaychuk + * Copyright(c) 2014-2016 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module dependencies. + * @private + */ + +var encodeUrl = require('encodeurl') +var escapeHtml = require('escape-html') +var parseUrl = require('parseurl') +var resolve = require('path').resolve +var send = require('send') +var url = require('url') + +/** + * Module exports. + * @public + */ + +module.exports = serveStatic +module.exports.mime = send.mime + +/** + * @param {string} root + * @param {object} [options] + * @return {function} + * @public + */ + +function serveStatic (root, options) { + if (!root) { + throw new TypeError('root path required') + } + + if (typeof root !== 'string') { + throw new TypeError('root path must be a string') + } + + // copy options object + var opts = Object.create(options || null) + + // fall-though + var fallthrough = opts.fallthrough !== false + + // default redirect + var redirect = opts.redirect !== false + + // headers listener + var setHeaders = opts.setHeaders + + if (setHeaders && typeof setHeaders !== 'function') { + throw new TypeError('option setHeaders must be function') + } + + // setup options for send + opts.maxage = opts.maxage || opts.maxAge || 0 + opts.root = resolve(root) + + // construct directory listener + var onDirectory = redirect + ? createRedirectDirectoryListener() + : createNotFoundDirectoryListener() + + return function serveStatic (req, res, next) { + if (req.method !== 'GET' && req.method !== 'HEAD') { + if (fallthrough) { + return next() + } + + // method not allowed + res.statusCode = 405 + res.setHeader('Allow', 'GET, HEAD') + res.setHeader('Content-Length', '0') + res.end() + return + } + + var forwardError = !fallthrough + var originalUrl = parseUrl.original(req) + var path = parseUrl(req).pathname + + // make sure redirect occurs at mount + if (path === '/' && originalUrl.pathname.substr(-1) !== '/') { + path = '' + } + + // create send stream + var stream = send(req, path, opts) + + // add directory handler + stream.on('directory', onDirectory) + + // add headers listener + if (setHeaders) { + stream.on('headers', setHeaders) + } + + // add file listener for fallthrough + if (fallthrough) { + stream.on('file', function onFile () { + // once file is determined, always forward error + forwardError = true + }) + } + + // forward errors + stream.on('error', function error (err) { + if (forwardError || !(err.statusCode < 500)) { + next(err) + return + } + + next() + }) + + // pipe + stream.pipe(res) + } +} + +/** + * Collapse all leading slashes into a single slash + * @private + */ +function collapseLeadingSlashes (str) { + for (var i = 0; i < str.length; i++) { + if (str[i] !== '/') { + break + } + } + + return i > 1 + ? '/' + str.substr(i) + : str +} + +/** + * Create a directory listener that just 404s. + * @private + */ + +function createNotFoundDirectoryListener () { + return function notFound () { + this.error(404) + } +} + +/** + * Create a directory listener that performs a redirect. + * @private + */ + +function createRedirectDirectoryListener () { + return function redirect () { + if (this.hasTrailingSlash()) { + this.error(404) + return + } + + // get original URL + var originalUrl = parseUrl.original(this.req) + + // append trailing slash + originalUrl.path = null + originalUrl.pathname = collapseLeadingSlashes(originalUrl.pathname + '/') + + // reformat the URL + var loc = encodeUrl(url.format(originalUrl)) + var msg = 'Redirecting to ' + escapeHtml(loc) + '\n' + var res = this.res + + // send redirect response + res.statusCode = 301 + res.setHeader('Content-Type', 'text/html; charset=UTF-8') + res.setHeader('Content-Length', Buffer.byteLength(msg)) + res.setHeader('X-Content-Type-Options', 'nosniff') + res.setHeader('Location', loc) + res.end(msg) + } +} diff --git a/node_modules/express/node_modules/serve-static/package.json b/node_modules/express/node_modules/serve-static/package.json new file mode 100644 index 0000000..0ba3cb5 --- /dev/null +++ b/node_modules/express/node_modules/serve-static/package.json @@ -0,0 +1,74 @@ +{ + "name": "serve-static", + "description": "Serve static files", + "version": "1.11.1", + "author": { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + }, + "license": "MIT", + "repository": { + "type": "git", + "url": "git+https://github.com/expressjs/serve-static.git" + }, + "dependencies": { + "encodeurl": "~1.0.1", + "escape-html": "~1.0.3", + "parseurl": "~1.3.1", + "send": "0.14.1" + }, + "devDependencies": { + "eslint": "2.11.1", + "eslint-config-standard": "5.3.1", + "eslint-plugin-promise": "1.3.2", + "eslint-plugin-standard": "1.3.2", + "istanbul": "0.4.3", + "mocha": "2.5.3", + "supertest": "1.1.0" + }, + "files": [ + "LICENSE", + "HISTORY.md", + "index.js" + ], + "engines": { + "node": ">= 0.8.0" + }, + "scripts": { + "lint": "eslint **/*.js", + "test": "mocha --reporter spec --bail --check-leaks test/", + "test-ci": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter spec --check-leaks test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot --check-leaks test/" + }, + "gitHead": "b3a24df138ea2f2c43afcbee0dcce5badf4c78ae", + "bugs": { + "url": "https://github.com/expressjs/serve-static/issues" + }, + "homepage": "https://github.com/expressjs/serve-static#readme", + "_id": "serve-static@1.11.1", + "_shasum": "d6cce7693505f733c759de57befc1af76c0f0805", + "_from": "serve-static@>=1.11.1 <1.12.0", + "_npmVersion": "2.15.1", + "_nodeVersion": "4.4.3", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "dist": { + "shasum": "d6cce7693505f733c759de57befc1af76c0f0805", + "tarball": "https://registry.npmjs.org/serve-static/-/serve-static-1.11.1.tgz" + }, + "maintainers": [ + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + } + ], + "_npmOperationalInternal": { + "host": "packages-12-west.internal.npmjs.com", + "tmp": "tmp/serve-static-1.11.1.tgz_1465608601758_0.0030737747438251972" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/serve-static/-/serve-static-1.11.1.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/express/node_modules/type-is/HISTORY.md b/node_modules/express/node_modules/type-is/HISTORY.md new file mode 100644 index 0000000..5ec118c --- /dev/null +++ b/node_modules/express/node_modules/type-is/HISTORY.md @@ -0,0 +1,206 @@ +1.6.13 / 2016-05-18 +=================== + + * deps: mime-types@~2.1.11 + - Add new mime types + +1.6.12 / 2016-02-28 +=================== + + * deps: mime-types@~2.1.10 + - Add new mime types + - Fix extension of `application/dash+xml` + - Update primary extension for `audio/mp4` + +1.6.11 / 2016-01-29 +=================== + + * deps: mime-types@~2.1.9 + - Add new mime types + +1.6.10 / 2015-12-01 +=================== + + * deps: mime-types@~2.1.8 + - Add new mime types + +1.6.9 / 2015-09-27 +================== + + * deps: mime-types@~2.1.7 + - Add new mime types + +1.6.8 / 2015-09-04 +================== + + * deps: mime-types@~2.1.6 + - Add new mime types + +1.6.7 / 2015-08-20 +================== + + * Fix type error when given invalid type to match against + * deps: mime-types@~2.1.5 + - Add new mime types + +1.6.6 / 2015-07-31 +================== + + * deps: mime-types@~2.1.4 + - Add new mime types + +1.6.5 / 2015-07-16 +================== + + * deps: mime-types@~2.1.3 + - Add new mime types + +1.6.4 / 2015-07-01 +================== + + * deps: mime-types@~2.1.2 + - Add new mime types + * perf: enable strict mode + * perf: remove argument reassignment + +1.6.3 / 2015-06-08 +================== + + * deps: mime-types@~2.1.1 + - Add new mime types + * perf: reduce try block size + * perf: remove bitwise operations + +1.6.2 / 2015-05-10 +================== + + * deps: mime-types@~2.0.11 + - Add new mime types + +1.6.1 / 2015-03-13 +================== + + * deps: mime-types@~2.0.10 + - Add new mime types + +1.6.0 / 2015-02-12 +================== + + * fix false-positives in `hasBody` `Transfer-Encoding` check + * support wildcard for both type and subtype (`*/*`) + +1.5.7 / 2015-02-09 +================== + + * fix argument reassignment + * deps: mime-types@~2.0.9 + - Add new mime types + +1.5.6 / 2015-01-29 +================== + + * deps: mime-types@~2.0.8 + - Add new mime types + +1.5.5 / 2014-12-30 +================== + + * deps: mime-types@~2.0.7 + - Add new mime types + - Fix missing extensions + - Fix various invalid MIME type entries + - Remove example template MIME types + - deps: mime-db@~1.5.0 + +1.5.4 / 2014-12-10 +================== + + * deps: mime-types@~2.0.4 + - Add new mime types + - deps: mime-db@~1.3.0 + +1.5.3 / 2014-11-09 +================== + + * deps: mime-types@~2.0.3 + - Add new mime types + - deps: mime-db@~1.2.0 + +1.5.2 / 2014-09-28 +================== + + * deps: mime-types@~2.0.2 + - Add new mime types + - deps: mime-db@~1.1.0 + +1.5.1 / 2014-09-07 +================== + + * Support Node.js 0.6 + * deps: media-typer@0.3.0 + * deps: mime-types@~2.0.1 + - Support Node.js 0.6 + +1.5.0 / 2014-09-05 +================== + + * fix `hasbody` to be true for `content-length: 0` + +1.4.0 / 2014-09-02 +================== + + * update mime-types + +1.3.2 / 2014-06-24 +================== + + * use `~` range on mime-types + +1.3.1 / 2014-06-19 +================== + + * fix global variable leak + +1.3.0 / 2014-06-19 +================== + + * improve type parsing + + - invalid media type never matches + - media type not case-sensitive + - extra LWS does not affect results + +1.2.2 / 2014-06-19 +================== + + * fix behavior on unknown type argument + +1.2.1 / 2014-06-03 +================== + + * switch dependency from `mime` to `mime-types@1.0.0` + +1.2.0 / 2014-05-11 +================== + + * support suffix matching: + + - `+json` matches `application/vnd+json` + - `*/vnd+json` matches `application/vnd+json` + - `application/*+json` matches `application/vnd+json` + +1.1.0 / 2014-04-12 +================== + + * add non-array values support + * expose internal utilities: + + - `.is()` + - `.hasBody()` + - `.normalize()` + - `.match()` + +1.0.1 / 2014-03-30 +================== + + * add `multipart` as a shorthand diff --git a/node_modules/express/node_modules/type-is/LICENSE b/node_modules/express/node_modules/type-is/LICENSE new file mode 100644 index 0000000..386b7b6 --- /dev/null +++ b/node_modules/express/node_modules/type-is/LICENSE @@ -0,0 +1,23 @@ +(The MIT License) + +Copyright (c) 2014 Jonathan Ong +Copyright (c) 2014-2015 Douglas Christopher Wilson + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/express/node_modules/type-is/README.md b/node_modules/express/node_modules/type-is/README.md new file mode 100644 index 0000000..008a7af --- /dev/null +++ b/node_modules/express/node_modules/type-is/README.md @@ -0,0 +1,136 @@ +# type-is + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Node.js Version][node-version-image]][node-version-url] +[![Build Status][travis-image]][travis-url] +[![Test Coverage][coveralls-image]][coveralls-url] + +Infer the content-type of a request. + +### Install + +```sh +$ npm install type-is +``` + +## API + +```js +var http = require('http') +var is = require('type-is') + +http.createServer(function (req, res) { + var istext = is(req, ['text/*']) + res.end('you ' + (istext ? 'sent' : 'did not send') + ' me text') +}) +``` + +### type = is(request, types) + +`request` is the node HTTP request. `types` is an array of types. + +```js +// req.headers.content-type = 'application/json' + +is(req, ['json']) // 'json' +is(req, ['html', 'json']) // 'json' +is(req, ['application/*']) // 'application/json' +is(req, ['application/json']) // 'application/json' + +is(req, ['html']) // false +``` + +### is.hasBody(request) + +Returns a Boolean if the given `request` has a body, regardless of the +`Content-Type` header. + +Having a body has no relation to how large the body is (it may be 0 bytes). +This is similar to how file existence works. If a body does exist, then this +indicates that there is data to read from the Node.js request stream. + +```js +if (is.hasBody(req)) { + // read the body, since there is one + + req.on('data', function (chunk) { + // ... + }) +} +``` + +### type = is.is(mediaType, types) + +`mediaType` is the [media type](https://tools.ietf.org/html/rfc6838) string. `types` is an array of types. + +```js +var mediaType = 'application/json' + +is.is(mediaType, ['json']) // 'json' +is.is(mediaType, ['html', 'json']) // 'json' +is.is(mediaType, ['application/*']) // 'application/json' +is.is(mediaType, ['application/json']) // 'application/json' + +is.is(mediaType, ['html']) // false +``` + +### Each type can be: + +- An extension name such as `json`. This name will be returned if matched. +- A mime type such as `application/json`. +- A mime type with a wildcard such as `*/*` or `*/json` or `application/*`. The full mime type will be returned if matched. +- A suffix such as `+json`. This can be combined with a wildcard such as `*/vnd+json` or `application/*+json`. The full mime type will be returned if matched. + +`false` will be returned if no type matches or the content type is invalid. + +`null` will be returned if the request does not have a body. + +## Examples + +#### Example body parser + +```js +var is = require('type-is'); + +function bodyParser(req, res, next) { + if (!is.hasBody(req)) { + return next() + } + + switch (is(req, ['urlencoded', 'json', 'multipart'])) { + case 'urlencoded': + // parse urlencoded body + throw new Error('implement urlencoded body parsing') + break + case 'json': + // parse json body + throw new Error('implement json body parsing') + break + case 'multipart': + // parse multipart body + throw new Error('implement multipart body parsing') + break + default: + // 415 error code + res.statusCode = 415 + res.end() + return + } +} +``` + +## License + +[MIT](LICENSE) + +[npm-image]: https://img.shields.io/npm/v/type-is.svg +[npm-url]: https://npmjs.org/package/type-is +[node-version-image]: https://img.shields.io/node/v/type-is.svg +[node-version-url]: https://nodejs.org/en/download/ +[travis-image]: https://img.shields.io/travis/jshttp/type-is/master.svg +[travis-url]: https://travis-ci.org/jshttp/type-is +[coveralls-image]: https://img.shields.io/coveralls/jshttp/type-is/master.svg +[coveralls-url]: https://coveralls.io/r/jshttp/type-is?branch=master +[downloads-image]: https://img.shields.io/npm/dm/type-is.svg +[downloads-url]: https://npmjs.org/package/type-is diff --git a/node_modules/express/node_modules/type-is/index.js b/node_modules/express/node_modules/type-is/index.js new file mode 100644 index 0000000..4da7301 --- /dev/null +++ b/node_modules/express/node_modules/type-is/index.js @@ -0,0 +1,262 @@ +/*! + * type-is + * Copyright(c) 2014 Jonathan Ong + * Copyright(c) 2014-2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module dependencies. + * @private + */ + +var typer = require('media-typer') +var mime = require('mime-types') + +/** + * Module exports. + * @public + */ + +module.exports = typeofrequest +module.exports.is = typeis +module.exports.hasBody = hasbody +module.exports.normalize = normalize +module.exports.match = mimeMatch + +/** + * Compare a `value` content-type with `types`. + * Each `type` can be an extension like `html`, + * a special shortcut like `multipart` or `urlencoded`, + * or a mime type. + * + * If no types match, `false` is returned. + * Otherwise, the first `type` that matches is returned. + * + * @param {String} value + * @param {Array} types + * @public + */ + +function typeis (value, types_) { + var i + var types = types_ + + // remove parameters and normalize + var val = tryNormalizeType(value) + + // no type or invalid + if (!val) { + return false + } + + // support flattened arguments + if (types && !Array.isArray(types)) { + types = new Array(arguments.length - 1) + for (i = 0; i < types.length; i++) { + types[i] = arguments[i + 1] + } + } + + // no types, return the content type + if (!types || !types.length) { + return val + } + + var type + for (i = 0; i < types.length; i++) { + if (mimeMatch(normalize(type = types[i]), val)) { + return type[0] === '+' || type.indexOf('*') !== -1 + ? val + : type + } + } + + // no matches + return false +} + +/** + * Check if a request has a request body. + * A request with a body __must__ either have `transfer-encoding` + * or `content-length` headers set. + * http://www.w3.org/Protocols/rfc2616/rfc2616-sec4.html#sec4.3 + * + * @param {Object} request + * @return {Boolean} + * @public + */ + +function hasbody (req) { + return req.headers['transfer-encoding'] !== undefined || + !isNaN(req.headers['content-length']) +} + +/** + * Check if the incoming request contains the "Content-Type" + * header field, and it contains any of the give mime `type`s. + * If there is no request body, `null` is returned. + * If there is no content type, `false` is returned. + * Otherwise, it returns the first `type` that matches. + * + * Examples: + * + * // With Content-Type: text/html; charset=utf-8 + * this.is('html'); // => 'html' + * this.is('text/html'); // => 'text/html' + * this.is('text/*', 'application/json'); // => 'text/html' + * + * // When Content-Type is application/json + * this.is('json', 'urlencoded'); // => 'json' + * this.is('application/json'); // => 'application/json' + * this.is('html', 'application/*'); // => 'application/json' + * + * this.is('html'); // => false + * + * @param {String|Array} types... + * @return {String|false|null} + * @public + */ + +function typeofrequest (req, types_) { + var types = types_ + + // no body + if (!hasbody(req)) { + return null + } + + // support flattened arguments + if (arguments.length > 2) { + types = new Array(arguments.length - 1) + for (var i = 0; i < types.length; i++) { + types[i] = arguments[i + 1] + } + } + + // request content type + var value = req.headers['content-type'] + + return typeis(value, types) +} + +/** + * Normalize a mime type. + * If it's a shorthand, expand it to a valid mime type. + * + * In general, you probably want: + * + * var type = is(req, ['urlencoded', 'json', 'multipart']); + * + * Then use the appropriate body parsers. + * These three are the most common request body types + * and are thus ensured to work. + * + * @param {String} type + * @private + */ + +function normalize (type) { + if (typeof type !== 'string') { + // invalid type + return false + } + + switch (type) { + case 'urlencoded': + return 'application/x-www-form-urlencoded' + case 'multipart': + return 'multipart/*' + } + + if (type[0] === '+') { + // "+json" -> "*/*+json" expando + return '*/*' + type + } + + return type.indexOf('/') === -1 + ? mime.lookup(type) + : type +} + +/** + * Check if `expected` mime type + * matches `actual` mime type with + * wildcard and +suffix support. + * + * @param {String} expected + * @param {String} actual + * @return {Boolean} + * @private + */ + +function mimeMatch (expected, actual) { + // invalid type + if (expected === false) { + return false + } + + // split types + var actualParts = actual.split('/') + var expectedParts = expected.split('/') + + // invalid format + if (actualParts.length !== 2 || expectedParts.length !== 2) { + return false + } + + // validate type + if (expectedParts[0] !== '*' && expectedParts[0] !== actualParts[0]) { + return false + } + + // validate suffix wildcard + if (expectedParts[1].substr(0, 2) === '*+') { + return expectedParts[1].length <= actualParts[1].length + 1 && + expectedParts[1].substr(1) === actualParts[1].substr(1 - expectedParts[1].length) + } + + // validate subtype + if (expectedParts[1] !== '*' && expectedParts[1] !== actualParts[1]) { + return false + } + + return true +} + +/** + * Normalize a type and remove parameters. + * + * @param {string} value + * @return {string} + * @private + */ + +function normalizeType (value) { + // parse the type + var type = typer.parse(value) + + // remove the parameters + type.parameters = undefined + + // reformat it + return typer.format(type) +} + +/** + * Try to normalize a type and remove parameters. + * + * @param {string} value + * @return {string} + * @private + */ + +function tryNormalizeType (value) { + try { + return normalizeType(value) + } catch (err) { + return null + } +} diff --git a/node_modules/express/node_modules/type-is/node_modules/media-typer/HISTORY.md b/node_modules/express/node_modules/type-is/node_modules/media-typer/HISTORY.md new file mode 100644 index 0000000..62c2003 --- /dev/null +++ b/node_modules/express/node_modules/type-is/node_modules/media-typer/HISTORY.md @@ -0,0 +1,22 @@ +0.3.0 / 2014-09-07 +================== + + * Support Node.js 0.6 + * Throw error when parameter format invalid on parse + +0.2.0 / 2014-06-18 +================== + + * Add `typer.format()` to format media types + +0.1.0 / 2014-06-17 +================== + + * Accept `req` as argument to `parse` + * Accept `res` as argument to `parse` + * Parse media type with extra LWS between type and first parameter + +0.0.0 / 2014-06-13 +================== + + * Initial implementation diff --git a/node_modules/express/node_modules/type-is/node_modules/media-typer/LICENSE b/node_modules/express/node_modules/type-is/node_modules/media-typer/LICENSE new file mode 100644 index 0000000..b7dce6c --- /dev/null +++ b/node_modules/express/node_modules/type-is/node_modules/media-typer/LICENSE @@ -0,0 +1,22 @@ +(The MIT License) + +Copyright (c) 2014 Douglas Christopher Wilson + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/express/node_modules/type-is/node_modules/media-typer/README.md b/node_modules/express/node_modules/type-is/node_modules/media-typer/README.md new file mode 100644 index 0000000..d8df623 --- /dev/null +++ b/node_modules/express/node_modules/type-is/node_modules/media-typer/README.md @@ -0,0 +1,81 @@ +# media-typer + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Node.js Version][node-version-image]][node-version-url] +[![Build Status][travis-image]][travis-url] +[![Test Coverage][coveralls-image]][coveralls-url] + +Simple RFC 6838 media type parser + +## Installation + +```sh +$ npm install media-typer +``` + +## API + +```js +var typer = require('media-typer') +``` + +### typer.parse(string) + +```js +var obj = typer.parse('image/svg+xml; charset=utf-8') +``` + +Parse a media type string. This will return an object with the following +properties (examples are shown for the string `'image/svg+xml; charset=utf-8'`): + + - `type`: The type of the media type (always lower case). Example: `'image'` + + - `subtype`: The subtype of the media type (always lower case). Example: `'svg'` + + - `suffix`: The suffix of the media type (always lower case). Example: `'xml'` + + - `parameters`: An object of the parameters in the media type (name of parameter always lower case). Example: `{charset: 'utf-8'}` + +### typer.parse(req) + +```js +var obj = typer.parse(req) +``` + +Parse the `content-type` header from the given `req`. Short-cut for +`typer.parse(req.headers['content-type'])`. + +### typer.parse(res) + +```js +var obj = typer.parse(res) +``` + +Parse the `content-type` header set on the given `res`. Short-cut for +`typer.parse(res.getHeader('content-type'))`. + +### typer.format(obj) + +```js +var obj = typer.format({type: 'image', subtype: 'svg', suffix: 'xml'}) +``` + +Format an object into a media type string. This will return a string of the +mime type for the given object. For the properties of the object, see the +documentation for `typer.parse(string)`. + +## License + +[MIT](LICENSE) + +[npm-image]: https://img.shields.io/npm/v/media-typer.svg?style=flat +[npm-url]: https://npmjs.org/package/media-typer +[node-version-image]: https://img.shields.io/badge/node.js-%3E%3D_0.6-brightgreen.svg?style=flat +[node-version-url]: http://nodejs.org/download/ +[travis-image]: https://img.shields.io/travis/jshttp/media-typer.svg?style=flat +[travis-url]: https://travis-ci.org/jshttp/media-typer +[coveralls-image]: https://img.shields.io/coveralls/jshttp/media-typer.svg?style=flat +[coveralls-url]: https://coveralls.io/r/jshttp/media-typer +[downloads-image]: https://img.shields.io/npm/dm/media-typer.svg?style=flat +[downloads-url]: https://npmjs.org/package/media-typer diff --git a/node_modules/express/node_modules/type-is/node_modules/media-typer/index.js b/node_modules/express/node_modules/type-is/node_modules/media-typer/index.js new file mode 100644 index 0000000..07f7295 --- /dev/null +++ b/node_modules/express/node_modules/type-is/node_modules/media-typer/index.js @@ -0,0 +1,270 @@ +/*! + * media-typer + * Copyright(c) 2014 Douglas Christopher Wilson + * MIT Licensed + */ + +/** + * RegExp to match *( ";" parameter ) in RFC 2616 sec 3.7 + * + * parameter = token "=" ( token | quoted-string ) + * token = 1* + * separators = "(" | ")" | "<" | ">" | "@" + * | "," | ";" | ":" | "\" | <"> + * | "/" | "[" | "]" | "?" | "=" + * | "{" | "}" | SP | HT + * quoted-string = ( <"> *(qdtext | quoted-pair ) <"> ) + * qdtext = > + * quoted-pair = "\" CHAR + * CHAR = + * TEXT = + * LWS = [CRLF] 1*( SP | HT ) + * CRLF = CR LF + * CR = + * LF = + * SP = + * SHT = + * CTL = + * OCTET = + */ +var paramRegExp = /; *([!#$%&'\*\+\-\.0-9A-Z\^_`a-z\|~]+) *= *("(?:[ !\u0023-\u005b\u005d-\u007e\u0080-\u00ff]|\\[\u0020-\u007e])*"|[!#$%&'\*\+\-\.0-9A-Z\^_`a-z\|~]+) */g; +var textRegExp = /^[\u0020-\u007e\u0080-\u00ff]+$/ +var tokenRegExp = /^[!#$%&'\*\+\-\.0-9A-Z\^_`a-z\|~]+$/ + +/** + * RegExp to match quoted-pair in RFC 2616 + * + * quoted-pair = "\" CHAR + * CHAR = + */ +var qescRegExp = /\\([\u0000-\u007f])/g; + +/** + * RegExp to match chars that must be quoted-pair in RFC 2616 + */ +var quoteRegExp = /([\\"])/g; + +/** + * RegExp to match type in RFC 6838 + * + * type-name = restricted-name + * subtype-name = restricted-name + * restricted-name = restricted-name-first *126restricted-name-chars + * restricted-name-first = ALPHA / DIGIT + * restricted-name-chars = ALPHA / DIGIT / "!" / "#" / + * "$" / "&" / "-" / "^" / "_" + * restricted-name-chars =/ "." ; Characters before first dot always + * ; specify a facet name + * restricted-name-chars =/ "+" ; Characters after last plus always + * ; specify a structured syntax suffix + * ALPHA = %x41-5A / %x61-7A ; A-Z / a-z + * DIGIT = %x30-39 ; 0-9 + */ +var subtypeNameRegExp = /^[A-Za-z0-9][A-Za-z0-9!#$&^_.-]{0,126}$/ +var typeNameRegExp = /^[A-Za-z0-9][A-Za-z0-9!#$&^_-]{0,126}$/ +var typeRegExp = /^ *([A-Za-z0-9][A-Za-z0-9!#$&^_-]{0,126})\/([A-Za-z0-9][A-Za-z0-9!#$&^_.+-]{0,126}) *$/; + +/** + * Module exports. + */ + +exports.format = format +exports.parse = parse + +/** + * Format object to media type. + * + * @param {object} obj + * @return {string} + * @api public + */ + +function format(obj) { + if (!obj || typeof obj !== 'object') { + throw new TypeError('argument obj is required') + } + + var parameters = obj.parameters + var subtype = obj.subtype + var suffix = obj.suffix + var type = obj.type + + if (!type || !typeNameRegExp.test(type)) { + throw new TypeError('invalid type') + } + + if (!subtype || !subtypeNameRegExp.test(subtype)) { + throw new TypeError('invalid subtype') + } + + // format as type/subtype + var string = type + '/' + subtype + + // append +suffix + if (suffix) { + if (!typeNameRegExp.test(suffix)) { + throw new TypeError('invalid suffix') + } + + string += '+' + suffix + } + + // append parameters + if (parameters && typeof parameters === 'object') { + var param + var params = Object.keys(parameters).sort() + + for (var i = 0; i < params.length; i++) { + param = params[i] + + if (!tokenRegExp.test(param)) { + throw new TypeError('invalid parameter name') + } + + string += '; ' + param + '=' + qstring(parameters[param]) + } + } + + return string +} + +/** + * Parse media type to object. + * + * @param {string|object} string + * @return {Object} + * @api public + */ + +function parse(string) { + if (!string) { + throw new TypeError('argument string is required') + } + + // support req/res-like objects as argument + if (typeof string === 'object') { + string = getcontenttype(string) + } + + if (typeof string !== 'string') { + throw new TypeError('argument string is required to be a string') + } + + var index = string.indexOf(';') + var type = index !== -1 + ? string.substr(0, index) + : string + + var key + var match + var obj = splitType(type) + var params = {} + var value + + paramRegExp.lastIndex = index + + while (match = paramRegExp.exec(string)) { + if (match.index !== index) { + throw new TypeError('invalid parameter format') + } + + index += match[0].length + key = match[1].toLowerCase() + value = match[2] + + if (value[0] === '"') { + // remove quotes and escapes + value = value + .substr(1, value.length - 2) + .replace(qescRegExp, '$1') + } + + params[key] = value + } + + if (index !== -1 && index !== string.length) { + throw new TypeError('invalid parameter format') + } + + obj.parameters = params + + return obj +} + +/** + * Get content-type from req/res objects. + * + * @param {object} + * @return {Object} + * @api private + */ + +function getcontenttype(obj) { + if (typeof obj.getHeader === 'function') { + // res-like + return obj.getHeader('content-type') + } + + if (typeof obj.headers === 'object') { + // req-like + return obj.headers && obj.headers['content-type'] + } +} + +/** + * Quote a string if necessary. + * + * @param {string} val + * @return {string} + * @api private + */ + +function qstring(val) { + var str = String(val) + + // no need to quote tokens + if (tokenRegExp.test(str)) { + return str + } + + if (str.length > 0 && !textRegExp.test(str)) { + throw new TypeError('invalid parameter value') + } + + return '"' + str.replace(quoteRegExp, '\\$1') + '"' +} + +/** + * Simply "type/subtype+siffx" into parts. + * + * @param {string} string + * @return {Object} + * @api private + */ + +function splitType(string) { + var match = typeRegExp.exec(string.toLowerCase()) + + if (!match) { + throw new TypeError('invalid media type') + } + + var type = match[1] + var subtype = match[2] + var suffix + + // suffix after last + + var index = subtype.lastIndexOf('+') + if (index !== -1) { + suffix = subtype.substr(index + 1) + subtype = subtype.substr(0, index) + } + + var obj = { + type: type, + subtype: subtype, + suffix: suffix + } + + return obj +} diff --git a/node_modules/express/node_modules/type-is/node_modules/media-typer/package.json b/node_modules/express/node_modules/type-is/node_modules/media-typer/package.json new file mode 100644 index 0000000..bd88bf2 --- /dev/null +++ b/node_modules/express/node_modules/type-is/node_modules/media-typer/package.json @@ -0,0 +1,58 @@ +{ + "name": "media-typer", + "description": "Simple RFC 6838 media type parser and formatter", + "version": "0.3.0", + "author": { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + }, + "license": "MIT", + "repository": { + "type": "git", + "url": "git+https://github.com/jshttp/media-typer.git" + }, + "devDependencies": { + "istanbul": "0.3.2", + "mocha": "~1.21.4", + "should": "~4.0.4" + }, + "files": [ + "LICENSE", + "HISTORY.md", + "index.js" + ], + "engines": { + "node": ">= 0.6" + }, + "scripts": { + "test": "mocha --reporter spec --check-leaks --bail test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot --check-leaks test/", + "test-travis": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter spec --check-leaks test/" + }, + "gitHead": "d49d41ffd0bb5a0655fa44a59df2ec0bfc835b16", + "bugs": { + "url": "https://github.com/jshttp/media-typer/issues" + }, + "homepage": "https://github.com/jshttp/media-typer", + "_id": "media-typer@0.3.0", + "_shasum": "8710d7af0aa626f8fffa1ce00168545263255748", + "_from": "media-typer@0.3.0", + "_npmVersion": "1.4.21", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "maintainers": [ + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + } + ], + "dist": { + "shasum": "8710d7af0aa626f8fffa1ce00168545263255748", + "tarball": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/express/node_modules/type-is/node_modules/mime-types/HISTORY.md b/node_modules/express/node_modules/type-is/node_modules/mime-types/HISTORY.md new file mode 100644 index 0000000..8c0383a --- /dev/null +++ b/node_modules/express/node_modules/type-is/node_modules/mime-types/HISTORY.md @@ -0,0 +1,204 @@ +2.1.12 / 2016-09-18 +=================== + + * deps: mime-db@~1.24.0 + - Add new mime types + - Add `audio/mp3` + +2.1.11 / 2016-05-01 +=================== + + * deps: mime-db@~1.23.0 + - Add new mime types + +2.1.10 / 2016-02-15 +=================== + + * deps: mime-db@~1.22.0 + - Add new mime types + - Fix extension of `application/dash+xml` + - Update primary extension for `audio/mp4` + +2.1.9 / 2016-01-06 +================== + + * deps: mime-db@~1.21.0 + - Add new mime types + +2.1.8 / 2015-11-30 +================== + + * deps: mime-db@~1.20.0 + - Add new mime types + +2.1.7 / 2015-09-20 +================== + + * deps: mime-db@~1.19.0 + - Add new mime types + +2.1.6 / 2015-09-03 +================== + + * deps: mime-db@~1.18.0 + - Add new mime types + +2.1.5 / 2015-08-20 +================== + + * deps: mime-db@~1.17.0 + - Add new mime types + +2.1.4 / 2015-07-30 +================== + + * deps: mime-db@~1.16.0 + - Add new mime types + +2.1.3 / 2015-07-13 +================== + + * deps: mime-db@~1.15.0 + - Add new mime types + +2.1.2 / 2015-06-25 +================== + + * deps: mime-db@~1.14.0 + - Add new mime types + +2.1.1 / 2015-06-08 +================== + + * perf: fix deopt during mapping + +2.1.0 / 2015-06-07 +================== + + * Fix incorrectly treating extension-less file name as extension + - i.e. `'path/to/json'` will no longer return `application/json` + * Fix `.charset(type)` to accept parameters + * Fix `.charset(type)` to match case-insensitive + * Improve generation of extension to MIME mapping + * Refactor internals for readability and no argument reassignment + * Prefer `application/*` MIME types from the same source + * Prefer any type over `application/octet-stream` + * deps: mime-db@~1.13.0 + - Add nginx as a source + - Add new mime types + +2.0.14 / 2015-06-06 +=================== + + * deps: mime-db@~1.12.0 + - Add new mime types + +2.0.13 / 2015-05-31 +=================== + + * deps: mime-db@~1.11.0 + - Add new mime types + +2.0.12 / 2015-05-19 +=================== + + * deps: mime-db@~1.10.0 + - Add new mime types + +2.0.11 / 2015-05-05 +=================== + + * deps: mime-db@~1.9.1 + - Add new mime types + +2.0.10 / 2015-03-13 +=================== + + * deps: mime-db@~1.8.0 + - Add new mime types + +2.0.9 / 2015-02-09 +================== + + * deps: mime-db@~1.7.0 + - Add new mime types + - Community extensions ownership transferred from `node-mime` + +2.0.8 / 2015-01-29 +================== + + * deps: mime-db@~1.6.0 + - Add new mime types + +2.0.7 / 2014-12-30 +================== + + * deps: mime-db@~1.5.0 + - Add new mime types + - Fix various invalid MIME type entries + +2.0.6 / 2014-12-30 +================== + + * deps: mime-db@~1.4.0 + - Add new mime types + - Fix various invalid MIME type entries + - Remove example template MIME types + +2.0.5 / 2014-12-29 +================== + + * deps: mime-db@~1.3.1 + - Fix missing extensions + +2.0.4 / 2014-12-10 +================== + + * deps: mime-db@~1.3.0 + - Add new mime types + +2.0.3 / 2014-11-09 +================== + + * deps: mime-db@~1.2.0 + - Add new mime types + +2.0.2 / 2014-09-28 +================== + + * deps: mime-db@~1.1.0 + - Add new mime types + - Add additional compressible + - Update charsets + +2.0.1 / 2014-09-07 +================== + + * Support Node.js 0.6 + +2.0.0 / 2014-09-02 +================== + + * Use `mime-db` + * Remove `.define()` + +1.0.2 / 2014-08-04 +================== + + * Set charset=utf-8 for `text/javascript` + +1.0.1 / 2014-06-24 +================== + + * Add `text/jsx` type + +1.0.0 / 2014-05-12 +================== + + * Return `false` for unknown types + * Set charset=utf-8 for `application/json` + +0.1.0 / 2014-05-02 +================== + + * Initial release diff --git a/node_modules/express/node_modules/type-is/node_modules/mime-types/LICENSE b/node_modules/express/node_modules/type-is/node_modules/mime-types/LICENSE new file mode 100644 index 0000000..0616607 --- /dev/null +++ b/node_modules/express/node_modules/type-is/node_modules/mime-types/LICENSE @@ -0,0 +1,23 @@ +(The MIT License) + +Copyright (c) 2014 Jonathan Ong +Copyright (c) 2015 Douglas Christopher Wilson + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/express/node_modules/type-is/node_modules/mime-types/README.md b/node_modules/express/node_modules/type-is/node_modules/mime-types/README.md new file mode 100644 index 0000000..e77d615 --- /dev/null +++ b/node_modules/express/node_modules/type-is/node_modules/mime-types/README.md @@ -0,0 +1,103 @@ +# mime-types + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Node.js Version][node-version-image]][node-version-url] +[![Build Status][travis-image]][travis-url] +[![Test Coverage][coveralls-image]][coveralls-url] + +The ultimate javascript content-type utility. + +Similar to [node-mime](https://github.com/broofa/node-mime), except: + +- __No fallbacks.__ Instead of naively returning the first available type, `mime-types` simply returns `false`, + so do `var type = mime.lookup('unrecognized') || 'application/octet-stream'`. +- No `new Mime()` business, so you could do `var lookup = require('mime-types').lookup`. +- Additional mime types are added such as jade and stylus via [mime-db](https://github.com/jshttp/mime-db) +- No `.define()` functionality + +Otherwise, the API is compatible. + +## Install + +```sh +$ npm install mime-types +``` + +## Adding Types + +All mime types are based on [mime-db](https://github.com/jshttp/mime-db), +so open a PR there if you'd like to add mime types. + +## API + +```js +var mime = require('mime-types') +``` + +All functions return `false` if input is invalid or not found. + +### mime.lookup(path) + +Lookup the content-type associated with a file. + +```js +mime.lookup('json') // 'application/json' +mime.lookup('.md') // 'text/x-markdown' +mime.lookup('file.html') // 'text/html' +mime.lookup('folder/file.js') // 'application/javascript' +mime.lookup('folder/.htaccess') // false + +mime.lookup('cats') // false +``` + +### mime.contentType(type) + +Create a full content-type header given a content-type or extension. + +```js +mime.contentType('markdown') // 'text/x-markdown; charset=utf-8' +mime.contentType('file.json') // 'application/json; charset=utf-8' + +// from a full path +mime.contentType(path.extname('/path/to/file.json')) // 'application/json; charset=utf-8' +``` + +### mime.extension(type) + +Get the default extension for a content-type. + +```js +mime.extension('application/octet-stream') // 'bin' +``` + +### mime.charset(type) + +Lookup the implied default charset of a content-type. + +```js +mime.charset('text/x-markdown') // 'UTF-8' +``` + +### var type = mime.types[extension] + +A map of content-types by extension. + +### [extensions...] = mime.extensions[type] + +A map of extensions by content-type. + +## License + +[MIT](LICENSE) + +[npm-image]: https://img.shields.io/npm/v/mime-types.svg +[npm-url]: https://npmjs.org/package/mime-types +[node-version-image]: https://img.shields.io/node/v/mime-types.svg +[node-version-url]: https://nodejs.org/en/download/ +[travis-image]: https://img.shields.io/travis/jshttp/mime-types/master.svg +[travis-url]: https://travis-ci.org/jshttp/mime-types +[coveralls-image]: https://img.shields.io/coveralls/jshttp/mime-types/master.svg +[coveralls-url]: https://coveralls.io/r/jshttp/mime-types +[downloads-image]: https://img.shields.io/npm/dm/mime-types.svg +[downloads-url]: https://npmjs.org/package/mime-types diff --git a/node_modules/express/node_modules/type-is/node_modules/mime-types/index.js b/node_modules/express/node_modules/type-is/node_modules/mime-types/index.js new file mode 100644 index 0000000..9226ca5 --- /dev/null +++ b/node_modules/express/node_modules/type-is/node_modules/mime-types/index.js @@ -0,0 +1,188 @@ +/*! + * mime-types + * Copyright(c) 2014 Jonathan Ong + * Copyright(c) 2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module dependencies. + * @private + */ + +var db = require('mime-db') +var extname = require('path').extname + +/** + * Module variables. + * @private + */ + +var extractTypeRegExp = /^\s*([^;\s]*)(?:;|\s|$)/ +var textTypeRegExp = /^text\//i + +/** + * Module exports. + * @public + */ + +exports.charset = charset +exports.charsets = { lookup: charset } +exports.contentType = contentType +exports.extension = extension +exports.extensions = Object.create(null) +exports.lookup = lookup +exports.types = Object.create(null) + +// Populate the extensions/types maps +populateMaps(exports.extensions, exports.types) + +/** + * Get the default charset for a MIME type. + * + * @param {string} type + * @return {boolean|string} + */ + +function charset (type) { + if (!type || typeof type !== 'string') { + return false + } + + // TODO: use media-typer + var match = extractTypeRegExp.exec(type) + var mime = match && db[match[1].toLowerCase()] + + if (mime && mime.charset) { + return mime.charset + } + + // default text/* to utf-8 + if (match && textTypeRegExp.test(match[1])) { + return 'UTF-8' + } + + return false +} + +/** + * Create a full Content-Type header given a MIME type or extension. + * + * @param {string} str + * @return {boolean|string} + */ + +function contentType (str) { + // TODO: should this even be in this module? + if (!str || typeof str !== 'string') { + return false + } + + var mime = str.indexOf('/') === -1 + ? exports.lookup(str) + : str + + if (!mime) { + return false + } + + // TODO: use content-type or other module + if (mime.indexOf('charset') === -1) { + var charset = exports.charset(mime) + if (charset) mime += '; charset=' + charset.toLowerCase() + } + + return mime +} + +/** + * Get the default extension for a MIME type. + * + * @param {string} type + * @return {boolean|string} + */ + +function extension (type) { + if (!type || typeof type !== 'string') { + return false + } + + // TODO: use media-typer + var match = extractTypeRegExp.exec(type) + + // get extensions + var exts = match && exports.extensions[match[1].toLowerCase()] + + if (!exts || !exts.length) { + return false + } + + return exts[0] +} + +/** + * Lookup the MIME type for a file path/extension. + * + * @param {string} path + * @return {boolean|string} + */ + +function lookup (path) { + if (!path || typeof path !== 'string') { + return false + } + + // get the extension ("ext" or ".ext" or full path) + var extension = extname('x.' + path) + .toLowerCase() + .substr(1) + + if (!extension) { + return false + } + + return exports.types[extension] || false +} + +/** + * Populate the extensions and types maps. + * @private + */ + +function populateMaps (extensions, types) { + // source preference (least -> most) + var preference = ['nginx', 'apache', undefined, 'iana'] + + Object.keys(db).forEach(function forEachMimeType (type) { + var mime = db[type] + var exts = mime.extensions + + if (!exts || !exts.length) { + return + } + + // mime -> extensions + extensions[type] = exts + + // extension -> mime + for (var i = 0; i < exts.length; i++) { + var extension = exts[i] + + if (types[extension]) { + var from = preference.indexOf(db[types[extension]].source) + var to = preference.indexOf(mime.source) + + if (types[extension] !== 'application/octet-stream' && + from > to || (from === to && types[extension].substr(0, 12) === 'application/')) { + // skip the remapping + continue + } + } + + // set the extension -> mime + types[extension] = type + } + }) +} diff --git a/node_modules/express/node_modules/type-is/node_modules/mime-types/node_modules/mime-db/HISTORY.md b/node_modules/express/node_modules/type-is/node_modules/mime-types/node_modules/mime-db/HISTORY.md new file mode 100644 index 0000000..d4796b5 --- /dev/null +++ b/node_modules/express/node_modules/type-is/node_modules/mime-types/node_modules/mime-db/HISTORY.md @@ -0,0 +1,365 @@ +1.24.0 / 2016-09-18 +=================== + + * Add `application/clue_info+xml` + * Add `application/geo+json` + * Add `application/lgr+xml` + * Add `application/vnd.amazon.mobi8-ebook` + * Add `application/vnd.chess-pgn` + * Add `application/vnd.comicbook+zip` + * Add `application/vnd.d2l.coursepackage1p0+zip` + * Add `application/vnd.espass-espass+zip` + * Add `application/vnd.nearst.inv+json` + * Add `application/vnd.oma.lwm2m+json` + * Add `application/vnd.oma.lwm2m+tlv` + * Add `application/vnd.quarantainenet` + * Add `application/vnd.rar` + * Add `audio/mp3` + * Add `image/dicom-rle` + * Add `image/emf` + * Add `image/jls` + * Add `image/wmf` + * Add `model/gltf+json` + * Add `text/vnd.ascii-art` + +1.23.0 / 2016-05-01 +=================== + + * Add `application/efi` + * Add `application/vnd.3gpp.sms+xml` + * Add `application/vnd.3lightssoftware.imagescal` + * Add `application/vnd.coreos.ignition+json` + * Add `application/vnd.desmume.movie` + * Add `application/vnd.onepager` + * Add `application/vnd.vel+json` + * Add `text/prs.prop.logic` + * Add `video/encaprtp` + * Add `video/h265` + * Add `video/iso.segment` + * Add `video/raptorfec` + * Add `video/rtploopback` + * Add `video/vnd.radgamettools.bink` + * Add `video/vnd.radgamettools.smacker` + * Add `video/vp8` + * Add extension `.3gpp` to `audio/3gpp` + +1.22.0 / 2016-02-15 +=================== + + * Add `application/ppsp-tracker+json` + * Add `application/problem+json` + * Add `application/problem+xml` + * Add `application/vnd.hdt` + * Add `application/vnd.ms-printschematicket+xml` + * Add `model/vnd.rosette.annotated-data-model` + * Add `text/slim` + * Add extension `.rng` to `application/xml` + * Fix extension of `application/dash+xml` to be `.mpd` + * Update primary extension to `.m4a` for `audio/mp4` + +1.21.0 / 2016-01-06 +=================== + + * Add `application/emergencycalldata.comment+xml` + * Add `application/emergencycalldata.deviceinfo+xml` + * Add `application/emergencycalldata.providerinfo+xml` + * Add `application/emergencycalldata.serviceinfo+xml` + * Add `application/emergencycalldata.subscriberinfo+xml` + * Add `application/vnd.filmit.zfc` + * Add `application/vnd.google-apps.document` + * Add `application/vnd.google-apps.presentation` + * Add `application/vnd.google-apps.spreadsheet` + * Add `application/vnd.mapbox-vector-tile` + * Add `application/vnd.ms-printdevicecapabilities+xml` + * Add `application/vnd.ms-windows.devicepairing` + * Add `application/vnd.ms-windows.nwprinting.oob` + * Add `application/vnd.tml` + * Add `audio/evs` + +1.20.0 / 2015-11-10 +=================== + + * Add `application/cdni` + * Add `application/csvm+json` + * Add `application/rfc+xml` + * Add `application/vnd.3gpp.access-transfer-events+xml` + * Add `application/vnd.3gpp.srvcc-ext+xml` + * Add `application/vnd.ms-windows.wsd.oob` + * Add `application/vnd.oxli.countgraph` + * Add `application/vnd.pagerduty+json` + * Add `text/x-suse-ymp` + +1.19.0 / 2015-09-17 +=================== + + * Add `application/vnd.3gpp-prose-pc3ch+xml` + * Add `application/vnd.3gpp.srvcc-info+xml` + * Add `application/vnd.apple.pkpass` + * Add `application/vnd.drive+json` + +1.18.0 / 2015-09-03 +=================== + + * Add `application/pkcs12` + * Add `application/vnd.3gpp-prose+xml` + * Add `application/vnd.3gpp.mid-call+xml` + * Add `application/vnd.3gpp.state-and-event-info+xml` + * Add `application/vnd.anki` + * Add `application/vnd.firemonkeys.cloudcell` + * Add `application/vnd.openblox.game+xml` + * Add `application/vnd.openblox.game-binary` + +1.17.0 / 2015-08-13 +=================== + + * Add `application/x-msdos-program` + * Add `audio/g711-0` + * Add `image/vnd.mozilla.apng` + * Add extension `.exe` to `application/x-msdos-program` + +1.16.0 / 2015-07-29 +=================== + + * Add `application/vnd.uri-map` + +1.15.0 / 2015-07-13 +=================== + + * Add `application/x-httpd-php` + +1.14.0 / 2015-06-25 +=================== + + * Add `application/scim+json` + * Add `application/vnd.3gpp.ussd+xml` + * Add `application/vnd.biopax.rdf+xml` + * Add `text/x-processing` + +1.13.0 / 2015-06-07 +=================== + + * Add nginx as a source + * Add `application/x-cocoa` + * Add `application/x-java-archive-diff` + * Add `application/x-makeself` + * Add `application/x-perl` + * Add `application/x-pilot` + * Add `application/x-redhat-package-manager` + * Add `application/x-sea` + * Add `audio/x-m4a` + * Add `audio/x-realaudio` + * Add `image/x-jng` + * Add `text/mathml` + +1.12.0 / 2015-06-05 +=================== + + * Add `application/bdoc` + * Add `application/vnd.hyperdrive+json` + * Add `application/x-bdoc` + * Add extension `.rtf` to `text/rtf` + +1.11.0 / 2015-05-31 +=================== + + * Add `audio/wav` + * Add `audio/wave` + * Add extension `.litcoffee` to `text/coffeescript` + * Add extension `.sfd-hdstx` to `application/vnd.hydrostatix.sof-data` + * Add extension `.n-gage` to `application/vnd.nokia.n-gage.symbian.install` + +1.10.0 / 2015-05-19 +=================== + + * Add `application/vnd.balsamiq.bmpr` + * Add `application/vnd.microsoft.portable-executable` + * Add `application/x-ns-proxy-autoconfig` + +1.9.1 / 2015-04-19 +================== + + * Remove `.json` extension from `application/manifest+json` + - This is causing bugs downstream + +1.9.0 / 2015-04-19 +================== + + * Add `application/manifest+json` + * Add `application/vnd.micro+json` + * Add `image/vnd.zbrush.pcx` + * Add `image/x-ms-bmp` + +1.8.0 / 2015-03-13 +================== + + * Add `application/vnd.citationstyles.style+xml` + * Add `application/vnd.fastcopy-disk-image` + * Add `application/vnd.gov.sk.xmldatacontainer+xml` + * Add extension `.jsonld` to `application/ld+json` + +1.7.0 / 2015-02-08 +================== + + * Add `application/vnd.gerber` + * Add `application/vnd.msa-disk-image` + +1.6.1 / 2015-02-05 +================== + + * Community extensions ownership transferred from `node-mime` + +1.6.0 / 2015-01-29 +================== + + * Add `application/jose` + * Add `application/jose+json` + * Add `application/json-seq` + * Add `application/jwk+json` + * Add `application/jwk-set+json` + * Add `application/jwt` + * Add `application/rdap+json` + * Add `application/vnd.gov.sk.e-form+xml` + * Add `application/vnd.ims.imsccv1p3` + +1.5.0 / 2014-12-30 +================== + + * Add `application/vnd.oracle.resource+json` + * Fix various invalid MIME type entries + - `application/mbox+xml` + - `application/oscp-response` + - `application/vwg-multiplexed` + - `audio/g721` + +1.4.0 / 2014-12-21 +================== + + * Add `application/vnd.ims.imsccv1p2` + * Fix various invalid MIME type entries + - `application/vnd-acucobol` + - `application/vnd-curl` + - `application/vnd-dart` + - `application/vnd-dxr` + - `application/vnd-fdf` + - `application/vnd-mif` + - `application/vnd-sema` + - `application/vnd-wap-wmlc` + - `application/vnd.adobe.flash-movie` + - `application/vnd.dece-zip` + - `application/vnd.dvb_service` + - `application/vnd.micrografx-igx` + - `application/vnd.sealed-doc` + - `application/vnd.sealed-eml` + - `application/vnd.sealed-mht` + - `application/vnd.sealed-ppt` + - `application/vnd.sealed-tiff` + - `application/vnd.sealed-xls` + - `application/vnd.sealedmedia.softseal-html` + - `application/vnd.sealedmedia.softseal-pdf` + - `application/vnd.wap-slc` + - `application/vnd.wap-wbxml` + - `audio/vnd.sealedmedia.softseal-mpeg` + - `image/vnd-djvu` + - `image/vnd-svf` + - `image/vnd-wap-wbmp` + - `image/vnd.sealed-png` + - `image/vnd.sealedmedia.softseal-gif` + - `image/vnd.sealedmedia.softseal-jpg` + - `model/vnd-dwf` + - `model/vnd.parasolid.transmit-binary` + - `model/vnd.parasolid.transmit-text` + - `text/vnd-a` + - `text/vnd-curl` + - `text/vnd.wap-wml` + * Remove example template MIME types + - `application/example` + - `audio/example` + - `image/example` + - `message/example` + - `model/example` + - `multipart/example` + - `text/example` + - `video/example` + +1.3.1 / 2014-12-16 +================== + + * Fix missing extensions + - `application/json5` + - `text/hjson` + +1.3.0 / 2014-12-07 +================== + + * Add `application/a2l` + * Add `application/aml` + * Add `application/atfx` + * Add `application/atxml` + * Add `application/cdfx+xml` + * Add `application/dii` + * Add `application/json5` + * Add `application/lxf` + * Add `application/mf4` + * Add `application/vnd.apache.thrift.compact` + * Add `application/vnd.apache.thrift.json` + * Add `application/vnd.coffeescript` + * Add `application/vnd.enphase.envoy` + * Add `application/vnd.ims.imsccv1p1` + * Add `text/csv-schema` + * Add `text/hjson` + * Add `text/markdown` + * Add `text/yaml` + +1.2.0 / 2014-11-09 +================== + + * Add `application/cea` + * Add `application/dit` + * Add `application/vnd.gov.sk.e-form+zip` + * Add `application/vnd.tmd.mediaflex.api+xml` + * Type `application/epub+zip` is now IANA-registered + +1.1.2 / 2014-10-23 +================== + + * Rebuild database for `application/x-www-form-urlencoded` change + +1.1.1 / 2014-10-20 +================== + + * Mark `application/x-www-form-urlencoded` as compressible. + +1.1.0 / 2014-09-28 +================== + + * Add `application/font-woff2` + +1.0.3 / 2014-09-25 +================== + + * Fix engine requirement in package + +1.0.2 / 2014-09-25 +================== + + * Add `application/coap-group+json` + * Add `application/dcd` + * Add `application/vnd.apache.thrift.binary` + * Add `image/vnd.tencent.tap` + * Mark all JSON-derived types as compressible + * Update `text/vtt` data + +1.0.1 / 2014-08-30 +================== + + * Fix extension ordering + +1.0.0 / 2014-08-30 +================== + + * Add `application/atf` + * Add `application/merge-patch+json` + * Add `multipart/x-mixed-replace` + * Add `source: 'apache'` metadata + * Add `source: 'iana'` metadata + * Remove badly-assumed charset data diff --git a/node_modules/express/node_modules/type-is/node_modules/mime-types/node_modules/mime-db/LICENSE b/node_modules/express/node_modules/type-is/node_modules/mime-types/node_modules/mime-db/LICENSE new file mode 100644 index 0000000..a7ae8ee --- /dev/null +++ b/node_modules/express/node_modules/type-is/node_modules/mime-types/node_modules/mime-db/LICENSE @@ -0,0 +1,22 @@ + +The MIT License (MIT) + +Copyright (c) 2014 Jonathan Ong me@jongleberry.com + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. diff --git a/node_modules/express/node_modules/type-is/node_modules/mime-types/node_modules/mime-db/README.md b/node_modules/express/node_modules/type-is/node_modules/mime-types/node_modules/mime-db/README.md new file mode 100644 index 0000000..7662440 --- /dev/null +++ b/node_modules/express/node_modules/type-is/node_modules/mime-types/node_modules/mime-db/README.md @@ -0,0 +1,82 @@ +# mime-db + +[![NPM Version][npm-version-image]][npm-url] +[![NPM Downloads][npm-downloads-image]][npm-url] +[![Node.js Version][node-image]][node-url] +[![Build Status][travis-image]][travis-url] +[![Coverage Status][coveralls-image]][coveralls-url] + +This is a database of all mime types. +It consists of a single, public JSON file and does not include any logic, +allowing it to remain as un-opinionated as possible with an API. +It aggregates data from the following sources: + +- http://www.iana.org/assignments/media-types/media-types.xhtml +- http://svn.apache.org/repos/asf/httpd/httpd/trunk/docs/conf/mime.types +- http://hg.nginx.org/nginx/raw-file/default/conf/mime.types + +## Installation + +```bash +npm install mime-db +``` + +### Database Download + +If you're crazy enough to use this in the browser, you can just grab the +JSON file using [RawGit](https://rawgit.com/). It is recommended to replace +`master` with [a release tag](https://github.com/jshttp/mime-db/tags) as the +JSON format may change in the future. + +``` +https://cdn.rawgit.com/jshttp/mime-db/master/db.json +``` + +## Usage + +```js +var db = require('mime-db'); + +// grab data on .js files +var data = db['application/javascript']; +``` + +## Data Structure + +The JSON file is a map lookup for lowercased mime types. +Each mime type has the following properties: + +- `.source` - where the mime type is defined. + If not set, it's probably a custom media type. + - `apache` - [Apache common media types](http://svn.apache.org/repos/asf/httpd/httpd/trunk/docs/conf/mime.types) + - `iana` - [IANA-defined media types](http://www.iana.org/assignments/media-types/media-types.xhtml) + - `nginx` - [nginx media types](http://hg.nginx.org/nginx/raw-file/default/conf/mime.types) +- `.extensions[]` - known extensions associated with this mime type. +- `.compressible` - whether a file of this type can be gzipped. +- `.charset` - the default charset associated with this type, if any. + +If unknown, every property could be `undefined`. + +## Contributing + +To edit the database, only make PRs against `src/custom.json` or +`src/custom-suffix.json`. + +To update the build, run `npm run build`. + +## Adding Custom Media Types + +The best way to get new media types included in this library is to register +them with the IANA. The community registration procedure is outlined in +[RFC 6838 section 5](http://tools.ietf.org/html/rfc6838#section-5). Types +registered with the IANA are automatically pulled into this library. + +[npm-version-image]: https://img.shields.io/npm/v/mime-db.svg +[npm-downloads-image]: https://img.shields.io/npm/dm/mime-db.svg +[npm-url]: https://npmjs.org/package/mime-db +[travis-image]: https://img.shields.io/travis/jshttp/mime-db/master.svg +[travis-url]: https://travis-ci.org/jshttp/mime-db +[coveralls-image]: https://img.shields.io/coveralls/jshttp/mime-db/master.svg +[coveralls-url]: https://coveralls.io/r/jshttp/mime-db?branch=master +[node-image]: https://img.shields.io/node/v/mime-db.svg +[node-url]: http://nodejs.org/download/ diff --git a/node_modules/express/node_modules/type-is/node_modules/mime-types/node_modules/mime-db/db.json b/node_modules/express/node_modules/type-is/node_modules/mime-types/node_modules/mime-db/db.json new file mode 100644 index 0000000..63b226f --- /dev/null +++ b/node_modules/express/node_modules/type-is/node_modules/mime-types/node_modules/mime-db/db.json @@ -0,0 +1,6692 @@ +{ + "application/1d-interleaved-parityfec": { + "source": "iana" + }, + "application/3gpdash-qoe-report+xml": { + "source": "iana" + }, + "application/3gpp-ims+xml": { + "source": "iana" + }, + "application/a2l": { + "source": "iana" + }, + "application/activemessage": { + "source": "iana" + }, + "application/alto-costmap+json": { + "source": "iana", + "compressible": true + }, + "application/alto-costmapfilter+json": { + "source": "iana", + "compressible": true + }, + "application/alto-directory+json": { + "source": "iana", + "compressible": true + }, + "application/alto-endpointcost+json": { + "source": "iana", + "compressible": true + }, + "application/alto-endpointcostparams+json": { + "source": "iana", + "compressible": true + }, + "application/alto-endpointprop+json": { + "source": "iana", + "compressible": true + }, + "application/alto-endpointpropparams+json": { + "source": "iana", + "compressible": true + }, + "application/alto-error+json": { + "source": "iana", + "compressible": true + }, + "application/alto-networkmap+json": { + "source": "iana", + "compressible": true + }, + "application/alto-networkmapfilter+json": { + "source": "iana", + "compressible": true + }, + "application/aml": { + "source": "iana" + }, + "application/andrew-inset": { + "source": "iana", + "extensions": ["ez"] + }, + "application/applefile": { + "source": "iana" + }, + "application/applixware": { + "source": "apache", + "extensions": ["aw"] + }, + "application/atf": { + "source": "iana" + }, + "application/atfx": { + "source": "iana" + }, + "application/atom+xml": { + "source": "iana", + "compressible": true, + "extensions": ["atom"] + }, + "application/atomcat+xml": { + "source": "iana", + "extensions": ["atomcat"] + }, + "application/atomdeleted+xml": { + "source": "iana" + }, + "application/atomicmail": { + "source": "iana" + }, + "application/atomsvc+xml": { + "source": "iana", + "extensions": ["atomsvc"] + }, + "application/atxml": { + "source": "iana" + }, + "application/auth-policy+xml": { + "source": "iana" + }, + "application/bacnet-xdd+zip": { + "source": "iana" + }, + "application/batch-smtp": { + "source": "iana" + }, + "application/bdoc": { + "compressible": false, + "extensions": ["bdoc"] + }, + "application/beep+xml": { + "source": "iana" + }, + "application/calendar+json": { + "source": "iana", + "compressible": true + }, + "application/calendar+xml": { + "source": "iana" + }, + "application/call-completion": { + "source": "iana" + }, + "application/cals-1840": { + "source": "iana" + }, + "application/cbor": { + "source": "iana" + }, + "application/ccmp+xml": { + "source": "iana" + }, + "application/ccxml+xml": { + "source": "iana", + "extensions": ["ccxml"] + }, + "application/cdfx+xml": { + "source": "iana" + }, + "application/cdmi-capability": { + "source": "iana", + "extensions": ["cdmia"] + }, + "application/cdmi-container": { + "source": "iana", + "extensions": ["cdmic"] + }, + "application/cdmi-domain": { + "source": "iana", + "extensions": ["cdmid"] + }, + "application/cdmi-object": { + "source": "iana", + "extensions": ["cdmio"] + }, + "application/cdmi-queue": { + "source": "iana", + "extensions": ["cdmiq"] + }, + "application/cdni": { + "source": "iana" + }, + "application/cea": { + "source": "iana" + }, + "application/cea-2018+xml": { + "source": "iana" + }, + "application/cellml+xml": { + "source": "iana" + }, + "application/cfw": { + "source": "iana" + }, + "application/clue_info+xml": { + "source": "iana" + }, + "application/cms": { + "source": "iana" + }, + "application/cnrp+xml": { + "source": "iana" + }, + "application/coap-group+json": { + "source": "iana", + "compressible": true + }, + "application/commonground": { + "source": "iana" + }, + "application/conference-info+xml": { + "source": "iana" + }, + "application/cpl+xml": { + "source": "iana" + }, + "application/csrattrs": { + "source": "iana" + }, + "application/csta+xml": { + "source": "iana" + }, + "application/cstadata+xml": { + "source": "iana" + }, + "application/csvm+json": { + "source": "iana", + "compressible": true + }, + "application/cu-seeme": { + "source": "apache", + "extensions": ["cu"] + }, + "application/cybercash": { + "source": "iana" + }, + "application/dart": { + "compressible": true + }, + "application/dash+xml": { + "source": "iana", + "extensions": ["mpd"] + }, + "application/dashdelta": { + "source": "iana" + }, + "application/davmount+xml": { + "source": "iana", + "extensions": ["davmount"] + }, + "application/dca-rft": { + "source": "iana" + }, + "application/dcd": { + "source": "iana" + }, + "application/dec-dx": { + "source": "iana" + }, + "application/dialog-info+xml": { + "source": "iana" + }, + "application/dicom": { + "source": "iana" + }, + "application/dii": { + "source": "iana" + }, + "application/dit": { + "source": "iana" + }, + "application/dns": { + "source": "iana" + }, + "application/docbook+xml": { + "source": "apache", + "extensions": ["dbk"] + }, + "application/dskpp+xml": { + "source": "iana" + }, + "application/dssc+der": { + "source": "iana", + "extensions": ["dssc"] + }, + "application/dssc+xml": { + "source": "iana", + "extensions": ["xdssc"] + }, + "application/dvcs": { + "source": "iana" + }, + "application/ecmascript": { + "source": "iana", + "compressible": true, + "extensions": ["ecma"] + }, + "application/edi-consent": { + "source": "iana" + }, + "application/edi-x12": { + "source": "iana", + "compressible": false + }, + "application/edifact": { + "source": "iana", + "compressible": false + }, + "application/efi": { + "source": "iana" + }, + "application/emergencycalldata.comment+xml": { + "source": "iana" + }, + "application/emergencycalldata.deviceinfo+xml": { + "source": "iana" + }, + "application/emergencycalldata.providerinfo+xml": { + "source": "iana" + }, + "application/emergencycalldata.serviceinfo+xml": { + "source": "iana" + }, + "application/emergencycalldata.subscriberinfo+xml": { + "source": "iana" + }, + "application/emma+xml": { + "source": "iana", + "extensions": ["emma"] + }, + "application/emotionml+xml": { + "source": "iana" + }, + "application/encaprtp": { + "source": "iana" + }, + "application/epp+xml": { + "source": "iana" + }, + "application/epub+zip": { + "source": "iana", + "extensions": ["epub"] + }, + "application/eshop": { + "source": "iana" + }, + "application/exi": { + "source": "iana", + "extensions": ["exi"] + }, + "application/fastinfoset": { + "source": "iana" + }, + "application/fastsoap": { + "source": "iana" + }, + "application/fdt+xml": { + "source": "iana" + }, + "application/fits": { + "source": "iana" + }, + "application/font-sfnt": { + "source": "iana" + }, + "application/font-tdpfr": { + "source": "iana", + "extensions": ["pfr"] + }, + "application/font-woff": { + "source": "iana", + "compressible": false, + "extensions": ["woff"] + }, + "application/font-woff2": { + "compressible": false, + "extensions": ["woff2"] + }, + "application/framework-attributes+xml": { + "source": "iana" + }, + "application/geo+json": { + "source": "iana", + "compressible": true + }, + "application/gml+xml": { + "source": "apache", + "extensions": ["gml"] + }, + "application/gpx+xml": { + "source": "apache", + "extensions": ["gpx"] + }, + "application/gxf": { + "source": "apache", + "extensions": ["gxf"] + }, + "application/gzip": { + "source": "iana", + "compressible": false + }, + "application/h224": { + "source": "iana" + }, + "application/held+xml": { + "source": "iana" + }, + "application/http": { + "source": "iana" + }, + "application/hyperstudio": { + "source": "iana", + "extensions": ["stk"] + }, + "application/ibe-key-request+xml": { + "source": "iana" + }, + "application/ibe-pkg-reply+xml": { + "source": "iana" + }, + "application/ibe-pp-data": { + "source": "iana" + }, + "application/iges": { + "source": "iana" + }, + "application/im-iscomposing+xml": { + "source": "iana" + }, + "application/index": { + "source": "iana" + }, + "application/index.cmd": { + "source": "iana" + }, + "application/index.obj": { + "source": "iana" + }, + "application/index.response": { + "source": "iana" + }, + "application/index.vnd": { + "source": "iana" + }, + "application/inkml+xml": { + "source": "iana", + "extensions": ["ink","inkml"] + }, + "application/iotp": { + "source": "iana" + }, + "application/ipfix": { + "source": "iana", + "extensions": ["ipfix"] + }, + "application/ipp": { + "source": "iana" + }, + "application/isup": { + "source": "iana" + }, + "application/its+xml": { + "source": "iana" + }, + "application/java-archive": { + "source": "apache", + "compressible": false, + "extensions": ["jar","war","ear"] + }, + "application/java-serialized-object": { + "source": "apache", + "compressible": false, + "extensions": ["ser"] + }, + "application/java-vm": { + "source": "apache", + "compressible": false, + "extensions": ["class"] + }, + "application/javascript": { + "source": "iana", + "charset": "UTF-8", + "compressible": true, + "extensions": ["js"] + }, + "application/jose": { + "source": "iana" + }, + "application/jose+json": { + "source": "iana", + "compressible": true + }, + "application/jrd+json": { + "source": "iana", + "compressible": true + }, + "application/json": { + "source": "iana", + "charset": "UTF-8", + "compressible": true, + "extensions": ["json","map"] + }, + "application/json-patch+json": { + "source": "iana", + "compressible": true + }, + "application/json-seq": { + "source": "iana" + }, + "application/json5": { + "extensions": ["json5"] + }, + "application/jsonml+json": { + "source": "apache", + "compressible": true, + "extensions": ["jsonml"] + }, + "application/jwk+json": { + "source": "iana", + "compressible": true + }, + "application/jwk-set+json": { + "source": "iana", + "compressible": true + }, + "application/jwt": { + "source": "iana" + }, + "application/kpml-request+xml": { + "source": "iana" + }, + "application/kpml-response+xml": { + "source": "iana" + }, + "application/ld+json": { + "source": "iana", + "compressible": true, + "extensions": ["jsonld"] + }, + "application/lgr+xml": { + "source": "iana" + }, + "application/link-format": { + "source": "iana" + }, + "application/load-control+xml": { + "source": "iana" + }, + "application/lost+xml": { + "source": "iana", + "extensions": ["lostxml"] + }, + "application/lostsync+xml": { + "source": "iana" + }, + "application/lxf": { + "source": "iana" + }, + "application/mac-binhex40": { + "source": "iana", + "extensions": ["hqx"] + }, + "application/mac-compactpro": { + "source": "apache", + "extensions": ["cpt"] + }, + "application/macwriteii": { + "source": "iana" + }, + "application/mads+xml": { + "source": "iana", + "extensions": ["mads"] + }, + "application/manifest+json": { + "charset": "UTF-8", + "compressible": true, + "extensions": ["webmanifest"] + }, + "application/marc": { + "source": "iana", + "extensions": ["mrc"] + }, + "application/marcxml+xml": { + "source": "iana", + "extensions": ["mrcx"] + }, + "application/mathematica": { + "source": "iana", + "extensions": ["ma","nb","mb"] + }, + "application/mathml+xml": { + "source": "iana", + "extensions": ["mathml"] + }, + "application/mathml-content+xml": { + "source": "iana" + }, + "application/mathml-presentation+xml": { + "source": "iana" + }, + "application/mbms-associated-procedure-description+xml": { + "source": "iana" + }, + "application/mbms-deregister+xml": { + "source": "iana" + }, + "application/mbms-envelope+xml": { + "source": "iana" + }, + "application/mbms-msk+xml": { + "source": "iana" + }, + "application/mbms-msk-response+xml": { + "source": "iana" + }, + "application/mbms-protection-description+xml": { + "source": "iana" + }, + "application/mbms-reception-report+xml": { + "source": "iana" + }, + "application/mbms-register+xml": { + "source": "iana" + }, + "application/mbms-register-response+xml": { + "source": "iana" + }, + "application/mbms-schedule+xml": { + "source": "iana" + }, + "application/mbms-user-service-description+xml": { + "source": "iana" + }, + "application/mbox": { + "source": "iana", + "extensions": ["mbox"] + }, + "application/media-policy-dataset+xml": { + "source": "iana" + }, + "application/media_control+xml": { + "source": "iana" + }, + "application/mediaservercontrol+xml": { + "source": "iana", + "extensions": ["mscml"] + }, + "application/merge-patch+json": { + "source": "iana", + "compressible": true + }, + "application/metalink+xml": { + "source": "apache", + "extensions": ["metalink"] + }, + "application/metalink4+xml": { + "source": "iana", + "extensions": ["meta4"] + }, + "application/mets+xml": { + "source": "iana", + "extensions": ["mets"] + }, + "application/mf4": { + "source": "iana" + }, + "application/mikey": { + "source": "iana" + }, + "application/mods+xml": { + "source": "iana", + "extensions": ["mods"] + }, + "application/moss-keys": { + "source": "iana" + }, + "application/moss-signature": { + "source": "iana" + }, + "application/mosskey-data": { + "source": "iana" + }, + "application/mosskey-request": { + "source": "iana" + }, + "application/mp21": { + "source": "iana", + "extensions": ["m21","mp21"] + }, + "application/mp4": { + "source": "iana", + "extensions": ["mp4s","m4p"] + }, + "application/mpeg4-generic": { + "source": "iana" + }, + "application/mpeg4-iod": { + "source": "iana" + }, + "application/mpeg4-iod-xmt": { + "source": "iana" + }, + "application/mrb-consumer+xml": { + "source": "iana" + }, + "application/mrb-publish+xml": { + "source": "iana" + }, + "application/msc-ivr+xml": { + "source": "iana" + }, + "application/msc-mixer+xml": { + "source": "iana" + }, + "application/msword": { + "source": "iana", + "compressible": false, + "extensions": ["doc","dot"] + }, + "application/mxf": { + "source": "iana", + "extensions": ["mxf"] + }, + "application/nasdata": { + "source": "iana" + }, + "application/news-checkgroups": { + "source": "iana" + }, + "application/news-groupinfo": { + "source": "iana" + }, + "application/news-transmission": { + "source": "iana" + }, + "application/nlsml+xml": { + "source": "iana" + }, + "application/nss": { + "source": "iana" + }, + "application/ocsp-request": { + "source": "iana" + }, + "application/ocsp-response": { + "source": "iana" + }, + "application/octet-stream": { + "source": "iana", + "compressible": false, + "extensions": ["bin","dms","lrf","mar","so","dist","distz","pkg","bpk","dump","elc","deploy","exe","dll","deb","dmg","iso","img","msi","msp","msm","buffer"] + }, + "application/oda": { + "source": "iana", + "extensions": ["oda"] + }, + "application/odx": { + "source": "iana" + }, + "application/oebps-package+xml": { + "source": "iana", + "extensions": ["opf"] + }, + "application/ogg": { + "source": "iana", + "compressible": false, + "extensions": ["ogx"] + }, + "application/omdoc+xml": { + "source": "apache", + "extensions": ["omdoc"] + }, + "application/onenote": { + "source": "apache", + "extensions": ["onetoc","onetoc2","onetmp","onepkg"] + }, + "application/oxps": { + "source": "iana", + "extensions": ["oxps"] + }, + "application/p2p-overlay+xml": { + "source": "iana" + }, + "application/parityfec": { + "source": "iana" + }, + "application/patch-ops-error+xml": { + "source": "iana", + "extensions": ["xer"] + }, + "application/pdf": { + "source": "iana", + "compressible": false, + "extensions": ["pdf"] + }, + "application/pdx": { + "source": "iana" + }, + "application/pgp-encrypted": { + "source": "iana", + "compressible": false, + "extensions": ["pgp"] + }, + "application/pgp-keys": { + "source": "iana" + }, + "application/pgp-signature": { + "source": "iana", + "extensions": ["asc","sig"] + }, + "application/pics-rules": { + "source": "apache", + "extensions": ["prf"] + }, + "application/pidf+xml": { + "source": "iana" + }, + "application/pidf-diff+xml": { + "source": "iana" + }, + "application/pkcs10": { + "source": "iana", + "extensions": ["p10"] + }, + "application/pkcs12": { + "source": "iana" + }, + "application/pkcs7-mime": { + "source": "iana", + "extensions": ["p7m","p7c"] + }, + "application/pkcs7-signature": { + "source": "iana", + "extensions": ["p7s"] + }, + "application/pkcs8": { + "source": "iana", + "extensions": ["p8"] + }, + "application/pkix-attr-cert": { + "source": "iana", + "extensions": ["ac"] + }, + "application/pkix-cert": { + "source": "iana", + "extensions": ["cer"] + }, + "application/pkix-crl": { + "source": "iana", + "extensions": ["crl"] + }, + "application/pkix-pkipath": { + "source": "iana", + "extensions": ["pkipath"] + }, + "application/pkixcmp": { + "source": "iana", + "extensions": ["pki"] + }, + "application/pls+xml": { + "source": "iana", + "extensions": ["pls"] + }, + "application/poc-settings+xml": { + "source": "iana" + }, + "application/postscript": { + "source": "iana", + "compressible": true, + "extensions": ["ai","eps","ps"] + }, + "application/ppsp-tracker+json": { + "source": "iana", + "compressible": true + }, + "application/problem+json": { + "source": "iana", + "compressible": true + }, + "application/problem+xml": { + "source": "iana" + }, + "application/provenance+xml": { + "source": "iana" + }, + "application/prs.alvestrand.titrax-sheet": { + "source": "iana" + }, + "application/prs.cww": { + "source": "iana", + "extensions": ["cww"] + }, + "application/prs.hpub+zip": { + "source": "iana" + }, + "application/prs.nprend": { + "source": "iana" + }, + "application/prs.plucker": { + "source": "iana" + }, + "application/prs.rdf-xml-crypt": { + "source": "iana" + }, + "application/prs.xsf+xml": { + "source": "iana" + }, + "application/pskc+xml": { + "source": "iana", + "extensions": ["pskcxml"] + }, + "application/qsig": { + "source": "iana" + }, + "application/raptorfec": { + "source": "iana" + }, + "application/rdap+json": { + "source": "iana", + "compressible": true + }, + "application/rdf+xml": { + "source": "iana", + "compressible": true, + "extensions": ["rdf"] + }, + "application/reginfo+xml": { + "source": "iana", + "extensions": ["rif"] + }, + "application/relax-ng-compact-syntax": { + "source": "iana", + "extensions": ["rnc"] + }, + "application/remote-printing": { + "source": "iana" + }, + "application/reputon+json": { + "source": "iana", + "compressible": true + }, + "application/resource-lists+xml": { + "source": "iana", + "extensions": ["rl"] + }, + "application/resource-lists-diff+xml": { + "source": "iana", + "extensions": ["rld"] + }, + "application/rfc+xml": { + "source": "iana" + }, + "application/riscos": { + "source": "iana" + }, + "application/rlmi+xml": { + "source": "iana" + }, + "application/rls-services+xml": { + "source": "iana", + "extensions": ["rs"] + }, + "application/rpki-ghostbusters": { + "source": "iana", + "extensions": ["gbr"] + }, + "application/rpki-manifest": { + "source": "iana", + "extensions": ["mft"] + }, + "application/rpki-roa": { + "source": "iana", + "extensions": ["roa"] + }, + "application/rpki-updown": { + "source": "iana" + }, + "application/rsd+xml": { + "source": "apache", + "extensions": ["rsd"] + }, + "application/rss+xml": { + "source": "apache", + "compressible": true, + "extensions": ["rss"] + }, + "application/rtf": { + "source": "iana", + "compressible": true, + "extensions": ["rtf"] + }, + "application/rtploopback": { + "source": "iana" + }, + "application/rtx": { + "source": "iana" + }, + "application/samlassertion+xml": { + "source": "iana" + }, + "application/samlmetadata+xml": { + "source": "iana" + }, + "application/sbml+xml": { + "source": "iana", + "extensions": ["sbml"] + }, + "application/scaip+xml": { + "source": "iana" + }, + "application/scim+json": { + "source": "iana", + "compressible": true + }, + "application/scvp-cv-request": { + "source": "iana", + "extensions": ["scq"] + }, + "application/scvp-cv-response": { + "source": "iana", + "extensions": ["scs"] + }, + "application/scvp-vp-request": { + "source": "iana", + "extensions": ["spq"] + }, + "application/scvp-vp-response": { + "source": "iana", + "extensions": ["spp"] + }, + "application/sdp": { + "source": "iana", + "extensions": ["sdp"] + }, + "application/sep+xml": { + "source": "iana" + }, + "application/sep-exi": { + "source": "iana" + }, + "application/session-info": { + "source": "iana" + }, + "application/set-payment": { + "source": "iana" + }, + "application/set-payment-initiation": { + "source": "iana", + "extensions": ["setpay"] + }, + "application/set-registration": { + "source": "iana" + }, + "application/set-registration-initiation": { + "source": "iana", + "extensions": ["setreg"] + }, + "application/sgml": { + "source": "iana" + }, + "application/sgml-open-catalog": { + "source": "iana" + }, + "application/shf+xml": { + "source": "iana", + "extensions": ["shf"] + }, + "application/sieve": { + "source": "iana" + }, + "application/simple-filter+xml": { + "source": "iana" + }, + "application/simple-message-summary": { + "source": "iana" + }, + "application/simplesymbolcontainer": { + "source": "iana" + }, + "application/slate": { + "source": "iana" + }, + "application/smil": { + "source": "iana" + }, + "application/smil+xml": { + "source": "iana", + "extensions": ["smi","smil"] + }, + "application/smpte336m": { + "source": "iana" + }, + "application/soap+fastinfoset": { + "source": "iana" + }, + "application/soap+xml": { + "source": "iana", + "compressible": true + }, + "application/sparql-query": { + "source": "iana", + "extensions": ["rq"] + }, + "application/sparql-results+xml": { + "source": "iana", + "extensions": ["srx"] + }, + "application/spirits-event+xml": { + "source": "iana" + }, + "application/sql": { + "source": "iana" + }, + "application/srgs": { + "source": "iana", + "extensions": ["gram"] + }, + "application/srgs+xml": { + "source": "iana", + "extensions": ["grxml"] + }, + "application/sru+xml": { + "source": "iana", + "extensions": ["sru"] + }, + "application/ssdl+xml": { + "source": "apache", + "extensions": ["ssdl"] + }, + "application/ssml+xml": { + "source": "iana", + "extensions": ["ssml"] + }, + "application/tamp-apex-update": { + "source": "iana" + }, + "application/tamp-apex-update-confirm": { + "source": "iana" + }, + "application/tamp-community-update": { + "source": "iana" + }, + "application/tamp-community-update-confirm": { + "source": "iana" + }, + "application/tamp-error": { + "source": "iana" + }, + "application/tamp-sequence-adjust": { + "source": "iana" + }, + "application/tamp-sequence-adjust-confirm": { + "source": "iana" + }, + "application/tamp-status-query": { + "source": "iana" + }, + "application/tamp-status-response": { + "source": "iana" + }, + "application/tamp-update": { + "source": "iana" + }, + "application/tamp-update-confirm": { + "source": "iana" + }, + "application/tar": { + "compressible": true + }, + "application/tei+xml": { + "source": "iana", + "extensions": ["tei","teicorpus"] + }, + "application/thraud+xml": { + "source": "iana", + "extensions": ["tfi"] + }, + "application/timestamp-query": { + "source": "iana" + }, + "application/timestamp-reply": { + "source": "iana" + }, + "application/timestamped-data": { + "source": "iana", + "extensions": ["tsd"] + }, + "application/ttml+xml": { + "source": "iana" + }, + "application/tve-trigger": { + "source": "iana" + }, + "application/ulpfec": { + "source": "iana" + }, + "application/urc-grpsheet+xml": { + "source": "iana" + }, + "application/urc-ressheet+xml": { + "source": "iana" + }, + "application/urc-targetdesc+xml": { + "source": "iana" + }, + "application/urc-uisocketdesc+xml": { + "source": "iana" + }, + "application/vcard+json": { + "source": "iana", + "compressible": true + }, + "application/vcard+xml": { + "source": "iana" + }, + "application/vemmi": { + "source": "iana" + }, + "application/vividence.scriptfile": { + "source": "apache" + }, + "application/vnd.3gpp-prose+xml": { + "source": "iana" + }, + "application/vnd.3gpp-prose-pc3ch+xml": { + "source": "iana" + }, + "application/vnd.3gpp.access-transfer-events+xml": { + "source": "iana" + }, + "application/vnd.3gpp.bsf+xml": { + "source": "iana" + }, + "application/vnd.3gpp.mid-call+xml": { + "source": "iana" + }, + "application/vnd.3gpp.pic-bw-large": { + "source": "iana", + "extensions": ["plb"] + }, + "application/vnd.3gpp.pic-bw-small": { + "source": "iana", + "extensions": ["psb"] + }, + "application/vnd.3gpp.pic-bw-var": { + "source": "iana", + "extensions": ["pvb"] + }, + "application/vnd.3gpp.sms": { + "source": "iana" + }, + "application/vnd.3gpp.sms+xml": { + "source": "iana" + }, + "application/vnd.3gpp.srvcc-ext+xml": { + "source": "iana" + }, + "application/vnd.3gpp.srvcc-info+xml": { + "source": "iana" + }, + "application/vnd.3gpp.state-and-event-info+xml": { + "source": "iana" + }, + "application/vnd.3gpp.ussd+xml": { + "source": "iana" + }, + "application/vnd.3gpp2.bcmcsinfo+xml": { + "source": "iana" + }, + "application/vnd.3gpp2.sms": { + "source": "iana" + }, + "application/vnd.3gpp2.tcap": { + "source": "iana", + "extensions": ["tcap"] + }, + "application/vnd.3lightssoftware.imagescal": { + "source": "iana" + }, + "application/vnd.3m.post-it-notes": { + "source": "iana", + "extensions": ["pwn"] + }, + "application/vnd.accpac.simply.aso": { + "source": "iana", + "extensions": ["aso"] + }, + "application/vnd.accpac.simply.imp": { + "source": "iana", + "extensions": ["imp"] + }, + "application/vnd.acucobol": { + "source": "iana", + "extensions": ["acu"] + }, + "application/vnd.acucorp": { + "source": "iana", + "extensions": ["atc","acutc"] + }, + "application/vnd.adobe.air-application-installer-package+zip": { + "source": "apache", + "extensions": ["air"] + }, + "application/vnd.adobe.flash.movie": { + "source": "iana" + }, + "application/vnd.adobe.formscentral.fcdt": { + "source": "iana", + "extensions": ["fcdt"] + }, + "application/vnd.adobe.fxp": { + "source": "iana", + "extensions": ["fxp","fxpl"] + }, + "application/vnd.adobe.partial-upload": { + "source": "iana" + }, + "application/vnd.adobe.xdp+xml": { + "source": "iana", + "extensions": ["xdp"] + }, + "application/vnd.adobe.xfdf": { + "source": "iana", + "extensions": ["xfdf"] + }, + "application/vnd.aether.imp": { + "source": "iana" + }, + "application/vnd.ah-barcode": { + "source": "iana" + }, + "application/vnd.ahead.space": { + "source": "iana", + "extensions": ["ahead"] + }, + "application/vnd.airzip.filesecure.azf": { + "source": "iana", + "extensions": ["azf"] + }, + "application/vnd.airzip.filesecure.azs": { + "source": "iana", + "extensions": ["azs"] + }, + "application/vnd.amazon.ebook": { + "source": "apache", + "extensions": ["azw"] + }, + "application/vnd.amazon.mobi8-ebook": { + "source": "iana" + }, + "application/vnd.americandynamics.acc": { + "source": "iana", + "extensions": ["acc"] + }, + "application/vnd.amiga.ami": { + "source": "iana", + "extensions": ["ami"] + }, + "application/vnd.amundsen.maze+xml": { + "source": "iana" + }, + "application/vnd.android.package-archive": { + "source": "apache", + "compressible": false, + "extensions": ["apk"] + }, + "application/vnd.anki": { + "source": "iana" + }, + "application/vnd.anser-web-certificate-issue-initiation": { + "source": "iana", + "extensions": ["cii"] + }, + "application/vnd.anser-web-funds-transfer-initiation": { + "source": "apache", + "extensions": ["fti"] + }, + "application/vnd.antix.game-component": { + "source": "iana", + "extensions": ["atx"] + }, + "application/vnd.apache.thrift.binary": { + "source": "iana" + }, + "application/vnd.apache.thrift.compact": { + "source": "iana" + }, + "application/vnd.apache.thrift.json": { + "source": "iana" + }, + "application/vnd.api+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.apple.installer+xml": { + "source": "iana", + "extensions": ["mpkg"] + }, + "application/vnd.apple.mpegurl": { + "source": "iana", + "extensions": ["m3u8"] + }, + "application/vnd.apple.pkpass": { + "compressible": false, + "extensions": ["pkpass"] + }, + "application/vnd.arastra.swi": { + "source": "iana" + }, + "application/vnd.aristanetworks.swi": { + "source": "iana", + "extensions": ["swi"] + }, + "application/vnd.artsquare": { + "source": "iana" + }, + "application/vnd.astraea-software.iota": { + "source": "iana", + "extensions": ["iota"] + }, + "application/vnd.audiograph": { + "source": "iana", + "extensions": ["aep"] + }, + "application/vnd.autopackage": { + "source": "iana" + }, + "application/vnd.avistar+xml": { + "source": "iana" + }, + "application/vnd.balsamiq.bmml+xml": { + "source": "iana" + }, + "application/vnd.balsamiq.bmpr": { + "source": "iana" + }, + "application/vnd.bekitzur-stech+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.biopax.rdf+xml": { + "source": "iana" + }, + "application/vnd.blueice.multipass": { + "source": "iana", + "extensions": ["mpm"] + }, + "application/vnd.bluetooth.ep.oob": { + "source": "iana" + }, + "application/vnd.bluetooth.le.oob": { + "source": "iana" + }, + "application/vnd.bmi": { + "source": "iana", + "extensions": ["bmi"] + }, + "application/vnd.businessobjects": { + "source": "iana", + "extensions": ["rep"] + }, + "application/vnd.cab-jscript": { + "source": "iana" + }, + "application/vnd.canon-cpdl": { + "source": "iana" + }, + "application/vnd.canon-lips": { + "source": "iana" + }, + "application/vnd.cendio.thinlinc.clientconf": { + "source": "iana" + }, + "application/vnd.century-systems.tcp_stream": { + "source": "iana" + }, + "application/vnd.chemdraw+xml": { + "source": "iana", + "extensions": ["cdxml"] + }, + "application/vnd.chess-pgn": { + "source": "iana" + }, + "application/vnd.chipnuts.karaoke-mmd": { + "source": "iana", + "extensions": ["mmd"] + }, + "application/vnd.cinderella": { + "source": "iana", + "extensions": ["cdy"] + }, + "application/vnd.cirpack.isdn-ext": { + "source": "iana" + }, + "application/vnd.citationstyles.style+xml": { + "source": "iana" + }, + "application/vnd.claymore": { + "source": "iana", + "extensions": ["cla"] + }, + "application/vnd.cloanto.rp9": { + "source": "iana", + "extensions": ["rp9"] + }, + "application/vnd.clonk.c4group": { + "source": "iana", + "extensions": ["c4g","c4d","c4f","c4p","c4u"] + }, + "application/vnd.cluetrust.cartomobile-config": { + "source": "iana", + "extensions": ["c11amc"] + }, + "application/vnd.cluetrust.cartomobile-config-pkg": { + "source": "iana", + "extensions": ["c11amz"] + }, + "application/vnd.coffeescript": { + "source": "iana" + }, + "application/vnd.collection+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.collection.doc+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.collection.next+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.comicbook+zip": { + "source": "iana" + }, + "application/vnd.commerce-battelle": { + "source": "iana" + }, + "application/vnd.commonspace": { + "source": "iana", + "extensions": ["csp"] + }, + "application/vnd.contact.cmsg": { + "source": "iana", + "extensions": ["cdbcmsg"] + }, + "application/vnd.coreos.ignition+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.cosmocaller": { + "source": "iana", + "extensions": ["cmc"] + }, + "application/vnd.crick.clicker": { + "source": "iana", + "extensions": ["clkx"] + }, + "application/vnd.crick.clicker.keyboard": { + "source": "iana", + "extensions": ["clkk"] + }, + "application/vnd.crick.clicker.palette": { + "source": "iana", + "extensions": ["clkp"] + }, + "application/vnd.crick.clicker.template": { + "source": "iana", + "extensions": ["clkt"] + }, + "application/vnd.crick.clicker.wordbank": { + "source": "iana", + "extensions": ["clkw"] + }, + "application/vnd.criticaltools.wbs+xml": { + "source": "iana", + "extensions": ["wbs"] + }, + "application/vnd.ctc-posml": { + "source": "iana", + "extensions": ["pml"] + }, + "application/vnd.ctct.ws+xml": { + "source": "iana" + }, + "application/vnd.cups-pdf": { + "source": "iana" + }, + "application/vnd.cups-postscript": { + "source": "iana" + }, + "application/vnd.cups-ppd": { + "source": "iana", + "extensions": ["ppd"] + }, + "application/vnd.cups-raster": { + "source": "iana" + }, + "application/vnd.cups-raw": { + "source": "iana" + }, + "application/vnd.curl": { + "source": "iana" + }, + "application/vnd.curl.car": { + "source": "apache", + "extensions": ["car"] + }, + "application/vnd.curl.pcurl": { + "source": "apache", + "extensions": ["pcurl"] + }, + "application/vnd.cyan.dean.root+xml": { + "source": "iana" + }, + "application/vnd.cybank": { + "source": "iana" + }, + "application/vnd.d2l.coursepackage1p0+zip": { + "source": "iana" + }, + "application/vnd.dart": { + "source": "iana", + "compressible": true, + "extensions": ["dart"] + }, + "application/vnd.data-vision.rdz": { + "source": "iana", + "extensions": ["rdz"] + }, + "application/vnd.debian.binary-package": { + "source": "iana" + }, + "application/vnd.dece.data": { + "source": "iana", + "extensions": ["uvf","uvvf","uvd","uvvd"] + }, + "application/vnd.dece.ttml+xml": { + "source": "iana", + "extensions": ["uvt","uvvt"] + }, + "application/vnd.dece.unspecified": { + "source": "iana", + "extensions": ["uvx","uvvx"] + }, + "application/vnd.dece.zip": { + "source": "iana", + "extensions": ["uvz","uvvz"] + }, + "application/vnd.denovo.fcselayout-link": { + "source": "iana", + "extensions": ["fe_launch"] + }, + "application/vnd.desmume-movie": { + "source": "iana" + }, + "application/vnd.desmume.movie": { + "source": "apache" + }, + "application/vnd.dir-bi.plate-dl-nosuffix": { + "source": "iana" + }, + "application/vnd.dm.delegation+xml": { + "source": "iana" + }, + "application/vnd.dna": { + "source": "iana", + "extensions": ["dna"] + }, + "application/vnd.document+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.dolby.mlp": { + "source": "apache", + "extensions": ["mlp"] + }, + "application/vnd.dolby.mobile.1": { + "source": "iana" + }, + "application/vnd.dolby.mobile.2": { + "source": "iana" + }, + "application/vnd.doremir.scorecloud-binary-document": { + "source": "iana" + }, + "application/vnd.dpgraph": { + "source": "iana", + "extensions": ["dpg"] + }, + "application/vnd.dreamfactory": { + "source": "iana", + "extensions": ["dfac"] + }, + "application/vnd.drive+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.ds-keypoint": { + "source": "apache", + "extensions": ["kpxx"] + }, + "application/vnd.dtg.local": { + "source": "iana" + }, + "application/vnd.dtg.local.flash": { + "source": "iana" + }, + "application/vnd.dtg.local.html": { + "source": "iana" + }, + "application/vnd.dvb.ait": { + "source": "iana", + "extensions": ["ait"] + }, + "application/vnd.dvb.dvbj": { + "source": "iana" + }, + "application/vnd.dvb.esgcontainer": { + "source": "iana" + }, + "application/vnd.dvb.ipdcdftnotifaccess": { + "source": "iana" + }, + "application/vnd.dvb.ipdcesgaccess": { + "source": "iana" + }, + "application/vnd.dvb.ipdcesgaccess2": { + "source": "iana" + }, + "application/vnd.dvb.ipdcesgpdd": { + "source": "iana" + }, + "application/vnd.dvb.ipdcroaming": { + "source": "iana" + }, + "application/vnd.dvb.iptv.alfec-base": { + "source": "iana" + }, + "application/vnd.dvb.iptv.alfec-enhancement": { + "source": "iana" + }, + "application/vnd.dvb.notif-aggregate-root+xml": { + "source": "iana" + }, + "application/vnd.dvb.notif-container+xml": { + "source": "iana" + }, + "application/vnd.dvb.notif-generic+xml": { + "source": "iana" + }, + "application/vnd.dvb.notif-ia-msglist+xml": { + "source": "iana" + }, + "application/vnd.dvb.notif-ia-registration-request+xml": { + "source": "iana" + }, + "application/vnd.dvb.notif-ia-registration-response+xml": { + "source": "iana" + }, + "application/vnd.dvb.notif-init+xml": { + "source": "iana" + }, + "application/vnd.dvb.pfr": { + "source": "iana" + }, + "application/vnd.dvb.service": { + "source": "iana", + "extensions": ["svc"] + }, + "application/vnd.dxr": { + "source": "iana" + }, + "application/vnd.dynageo": { + "source": "iana", + "extensions": ["geo"] + }, + "application/vnd.dzr": { + "source": "iana" + }, + "application/vnd.easykaraoke.cdgdownload": { + "source": "iana" + }, + "application/vnd.ecdis-update": { + "source": "iana" + }, + "application/vnd.ecowin.chart": { + "source": "iana", + "extensions": ["mag"] + }, + "application/vnd.ecowin.filerequest": { + "source": "iana" + }, + "application/vnd.ecowin.fileupdate": { + "source": "iana" + }, + "application/vnd.ecowin.series": { + "source": "iana" + }, + "application/vnd.ecowin.seriesrequest": { + "source": "iana" + }, + "application/vnd.ecowin.seriesupdate": { + "source": "iana" + }, + "application/vnd.emclient.accessrequest+xml": { + "source": "iana" + }, + "application/vnd.enliven": { + "source": "iana", + "extensions": ["nml"] + }, + "application/vnd.enphase.envoy": { + "source": "iana" + }, + "application/vnd.eprints.data+xml": { + "source": "iana" + }, + "application/vnd.epson.esf": { + "source": "iana", + "extensions": ["esf"] + }, + "application/vnd.epson.msf": { + "source": "iana", + "extensions": ["msf"] + }, + "application/vnd.epson.quickanime": { + "source": "iana", + "extensions": ["qam"] + }, + "application/vnd.epson.salt": { + "source": "iana", + "extensions": ["slt"] + }, + "application/vnd.epson.ssf": { + "source": "iana", + "extensions": ["ssf"] + }, + "application/vnd.ericsson.quickcall": { + "source": "iana" + }, + "application/vnd.espass-espass+zip": { + "source": "iana" + }, + "application/vnd.eszigno3+xml": { + "source": "iana", + "extensions": ["es3","et3"] + }, + "application/vnd.etsi.aoc+xml": { + "source": "iana" + }, + "application/vnd.etsi.asic-e+zip": { + "source": "iana" + }, + "application/vnd.etsi.asic-s+zip": { + "source": "iana" + }, + "application/vnd.etsi.cug+xml": { + "source": "iana" + }, + "application/vnd.etsi.iptvcommand+xml": { + "source": "iana" + }, + "application/vnd.etsi.iptvdiscovery+xml": { + "source": "iana" + }, + "application/vnd.etsi.iptvprofile+xml": { + "source": "iana" + }, + "application/vnd.etsi.iptvsad-bc+xml": { + "source": "iana" + }, + "application/vnd.etsi.iptvsad-cod+xml": { + "source": "iana" + }, + "application/vnd.etsi.iptvsad-npvr+xml": { + "source": "iana" + }, + "application/vnd.etsi.iptvservice+xml": { + "source": "iana" + }, + "application/vnd.etsi.iptvsync+xml": { + "source": "iana" + }, + "application/vnd.etsi.iptvueprofile+xml": { + "source": "iana" + }, + "application/vnd.etsi.mcid+xml": { + "source": "iana" + }, + "application/vnd.etsi.mheg5": { + "source": "iana" + }, + "application/vnd.etsi.overload-control-policy-dataset+xml": { + "source": "iana" + }, + "application/vnd.etsi.pstn+xml": { + "source": "iana" + }, + "application/vnd.etsi.sci+xml": { + "source": "iana" + }, + "application/vnd.etsi.simservs+xml": { + "source": "iana" + }, + "application/vnd.etsi.timestamp-token": { + "source": "iana" + }, + "application/vnd.etsi.tsl+xml": { + "source": "iana" + }, + "application/vnd.etsi.tsl.der": { + "source": "iana" + }, + "application/vnd.eudora.data": { + "source": "iana" + }, + "application/vnd.ezpix-album": { + "source": "iana", + "extensions": ["ez2"] + }, + "application/vnd.ezpix-package": { + "source": "iana", + "extensions": ["ez3"] + }, + "application/vnd.f-secure.mobile": { + "source": "iana" + }, + "application/vnd.fastcopy-disk-image": { + "source": "iana" + }, + "application/vnd.fdf": { + "source": "iana", + "extensions": ["fdf"] + }, + "application/vnd.fdsn.mseed": { + "source": "iana", + "extensions": ["mseed"] + }, + "application/vnd.fdsn.seed": { + "source": "iana", + "extensions": ["seed","dataless"] + }, + "application/vnd.ffsns": { + "source": "iana" + }, + "application/vnd.filmit.zfc": { + "source": "iana" + }, + "application/vnd.fints": { + "source": "iana" + }, + "application/vnd.firemonkeys.cloudcell": { + "source": "iana" + }, + "application/vnd.flographit": { + "source": "iana", + "extensions": ["gph"] + }, + "application/vnd.fluxtime.clip": { + "source": "iana", + "extensions": ["ftc"] + }, + "application/vnd.font-fontforge-sfd": { + "source": "iana" + }, + "application/vnd.framemaker": { + "source": "iana", + "extensions": ["fm","frame","maker","book"] + }, + "application/vnd.frogans.fnc": { + "source": "iana", + "extensions": ["fnc"] + }, + "application/vnd.frogans.ltf": { + "source": "iana", + "extensions": ["ltf"] + }, + "application/vnd.fsc.weblaunch": { + "source": "iana", + "extensions": ["fsc"] + }, + "application/vnd.fujitsu.oasys": { + "source": "iana", + "extensions": ["oas"] + }, + "application/vnd.fujitsu.oasys2": { + "source": "iana", + "extensions": ["oa2"] + }, + "application/vnd.fujitsu.oasys3": { + "source": "iana", + "extensions": ["oa3"] + }, + "application/vnd.fujitsu.oasysgp": { + "source": "iana", + "extensions": ["fg5"] + }, + "application/vnd.fujitsu.oasysprs": { + "source": "iana", + "extensions": ["bh2"] + }, + "application/vnd.fujixerox.art-ex": { + "source": "iana" + }, + "application/vnd.fujixerox.art4": { + "source": "iana" + }, + "application/vnd.fujixerox.ddd": { + "source": "iana", + "extensions": ["ddd"] + }, + "application/vnd.fujixerox.docuworks": { + "source": "iana", + "extensions": ["xdw"] + }, + "application/vnd.fujixerox.docuworks.binder": { + "source": "iana", + "extensions": ["xbd"] + }, + "application/vnd.fujixerox.docuworks.container": { + "source": "iana" + }, + "application/vnd.fujixerox.hbpl": { + "source": "iana" + }, + "application/vnd.fut-misnet": { + "source": "iana" + }, + "application/vnd.fuzzysheet": { + "source": "iana", + "extensions": ["fzs"] + }, + "application/vnd.genomatix.tuxedo": { + "source": "iana", + "extensions": ["txd"] + }, + "application/vnd.geo+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.geocube+xml": { + "source": "iana" + }, + "application/vnd.geogebra.file": { + "source": "iana", + "extensions": ["ggb"] + }, + "application/vnd.geogebra.tool": { + "source": "iana", + "extensions": ["ggt"] + }, + "application/vnd.geometry-explorer": { + "source": "iana", + "extensions": ["gex","gre"] + }, + "application/vnd.geonext": { + "source": "iana", + "extensions": ["gxt"] + }, + "application/vnd.geoplan": { + "source": "iana", + "extensions": ["g2w"] + }, + "application/vnd.geospace": { + "source": "iana", + "extensions": ["g3w"] + }, + "application/vnd.gerber": { + "source": "iana" + }, + "application/vnd.globalplatform.card-content-mgt": { + "source": "iana" + }, + "application/vnd.globalplatform.card-content-mgt-response": { + "source": "iana" + }, + "application/vnd.gmx": { + "source": "iana", + "extensions": ["gmx"] + }, + "application/vnd.google-apps.document": { + "compressible": false, + "extensions": ["gdoc"] + }, + "application/vnd.google-apps.presentation": { + "compressible": false, + "extensions": ["gslides"] + }, + "application/vnd.google-apps.spreadsheet": { + "compressible": false, + "extensions": ["gsheet"] + }, + "application/vnd.google-earth.kml+xml": { + "source": "iana", + "compressible": true, + "extensions": ["kml"] + }, + "application/vnd.google-earth.kmz": { + "source": "iana", + "compressible": false, + "extensions": ["kmz"] + }, + "application/vnd.gov.sk.e-form+xml": { + "source": "iana" + }, + "application/vnd.gov.sk.e-form+zip": { + "source": "iana" + }, + "application/vnd.gov.sk.xmldatacontainer+xml": { + "source": "iana" + }, + "application/vnd.grafeq": { + "source": "iana", + "extensions": ["gqf","gqs"] + }, + "application/vnd.gridmp": { + "source": "iana" + }, + "application/vnd.groove-account": { + "source": "iana", + "extensions": ["gac"] + }, + "application/vnd.groove-help": { + "source": "iana", + "extensions": ["ghf"] + }, + "application/vnd.groove-identity-message": { + "source": "iana", + "extensions": ["gim"] + }, + "application/vnd.groove-injector": { + "source": "iana", + "extensions": ["grv"] + }, + "application/vnd.groove-tool-message": { + "source": "iana", + "extensions": ["gtm"] + }, + "application/vnd.groove-tool-template": { + "source": "iana", + "extensions": ["tpl"] + }, + "application/vnd.groove-vcard": { + "source": "iana", + "extensions": ["vcg"] + }, + "application/vnd.hal+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.hal+xml": { + "source": "iana", + "extensions": ["hal"] + }, + "application/vnd.handheld-entertainment+xml": { + "source": "iana", + "extensions": ["zmm"] + }, + "application/vnd.hbci": { + "source": "iana", + "extensions": ["hbci"] + }, + "application/vnd.hcl-bireports": { + "source": "iana" + }, + "application/vnd.hdt": { + "source": "iana" + }, + "application/vnd.heroku+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.hhe.lesson-player": { + "source": "iana", + "extensions": ["les"] + }, + "application/vnd.hp-hpgl": { + "source": "iana", + "extensions": ["hpgl"] + }, + "application/vnd.hp-hpid": { + "source": "iana", + "extensions": ["hpid"] + }, + "application/vnd.hp-hps": { + "source": "iana", + "extensions": ["hps"] + }, + "application/vnd.hp-jlyt": { + "source": "iana", + "extensions": ["jlt"] + }, + "application/vnd.hp-pcl": { + "source": "iana", + "extensions": ["pcl"] + }, + "application/vnd.hp-pclxl": { + "source": "iana", + "extensions": ["pclxl"] + }, + "application/vnd.httphone": { + "source": "iana" + }, + "application/vnd.hydrostatix.sof-data": { + "source": "iana", + "extensions": ["sfd-hdstx"] + }, + "application/vnd.hyperdrive+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.hzn-3d-crossword": { + "source": "iana" + }, + "application/vnd.ibm.afplinedata": { + "source": "iana" + }, + "application/vnd.ibm.electronic-media": { + "source": "iana" + }, + "application/vnd.ibm.minipay": { + "source": "iana", + "extensions": ["mpy"] + }, + "application/vnd.ibm.modcap": { + "source": "iana", + "extensions": ["afp","listafp","list3820"] + }, + "application/vnd.ibm.rights-management": { + "source": "iana", + "extensions": ["irm"] + }, + "application/vnd.ibm.secure-container": { + "source": "iana", + "extensions": ["sc"] + }, + "application/vnd.iccprofile": { + "source": "iana", + "extensions": ["icc","icm"] + }, + "application/vnd.ieee.1905": { + "source": "iana" + }, + "application/vnd.igloader": { + "source": "iana", + "extensions": ["igl"] + }, + "application/vnd.immervision-ivp": { + "source": "iana", + "extensions": ["ivp"] + }, + "application/vnd.immervision-ivu": { + "source": "iana", + "extensions": ["ivu"] + }, + "application/vnd.ims.imsccv1p1": { + "source": "iana" + }, + "application/vnd.ims.imsccv1p2": { + "source": "iana" + }, + "application/vnd.ims.imsccv1p3": { + "source": "iana" + }, + "application/vnd.ims.lis.v2.result+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.ims.lti.v2.toolconsumerprofile+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.ims.lti.v2.toolproxy+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.ims.lti.v2.toolproxy.id+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.ims.lti.v2.toolsettings+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.ims.lti.v2.toolsettings.simple+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.informedcontrol.rms+xml": { + "source": "iana" + }, + "application/vnd.informix-visionary": { + "source": "iana" + }, + "application/vnd.infotech.project": { + "source": "iana" + }, + "application/vnd.infotech.project+xml": { + "source": "iana" + }, + "application/vnd.innopath.wamp.notification": { + "source": "iana" + }, + "application/vnd.insors.igm": { + "source": "iana", + "extensions": ["igm"] + }, + "application/vnd.intercon.formnet": { + "source": "iana", + "extensions": ["xpw","xpx"] + }, + "application/vnd.intergeo": { + "source": "iana", + "extensions": ["i2g"] + }, + "application/vnd.intertrust.digibox": { + "source": "iana" + }, + "application/vnd.intertrust.nncp": { + "source": "iana" + }, + "application/vnd.intu.qbo": { + "source": "iana", + "extensions": ["qbo"] + }, + "application/vnd.intu.qfx": { + "source": "iana", + "extensions": ["qfx"] + }, + "application/vnd.iptc.g2.catalogitem+xml": { + "source": "iana" + }, + "application/vnd.iptc.g2.conceptitem+xml": { + "source": "iana" + }, + "application/vnd.iptc.g2.knowledgeitem+xml": { + "source": "iana" + }, + "application/vnd.iptc.g2.newsitem+xml": { + "source": "iana" + }, + "application/vnd.iptc.g2.newsmessage+xml": { + "source": "iana" + }, + "application/vnd.iptc.g2.packageitem+xml": { + "source": "iana" + }, + "application/vnd.iptc.g2.planningitem+xml": { + "source": "iana" + }, + "application/vnd.ipunplugged.rcprofile": { + "source": "iana", + "extensions": ["rcprofile"] + }, + "application/vnd.irepository.package+xml": { + "source": "iana", + "extensions": ["irp"] + }, + "application/vnd.is-xpr": { + "source": "iana", + "extensions": ["xpr"] + }, + "application/vnd.isac.fcs": { + "source": "iana", + "extensions": ["fcs"] + }, + "application/vnd.jam": { + "source": "iana", + "extensions": ["jam"] + }, + "application/vnd.japannet-directory-service": { + "source": "iana" + }, + "application/vnd.japannet-jpnstore-wakeup": { + "source": "iana" + }, + "application/vnd.japannet-payment-wakeup": { + "source": "iana" + }, + "application/vnd.japannet-registration": { + "source": "iana" + }, + "application/vnd.japannet-registration-wakeup": { + "source": "iana" + }, + "application/vnd.japannet-setstore-wakeup": { + "source": "iana" + }, + "application/vnd.japannet-verification": { + "source": "iana" + }, + "application/vnd.japannet-verification-wakeup": { + "source": "iana" + }, + "application/vnd.jcp.javame.midlet-rms": { + "source": "iana", + "extensions": ["rms"] + }, + "application/vnd.jisp": { + "source": "iana", + "extensions": ["jisp"] + }, + "application/vnd.joost.joda-archive": { + "source": "iana", + "extensions": ["joda"] + }, + "application/vnd.jsk.isdn-ngn": { + "source": "iana" + }, + "application/vnd.kahootz": { + "source": "iana", + "extensions": ["ktz","ktr"] + }, + "application/vnd.kde.karbon": { + "source": "iana", + "extensions": ["karbon"] + }, + "application/vnd.kde.kchart": { + "source": "iana", + "extensions": ["chrt"] + }, + "application/vnd.kde.kformula": { + "source": "iana", + "extensions": ["kfo"] + }, + "application/vnd.kde.kivio": { + "source": "iana", + "extensions": ["flw"] + }, + "application/vnd.kde.kontour": { + "source": "iana", + "extensions": ["kon"] + }, + "application/vnd.kde.kpresenter": { + "source": "iana", + "extensions": ["kpr","kpt"] + }, + "application/vnd.kde.kspread": { + "source": "iana", + "extensions": ["ksp"] + }, + "application/vnd.kde.kword": { + "source": "iana", + "extensions": ["kwd","kwt"] + }, + "application/vnd.kenameaapp": { + "source": "iana", + "extensions": ["htke"] + }, + "application/vnd.kidspiration": { + "source": "iana", + "extensions": ["kia"] + }, + "application/vnd.kinar": { + "source": "iana", + "extensions": ["kne","knp"] + }, + "application/vnd.koan": { + "source": "iana", + "extensions": ["skp","skd","skt","skm"] + }, + "application/vnd.kodak-descriptor": { + "source": "iana", + "extensions": ["sse"] + }, + "application/vnd.las.las+xml": { + "source": "iana", + "extensions": ["lasxml"] + }, + "application/vnd.liberty-request+xml": { + "source": "iana" + }, + "application/vnd.llamagraphics.life-balance.desktop": { + "source": "iana", + "extensions": ["lbd"] + }, + "application/vnd.llamagraphics.life-balance.exchange+xml": { + "source": "iana", + "extensions": ["lbe"] + }, + "application/vnd.lotus-1-2-3": { + "source": "iana", + "extensions": ["123"] + }, + "application/vnd.lotus-approach": { + "source": "iana", + "extensions": ["apr"] + }, + "application/vnd.lotus-freelance": { + "source": "iana", + "extensions": ["pre"] + }, + "application/vnd.lotus-notes": { + "source": "iana", + "extensions": ["nsf"] + }, + "application/vnd.lotus-organizer": { + "source": "iana", + "extensions": ["org"] + }, + "application/vnd.lotus-screencam": { + "source": "iana", + "extensions": ["scm"] + }, + "application/vnd.lotus-wordpro": { + "source": "iana", + "extensions": ["lwp"] + }, + "application/vnd.macports.portpkg": { + "source": "iana", + "extensions": ["portpkg"] + }, + "application/vnd.mapbox-vector-tile": { + "source": "iana" + }, + "application/vnd.marlin.drm.actiontoken+xml": { + "source": "iana" + }, + "application/vnd.marlin.drm.conftoken+xml": { + "source": "iana" + }, + "application/vnd.marlin.drm.license+xml": { + "source": "iana" + }, + "application/vnd.marlin.drm.mdcf": { + "source": "iana" + }, + "application/vnd.mason+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.maxmind.maxmind-db": { + "source": "iana" + }, + "application/vnd.mcd": { + "source": "iana", + "extensions": ["mcd"] + }, + "application/vnd.medcalcdata": { + "source": "iana", + "extensions": ["mc1"] + }, + "application/vnd.mediastation.cdkey": { + "source": "iana", + "extensions": ["cdkey"] + }, + "application/vnd.meridian-slingshot": { + "source": "iana" + }, + "application/vnd.mfer": { + "source": "iana", + "extensions": ["mwf"] + }, + "application/vnd.mfmp": { + "source": "iana", + "extensions": ["mfm"] + }, + "application/vnd.micro+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.micrografx.flo": { + "source": "iana", + "extensions": ["flo"] + }, + "application/vnd.micrografx.igx": { + "source": "iana", + "extensions": ["igx"] + }, + "application/vnd.microsoft.portable-executable": { + "source": "iana" + }, + "application/vnd.miele+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.mif": { + "source": "iana", + "extensions": ["mif"] + }, + "application/vnd.minisoft-hp3000-save": { + "source": "iana" + }, + "application/vnd.mitsubishi.misty-guard.trustweb": { + "source": "iana" + }, + "application/vnd.mobius.daf": { + "source": "iana", + "extensions": ["daf"] + }, + "application/vnd.mobius.dis": { + "source": "iana", + "extensions": ["dis"] + }, + "application/vnd.mobius.mbk": { + "source": "iana", + "extensions": ["mbk"] + }, + "application/vnd.mobius.mqy": { + "source": "iana", + "extensions": ["mqy"] + }, + "application/vnd.mobius.msl": { + "source": "iana", + "extensions": ["msl"] + }, + "application/vnd.mobius.plc": { + "source": "iana", + "extensions": ["plc"] + }, + "application/vnd.mobius.txf": { + "source": "iana", + "extensions": ["txf"] + }, + "application/vnd.mophun.application": { + "source": "iana", + "extensions": ["mpn"] + }, + "application/vnd.mophun.certificate": { + "source": "iana", + "extensions": ["mpc"] + }, + "application/vnd.motorola.flexsuite": { + "source": "iana" + }, + "application/vnd.motorola.flexsuite.adsi": { + "source": "iana" + }, + "application/vnd.motorola.flexsuite.fis": { + "source": "iana" + }, + "application/vnd.motorola.flexsuite.gotap": { + "source": "iana" + }, + "application/vnd.motorola.flexsuite.kmr": { + "source": "iana" + }, + "application/vnd.motorola.flexsuite.ttc": { + "source": "iana" + }, + "application/vnd.motorola.flexsuite.wem": { + "source": "iana" + }, + "application/vnd.motorola.iprm": { + "source": "iana" + }, + "application/vnd.mozilla.xul+xml": { + "source": "iana", + "compressible": true, + "extensions": ["xul"] + }, + "application/vnd.ms-3mfdocument": { + "source": "iana" + }, + "application/vnd.ms-artgalry": { + "source": "iana", + "extensions": ["cil"] + }, + "application/vnd.ms-asf": { + "source": "iana" + }, + "application/vnd.ms-cab-compressed": { + "source": "iana", + "extensions": ["cab"] + }, + "application/vnd.ms-color.iccprofile": { + "source": "apache" + }, + "application/vnd.ms-excel": { + "source": "iana", + "compressible": false, + "extensions": ["xls","xlm","xla","xlc","xlt","xlw"] + }, + "application/vnd.ms-excel.addin.macroenabled.12": { + "source": "iana", + "extensions": ["xlam"] + }, + "application/vnd.ms-excel.sheet.binary.macroenabled.12": { + "source": "iana", + "extensions": ["xlsb"] + }, + "application/vnd.ms-excel.sheet.macroenabled.12": { + "source": "iana", + "extensions": ["xlsm"] + }, + "application/vnd.ms-excel.template.macroenabled.12": { + "source": "iana", + "extensions": ["xltm"] + }, + "application/vnd.ms-fontobject": { + "source": "iana", + "compressible": true, + "extensions": ["eot"] + }, + "application/vnd.ms-htmlhelp": { + "source": "iana", + "extensions": ["chm"] + }, + "application/vnd.ms-ims": { + "source": "iana", + "extensions": ["ims"] + }, + "application/vnd.ms-lrm": { + "source": "iana", + "extensions": ["lrm"] + }, + "application/vnd.ms-office.activex+xml": { + "source": "iana" + }, + "application/vnd.ms-officetheme": { + "source": "iana", + "extensions": ["thmx"] + }, + "application/vnd.ms-opentype": { + "source": "apache", + "compressible": true + }, + "application/vnd.ms-package.obfuscated-opentype": { + "source": "apache" + }, + "application/vnd.ms-pki.seccat": { + "source": "apache", + "extensions": ["cat"] + }, + "application/vnd.ms-pki.stl": { + "source": "apache", + "extensions": ["stl"] + }, + "application/vnd.ms-playready.initiator+xml": { + "source": "iana" + }, + "application/vnd.ms-powerpoint": { + "source": "iana", + "compressible": false, + "extensions": ["ppt","pps","pot"] + }, + "application/vnd.ms-powerpoint.addin.macroenabled.12": { + "source": "iana", + "extensions": ["ppam"] + }, + "application/vnd.ms-powerpoint.presentation.macroenabled.12": { + "source": "iana", + "extensions": ["pptm"] + }, + "application/vnd.ms-powerpoint.slide.macroenabled.12": { + "source": "iana", + "extensions": ["sldm"] + }, + "application/vnd.ms-powerpoint.slideshow.macroenabled.12": { + "source": "iana", + "extensions": ["ppsm"] + }, + "application/vnd.ms-powerpoint.template.macroenabled.12": { + "source": "iana", + "extensions": ["potm"] + }, + "application/vnd.ms-printdevicecapabilities+xml": { + "source": "iana" + }, + "application/vnd.ms-printing.printticket+xml": { + "source": "apache" + }, + "application/vnd.ms-printschematicket+xml": { + "source": "iana" + }, + "application/vnd.ms-project": { + "source": "iana", + "extensions": ["mpp","mpt"] + }, + "application/vnd.ms-tnef": { + "source": "iana" + }, + "application/vnd.ms-windows.devicepairing": { + "source": "iana" + }, + "application/vnd.ms-windows.nwprinting.oob": { + "source": "iana" + }, + "application/vnd.ms-windows.printerpairing": { + "source": "iana" + }, + "application/vnd.ms-windows.wsd.oob": { + "source": "iana" + }, + "application/vnd.ms-wmdrm.lic-chlg-req": { + "source": "iana" + }, + "application/vnd.ms-wmdrm.lic-resp": { + "source": "iana" + }, + "application/vnd.ms-wmdrm.meter-chlg-req": { + "source": "iana" + }, + "application/vnd.ms-wmdrm.meter-resp": { + "source": "iana" + }, + "application/vnd.ms-word.document.macroenabled.12": { + "source": "iana", + "extensions": ["docm"] + }, + "application/vnd.ms-word.template.macroenabled.12": { + "source": "iana", + "extensions": ["dotm"] + }, + "application/vnd.ms-works": { + "source": "iana", + "extensions": ["wps","wks","wcm","wdb"] + }, + "application/vnd.ms-wpl": { + "source": "iana", + "extensions": ["wpl"] + }, + "application/vnd.ms-xpsdocument": { + "source": "iana", + "compressible": false, + "extensions": ["xps"] + }, + "application/vnd.msa-disk-image": { + "source": "iana" + }, + "application/vnd.mseq": { + "source": "iana", + "extensions": ["mseq"] + }, + "application/vnd.msign": { + "source": "iana" + }, + "application/vnd.multiad.creator": { + "source": "iana" + }, + "application/vnd.multiad.creator.cif": { + "source": "iana" + }, + "application/vnd.music-niff": { + "source": "iana" + }, + "application/vnd.musician": { + "source": "iana", + "extensions": ["mus"] + }, + "application/vnd.muvee.style": { + "source": "iana", + "extensions": ["msty"] + }, + "application/vnd.mynfc": { + "source": "iana", + "extensions": ["taglet"] + }, + "application/vnd.ncd.control": { + "source": "iana" + }, + "application/vnd.ncd.reference": { + "source": "iana" + }, + "application/vnd.nearst.inv+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.nervana": { + "source": "iana" + }, + "application/vnd.netfpx": { + "source": "iana" + }, + "application/vnd.neurolanguage.nlu": { + "source": "iana", + "extensions": ["nlu"] + }, + "application/vnd.nintendo.nitro.rom": { + "source": "iana" + }, + "application/vnd.nintendo.snes.rom": { + "source": "iana" + }, + "application/vnd.nitf": { + "source": "iana", + "extensions": ["ntf","nitf"] + }, + "application/vnd.noblenet-directory": { + "source": "iana", + "extensions": ["nnd"] + }, + "application/vnd.noblenet-sealer": { + "source": "iana", + "extensions": ["nns"] + }, + "application/vnd.noblenet-web": { + "source": "iana", + "extensions": ["nnw"] + }, + "application/vnd.nokia.catalogs": { + "source": "iana" + }, + "application/vnd.nokia.conml+wbxml": { + "source": "iana" + }, + "application/vnd.nokia.conml+xml": { + "source": "iana" + }, + "application/vnd.nokia.iptv.config+xml": { + "source": "iana" + }, + "application/vnd.nokia.isds-radio-presets": { + "source": "iana" + }, + "application/vnd.nokia.landmark+wbxml": { + "source": "iana" + }, + "application/vnd.nokia.landmark+xml": { + "source": "iana" + }, + "application/vnd.nokia.landmarkcollection+xml": { + "source": "iana" + }, + "application/vnd.nokia.n-gage.ac+xml": { + "source": "iana" + }, + "application/vnd.nokia.n-gage.data": { + "source": "iana", + "extensions": ["ngdat"] + }, + "application/vnd.nokia.n-gage.symbian.install": { + "source": "iana", + "extensions": ["n-gage"] + }, + "application/vnd.nokia.ncd": { + "source": "iana" + }, + "application/vnd.nokia.pcd+wbxml": { + "source": "iana" + }, + "application/vnd.nokia.pcd+xml": { + "source": "iana" + }, + "application/vnd.nokia.radio-preset": { + "source": "iana", + "extensions": ["rpst"] + }, + "application/vnd.nokia.radio-presets": { + "source": "iana", + "extensions": ["rpss"] + }, + "application/vnd.novadigm.edm": { + "source": "iana", + "extensions": ["edm"] + }, + "application/vnd.novadigm.edx": { + "source": "iana", + "extensions": ["edx"] + }, + "application/vnd.novadigm.ext": { + "source": "iana", + "extensions": ["ext"] + }, + "application/vnd.ntt-local.content-share": { + "source": "iana" + }, + "application/vnd.ntt-local.file-transfer": { + "source": "iana" + }, + "application/vnd.ntt-local.ogw_remote-access": { + "source": "iana" + }, + "application/vnd.ntt-local.sip-ta_remote": { + "source": "iana" + }, + "application/vnd.ntt-local.sip-ta_tcp_stream": { + "source": "iana" + }, + "application/vnd.oasis.opendocument.chart": { + "source": "iana", + "extensions": ["odc"] + }, + "application/vnd.oasis.opendocument.chart-template": { + "source": "iana", + "extensions": ["otc"] + }, + "application/vnd.oasis.opendocument.database": { + "source": "iana", + "extensions": ["odb"] + }, + "application/vnd.oasis.opendocument.formula": { + "source": "iana", + "extensions": ["odf"] + }, + "application/vnd.oasis.opendocument.formula-template": { + "source": "iana", + "extensions": ["odft"] + }, + "application/vnd.oasis.opendocument.graphics": { + "source": "iana", + "compressible": false, + "extensions": ["odg"] + }, + "application/vnd.oasis.opendocument.graphics-template": { + "source": "iana", + "extensions": ["otg"] + }, + "application/vnd.oasis.opendocument.image": { + "source": "iana", + "extensions": ["odi"] + }, + "application/vnd.oasis.opendocument.image-template": { + "source": "iana", + "extensions": ["oti"] + }, + "application/vnd.oasis.opendocument.presentation": { + "source": "iana", + "compressible": false, + "extensions": ["odp"] + }, + "application/vnd.oasis.opendocument.presentation-template": { + "source": "iana", + "extensions": ["otp"] + }, + "application/vnd.oasis.opendocument.spreadsheet": { + "source": "iana", + "compressible": false, + "extensions": ["ods"] + }, + "application/vnd.oasis.opendocument.spreadsheet-template": { + "source": "iana", + "extensions": ["ots"] + }, + "application/vnd.oasis.opendocument.text": { + "source": "iana", + "compressible": false, + "extensions": ["odt"] + }, + "application/vnd.oasis.opendocument.text-master": { + "source": "iana", + "extensions": ["odm"] + }, + "application/vnd.oasis.opendocument.text-template": { + "source": "iana", + "extensions": ["ott"] + }, + "application/vnd.oasis.opendocument.text-web": { + "source": "iana", + "extensions": ["oth"] + }, + "application/vnd.obn": { + "source": "iana" + }, + "application/vnd.oftn.l10n+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.oipf.contentaccessdownload+xml": { + "source": "iana" + }, + "application/vnd.oipf.contentaccessstreaming+xml": { + "source": "iana" + }, + "application/vnd.oipf.cspg-hexbinary": { + "source": "iana" + }, + "application/vnd.oipf.dae.svg+xml": { + "source": "iana" + }, + "application/vnd.oipf.dae.xhtml+xml": { + "source": "iana" + }, + "application/vnd.oipf.mippvcontrolmessage+xml": { + "source": "iana" + }, + "application/vnd.oipf.pae.gem": { + "source": "iana" + }, + "application/vnd.oipf.spdiscovery+xml": { + "source": "iana" + }, + "application/vnd.oipf.spdlist+xml": { + "source": "iana" + }, + "application/vnd.oipf.ueprofile+xml": { + "source": "iana" + }, + "application/vnd.oipf.userprofile+xml": { + "source": "iana" + }, + "application/vnd.olpc-sugar": { + "source": "iana", + "extensions": ["xo"] + }, + "application/vnd.oma-scws-config": { + "source": "iana" + }, + "application/vnd.oma-scws-http-request": { + "source": "iana" + }, + "application/vnd.oma-scws-http-response": { + "source": "iana" + }, + "application/vnd.oma.bcast.associated-procedure-parameter+xml": { + "source": "iana" + }, + "application/vnd.oma.bcast.drm-trigger+xml": { + "source": "iana" + }, + "application/vnd.oma.bcast.imd+xml": { + "source": "iana" + }, + "application/vnd.oma.bcast.ltkm": { + "source": "iana" + }, + "application/vnd.oma.bcast.notification+xml": { + "source": "iana" + }, + "application/vnd.oma.bcast.provisioningtrigger": { + "source": "iana" + }, + "application/vnd.oma.bcast.sgboot": { + "source": "iana" + }, + "application/vnd.oma.bcast.sgdd+xml": { + "source": "iana" + }, + "application/vnd.oma.bcast.sgdu": { + "source": "iana" + }, + "application/vnd.oma.bcast.simple-symbol-container": { + "source": "iana" + }, + "application/vnd.oma.bcast.smartcard-trigger+xml": { + "source": "iana" + }, + "application/vnd.oma.bcast.sprov+xml": { + "source": "iana" + }, + "application/vnd.oma.bcast.stkm": { + "source": "iana" + }, + "application/vnd.oma.cab-address-book+xml": { + "source": "iana" + }, + "application/vnd.oma.cab-feature-handler+xml": { + "source": "iana" + }, + "application/vnd.oma.cab-pcc+xml": { + "source": "iana" + }, + "application/vnd.oma.cab-subs-invite+xml": { + "source": "iana" + }, + "application/vnd.oma.cab-user-prefs+xml": { + "source": "iana" + }, + "application/vnd.oma.dcd": { + "source": "iana" + }, + "application/vnd.oma.dcdc": { + "source": "iana" + }, + "application/vnd.oma.dd2+xml": { + "source": "iana", + "extensions": ["dd2"] + }, + "application/vnd.oma.drm.risd+xml": { + "source": "iana" + }, + "application/vnd.oma.group-usage-list+xml": { + "source": "iana" + }, + "application/vnd.oma.lwm2m+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.oma.lwm2m+tlv": { + "source": "iana" + }, + "application/vnd.oma.pal+xml": { + "source": "iana" + }, + "application/vnd.oma.poc.detailed-progress-report+xml": { + "source": "iana" + }, + "application/vnd.oma.poc.final-report+xml": { + "source": "iana" + }, + "application/vnd.oma.poc.groups+xml": { + "source": "iana" + }, + "application/vnd.oma.poc.invocation-descriptor+xml": { + "source": "iana" + }, + "application/vnd.oma.poc.optimized-progress-report+xml": { + "source": "iana" + }, + "application/vnd.oma.push": { + "source": "iana" + }, + "application/vnd.oma.scidm.messages+xml": { + "source": "iana" + }, + "application/vnd.oma.xcap-directory+xml": { + "source": "iana" + }, + "application/vnd.omads-email+xml": { + "source": "iana" + }, + "application/vnd.omads-file+xml": { + "source": "iana" + }, + "application/vnd.omads-folder+xml": { + "source": "iana" + }, + "application/vnd.omaloc-supl-init": { + "source": "iana" + }, + "application/vnd.onepager": { + "source": "iana" + }, + "application/vnd.openblox.game+xml": { + "source": "iana" + }, + "application/vnd.openblox.game-binary": { + "source": "iana" + }, + "application/vnd.openeye.oeb": { + "source": "iana" + }, + "application/vnd.openofficeorg.extension": { + "source": "apache", + "extensions": ["oxt"] + }, + "application/vnd.openxmlformats-officedocument.custom-properties+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.customxmlproperties+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.drawing+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.drawingml.chart+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.drawingml.chartshapes+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.drawingml.diagramcolors+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.drawingml.diagramdata+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.drawingml.diagramlayout+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.drawingml.diagramstyle+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.extended-properties+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml-template": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml.commentauthors+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml.comments+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml.handoutmaster+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml.notesmaster+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml.notesslide+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml.presentation": { + "source": "iana", + "compressible": false, + "extensions": ["pptx"] + }, + "application/vnd.openxmlformats-officedocument.presentationml.presentation.main+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml.presprops+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml.slide": { + "source": "iana", + "extensions": ["sldx"] + }, + "application/vnd.openxmlformats-officedocument.presentationml.slide+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml.slidelayout+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml.slidemaster+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml.slideshow": { + "source": "iana", + "extensions": ["ppsx"] + }, + "application/vnd.openxmlformats-officedocument.presentationml.slideshow.main+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml.slideupdateinfo+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml.tablestyles+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml.tags+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml.template": { + "source": "apache", + "extensions": ["potx"] + }, + "application/vnd.openxmlformats-officedocument.presentationml.template.main+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.presentationml.viewprops+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml-template": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.calcchain+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.chartsheet+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.comments+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.connections+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.dialogsheet+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.externallink+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.pivotcachedefinition+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.pivotcacherecords+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.pivottable+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.querytable+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.revisionheaders+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.revisionlog+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.sharedstrings+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet": { + "source": "iana", + "compressible": false, + "extensions": ["xlsx"] + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet.main+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.sheetmetadata+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.styles+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.table+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.tablesinglecells+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.template": { + "source": "apache", + "extensions": ["xltx"] + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.template.main+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.usernames+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.volatiledependencies+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.spreadsheetml.worksheet+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.theme+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.themeoverride+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.vmldrawing": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.wordprocessingml-template": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.wordprocessingml.comments+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.wordprocessingml.document": { + "source": "iana", + "compressible": false, + "extensions": ["docx"] + }, + "application/vnd.openxmlformats-officedocument.wordprocessingml.document.glossary+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.wordprocessingml.document.main+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.wordprocessingml.endnotes+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.wordprocessingml.fonttable+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.wordprocessingml.footer+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.wordprocessingml.footnotes+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.wordprocessingml.numbering+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.wordprocessingml.settings+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.wordprocessingml.styles+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.wordprocessingml.template": { + "source": "apache", + "extensions": ["dotx"] + }, + "application/vnd.openxmlformats-officedocument.wordprocessingml.template.main+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-officedocument.wordprocessingml.websettings+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-package.core-properties+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-package.digital-signature-xmlsignature+xml": { + "source": "iana" + }, + "application/vnd.openxmlformats-package.relationships+xml": { + "source": "iana" + }, + "application/vnd.oracle.resource+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.orange.indata": { + "source": "iana" + }, + "application/vnd.osa.netdeploy": { + "source": "iana" + }, + "application/vnd.osgeo.mapguide.package": { + "source": "iana", + "extensions": ["mgp"] + }, + "application/vnd.osgi.bundle": { + "source": "iana" + }, + "application/vnd.osgi.dp": { + "source": "iana", + "extensions": ["dp"] + }, + "application/vnd.osgi.subsystem": { + "source": "iana", + "extensions": ["esa"] + }, + "application/vnd.otps.ct-kip+xml": { + "source": "iana" + }, + "application/vnd.oxli.countgraph": { + "source": "iana" + }, + "application/vnd.pagerduty+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.palm": { + "source": "iana", + "extensions": ["pdb","pqa","oprc"] + }, + "application/vnd.panoply": { + "source": "iana" + }, + "application/vnd.paos+xml": { + "source": "iana" + }, + "application/vnd.paos.xml": { + "source": "apache" + }, + "application/vnd.pawaafile": { + "source": "iana", + "extensions": ["paw"] + }, + "application/vnd.pcos": { + "source": "iana" + }, + "application/vnd.pg.format": { + "source": "iana", + "extensions": ["str"] + }, + "application/vnd.pg.osasli": { + "source": "iana", + "extensions": ["ei6"] + }, + "application/vnd.piaccess.application-licence": { + "source": "iana" + }, + "application/vnd.picsel": { + "source": "iana", + "extensions": ["efif"] + }, + "application/vnd.pmi.widget": { + "source": "iana", + "extensions": ["wg"] + }, + "application/vnd.poc.group-advertisement+xml": { + "source": "iana" + }, + "application/vnd.pocketlearn": { + "source": "iana", + "extensions": ["plf"] + }, + "application/vnd.powerbuilder6": { + "source": "iana", + "extensions": ["pbd"] + }, + "application/vnd.powerbuilder6-s": { + "source": "iana" + }, + "application/vnd.powerbuilder7": { + "source": "iana" + }, + "application/vnd.powerbuilder7-s": { + "source": "iana" + }, + "application/vnd.powerbuilder75": { + "source": "iana" + }, + "application/vnd.powerbuilder75-s": { + "source": "iana" + }, + "application/vnd.preminet": { + "source": "iana" + }, + "application/vnd.previewsystems.box": { + "source": "iana", + "extensions": ["box"] + }, + "application/vnd.proteus.magazine": { + "source": "iana", + "extensions": ["mgz"] + }, + "application/vnd.publishare-delta-tree": { + "source": "iana", + "extensions": ["qps"] + }, + "application/vnd.pvi.ptid1": { + "source": "iana", + "extensions": ["ptid"] + }, + "application/vnd.pwg-multiplexed": { + "source": "iana" + }, + "application/vnd.pwg-xhtml-print+xml": { + "source": "iana" + }, + "application/vnd.qualcomm.brew-app-res": { + "source": "iana" + }, + "application/vnd.quarantainenet": { + "source": "iana" + }, + "application/vnd.quark.quarkxpress": { + "source": "iana", + "extensions": ["qxd","qxt","qwd","qwt","qxl","qxb"] + }, + "application/vnd.quobject-quoxdocument": { + "source": "iana" + }, + "application/vnd.radisys.moml+xml": { + "source": "iana" + }, + "application/vnd.radisys.msml+xml": { + "source": "iana" + }, + "application/vnd.radisys.msml-audit+xml": { + "source": "iana" + }, + "application/vnd.radisys.msml-audit-conf+xml": { + "source": "iana" + }, + "application/vnd.radisys.msml-audit-conn+xml": { + "source": "iana" + }, + "application/vnd.radisys.msml-audit-dialog+xml": { + "source": "iana" + }, + "application/vnd.radisys.msml-audit-stream+xml": { + "source": "iana" + }, + "application/vnd.radisys.msml-conf+xml": { + "source": "iana" + }, + "application/vnd.radisys.msml-dialog+xml": { + "source": "iana" + }, + "application/vnd.radisys.msml-dialog-base+xml": { + "source": "iana" + }, + "application/vnd.radisys.msml-dialog-fax-detect+xml": { + "source": "iana" + }, + "application/vnd.radisys.msml-dialog-fax-sendrecv+xml": { + "source": "iana" + }, + "application/vnd.radisys.msml-dialog-group+xml": { + "source": "iana" + }, + "application/vnd.radisys.msml-dialog-speech+xml": { + "source": "iana" + }, + "application/vnd.radisys.msml-dialog-transform+xml": { + "source": "iana" + }, + "application/vnd.rainstor.data": { + "source": "iana" + }, + "application/vnd.rapid": { + "source": "iana" + }, + "application/vnd.rar": { + "source": "iana" + }, + "application/vnd.realvnc.bed": { + "source": "iana", + "extensions": ["bed"] + }, + "application/vnd.recordare.musicxml": { + "source": "iana", + "extensions": ["mxl"] + }, + "application/vnd.recordare.musicxml+xml": { + "source": "iana", + "extensions": ["musicxml"] + }, + "application/vnd.renlearn.rlprint": { + "source": "iana" + }, + "application/vnd.rig.cryptonote": { + "source": "iana", + "extensions": ["cryptonote"] + }, + "application/vnd.rim.cod": { + "source": "apache", + "extensions": ["cod"] + }, + "application/vnd.rn-realmedia": { + "source": "apache", + "extensions": ["rm"] + }, + "application/vnd.rn-realmedia-vbr": { + "source": "apache", + "extensions": ["rmvb"] + }, + "application/vnd.route66.link66+xml": { + "source": "iana", + "extensions": ["link66"] + }, + "application/vnd.rs-274x": { + "source": "iana" + }, + "application/vnd.ruckus.download": { + "source": "iana" + }, + "application/vnd.s3sms": { + "source": "iana" + }, + "application/vnd.sailingtracker.track": { + "source": "iana", + "extensions": ["st"] + }, + "application/vnd.sbm.cid": { + "source": "iana" + }, + "application/vnd.sbm.mid2": { + "source": "iana" + }, + "application/vnd.scribus": { + "source": "iana" + }, + "application/vnd.sealed.3df": { + "source": "iana" + }, + "application/vnd.sealed.csf": { + "source": "iana" + }, + "application/vnd.sealed.doc": { + "source": "iana" + }, + "application/vnd.sealed.eml": { + "source": "iana" + }, + "application/vnd.sealed.mht": { + "source": "iana" + }, + "application/vnd.sealed.net": { + "source": "iana" + }, + "application/vnd.sealed.ppt": { + "source": "iana" + }, + "application/vnd.sealed.tiff": { + "source": "iana" + }, + "application/vnd.sealed.xls": { + "source": "iana" + }, + "application/vnd.sealedmedia.softseal.html": { + "source": "iana" + }, + "application/vnd.sealedmedia.softseal.pdf": { + "source": "iana" + }, + "application/vnd.seemail": { + "source": "iana", + "extensions": ["see"] + }, + "application/vnd.sema": { + "source": "iana", + "extensions": ["sema"] + }, + "application/vnd.semd": { + "source": "iana", + "extensions": ["semd"] + }, + "application/vnd.semf": { + "source": "iana", + "extensions": ["semf"] + }, + "application/vnd.shana.informed.formdata": { + "source": "iana", + "extensions": ["ifm"] + }, + "application/vnd.shana.informed.formtemplate": { + "source": "iana", + "extensions": ["itp"] + }, + "application/vnd.shana.informed.interchange": { + "source": "iana", + "extensions": ["iif"] + }, + "application/vnd.shana.informed.package": { + "source": "iana", + "extensions": ["ipk"] + }, + "application/vnd.simtech-mindmapper": { + "source": "iana", + "extensions": ["twd","twds"] + }, + "application/vnd.siren+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.smaf": { + "source": "iana", + "extensions": ["mmf"] + }, + "application/vnd.smart.notebook": { + "source": "iana" + }, + "application/vnd.smart.teacher": { + "source": "iana", + "extensions": ["teacher"] + }, + "application/vnd.software602.filler.form+xml": { + "source": "iana" + }, + "application/vnd.software602.filler.form-xml-zip": { + "source": "iana" + }, + "application/vnd.solent.sdkm+xml": { + "source": "iana", + "extensions": ["sdkm","sdkd"] + }, + "application/vnd.spotfire.dxp": { + "source": "iana", + "extensions": ["dxp"] + }, + "application/vnd.spotfire.sfs": { + "source": "iana", + "extensions": ["sfs"] + }, + "application/vnd.sss-cod": { + "source": "iana" + }, + "application/vnd.sss-dtf": { + "source": "iana" + }, + "application/vnd.sss-ntf": { + "source": "iana" + }, + "application/vnd.stardivision.calc": { + "source": "apache", + "extensions": ["sdc"] + }, + "application/vnd.stardivision.draw": { + "source": "apache", + "extensions": ["sda"] + }, + "application/vnd.stardivision.impress": { + "source": "apache", + "extensions": ["sdd"] + }, + "application/vnd.stardivision.math": { + "source": "apache", + "extensions": ["smf"] + }, + "application/vnd.stardivision.writer": { + "source": "apache", + "extensions": ["sdw","vor"] + }, + "application/vnd.stardivision.writer-global": { + "source": "apache", + "extensions": ["sgl"] + }, + "application/vnd.stepmania.package": { + "source": "iana", + "extensions": ["smzip"] + }, + "application/vnd.stepmania.stepchart": { + "source": "iana", + "extensions": ["sm"] + }, + "application/vnd.street-stream": { + "source": "iana" + }, + "application/vnd.sun.wadl+xml": { + "source": "iana" + }, + "application/vnd.sun.xml.calc": { + "source": "apache", + "extensions": ["sxc"] + }, + "application/vnd.sun.xml.calc.template": { + "source": "apache", + "extensions": ["stc"] + }, + "application/vnd.sun.xml.draw": { + "source": "apache", + "extensions": ["sxd"] + }, + "application/vnd.sun.xml.draw.template": { + "source": "apache", + "extensions": ["std"] + }, + "application/vnd.sun.xml.impress": { + "source": "apache", + "extensions": ["sxi"] + }, + "application/vnd.sun.xml.impress.template": { + "source": "apache", + "extensions": ["sti"] + }, + "application/vnd.sun.xml.math": { + "source": "apache", + "extensions": ["sxm"] + }, + "application/vnd.sun.xml.writer": { + "source": "apache", + "extensions": ["sxw"] + }, + "application/vnd.sun.xml.writer.global": { + "source": "apache", + "extensions": ["sxg"] + }, + "application/vnd.sun.xml.writer.template": { + "source": "apache", + "extensions": ["stw"] + }, + "application/vnd.sus-calendar": { + "source": "iana", + "extensions": ["sus","susp"] + }, + "application/vnd.svd": { + "source": "iana", + "extensions": ["svd"] + }, + "application/vnd.swiftview-ics": { + "source": "iana" + }, + "application/vnd.symbian.install": { + "source": "apache", + "extensions": ["sis","sisx"] + }, + "application/vnd.syncml+xml": { + "source": "iana", + "extensions": ["xsm"] + }, + "application/vnd.syncml.dm+wbxml": { + "source": "iana", + "extensions": ["bdm"] + }, + "application/vnd.syncml.dm+xml": { + "source": "iana", + "extensions": ["xdm"] + }, + "application/vnd.syncml.dm.notification": { + "source": "iana" + }, + "application/vnd.syncml.dmddf+wbxml": { + "source": "iana" + }, + "application/vnd.syncml.dmddf+xml": { + "source": "iana" + }, + "application/vnd.syncml.dmtnds+wbxml": { + "source": "iana" + }, + "application/vnd.syncml.dmtnds+xml": { + "source": "iana" + }, + "application/vnd.syncml.ds.notification": { + "source": "iana" + }, + "application/vnd.tao.intent-module-archive": { + "source": "iana", + "extensions": ["tao"] + }, + "application/vnd.tcpdump.pcap": { + "source": "iana", + "extensions": ["pcap","cap","dmp"] + }, + "application/vnd.tmd.mediaflex.api+xml": { + "source": "iana" + }, + "application/vnd.tml": { + "source": "iana" + }, + "application/vnd.tmobile-livetv": { + "source": "iana", + "extensions": ["tmo"] + }, + "application/vnd.trid.tpt": { + "source": "iana", + "extensions": ["tpt"] + }, + "application/vnd.triscape.mxs": { + "source": "iana", + "extensions": ["mxs"] + }, + "application/vnd.trueapp": { + "source": "iana", + "extensions": ["tra"] + }, + "application/vnd.truedoc": { + "source": "iana" + }, + "application/vnd.ubisoft.webplayer": { + "source": "iana" + }, + "application/vnd.ufdl": { + "source": "iana", + "extensions": ["ufd","ufdl"] + }, + "application/vnd.uiq.theme": { + "source": "iana", + "extensions": ["utz"] + }, + "application/vnd.umajin": { + "source": "iana", + "extensions": ["umj"] + }, + "application/vnd.unity": { + "source": "iana", + "extensions": ["unityweb"] + }, + "application/vnd.uoml+xml": { + "source": "iana", + "extensions": ["uoml"] + }, + "application/vnd.uplanet.alert": { + "source": "iana" + }, + "application/vnd.uplanet.alert-wbxml": { + "source": "iana" + }, + "application/vnd.uplanet.bearer-choice": { + "source": "iana" + }, + "application/vnd.uplanet.bearer-choice-wbxml": { + "source": "iana" + }, + "application/vnd.uplanet.cacheop": { + "source": "iana" + }, + "application/vnd.uplanet.cacheop-wbxml": { + "source": "iana" + }, + "application/vnd.uplanet.channel": { + "source": "iana" + }, + "application/vnd.uplanet.channel-wbxml": { + "source": "iana" + }, + "application/vnd.uplanet.list": { + "source": "iana" + }, + "application/vnd.uplanet.list-wbxml": { + "source": "iana" + }, + "application/vnd.uplanet.listcmd": { + "source": "iana" + }, + "application/vnd.uplanet.listcmd-wbxml": { + "source": "iana" + }, + "application/vnd.uplanet.signal": { + "source": "iana" + }, + "application/vnd.uri-map": { + "source": "iana" + }, + "application/vnd.valve.source.material": { + "source": "iana" + }, + "application/vnd.vcx": { + "source": "iana", + "extensions": ["vcx"] + }, + "application/vnd.vd-study": { + "source": "iana" + }, + "application/vnd.vectorworks": { + "source": "iana" + }, + "application/vnd.vel+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.verimatrix.vcas": { + "source": "iana" + }, + "application/vnd.vidsoft.vidconference": { + "source": "iana" + }, + "application/vnd.visio": { + "source": "iana", + "extensions": ["vsd","vst","vss","vsw"] + }, + "application/vnd.visionary": { + "source": "iana", + "extensions": ["vis"] + }, + "application/vnd.vividence.scriptfile": { + "source": "iana" + }, + "application/vnd.vsf": { + "source": "iana", + "extensions": ["vsf"] + }, + "application/vnd.wap.sic": { + "source": "iana" + }, + "application/vnd.wap.slc": { + "source": "iana" + }, + "application/vnd.wap.wbxml": { + "source": "iana", + "extensions": ["wbxml"] + }, + "application/vnd.wap.wmlc": { + "source": "iana", + "extensions": ["wmlc"] + }, + "application/vnd.wap.wmlscriptc": { + "source": "iana", + "extensions": ["wmlsc"] + }, + "application/vnd.webturbo": { + "source": "iana", + "extensions": ["wtb"] + }, + "application/vnd.wfa.p2p": { + "source": "iana" + }, + "application/vnd.wfa.wsc": { + "source": "iana" + }, + "application/vnd.windows.devicepairing": { + "source": "iana" + }, + "application/vnd.wmc": { + "source": "iana" + }, + "application/vnd.wmf.bootstrap": { + "source": "iana" + }, + "application/vnd.wolfram.mathematica": { + "source": "iana" + }, + "application/vnd.wolfram.mathematica.package": { + "source": "iana" + }, + "application/vnd.wolfram.player": { + "source": "iana", + "extensions": ["nbp"] + }, + "application/vnd.wordperfect": { + "source": "iana", + "extensions": ["wpd"] + }, + "application/vnd.wqd": { + "source": "iana", + "extensions": ["wqd"] + }, + "application/vnd.wrq-hp3000-labelled": { + "source": "iana" + }, + "application/vnd.wt.stf": { + "source": "iana", + "extensions": ["stf"] + }, + "application/vnd.wv.csp+wbxml": { + "source": "iana" + }, + "application/vnd.wv.csp+xml": { + "source": "iana" + }, + "application/vnd.wv.ssp+xml": { + "source": "iana" + }, + "application/vnd.xacml+json": { + "source": "iana", + "compressible": true + }, + "application/vnd.xara": { + "source": "iana", + "extensions": ["xar"] + }, + "application/vnd.xfdl": { + "source": "iana", + "extensions": ["xfdl"] + }, + "application/vnd.xfdl.webform": { + "source": "iana" + }, + "application/vnd.xmi+xml": { + "source": "iana" + }, + "application/vnd.xmpie.cpkg": { + "source": "iana" + }, + "application/vnd.xmpie.dpkg": { + "source": "iana" + }, + "application/vnd.xmpie.plan": { + "source": "iana" + }, + "application/vnd.xmpie.ppkg": { + "source": "iana" + }, + "application/vnd.xmpie.xlim": { + "source": "iana" + }, + "application/vnd.yamaha.hv-dic": { + "source": "iana", + "extensions": ["hvd"] + }, + "application/vnd.yamaha.hv-script": { + "source": "iana", + "extensions": ["hvs"] + }, + "application/vnd.yamaha.hv-voice": { + "source": "iana", + "extensions": ["hvp"] + }, + "application/vnd.yamaha.openscoreformat": { + "source": "iana", + "extensions": ["osf"] + }, + "application/vnd.yamaha.openscoreformat.osfpvg+xml": { + "source": "iana", + "extensions": ["osfpvg"] + }, + "application/vnd.yamaha.remote-setup": { + "source": "iana" + }, + "application/vnd.yamaha.smaf-audio": { + "source": "iana", + "extensions": ["saf"] + }, + "application/vnd.yamaha.smaf-phrase": { + "source": "iana", + "extensions": ["spf"] + }, + "application/vnd.yamaha.through-ngn": { + "source": "iana" + }, + "application/vnd.yamaha.tunnel-udpencap": { + "source": "iana" + }, + "application/vnd.yaoweme": { + "source": "iana" + }, + "application/vnd.yellowriver-custom-menu": { + "source": "iana", + "extensions": ["cmp"] + }, + "application/vnd.zul": { + "source": "iana", + "extensions": ["zir","zirz"] + }, + "application/vnd.zzazz.deck+xml": { + "source": "iana", + "extensions": ["zaz"] + }, + "application/voicexml+xml": { + "source": "iana", + "extensions": ["vxml"] + }, + "application/vq-rtcpxr": { + "source": "iana" + }, + "application/watcherinfo+xml": { + "source": "iana" + }, + "application/whoispp-query": { + "source": "iana" + }, + "application/whoispp-response": { + "source": "iana" + }, + "application/widget": { + "source": "iana", + "extensions": ["wgt"] + }, + "application/winhlp": { + "source": "apache", + "extensions": ["hlp"] + }, + "application/wita": { + "source": "iana" + }, + "application/wordperfect5.1": { + "source": "iana" + }, + "application/wsdl+xml": { + "source": "iana", + "extensions": ["wsdl"] + }, + "application/wspolicy+xml": { + "source": "iana", + "extensions": ["wspolicy"] + }, + "application/x-7z-compressed": { + "source": "apache", + "compressible": false, + "extensions": ["7z"] + }, + "application/x-abiword": { + "source": "apache", + "extensions": ["abw"] + }, + "application/x-ace-compressed": { + "source": "apache", + "extensions": ["ace"] + }, + "application/x-amf": { + "source": "apache" + }, + "application/x-apple-diskimage": { + "source": "apache", + "extensions": ["dmg"] + }, + "application/x-authorware-bin": { + "source": "apache", + "extensions": ["aab","x32","u32","vox"] + }, + "application/x-authorware-map": { + "source": "apache", + "extensions": ["aam"] + }, + "application/x-authorware-seg": { + "source": "apache", + "extensions": ["aas"] + }, + "application/x-bcpio": { + "source": "apache", + "extensions": ["bcpio"] + }, + "application/x-bdoc": { + "compressible": false, + "extensions": ["bdoc"] + }, + "application/x-bittorrent": { + "source": "apache", + "extensions": ["torrent"] + }, + "application/x-blorb": { + "source": "apache", + "extensions": ["blb","blorb"] + }, + "application/x-bzip": { + "source": "apache", + "compressible": false, + "extensions": ["bz"] + }, + "application/x-bzip2": { + "source": "apache", + "compressible": false, + "extensions": ["bz2","boz"] + }, + "application/x-cbr": { + "source": "apache", + "extensions": ["cbr","cba","cbt","cbz","cb7"] + }, + "application/x-cdlink": { + "source": "apache", + "extensions": ["vcd"] + }, + "application/x-cfs-compressed": { + "source": "apache", + "extensions": ["cfs"] + }, + "application/x-chat": { + "source": "apache", + "extensions": ["chat"] + }, + "application/x-chess-pgn": { + "source": "apache", + "extensions": ["pgn"] + }, + "application/x-chrome-extension": { + "extensions": ["crx"] + }, + "application/x-cocoa": { + "source": "nginx", + "extensions": ["cco"] + }, + "application/x-compress": { + "source": "apache" + }, + "application/x-conference": { + "source": "apache", + "extensions": ["nsc"] + }, + "application/x-cpio": { + "source": "apache", + "extensions": ["cpio"] + }, + "application/x-csh": { + "source": "apache", + "extensions": ["csh"] + }, + "application/x-deb": { + "compressible": false + }, + "application/x-debian-package": { + "source": "apache", + "extensions": ["deb","udeb"] + }, + "application/x-dgc-compressed": { + "source": "apache", + "extensions": ["dgc"] + }, + "application/x-director": { + "source": "apache", + "extensions": ["dir","dcr","dxr","cst","cct","cxt","w3d","fgd","swa"] + }, + "application/x-doom": { + "source": "apache", + "extensions": ["wad"] + }, + "application/x-dtbncx+xml": { + "source": "apache", + "extensions": ["ncx"] + }, + "application/x-dtbook+xml": { + "source": "apache", + "extensions": ["dtb"] + }, + "application/x-dtbresource+xml": { + "source": "apache", + "extensions": ["res"] + }, + "application/x-dvi": { + "source": "apache", + "compressible": false, + "extensions": ["dvi"] + }, + "application/x-envoy": { + "source": "apache", + "extensions": ["evy"] + }, + "application/x-eva": { + "source": "apache", + "extensions": ["eva"] + }, + "application/x-font-bdf": { + "source": "apache", + "extensions": ["bdf"] + }, + "application/x-font-dos": { + "source": "apache" + }, + "application/x-font-framemaker": { + "source": "apache" + }, + "application/x-font-ghostscript": { + "source": "apache", + "extensions": ["gsf"] + }, + "application/x-font-libgrx": { + "source": "apache" + }, + "application/x-font-linux-psf": { + "source": "apache", + "extensions": ["psf"] + }, + "application/x-font-otf": { + "source": "apache", + "compressible": true, + "extensions": ["otf"] + }, + "application/x-font-pcf": { + "source": "apache", + "extensions": ["pcf"] + }, + "application/x-font-snf": { + "source": "apache", + "extensions": ["snf"] + }, + "application/x-font-speedo": { + "source": "apache" + }, + "application/x-font-sunos-news": { + "source": "apache" + }, + "application/x-font-ttf": { + "source": "apache", + "compressible": true, + "extensions": ["ttf","ttc"] + }, + "application/x-font-type1": { + "source": "apache", + "extensions": ["pfa","pfb","pfm","afm"] + }, + "application/x-font-vfont": { + "source": "apache" + }, + "application/x-freearc": { + "source": "apache", + "extensions": ["arc"] + }, + "application/x-futuresplash": { + "source": "apache", + "extensions": ["spl"] + }, + "application/x-gca-compressed": { + "source": "apache", + "extensions": ["gca"] + }, + "application/x-glulx": { + "source": "apache", + "extensions": ["ulx"] + }, + "application/x-gnumeric": { + "source": "apache", + "extensions": ["gnumeric"] + }, + "application/x-gramps-xml": { + "source": "apache", + "extensions": ["gramps"] + }, + "application/x-gtar": { + "source": "apache", + "extensions": ["gtar"] + }, + "application/x-gzip": { + "source": "apache" + }, + "application/x-hdf": { + "source": "apache", + "extensions": ["hdf"] + }, + "application/x-httpd-php": { + "compressible": true, + "extensions": ["php"] + }, + "application/x-install-instructions": { + "source": "apache", + "extensions": ["install"] + }, + "application/x-iso9660-image": { + "source": "apache", + "extensions": ["iso"] + }, + "application/x-java-archive-diff": { + "source": "nginx", + "extensions": ["jardiff"] + }, + "application/x-java-jnlp-file": { + "source": "apache", + "compressible": false, + "extensions": ["jnlp"] + }, + "application/x-javascript": { + "compressible": true + }, + "application/x-latex": { + "source": "apache", + "compressible": false, + "extensions": ["latex"] + }, + "application/x-lua-bytecode": { + "extensions": ["luac"] + }, + "application/x-lzh-compressed": { + "source": "apache", + "extensions": ["lzh","lha"] + }, + "application/x-makeself": { + "source": "nginx", + "extensions": ["run"] + }, + "application/x-mie": { + "source": "apache", + "extensions": ["mie"] + }, + "application/x-mobipocket-ebook": { + "source": "apache", + "extensions": ["prc","mobi"] + }, + "application/x-mpegurl": { + "compressible": false + }, + "application/x-ms-application": { + "source": "apache", + "extensions": ["application"] + }, + "application/x-ms-shortcut": { + "source": "apache", + "extensions": ["lnk"] + }, + "application/x-ms-wmd": { + "source": "apache", + "extensions": ["wmd"] + }, + "application/x-ms-wmz": { + "source": "apache", + "extensions": ["wmz"] + }, + "application/x-ms-xbap": { + "source": "apache", + "extensions": ["xbap"] + }, + "application/x-msaccess": { + "source": "apache", + "extensions": ["mdb"] + }, + "application/x-msbinder": { + "source": "apache", + "extensions": ["obd"] + }, + "application/x-mscardfile": { + "source": "apache", + "extensions": ["crd"] + }, + "application/x-msclip": { + "source": "apache", + "extensions": ["clp"] + }, + "application/x-msdos-program": { + "extensions": ["exe"] + }, + "application/x-msdownload": { + "source": "apache", + "extensions": ["exe","dll","com","bat","msi"] + }, + "application/x-msmediaview": { + "source": "apache", + "extensions": ["mvb","m13","m14"] + }, + "application/x-msmetafile": { + "source": "apache", + "extensions": ["wmf","wmz","emf","emz"] + }, + "application/x-msmoney": { + "source": "apache", + "extensions": ["mny"] + }, + "application/x-mspublisher": { + "source": "apache", + "extensions": ["pub"] + }, + "application/x-msschedule": { + "source": "apache", + "extensions": ["scd"] + }, + "application/x-msterminal": { + "source": "apache", + "extensions": ["trm"] + }, + "application/x-mswrite": { + "source": "apache", + "extensions": ["wri"] + }, + "application/x-netcdf": { + "source": "apache", + "extensions": ["nc","cdf"] + }, + "application/x-ns-proxy-autoconfig": { + "compressible": true, + "extensions": ["pac"] + }, + "application/x-nzb": { + "source": "apache", + "extensions": ["nzb"] + }, + "application/x-perl": { + "source": "nginx", + "extensions": ["pl","pm"] + }, + "application/x-pilot": { + "source": "nginx", + "extensions": ["prc","pdb"] + }, + "application/x-pkcs12": { + "source": "apache", + "compressible": false, + "extensions": ["p12","pfx"] + }, + "application/x-pkcs7-certificates": { + "source": "apache", + "extensions": ["p7b","spc"] + }, + "application/x-pkcs7-certreqresp": { + "source": "apache", + "extensions": ["p7r"] + }, + "application/x-rar-compressed": { + "source": "apache", + "compressible": false, + "extensions": ["rar"] + }, + "application/x-redhat-package-manager": { + "source": "nginx", + "extensions": ["rpm"] + }, + "application/x-research-info-systems": { + "source": "apache", + "extensions": ["ris"] + }, + "application/x-sea": { + "source": "nginx", + "extensions": ["sea"] + }, + "application/x-sh": { + "source": "apache", + "compressible": true, + "extensions": ["sh"] + }, + "application/x-shar": { + "source": "apache", + "extensions": ["shar"] + }, + "application/x-shockwave-flash": { + "source": "apache", + "compressible": false, + "extensions": ["swf"] + }, + "application/x-silverlight-app": { + "source": "apache", + "extensions": ["xap"] + }, + "application/x-sql": { + "source": "apache", + "extensions": ["sql"] + }, + "application/x-stuffit": { + "source": "apache", + "compressible": false, + "extensions": ["sit"] + }, + "application/x-stuffitx": { + "source": "apache", + "extensions": ["sitx"] + }, + "application/x-subrip": { + "source": "apache", + "extensions": ["srt"] + }, + "application/x-sv4cpio": { + "source": "apache", + "extensions": ["sv4cpio"] + }, + "application/x-sv4crc": { + "source": "apache", + "extensions": ["sv4crc"] + }, + "application/x-t3vm-image": { + "source": "apache", + "extensions": ["t3"] + }, + "application/x-tads": { + "source": "apache", + "extensions": ["gam"] + }, + "application/x-tar": { + "source": "apache", + "compressible": true, + "extensions": ["tar"] + }, + "application/x-tcl": { + "source": "apache", + "extensions": ["tcl","tk"] + }, + "application/x-tex": { + "source": "apache", + "extensions": ["tex"] + }, + "application/x-tex-tfm": { + "source": "apache", + "extensions": ["tfm"] + }, + "application/x-texinfo": { + "source": "apache", + "extensions": ["texinfo","texi"] + }, + "application/x-tgif": { + "source": "apache", + "extensions": ["obj"] + }, + "application/x-ustar": { + "source": "apache", + "extensions": ["ustar"] + }, + "application/x-wais-source": { + "source": "apache", + "extensions": ["src"] + }, + "application/x-web-app-manifest+json": { + "compressible": true, + "extensions": ["webapp"] + }, + "application/x-www-form-urlencoded": { + "source": "iana", + "compressible": true + }, + "application/x-x509-ca-cert": { + "source": "apache", + "extensions": ["der","crt","pem"] + }, + "application/x-xfig": { + "source": "apache", + "extensions": ["fig"] + }, + "application/x-xliff+xml": { + "source": "apache", + "extensions": ["xlf"] + }, + "application/x-xpinstall": { + "source": "apache", + "compressible": false, + "extensions": ["xpi"] + }, + "application/x-xz": { + "source": "apache", + "extensions": ["xz"] + }, + "application/x-zmachine": { + "source": "apache", + "extensions": ["z1","z2","z3","z4","z5","z6","z7","z8"] + }, + "application/x400-bp": { + "source": "iana" + }, + "application/xacml+xml": { + "source": "iana" + }, + "application/xaml+xml": { + "source": "apache", + "extensions": ["xaml"] + }, + "application/xcap-att+xml": { + "source": "iana" + }, + "application/xcap-caps+xml": { + "source": "iana" + }, + "application/xcap-diff+xml": { + "source": "iana", + "extensions": ["xdf"] + }, + "application/xcap-el+xml": { + "source": "iana" + }, + "application/xcap-error+xml": { + "source": "iana" + }, + "application/xcap-ns+xml": { + "source": "iana" + }, + "application/xcon-conference-info+xml": { + "source": "iana" + }, + "application/xcon-conference-info-diff+xml": { + "source": "iana" + }, + "application/xenc+xml": { + "source": "iana", + "extensions": ["xenc"] + }, + "application/xhtml+xml": { + "source": "iana", + "compressible": true, + "extensions": ["xhtml","xht"] + }, + "application/xhtml-voice+xml": { + "source": "apache" + }, + "application/xml": { + "source": "iana", + "compressible": true, + "extensions": ["xml","xsl","xsd","rng"] + }, + "application/xml-dtd": { + "source": "iana", + "compressible": true, + "extensions": ["dtd"] + }, + "application/xml-external-parsed-entity": { + "source": "iana" + }, + "application/xml-patch+xml": { + "source": "iana" + }, + "application/xmpp+xml": { + "source": "iana" + }, + "application/xop+xml": { + "source": "iana", + "compressible": true, + "extensions": ["xop"] + }, + "application/xproc+xml": { + "source": "apache", + "extensions": ["xpl"] + }, + "application/xslt+xml": { + "source": "iana", + "extensions": ["xslt"] + }, + "application/xspf+xml": { + "source": "apache", + "extensions": ["xspf"] + }, + "application/xv+xml": { + "source": "iana", + "extensions": ["mxml","xhvml","xvml","xvm"] + }, + "application/yang": { + "source": "iana", + "extensions": ["yang"] + }, + "application/yin+xml": { + "source": "iana", + "extensions": ["yin"] + }, + "application/zip": { + "source": "iana", + "compressible": false, + "extensions": ["zip"] + }, + "application/zlib": { + "source": "iana" + }, + "audio/1d-interleaved-parityfec": { + "source": "iana" + }, + "audio/32kadpcm": { + "source": "iana" + }, + "audio/3gpp": { + "source": "iana", + "compressible": false, + "extensions": ["3gpp"] + }, + "audio/3gpp2": { + "source": "iana" + }, + "audio/ac3": { + "source": "iana" + }, + "audio/adpcm": { + "source": "apache", + "extensions": ["adp"] + }, + "audio/amr": { + "source": "iana" + }, + "audio/amr-wb": { + "source": "iana" + }, + "audio/amr-wb+": { + "source": "iana" + }, + "audio/aptx": { + "source": "iana" + }, + "audio/asc": { + "source": "iana" + }, + "audio/atrac-advanced-lossless": { + "source": "iana" + }, + "audio/atrac-x": { + "source": "iana" + }, + "audio/atrac3": { + "source": "iana" + }, + "audio/basic": { + "source": "iana", + "compressible": false, + "extensions": ["au","snd"] + }, + "audio/bv16": { + "source": "iana" + }, + "audio/bv32": { + "source": "iana" + }, + "audio/clearmode": { + "source": "iana" + }, + "audio/cn": { + "source": "iana" + }, + "audio/dat12": { + "source": "iana" + }, + "audio/dls": { + "source": "iana" + }, + "audio/dsr-es201108": { + "source": "iana" + }, + "audio/dsr-es202050": { + "source": "iana" + }, + "audio/dsr-es202211": { + "source": "iana" + }, + "audio/dsr-es202212": { + "source": "iana" + }, + "audio/dv": { + "source": "iana" + }, + "audio/dvi4": { + "source": "iana" + }, + "audio/eac3": { + "source": "iana" + }, + "audio/encaprtp": { + "source": "iana" + }, + "audio/evrc": { + "source": "iana" + }, + "audio/evrc-qcp": { + "source": "iana" + }, + "audio/evrc0": { + "source": "iana" + }, + "audio/evrc1": { + "source": "iana" + }, + "audio/evrcb": { + "source": "iana" + }, + "audio/evrcb0": { + "source": "iana" + }, + "audio/evrcb1": { + "source": "iana" + }, + "audio/evrcnw": { + "source": "iana" + }, + "audio/evrcnw0": { + "source": "iana" + }, + "audio/evrcnw1": { + "source": "iana" + }, + "audio/evrcwb": { + "source": "iana" + }, + "audio/evrcwb0": { + "source": "iana" + }, + "audio/evrcwb1": { + "source": "iana" + }, + "audio/evs": { + "source": "iana" + }, + "audio/fwdred": { + "source": "iana" + }, + "audio/g711-0": { + "source": "iana" + }, + "audio/g719": { + "source": "iana" + }, + "audio/g722": { + "source": "iana" + }, + "audio/g7221": { + "source": "iana" + }, + "audio/g723": { + "source": "iana" + }, + "audio/g726-16": { + "source": "iana" + }, + "audio/g726-24": { + "source": "iana" + }, + "audio/g726-32": { + "source": "iana" + }, + "audio/g726-40": { + "source": "iana" + }, + "audio/g728": { + "source": "iana" + }, + "audio/g729": { + "source": "iana" + }, + "audio/g7291": { + "source": "iana" + }, + "audio/g729d": { + "source": "iana" + }, + "audio/g729e": { + "source": "iana" + }, + "audio/gsm": { + "source": "iana" + }, + "audio/gsm-efr": { + "source": "iana" + }, + "audio/gsm-hr-08": { + "source": "iana" + }, + "audio/ilbc": { + "source": "iana" + }, + "audio/ip-mr_v2.5": { + "source": "iana" + }, + "audio/isac": { + "source": "apache" + }, + "audio/l16": { + "source": "iana" + }, + "audio/l20": { + "source": "iana" + }, + "audio/l24": { + "source": "iana", + "compressible": false + }, + "audio/l8": { + "source": "iana" + }, + "audio/lpc": { + "source": "iana" + }, + "audio/midi": { + "source": "apache", + "extensions": ["mid","midi","kar","rmi"] + }, + "audio/mobile-xmf": { + "source": "iana" + }, + "audio/mp3": { + "compressible": false, + "extensions": ["mp3"] + }, + "audio/mp4": { + "source": "iana", + "compressible": false, + "extensions": ["m4a","mp4a"] + }, + "audio/mp4a-latm": { + "source": "iana" + }, + "audio/mpa": { + "source": "iana" + }, + "audio/mpa-robust": { + "source": "iana" + }, + "audio/mpeg": { + "source": "iana", + "compressible": false, + "extensions": ["mpga","mp2","mp2a","mp3","m2a","m3a"] + }, + "audio/mpeg4-generic": { + "source": "iana" + }, + "audio/musepack": { + "source": "apache" + }, + "audio/ogg": { + "source": "iana", + "compressible": false, + "extensions": ["oga","ogg","spx"] + }, + "audio/opus": { + "source": "iana" + }, + "audio/parityfec": { + "source": "iana" + }, + "audio/pcma": { + "source": "iana" + }, + "audio/pcma-wb": { + "source": "iana" + }, + "audio/pcmu": { + "source": "iana" + }, + "audio/pcmu-wb": { + "source": "iana" + }, + "audio/prs.sid": { + "source": "iana" + }, + "audio/qcelp": { + "source": "iana" + }, + "audio/raptorfec": { + "source": "iana" + }, + "audio/red": { + "source": "iana" + }, + "audio/rtp-enc-aescm128": { + "source": "iana" + }, + "audio/rtp-midi": { + "source": "iana" + }, + "audio/rtploopback": { + "source": "iana" + }, + "audio/rtx": { + "source": "iana" + }, + "audio/s3m": { + "source": "apache", + "extensions": ["s3m"] + }, + "audio/silk": { + "source": "apache", + "extensions": ["sil"] + }, + "audio/smv": { + "source": "iana" + }, + "audio/smv-qcp": { + "source": "iana" + }, + "audio/smv0": { + "source": "iana" + }, + "audio/sp-midi": { + "source": "iana" + }, + "audio/speex": { + "source": "iana" + }, + "audio/t140c": { + "source": "iana" + }, + "audio/t38": { + "source": "iana" + }, + "audio/telephone-event": { + "source": "iana" + }, + "audio/tone": { + "source": "iana" + }, + "audio/uemclip": { + "source": "iana" + }, + "audio/ulpfec": { + "source": "iana" + }, + "audio/vdvi": { + "source": "iana" + }, + "audio/vmr-wb": { + "source": "iana" + }, + "audio/vnd.3gpp.iufp": { + "source": "iana" + }, + "audio/vnd.4sb": { + "source": "iana" + }, + "audio/vnd.audiokoz": { + "source": "iana" + }, + "audio/vnd.celp": { + "source": "iana" + }, + "audio/vnd.cisco.nse": { + "source": "iana" + }, + "audio/vnd.cmles.radio-events": { + "source": "iana" + }, + "audio/vnd.cns.anp1": { + "source": "iana" + }, + "audio/vnd.cns.inf1": { + "source": "iana" + }, + "audio/vnd.dece.audio": { + "source": "iana", + "extensions": ["uva","uvva"] + }, + "audio/vnd.digital-winds": { + "source": "iana", + "extensions": ["eol"] + }, + "audio/vnd.dlna.adts": { + "source": "iana" + }, + "audio/vnd.dolby.heaac.1": { + "source": "iana" + }, + "audio/vnd.dolby.heaac.2": { + "source": "iana" + }, + "audio/vnd.dolby.mlp": { + "source": "iana" + }, + "audio/vnd.dolby.mps": { + "source": "iana" + }, + "audio/vnd.dolby.pl2": { + "source": "iana" + }, + "audio/vnd.dolby.pl2x": { + "source": "iana" + }, + "audio/vnd.dolby.pl2z": { + "source": "iana" + }, + "audio/vnd.dolby.pulse.1": { + "source": "iana" + }, + "audio/vnd.dra": { + "source": "iana", + "extensions": ["dra"] + }, + "audio/vnd.dts": { + "source": "iana", + "extensions": ["dts"] + }, + "audio/vnd.dts.hd": { + "source": "iana", + "extensions": ["dtshd"] + }, + "audio/vnd.dvb.file": { + "source": "iana" + }, + "audio/vnd.everad.plj": { + "source": "iana" + }, + "audio/vnd.hns.audio": { + "source": "iana" + }, + "audio/vnd.lucent.voice": { + "source": "iana", + "extensions": ["lvp"] + }, + "audio/vnd.ms-playready.media.pya": { + "source": "iana", + "extensions": ["pya"] + }, + "audio/vnd.nokia.mobile-xmf": { + "source": "iana" + }, + "audio/vnd.nortel.vbk": { + "source": "iana" + }, + "audio/vnd.nuera.ecelp4800": { + "source": "iana", + "extensions": ["ecelp4800"] + }, + "audio/vnd.nuera.ecelp7470": { + "source": "iana", + "extensions": ["ecelp7470"] + }, + "audio/vnd.nuera.ecelp9600": { + "source": "iana", + "extensions": ["ecelp9600"] + }, + "audio/vnd.octel.sbc": { + "source": "iana" + }, + "audio/vnd.qcelp": { + "source": "iana" + }, + "audio/vnd.rhetorex.32kadpcm": { + "source": "iana" + }, + "audio/vnd.rip": { + "source": "iana", + "extensions": ["rip"] + }, + "audio/vnd.rn-realaudio": { + "compressible": false + }, + "audio/vnd.sealedmedia.softseal.mpeg": { + "source": "iana" + }, + "audio/vnd.vmx.cvsd": { + "source": "iana" + }, + "audio/vnd.wave": { + "compressible": false + }, + "audio/vorbis": { + "source": "iana", + "compressible": false + }, + "audio/vorbis-config": { + "source": "iana" + }, + "audio/wav": { + "compressible": false, + "extensions": ["wav"] + }, + "audio/wave": { + "compressible": false, + "extensions": ["wav"] + }, + "audio/webm": { + "source": "apache", + "compressible": false, + "extensions": ["weba"] + }, + "audio/x-aac": { + "source": "apache", + "compressible": false, + "extensions": ["aac"] + }, + "audio/x-aiff": { + "source": "apache", + "extensions": ["aif","aiff","aifc"] + }, + "audio/x-caf": { + "source": "apache", + "compressible": false, + "extensions": ["caf"] + }, + "audio/x-flac": { + "source": "apache", + "extensions": ["flac"] + }, + "audio/x-m4a": { + "source": "nginx", + "extensions": ["m4a"] + }, + "audio/x-matroska": { + "source": "apache", + "extensions": ["mka"] + }, + "audio/x-mpegurl": { + "source": "apache", + "extensions": ["m3u"] + }, + "audio/x-ms-wax": { + "source": "apache", + "extensions": ["wax"] + }, + "audio/x-ms-wma": { + "source": "apache", + "extensions": ["wma"] + }, + "audio/x-pn-realaudio": { + "source": "apache", + "extensions": ["ram","ra"] + }, + "audio/x-pn-realaudio-plugin": { + "source": "apache", + "extensions": ["rmp"] + }, + "audio/x-realaudio": { + "source": "nginx", + "extensions": ["ra"] + }, + "audio/x-tta": { + "source": "apache" + }, + "audio/x-wav": { + "source": "apache", + "extensions": ["wav"] + }, + "audio/xm": { + "source": "apache", + "extensions": ["xm"] + }, + "chemical/x-cdx": { + "source": "apache", + "extensions": ["cdx"] + }, + "chemical/x-cif": { + "source": "apache", + "extensions": ["cif"] + }, + "chemical/x-cmdf": { + "source": "apache", + "extensions": ["cmdf"] + }, + "chemical/x-cml": { + "source": "apache", + "extensions": ["cml"] + }, + "chemical/x-csml": { + "source": "apache", + "extensions": ["csml"] + }, + "chemical/x-pdb": { + "source": "apache" + }, + "chemical/x-xyz": { + "source": "apache", + "extensions": ["xyz"] + }, + "font/opentype": { + "compressible": true, + "extensions": ["otf"] + }, + "image/bmp": { + "source": "iana", + "compressible": true, + "extensions": ["bmp"] + }, + "image/cgm": { + "source": "iana", + "extensions": ["cgm"] + }, + "image/dicom-rle": { + "source": "iana" + }, + "image/emf": { + "source": "iana" + }, + "image/fits": { + "source": "iana" + }, + "image/g3fax": { + "source": "iana", + "extensions": ["g3"] + }, + "image/gif": { + "source": "iana", + "compressible": false, + "extensions": ["gif"] + }, + "image/ief": { + "source": "iana", + "extensions": ["ief"] + }, + "image/jls": { + "source": "iana" + }, + "image/jp2": { + "source": "iana" + }, + "image/jpeg": { + "source": "iana", + "compressible": false, + "extensions": ["jpeg","jpg","jpe"] + }, + "image/jpm": { + "source": "iana" + }, + "image/jpx": { + "source": "iana" + }, + "image/ktx": { + "source": "iana", + "extensions": ["ktx"] + }, + "image/naplps": { + "source": "iana" + }, + "image/pjpeg": { + "compressible": false + }, + "image/png": { + "source": "iana", + "compressible": false, + "extensions": ["png"] + }, + "image/prs.btif": { + "source": "iana", + "extensions": ["btif"] + }, + "image/prs.pti": { + "source": "iana" + }, + "image/pwg-raster": { + "source": "iana" + }, + "image/sgi": { + "source": "apache", + "extensions": ["sgi"] + }, + "image/svg+xml": { + "source": "iana", + "compressible": true, + "extensions": ["svg","svgz"] + }, + "image/t38": { + "source": "iana" + }, + "image/tiff": { + "source": "iana", + "compressible": false, + "extensions": ["tiff","tif"] + }, + "image/tiff-fx": { + "source": "iana" + }, + "image/vnd.adobe.photoshop": { + "source": "iana", + "compressible": true, + "extensions": ["psd"] + }, + "image/vnd.airzip.accelerator.azv": { + "source": "iana" + }, + "image/vnd.cns.inf2": { + "source": "iana" + }, + "image/vnd.dece.graphic": { + "source": "iana", + "extensions": ["uvi","uvvi","uvg","uvvg"] + }, + "image/vnd.djvu": { + "source": "iana", + "extensions": ["djvu","djv"] + }, + "image/vnd.dvb.subtitle": { + "source": "iana", + "extensions": ["sub"] + }, + "image/vnd.dwg": { + "source": "iana", + "extensions": ["dwg"] + }, + "image/vnd.dxf": { + "source": "iana", + "extensions": ["dxf"] + }, + "image/vnd.fastbidsheet": { + "source": "iana", + "extensions": ["fbs"] + }, + "image/vnd.fpx": { + "source": "iana", + "extensions": ["fpx"] + }, + "image/vnd.fst": { + "source": "iana", + "extensions": ["fst"] + }, + "image/vnd.fujixerox.edmics-mmr": { + "source": "iana", + "extensions": ["mmr"] + }, + "image/vnd.fujixerox.edmics-rlc": { + "source": "iana", + "extensions": ["rlc"] + }, + "image/vnd.globalgraphics.pgb": { + "source": "iana" + }, + "image/vnd.microsoft.icon": { + "source": "iana" + }, + "image/vnd.mix": { + "source": "iana" + }, + "image/vnd.mozilla.apng": { + "source": "iana" + }, + "image/vnd.ms-modi": { + "source": "iana", + "extensions": ["mdi"] + }, + "image/vnd.ms-photo": { + "source": "apache", + "extensions": ["wdp"] + }, + "image/vnd.net-fpx": { + "source": "iana", + "extensions": ["npx"] + }, + "image/vnd.radiance": { + "source": "iana" + }, + "image/vnd.sealed.png": { + "source": "iana" + }, + "image/vnd.sealedmedia.softseal.gif": { + "source": "iana" + }, + "image/vnd.sealedmedia.softseal.jpg": { + "source": "iana" + }, + "image/vnd.svf": { + "source": "iana" + }, + "image/vnd.tencent.tap": { + "source": "iana" + }, + "image/vnd.valve.source.texture": { + "source": "iana" + }, + "image/vnd.wap.wbmp": { + "source": "iana", + "extensions": ["wbmp"] + }, + "image/vnd.xiff": { + "source": "iana", + "extensions": ["xif"] + }, + "image/vnd.zbrush.pcx": { + "source": "iana" + }, + "image/webp": { + "source": "apache", + "extensions": ["webp"] + }, + "image/wmf": { + "source": "iana" + }, + "image/x-3ds": { + "source": "apache", + "extensions": ["3ds"] + }, + "image/x-cmu-raster": { + "source": "apache", + "extensions": ["ras"] + }, + "image/x-cmx": { + "source": "apache", + "extensions": ["cmx"] + }, + "image/x-freehand": { + "source": "apache", + "extensions": ["fh","fhc","fh4","fh5","fh7"] + }, + "image/x-icon": { + "source": "apache", + "compressible": true, + "extensions": ["ico"] + }, + "image/x-jng": { + "source": "nginx", + "extensions": ["jng"] + }, + "image/x-mrsid-image": { + "source": "apache", + "extensions": ["sid"] + }, + "image/x-ms-bmp": { + "source": "nginx", + "compressible": true, + "extensions": ["bmp"] + }, + "image/x-pcx": { + "source": "apache", + "extensions": ["pcx"] + }, + "image/x-pict": { + "source": "apache", + "extensions": ["pic","pct"] + }, + "image/x-portable-anymap": { + "source": "apache", + "extensions": ["pnm"] + }, + "image/x-portable-bitmap": { + "source": "apache", + "extensions": ["pbm"] + }, + "image/x-portable-graymap": { + "source": "apache", + "extensions": ["pgm"] + }, + "image/x-portable-pixmap": { + "source": "apache", + "extensions": ["ppm"] + }, + "image/x-rgb": { + "source": "apache", + "extensions": ["rgb"] + }, + "image/x-tga": { + "source": "apache", + "extensions": ["tga"] + }, + "image/x-xbitmap": { + "source": "apache", + "extensions": ["xbm"] + }, + "image/x-xcf": { + "compressible": false + }, + "image/x-xpixmap": { + "source": "apache", + "extensions": ["xpm"] + }, + "image/x-xwindowdump": { + "source": "apache", + "extensions": ["xwd"] + }, + "message/cpim": { + "source": "iana" + }, + "message/delivery-status": { + "source": "iana" + }, + "message/disposition-notification": { + "source": "iana" + }, + "message/external-body": { + "source": "iana" + }, + "message/feedback-report": { + "source": "iana" + }, + "message/global": { + "source": "iana" + }, + "message/global-delivery-status": { + "source": "iana" + }, + "message/global-disposition-notification": { + "source": "iana" + }, + "message/global-headers": { + "source": "iana" + }, + "message/http": { + "source": "iana", + "compressible": false + }, + "message/imdn+xml": { + "source": "iana", + "compressible": true + }, + "message/news": { + "source": "iana" + }, + "message/partial": { + "source": "iana", + "compressible": false + }, + "message/rfc822": { + "source": "iana", + "compressible": true, + "extensions": ["eml","mime"] + }, + "message/s-http": { + "source": "iana" + }, + "message/sip": { + "source": "iana" + }, + "message/sipfrag": { + "source": "iana" + }, + "message/tracking-status": { + "source": "iana" + }, + "message/vnd.si.simp": { + "source": "iana" + }, + "message/vnd.wfa.wsc": { + "source": "iana" + }, + "model/gltf+json": { + "source": "iana", + "compressible": true + }, + "model/iges": { + "source": "iana", + "compressible": false, + "extensions": ["igs","iges"] + }, + "model/mesh": { + "source": "iana", + "compressible": false, + "extensions": ["msh","mesh","silo"] + }, + "model/vnd.collada+xml": { + "source": "iana", + "extensions": ["dae"] + }, + "model/vnd.dwf": { + "source": "iana", + "extensions": ["dwf"] + }, + "model/vnd.flatland.3dml": { + "source": "iana" + }, + "model/vnd.gdl": { + "source": "iana", + "extensions": ["gdl"] + }, + "model/vnd.gs-gdl": { + "source": "apache" + }, + "model/vnd.gs.gdl": { + "source": "iana" + }, + "model/vnd.gtw": { + "source": "iana", + "extensions": ["gtw"] + }, + "model/vnd.moml+xml": { + "source": "iana" + }, + "model/vnd.mts": { + "source": "iana", + "extensions": ["mts"] + }, + "model/vnd.opengex": { + "source": "iana" + }, + "model/vnd.parasolid.transmit.binary": { + "source": "iana" + }, + "model/vnd.parasolid.transmit.text": { + "source": "iana" + }, + "model/vnd.rosette.annotated-data-model": { + "source": "iana" + }, + "model/vnd.valve.source.compiled-map": { + "source": "iana" + }, + "model/vnd.vtu": { + "source": "iana", + "extensions": ["vtu"] + }, + "model/vrml": { + "source": "iana", + "compressible": false, + "extensions": ["wrl","vrml"] + }, + "model/x3d+binary": { + "source": "apache", + "compressible": false, + "extensions": ["x3db","x3dbz"] + }, + "model/x3d+fastinfoset": { + "source": "iana" + }, + "model/x3d+vrml": { + "source": "apache", + "compressible": false, + "extensions": ["x3dv","x3dvz"] + }, + "model/x3d+xml": { + "source": "iana", + "compressible": true, + "extensions": ["x3d","x3dz"] + }, + "model/x3d-vrml": { + "source": "iana" + }, + "multipart/alternative": { + "source": "iana", + "compressible": false + }, + "multipart/appledouble": { + "source": "iana" + }, + "multipart/byteranges": { + "source": "iana" + }, + "multipart/digest": { + "source": "iana" + }, + "multipart/encrypted": { + "source": "iana", + "compressible": false + }, + "multipart/form-data": { + "source": "iana", + "compressible": false + }, + "multipart/header-set": { + "source": "iana" + }, + "multipart/mixed": { + "source": "iana", + "compressible": false + }, + "multipart/parallel": { + "source": "iana" + }, + "multipart/related": { + "source": "iana", + "compressible": false + }, + "multipart/report": { + "source": "iana" + }, + "multipart/signed": { + "source": "iana", + "compressible": false + }, + "multipart/voice-message": { + "source": "iana" + }, + "multipart/x-mixed-replace": { + "source": "iana" + }, + "text/1d-interleaved-parityfec": { + "source": "iana" + }, + "text/cache-manifest": { + "source": "iana", + "compressible": true, + "extensions": ["appcache","manifest"] + }, + "text/calendar": { + "source": "iana", + "extensions": ["ics","ifb"] + }, + "text/calender": { + "compressible": true + }, + "text/cmd": { + "compressible": true + }, + "text/coffeescript": { + "extensions": ["coffee","litcoffee"] + }, + "text/css": { + "source": "iana", + "compressible": true, + "extensions": ["css"] + }, + "text/csv": { + "source": "iana", + "compressible": true, + "extensions": ["csv"] + }, + "text/csv-schema": { + "source": "iana" + }, + "text/directory": { + "source": "iana" + }, + "text/dns": { + "source": "iana" + }, + "text/ecmascript": { + "source": "iana" + }, + "text/encaprtp": { + "source": "iana" + }, + "text/enriched": { + "source": "iana" + }, + "text/fwdred": { + "source": "iana" + }, + "text/grammar-ref-list": { + "source": "iana" + }, + "text/hjson": { + "extensions": ["hjson"] + }, + "text/html": { + "source": "iana", + "compressible": true, + "extensions": ["html","htm","shtml"] + }, + "text/jade": { + "extensions": ["jade"] + }, + "text/javascript": { + "source": "iana", + "compressible": true + }, + "text/jcr-cnd": { + "source": "iana" + }, + "text/jsx": { + "compressible": true, + "extensions": ["jsx"] + }, + "text/less": { + "extensions": ["less"] + }, + "text/markdown": { + "source": "iana" + }, + "text/mathml": { + "source": "nginx", + "extensions": ["mml"] + }, + "text/mizar": { + "source": "iana" + }, + "text/n3": { + "source": "iana", + "compressible": true, + "extensions": ["n3"] + }, + "text/parameters": { + "source": "iana" + }, + "text/parityfec": { + "source": "iana" + }, + "text/plain": { + "source": "iana", + "compressible": true, + "extensions": ["txt","text","conf","def","list","log","in","ini"] + }, + "text/provenance-notation": { + "source": "iana" + }, + "text/prs.fallenstein.rst": { + "source": "iana" + }, + "text/prs.lines.tag": { + "source": "iana", + "extensions": ["dsc"] + }, + "text/prs.prop.logic": { + "source": "iana" + }, + "text/raptorfec": { + "source": "iana" + }, + "text/red": { + "source": "iana" + }, + "text/rfc822-headers": { + "source": "iana" + }, + "text/richtext": { + "source": "iana", + "compressible": true, + "extensions": ["rtx"] + }, + "text/rtf": { + "source": "iana", + "compressible": true, + "extensions": ["rtf"] + }, + "text/rtp-enc-aescm128": { + "source": "iana" + }, + "text/rtploopback": { + "source": "iana" + }, + "text/rtx": { + "source": "iana" + }, + "text/sgml": { + "source": "iana", + "extensions": ["sgml","sgm"] + }, + "text/slim": { + "extensions": ["slim","slm"] + }, + "text/stylus": { + "extensions": ["stylus","styl"] + }, + "text/t140": { + "source": "iana" + }, + "text/tab-separated-values": { + "source": "iana", + "compressible": true, + "extensions": ["tsv"] + }, + "text/troff": { + "source": "iana", + "extensions": ["t","tr","roff","man","me","ms"] + }, + "text/turtle": { + "source": "iana", + "extensions": ["ttl"] + }, + "text/ulpfec": { + "source": "iana" + }, + "text/uri-list": { + "source": "iana", + "compressible": true, + "extensions": ["uri","uris","urls"] + }, + "text/vcard": { + "source": "iana", + "compressible": true, + "extensions": ["vcard"] + }, + "text/vnd.a": { + "source": "iana" + }, + "text/vnd.abc": { + "source": "iana" + }, + "text/vnd.ascii-art": { + "source": "iana" + }, + "text/vnd.curl": { + "source": "iana", + "extensions": ["curl"] + }, + "text/vnd.curl.dcurl": { + "source": "apache", + "extensions": ["dcurl"] + }, + "text/vnd.curl.mcurl": { + "source": "apache", + "extensions": ["mcurl"] + }, + "text/vnd.curl.scurl": { + "source": "apache", + "extensions": ["scurl"] + }, + "text/vnd.debian.copyright": { + "source": "iana" + }, + "text/vnd.dmclientscript": { + "source": "iana" + }, + "text/vnd.dvb.subtitle": { + "source": "iana", + "extensions": ["sub"] + }, + "text/vnd.esmertec.theme-descriptor": { + "source": "iana" + }, + "text/vnd.fly": { + "source": "iana", + "extensions": ["fly"] + }, + "text/vnd.fmi.flexstor": { + "source": "iana", + "extensions": ["flx"] + }, + "text/vnd.graphviz": { + "source": "iana", + "extensions": ["gv"] + }, + "text/vnd.in3d.3dml": { + "source": "iana", + "extensions": ["3dml"] + }, + "text/vnd.in3d.spot": { + "source": "iana", + "extensions": ["spot"] + }, + "text/vnd.iptc.newsml": { + "source": "iana" + }, + "text/vnd.iptc.nitf": { + "source": "iana" + }, + "text/vnd.latex-z": { + "source": "iana" + }, + "text/vnd.motorola.reflex": { + "source": "iana" + }, + "text/vnd.ms-mediapackage": { + "source": "iana" + }, + "text/vnd.net2phone.commcenter.command": { + "source": "iana" + }, + "text/vnd.radisys.msml-basic-layout": { + "source": "iana" + }, + "text/vnd.si.uricatalogue": { + "source": "iana" + }, + "text/vnd.sun.j2me.app-descriptor": { + "source": "iana", + "extensions": ["jad"] + }, + "text/vnd.trolltech.linguist": { + "source": "iana" + }, + "text/vnd.wap.si": { + "source": "iana" + }, + "text/vnd.wap.sl": { + "source": "iana" + }, + "text/vnd.wap.wml": { + "source": "iana", + "extensions": ["wml"] + }, + "text/vnd.wap.wmlscript": { + "source": "iana", + "extensions": ["wmls"] + }, + "text/vtt": { + "charset": "UTF-8", + "compressible": true, + "extensions": ["vtt"] + }, + "text/x-asm": { + "source": "apache", + "extensions": ["s","asm"] + }, + "text/x-c": { + "source": "apache", + "extensions": ["c","cc","cxx","cpp","h","hh","dic"] + }, + "text/x-component": { + "source": "nginx", + "extensions": ["htc"] + }, + "text/x-fortran": { + "source": "apache", + "extensions": ["f","for","f77","f90"] + }, + "text/x-gwt-rpc": { + "compressible": true + }, + "text/x-handlebars-template": { + "extensions": ["hbs"] + }, + "text/x-java-source": { + "source": "apache", + "extensions": ["java"] + }, + "text/x-jquery-tmpl": { + "compressible": true + }, + "text/x-lua": { + "extensions": ["lua"] + }, + "text/x-markdown": { + "compressible": true, + "extensions": ["markdown","md","mkd"] + }, + "text/x-nfo": { + "source": "apache", + "extensions": ["nfo"] + }, + "text/x-opml": { + "source": "apache", + "extensions": ["opml"] + }, + "text/x-pascal": { + "source": "apache", + "extensions": ["p","pas"] + }, + "text/x-processing": { + "compressible": true, + "extensions": ["pde"] + }, + "text/x-sass": { + "extensions": ["sass"] + }, + "text/x-scss": { + "extensions": ["scss"] + }, + "text/x-setext": { + "source": "apache", + "extensions": ["etx"] + }, + "text/x-sfv": { + "source": "apache", + "extensions": ["sfv"] + }, + "text/x-suse-ymp": { + "compressible": true, + "extensions": ["ymp"] + }, + "text/x-uuencode": { + "source": "apache", + "extensions": ["uu"] + }, + "text/x-vcalendar": { + "source": "apache", + "extensions": ["vcs"] + }, + "text/x-vcard": { + "source": "apache", + "extensions": ["vcf"] + }, + "text/xml": { + "source": "iana", + "compressible": true, + "extensions": ["xml"] + }, + "text/xml-external-parsed-entity": { + "source": "iana" + }, + "text/yaml": { + "extensions": ["yaml","yml"] + }, + "video/1d-interleaved-parityfec": { + "source": "apache" + }, + "video/3gpp": { + "source": "apache", + "extensions": ["3gp","3gpp"] + }, + "video/3gpp-tt": { + "source": "apache" + }, + "video/3gpp2": { + "source": "apache", + "extensions": ["3g2"] + }, + "video/bmpeg": { + "source": "apache" + }, + "video/bt656": { + "source": "apache" + }, + "video/celb": { + "source": "apache" + }, + "video/dv": { + "source": "apache" + }, + "video/encaprtp": { + "source": "apache" + }, + "video/h261": { + "source": "apache", + "extensions": ["h261"] + }, + "video/h263": { + "source": "apache", + "extensions": ["h263"] + }, + "video/h263-1998": { + "source": "apache" + }, + "video/h263-2000": { + "source": "apache" + }, + "video/h264": { + "source": "apache", + "extensions": ["h264"] + }, + "video/h264-rcdo": { + "source": "apache" + }, + "video/h264-svc": { + "source": "apache" + }, + "video/h265": { + "source": "apache" + }, + "video/iso.segment": { + "source": "apache" + }, + "video/jpeg": { + "source": "apache", + "extensions": ["jpgv"] + }, + "video/jpeg2000": { + "source": "apache" + }, + "video/jpm": { + "source": "apache", + "extensions": ["jpm","jpgm"] + }, + "video/mj2": { + "source": "apache", + "extensions": ["mj2","mjp2"] + }, + "video/mp1s": { + "source": "apache" + }, + "video/mp2p": { + "source": "apache" + }, + "video/mp2t": { + "source": "apache", + "extensions": ["ts"] + }, + "video/mp4": { + "source": "apache", + "compressible": false, + "extensions": ["mp4","mp4v","mpg4"] + }, + "video/mp4v-es": { + "source": "apache" + }, + "video/mpeg": { + "source": "apache", + "compressible": false, + "extensions": ["mpeg","mpg","mpe","m1v","m2v"] + }, + "video/mpeg4-generic": { + "source": "apache" + }, + "video/mpv": { + "source": "apache" + }, + "video/nv": { + "source": "apache" + }, + "video/ogg": { + "source": "apache", + "compressible": false, + "extensions": ["ogv"] + }, + "video/parityfec": { + "source": "apache" + }, + "video/pointer": { + "source": "apache" + }, + "video/quicktime": { + "source": "apache", + "compressible": false, + "extensions": ["qt","mov"] + }, + "video/raptorfec": { + "source": "apache" + }, + "video/raw": { + "source": "apache" + }, + "video/rtp-enc-aescm128": { + "source": "apache" + }, + "video/rtploopback": { + "source": "apache" + }, + "video/rtx": { + "source": "apache" + }, + "video/smpte292m": { + "source": "apache" + }, + "video/ulpfec": { + "source": "apache" + }, + "video/vc1": { + "source": "apache" + }, + "video/vnd.cctv": { + "source": "apache" + }, + "video/vnd.dece.hd": { + "source": "apache", + "extensions": ["uvh","uvvh"] + }, + "video/vnd.dece.mobile": { + "source": "apache", + "extensions": ["uvm","uvvm"] + }, + "video/vnd.dece.mp4": { + "source": "apache" + }, + "video/vnd.dece.pd": { + "source": "apache", + "extensions": ["uvp","uvvp"] + }, + "video/vnd.dece.sd": { + "source": "apache", + "extensions": ["uvs","uvvs"] + }, + "video/vnd.dece.video": { + "source": "apache", + "extensions": ["uvv","uvvv"] + }, + "video/vnd.directv.mpeg": { + "source": "apache" + }, + "video/vnd.directv.mpeg-tts": { + "source": "apache" + }, + "video/vnd.dlna.mpeg-tts": { + "source": "apache" + }, + "video/vnd.dvb.file": { + "source": "apache", + "extensions": ["dvb"] + }, + "video/vnd.fvt": { + "source": "apache", + "extensions": ["fvt"] + }, + "video/vnd.hns.video": { + "source": "apache" + }, + "video/vnd.iptvforum.1dparityfec-1010": { + "source": "apache" + }, + "video/vnd.iptvforum.1dparityfec-2005": { + "source": "apache" + }, + "video/vnd.iptvforum.2dparityfec-1010": { + "source": "apache" + }, + "video/vnd.iptvforum.2dparityfec-2005": { + "source": "apache" + }, + "video/vnd.iptvforum.ttsavc": { + "source": "apache" + }, + "video/vnd.iptvforum.ttsmpeg2": { + "source": "apache" + }, + "video/vnd.motorola.video": { + "source": "apache" + }, + "video/vnd.motorola.videop": { + "source": "apache" + }, + "video/vnd.mpegurl": { + "source": "apache", + "extensions": ["mxu","m4u"] + }, + "video/vnd.ms-playready.media.pyv": { + "source": "apache", + "extensions": ["pyv"] + }, + "video/vnd.nokia.interleaved-multimedia": { + "source": "apache" + }, + "video/vnd.nokia.videovoip": { + "source": "apache" + }, + "video/vnd.objectvideo": { + "source": "apache" + }, + "video/vnd.radgamettools.bink": { + "source": "apache" + }, + "video/vnd.radgamettools.smacker": { + "source": "apache" + }, + "video/vnd.sealed.mpeg1": { + "source": "apache" + }, + "video/vnd.sealed.mpeg4": { + "source": "apache" + }, + "video/vnd.sealed.swf": { + "source": "apache" + }, + "video/vnd.sealedmedia.softseal.mov": { + "source": "apache" + }, + "video/vnd.uvvu.mp4": { + "source": "apache", + "extensions": ["uvu","uvvu"] + }, + "video/vnd.vivo": { + "source": "apache", + "extensions": ["viv"] + }, + "video/vp8": { + "source": "apache" + }, + "video/webm": { + "source": "apache", + "compressible": false, + "extensions": ["webm"] + }, + "video/x-f4v": { + "source": "apache", + "extensions": ["f4v"] + }, + "video/x-fli": { + "source": "apache", + "extensions": ["fli"] + }, + "video/x-flv": { + "source": "apache", + "compressible": false, + "extensions": ["flv"] + }, + "video/x-m4v": { + "source": "apache", + "extensions": ["m4v"] + }, + "video/x-matroska": { + "source": "apache", + "compressible": false, + "extensions": ["mkv","mk3d","mks"] + }, + "video/x-mng": { + "source": "apache", + "extensions": ["mng"] + }, + "video/x-ms-asf": { + "source": "apache", + "extensions": ["asf","asx"] + }, + "video/x-ms-vob": { + "source": "apache", + "extensions": ["vob"] + }, + "video/x-ms-wm": { + "source": "apache", + "extensions": ["wm"] + }, + "video/x-ms-wmv": { + "source": "apache", + "compressible": false, + "extensions": ["wmv"] + }, + "video/x-ms-wmx": { + "source": "apache", + "extensions": ["wmx"] + }, + "video/x-ms-wvx": { + "source": "apache", + "extensions": ["wvx"] + }, + "video/x-msvideo": { + "source": "apache", + "extensions": ["avi"] + }, + "video/x-sgi-movie": { + "source": "apache", + "extensions": ["movie"] + }, + "video/x-smv": { + "source": "apache", + "extensions": ["smv"] + }, + "x-conference/x-cooltalk": { + "source": "apache", + "extensions": ["ice"] + }, + "x-shader/x-fragment": { + "compressible": true + }, + "x-shader/x-vertex": { + "compressible": true + } +} diff --git a/node_modules/express/node_modules/type-is/node_modules/mime-types/node_modules/mime-db/index.js b/node_modules/express/node_modules/type-is/node_modules/mime-types/node_modules/mime-db/index.js new file mode 100644 index 0000000..551031f --- /dev/null +++ b/node_modules/express/node_modules/type-is/node_modules/mime-types/node_modules/mime-db/index.js @@ -0,0 +1,11 @@ +/*! + * mime-db + * Copyright(c) 2014 Jonathan Ong + * MIT Licensed + */ + +/** + * Module exports. + */ + +module.exports = require('./db.json') diff --git a/node_modules/express/node_modules/type-is/node_modules/mime-types/node_modules/mime-db/package.json b/node_modules/express/node_modules/type-is/node_modules/mime-types/node_modules/mime-db/package.json new file mode 100644 index 0000000..a468393 --- /dev/null +++ b/node_modules/express/node_modules/type-is/node_modules/mime-types/node_modules/mime-db/package.json @@ -0,0 +1,99 @@ +{ + "name": "mime-db", + "description": "Media Type Database", + "version": "1.24.0", + "contributors": [ + { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "Jonathan Ong", + "email": "me@jongleberry.com", + "url": "http://jongleberry.com" + }, + { + "name": "Robert Kieffer", + "email": "robert@broofa.com", + "url": "http://github.com/broofa" + } + ], + "license": "MIT", + "keywords": [ + "mime", + "db", + "type", + "types", + "database", + "charset", + "charsets" + ], + "repository": { + "type": "git", + "url": "git+https://github.com/jshttp/mime-db.git" + }, + "devDependencies": { + "bluebird": "3.4.6", + "co": "4.6.0", + "cogent": "1.0.1", + "csv-parse": "1.1.7", + "gnode": "0.1.2", + "istanbul": "0.4.5", + "mocha": "1.21.5", + "raw-body": "2.1.7", + "stream-to-array": "2.3.0" + }, + "files": [ + "HISTORY.md", + "LICENSE", + "README.md", + "db.json", + "index.js" + ], + "engines": { + "node": ">= 0.6" + }, + "scripts": { + "build": "node scripts/build", + "fetch": "gnode scripts/fetch-apache && gnode scripts/fetch-iana && gnode scripts/fetch-nginx", + "test": "mocha --reporter spec --bail --check-leaks test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot --check-leaks test/", + "test-travis": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter spec --check-leaks test/", + "update": "npm run fetch && npm run build" + }, + "gitHead": "9dd00b34556a8cdd6f3385f09d4989298c4b86e1", + "bugs": { + "url": "https://github.com/jshttp/mime-db/issues" + }, + "homepage": "https://github.com/jshttp/mime-db#readme", + "_id": "mime-db@1.24.0", + "_shasum": "e2d13f939f0016c6e4e9ad25a8652f126c467f0c", + "_from": "mime-db@>=1.24.0 <1.25.0", + "_npmVersion": "2.15.9", + "_nodeVersion": "4.5.0", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "dist": { + "shasum": "e2d13f939f0016c6e4e9ad25a8652f126c467f0c", + "tarball": "https://registry.npmjs.org/mime-db/-/mime-db-1.24.0.tgz" + }, + "maintainers": [ + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "jongleberry", + "email": "jonathanrichardong@gmail.com" + } + ], + "_npmOperationalInternal": { + "host": "packages-16-east.internal.npmjs.com", + "tmp": "tmp/mime-db-1.24.0.tgz_1474198792761_0.7161959335207939" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/mime-db/-/mime-db-1.24.0.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/express/node_modules/type-is/node_modules/mime-types/package.json b/node_modules/express/node_modules/type-is/node_modules/mime-types/package.json new file mode 100644 index 0000000..0ca4603 --- /dev/null +++ b/node_modules/express/node_modules/type-is/node_modules/mime-types/package.json @@ -0,0 +1,94 @@ +{ + "name": "mime-types", + "description": "The ultimate javascript content-type utility.", + "version": "2.1.12", + "contributors": [ + { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "Jeremiah Senkpiel", + "email": "fishrock123@rocketmail.com", + "url": "https://searchbeam.jit.su" + }, + { + "name": "Jonathan Ong", + "email": "me@jongleberry.com", + "url": "http://jongleberry.com" + } + ], + "license": "MIT", + "keywords": [ + "mime", + "types" + ], + "repository": { + "type": "git", + "url": "git+https://github.com/jshttp/mime-types.git" + }, + "dependencies": { + "mime-db": "~1.24.0" + }, + "devDependencies": { + "eslint": "3.5.0", + "eslint-config-standard": "6.0.1", + "eslint-plugin-promise": "2.0.1", + "eslint-plugin-standard": "2.0.0", + "istanbul": "0.4.5", + "mocha": "1.21.5" + }, + "files": [ + "HISTORY.md", + "LICENSE", + "index.js" + ], + "engines": { + "node": ">= 0.6" + }, + "scripts": { + "lint": "eslint **/*.js", + "test": "mocha --reporter spec test/test.js", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot test/test.js", + "test-travis": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter dot test/test.js" + }, + "gitHead": "7193a9094e2efe31da93988350bb0b32ab18b1ea", + "bugs": { + "url": "https://github.com/jshttp/mime-types/issues" + }, + "homepage": "https://github.com/jshttp/mime-types#readme", + "_id": "mime-types@2.1.12", + "_shasum": "152ba256777020dd4663f54c2e7bc26381e71729", + "_from": "mime-types@>=2.1.11 <2.2.0", + "_npmVersion": "2.15.9", + "_nodeVersion": "4.5.0", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "dist": { + "shasum": "152ba256777020dd4663f54c2e7bc26381e71729", + "tarball": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.12.tgz" + }, + "maintainers": [ + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "fishrock123", + "email": "fishrock123@rocketmail.com" + }, + { + "name": "jongleberry", + "email": "jonathanrichardong@gmail.com" + } + ], + "_npmOperationalInternal": { + "host": "packages-12-west.internal.npmjs.com", + "tmp": "tmp/mime-types-2.1.12.tgz_1474237415119_0.03028594213537872" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/mime-types/-/mime-types-2.1.12.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/express/node_modules/type-is/package.json b/node_modules/express/node_modules/type-is/package.json new file mode 100644 index 0000000..5142674 --- /dev/null +++ b/node_modules/express/node_modules/type-is/package.json @@ -0,0 +1,87 @@ +{ + "name": "type-is", + "description": "Infer the content-type of a request.", + "version": "1.6.13", + "contributors": [ + { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "Jonathan Ong", + "email": "me@jongleberry.com", + "url": "http://jongleberry.com" + } + ], + "license": "MIT", + "repository": { + "type": "git", + "url": "git+https://github.com/jshttp/type-is.git" + }, + "dependencies": { + "media-typer": "0.3.0", + "mime-types": "~2.1.11" + }, + "devDependencies": { + "eslint": "2.10.2", + "eslint-config-standard": "5.3.1", + "eslint-plugin-promise": "1.1.0", + "eslint-plugin-standard": "1.3.2", + "istanbul": "0.4.3", + "mocha": "1.21.5" + }, + "engines": { + "node": ">= 0.6" + }, + "files": [ + "LICENSE", + "HISTORY.md", + "index.js" + ], + "scripts": { + "lint": "eslint **/*.js", + "test": "mocha --reporter spec --check-leaks --bail test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot --check-leaks test/", + "test-travis": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter spec --check-leaks test/" + }, + "keywords": [ + "content", + "type", + "checking" + ], + "gitHead": "88c47523fff910343b3ca7d4928dad40f21ea6cd", + "bugs": { + "url": "https://github.com/jshttp/type-is/issues" + }, + "homepage": "https://github.com/jshttp/type-is#readme", + "_id": "type-is@1.6.13", + "_shasum": "6e83ba7bc30cd33a7bb0b7fb00737a2085bf9d08", + "_from": "type-is@>=1.6.13 <1.7.0", + "_npmVersion": "2.15.1", + "_nodeVersion": "4.4.3", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "dist": { + "shasum": "6e83ba7bc30cd33a7bb0b7fb00737a2085bf9d08", + "tarball": "https://registry.npmjs.org/type-is/-/type-is-1.6.13.tgz" + }, + "maintainers": [ + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "jongleberry", + "email": "jonathanrichardong@gmail.com" + } + ], + "_npmOperationalInternal": { + "host": "packages-16-east.internal.npmjs.com", + "tmp": "tmp/type-is-1.6.13.tgz_1463622049206_0.9134831207338721" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/type-is/-/type-is-1.6.13.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/express/node_modules/utils-merge/.travis.yml b/node_modules/express/node_modules/utils-merge/.travis.yml new file mode 100644 index 0000000..af92b02 --- /dev/null +++ b/node_modules/express/node_modules/utils-merge/.travis.yml @@ -0,0 +1,6 @@ +language: "node_js" +node_js: + - "0.4" + - "0.6" + - "0.8" + - "0.10" diff --git a/node_modules/express/node_modules/utils-merge/LICENSE b/node_modules/express/node_modules/utils-merge/LICENSE new file mode 100644 index 0000000..e33bd10 --- /dev/null +++ b/node_modules/express/node_modules/utils-merge/LICENSE @@ -0,0 +1,20 @@ +(The MIT License) + +Copyright (c) 2013 Jared Hanson + +Permission is hereby granted, free of charge, to any person obtaining a copy of +this software and associated documentation files (the "Software"), to deal in +the Software without restriction, including without limitation the rights to +use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of +the Software, and to permit persons to whom the Software is furnished to do so, +subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS +FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR +COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER +IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN +CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/express/node_modules/utils-merge/README.md b/node_modules/express/node_modules/utils-merge/README.md new file mode 100644 index 0000000..2f94e9b --- /dev/null +++ b/node_modules/express/node_modules/utils-merge/README.md @@ -0,0 +1,34 @@ +# utils-merge + +Merges the properties from a source object into a destination object. + +## Install + + $ npm install utils-merge + +## Usage + +```javascript +var a = { foo: 'bar' } + , b = { bar: 'baz' }; + +merge(a, b); +// => { foo: 'bar', bar: 'baz' } +``` + +## Tests + + $ npm install + $ npm test + +[![Build Status](https://secure.travis-ci.org/jaredhanson/utils-merge.png)](http://travis-ci.org/jaredhanson/utils-merge) + +## Credits + + - [Jared Hanson](http://github.com/jaredhanson) + +## License + +[The MIT License](http://opensource.org/licenses/MIT) + +Copyright (c) 2013 Jared Hanson <[http://jaredhanson.net/](http://jaredhanson.net/)> diff --git a/node_modules/express/node_modules/utils-merge/index.js b/node_modules/express/node_modules/utils-merge/index.js new file mode 100644 index 0000000..4265c69 --- /dev/null +++ b/node_modules/express/node_modules/utils-merge/index.js @@ -0,0 +1,23 @@ +/** + * Merge object b with object a. + * + * var a = { foo: 'bar' } + * , b = { bar: 'baz' }; + * + * merge(a, b); + * // => { foo: 'bar', bar: 'baz' } + * + * @param {Object} a + * @param {Object} b + * @return {Object} + * @api public + */ + +exports = module.exports = function(a, b){ + if (a && b) { + for (var key in b) { + a[key] = b[key]; + } + } + return a; +}; diff --git a/node_modules/express/node_modules/utils-merge/package.json b/node_modules/express/node_modules/utils-merge/package.json new file mode 100644 index 0000000..83c37a4 --- /dev/null +++ b/node_modules/express/node_modules/utils-merge/package.json @@ -0,0 +1,60 @@ +{ + "name": "utils-merge", + "version": "1.0.0", + "description": "merge() utility function", + "keywords": [ + "util" + ], + "repository": { + "type": "git", + "url": "git://github.com/jaredhanson/utils-merge.git" + }, + "bugs": { + "url": "http://github.com/jaredhanson/utils-merge/issues" + }, + "author": { + "name": "Jared Hanson", + "email": "jaredhanson@gmail.com", + "url": "http://www.jaredhanson.net/" + }, + "licenses": [ + { + "type": "MIT", + "url": "http://www.opensource.org/licenses/MIT" + } + ], + "main": "./index", + "dependencies": {}, + "devDependencies": { + "mocha": "1.x.x", + "chai": "1.x.x" + }, + "scripts": { + "test": "mocha --reporter spec --require test/bootstrap/node test/*.test.js" + }, + "engines": { + "node": ">= 0.4.0" + }, + "_id": "utils-merge@1.0.0", + "dist": { + "shasum": "0294fb922bb9375153541c4f7096231f287c8af8", + "tarball": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.0.tgz" + }, + "_from": "utils-merge@1.0.0", + "_npmVersion": "1.2.25", + "_npmUser": { + "name": "jaredhanson", + "email": "jaredhanson@gmail.com" + }, + "maintainers": [ + { + "name": "jaredhanson", + "email": "jaredhanson@gmail.com" + } + ], + "directories": {}, + "_shasum": "0294fb922bb9375153541c4f7096231f287c8af8", + "_resolved": "http://registry.npmjs.org/utils-merge/-/utils-merge-1.0.0.tgz", + "readme": "ERROR: No README data found!", + "homepage": "https://github.com/jaredhanson/utils-merge#readme" +} diff --git a/node_modules/express/node_modules/vary/HISTORY.md b/node_modules/express/node_modules/vary/HISTORY.md new file mode 100644 index 0000000..ed68118 --- /dev/null +++ b/node_modules/express/node_modules/vary/HISTORY.md @@ -0,0 +1,29 @@ +1.1.0 / 2015-09-29 +================== + + * Only accept valid field names in the `field` argument + - Ensures the resulting string is a valid HTTP header value + +1.0.1 / 2015-07-08 +================== + + * Fix setting empty header from empty `field` + * perf: enable strict mode + * perf: remove argument reassignments + +1.0.0 / 2014-08-10 +================== + + * Accept valid `Vary` header string as `field` + * Add `vary.append` for low-level string manipulation + * Move to `jshttp` orgainzation + +0.1.0 / 2014-06-05 +================== + + * Support array of fields to set + +0.0.0 / 2014-06-04 +================== + + * Initial release diff --git a/node_modules/express/node_modules/vary/LICENSE b/node_modules/express/node_modules/vary/LICENSE new file mode 100644 index 0000000..142ede3 --- /dev/null +++ b/node_modules/express/node_modules/vary/LICENSE @@ -0,0 +1,22 @@ +(The MIT License) + +Copyright (c) 2014-2015 Douglas Christopher Wilson + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/express/node_modules/vary/README.md b/node_modules/express/node_modules/vary/README.md new file mode 100644 index 0000000..5966542 --- /dev/null +++ b/node_modules/express/node_modules/vary/README.md @@ -0,0 +1,91 @@ +# vary + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Node.js Version][node-version-image]][node-version-url] +[![Build Status][travis-image]][travis-url] +[![Test Coverage][coveralls-image]][coveralls-url] + +Manipulate the HTTP Vary header + +## Installation + +```sh +$ npm install vary +``` + +## API + +```js +var vary = require('vary') +``` + +### vary(res, field) + +Adds the given header `field` to the `Vary` response header of `res`. +This can be a string of a single field, a string of a valid `Vary` +header, or an array of multiple fields. + +This will append the header if not already listed, otherwise leaves +it listed in the current location. + +```js +// Append "Origin" to the Vary header of the response +vary(res, 'Origin') +``` + +### vary.append(header, field) + +Adds the given header `field` to the `Vary` response header string `header`. +This can be a string of a single field, a string of a valid `Vary` header, +or an array of multiple fields. + +This will append the header if not already listed, otherwise leaves +it listed in the current location. The new header string is returned. + +```js +// Get header string appending "Origin" to "Accept, User-Agent" +vary.append('Accept, User-Agent', 'Origin') +``` + +## Examples + +### Updating the Vary header when content is based on it + +```js +var http = require('http') +var vary = require('vary') + +http.createServer(function onRequest(req, res) { + // about to user-agent sniff + vary(res, 'User-Agent') + + var ua = req.headers['user-agent'] || '' + var isMobile = /mobi|android|touch|mini/i.test(ua) + + // serve site, depending on isMobile + res.setHeader('Content-Type', 'text/html') + res.end('You are (probably) ' + (isMobile ? '' : 'not ') + 'a mobile user') +}) +``` + +## Testing + +```sh +$ npm test +``` + +## License + +[MIT](LICENSE) + +[npm-image]: https://img.shields.io/npm/v/vary.svg +[npm-url]: https://npmjs.org/package/vary +[node-version-image]: https://img.shields.io/node/v/vary.svg +[node-version-url]: http://nodejs.org/download/ +[travis-image]: https://img.shields.io/travis/jshttp/vary/master.svg +[travis-url]: https://travis-ci.org/jshttp/vary +[coveralls-image]: https://img.shields.io/coveralls/jshttp/vary/master.svg +[coveralls-url]: https://coveralls.io/r/jshttp/vary +[downloads-image]: https://img.shields.io/npm/dm/vary.svg +[downloads-url]: https://npmjs.org/package/vary diff --git a/node_modules/express/node_modules/vary/index.js b/node_modules/express/node_modules/vary/index.js new file mode 100644 index 0000000..21dbaf1 --- /dev/null +++ b/node_modules/express/node_modules/vary/index.js @@ -0,0 +1,124 @@ +/*! + * vary + * Copyright(c) 2014-2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict'; + +/** + * Module exports. + */ + +module.exports = vary; +module.exports.append = append; + +/** + * RegExp to match field-name in RFC 7230 sec 3.2 + * + * field-name = token + * token = 1*tchar + * tchar = "!" / "#" / "$" / "%" / "&" / "'" / "*" + * / "+" / "-" / "." / "^" / "_" / "`" / "|" / "~" + * / DIGIT / ALPHA + * ; any VCHAR, except delimiters + */ + +var fieldNameRegExp = /^[!#$%&'\*\+\-\.\^_`\|~0-9A-Za-z]+$/ + +/** + * Append a field to a vary header. + * + * @param {String} header + * @param {String|Array} field + * @return {String} + * @api public + */ + +function append(header, field) { + if (typeof header !== 'string') { + throw new TypeError('header argument is required'); + } + + if (!field) { + throw new TypeError('field argument is required'); + } + + // get fields array + var fields = !Array.isArray(field) + ? parse(String(field)) + : field; + + // assert on invalid field names + for (var i = 0; i < fields.length; i++) { + if (!fieldNameRegExp.test(fields[i])) { + throw new TypeError('field argument contains an invalid header name'); + } + } + + // existing, unspecified vary + if (header === '*') { + return header; + } + + // enumerate current values + var val = header; + var vals = parse(header.toLowerCase()); + + // unspecified vary + if (fields.indexOf('*') !== -1 || vals.indexOf('*') !== -1) { + return '*'; + } + + for (var i = 0; i < fields.length; i++) { + var fld = fields[i].toLowerCase(); + + // append value (case-preserving) + if (vals.indexOf(fld) === -1) { + vals.push(fld); + val = val + ? val + ', ' + fields[i] + : fields[i]; + } + } + + return val; +} + +/** + * Parse a vary header into an array. + * + * @param {String} header + * @return {Array} + * @api private + */ + +function parse(header) { + return header.trim().split(/ *, */); +} + +/** + * Mark that a request is varied on a header field. + * + * @param {Object} res + * @param {String|Array} field + * @api public + */ + +function vary(res, field) { + if (!res || !res.getHeader || !res.setHeader) { + // quack quack + throw new TypeError('res argument is required'); + } + + // get existing header + var val = res.getHeader('Vary') || '' + var header = Array.isArray(val) + ? val.join(', ') + : String(val); + + // set new header + if ((val = append(header, field))) { + res.setHeader('Vary', val); + } +} diff --git a/node_modules/express/node_modules/vary/package.json b/node_modules/express/node_modules/vary/package.json new file mode 100644 index 0000000..51646a3 --- /dev/null +++ b/node_modules/express/node_modules/vary/package.json @@ -0,0 +1,72 @@ +{ + "name": "vary", + "description": "Manipulate the HTTP Vary header", + "version": "1.1.0", + "author": { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + }, + "license": "MIT", + "keywords": [ + "http", + "res", + "vary" + ], + "repository": { + "type": "git", + "url": "git+https://github.com/jshttp/vary.git" + }, + "devDependencies": { + "istanbul": "0.3.21", + "mocha": "2.3.3", + "supertest": "1.1.0" + }, + "files": [ + "HISTORY.md", + "LICENSE", + "README.md", + "index.js" + ], + "engines": { + "node": ">= 0.8" + }, + "scripts": { + "test": "mocha --reporter spec --bail --check-leaks test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot --check-leaks test/", + "test-travis": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter spec --check-leaks test/" + }, + "gitHead": "13b03e9bf97da9d83bfeac84d84144137d84c257", + "bugs": { + "url": "https://github.com/jshttp/vary/issues" + }, + "homepage": "https://github.com/jshttp/vary", + "_id": "vary@1.1.0", + "_shasum": "e1e5affbbd16ae768dd2674394b9ad3022653140", + "_from": "vary@>=1.1.0 <1.2.0", + "_npmVersion": "1.4.28", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "maintainers": [ + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "jongleberry", + "email": "jonathanrichardong@gmail.com" + }, + { + "name": "fishrock123", + "email": "fishrock123@rocketmail.com" + } + ], + "dist": { + "shasum": "e1e5affbbd16ae768dd2674394b9ad3022653140", + "tarball": "https://registry.npmjs.org/vary/-/vary-1.1.0.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/vary/-/vary-1.1.0.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/express/package.json b/node_modules/express/package.json new file mode 100644 index 0000000..65bf8e6 --- /dev/null +++ b/node_modules/express/package.json @@ -0,0 +1,160 @@ +{ + "name": "express", + "description": "Fast, unopinionated, minimalist web framework", + "version": "4.14.0", + "author": { + "name": "TJ Holowaychuk", + "email": "tj@vision-media.ca" + }, + "contributors": [ + { + "name": "Aaron Heckmann", + "email": "aaron.heckmann+github@gmail.com" + }, + { + "name": "Ciaran Jessup", + "email": "ciaranj@gmail.com" + }, + { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "Guillermo Rauch", + "email": "rauchg@gmail.com" + }, + { + "name": "Jonathan Ong", + "email": "me@jongleberry.com" + }, + { + "name": "Roman Shtylman", + "email": "shtylman+expressjs@gmail.com" + }, + { + "name": "Young Jae Sim", + "email": "hanul@hanul.me" + } + ], + "license": "MIT", + "repository": { + "type": "git", + "url": "git+https://github.com/expressjs/express.git" + }, + "homepage": "http://expressjs.com/", + "keywords": [ + "express", + "framework", + "sinatra", + "web", + "rest", + "restful", + "router", + "app", + "api" + ], + "dependencies": { + "accepts": "~1.3.3", + "array-flatten": "1.1.1", + "content-disposition": "0.5.1", + "content-type": "~1.0.2", + "cookie": "0.3.1", + "cookie-signature": "1.0.6", + "debug": "~2.2.0", + "depd": "~1.1.0", + "encodeurl": "~1.0.1", + "escape-html": "~1.0.3", + "etag": "~1.7.0", + "finalhandler": "0.5.0", + "fresh": "0.3.0", + "merge-descriptors": "1.0.1", + "methods": "~1.1.2", + "on-finished": "~2.3.0", + "parseurl": "~1.3.1", + "path-to-regexp": "0.1.7", + "proxy-addr": "~1.1.2", + "qs": "6.2.0", + "range-parser": "~1.2.0", + "send": "0.14.1", + "serve-static": "~1.11.1", + "type-is": "~1.6.13", + "utils-merge": "1.0.0", + "vary": "~1.1.0" + }, + "devDependencies": { + "after": "0.8.1", + "body-parser": "~1.15.1", + "cookie-parser": "~1.4.3", + "ejs": "2.4.2", + "istanbul": "0.4.3", + "marked": "0.3.5", + "method-override": "~2.3.6", + "mocha": "2.5.3", + "morgan": "~1.7.0", + "should": "9.0.2", + "supertest": "1.2.0", + "connect-redis": "~2.4.1", + "cookie-session": "~1.2.0", + "express-session": "~1.13.0", + "jade": "~1.11.0", + "multiparty": "~4.1.2", + "vhost": "~3.0.2" + }, + "engines": { + "node": ">= 0.10.0" + }, + "files": [ + "LICENSE", + "History.md", + "Readme.md", + "index.js", + "lib/" + ], + "scripts": { + "test": "mocha --require test/support/env --reporter spec --bail --check-leaks test/ test/acceptance/", + "test-ci": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --require test/support/env --reporter spec --check-leaks test/ test/acceptance/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --require test/support/env --reporter dot --check-leaks test/ test/acceptance/", + "test-tap": "mocha --require test/support/env --reporter tap --check-leaks test/ test/acceptance/" + }, + "gitHead": "9375a9afa9d7baa814b454c7a6818a7471aaef00", + "bugs": { + "url": "https://github.com/expressjs/express/issues" + }, + "_id": "express@4.14.0", + "_shasum": "c1ee3f42cdc891fb3dc650a8922d51ec847d0d66", + "_from": "express@>=4.13.4 <5.0.0", + "_npmVersion": "1.4.28", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "maintainers": [ + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "hacksparrow", + "email": "captain@hacksparrow.com" + }, + { + "name": "jasnell", + "email": "jasnell@gmail.com" + }, + { + "name": "mikeal", + "email": "mikeal.rogers@gmail.com" + } + ], + "dist": { + "shasum": "c1ee3f42cdc891fb3dc650a8922d51ec847d0d66", + "tarball": "https://registry.npmjs.org/express/-/express-4.14.0.tgz" + }, + "_npmOperationalInternal": { + "host": "packages-12-west.internal.npmjs.com", + "tmp": "tmp/express-4.14.0.tgz_1466095407850_0.17484632693231106" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/express/-/express-4.14.0.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/method-override/HISTORY.md b/node_modules/method-override/HISTORY.md new file mode 100644 index 0000000..76464f0 --- /dev/null +++ b/node_modules/method-override/HISTORY.md @@ -0,0 +1,116 @@ +2.3.6 / 2016-05-20 +================== + + * deps: methods@~1.1.2 + - perf: enable strict mode + * deps: parseurl@~1.3.1 + - perf: enable strict mode + * deps: vary@~1.1.0 + +2.3.5 / 2015-07-31 +================== + + * perf: enable strict mode + +2.3.4 / 2015-07-14 +================== + + * deps: vary@~1.0.1 + +2.3.3 / 2015-05-12 +================== + + * deps: debug@~2.2.0 + - deps: ms@0.7.1 + +2.3.2 / 2015-03-14 +================== + + * deps: debug@~2.1.3 + - Fix high intensity foreground color for bold + - deps: ms@0.7.0 + +2.3.1 / 2014-12-30 +================== + + * deps: debug@~2.1.1 + * deps: methods@~1.1.1 + +2.3.0 / 2014-10-16 +================== + + * deps: debug@~2.1.0 + - Implement `DEBUG_FD` env variable support + +2.2.0 / 2014-09-02 +================== + + * deps: debug@~2.0.0 + +2.1.3 / 2014-08-10 +================== + + * deps: parseurl@~1.3.0 + * deps: vary@~1.0.0 + +2.1.2 / 2014-07-22 +================== + + * deps: debug@1.0.4 + * deps: parseurl@~1.2.0 + - Cache URLs based on original value + - Remove no-longer-needed URL mis-parse work-around + - Simplify the "fast-path" `RegExp` + +2.1.1 / 2014-07-11 +================== + + * deps: debug@1.0.3 + - Add support for multiple wildcards in namespaces + +2.1.0 / 2014-07-08 +================== + + * add simple debug output + * deps: methods@1.1.0 + - add `CONNECT` + * deps: parseurl@~1.1.3 + - faster parsing of href-only URLs + +2.0.2 / 2014-06-05 +================== + + * use vary module for better `Vary` behavior + +2.0.1 / 2014-06-02 +================== + + * deps: methods@1.0.1 + +2.0.0 / 2014-06-01 +================== + + * Default behavior only checks `X-HTTP-Method-Override` header + * New interface, less magic + - Can specify what header to look for override in, if wanted + - Can specify custom function to get method from request + * Only `POST` requests are examined by default + * Remove `req.body` support for more standard query param support + - Use custom `getter` function if `req.body` support is needed + * Set `Vary` header when using built-in header checking + +1.0.2 / 2014-05-22 +================== + + * Handle `req.body` key referencing array or object + * Handle multiple HTTP headers + +1.0.1 / 2014-05-17 +================== + + * deps: pin dependency versions + +1.0.0 / 2014-03-03 +================== + + * Genesis from `connect` diff --git a/node_modules/method-override/LICENSE b/node_modules/method-override/LICENSE new file mode 100644 index 0000000..53e49a3 --- /dev/null +++ b/node_modules/method-override/LICENSE @@ -0,0 +1,23 @@ +(The MIT License) + +Copyright (c) 2014 Jonathan Ong +Copyright (c) 2014 Douglas Christopher Wilson + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/method-override/README.md b/node_modules/method-override/README.md new file mode 100644 index 0000000..1e7adc6 --- /dev/null +++ b/node_modules/method-override/README.md @@ -0,0 +1,173 @@ +# method-override + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Build Status][travis-image]][travis-url] +[![Test Coverage][coveralls-image]][coveralls-url] +[![Gratipay][gratipay-image]][gratipay-url] + +Lets you use HTTP verbs such as PUT or DELETE in places where the client doesn't support it. + +## Install + +```sh +$ npm install method-override +``` + +## API + +**NOTE** It is very important that this module is used **before** any module that +needs to know the method of the request (for example, it _must_ be used prior to +the `csurf` module). + +### methodOverride(getter, options) + +Create a new middleware function to override the `req.method` property with a new +value. This value will be pulled from the provided `getter`. + +- `getter` - The getter to use to look up the overridden request method for the request. (default: `X-HTTP-Method-Override`) +- `options.methods` - The allowed methods the original request must be in to check for a method override value. (default: `['POST']`) + +If the found method is supported by node.js core, then `req.method` will be set to +this value, as if it has originally been that value. The previous `req.method` +value will be stored in `req.originalMethod`. + +#### getter + +This is the method of getting the override value from the request. If a function is provided, +the `req` is passed as the first argument, the `res` as the second argument and the method is +expected to be returned. If a string is provided, the string is used to look up the method +with the following rules: + +- If the string starts with `X-`, then it is treated as the name of a header and that header + is used for the method override. If the request contains the same header multiple times, the + first occurrence is used. +- All other strings are treated as a key in the URL query string. + +#### options.methods + +This allows the specification of what methods(s) the request *MUST* be in in order to check for +the method override value. This defaults to only `POST` methods, which is the only method the +override should arrive in. More methods may be specified here, but it may introduce security +issues and cause weird behavior when requests travel through caches. This value is an array +of methods in upper-case. `null` can be specified to allow all methods. + +## Examples + +### override using a header + +To use a header to override the method, specify the header name +as a string argument to the `methodOverride` function. To then make +the call, send a `POST` request to a URL with the overridden method +as the value of that header. This method of using a header would +typically be used in conjunction with `XMLHttpRequest` on implementations +that do not support the method you are trying to use. + +```js +var connect = require('connect') +var methodOverride = require('method-override') + +// override with the X-HTTP-Method-Override header in the request +app.use(methodOverride('X-HTTP-Method-Override')) +``` + +Example call with header override using `XMLHttpRequest`: + +```js +var xhr = new XMLHttpRequest() +xhr.onload = onload +xhr.open('post', '/resource', true) +xhr.setRequestHeader('X-HTTP-Method-Override', 'DELETE') +xhr.send() + +function onload() { + alert('got response: ' + this.responseText) +} +``` + +### override using a query value + +To use a query string value to override the method, specify the query +string key as a string argument to the `methodOverride` function. To +then make the call, send a `POST` request to a URL with the overridden +method as the value of that query string key. This method of using a +query value would typically be used in conjunction with plain HTML +`` elements when trying to support legacy browsers but still use +newer methods. + +```js +var connect = require('connect') +var methodOverride = require('method-override') + +// override with POST having ?_method=DELETE +app.use(methodOverride('_method')) +``` + +Example call with query override using HTML ``: + +```html + + + +``` + +### multiple format support + +```js +var connect = require('connect') +var methodOverride = require('method-override') + +// override with different headers; last one takes precedence +app.use(methodOverride('X-HTTP-Method')) // Microsoft +app.use(methodOverride('X-HTTP-Method-Override')) // Google/GData +app.use(methodOverride('X-Method-Override')) // IBM +``` + +### custom logic + +You can implement any kind of custom logic with a function for the `getter`. The following +implements the logic for looking in `req.body` that was in `method-override@1`: + +```js +var bodyParser = require('body-parser') +var connect = require('connect') +var methodOverride = require('method-override') + +// NOTE: when using req.body, you must fully parse the request body +// before you call methodOverride() in your middleware stack, +// otherwise req.body will not be populated. +app.use(bodyParser.urlencoded()) +app.use(methodOverride(function(req, res){ + if (req.body && typeof req.body === 'object' && '_method' in req.body) { + // look in urlencoded POST bodies and delete it + var method = req.body._method + delete req.body._method + return method + } +})) +``` + +Example call with query override using HTML `
`: + +```html + + + + +
+``` + +## License + +[MIT](LICENSE) + +[npm-image]: https://img.shields.io/npm/v/method-override.svg +[npm-url]: https://npmjs.org/package/method-override +[travis-image]: https://img.shields.io/travis/expressjs/method-override/master.svg +[travis-url]: https://travis-ci.org/expressjs/method-override +[coveralls-image]: https://img.shields.io/coveralls/expressjs/method-override/master.svg +[coveralls-url]: https://coveralls.io/r/expressjs/method-override?branch=master +[downloads-image]: https://img.shields.io/npm/dm/method-override.svg +[downloads-url]: https://npmjs.org/package/method-override +[gratipay-image]: https://img.shields.io/gratipay/dougwilson.svg +[gratipay-url]: https://www.gratipay.com/dougwilson/ diff --git a/node_modules/method-override/index.js b/node_modules/method-override/index.js new file mode 100644 index 0000000..2e34c20 --- /dev/null +++ b/node_modules/method-override/index.js @@ -0,0 +1,132 @@ +/*! + * method-override + * Copyright(c) 2010 Sencha Inc. + * Copyright(c) 2011 TJ Holowaychuk + * Copyright(c) 2014 Jonathan Ong + * Copyright(c) 2014 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module dependencies. + */ + +var debug = require('debug')('method-override') +var methods = require('methods') +var parseurl = require('parseurl') +var querystring = require('querystring') +var vary = require('vary') + +/** + * Method Override: + * + * Provides faux HTTP method support. + * + * Pass an optional `getter` to use when checking for + * a method override. + * + * A string is converted to a getter that will look for + * the method in `req.body[getter]` and a function will be + * called with `req` and expects the method to be returned. + * If the string starts with `X-` then it will look in + * `req.headers[getter]` instead. + * + * The original method is available via `req.originalMethod`. + * + * @param {string|function} [getter=X-HTTP-Method-Override] + * @param {object} [options] + * @return {function} + * @api public + */ + +module.exports = function methodOverride (getter, options) { + options = options || {} + + // get the getter fn + var get = typeof getter === 'function' + ? getter + : createGetter(getter || 'X-HTTP-Method-Override') + + // get allowed request methods to examine + var methods = options.methods === undefined + ? ['POST'] + : options.methods + + return function methodOverride (req, res, next) { + var method + var val + + req.originalMethod = req.originalMethod || req.method + + // validate request is an allowed method + if (methods && methods.indexOf(req.originalMethod) === -1) { + return next() + } + + val = get(req, res) + method = Array.isArray(val) + ? val[0] + : val + + // replace + if (method !== undefined && supports(method)) { + req.method = method.toUpperCase() + debug('override %s as %s', req.originalMethod, req.method) + } + + next() + } +} + +/** + * Create a getter for the given string. + */ + +function createGetter (str) { + if (str.substr(0, 2).toUpperCase() === 'X-') { + // header getter + return createHeaderGetter(str) + } + + return createQueryGetter(str) +} + +/** + * Create a getter for the given query key name. + */ + +function createQueryGetter (key) { + return function (req, res) { + var url = parseurl(req) + var query = querystring.parse(url.query || '') + return query[key] + } +} + +/** + * Create a getter for the given header name. + */ + +function createHeaderGetter (str) { + var header = str.toLowerCase() + + return function (req, res) { + // set appropriate Vary header + vary(res, str) + + // multiple headers get joined with comma by node.js core + return (req.headers[header] || '').split(/ *, */) + } +} + +/** + * Check if node supports `method`. + */ + +function supports (method) { + return method && + typeof method === 'string' && + methods.indexOf(method.toLowerCase()) !== -1 +} diff --git a/node_modules/method-override/node_modules/debug/.jshintrc b/node_modules/method-override/node_modules/debug/.jshintrc new file mode 100644 index 0000000..299877f --- /dev/null +++ b/node_modules/method-override/node_modules/debug/.jshintrc @@ -0,0 +1,3 @@ +{ + "laxbreak": true +} diff --git a/node_modules/method-override/node_modules/debug/.npmignore b/node_modules/method-override/node_modules/debug/.npmignore new file mode 100644 index 0000000..7e6163d --- /dev/null +++ b/node_modules/method-override/node_modules/debug/.npmignore @@ -0,0 +1,6 @@ +support +test +examples +example +*.sock +dist diff --git a/node_modules/method-override/node_modules/debug/History.md b/node_modules/method-override/node_modules/debug/History.md new file mode 100644 index 0000000..854c971 --- /dev/null +++ b/node_modules/method-override/node_modules/debug/History.md @@ -0,0 +1,195 @@ + +2.2.0 / 2015-05-09 +================== + + * package: update "ms" to v0.7.1 (#202, @dougwilson) + * README: add logging to file example (#193, @DanielOchoa) + * README: fixed a typo (#191, @amir-s) + * browser: expose `storage` (#190, @stephenmathieson) + * Makefile: add a `distclean` target (#189, @stephenmathieson) + +2.1.3 / 2015-03-13 +================== + + * Updated stdout/stderr example (#186) + * Updated example/stdout.js to match debug current behaviour + * Renamed example/stderr.js to stdout.js + * Update Readme.md (#184) + * replace high intensity foreground color for bold (#182, #183) + +2.1.2 / 2015-03-01 +================== + + * dist: recompile + * update "ms" to v0.7.0 + * package: update "browserify" to v9.0.3 + * component: fix "ms.js" repo location + * changed bower package name + * updated documentation about using debug in a browser + * fix: security error on safari (#167, #168, @yields) + +2.1.1 / 2014-12-29 +================== + + * browser: use `typeof` to check for `console` existence + * browser: check for `console.log` truthiness (fix IE 8/9) + * browser: add support for Chrome apps + * Readme: added Windows usage remarks + * Add `bower.json` to properly support bower install + +2.1.0 / 2014-10-15 +================== + + * node: implement `DEBUG_FD` env variable support + * package: update "browserify" to v6.1.0 + * package: add "license" field to package.json (#135, @panuhorsmalahti) + +2.0.0 / 2014-09-01 +================== + + * package: update "browserify" to v5.11.0 + * node: use stderr rather than stdout for logging (#29, @stephenmathieson) + +1.0.4 / 2014-07-15 +================== + + * dist: recompile + * example: remove `console.info()` log usage + * example: add "Content-Type" UTF-8 header to browser example + * browser: place %c marker after the space character + * browser: reset the "content" color via `color: inherit` + * browser: add colors support for Firefox >= v31 + * debug: prefer an instance `log()` function over the global one (#119) + * Readme: update documentation about styled console logs for FF v31 (#116, @wryk) + +1.0.3 / 2014-07-09 +================== + + * Add support for multiple wildcards in namespaces (#122, @seegno) + * browser: fix lint + +1.0.2 / 2014-06-10 +================== + + * browser: update color palette (#113, @gscottolson) + * common: make console logging function configurable (#108, @timoxley) + * node: fix %o colors on old node <= 0.8.x + * Makefile: find node path using shell/which (#109, @timoxley) + +1.0.1 / 2014-06-06 +================== + + * browser: use `removeItem()` to clear localStorage + * browser, node: don't set DEBUG if namespaces is undefined (#107, @leedm777) + * package: add "contributors" section + * node: fix comment typo + * README: list authors + +1.0.0 / 2014-06-04 +================== + + * make ms diff be global, not be scope + * debug: ignore empty strings in enable() + * node: make DEBUG_COLORS able to disable coloring + * *: export the `colors` array + * npmignore: don't publish the `dist` dir + * Makefile: refactor to use browserify + * package: add "browserify" as a dev dependency + * Readme: add Web Inspector Colors section + * node: reset terminal color for the debug content + * node: map "%o" to `util.inspect()` + * browser: map "%j" to `JSON.stringify()` + * debug: add custom "formatters" + * debug: use "ms" module for humanizing the diff + * Readme: add "bash" syntax highlighting + * browser: add Firebug color support + * browser: add colors for WebKit browsers + * node: apply log to `console` + * rewrite: abstract common logic for Node & browsers + * add .jshintrc file + +0.8.1 / 2014-04-14 +================== + + * package: re-add the "component" section + +0.8.0 / 2014-03-30 +================== + + * add `enable()` method for nodejs. Closes #27 + * change from stderr to stdout + * remove unnecessary index.js file + +0.7.4 / 2013-11-13 +================== + + * remove "browserify" key from package.json (fixes something in browserify) + +0.7.3 / 2013-10-30 +================== + + * fix: catch localStorage security error when cookies are blocked (Chrome) + * add debug(err) support. Closes #46 + * add .browser prop to package.json. Closes #42 + +0.7.2 / 2013-02-06 +================== + + * fix package.json + * fix: Mobile Safari (private mode) is broken with debug + * fix: Use unicode to send escape character to shell instead of octal to work with strict mode javascript + +0.7.1 / 2013-02-05 +================== + + * add repository URL to package.json + * add DEBUG_COLORED to force colored output + * add browserify support + * fix component. Closes #24 + +0.7.0 / 2012-05-04 +================== + + * Added .component to package.json + * Added debug.component.js build + +0.6.0 / 2012-03-16 +================== + + * Added support for "-" prefix in DEBUG [Vinay Pulim] + * Added `.enabled` flag to the node version [TooTallNate] + +0.5.0 / 2012-02-02 +================== + + * Added: humanize diffs. Closes #8 + * Added `debug.disable()` to the CS variant + * Removed padding. Closes #10 + * Fixed: persist client-side variant again. Closes #9 + +0.4.0 / 2012-02-01 +================== + + * Added browser variant support for older browsers [TooTallNate] + * Added `debug.enable('project:*')` to browser variant [TooTallNate] + * Added padding to diff (moved it to the right) + +0.3.0 / 2012-01-26 +================== + + * Added millisecond diff when isatty, otherwise UTC string + +0.2.0 / 2012-01-22 +================== + + * Added wildcard support + +0.1.0 / 2011-12-02 +================== + + * Added: remove colors unless stderr isatty [TooTallNate] + +0.0.1 / 2010-01-03 +================== + + * Initial release diff --git a/node_modules/method-override/node_modules/debug/Makefile b/node_modules/method-override/node_modules/debug/Makefile new file mode 100644 index 0000000..5cf4a59 --- /dev/null +++ b/node_modules/method-override/node_modules/debug/Makefile @@ -0,0 +1,36 @@ + +# get Makefile directory name: http://stackoverflow.com/a/5982798/376773 +THIS_MAKEFILE_PATH:=$(word $(words $(MAKEFILE_LIST)),$(MAKEFILE_LIST)) +THIS_DIR:=$(shell cd $(dir $(THIS_MAKEFILE_PATH));pwd) + +# BIN directory +BIN := $(THIS_DIR)/node_modules/.bin + +# applications +NODE ?= $(shell which node) +NPM ?= $(NODE) $(shell which npm) +BROWSERIFY ?= $(NODE) $(BIN)/browserify + +all: dist/debug.js + +install: node_modules + +clean: + @rm -rf dist + +dist: + @mkdir -p $@ + +dist/debug.js: node_modules browser.js debug.js dist + @$(BROWSERIFY) \ + --standalone debug \ + . > $@ + +distclean: clean + @rm -rf node_modules + +node_modules: package.json + @NODE_ENV= $(NPM) install + @touch node_modules + +.PHONY: all install clean distclean diff --git a/node_modules/method-override/node_modules/debug/Readme.md b/node_modules/method-override/node_modules/debug/Readme.md new file mode 100644 index 0000000..b4f45e3 --- /dev/null +++ b/node_modules/method-override/node_modules/debug/Readme.md @@ -0,0 +1,188 @@ +# debug + + tiny node.js debugging utility modelled after node core's debugging technique. + +## Installation + +```bash +$ npm install debug +``` + +## Usage + + With `debug` you simply invoke the exported function to generate your debug function, passing it a name which will determine if a noop function is returned, or a decorated `console.error`, so all of the `console` format string goodies you're used to work fine. A unique color is selected per-function for visibility. + +Example _app.js_: + +```js +var debug = require('debug')('http') + , http = require('http') + , name = 'My App'; + +// fake app + +debug('booting %s', name); + +http.createServer(function(req, res){ + debug(req.method + ' ' + req.url); + res.end('hello\n'); +}).listen(3000, function(){ + debug('listening'); +}); + +// fake worker of some kind + +require('./worker'); +``` + +Example _worker.js_: + +```js +var debug = require('debug')('worker'); + +setInterval(function(){ + debug('doing some work'); +}, 1000); +``` + + The __DEBUG__ environment variable is then used to enable these based on space or comma-delimited names. Here are some examples: + + ![debug http and worker](http://f.cl.ly/items/18471z1H402O24072r1J/Screenshot.png) + + ![debug worker](http://f.cl.ly/items/1X413v1a3M0d3C2c1E0i/Screenshot.png) + +#### Windows note + + On Windows the environment variable is set using the `set` command. + + ```cmd + set DEBUG=*,-not_this + ``` + +Then, run the program to be debugged as usual. + +## Millisecond diff + + When actively developing an application it can be useful to see when the time spent between one `debug()` call and the next. Suppose for example you invoke `debug()` before requesting a resource, and after as well, the "+NNNms" will show you how much time was spent between calls. + + ![](http://f.cl.ly/items/2i3h1d3t121M2Z1A3Q0N/Screenshot.png) + + When stdout is not a TTY, `Date#toUTCString()` is used, making it more useful for logging the debug information as shown below: + + ![](http://f.cl.ly/items/112H3i0e0o0P0a2Q2r11/Screenshot.png) + +## Conventions + + If you're using this in one or more of your libraries, you _should_ use the name of your library so that developers may toggle debugging as desired without guessing names. If you have more than one debuggers you _should_ prefix them with your library name and use ":" to separate features. For example "bodyParser" from Connect would then be "connect:bodyParser". + +## Wildcards + + The `*` character may be used as a wildcard. Suppose for example your library has debuggers named "connect:bodyParser", "connect:compress", "connect:session", instead of listing all three with `DEBUG=connect:bodyParser,connect:compress,connect:session`, you may simply do `DEBUG=connect:*`, or to run everything using this module simply use `DEBUG=*`. + + You can also exclude specific debuggers by prefixing them with a "-" character. For example, `DEBUG=*,-connect:*` would include all debuggers except those starting with "connect:". + +## Browser support + + Debug works in the browser as well, currently persisted by `localStorage`. Consider the situation shown below where you have `worker:a` and `worker:b`, and wish to debug both. Somewhere in the code on your page, include: + +```js +window.myDebug = require("debug"); +``` + + ("debug" is a global object in the browser so we give this object a different name.) When your page is open in the browser, type the following in the console: + +```js +myDebug.enable("worker:*") +``` + + Refresh the page. Debug output will continue to be sent to the console until it is disabled by typing `myDebug.disable()` in the console. + +```js +a = debug('worker:a'); +b = debug('worker:b'); + +setInterval(function(){ + a('doing some work'); +}, 1000); + +setInterval(function(){ + b('doing some work'); +}, 1200); +``` + +#### Web Inspector Colors + + Colors are also enabled on "Web Inspectors" that understand the `%c` formatting + option. These are WebKit web inspectors, Firefox ([since version + 31](https://hacks.mozilla.org/2014/05/editable-box-model-multiple-selection-sublime-text-keys-much-more-firefox-developer-tools-episode-31/)) + and the Firebug plugin for Firefox (any version). + + Colored output looks something like: + + ![](https://cloud.githubusercontent.com/assets/71256/3139768/b98c5fd8-e8ef-11e3-862a-f7253b6f47c6.png) + +### stderr vs stdout + +You can set an alternative logging method per-namespace by overriding the `log` method on a per-namespace or globally: + +Example _stdout.js_: + +```js +var debug = require('debug'); +var error = debug('app:error'); + +// by default stderr is used +error('goes to stderr!'); + +var log = debug('app:log'); +// set this namespace to log via console.log +log.log = console.log.bind(console); // don't forget to bind to console! +log('goes to stdout'); +error('still goes to stderr!'); + +// set all output to go via console.info +// overrides all per-namespace log settings +debug.log = console.info.bind(console); +error('now goes to stdout via console.info'); +log('still goes to stdout, but via console.info now'); +``` + +### Save debug output to a file + +You can save all debug statements to a file by piping them. + +Example: + +```bash +$ DEBUG_FD=3 node your-app.js 3> whatever.log +``` + +## Authors + + - TJ Holowaychuk + - Nathan Rajlich + +## License + +(The MIT License) + +Copyright (c) 2014 TJ Holowaychuk <tj@vision-media.ca> + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/method-override/node_modules/debug/bower.json b/node_modules/method-override/node_modules/debug/bower.json new file mode 100644 index 0000000..6af573f --- /dev/null +++ b/node_modules/method-override/node_modules/debug/bower.json @@ -0,0 +1,28 @@ +{ + "name": "visionmedia-debug", + "main": "dist/debug.js", + "version": "2.2.0", + "homepage": "https://github.com/visionmedia/debug", + "authors": [ + "TJ Holowaychuk " + ], + "description": "visionmedia-debug", + "moduleType": [ + "amd", + "es6", + "globals", + "node" + ], + "keywords": [ + "visionmedia", + "debug" + ], + "license": "MIT", + "ignore": [ + "**/.*", + "node_modules", + "bower_components", + "test", + "tests" + ] +} diff --git a/node_modules/method-override/node_modules/debug/browser.js b/node_modules/method-override/node_modules/debug/browser.js new file mode 100644 index 0000000..7c76452 --- /dev/null +++ b/node_modules/method-override/node_modules/debug/browser.js @@ -0,0 +1,168 @@ + +/** + * This is the web browser implementation of `debug()`. + * + * Expose `debug()` as the module. + */ + +exports = module.exports = require('./debug'); +exports.log = log; +exports.formatArgs = formatArgs; +exports.save = save; +exports.load = load; +exports.useColors = useColors; +exports.storage = 'undefined' != typeof chrome + && 'undefined' != typeof chrome.storage + ? chrome.storage.local + : localstorage(); + +/** + * Colors. + */ + +exports.colors = [ + 'lightseagreen', + 'forestgreen', + 'goldenrod', + 'dodgerblue', + 'darkorchid', + 'crimson' +]; + +/** + * Currently only WebKit-based Web Inspectors, Firefox >= v31, + * and the Firebug extension (any Firefox version) are known + * to support "%c" CSS customizations. + * + * TODO: add a `localStorage` variable to explicitly enable/disable colors + */ + +function useColors() { + // is webkit? http://stackoverflow.com/a/16459606/376773 + return ('WebkitAppearance' in document.documentElement.style) || + // is firebug? http://stackoverflow.com/a/398120/376773 + (window.console && (console.firebug || (console.exception && console.table))) || + // is firefox >= v31? + // https://developer.mozilla.org/en-US/docs/Tools/Web_Console#Styling_messages + (navigator.userAgent.toLowerCase().match(/firefox\/(\d+)/) && parseInt(RegExp.$1, 10) >= 31); +} + +/** + * Map %j to `JSON.stringify()`, since no Web Inspectors do that by default. + */ + +exports.formatters.j = function(v) { + return JSON.stringify(v); +}; + + +/** + * Colorize log arguments if enabled. + * + * @api public + */ + +function formatArgs() { + var args = arguments; + var useColors = this.useColors; + + args[0] = (useColors ? '%c' : '') + + this.namespace + + (useColors ? ' %c' : ' ') + + args[0] + + (useColors ? '%c ' : ' ') + + '+' + exports.humanize(this.diff); + + if (!useColors) return args; + + var c = 'color: ' + this.color; + args = [args[0], c, 'color: inherit'].concat(Array.prototype.slice.call(args, 1)); + + // the final "%c" is somewhat tricky, because there could be other + // arguments passed either before or after the %c, so we need to + // figure out the correct index to insert the CSS into + var index = 0; + var lastC = 0; + args[0].replace(/%[a-z%]/g, function(match) { + if ('%%' === match) return; + index++; + if ('%c' === match) { + // we only are interested in the *last* %c + // (the user may have provided their own) + lastC = index; + } + }); + + args.splice(lastC, 0, c); + return args; +} + +/** + * Invokes `console.log()` when available. + * No-op when `console.log` is not a "function". + * + * @api public + */ + +function log() { + // this hackery is required for IE8/9, where + // the `console.log` function doesn't have 'apply' + return 'object' === typeof console + && console.log + && Function.prototype.apply.call(console.log, console, arguments); +} + +/** + * Save `namespaces`. + * + * @param {String} namespaces + * @api private + */ + +function save(namespaces) { + try { + if (null == namespaces) { + exports.storage.removeItem('debug'); + } else { + exports.storage.debug = namespaces; + } + } catch(e) {} +} + +/** + * Load `namespaces`. + * + * @return {String} returns the previously persisted debug modes + * @api private + */ + +function load() { + var r; + try { + r = exports.storage.debug; + } catch(e) {} + return r; +} + +/** + * Enable namespaces listed in `localStorage.debug` initially. + */ + +exports.enable(load()); + +/** + * Localstorage attempts to return the localstorage. + * + * This is necessary because safari throws + * when a user disables cookies/localstorage + * and you attempt to access it. + * + * @return {LocalStorage} + * @api private + */ + +function localstorage(){ + try { + return window.localStorage; + } catch (e) {} +} diff --git a/node_modules/method-override/node_modules/debug/component.json b/node_modules/method-override/node_modules/debug/component.json new file mode 100644 index 0000000..ca10637 --- /dev/null +++ b/node_modules/method-override/node_modules/debug/component.json @@ -0,0 +1,19 @@ +{ + "name": "debug", + "repo": "visionmedia/debug", + "description": "small debugging utility", + "version": "2.2.0", + "keywords": [ + "debug", + "log", + "debugger" + ], + "main": "browser.js", + "scripts": [ + "browser.js", + "debug.js" + ], + "dependencies": { + "rauchg/ms.js": "0.7.1" + } +} diff --git a/node_modules/method-override/node_modules/debug/debug.js b/node_modules/method-override/node_modules/debug/debug.js new file mode 100644 index 0000000..7571a86 --- /dev/null +++ b/node_modules/method-override/node_modules/debug/debug.js @@ -0,0 +1,197 @@ + +/** + * This is the common logic for both the Node.js and web browser + * implementations of `debug()`. + * + * Expose `debug()` as the module. + */ + +exports = module.exports = debug; +exports.coerce = coerce; +exports.disable = disable; +exports.enable = enable; +exports.enabled = enabled; +exports.humanize = require('ms'); + +/** + * The currently active debug mode names, and names to skip. + */ + +exports.names = []; +exports.skips = []; + +/** + * Map of special "%n" handling functions, for the debug "format" argument. + * + * Valid key names are a single, lowercased letter, i.e. "n". + */ + +exports.formatters = {}; + +/** + * Previously assigned color. + */ + +var prevColor = 0; + +/** + * Previous log timestamp. + */ + +var prevTime; + +/** + * Select a color. + * + * @return {Number} + * @api private + */ + +function selectColor() { + return exports.colors[prevColor++ % exports.colors.length]; +} + +/** + * Create a debugger with the given `namespace`. + * + * @param {String} namespace + * @return {Function} + * @api public + */ + +function debug(namespace) { + + // define the `disabled` version + function disabled() { + } + disabled.enabled = false; + + // define the `enabled` version + function enabled() { + + var self = enabled; + + // set `diff` timestamp + var curr = +new Date(); + var ms = curr - (prevTime || curr); + self.diff = ms; + self.prev = prevTime; + self.curr = curr; + prevTime = curr; + + // add the `color` if not set + if (null == self.useColors) self.useColors = exports.useColors(); + if (null == self.color && self.useColors) self.color = selectColor(); + + var args = Array.prototype.slice.call(arguments); + + args[0] = exports.coerce(args[0]); + + if ('string' !== typeof args[0]) { + // anything else let's inspect with %o + args = ['%o'].concat(args); + } + + // apply any `formatters` transformations + var index = 0; + args[0] = args[0].replace(/%([a-z%])/g, function(match, format) { + // if we encounter an escaped % then don't increase the array index + if (match === '%%') return match; + index++; + var formatter = exports.formatters[format]; + if ('function' === typeof formatter) { + var val = args[index]; + match = formatter.call(self, val); + + // now we need to remove `args[index]` since it's inlined in the `format` + args.splice(index, 1); + index--; + } + return match; + }); + + if ('function' === typeof exports.formatArgs) { + args = exports.formatArgs.apply(self, args); + } + var logFn = enabled.log || exports.log || console.log.bind(console); + logFn.apply(self, args); + } + enabled.enabled = true; + + var fn = exports.enabled(namespace) ? enabled : disabled; + + fn.namespace = namespace; + + return fn; +} + +/** + * Enables a debug mode by namespaces. This can include modes + * separated by a colon and wildcards. + * + * @param {String} namespaces + * @api public + */ + +function enable(namespaces) { + exports.save(namespaces); + + var split = (namespaces || '').split(/[\s,]+/); + var len = split.length; + + for (var i = 0; i < len; i++) { + if (!split[i]) continue; // ignore empty strings + namespaces = split[i].replace(/\*/g, '.*?'); + if (namespaces[0] === '-') { + exports.skips.push(new RegExp('^' + namespaces.substr(1) + '$')); + } else { + exports.names.push(new RegExp('^' + namespaces + '$')); + } + } +} + +/** + * Disable debug output. + * + * @api public + */ + +function disable() { + exports.enable(''); +} + +/** + * Returns true if the given mode name is enabled, false otherwise. + * + * @param {String} name + * @return {Boolean} + * @api public + */ + +function enabled(name) { + var i, len; + for (i = 0, len = exports.skips.length; i < len; i++) { + if (exports.skips[i].test(name)) { + return false; + } + } + for (i = 0, len = exports.names.length; i < len; i++) { + if (exports.names[i].test(name)) { + return true; + } + } + return false; +} + +/** + * Coerce `val`. + * + * @param {Mixed} val + * @return {Mixed} + * @api private + */ + +function coerce(val) { + if (val instanceof Error) return val.stack || val.message; + return val; +} diff --git a/node_modules/method-override/node_modules/debug/node.js b/node_modules/method-override/node_modules/debug/node.js new file mode 100644 index 0000000..1d392a8 --- /dev/null +++ b/node_modules/method-override/node_modules/debug/node.js @@ -0,0 +1,209 @@ + +/** + * Module dependencies. + */ + +var tty = require('tty'); +var util = require('util'); + +/** + * This is the Node.js implementation of `debug()`. + * + * Expose `debug()` as the module. + */ + +exports = module.exports = require('./debug'); +exports.log = log; +exports.formatArgs = formatArgs; +exports.save = save; +exports.load = load; +exports.useColors = useColors; + +/** + * Colors. + */ + +exports.colors = [6, 2, 3, 4, 5, 1]; + +/** + * The file descriptor to write the `debug()` calls to. + * Set the `DEBUG_FD` env variable to override with another value. i.e.: + * + * $ DEBUG_FD=3 node script.js 3>debug.log + */ + +var fd = parseInt(process.env.DEBUG_FD, 10) || 2; +var stream = 1 === fd ? process.stdout : + 2 === fd ? process.stderr : + createWritableStdioStream(fd); + +/** + * Is stdout a TTY? Colored output is enabled when `true`. + */ + +function useColors() { + var debugColors = (process.env.DEBUG_COLORS || '').trim().toLowerCase(); + if (0 === debugColors.length) { + return tty.isatty(fd); + } else { + return '0' !== debugColors + && 'no' !== debugColors + && 'false' !== debugColors + && 'disabled' !== debugColors; + } +} + +/** + * Map %o to `util.inspect()`, since Node doesn't do that out of the box. + */ + +var inspect = (4 === util.inspect.length ? + // node <= 0.8.x + function (v, colors) { + return util.inspect(v, void 0, void 0, colors); + } : + // node > 0.8.x + function (v, colors) { + return util.inspect(v, { colors: colors }); + } +); + +exports.formatters.o = function(v) { + return inspect(v, this.useColors) + .replace(/\s*\n\s*/g, ' '); +}; + +/** + * Adds ANSI color escape codes if enabled. + * + * @api public + */ + +function formatArgs() { + var args = arguments; + var useColors = this.useColors; + var name = this.namespace; + + if (useColors) { + var c = this.color; + + args[0] = ' \u001b[3' + c + ';1m' + name + ' ' + + '\u001b[0m' + + args[0] + '\u001b[3' + c + 'm' + + ' +' + exports.humanize(this.diff) + '\u001b[0m'; + } else { + args[0] = new Date().toUTCString() + + ' ' + name + ' ' + args[0]; + } + return args; +} + +/** + * Invokes `console.error()` with the specified arguments. + */ + +function log() { + return stream.write(util.format.apply(this, arguments) + '\n'); +} + +/** + * Save `namespaces`. + * + * @param {String} namespaces + * @api private + */ + +function save(namespaces) { + if (null == namespaces) { + // If you set a process.env field to null or undefined, it gets cast to the + // string 'null' or 'undefined'. Just delete instead. + delete process.env.DEBUG; + } else { + process.env.DEBUG = namespaces; + } +} + +/** + * Load `namespaces`. + * + * @return {String} returns the previously persisted debug modes + * @api private + */ + +function load() { + return process.env.DEBUG; +} + +/** + * Copied from `node/src/node.js`. + * + * XXX: It's lame that node doesn't expose this API out-of-the-box. It also + * relies on the undocumented `tty_wrap.guessHandleType()` which is also lame. + */ + +function createWritableStdioStream (fd) { + var stream; + var tty_wrap = process.binding('tty_wrap'); + + // Note stream._type is used for test-module-load-list.js + + switch (tty_wrap.guessHandleType(fd)) { + case 'TTY': + stream = new tty.WriteStream(fd); + stream._type = 'tty'; + + // Hack to have stream not keep the event loop alive. + // See https://github.com/joyent/node/issues/1726 + if (stream._handle && stream._handle.unref) { + stream._handle.unref(); + } + break; + + case 'FILE': + var fs = require('fs'); + stream = new fs.SyncWriteStream(fd, { autoClose: false }); + stream._type = 'fs'; + break; + + case 'PIPE': + case 'TCP': + var net = require('net'); + stream = new net.Socket({ + fd: fd, + readable: false, + writable: true + }); + + // FIXME Should probably have an option in net.Socket to create a + // stream from an existing fd which is writable only. But for now + // we'll just add this hack and set the `readable` member to false. + // Test: ./node test/fixtures/echo.js < /etc/passwd + stream.readable = false; + stream.read = null; + stream._type = 'pipe'; + + // FIXME Hack to have stream not keep the event loop alive. + // See https://github.com/joyent/node/issues/1726 + if (stream._handle && stream._handle.unref) { + stream._handle.unref(); + } + break; + + default: + // Probably an error on in uv_guess_handle() + throw new Error('Implement me. Unknown stream file type!'); + } + + // For supporting legacy API we put the FD here. + stream.fd = fd; + + stream._isStdio = true; + + return stream; +} + +/** + * Enable namespaces listed in `process.env.DEBUG` initially. + */ + +exports.enable(load()); diff --git a/node_modules/method-override/node_modules/debug/node_modules/ms/.npmignore b/node_modules/method-override/node_modules/debug/node_modules/ms/.npmignore new file mode 100644 index 0000000..d1aa0ce --- /dev/null +++ b/node_modules/method-override/node_modules/debug/node_modules/ms/.npmignore @@ -0,0 +1,5 @@ +node_modules +test +History.md +Makefile +component.json diff --git a/node_modules/method-override/node_modules/debug/node_modules/ms/History.md b/node_modules/method-override/node_modules/debug/node_modules/ms/History.md new file mode 100644 index 0000000..32fdfc1 --- /dev/null +++ b/node_modules/method-override/node_modules/debug/node_modules/ms/History.md @@ -0,0 +1,66 @@ + +0.7.1 / 2015-04-20 +================== + + * prevent extraordinary long inputs (@evilpacket) + * Fixed broken readme link + +0.7.0 / 2014-11-24 +================== + + * add time abbreviations, updated tests and readme for the new units + * fix example in the readme. + * add LICENSE file + +0.6.2 / 2013-12-05 +================== + + * Adding repository section to package.json to suppress warning from NPM. + +0.6.1 / 2013-05-10 +================== + + * fix singularization [visionmedia] + +0.6.0 / 2013-03-15 +================== + + * fix minutes + +0.5.1 / 2013-02-24 +================== + + * add component namespace + +0.5.0 / 2012-11-09 +================== + + * add short formatting as default and .long option + * add .license property to component.json + * add version to component.json + +0.4.0 / 2012-10-22 +================== + + * add rounding to fix crazy decimals + +0.3.0 / 2012-09-07 +================== + + * fix `ms()` [visionmedia] + +0.2.0 / 2012-09-03 +================== + + * add component.json [visionmedia] + * add days support [visionmedia] + * add hours support [visionmedia] + * add minutes support [visionmedia] + * add seconds support [visionmedia] + * add ms string support [visionmedia] + * refactor tests to facilitate ms(number) [visionmedia] + +0.1.0 / 2012-03-07 +================== + + * Initial release diff --git a/node_modules/method-override/node_modules/debug/node_modules/ms/LICENSE b/node_modules/method-override/node_modules/debug/node_modules/ms/LICENSE new file mode 100644 index 0000000..6c07561 --- /dev/null +++ b/node_modules/method-override/node_modules/debug/node_modules/ms/LICENSE @@ -0,0 +1,20 @@ +(The MIT License) + +Copyright (c) 2014 Guillermo Rauch + +Permission is hereby granted, free of charge, to any person obtaining a copy of +this software and associated documentation files (the "Software"), to deal in +the Software without restriction, including without limitation the rights to +use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of +the Software, and to permit persons to whom the Software is furnished to do so, +subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS +FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR +COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER +IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN +CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/method-override/node_modules/debug/node_modules/ms/README.md b/node_modules/method-override/node_modules/debug/node_modules/ms/README.md new file mode 100644 index 0000000..9b4fd03 --- /dev/null +++ b/node_modules/method-override/node_modules/debug/node_modules/ms/README.md @@ -0,0 +1,35 @@ +# ms.js: miliseconds conversion utility + +```js +ms('2 days') // 172800000 +ms('1d') // 86400000 +ms('10h') // 36000000 +ms('2.5 hrs') // 9000000 +ms('2h') // 7200000 +ms('1m') // 60000 +ms('5s') // 5000 +ms('100') // 100 +``` + +```js +ms(60000) // "1m" +ms(2 * 60000) // "2m" +ms(ms('10 hours')) // "10h" +``` + +```js +ms(60000, { long: true }) // "1 minute" +ms(2 * 60000, { long: true }) // "2 minutes" +ms(ms('10 hours'), { long: true }) // "10 hours" +``` + +- Node/Browser compatible. Published as [`ms`](https://www.npmjs.org/package/ms) in [NPM](http://nodejs.org/download). +- If a number is supplied to `ms`, a string with a unit is returned. +- If a string that contains the number is supplied, it returns it as +a number (e.g: it returns `100` for `'100'`). +- If you pass a string with a number and a valid unit, the number of +equivalent ms is returned. + +## License + +MIT diff --git a/node_modules/method-override/node_modules/debug/node_modules/ms/index.js b/node_modules/method-override/node_modules/debug/node_modules/ms/index.js new file mode 100644 index 0000000..4f92771 --- /dev/null +++ b/node_modules/method-override/node_modules/debug/node_modules/ms/index.js @@ -0,0 +1,125 @@ +/** + * Helpers. + */ + +var s = 1000; +var m = s * 60; +var h = m * 60; +var d = h * 24; +var y = d * 365.25; + +/** + * Parse or format the given `val`. + * + * Options: + * + * - `long` verbose formatting [false] + * + * @param {String|Number} val + * @param {Object} options + * @return {String|Number} + * @api public + */ + +module.exports = function(val, options){ + options = options || {}; + if ('string' == typeof val) return parse(val); + return options.long + ? long(val) + : short(val); +}; + +/** + * Parse the given `str` and return milliseconds. + * + * @param {String} str + * @return {Number} + * @api private + */ + +function parse(str) { + str = '' + str; + if (str.length > 10000) return; + var match = /^((?:\d+)?\.?\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|years?|yrs?|y)?$/i.exec(str); + if (!match) return; + var n = parseFloat(match[1]); + var type = (match[2] || 'ms').toLowerCase(); + switch (type) { + case 'years': + case 'year': + case 'yrs': + case 'yr': + case 'y': + return n * y; + case 'days': + case 'day': + case 'd': + return n * d; + case 'hours': + case 'hour': + case 'hrs': + case 'hr': + case 'h': + return n * h; + case 'minutes': + case 'minute': + case 'mins': + case 'min': + case 'm': + return n * m; + case 'seconds': + case 'second': + case 'secs': + case 'sec': + case 's': + return n * s; + case 'milliseconds': + case 'millisecond': + case 'msecs': + case 'msec': + case 'ms': + return n; + } +} + +/** + * Short format for `ms`. + * + * @param {Number} ms + * @return {String} + * @api private + */ + +function short(ms) { + if (ms >= d) return Math.round(ms / d) + 'd'; + if (ms >= h) return Math.round(ms / h) + 'h'; + if (ms >= m) return Math.round(ms / m) + 'm'; + if (ms >= s) return Math.round(ms / s) + 's'; + return ms + 'ms'; +} + +/** + * Long format for `ms`. + * + * @param {Number} ms + * @return {String} + * @api private + */ + +function long(ms) { + return plural(ms, d, 'day') + || plural(ms, h, 'hour') + || plural(ms, m, 'minute') + || plural(ms, s, 'second') + || ms + ' ms'; +} + +/** + * Pluralization helper. + */ + +function plural(ms, n, name) { + if (ms < n) return; + if (ms < n * 1.5) return Math.floor(ms / n) + ' ' + name; + return Math.ceil(ms / n) + ' ' + name + 's'; +} diff --git a/node_modules/method-override/node_modules/debug/node_modules/ms/package.json b/node_modules/method-override/node_modules/debug/node_modules/ms/package.json new file mode 100644 index 0000000..64818de --- /dev/null +++ b/node_modules/method-override/node_modules/debug/node_modules/ms/package.json @@ -0,0 +1,48 @@ +{ + "name": "ms", + "version": "0.7.1", + "description": "Tiny ms conversion utility", + "repository": { + "type": "git", + "url": "git://github.com/guille/ms.js.git" + }, + "main": "./index", + "devDependencies": { + "mocha": "*", + "expect.js": "*", + "serve": "*" + }, + "component": { + "scripts": { + "ms/index.js": "index.js" + } + }, + "gitHead": "713dcf26d9e6fd9dbc95affe7eff9783b7f1b909", + "bugs": { + "url": "https://github.com/guille/ms.js/issues" + }, + "homepage": "https://github.com/guille/ms.js", + "_id": "ms@0.7.1", + "scripts": {}, + "_shasum": "9cd13c03adbff25b65effde7ce864ee952017098", + "_from": "ms@0.7.1", + "_npmVersion": "2.7.5", + "_nodeVersion": "0.12.2", + "_npmUser": { + "name": "rauchg", + "email": "rauchg@gmail.com" + }, + "maintainers": [ + { + "name": "rauchg", + "email": "rauchg@gmail.com" + } + ], + "dist": { + "shasum": "9cd13c03adbff25b65effde7ce864ee952017098", + "tarball": "https://registry.npmjs.org/ms/-/ms-0.7.1.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/ms/-/ms-0.7.1.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/method-override/node_modules/debug/package.json b/node_modules/method-override/node_modules/debug/package.json new file mode 100644 index 0000000..5228b80 --- /dev/null +++ b/node_modules/method-override/node_modules/debug/package.json @@ -0,0 +1,73 @@ +{ + "name": "debug", + "version": "2.2.0", + "repository": { + "type": "git", + "url": "git://github.com/visionmedia/debug.git" + }, + "description": "small debugging utility", + "keywords": [ + "debug", + "log", + "debugger" + ], + "author": { + "name": "TJ Holowaychuk", + "email": "tj@vision-media.ca" + }, + "contributors": [ + { + "name": "Nathan Rajlich", + "email": "nathan@tootallnate.net", + "url": "http://n8.io" + } + ], + "license": "MIT", + "dependencies": { + "ms": "0.7.1" + }, + "devDependencies": { + "browserify": "9.0.3", + "mocha": "*" + }, + "main": "./node.js", + "browser": "./browser.js", + "component": { + "scripts": { + "debug/index.js": "browser.js", + "debug/debug.js": "debug.js" + } + }, + "gitHead": "b38458422b5aa8aa6d286b10dfe427e8a67e2b35", + "bugs": { + "url": "https://github.com/visionmedia/debug/issues" + }, + "homepage": "https://github.com/visionmedia/debug", + "_id": "debug@2.2.0", + "scripts": {}, + "_shasum": "f87057e995b1a1f6ae6a4960664137bc56f039da", + "_from": "debug@>=2.2.0 <2.3.0", + "_npmVersion": "2.7.4", + "_nodeVersion": "0.12.2", + "_npmUser": { + "name": "tootallnate", + "email": "nathan@tootallnate.net" + }, + "maintainers": [ + { + "name": "tjholowaychuk", + "email": "tj@vision-media.ca" + }, + { + "name": "tootallnate", + "email": "nathan@tootallnate.net" + } + ], + "dist": { + "shasum": "f87057e995b1a1f6ae6a4960664137bc56f039da", + "tarball": "https://registry.npmjs.org/debug/-/debug-2.2.0.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/debug/-/debug-2.2.0.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/method-override/node_modules/methods/HISTORY.md b/node_modules/method-override/node_modules/methods/HISTORY.md new file mode 100644 index 0000000..c0ecf07 --- /dev/null +++ b/node_modules/method-override/node_modules/methods/HISTORY.md @@ -0,0 +1,29 @@ +1.1.2 / 2016-01-17 +================== + + * perf: enable strict mode + +1.1.1 / 2014-12-30 +================== + + * Improve `browserify` support + +1.1.0 / 2014-07-05 +================== + + * Add `CONNECT` method + +1.0.1 / 2014-06-02 +================== + + * Fix module to work with harmony transform + +1.0.0 / 2014-05-08 +================== + + * Add `PURGE` method + +0.1.0 / 2013-10-28 +================== + + * Add `http.METHODS` support diff --git a/node_modules/method-override/node_modules/methods/LICENSE b/node_modules/method-override/node_modules/methods/LICENSE new file mode 100644 index 0000000..220dc1a --- /dev/null +++ b/node_modules/method-override/node_modules/methods/LICENSE @@ -0,0 +1,24 @@ +(The MIT License) + +Copyright (c) 2013-2014 TJ Holowaychuk +Copyright (c) 2015-2016 Douglas Christopher Wilson + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + diff --git a/node_modules/method-override/node_modules/methods/README.md b/node_modules/method-override/node_modules/methods/README.md new file mode 100644 index 0000000..672a32b --- /dev/null +++ b/node_modules/method-override/node_modules/methods/README.md @@ -0,0 +1,51 @@ +# Methods + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Node.js Version][node-version-image]][node-version-url] +[![Build Status][travis-image]][travis-url] +[![Test Coverage][coveralls-image]][coveralls-url] + +HTTP verbs that Node.js core's HTTP parser supports. + +This module provides an export that is just like `http.METHODS` from Node.js core, +with the following differences: + + * All method names are lower-cased. + * Contains a fallback list of methods for Node.js versions that do not have a + `http.METHODS` export (0.10 and lower). + * Provides the fallback list when using tools like `browserify` without pulling + in the `http` shim module. + +## Install + +```bash +$ npm install methods +``` + +## API + +```js +var methods = require('methods') +``` + +### methods + +This is an array of lower-cased method names that Node.js supports. If Node.js +provides the `http.METHODS` export, then this is the same array lower-cased, +otherwise it is a snapshot of the verbs from Node.js 0.10. + +## License + +[MIT](LICENSE) + +[npm-image]: https://img.shields.io/npm/v/methods.svg?style=flat +[npm-url]: https://npmjs.org/package/methods +[node-version-image]: https://img.shields.io/node/v/methods.svg?style=flat +[node-version-url]: https://nodejs.org/en/download/ +[travis-image]: https://img.shields.io/travis/jshttp/methods.svg?style=flat +[travis-url]: https://travis-ci.org/jshttp/methods +[coveralls-image]: https://img.shields.io/coveralls/jshttp/methods.svg?style=flat +[coveralls-url]: https://coveralls.io/r/jshttp/methods?branch=master +[downloads-image]: https://img.shields.io/npm/dm/methods.svg?style=flat +[downloads-url]: https://npmjs.org/package/methods diff --git a/node_modules/method-override/node_modules/methods/index.js b/node_modules/method-override/node_modules/methods/index.js new file mode 100644 index 0000000..667a50b --- /dev/null +++ b/node_modules/method-override/node_modules/methods/index.js @@ -0,0 +1,69 @@ +/*! + * methods + * Copyright(c) 2013-2014 TJ Holowaychuk + * Copyright(c) 2015-2016 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict'; + +/** + * Module dependencies. + * @private + */ + +var http = require('http'); + +/** + * Module exports. + * @public + */ + +module.exports = getCurrentNodeMethods() || getBasicNodeMethods(); + +/** + * Get the current Node.js methods. + * @private + */ + +function getCurrentNodeMethods() { + return http.METHODS && http.METHODS.map(function lowerCaseMethod(method) { + return method.toLowerCase(); + }); +} + +/** + * Get the "basic" Node.js methods, a snapshot from Node.js 0.10. + * @private + */ + +function getBasicNodeMethods() { + return [ + 'get', + 'post', + 'put', + 'head', + 'delete', + 'options', + 'trace', + 'copy', + 'lock', + 'mkcol', + 'move', + 'purge', + 'propfind', + 'proppatch', + 'unlock', + 'report', + 'mkactivity', + 'checkout', + 'merge', + 'm-search', + 'notify', + 'subscribe', + 'unsubscribe', + 'patch', + 'search', + 'connect' + ]; +} diff --git a/node_modules/method-override/node_modules/methods/package.json b/node_modules/method-override/node_modules/methods/package.json new file mode 100644 index 0000000..dc53ac0 --- /dev/null +++ b/node_modules/method-override/node_modules/methods/package.json @@ -0,0 +1,88 @@ +{ + "name": "methods", + "description": "HTTP methods that node supports", + "version": "1.1.2", + "contributors": [ + { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "Jonathan Ong", + "email": "me@jongleberry.com", + "url": "http://jongleberry.com" + }, + { + "name": "TJ Holowaychuk", + "email": "tj@vision-media.ca", + "url": "http://tjholowaychuk.com" + } + ], + "license": "MIT", + "repository": { + "type": "git", + "url": "git+https://github.com/jshttp/methods.git" + }, + "devDependencies": { + "istanbul": "0.4.1", + "mocha": "1.21.5" + }, + "files": [ + "index.js", + "HISTORY.md", + "LICENSE" + ], + "engines": { + "node": ">= 0.6" + }, + "scripts": { + "test": "mocha --reporter spec --bail --check-leaks test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot --check-leaks test/", + "test-travis": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter spec --check-leaks test/" + }, + "browser": { + "http": false + }, + "keywords": [ + "http", + "methods" + ], + "gitHead": "25d257d913f1b94bd2d73581521ff72c81469140", + "bugs": { + "url": "https://github.com/jshttp/methods/issues" + }, + "homepage": "https://github.com/jshttp/methods", + "_id": "methods@1.1.2", + "_shasum": "5529a4d67654134edcc5266656835b0f851afcee", + "_from": "methods@>=1.1.2 <1.2.0", + "_npmVersion": "1.4.28", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "maintainers": [ + { + "name": "tjholowaychuk", + "email": "tj@vision-media.ca" + }, + { + "name": "jonathanong", + "email": "jonathanrichardong@gmail.com" + }, + { + "name": "jongleberry", + "email": "jonathanrichardong@gmail.com" + }, + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + } + ], + "dist": { + "shasum": "5529a4d67654134edcc5266656835b0f851afcee", + "tarball": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/methods/-/methods-1.1.2.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/method-override/node_modules/parseurl/HISTORY.md b/node_modules/method-override/node_modules/parseurl/HISTORY.md new file mode 100644 index 0000000..395041e --- /dev/null +++ b/node_modules/method-override/node_modules/parseurl/HISTORY.md @@ -0,0 +1,47 @@ +1.3.1 / 2016-01-17 +================== + + * perf: enable strict mode + +1.3.0 / 2014-08-09 +================== + + * Add `parseurl.original` for parsing `req.originalUrl` with fallback + * Return `undefined` if `req.url` is `undefined` + +1.2.0 / 2014-07-21 +================== + + * Cache URLs based on original value + * Remove no-longer-needed URL mis-parse work-around + * Simplify the "fast-path" `RegExp` + +1.1.3 / 2014-07-08 +================== + + * Fix typo + +1.1.2 / 2014-07-08 +================== + + * Seriously fix Node.js 0.8 compatibility + +1.1.1 / 2014-07-08 +================== + + * Fix Node.js 0.8 compatibility + +1.1.0 / 2014-07-08 +================== + + * Incorporate URL href-only parse fast-path + +1.0.1 / 2014-03-08 +================== + + * Add missing `require` + +1.0.0 / 2014-03-08 +================== + + * Genesis from `connect` diff --git a/node_modules/method-override/node_modules/parseurl/LICENSE b/node_modules/method-override/node_modules/parseurl/LICENSE new file mode 100644 index 0000000..ec7dfe7 --- /dev/null +++ b/node_modules/method-override/node_modules/parseurl/LICENSE @@ -0,0 +1,24 @@ + +(The MIT License) + +Copyright (c) 2014 Jonathan Ong +Copyright (c) 2014 Douglas Christopher Wilson + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/method-override/node_modules/parseurl/README.md b/node_modules/method-override/node_modules/parseurl/README.md new file mode 100644 index 0000000..f4796eb --- /dev/null +++ b/node_modules/method-override/node_modules/parseurl/README.md @@ -0,0 +1,120 @@ +# parseurl + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Node.js Version][node-version-image]][node-version-url] +[![Build Status][travis-image]][travis-url] +[![Test Coverage][coveralls-image]][coveralls-url] + +Parse a URL with memoization. + +## Install + +```bash +$ npm install parseurl +``` + +## API + +```js +var parseurl = require('parseurl') +``` + +### parseurl(req) + +Parse the URL of the given request object (looks at the `req.url` property) +and return the result. The result is the same as `url.parse` in Node.js core. +Calling this function multiple times on the same `req` where `req.url` does +not change will return a cached parsed object, rather than parsing again. + +### parseurl.original(req) + +Parse the original URL of the given request object and return the result. +This works by trying to parse `req.originalUrl` if it is a string, otherwise +parses `req.url`. The result is the same as `url.parse` in Node.js core. +Calling this function multiple times on the same `req` where `req.originalUrl` +does not change will return a cached parsed object, rather than parsing again. + +## Benchmark + +```bash +$ npm run-script bench + +> parseurl@1.3.1 bench nodejs-parseurl +> node benchmark/index.js + +> node benchmark/fullurl.js + + Parsing URL "http://localhost:8888/foo/bar?user=tj&pet=fluffy" + + 1 test completed. + 2 tests completed. + 3 tests completed. + + fasturl x 1,290,780 ops/sec ±0.46% (195 runs sampled) + nativeurl x 56,401 ops/sec ±0.22% (196 runs sampled) + parseurl x 55,231 ops/sec ±0.22% (194 runs sampled) + +> node benchmark/pathquery.js + + Parsing URL "/foo/bar?user=tj&pet=fluffy" + + 1 test completed. + 2 tests completed. + 3 tests completed. + + fasturl x 1,986,668 ops/sec ±0.27% (190 runs sampled) + nativeurl x 98,740 ops/sec ±0.21% (195 runs sampled) + parseurl x 2,628,171 ops/sec ±0.36% (195 runs sampled) + +> node benchmark/samerequest.js + + Parsing URL "/foo/bar?user=tj&pet=fluffy" on same request object + + 1 test completed. + 2 tests completed. + 3 tests completed. + + fasturl x 2,184,468 ops/sec ±0.40% (194 runs sampled) + nativeurl x 99,437 ops/sec ±0.71% (194 runs sampled) + parseurl x 10,498,005 ops/sec ±0.61% (186 runs sampled) + +> node benchmark/simplepath.js + + Parsing URL "/foo/bar" + + 1 test completed. + 2 tests completed. + 3 tests completed. + + fasturl x 4,535,825 ops/sec ±0.27% (191 runs sampled) + nativeurl x 98,769 ops/sec ±0.54% (191 runs sampled) + parseurl x 4,164,865 ops/sec ±0.34% (192 runs sampled) + +> node benchmark/slash.js + + Parsing URL "/" + + 1 test completed. + 2 tests completed. + 3 tests completed. + + fasturl x 4,908,405 ops/sec ±0.42% (191 runs sampled) + nativeurl x 100,945 ops/sec ±0.59% (188 runs sampled) + parseurl x 4,333,208 ops/sec ±0.27% (194 runs sampled) +``` + +## License + + [MIT](LICENSE) + +[npm-image]: https://img.shields.io/npm/v/parseurl.svg +[npm-url]: https://npmjs.org/package/parseurl +[node-version-image]: https://img.shields.io/node/v/parseurl.svg +[node-version-url]: http://nodejs.org/download/ +[travis-image]: https://img.shields.io/travis/pillarjs/parseurl/master.svg +[travis-url]: https://travis-ci.org/pillarjs/parseurl +[coveralls-image]: https://img.shields.io/coveralls/pillarjs/parseurl/master.svg +[coveralls-url]: https://coveralls.io/r/pillarjs/parseurl?branch=master +[downloads-image]: https://img.shields.io/npm/dm/parseurl.svg +[downloads-url]: https://npmjs.org/package/parseurl diff --git a/node_modules/method-override/node_modules/parseurl/index.js b/node_modules/method-override/node_modules/parseurl/index.js new file mode 100644 index 0000000..56cc6ec --- /dev/null +++ b/node_modules/method-override/node_modules/parseurl/index.js @@ -0,0 +1,138 @@ +/*! + * parseurl + * Copyright(c) 2014 Jonathan Ong + * Copyright(c) 2014 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module dependencies. + */ + +var url = require('url') +var parse = url.parse +var Url = url.Url + +/** + * Pattern for a simple path case. + * See: https://github.com/joyent/node/pull/7878 + */ + +var simplePathRegExp = /^(\/\/?(?!\/)[^\?#\s]*)(\?[^#\s]*)?$/ + +/** + * Exports. + */ + +module.exports = parseurl +module.exports.original = originalurl + +/** + * Parse the `req` url with memoization. + * + * @param {ServerRequest} req + * @return {Object} + * @api public + */ + +function parseurl(req) { + var url = req.url + + if (url === undefined) { + // URL is undefined + return undefined + } + + var parsed = req._parsedUrl + + if (fresh(url, parsed)) { + // Return cached URL parse + return parsed + } + + // Parse the URL + parsed = fastparse(url) + parsed._raw = url + + return req._parsedUrl = parsed +}; + +/** + * Parse the `req` original url with fallback and memoization. + * + * @param {ServerRequest} req + * @return {Object} + * @api public + */ + +function originalurl(req) { + var url = req.originalUrl + + if (typeof url !== 'string') { + // Fallback + return parseurl(req) + } + + var parsed = req._parsedOriginalUrl + + if (fresh(url, parsed)) { + // Return cached URL parse + return parsed + } + + // Parse the URL + parsed = fastparse(url) + parsed._raw = url + + return req._parsedOriginalUrl = parsed +}; + +/** + * Parse the `str` url with fast-path short-cut. + * + * @param {string} str + * @return {Object} + * @api private + */ + +function fastparse(str) { + // Try fast path regexp + // See: https://github.com/joyent/node/pull/7878 + var simplePath = typeof str === 'string' && simplePathRegExp.exec(str) + + // Construct simple URL + if (simplePath) { + var pathname = simplePath[1] + var search = simplePath[2] || null + var url = Url !== undefined + ? new Url() + : {} + url.path = str + url.href = str + url.pathname = pathname + url.search = search + url.query = search && search.substr(1) + + return url + } + + return parse(str) +} + +/** + * Determine if parsed is still fresh for url. + * + * @param {string} url + * @param {object} parsedUrl + * @return {boolean} + * @api private + */ + +function fresh(url, parsedUrl) { + return typeof parsedUrl === 'object' + && parsedUrl !== null + && (Url === undefined || parsedUrl instanceof Url) + && parsedUrl._raw === url +} diff --git a/node_modules/method-override/node_modules/parseurl/package.json b/node_modules/method-override/node_modules/parseurl/package.json new file mode 100644 index 0000000..35e6d20 --- /dev/null +++ b/node_modules/method-override/node_modules/parseurl/package.json @@ -0,0 +1,89 @@ +{ + "name": "parseurl", + "description": "parse a url with memoization", + "version": "1.3.1", + "author": { + "name": "Jonathan Ong", + "email": "me@jongleberry.com", + "url": "http://jongleberry.com" + }, + "contributors": [ + { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + } + ], + "repository": { + "type": "git", + "url": "git+https://github.com/pillarjs/parseurl.git" + }, + "license": "MIT", + "devDependencies": { + "benchmark": "2.0.0", + "beautify-benchmark": "0.2.4", + "fast-url-parser": "1.1.3", + "istanbul": "0.4.2", + "mocha": "~1.21.5" + }, + "files": [ + "LICENSE", + "HISTORY.md", + "README.md", + "index.js" + ], + "engines": { + "node": ">= 0.8" + }, + "scripts": { + "bench": "node benchmark/index.js", + "test": "mocha --check-leaks --bail --reporter spec test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --check-leaks --reporter dot test/", + "test-travis": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --check-leaks --reporter spec test/" + }, + "gitHead": "6d22d376d75b927ab2b5347ce3a1d6735133dd43", + "bugs": { + "url": "https://github.com/pillarjs/parseurl/issues" + }, + "homepage": "https://github.com/pillarjs/parseurl", + "_id": "parseurl@1.3.1", + "_shasum": "c8ab8c9223ba34888aa64a297b28853bec18da56", + "_from": "parseurl@>=1.3.1 <1.4.0", + "_npmVersion": "1.4.28", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "maintainers": [ + { + "name": "jongleberry", + "email": "jonathanrichardong@gmail.com" + }, + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "tjholowaychuk", + "email": "tj@vision-media.ca" + }, + { + "name": "mscdex", + "email": "mscdex@mscdex.net" + }, + { + "name": "fishrock123", + "email": "fishrock123@rocketmail.com" + }, + { + "name": "defunctzombie", + "email": "shtylman@gmail.com" + } + ], + "dist": { + "shasum": "c8ab8c9223ba34888aa64a297b28853bec18da56", + "tarball": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.1.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/parseurl/-/parseurl-1.3.1.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/method-override/node_modules/vary/HISTORY.md b/node_modules/method-override/node_modules/vary/HISTORY.md new file mode 100644 index 0000000..ed68118 --- /dev/null +++ b/node_modules/method-override/node_modules/vary/HISTORY.md @@ -0,0 +1,29 @@ +1.1.0 / 2015-09-29 +================== + + * Only accept valid field names in the `field` argument + - Ensures the resulting string is a valid HTTP header value + +1.0.1 / 2015-07-08 +================== + + * Fix setting empty header from empty `field` + * perf: enable strict mode + * perf: remove argument reassignments + +1.0.0 / 2014-08-10 +================== + + * Accept valid `Vary` header string as `field` + * Add `vary.append` for low-level string manipulation + * Move to `jshttp` orgainzation + +0.1.0 / 2014-06-05 +================== + + * Support array of fields to set + +0.0.0 / 2014-06-04 +================== + + * Initial release diff --git a/node_modules/method-override/node_modules/vary/LICENSE b/node_modules/method-override/node_modules/vary/LICENSE new file mode 100644 index 0000000..142ede3 --- /dev/null +++ b/node_modules/method-override/node_modules/vary/LICENSE @@ -0,0 +1,22 @@ +(The MIT License) + +Copyright (c) 2014-2015 Douglas Christopher Wilson + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/method-override/node_modules/vary/README.md b/node_modules/method-override/node_modules/vary/README.md new file mode 100644 index 0000000..5966542 --- /dev/null +++ b/node_modules/method-override/node_modules/vary/README.md @@ -0,0 +1,91 @@ +# vary + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Node.js Version][node-version-image]][node-version-url] +[![Build Status][travis-image]][travis-url] +[![Test Coverage][coveralls-image]][coveralls-url] + +Manipulate the HTTP Vary header + +## Installation + +```sh +$ npm install vary +``` + +## API + +```js +var vary = require('vary') +``` + +### vary(res, field) + +Adds the given header `field` to the `Vary` response header of `res`. +This can be a string of a single field, a string of a valid `Vary` +header, or an array of multiple fields. + +This will append the header if not already listed, otherwise leaves +it listed in the current location. + +```js +// Append "Origin" to the Vary header of the response +vary(res, 'Origin') +``` + +### vary.append(header, field) + +Adds the given header `field` to the `Vary` response header string `header`. +This can be a string of a single field, a string of a valid `Vary` header, +or an array of multiple fields. + +This will append the header if not already listed, otherwise leaves +it listed in the current location. The new header string is returned. + +```js +// Get header string appending "Origin" to "Accept, User-Agent" +vary.append('Accept, User-Agent', 'Origin') +``` + +## Examples + +### Updating the Vary header when content is based on it + +```js +var http = require('http') +var vary = require('vary') + +http.createServer(function onRequest(req, res) { + // about to user-agent sniff + vary(res, 'User-Agent') + + var ua = req.headers['user-agent'] || '' + var isMobile = /mobi|android|touch|mini/i.test(ua) + + // serve site, depending on isMobile + res.setHeader('Content-Type', 'text/html') + res.end('You are (probably) ' + (isMobile ? '' : 'not ') + 'a mobile user') +}) +``` + +## Testing + +```sh +$ npm test +``` + +## License + +[MIT](LICENSE) + +[npm-image]: https://img.shields.io/npm/v/vary.svg +[npm-url]: https://npmjs.org/package/vary +[node-version-image]: https://img.shields.io/node/v/vary.svg +[node-version-url]: http://nodejs.org/download/ +[travis-image]: https://img.shields.io/travis/jshttp/vary/master.svg +[travis-url]: https://travis-ci.org/jshttp/vary +[coveralls-image]: https://img.shields.io/coveralls/jshttp/vary/master.svg +[coveralls-url]: https://coveralls.io/r/jshttp/vary +[downloads-image]: https://img.shields.io/npm/dm/vary.svg +[downloads-url]: https://npmjs.org/package/vary diff --git a/node_modules/method-override/node_modules/vary/index.js b/node_modules/method-override/node_modules/vary/index.js new file mode 100644 index 0000000..21dbaf1 --- /dev/null +++ b/node_modules/method-override/node_modules/vary/index.js @@ -0,0 +1,124 @@ +/*! + * vary + * Copyright(c) 2014-2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict'; + +/** + * Module exports. + */ + +module.exports = vary; +module.exports.append = append; + +/** + * RegExp to match field-name in RFC 7230 sec 3.2 + * + * field-name = token + * token = 1*tchar + * tchar = "!" / "#" / "$" / "%" / "&" / "'" / "*" + * / "+" / "-" / "." / "^" / "_" / "`" / "|" / "~" + * / DIGIT / ALPHA + * ; any VCHAR, except delimiters + */ + +var fieldNameRegExp = /^[!#$%&'\*\+\-\.\^_`\|~0-9A-Za-z]+$/ + +/** + * Append a field to a vary header. + * + * @param {String} header + * @param {String|Array} field + * @return {String} + * @api public + */ + +function append(header, field) { + if (typeof header !== 'string') { + throw new TypeError('header argument is required'); + } + + if (!field) { + throw new TypeError('field argument is required'); + } + + // get fields array + var fields = !Array.isArray(field) + ? parse(String(field)) + : field; + + // assert on invalid field names + for (var i = 0; i < fields.length; i++) { + if (!fieldNameRegExp.test(fields[i])) { + throw new TypeError('field argument contains an invalid header name'); + } + } + + // existing, unspecified vary + if (header === '*') { + return header; + } + + // enumerate current values + var val = header; + var vals = parse(header.toLowerCase()); + + // unspecified vary + if (fields.indexOf('*') !== -1 || vals.indexOf('*') !== -1) { + return '*'; + } + + for (var i = 0; i < fields.length; i++) { + var fld = fields[i].toLowerCase(); + + // append value (case-preserving) + if (vals.indexOf(fld) === -1) { + vals.push(fld); + val = val + ? val + ', ' + fields[i] + : fields[i]; + } + } + + return val; +} + +/** + * Parse a vary header into an array. + * + * @param {String} header + * @return {Array} + * @api private + */ + +function parse(header) { + return header.trim().split(/ *, */); +} + +/** + * Mark that a request is varied on a header field. + * + * @param {Object} res + * @param {String|Array} field + * @api public + */ + +function vary(res, field) { + if (!res || !res.getHeader || !res.setHeader) { + // quack quack + throw new TypeError('res argument is required'); + } + + // get existing header + var val = res.getHeader('Vary') || '' + var header = Array.isArray(val) + ? val.join(', ') + : String(val); + + // set new header + if ((val = append(header, field))) { + res.setHeader('Vary', val); + } +} diff --git a/node_modules/method-override/node_modules/vary/package.json b/node_modules/method-override/node_modules/vary/package.json new file mode 100644 index 0000000..51646a3 --- /dev/null +++ b/node_modules/method-override/node_modules/vary/package.json @@ -0,0 +1,72 @@ +{ + "name": "vary", + "description": "Manipulate the HTTP Vary header", + "version": "1.1.0", + "author": { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + }, + "license": "MIT", + "keywords": [ + "http", + "res", + "vary" + ], + "repository": { + "type": "git", + "url": "git+https://github.com/jshttp/vary.git" + }, + "devDependencies": { + "istanbul": "0.3.21", + "mocha": "2.3.3", + "supertest": "1.1.0" + }, + "files": [ + "HISTORY.md", + "LICENSE", + "README.md", + "index.js" + ], + "engines": { + "node": ">= 0.8" + }, + "scripts": { + "test": "mocha --reporter spec --bail --check-leaks test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot --check-leaks test/", + "test-travis": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter spec --check-leaks test/" + }, + "gitHead": "13b03e9bf97da9d83bfeac84d84144137d84c257", + "bugs": { + "url": "https://github.com/jshttp/vary/issues" + }, + "homepage": "https://github.com/jshttp/vary", + "_id": "vary@1.1.0", + "_shasum": "e1e5affbbd16ae768dd2674394b9ad3022653140", + "_from": "vary@>=1.1.0 <1.2.0", + "_npmVersion": "1.4.28", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "maintainers": [ + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "jongleberry", + "email": "jonathanrichardong@gmail.com" + }, + { + "name": "fishrock123", + "email": "fishrock123@rocketmail.com" + } + ], + "dist": { + "shasum": "e1e5affbbd16ae768dd2674394b9ad3022653140", + "tarball": "https://registry.npmjs.org/vary/-/vary-1.1.0.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/vary/-/vary-1.1.0.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/method-override/package.json b/node_modules/method-override/package.json new file mode 100644 index 0000000..dba8bf8 --- /dev/null +++ b/node_modules/method-override/package.json @@ -0,0 +1,100 @@ +{ + "name": "method-override", + "description": "Override HTTP verbs", + "version": "2.3.6", + "contributors": [ + { + "name": "Douglas Christopher Wilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "Jonathan Ong", + "email": "me@jongleberry.com", + "url": "http://jongleberry.com" + } + ], + "license": "MIT", + "repository": { + "type": "git", + "url": "git+https://github.com/expressjs/method-override.git" + }, + "dependencies": { + "debug": "~2.2.0", + "methods": "~1.1.2", + "parseurl": "~1.3.1", + "vary": "~1.1.0" + }, + "devDependencies": { + "eslint": "2.10.2", + "eslint-config-standard": "5.3.1", + "eslint-plugin-promise": "1.1.0", + "eslint-plugin-standard": "1.3.2", + "istanbul": "0.4.3", + "mocha": "2.4.5", + "supertest": "1.1.0" + }, + "files": [ + "LICENSE", + "HISTORY.md", + "index.js" + ], + "engines": { + "node": ">= 0.8.0" + }, + "scripts": { + "lint": "eslint **/*.js", + "test": "mocha --check-leaks --reporter spec --bail test/", + "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --check-leaks --reporter dot test/", + "test-travis": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --check-leaks --reporter spec test/" + }, + "gitHead": "9bd45a87a14727f6986fa3f50a7d18f32812c4d7", + "bugs": { + "url": "https://github.com/expressjs/method-override/issues" + }, + "homepage": "https://github.com/expressjs/method-override", + "_id": "method-override@2.3.6", + "_shasum": "209261cc588d45d9d5a022ff20d7d5eb8e92179e", + "_from": "method-override@>=2.1.3 <3.0.0", + "_npmVersion": "1.4.28", + "_npmUser": { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + "maintainers": [ + { + "name": "defunctzombie", + "email": "shtylman@gmail.com" + }, + { + "name": "dougwilson", + "email": "doug@somethingdoug.com" + }, + { + "name": "fishrock123", + "email": "fishrock123@rocketmail.com" + }, + { + "name": "jongleberry", + "email": "jonathanrichardong@gmail.com" + }, + { + "name": "mscdex", + "email": "mscdex@mscdex.net" + }, + { + "name": "tjholowaychuk", + "email": "tj@vision-media.ca" + } + ], + "dist": { + "shasum": "209261cc588d45d9d5a022ff20d7d5eb8e92179e", + "tarball": "https://registry.npmjs.org/method-override/-/method-override-2.3.6.tgz" + }, + "_npmOperationalInternal": { + "host": "packages-12-west.internal.npmjs.com", + "tmp": "tmp/method-override-2.3.6.tgz_1463797613529_0.37302224803715944" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/method-override/-/method-override-2.3.6.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/mongoose/.eslintignore b/node_modules/mongoose/.eslintignore new file mode 100644 index 0000000..235bdcd --- /dev/null +++ b/node_modules/mongoose/.eslintignore @@ -0,0 +1,3 @@ +docs/ +bin/ +test/triage/ diff --git a/node_modules/mongoose/.eslintrc.yml b/node_modules/mongoose/.eslintrc.yml new file mode 100644 index 0000000..013d2ec --- /dev/null +++ b/node_modules/mongoose/.eslintrc.yml @@ -0,0 +1,31 @@ +extends: 'eslint:recommended' + +env: + node: true + mocha: true + +rules: + comma-style: error + consistent-this: + - error + - _this + indent: + - error + - 2 + - SwitchCase: 1 + VariableDeclarator: 2 + keyword-spacing: error + no-console: off + no-multi-spaces: error + no-spaced-func: error + no-trailing-spaces: error + quotes: + - error + - single + semi: error + space-before-blocks: error + space-before-function-paren: + - error + - never + space-infix-ops: error + space-unary-ops: error diff --git a/node_modules/mongoose/.npmignore b/node_modules/mongoose/.npmignore new file mode 100644 index 0000000..377d63f --- /dev/null +++ b/node_modules/mongoose/.npmignore @@ -0,0 +1,16 @@ +lib-cov +**.swp +*.sw* +*.orig +.DS_Store +node_modules/ +benchmarks/ +docs/ +test/ +Makefile +CNAME +index.html +index.jade +bin/ +karma.*.js +format_deps.js diff --git a/node_modules/mongoose/.travis.yml b/node_modules/mongoose/.travis.yml new file mode 100644 index 0000000..b9348aa --- /dev/null +++ b/node_modules/mongoose/.travis.yml @@ -0,0 +1,14 @@ +language: node_js +sudo: false +node_js: + - "6" + - "5" + - "4" + - "0.12" + - "0.10" + - "iojs" +before_script: + - wget http://fastdl.mongodb.org/linux/mongodb-linux-x86_64-2.6.11.tgz + - tar -zxvf mongodb-linux-x86_64-2.6.11.tgz + - mkdir -p ./data/db + - ./mongodb-linux-x86_64-2.6.11/bin/mongod --fork --nopreallocj --dbpath ./data/db --syslog --port 27017 diff --git a/node_modules/mongoose/CONTRIBUTING.md b/node_modules/mongoose/CONTRIBUTING.md new file mode 100644 index 0000000..904aeef --- /dev/null +++ b/node_modules/mongoose/CONTRIBUTING.md @@ -0,0 +1,56 @@ +## Contributing to Mongoose + +If you have a question about Mongoose (not a bug report) please post it to either [StackOverflow](http://stackoverflow.com/questions/tagged/mongoose), or on [Gitter](https://gitter.im/Automattic/mongoose?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge) + +### Reporting bugs + +- Before opening a new issue, look for existing [issues](https://github.com/Automattic/mongoose/issues) to avoid duplication. If the issue does not yet exist, [create one](https://github.com/Automattic/mongoose/issues/new). + - Please post any relevant code samples, preferably a standalone script that + reproduces your issue. Do **not** describe your issue in prose, show your + code. + - If the bug involves an error, please post the stack trace. + - Please post the version of mongoose and mongodb that you're using. + - Please write bug reports in JavaScript (ES5 or ES2015), not coffeescript, typescript, etc. + +### Requesting new features + +- Before opening a new issue, look for existing [issues](https://github.com/learnboost/mongoose/issues) to avoid duplication. If the issue does not yet exist, [create one](https://github.com/learnboost/mongoose/issues/new). +- Please describe a use case for it +- it would be ideal to include test cases as well + +### Fixing bugs / Adding features + +- Before starting to write code, look for existing [issues](https://github.com/learnboost/mongoose/issues). That way you avoid working on something that might not be of interest or that has been addressed already in a different branch. You can create a new issue [here](https://github.com/learnboost/mongoose/issues/new). + - _The source of this project is written in javascript, not coffeescript, therefore your bug reports should be written in javascript_. +- Fork the [repo](https://github.com/Automattic/mongoose) _or_ for small documentation changes, navigate to the source on github and click the [Edit](https://github.com/blog/844-forking-with-the-edit-button) button. +- Follow the general coding style of the rest of the project: + - 2 space tabs + - no trailing whitespace + - inline documentation for new methods, class members, etc. + - 1 space between conditionals, no space before function parenthesis + - `if (..) {` + - `for (..) {` + - `while (..) {` + - `function(err) {` +- Write tests and make sure they pass (tests are in the [test](https://github.com/Automattic/mongoose/tree/master/test) directory). + +### Running the tests +- Open a terminal and navigate to the root of the project +- execute `npm install` to install the necessary dependencies +- start a mongodb instance on port 27017 if one isn't running already. `mongod --dbpath --port 27017` +- execute `npm test` to run the tests (we're using [mocha](http://mochajs.org/)) + - or to execute a single test `npm test -- -g 'some regexp that matches the test description'` + - any mocha flags can be specified with `-- ` + - For example, you can use `npm test -- -R spec` to use the spec reporter, rather than the dot reporter (by default, the test output looks like a bunch of dots) + +### Documentation + +To contribute to the [API documentation](http://mongoosejs.com/docs/api.html) just make your changes to the inline documentation of the appropriate [source code](https://github.com/Automattic/mongoose/tree/master/lib) in the master branch and submit a [pull request](https://help.github.com/articles/using-pull-requests/). You might also use the github [Edit](https://github.com/blog/844-forking-with-the-edit-button) button. + +To contribute to the [guide](http://mongoosejs.com/docs/guide.html) or [quick start](http://mongoosejs.com/docs/index.html) docs, make your changes to the appropriate `.jade` files in the [docs](https://github.com/Automattic/mongoose/tree/master/docs) directory of the master branch and submit a pull request. Again, the [Edit](https://github.com/blog/844-forking-with-the-edit-button) button might work for you here. + +If you'd like to preview your documentation changes, first commit your changes to your local master branch, then execute `make docs` from the project root, which switches to the gh-pages branch, merges from the master branch and builds all the static pages for you. Now execute `node static.js` from the project root which will launch a local webserver where you can browse the documentation site locally. If all looks good, submit a [pull request](https://help.github.com/articles/using-pull-requests/) to the master branch with your changes. + +### Plugins website + +The [plugins](http://plugins.mongoosejs.io/) site is also an [open source project](https://github.com/vkarpov15/mongooseplugins) that you can get involved with. Feel free to fork and improve it as well! diff --git a/node_modules/mongoose/History.md b/node_modules/mongoose/History.md new file mode 100644 index 0000000..2293580 --- /dev/null +++ b/node_modules/mongoose/History.md @@ -0,0 +1,3241 @@ +4.6.3 / 2016-10-05 +================== + * fix(document): ensure single nested docs get initialized correctly when setting nested paths #4578 + * fix: turn off transforms when writing nested docs to db #4574 + * fix(document): don't set single nested subdocs to null when removing parent doc #4566 + * fix(model): ensure versionKey gets set in insertMany #4561 + * fix(schema): handle typeKey in arrays #4548 + * feat(schema): set $implicitlyCreated on schema if created by interpretAsType #4443 + +4.6.2 / 2016-09-30 +================== + * chore: upgrade to async 2.0.1 internally #4579 [billouboq](https://github.com/billouboq) + * fix(types): ensure nested single doc schema errors reach update validators #4557 #4519 + * fix(connection): handle rs names with leading numbers (muri 1.1.1) #4556 + * fix(model): don't throw if method name conflicts with Object.prototype prop #4551 + * docs: fix broken link #4544 [VFedyk](https://github.com/VFedyk) + * fix: allow overwriting model on mongoose singleton #4541 [Nainterceptor](https://github.com/Nainterceptor) + * fix(document): don't use init: true when building doc defaults #4540 + * fix(connection): use replSet option if replset not specified #4535 + * fix(query): cast $not objects #4495 + +4.6.1 / 2016-09-20 +================== + * fix(query): improve handling of $not with $elemMatch #4531 #3719 [timbowhite](https://github.com/timbowhite) + * fix: upgrade mongodb -> 2.2.10 #4517 + * chore: fix webpack build issue #4512 [saiichihashimoto](https://github.com/saiichihashimoto) + * fix(query): emit error on next tick when exec callback errors #4500 + * test: improve test case #4496 [isayme](https://github.com/isayme) + * fix(schema): use same check for array types and top-level types #4493 + * style: fix indentation in docs #4489 [dhurlburtusa](https://github.com/dhurlburtusa) + * fix(schema): expose original object passed to constructor #4486 + * fix(query): handle findOneAndUpdate with array of arrays #4484 #4470 [fedotov](https://github.com/fedotov) + * feat(document): add $ignore to make a path ignored #4480 + * fix(query): properly handle setting single embedded in update #4475 #4466 #4465 + * fix(updateValidators): handle single nested schema subpaths correctly #4479 + * fix(model): throw handy error when method name conflicts with property name #4475 + * fix(schema): handle .set() with array field #4472 + * fix(query): check nested path when avoiding double-validating Mixed #4441 + * fix(schema): handle calling path.trim() with no args correctly #4042 + +4.6.0 / 2016-09-02 +================== + * docs(document): clarify the findById and findByIdAndUpdate examples #4471 [mdcanham](https://github.com/mdcanham) + * docs(schematypes): add details re: options #4452 + * docs(middleware): add docs for insertMany hooks #4451 + * fix(schema): create new array when copying from existing object to preserve change tracking #4449 + * docs: fix typo in index.jade #4448 + * fix(query): allow array for populate options #4446 + * fix(model): create should not cause unhandle reject promise #4439 + * fix: upgrade to mongodb driver 2.2.9 #4363 #4341 #4311 (see [comments here](https://github.com/mongodb/js-bson/commit/aa0b54597a0af28cce3530d2144af708e4b66bf0#commitcomment-18850498) if you use node 0.10) + +4.5.10 / 2016-08-23 +=================== + * docs: fix typo on documents.jade #4444 [Gabri3l](https://github.com/Gabri3l) + * chore: upgrade mocha to 3.0.2 #4437 [TrejGun](https://github.com/TrejGun) + * fix: subdocuments causing error with parent timestamp on update #4434 [dyang108](https://github.com/dyang108) + * fix(query): don't crash if timestamps on and update doesn't have a path #4425 #4424 #4418 + * fix(query): ensure single nested subdoc is hydrated when running update validators #4420 + * fix(query): cast non-$geometry operators for $geoWithin #4419 + * docs: update contributor count #4415 [AdamZaczek](https://github.com/AdamZaczek) + * docs: add more clarification re: the index event #4410 + * fix(document): only skip modifying subdoc path if parent is direct modified #4405 + * fix(schema): throw cast error if provided date invalid #4404 + * feat(error): use util.inspect() so CastError never prints "[object Object]" #4398 + * fix(model): dont error if the discriminator key is unchanged #4387 + * fix(query): don't throw unhandled rejection with bluebird when using cbs #4379 + +4.5.9 / 2016-08-14 +================== + * docs: add mixed schema doc for Object literal #4400 [Kikobeats](https://github.com/Kikobeats) + * fix(query): cast $geoWithin and convert mongoose objects to POJOs before casting #4392 + * fix(schematype): dont cast defaults without parent doc #4390 + * fix(query): disallow passing empty string to findOne() #4378 + * fix(document): set single nested doc isNew correctly #4369 + * fix(types): checks field name correctly with nested arrays and populate #4365 + * fix(drivers): make debug output copy-pastable into mongodb shell #4352 + * fix(services): run update validators on nested paths #4332 + * fix(model): handle typeKey with discriminators #4339 + * fix(query): apply timestamps to child schemas when explicitly specified in update #4049 + * fix(schema): set prefix as nested path with add() #1730 + +4.5.8 / 2016-08-01 +================== + * fix(model): make changing the discriminator key cause a cast error #4374 + * fix(query): pass projection fields to cursor #4371 #4342 [Corei13](https://github.com/Corei13) + * fix(document): support multiple paths for isModified #4370 [adambuczynski](https://github.com/adambuczynski) + * fix(querycursor): always cast fields before returning cursor #4355 + * fix(query): support projection as alias for fields in findOneAndUpdate #4315 + * fix(schema): treat index false + unique false as no index #4304 + * fix(types): dont mark single nested subpath as modified if whole doc already modified #4224 + +4.5.7 / 2016-07-25 +================== + * fix(document): ensure no unhandled rejections if callback specified for save #4364 + +4.5.6 / 2016-07-23 +================== + * fix(schema): don't overwrite createdAt if it isn't selected #4351 [tusbar](https://github.com/tusbar) + * docs(api): fix link to populate() and add a new one from depopulate() #4345 [Delapouite](https://github.com/Delapouite) + * fix(types): ownerDocument() works properly with single nested docs #4344 [vichle](https://github.com/vichle) + * fix(populate): dont use findOne when justOne option set #4329 + * fix(document): dont trigger .then() deprecated warning when calling doc.remove() #4291 + * docs(connection): add promiseLibrary option #4280 + * fix(plugins): apply global plugins to subschemas #4271 + * fix(model): ensure `ensureIndex()` never calls back in the same tick #4246 + * docs(schema): improve post hook docs on schema #4238 + +4.5.5 / 2016-07-18 +================== + * fix(document): handle setting root to empty obj if minimize false #4337 + * fix: downgrade to mongodb 2.1.18 #4335 #4334 #4328 #4323 + * perf(types): remove defineProperty usage in documentarray #4333 + * fix(query): correctly pass model in .toConstructor() #4318 + * fix(services): avoid double-validating mixed types with update validators #4305 + * docs(middleware): add docs describing error handling middleware #4229 + * fix(types): throw correct error when invalidating doc array #3602 + +4.5.4 / 2016-07-11 +================== + * fix(types): fix removing embedded documents #4309 [RoCat](https://github.com/RoCat) + * docs: various docs improvements #4302 #4294 [simonxca](https://github.com/simonxca) + * fix: upgrade mongodb -> 2.1.21 #4295 #4202 [RoCat](https://github.com/RoCat) + * fix(populate): convert single result to array for virtual populate because of lean #4288 + * fix(populate): handle empty results for populate virtuals properly #4285 #4284 + * fix(query): dont cast $inc to number if type is long #4283 + * fix(types): allow setting single nested doc to null #4281 + * fix(populate): handle deeply nested virtual populate #4278 + * fix(document): allow setting empty obj if strict mode is false #4274 + * fix(aggregate): allow passing obj to .unwind() #4239 + * docs(document): add return statements to transform examples #1963 + +4.5.3 / 2016-06-30 +================== + * fix(query): pass correct options to QueryCursor #4277 #4266 + * fix(querycursor): handle lean option correctly #4276 [gchudnov](https://github.com/gchudnov) + * fix(document): fix error handling when no error occurred #4275 + * fix(error): use strict mode for version error #4272 + * docs(populate): fix crashing compilation for populate.jade #4267 + * fix(populate): support `justOne` option for populate virtuals #4263 + * fix(populate): ensure model param gets used for populate virtuals #4261 #4243 + * fix(querycursor): add ability to properly close the cursor #4258 + * docs(model): correct link to Document #4250 + * docs(populate): correct path for refPath populate #4240 + * fix(document): support validator.isEmail as validator #4064 + +4.5.2 / 2016-06-24 +================== + * fix(connection): add checks for collection presence for `onOpen` and `onClose` #4259 [nodkz](https://github.com/nodkz) + * fix(cast): allow strings for $type operator #4256 + * fix(querycursor): support lean() #4255 [pyramation](https://github.com/pyramation) + * fix(aggregate): allow setting noCursorTimeout option #4241 + * fix(document): handle undefined for Array.pull #4222 [Sebmaster](https://github.com/Sebmaster) + * fix(connection): ensure promise.catch() catches initial connection error #4135 + * fix(document): show additional context for VersionError #2633 + +4.5.1 / 2016-06-18 +================== + * fix(model): ensure wrapped insertMany() returns a promise #4237 + * fix(populate): dont overwrite populateVirtuals when populating multiple paths #4234 + * docs(model): clarify relationship between create() and save() #4233 + * fix(types): handle option param in subdoc remove() #4231 [tdebarochez](https://github.com/tdebarochez) + * fix(document): dedupe modified paths #4226 #4223 [adambuczynski](https://github.com/adambuczynski) + * fix(model): don't modify user-provided options object #4221 + * fix(document): handle setting nested path to empty object #4218 #4182 + * fix(document): clean subpaths when removing single nested #4216 + * fix(document): don't force transform on subdocs with inspect #4213 + * fix(error): allow setting .messages object #4207 + +4.5.0 / 2016-06-13 +================== + * feat(query): added Query.prototype.catch() #4215 #4173 [adambuczynski](https://github.com/adambuczynski) + * feat(query): add Query.prototype.cursor() as a .stream() alternative #4117 #3637 #1907 + * feat(document): add markUnmodified() function #4092 [vincentcr](https://github.com/vincentcr) + * feat(aggregate): convert aggregate object to a thenable #3995 #3946 [megagon](https://github.com/megagon) + * perf(types): remove defineProperties call for array (**Note:** Because of this, a mongoose array will no longer `assert.deepEqual()` a plain old JS array) #3886 + * feat(model): add hooks for insertMany() #3846 + * feat(schema): add support for custom query methods #3740 #2372 + * feat(drivers): emit error on 'serverClosed' because that means that reconnect failed #3615 + * feat(model): emit error event when callback throws exception #3499 + * feat(model): inherit options from discriminator base schema #3414 #1818 + * feat(populate): expose mongoose-populate-virtuals inspired populate API #2562 + * feat(document): trigger remove hooks on subdocs when removing parent #2348 + * feat(schema): add support for express-style error handling middleware #2284 + * fix(model): disallow setting discriminator key #2041 + * feat(schema): add support for nested arrays #1361 + +4.4.20 / 2016-06-05 +=================== + * docs: clarify command buffering when using driver directly #4195 + * fix(promise): correct broken mpromise .catch() #4189 + * fix(document): clean modified subpaths when set path to empty obj #4182 + * fix(query): support minDistance with query casting and `.near()` #4179 + * fix(model): remove unnecessary .save() promise #4177 + * fix(schema): cast all valid ObjectId strings to object ids #3365 + * docs: remove unclear "unsafe" term in query docs #3282 + +4.4.19 / 2016-05-21 +=================== + * fix(model): handle insertMany if timestamps not set #4171 + +4.4.18 / 2016-05-21 +=================== + * docs: add missing period #4170 [gitname](https://github.com/gitname) + * docs: change build badge to svg #4158 [a0viedo](https://github.com/a0viedo) + * fix(model): update timestamps when setting `createdAt` #4155 + * fix(utils): make sure to require in document properly #4152 + * fix(model): throw overwrite error when discriminator name conflicts #4148 + +4.4.17 / 2016-05-13 +=================== + * docs: remove repetition in QueryStream docs #4147 [hugoabonizio](https://github.com/hugoabonizio) + * fix(document): dont double-validate doc array elements #4145 + * fix(document): call required function with correct scope #4142 [JedWatson](https://github.com/JedWatson) + +4.4.16 / 2016-05-09 +=================== + * refactor(document): use function reference #4133 [dciccale](https://github.com/dciccale) + * docs(querystream): clarify `destroy()` and close event #4126 [AnthonyCC](https://github.com/AnthonyCC) + * test: make before hook fail fast if it can't connect #4121 + * docs: add description of CastError constructor params #4120 + * fix(schematype): ensure single embedded defaults have $parent #4115 + * fix(document): mark nested paths for validation #4111 + * fix(schema): make sure element is always a subdoc in doc array validation #3816 + +4.4.15 / 2016-05-06 +=================== + * fix(schema): support overwriting array default #4109 + * fix(populate): assign values when resolving each populate #4104 + * fix(aggregate): dont send async option to server #4101 + * fix(model): ensure isNew set to false after insertMany #4099 + * fix(connection): emit on error if listeners and no callback #4098 + * fix(document): treat required fn that returns false as required: false #4094 + +4.4.14 / 2016-04-27 +=================== + * fix: upgrade mongodb -> 2.1.18 #4102 + * feat(connection): allow setting mongos as a uri query param #4093 #4035 [burtonjc](https://github.com/burtonjc) + * fix(populate): make sure to use correct assignment order for each model #4073 + * fix(schema): add complete set of geospatial operators for single embedded subdocs #4014 + +3.8.40 / 2016-04-24 +=================== + * upgraded; mquery -> 1.10.0 #3989 + +4.4.13 / 2016-04-21 +=================== + * docs: add docs favicons #4082 [robertjustjones](https://github.com/robertjustjones) + * docs(model): correct Model.remove() return value #4075 [Jokero](https://github.com/Jokero) + * fix(query): add $geoWithin query casting for single embedded docs #4044 + * fix(schema): handle setting trim option to falsy #4042 + * fix(query): handle setDefaultsOnInsert with empty update #3835 + +4.4.12 / 2016-04-08 +=================== + * docs(query): document context option for update and findOneAndUpdate #4055 + * docs(query): correct link to $geoWithin docs #4050 + * fix(project): upgrade to mongodb driver 2.1.16 #4048 [schmalliso](https://github.com/schmalliso) + * docs(validation): fix validation docs #4028 + * fix(types): improve .id() check for document arrays #4011 + * fix(query): remove premature return when using $rename #3171 + * docs(connection): clarify relationship between models and connections #2157 + +4.4.11 / 2016-04-03 +=================== + * fix: upgrade to mongodb driver 2.1.14 #4036 #4030 #3945 + * fix(connection): allow connecting with { mongos: true } to handle query params #4032 [burtonjc](https://github.com/burtonjc) + * docs(connection): add autoIndex example #4026 [tilleps](https://github.com/tilleps) + * fix(query): handle passRawResult option when zero results #4023 + * fix(populate): clone options before modifying #4022 + * docs: add missing whitespace #4019 [chenxsan](https://github.com/chenxsan) + * chore: upgrade to ESLint 2.4.0 #4015 [ChristianMurphy](https://github.com/ChristianMurphy) + * fix(types): single nested subdocs get ids by default #4008 + * chore(project): add dependency status badge #4007 [Maheshkumar-Kakade](http://github.com/Maheshkumar-Kakade) + * fix: make sure timestamps don't trigger unnecessary updates #4005 #3991 [tommarien](https://github.com/tommarien) + * fix(document): inspect inherits schema options #4001 + * fix(populate): don't mark populated path as modified if setting to object w/ same id #3992 + * fix(document): support kind argument to invalidate #3965 + +4.4.10 / 2016-03-24 +=================== + * fix(document): copy isNew when copying a document #3982 + * fix(document): don't override defaults with undefined keys #3981 + * fix(populate): merge multiple deep populate options for the same path #3974 + +4.4.9 / 2016-03-22 +================== + * fix: upgrade mongodb -> 2.1.10 re https://jira.mongodb.org/browse/NODE-679 #4010 + * docs: add syntax highlighting for acquit examples #3975 + +4.4.8 / 2016-03-18 +================== + * docs(aggregate): clarify promises #3990 [megagon](https://github.com/megagon) + * fix: upgrade mquery -> 1.10 #3988 [matskiv](https://github.com/matskiv) + * feat(connection): 'all' event for repl sets #3986 [xizhibei](https://github.com/xizhibei) + * docs(types): clarify Array.pull #3985 [seriousManual](https://github.com/seriousManual) + * feat(query): support array syntax for .sort() via mquery 1.9 #3980 + * fix(populate): support > 3 level nested populate #3973 + * fix: MongooseThenable exposes connection correctly #3972 + * docs(connection): add note about reconnectTries and reconnectInterval #3969 + * feat(document): invalidate returns the new validationError #3964 + * fix(query): .eq() as shorthand for .equals #3953 [Fonger](https://github.com/Fonger) + * docs(connection): clarify connection string vs passed options #3941 + * docs(query): select option for findOneAndUpdate #3933 + * fix(error): ValidationError.properties no longer enumerable #3925 + * docs(validation): clarify how required validators work with nested schemas #3915 + * fix: upgrade mongodb driver -> 2.1.8 to make partial index errors more sane #3864 + +4.4.7 / 2016-03-11 +================== + * fix(query): stop infinite recursion caused by merging a mongoose buffer #3961 + * fix(populate): handle deep populate array -> array #3954 + * fix(schema): allow setting timestamps with .set() #3952 #3951 #3907 [Fonger](https://github.com/Fonger) + * fix: MongooseThenable doesn't overwrite constructors #3940 + * fix(schema): don't cast boolean to date #3935 + * fix(drivers): support sslValidate in connection string #3929 + * fix(types): correct markModified() for single nested subdocs #3910 + * fix(drivers): catch and report any errors that occur in driver methods #3906 + * fix(populate): get subpopulate model correctly when array under nested #3904 + * fix(document): allow fields named 'pre' and 'post' #3902 + * docs(query): clarify runValidators and setDefaultsOnInsert options #3892 + * docs(validation): show how to use custom required messages in schema #2616 + +4.4.6 / 2016-03-02 +================== + * fix: upgrade mongodb driver to 2.1.7 #3938 + * docs: fix plugins link #3917 #3909 [fbertone](https://github.com/fbertone) + * fix(query): sort+select with count works #3914 + * fix(query): improve mergeUpdate's ability to handle nested docs #3890 + +4.4.5 / 2016-02-24 +================== + * fix(query): ability to select a length field (upgrade to mquery 1.7.0) #3903 + * fix: include nested CastError as reason for array CastError #3897 [kotarou3](https://github.com/kotarou3) + * fix(schema): check for doc existence before taking fields #3889 + * feat(schema): useNestedStrict option to take nested strict mode for update #3883 + * docs(validation): clarify relationship between required and checkRequired #3822 + * docs(populate): dynamic reference docs #3809 + * docs: expand dropdown when clicking on file name #3807 + * docs: plugins.mongoosejs.io is up #3127 + * fix(schema): ability to add a virtual with same name as removed path #2398 + +4.4.4 / 2016-02-17 +================== + * fix(schema): handle field selection when casting single nested subdocs #3880 + * fix(populate): populating using base model with multiple child models in result #3878 + * fix: ability to properly use return value of `mongoose.connect()` #3874 + * fix(populate): dont hydrate populated subdoc if lean option set #3873 + * fix(connection): dont re-auth if already connected with useDb #3871 + * docs: cover how to set underlying driver's promise lib #3869 + * fix(document): handle conflicting names in validation errors with subdocs #3867 + * fix(populate): set undefined instead of null consistently when populate couldn't find results #3859 + * docs: link to `execPopulate()` in `doc.populate()` docs #3836 + * docs(plugin): link to the `mongoose.plugin()` function #3732 + +4.4.3 / 2016-02-09 +================== + * fix: upgrade to mongodb 2.1.6 to remove kerberos log output #3861 #3860 [cartuchogl](https://github.com/cartuchogl) + * fix: require('mongoose') is no longer a pseudo-promise #3856 + * fix(query): update casting for single nested docs #3820 + * fix(populate): deep populating multiple paths with same options #3808 + * docs(middleware): clarify save/validate hook order #1149 + +4.4.2 / 2016-02-05 +================== + * fix(aggregate): handle calling .cursor() with no options #3855 + * fix: upgrade mongodb driver to 2.1.5 for GridFS memory leak fix #3854 + * docs: fix schematype.html conflict #3853 #3850 #3843 + * fix(model): bluebird unhandled rejection with ensureIndexes() on init #3837 + * docs: autoIndex option for createConnection #3805 + +4.4.1 / 2016-02-03 +================== + * fix: linting broke some cases where we use `== null` as shorthand #3852 + * docs: fix up schematype.html conflict #3848 #3843 [mynameiscoffey](https://github.com/mynameiscoffey) + * fix: backwards breaking change with `.connect()` return value #3847 + * docs: downgrade dox and highlight.js to fix docs build #3845 + * docs: clean up typo #3842 [Flash-](https://github.com/Flash-) + * fix(document): storeShard handles undefined values #3841 + * chore: more linting #3838 [TrejGun](https://github.com/TrejGun) + * fix(schema): handle `text: true` as a way to declare a text index #3824 + +4.4.0 / 2016-02-02 +================== + * docs: fix expireAfterSeconds index option name #3831 [Flash-](https://github.com/Flash-) + * chore: run lint after test #3829 [ChristianMurphy](https://github.com/ChristianMurphy) + * chore: use power-assert instead of assert #3828 [TrejGun](https://github.com/TrejGun) + * chore: stricter lint #3827 [TrejGun](https://github.com/TrejGun) + * feat(types): casting moment to date #3813 [TrejGun](https://github.com/TrejGun) + * chore: comma-last lint for test folder #3810 [ChristianMurphy](https://github.com/ChristianMurphy) + * fix: upgrade async mpath, mpromise, muri, and sliced #3801 [TrejGun](https://github.com/TrejGun) + * fix(query): geo queries now return proper ES2015 promises #3800 [TrejGun](https://github.com/TrejGun) + * perf(types): use `Object.defineProperties()` for array #3799 [TrejGun](https://github.com/TrejGun) + * fix(model): mapReduce, ensureIndexes, remove, and save properly return ES2015 promises #3795 #3628 #3595 [TrejGun](https://github.com/TrejGun) + * docs: fixed dates in History.md #3791 [Jokero](https://github.com/Jokero) + * feat: connect, open, openSet, and disconnect return ES2015 promises #3790 #3622 [TrejGun](https://github.com/TrejGun) + * feat: custom type for int32 via mongoose-int32 npm package #3652 #3102 + * feat: basic custom schema type API #995 + * feat(model): `insertMany()` for more performant bulk inserts #723 + +4.3.7 / 2016-01-23 +================== + * docs: grammar fix in timestamps docs #3786 [zclancy](https://github.com/zclancy) + * fix(document): setting nested populated docs #3783 [slamuu](https://github.com/slamuu) + * fix(document): don't call post save hooks twice for pushed docs #3780 + * fix(model): handle `_id=0` correctly #3776 + * docs(middleware): async post hooks #3770 + * docs: remove confusing sentence #3765 [marcusmellis89](https://github.com/marcusmellis89) + +3.8.39 / 2016-01-15 +=================== + * fixed; casting a number to a buffer #3764 + * fixed; enumerating virtual property with nested objects #3743 [kusold](https://github.com/kusold) + +4.3.6 / 2016-01-15 +================== + * fix(types): casting a number to a buffer #3764 + * fix: add "listener" to reserved keywords #3759 + * chore: upgrade uglify #3757 [ChristianMurphy](https://github.com/ChristianMurphy) + * fix: broken execPopulate() in 4.3.5 #3755 #3753 + * fix: ability to remove() a single embedded doc #3754 + * style: comma-last in test folder #3751 [ChristianMurphy](https://github.com/ChristianMurphy) + * docs: clarify versionKey option #3747 + * fix: improve colorization for arrays #3744 [TrejGun](https://github.com/TrejGun) + * fix: webpack build #3713 + +4.3.5 / 2016-01-09 +================== + * fix(query): throw when 4th parameter to update not a function #3741 [kasselTrankos](https://github.com/kasselTrankos) + * fix(document): separate error type for setting an object to a primitive #3735 + * fix(populate): Model.populate returns ES6 promise #3734 + * fix(drivers): re-register event handlers after manual reconnect #3729 + * docs: broken links #3727 + * fix(validation): update validators run array validation #3724 + * docs: clarify the need to use markModified with in-place date ops #3722 + * fix(document): mark correct path as populated when manually populating array #3721 + * fix(aggregate): support for array pipeline argument to append #3718 [dbkup](https://github.com/dbkup) + * docs: clarify `.connect()` callback #3705 + * fix(schema): properly validate nested single nested docs #3702 + * fix(types): handle setting documentarray of wrong type #3701 + * docs: broken links #3700 + * fix(drivers): debug output properly displays '0' #3689 + +3.8.38 / 2016-01-07 +=================== + * fixed; aggregate.append an array #3730 [dbkup](https://github.com/dbkup) + +4.3.4 / 2015-12-23 +================== + * fix: upgrade mongodb driver to 2.1.2 for repl set error #3712 [sansmischevia](https://github.com/sansmischevia) + * docs: validation docs typo #3709 [ivanmaeder](https://github.com/ivanmaeder) + * style: remove unused variables #3708 [ChristianMurphy](https://github.com/ChristianMurphy) + * fix(schema): duck-typing for schemas #3703 [mgcrea](https://github.com/mgcrea) + * docs: connection sample code issue #3697 + * fix(schema): duck-typing for schemas #3693 [mgcrea](https://github.com/mgcrea) + * docs: clarify id schema option #3638 + +4.3.3 / 2015-12-18 +================== + * fix(connection): properly support 'replSet' as well as 'replset' #3688 [taxilian](https://github.com/taxilian) + * fix(document): single nested doc pre hooks called before nested doc array #3687 [aliatsis](https://github.com/aliatsis) + +4.3.2 / 2015-12-17 +================== + * fix(document): .set() into single nested schemas #3686 + * fix(connection): support 'replSet' as well as 'replset' option #3685 + * fix(document): bluebird unhandled rejection when validating doc arrays #3681 + * fix(document): hooks for doc arrays in single nested schemas #3680 + * fix(document): post hooks for single nested schemas #3679 + * fix: remove unused npm module #3674 [sybarite](https://github.com/sybarite) + * fix(model): don't swallow exceptions in nested doc save callback #3671 + * docs: update keepAlive info #3667 [ChrisZieba](https://github.com/ChrisZieba) + * fix(document): strict 'throw' throws a specific mongoose error #3662 + * fix: flakey test #3332 + * fix(query): more robust check for RegExp #2969 + +4.3.1 / 2015-12-11 +================== + * feat(aggregate): `.sample()` helper #3665 + * fix(query): bitwise query operators with buffers #3663 + * docs(migration): clarify `new` option and findByIdAndUpdate #3661 + +4.3.0 / 2015-12-09 +================== + * feat(query): support for mongodb 3.2 bitwise query operators #3660 + * style: use comma-last style consistently #3657 [ChristianMurphy](https://github.com/ChristianMurphy) + * feat: upgrade mongodb driver to 2.1.0 for full MongoDB 3.2 support #3656 + * feat(aggregate): `.lookup()` helper #3532 + +4.2.10 / 2015-12-08 +=================== + * fixed; upgraded marked #3653 [ChristianMurphy](https://github.com/ChristianMurphy) + * docs; cross-db populate #3648 + * docs; update mocha URL #3646 [ojhaujjwal](https://github.com/ojhaujjwal) + * fixed; call close callback asynchronously #3645 + * docs; virtuals.html issue #3644 [Psarna94](https://github.com/Psarna94) + * fixed; single embedded doc casting on init #3642 + * docs; validation docs improvements #3640 + +4.2.9 / 2015-12-02 +================== + * docs; defaults docs #3625 + * fix; nested numeric keys causing an embedded document crash #3623 + * fix; apply path getters before virtual getters #3618 + * fix; casting for arrays in single nested schemas #3616 + +4.2.8 / 2015-11-25 +================== + * docs; clean up README links #3612 [ReadmeCritic](https://github.com/ReadmeCritic) + * fix; ESLint improvements #3605 [ChristianMurphy](https://github.com/ChristianMurphy) + * fix; assigning single nested subdocs #3601 + * docs; describe custom logging functions in `mongoose.set()` docs #3557 + +4.2.7 / 2015-11-20 +================== + * fixed; readPreference connection string option #3600 + * fixed; pulling from manually populated arrays #3598 #3579 + * docs; FAQ about OverwriteModelError #3597 [stcruy](https://github.com/stcruy) + * fixed; setting single embedded schemas to null #3596 + * fixed; indexes for single embedded schemas #3594 + * docs; clarify projection for `findOne()` #3593 [gunar](https://github.com/gunar) + * fixed; .ownerDocument() method on single embedded schemas #3589 + * fixed; properly throw casterror for query on single embedded schema #3580 + * upgraded; mongodb driver -> 2.0.49 for reconnect issue fix #3481 + +4.2.6 / 2015-11-16 +================== + * fixed; ability to manually populate an array #3575 + * docs; clarify `isAsync` parameter to hooks #3573 + * fixed; use captureStackTrace if possible instead #3571 + * fixed; crash with buffer and update validators #3565 [johnpeb](https://github.com/johnpeb) + * fixed; update casting with operators overwrite: true #3564 + * fixed; validation with single embedded docs #3562 + * fixed; inline docs inherit parents $type key #3560 + * docs; bad grammar in populate docs #3559 [amaurymedeiros](https://github.com/amaurymedeiros) + * fixed; properly handle populate option for find() #2321 + +3.8.37 / 2015-11-16 +=================== + * fixed; use retainKeyOrder for cloning update op #3572 + +4.2.5 / 2015-11-09 +================== + * fixed; handle setting fields in pre update hooks with exec #3549 + * upgraded; ESLint #3547 [ChristianMurphy](https://github.com/ChristianMurphy) + * fixed; bluebird unhandled rejections with cast errors and .exec #3543 + * fixed; min/max validators handling undefined #3539 + * fixed; standalone mongos connections #3537 + * fixed; call `.toObject()` when setting a single nested doc #3535 + * fixed; single nested docs now have methods #3534 + * fixed; single nested docs with .create() #3533 #3521 [tusbar](https://github.com/tusbar) + * docs; deep populate docs #3528 + * fixed; deep populate schema ref handling #3507 + * upgraded; mongodb driver -> 2.0.48 for sort overflow issue #3493 + * docs; clarify default ids for discriminators #3482 + * fixed; properly support .update(doc) #3221 + +4.2.4 / 2015-11-02 +================== + * fixed; upgraded `ms` package for security vulnerability #3524 [fhemberger](https://github.com/fhemberger) + * fixed; ESlint rules #3517 [ChristianMurphy](https://github.com/ChristianMurphy) + * docs; typo in aggregation docs #3513 [rafakato](https://github.com/rafakato) + * fixed; add `dontThrowCastError` option to .update() for promises #3512 + * fixed; don't double-cast buffers in node 4.x #3510 #3496 + * fixed; population with single embedded schemas #3501 + * fixed; pre('set') hooks work properly #3479 + * docs; promises guide #3441 + +4.2.3 / 2015-10-26 +================== + * docs; remove unreferenced function in middleware.jade #3506 + * fixed; handling auth with no username/password #3500 #3498 #3484 [mleanos](https://github.com/mleanos) + * fixed; more ESlint rules #3491 [ChristianMurphy](https://github.com/ChristianMurphy) + * fixed; swallowing exceptions in save callback #3478 + * docs; fixed broken links in subdocs guide #3477 + * fixed; casting booleans to numbers #3475 + * fixed; report CastError for subdoc arrays in findOneAndUpdate #3468 + * fixed; geoNear returns ES6 promise #3458 + +4.2.2 / 2015-10-22 +================== + * fixed; go back to old pluralization code #3490 + +4.2.1 / 2015-10-22 +================== + * fixed; pluralization issues #3492 [ChristianMurphy](https://github.com/ChristianMurphy) + +4.2.0 / 2015-10-22 +================== + * added; support for skipVersioning for document arrays #3467 [chazmo03](https://github.com/chazmo03) + * added; ability to customize schema 'type' key #3459 #3245 + * fixed; writeConcern for index builds #3455 + * added; emit event when individual index build starts #3440 [objectiveSee](https://github.com/objectiveSee) + * added; 'context' option for update validators #3430 + * refactor; pluralization now in separate pluralize-mongoose npm module #3415 [ChristianMurphy](https://github.com/ChristianMurphy) + * added; customizable error validation messages #3406 [geronime](https://github.com/geronime) + * added; support for passing 'minimize' option to update #3381 + * added; ability to customize debug logging format #3261 + * added; baseModelName property for discriminator models #3202 + * added; 'emitIndexErrors' option #3174 + * added; 'async' option for aggregation cursor to support buffering #3160 + * added; ability to skip validation for individual save() calls #2981 + * added; single embedded schema support #2689 #585 + * added; depopulate function #2509 + +4.1.12 / 2015-10-19 +=================== + * docs; use readPreference instead of slaveOk for Query.setOptions docs #3471 [buunguyen](https://github.com/buunguyen) + * fixed; more helpful error when regexp contains null bytes #3456 + * fixed; x509 auth issue #3454 [NoxHarmonium](https://github.com/NoxHarmonium) + +3.8.36 / 2015-10-18 +=================== + * fixed; Make array props non-enumerable #3461 [boblauer](https://github.com/boblauer) + +4.1.11 / 2015-10-12 +=================== + * fixed; update timestamps for update() if they're enabled #3450 [isayme](https://github.com/isayme) + * fixed; unit test error on node 0.10 #3449 [isayme](https://github.com/isayme) + * docs; timestamp option docs #3448 [isayme](https://github.com/isayme) + * docs; fix unexpected indent #3443 [isayme](https://github.com/isayme) + * fixed; use ES6 promises for Model.prototype.remove() #3442 + * fixed; don't use unused 'safe' option for index builds #3439 + * fixed; elemMatch casting bug #3437 #3435 [DefinitelyCarter](https://github.com/DefinitelyCarter) + * docs; schema.index docs #3434 + * fixed; exceptions in save() callback getting swallowed on mongodb 2.4 #3371 + +4.1.10 / 2015-10-05 +=================== + * docs; improve virtuals docs to explain virtuals schema option #3433 [zoyaH](https://github.com/zoyaH) + * docs; MongoDB server version compatibility guide #3427 + * docs; clarify that findById and findByIdAndUpdate fire hooks #3422 + * docs; clean up Model.save() docs #3420 + * fixed; properly handle projection with just id #3407 #3412 + * fixed; infinite loop when database document is corrupted #3405 + * docs; clarify remove middleware #3388 + +4.1.9 / 2015-09-28 +================== + * docs; minlength and maxlength string validation docs #3368 #3413 [cosmosgenius](https://github.com/cosmosgenius) + * fixed; linting for infix operators #3397 [ChristianMurphy](https://github.com/ChristianMurphy) + * fixed; proper casting for $all #3394 + * fixed; unhandled rejection warnings with .create() #3391 + * docs; clarify update validators on paths that aren't explicitly set #3386 + * docs; custom validator examples #2778 + +4.1.8 / 2015-09-21 +================== + * docs; fixed typo in example #3390 [kmctown](https://github.com/kmctown) + * fixed; error in toObject() #3387 [guumaster](https://github.com/guumaster) + * fixed; handling for casting null dates #3383 [alexmingoia](https://github.com/alexmingoia) + * fixed; passing composite ids to `findByIdAndUpdate` #3380 + * fixed; linting #3376 #3375 [ChristianMurphy](https://github.com/ChristianMurphy) + * fixed; added NodeJS v4 to Travis #3374 [ChristianMurphy](https://github.com/ChristianMurphy) + * fixed; casting $elemMatch inside of $not #3373 [gaguirre](https://github.com/gaguirre) + * fixed; handle case where $slice is 0 #3369 + * fixed; avoid running getters if path is populated #3357 + * fixed; cast documents to objects when setting to a nested path #3346 + +4.1.7 / 2015-09-14 +================== + * docs; typos in SchemaType documentation #3367 [jasson15](https://github.com/jasson15) + * fixed; MONGOOSE_DRIVER_PATH env variable again #3360 + * docs; added validateSync docs #3353 + * fixed; set findOne op synchronously in query #3344 + * fixed; handling for `.pull()` on a documentarray without an id #3341 + * fixed; use natural order for cloning update conditions #3338 + * fixed; issue with strict mode casting for mixed type updates #3337 + +4.1.6 / 2015-09-08 +================== + * fixed; MONGOOSE_DRIVER_PATH env variable #3345 [g13013](https://github.com/g13013) + * docs; global autoIndex option #3335 [albertorestifo](https://github.com/albertorestifo) + * docs; model documentation typos #3330 + * fixed; report reason for CastError #3320 + * fixed; .populate() no longer returns true after re-assigning #3308 + * fixed; discriminators with aggregation geoNear #3304 + * docs; discriminator docs #2743 + +4.1.5 / 2015-09-01 +================== + * fixed; document.remove() removing all docs #3326 #3325 + * fixed; connect() checks for rs_name in options #3299 + * docs; examples for schema.set() #3288 + * fixed; checkKeys issue with bluebird #3286 [gregthegeek](https://github.com/gregthegeek) + +4.1.4 / 2015-08-31 +================== + * fixed; ability to set strict: false for update #3305 + * fixed; .create() properly uses ES6 promises #3297 + * fixed; pre hooks on nested subdocs #3291 #3284 [aliatsis](https://github.com/aliatsis) + * docs; remove unclear text in .remove() docs #3282 + * fixed; pre hooks called twice for 3rd-level nested doc #3281 + * fixed; nested transforms #3279 + * upgraded; mquery -> 1.6.3 #3278 #3272 + * fixed; don't swallow callback errors by default #3273 #3222 + * fixed; properly get nested paths from nested schemas #3265 + * fixed; remove() with id undefined deleting all docs #3260 [thanpolas](https://github.com/thanpolas) + * fixed; handling for non-numeric projections #3256 + * fixed; findById with id undefined returning first doc #3255 + * fixed; use retainKeyOrder for update #3215 + * added; passRawResult option to findOneAndUpdate for backwards compat #3173 + +4.1.3 / 2015-08-16 +================== + * fixed; getUpdate() in pre update hooks #3520 [gregthegeek](https://github.com/gregthegeek) + * fixed; handleArray() ensures arg is an array #3238 [jloveridge](https://github.com/jloveridge) + * fixed; refresh required path cache when recreating docs #3199 + * fixed; $ operator on unwind aggregation helper #3197 + * fixed; findOneAndUpdate() properly returns raw result as third arg to callback #3173 + * fixed; querystream with dynamic refs #3108 + +3.8.35 / 2015-08-14 +=================== + * fixed; handling for minimize on nested objects #2930 + * fixed; don't crash when schema.path.options undefined #1824 + +4.1.2 / 2015-08-10 +================== + * fixed; better handling for Jade templates #3241 [kbadk](https://github.com/kbadk) + * added; ESlint trailing spaces #3234 [ChristianMurphy](https://github.com/ChristianMurphy) + * added; ESlint #3191 [ChristianMurphy](https://github.com/ChristianMurphy) + * fixed; properly emit event on disconnect #3183 + * fixed; copy options properly using Query.toConstructor() #3176 + * fixed; setMaxListeners() issue in browser build #3170 + * fixed; node driver -> 2.0.40 to not store undefined keys as null #3169 + * fixed; update validators handle positional operator #3167 + * fixed; handle $all + $elemMatch query casting #3163 + * fixed; post save hooks don't swallow extra args #3155 + * docs; spelling mistake in index.jade #3154 + * fixed; don't crash when toObject() has no fields #3130 + * fixed; apply toObject() recursively for find and update queries #3086 [naoina](https://github.com/naoina) + +4.1.1 / 2015-08-03 +================== + * fixed; aggregate exec() crash with no callback #3212 #3198 [jpgarcia](https://github.com/jpgarcia) + * fixed; pre init hooks now properly synchronous #3207 [burtonjc](https://github.com/burtonjc) + * fixed; updateValidators doesn't flatten dates #3206 #3194 [victorkohl](https://github.com/victorkohl) + * fixed; default fields don't make document dirty between saves #3205 [burtonjc](https://github.com/burtonjc) + * fixed; save passes 0 as numAffected rather than undefined when no change #3195 [burtonjc](https://github.com/burtonjc) + * fixed; better handling for positional operator in update #3185 + * fixed; use Travis containers #3181 [ChristianMurphy](https://github.com/ChristianMurphy) + * fixed; leaked variable #3180 [ChristianMurphy](https://github.com/ChristianMurphy) + +4.1.0 / 2015-07-24 +================== + * added; `schema.queue()` now public #3193 + * added; raw result as third parameter to findOneAndX callback #3173 + * added; ability to run validateSync() on only certain fields #3153 + * added; subPopulate #3103 [timbur](https://github.com/timbur) + * added; $isDefault function on documents #3077 + * added; additional properties for built-in validator messages #3063 [KLicheR](https://github.com/KLicheR) + * added; getQuery() and getUpdate() functions for Query #3013 + * added; export DocumentProvider #2996 + * added; ability to remove path from schema #2993 [JohnnyEstilles](https://github.com/JohnnyEstilles) + * added; .explain() helper for aggregate #2714 + * added; ability to specify which ES6-compatible promises library mongoose uses #2688 + * added; export Aggregate #1910 + +4.0.8 / 2015-07-20 +================== + * fixed; assignment with document arrays #3178 [rosston](https://github.com/rosston) + * docs; remove duplicate paragraph #3164 [rhmeeuwisse](https://github.com/rhmeeuwisse) + * docs; improve findOneAndXYZ parameter descriptions #3159 [rhmeeuwisse](https://github.com/rhmeeuwisse) + * docs; add findOneAndRemove to list of supported middleware #3158 + * docs; clarify ensureIndex #3156 + * fixed; refuse to save/remove document without id #3118 + * fixed; hooks next() no longer accidentally returns promise #3104 + * fixed; strict mode for findOneAndUpdate #2947 + * added; .min.js.gz file for browser component #2806 + +3.8.34 / 2015-07-20 +=================== + * fixed; allow using $rename #3171 + * fixed; no longer modifies update arguments #3008 + +4.0.7 / 2015-07-11 +================== + * fixed; documentarray id method when using object id #3157 [siboulet](https://github.com/siboulet) + * docs; improve findById docs #3147 + * fixed; update validators handle null properly #3136 [odeke-em](https://github.com/odeke-em) + * docs; jsdoc syntax errors #3128 [rhmeeuwisse](https://github.com/rhmeeuwisse) + * docs; fix typo #3126 [rhmeeuwisse](https://github.com/rhmeeuwisse) + * docs; proper formatting in queries.jade #3121 [rhmeeuwisse](https://github.com/rhmeeuwisse) + * docs; correct example for string maxlength validator #3111 [rhmeeuwisse](https://github.com/rhmeeuwisse) + * fixed; setDefaultsOnInsert with arrays #3107 + * docs; LearnBoost -> Automattic in package.json #3099 + * docs; pre update hook example #3094 [danpe](https://github.com/danpe) + * docs; clarify query middleware example #3051 + * fixed; ValidationErrors in strict mode #3046 + * fixed; set findOneAndUpdate properties before hooks run #3024 + +3.8.33 / 2015-07-10 +=================== + * upgraded; node driver -> 1.4.38 + * fixed; dont crash when `match` validator undefined + +4.0.6 / 2015-06-21 +================== + * upgraded; node driver -> 2.0.34 #3087 + * fixed; apply setters on addToSet, etc #3067 [victorkohl](https://github.com/victorkohl) + * fixed; missing semicolons #3065 [sokolikp](https://github.com/sokolikp) + * fixed; proper handling for async doc hooks #3062 [gregthegeek](https://github.com/gregthegeek) + * fixed; dont set failed populate field to null if other docs are successfully populated #3055 [eloytoro](https://github.com/eloytoro) + * fixed; setDefaultsOnInsert with document arrays #3034 [taxilian](https://github.com/taxilian) + * fixed; setters fired on array items #3032 + * fixed; stop validateSync() on first error #3025 [victorkohl](https://github.com/victorkohl) + * docs; improve query docs #3016 + * fixed; always exclude _id when its deselected #3010 + * fixed; enum validator kind property #3009 + * fixed; mquery collection names #3005 + * docs; clarify mongos option #3000 + * docs; clarify that query builder has a .then() #2995 + * fixed; race condition in dynamic ref #2992 + +3.8.31 / 2015-06-20 +=================== + * fixed; properly handle text search with discriminators and $meta #2166 + +4.0.5 / 2015-06-05 +================== + * fixed; ObjectIds and buffers when mongodb driver is a sibling dependency #3050 #3048 #3040 #3031 #3020 #2988 #2951 + * fixed; warn user when 'increment' is used in schema #3039 + * fixed; setDefaultsOnInsert with array in schema #3035 + * fixed; dont use default Object toString to cast to string #3030 + * added; npm badge #3020 [odeke-em](https://github.com/odeke-em) + * fixed; proper handling for calling .set() with a subdoc #2782 + * fixed; dont throw cast error when using $rename on non-string path #1845 + +3.8.30 / 2015-06-05 +=================== + * fixed; enable users to set all options with tailable() #2883 + +4.0.4 / 2015-05-28 +================== + * docs; findAndModify new parameter correct default value #3012 [JonForest](https://github.com/JonForest) + * docs; clarify pluralization rules #2999 [anonmily](https://github.com/anonmily) + * fix; discriminators with schema methods #2978 + * fix; make `isModified` a schema reserved keyword #2975 + * fix; properly fire setters when initializing path with object #2943 + * fix; can use `setDefaultsOnInsert` without specifying `runValidators` #2938 + * fix; always set validation errors `kind` property #2885 + * upgraded; node driver -> 2.0.33 #2865 + +3.8.29 / 2015-05-27 +=================== + * fixed; Handle JSON.stringify properly for nested docs #2990 + +4.0.3 / 2015-05-13 +================== + * upgraded; mquery -> 1.5.1 #2983 + * docs; clarify context for query middleware #2974 + * docs; fix missing type -> kind rename in History.md #2961 + * fixed; broken ReadPreference include on Heroku #2957 + * docs; correct form for cursor aggregate option #2955 + * fixed; sync post hooks now properly called after function #2949 #2925 + * fixed; fix sub-doc validate() function #2929 + * upgraded; node driver -> 2.0.30 #2926 + * docs; retainKeyOrder for save() #2924 + * docs; fix broken class names #2913 + * fixed; error when using node-clone on a doc #2909 + * fixed; no more hard references to bson #2908 #2906 + * fixed; dont overwrite array values #2907 [naoina](https://github.com/naoina) + * fixed; use readPreference=primary for findOneAndUpdate #2899 #2823 + * docs; clarify that update validators only run on $set and $unset #2889 + * fixed; set kind consistently for built-in validators #2885 + * docs; single field populated documents #2884 + * fixed; nested objects are now enumerable #2880 [toblerpwn](https://github.com/toblerpwn) + * fixed; properly populate field when ref, lean, stream used together #2841 + * docs; fixed migration guide jade error #2807 + +3.8.28 / 2015-05-12 +=================== + * fixed; proper handling for toJSON options #2910 + * fixed; dont attach virtuals to embedded docs in update() #2046 + +4.0.2 / 2015-04-23 +================== + * fixed; error thrown when calling .validate() on subdoc not in an array #2902 + * fixed; rename define() to play nice with webpack #2900 [jspears](https://github.com/jspears) + * fixed; pre validate called twice with discriminators #2892 + * fixed; .inspect() on mongoose.Types #2875 + * docs; correct callback params for Model.update #2872 + * fixed; setDefaultsOnInsert now works when runValidators not specified #2870 + * fixed; Document now wraps EventEmitter.addListener #2867 + * fixed; call non-hook functions in schema queue #2856 + * fixed; statics can be mocked out for tests #2848 [ninelb](https://github.com/ninelb) + * upgraded; mquery 1.4.0 for bluebird bug fix #2846 + * fixed; required validators run first #2843 + * docs; improved docs for new option to findAndMody #2838 + * docs; populate example now uses correct field #2837 [swilliams](https://github.com/swilliams) + * fixed; pre validate changes causing VersionError #2835 + * fixed; get path from correct place when setting CastError #2832 + * docs; improve docs for Model.update() function signature #2827 [irnc](https://github.com/irnc) + * fixed; populating discriminators #2825 [chetverikov](https://github.com/chetverikov) + * fixed; discriminators with nested schemas #2821 + * fixed; CastErrors with embedded docs #2819 + * fixed; post save hook context #2816 + * docs; 3.8.x -> 4.x migration guide #2807 + * fixed; proper _distinct copying for query #2765 [cdelauder](https://github.com/cdelauder) + +3.8.27 / 2015-04-22 +=================== + * fixed; dont duplicate db calls on Q.ninvoke() #2864 + * fixed; Model.find arguments naming in docs #2828 + * fixed; Support ipv6 in connection strings #2298 + +3.8.26 / 2015-04-07 +=================== + * fixed; TypeError when setting date to undefined #2833 + * fixed; handle CastError properly in distinct() with no callback #2786 + * fixed; broken links in queries docs #2779 + * fixed; dont mark buffer as modified when setting type initially #2738 + * fixed; dont crash when using slice with populate #1934 + +4.0.1 / 2015-03-28 +================== + * fixed; properly handle empty cast doc in update() with promises #2796 + * fixed; unstable warning #2794 + * fixed; findAndModify docs now show new option is false by default #2793 + +4.0.0 / 2015-03-25 +================== + * fixed; on-the-fly schema docs typo #2783 [artiifix](https://github.com/artiifix) + * fixed; cast error validation handling #2775 #2766 #2678 + * fixed; discriminators with populate() #2773 #2719 [chetverikov](https://github.com/chetverikov) + * fixed; increment now a reserved path #2709 + * fixed; avoid sending duplicate object ids in populate() #2683 + * upgraded; mongodb to 2.0.24 to properly emit reconnect event multiple times #2656 + +4.0.0-rc4 / 2015-03-14 +====================== + * fixed; toObject virtuals schema option handled properly #2751 + * fixed; update validators work on document arrays #2733 + * fixed; check for cast errors on $set #2729 + * fixed; instance field set for all schema types #2727 [csdco](https://github.com/csdco) + * fixed; dont run other validators if required fails #2725 + * fixed; custom getters execute on ref paths #2610 + * fixed; save defaults if they were set when doc was loaded from db #2558 + * fixed; pre validate now runs before pre save #2462 + * fixed; no longer throws errors with --use_strict #2281 + +3.8.25 / 2015-03-13 +=================== + * fixed; debug output reverses order of aggregation keys #2759 + * fixed; $eq is a valid query selector in 3.0 #2752 + * fixed; upgraded node driver to 1.4.32 for handling non-numeric poolSize #2682 + * fixed; update() with overwrite sets _id for nested docs #2658 + * fixed; casting for operators in $elemMatch #2199 + +4.0.0-rc3 / 2015-02-28 +====================== + * fixed; update() pre hooks run before validators #2706 + * fixed; setters not called on arrays of refs #2698 [brandom](https://github.com/brandom) + * fixed; use node driver 2.0.18 for nodejs 0.12 support #2685 + * fixed; comments reference file that no longer exists #2681 + * fixed; populated() returns _id of manually populated doc #2678 + * added; ability to exclude version key in toObject() #2675 + * fixed; dont allow setting nested path to a string #2592 + * fixed; can cast objects with _id field to ObjectIds #2581 + * fixed; on-the-fly schema getters #2360 + * added; strict option for findOneAndUpdate() #1967 + +3.8.24 / 2015-02-25 +=================== + * fixed; properly apply child schema transforms #2691 + * fixed; make copy of findOneAndUpdate options before modifying #2687 + * fixed; apply defaults when parent path is selected #2670 #2629 + * fixed; properly get ref property for nested paths #2665 + * fixed; node driver makes copy of authenticate options before modifying them #2619 + * fixed; dont block process exit when auth fails #2599 + * fixed; remove redundant clone in update() #2537 + +4.0.0-rc2 / 2015-02-10 +====================== + * added; io.js to travis build + * removed; browser build dependencies not installed by default + * added; dynamic refpaths #2640 [chetverikov](https://github.com/chetverikov) + * fixed; dont call child schema transforms on parent #2639 [chetverikov](https://github.com/chetverikov) + * fixed; get rid of remove option if new is set in findAndModify #2598 + * fixed; aggregate all document array validation errors #2589 + * fixed; custom setters called when setting value to undefined #1892 + +3.8.23 / 2015-02-06 +=================== + * fixed; unset opts.remove when upsert is true #2519 + * fixed; array saved as object when path is object in array #2442 + * fixed; inline transforms #2440 + * fixed; check for callback in count() #2204 + * fixed; documentation for selecting fields #1534 + +4.0.0-rc1 / 2015-02-01 +====================== + * fixed; use driver 2.0.14 + * changed; use transform: true by default #2245 + +4.0.0-rc0 / 2015-01-31 +=================== + * fixed; wrong order for distinct() params #2628 + * fixed; handling no query argument to remove() #2627 + * fixed; createModel and discriminators #2623 [ashaffer](https://github.com/ashaffer) + * added; pre('count') middleware #2621 + * fixed; double validation calls on document arrays #2618 + * added; validate() catches cast errors #2611 + * fixed; respect replicaSet parameter in connection string #2609 + * added; can explicitly exclude paths from versioning #2576 [csabapalfi](https://github.com/csabapalfi) + * upgraded; driver to 2.0.15 #2552 + * fixed; save() handles errors more gracefully in ES6 #2371 + * fixed; undefined is now a valid argument to findOneAndUpdate #2272 + * changed; `new` option to findAndModify ops is false by default #2262 + +3.8.22 / 2015-01-24 +=================== + * upgraded; node-mongodb-native to 1.4.28 #2587 [Climax777](https://github.com/Climax777) + * added; additional documentation for validators #2449 + * fixed; stack overflow when creating massive arrays #2423 + * fixed; undefined is a valid id for queries #2411 + * fixed; properly create nested schema index when same schema used twice #2322 + * added; link to plugin generator in docs #2085 [huei90](https://github.com/huei90) + * fixed; optional arguments documentation for findOne() #1971 [nachinius](https://github.com/nachinius) + +3.9.7 / 2014-12-19 +=================== + * added; proper cursors for aggregate #2539 [changyy](https://github.com/changyy) + * added; min/max built-in validators for dates #2531 [bshamblen](https://github.com/bshamblen) + * fixed; save and validate are now reserved keywords #2380 + * added; basic documentation for browser component #2256 + * added; find and findOne hooks (query middleware) #2138 + * fixed; throw a DivergentArrayError when saving positional operator queries #2031 + * added; ability to use options as a document property #1416 + * fixed; document no longer inherits from event emitter and so domain and _events are no longer reserved #1351 + * removed; setProfiling #1349 + +3.8.21 / 2014-12-18 +=================== + * fixed; syntax in index.jade #2517 [elderbas](https://github.com/elderbas) + * fixed; writable statics #2510 #2528 + * fixed; overwrite and explicit $set casting #2515 + +3.9.6 / 2014-12-05 +=================== + * added; correctly run validators on each element of array when entire array is modified #661 #1227 + * added; castErrors in validation #1013 [jondavidjohn](https://github.com/jondavidjohn) + * added; specify text indexes in schema fields #1401 [sr527](https://github.com/sr527) + * added; ability to set field with validators to undefined #1594 [alabid](https://github.com/alabid) + * added; .create() returns an array when passed an array #1746 [alabid](https://github.com/alabid) + * added; test suite and docs for use with co and yield #2177 #2474 + * fixed; subdocument toObject() transforms #2447 [chmanie](https://github.com/chmanie) + * fixed; Model.create() with save errors #2484 + * added; pass options to .save() and .remove() #2494 [jondavidjohn](https://github.com/jondavidjohn) + +3.8.20 / 2014-12-01 +=================== + * fixed; recursive readPref #2490 [kjvalencik](https://github.com/kjvalencik) + * fixed; make sure to copy parameters to update() before modifying #2406 [alabid](https://github.com/alabid) + * fixed; unclear documentation about query callbacks #2319 + * fixed; setting a schema-less field to an empty object #2314 [alabid](https://github.com/alabid) + * fixed; registering statics and methods for discriminators #2167 [alabid](https://github.com/alabid) + +3.9.5 / 2014-11-10 +=================== + * added; ability to disable autoIndex on a per-connection basis #1875 [sr527](https://github.com/sr527) + * fixed; `geoNear()` no longer enforces legacy coordinate pairs - supports GeoJSON #1987 [alabid](https://github.com/alabid) + * fixed; browser component works when minified with mangled variable names #2302 + * fixed; `doc.errors` now cleared before `validate()` called #2302 + * added; `execPopulate()` function to make `doc.populate()` compatible with promises #2317 + * fixed; `count()` no longer throws an error when used with `sort()` #2374 + * fixed; `save()` no longer recursively calls `save()` on populated fields #2418 + +3.8.19 / 2014-11-09 +=================== + * fixed; make sure to not override subdoc _ids on find #2276 [alabid](https://github.com/alabid) + * fixed; exception when comparing two documents when one lacks _id #2333 [slawo](https://github.com/slawo) + * fixed; getters for properties with non-strict schemas #2439 [alabid](https://github.com/alabid) + * fixed; inconsistent URI format in docs #2414 [sr527](https://github.com/sr527) + +3.9.4 / 2014-10-25 +================== + * fixed; statics no longer can be overwritten #2343 [nkcmr](https://github.com/chetverikov) + * added; ability to set single populated paths to documents #1530 + * added; setDefaultsOnInsert and runValidator options for findOneAndUpdate() #860 + +3.8.18 / 2014-10-22 +================== + * fixed; Dont use all toObject options in save #2340 [chetverikov](https://github.com/chetverikov) + +3.9.3 / 2014-10-01 +================= + * added; support for virtuals that return objects #2294 + * added; ability to manually hydrate POJOs into mongoose objects #2292 + * added; setDefaultsOnInsert and runValidator options for update() #860 + +3.8.17 / 2014-09-29 +================== + * fixed; use schema options retainKeyOrder in save() #2274 + * fixed; fix skip in populate when limit is set #2252 + * fixed; fix stack overflow when passing MongooseArray to findAndModify #2214 + * fixed; optimize .length usage in populate #2289 + +3.9.2 / 2014-09-08 +================== + * added; test coverage for browser component #2255 + * added; in-order execution of validators #2243 + * added; custom fields for validators #2132 + * removed; exception thrown when find() used with count() #1950 + +3.8.16 / 2014-09-08 +================== + * fixed; properly remove modified array paths if array has been overwritten #1638 + * fixed; key check errors #1884 + * fixed; make sure populate on an array always returns a Mongoose array #2214 + * fixed; SSL connections with node 0.11 #2234 + * fixed; return sensible strings for promise errors #2239 + +3.9.1 / 2014-08-17 +================== + * added; alpha version of browser-side schema validation #2254 + * added; support passing a function to schemas `required` field #2247 + * added; support for setting updatedAt and createdAt timestamps #2227 + * added; document.validate() returns a promise #2131 + +3.8.15 / 2014-08-17 +================== + * fixed; Replica set connection string example in docs #2246 + * fixed; bubble up parseError event #2229 + * fixed; removed buggy populate cache #2176 + * fixed; dont $inc versionKey if its being $set #1933 + * fixed; cast $or and $and in $pull #1932 + * fixed; properly cast to schema in stream() #1862 + * fixed; memory leak in nested objects #1565 #2211 [devongovett](https://github.com/devongovett) + +3.8.14 / 2014-07-26 +================== + * fixed; stringifying MongooseArray shows nested arrays #2002 + * fixed; use populated doc schema in toObject and toJSON by default #2035 + * fixed; dont crash on arrays containing null #2140 + * fixed; model.update w/ upsert has same return values on .exec and promise #2143 + * fixed; better handling for populate limit with multiple documents #2151 + * fixed; dont prevent users from adding weights to text index #2183 + * fixed; helper for aggregation cursor #2187 + * updated; node-mongodb-native to 1.4.7 + +3.8.13 / 2014-07-15 +================== + * fixed; memory leak with isNew events #2159 + * fixed; docs for overwrite option for update() #2144 + * fixed; storeShard() handles dates properly #2127 + * fixed; sub-doc changes not getting persisted to db after save #2082 + * fixed; populate with _id: 0 actually removes _id instead of setting to undefined #2123 + * fixed; save versionKey on findOneAndUpdate w/ upsert #2122 + * fixed; fix typo in 2.8 docs #2120 [shakirullahi](https://github.com/shakirullahi) + * fixed; support maxTimeMs #2102 [yuukinajima](https://github.com/yuukinajima) + * fixed; support $currentDate #2019 + * fixed; $addToSet handles objects without _ids properly #1973 + * fixed; dont crash on invalid nearSphere query #1874 + +3.8.12 / 2014-05-30 +================== + * fixed; single-server reconnect event fires #1672 + * fixed; sub-docs not saved when pushed into populated array #1794 + * fixed; .set() sometimes converts embedded docs to pojos #1954 [archangel-irk](https://github.com/archangel-irk) + * fixed; sub-doc changes not getting persisted to db after save #2082 + * fixed; custom getter might cause mongoose to mistakenly think a path is dirty #2100 [pgherveou](https://github.com/pgherveou) + * fixed; chainable helper for allowDiskUse option in aggregation #2114 + +3.9.0 (unstable) / 2014-05-22 +================== + * changed; added `domain` to reserved keywords #1338 #2052 [antoinepairet](https://github.com/antoinepairet) + * added; asynchronous post hooks #1977 #2081 [chopachom](https://github.com/chopachom) [JasonGhent](https://github.com/JasonGhent) + * added; using model for population, cross-db populate [mihai-chiorean](https://github.com/mihai-chiorean) + * added; can define a type for schema validators + * added; `doc.remove()` returns a promise #1619 [refack](https://github.com/refack) + * added; internal promises for hooks, pre-save hooks run in parallel #1732 [refack](https://github.com/refack) + * fixed; geoSearch hanging when no results returned #1846 [ghartnett](https://github.com/ghartnett) + * fixed; do not set .type property on ValidationError, use .kind instead #1323 + +3.8.11 / 2014-05-22 +================== + * updated; node-mongodb-native to 1.4.5 + * reverted; #2052, fixes #2097 + +3.8.10 / 2014-05-20 +================== + + * updated; node-mongodb-native to 1.4.4 + * fixed; _.isEqual false negatives bug in js-bson #2070 + * fixed; missing check for schema.options #2014 + * fixed; missing support for $position #2024 + * fixed; options object corruption #2049 + * fixed; improvements to virtuals docs #2055 + * fixed; added `domain` to reserved keywords #2052 #1338 + +3.8.9 / 2014-05-08 +================== + + * updated; mquery to 0.7.0 + * updated; node-mongodb-native to 1.4.3 + * fixed; $near failing against MongoDB 2.6 + * fixed; relying on .options() to determine if collection exists + * fixed; $out aggregate helper + * fixed; all test failures against MongoDB 2.6.1, with caveat #2065 + +3.8.8 / 2014-02-22 +================== + + * fixed; saving Buffers #1914 + * updated; expose connection states for user-land #1926 [yorkie](https://github.com/yorkie) + * updated; mquery to 0.5.3 + * updated; added get / set to reserved path list #1903 [tstrimple](https://github.com/tstrimple) + * docs; README code highlighting, syntax fixes #1930 [IonicaBizau](https://github.com/IonicaBizau) + * docs; fixes link in the doc at #1925 [kapeels](https://github.com/kapeels) + * docs; add a missed word 'hook' for the description of the post-hook api #1924 [ipoval](https://github.com/ipoval) + +3.8.7 / 2014-02-09 +================== + + * fixed; sending safe/read options in Query#exec #1895 + * fixed; findOneAnd..() with sort #1887 + +3.8.6 / 2014-01-30 +================== + + * fixed; setting readPreferences #1895 + +3.8.5 / 2014-01-23 +================== + + * fixed; ssl setting when using URI #1882 + * fixed; findByIdAndUpdate now respects the overwrite option #1809 [owenallenaz](https://github.com/owenallenaz) + +3.8.4 / 2014-01-07 +================== + + * updated; mongodb driver to 1.3.23 + * updated; mquery to 0.4.1 + * updated; mpromise to 0.4.3 + * fixed; discriminators now work when selecting fields #1820 [daemon1981](https://github.com/daemon1981) + * fixed; geoSearch with no results timeout #1846 [ghartnett](https://github.com/ghartnett) + * fixed; infitite recursion in ValidationError #1834 [chetverikov](https://github.com/chetverikov) + +3.8.3 / 2013-12-17 +================== + + * fixed; setting empty array with model.update #1838 + * docs; fix url + +3.8.2 / 2013-12-14 +================== + + * fixed; enum validation of multiple values #1778 [heroicyang](https://github.com/heroicyang) + * fixed; global var leak #1803 + * fixed; post remove now fires on subdocs #1810 + * fixed; no longer set default empty array for geospatial-indexed fields #1668 [shirish87](https://github.com/shirish87) + * fixed; model.stream() not hydrating discriminators correctly #1792 [j](https://github.com/j) + * docs: Stablility -> Stability [nikmartin](https://github.com/nikmartin) + * tests; improve shard error handling + +3.8.1 / 2013-11-19 +================== + + * fixed; mishandling of Dates with minimize/getters #1764 + * fixed; Normalize bugs.email, so `npm` will shut up #1769 [refack](https://github.com/refack) + * docs; Improve the grammar where "lets us" was used #1777 [alexyoung](https://github.com/alexyoung) + * docs; Fix some grammatical issues in the documentation #1777 [alexyoung](https://github.com/alexyoung) + * docs; fix Query api exposure + * docs; fix return description + * docs; Added Notes on findAndUpdate() #1750 [sstadelman](https://github.com/sstadelman) + * docs; Update version number in README #1762 [Fodi69](https://github.com/Fodi69) + +3.8.0 / 2013-10-31 +================== + + * updated; warn when using an unstable version + * updated; error message returned in doc.save() #1595 + * updated; mongodb driver to 1.3.19 (fix error swallowing behavior) + * updated; mquery to 0.3.2 + * updated; mocha to 1.12.0 + * updated; mpromise 0.3.0 + * updated; sliced 0.0.5 + * removed; mongoose.Error.DocumentError (never used) + * removed; namedscope (undocumented and broken) #679 #642 #455 #379 + * changed; no longer offically supporting node 0.6.x + * changed; query.within getter is now a method -> query.within() + * changed; query.intersects getter is now a method -> query.intersects() + * added; custom error msgs for built-in validators #747 + * added; discriminator support #1647 #1003 [j](https://github.com/j) + * added; support disabled collection name pluralization #1350 #1707 [refack](https://github.com/refack) + * added; support for GeoJSON to Query#near [ebensing](https://github.com/ebensing) + * added; stand-alone base query support - query.toConstructor() [ebensing](https://github.com/ebensing) + * added; promise support to geoSearch #1614 [ebensing](https://github.com/ebensing) + * added; promise support for geoNear #1614 [ebensing](https://github.com/ebensing) + * added; connection.useDb() #1124 [ebensing](https://github.com/ebensing) + * added; promise support to model.mapReduce() + * added; promise support to model.ensureIndexes() + * added; promise support to model.populate() + * added; benchmarks [ebensing](https://github.com/ebensing) + * added; publicly exposed connection states #1585 + * added; $geoWithin support #1529 $1455 [ebensing](https://github.com/ebensing) + * added; query method chain validation + * added; model.update `overwrite` option + * added; model.geoNear() support #1563 [ebensing](https://github.com/ebensing) + * added; model.geoSearch() support #1560 [ebensing](https://github.com/ebensing) + * added; MongooseBuffer#subtype() + * added; model.create() now returns a promise #1340 + * added; support for `awaitdata` query option + * added; pass the doc to doc.remove() callback #1419 [JoeWagner](https://github.com/JoeWagner) + * added; aggregation query builder #1404 [njoyard](https://github.com/njoyard) + * fixed; document.toObject when using `minimize` and `getters` options #1607 [JedWatson](https://github.com/JedWatson) + * fixed; Mixed types can now be required #1722 [Reggino](https://github.com/Reggino) + * fixed; do not pluralize model names not ending with letters #1703 [refack](https://github.com/refack) + * fixed; repopulating modified populated paths #1697 + * fixed; doc.equals() when _id option is set to false #1687 + * fixed; strict mode warnings #1686 + * fixed; $near GeoJSON casting #1683 + * fixed; nearSphere GeoJSON query builder + * fixed; population field selection w/ strings #1669 + * fixed; setters not firing on null values #1445 [ebensing](https://github.com/ebensing) + * fixed; handle another versioning edge case #1520 + * fixed; excluding subdocument fields #1280 [ebensing](https://github.com/ebensing) + * fixed; allow array properties to be set to null with findOneAndUpdate [aheuermann](https://github.com/aheuermann) + * fixed; subdocuments now use own toJSON opts #1376 [ebensing](https://github.com/ebensing) + * fixed; model#geoNear fulfills promise when results empty #1658 [ebensing](https://github.com/ebensing) + * fixed; utils.merge no longer overrides props and methods #1655 [j](https://github.com/j) + * fixed; subdocuments now use their own transform #1412 [ebensing](https://github.com/ebensing) + * fixed; model.remove() removes only what is necessary #1649 + * fixed; update() now only runs with cb or explicit true #1644 + * fixed; casting ref docs on creation #1606 [ebensing](https://github.com/ebensing) + * fixed; model.update "overwrite" option works as documented + * fixed; query#remove() works as documented + * fixed; "limit" correctly applies to individual items on population #1490 [ebensing](https://github.com/ebensing) + * fixed; issue with positional operator on ref docs #1572 [ebensing](https://github.com/ebensing) + * fixed; benchmarks to actually output valid json + * deprecated; promise#addBack (use promise#onResolve) + * deprecated; promise#complete (use promise#fulfill) + * deprecated; promise#addCallback (use promise#onFulFill) + * deprecated; promise#addErrback (use promise#onReject) + * deprecated; query.nearSphere() (use query.near) + * deprecated; query.center() (use query.circle) + * deprecated; query.centerSphere() (use query.circle) + * deprecated; query#slaveOk (use query#read) + * docs; custom validator messages + * docs; 10gen -> MongoDB + * docs; add Date method caveats #1598 + * docs; more validation details + * docs; state which branch is stable/unstable + * docs; mention that middleware does not run on Models + * docs; promise.fulfill() + * docs; fix readme spelling #1483 [yorchopolis](https://github.com/yorchopolis) + * docs; fixed up the README and examples [ebensing](https://github.com/ebensing) + * website; add "show code" for properties + * website; move "show code" links down + * website; update guide + * website; add unstable docs + * website; many improvements + * website; fix copyright #1439 + * website; server.js -> static.js #1546 [nikmartin](https://github.com/nikmartin) + * tests; refactor 1703 + * tests; add test generator + * tests; validate formatMessage() throws + * tests; add script for continuously running tests + * tests; fixed versioning tests + * tests; race conditions in tests + * tests; added for nested and/or queries + * tests; close some test connections + * tests; validate db contents + * tests; remove .only + * tests; close some test connections + * tests; validate db contents + * tests; remove .only + * tests; replace deprecated method names + * tests; convert id to string + * tests; fix sharding tests for MongoDB 2.4.5 + * tests; now 4-5 seconds faster + * tests; fix race condition + * make; suppress warning msg in test + * benchmarks; updated for pull requests + * examples; improved and expanded [ebensing](https://github.com/ebensing) + +3.7.4 (unstable) / 2013-10-01 +============================= + + * updated; mquery to 0.3.2 + * removed; mongoose.Error.DocumentError (never used) + * added; custom error msgs for built-in validators #747 + * added; discriminator support #1647 #1003 [j](https://github.com/j) + * added; support disabled collection name pluralization #1350 #1707 [refack](https://github.com/refack) + * fixed; do not pluralize model names not ending with letters #1703 [refack](https://github.com/refack) + * fixed; repopulating modified populated paths #1697 + * fixed; doc.equals() when _id option is set to false #1687 + * fixed; strict mode warnings #1686 + * fixed; $near GeoJSON casting #1683 + * fixed; nearSphere GeoJSON query builder + * fixed; population field selection w/ strings #1669 + * docs; custom validator messages + * docs; 10gen -> MongoDB + * docs; add Date method caveats #1598 + * docs; more validation details + * website; add "show code" for properties + * website; move "show code" links down + * tests; refactor 1703 + * tests; add test generator + * tests; validate formatMessage() throws + +3.7.3 (unstable) / 2013-08-22 +============================= + + * updated; warn when using an unstable version + * updated; mquery to 0.3.1 + * updated; mocha to 1.12.0 + * updated; mongodb driver to 1.3.19 (fix error swallowing behavior) + * changed; no longer offically supporting node 0.6.x + * added; support for GeoJSON to Query#near [ebensing](https://github.com/ebensing) + * added; stand-alone base query support - query.toConstructor() [ebensing](https://github.com/ebensing) + * added; promise support to geoSearch #1614 [ebensing](https://github.com/ebensing) + * added; promise support for geoNear #1614 [ebensing](https://github.com/ebensing) + * fixed; setters not firing on null values #1445 [ebensing](https://github.com/ebensing) + * fixed; handle another versioning edge case #1520 + * fixed; excluding subdocument fields #1280 [ebensing](https://github.com/ebensing) + * fixed; allow array properties to be set to null with findOneAndUpdate [aheuermann](https://github.com/aheuermann) + * fixed; subdocuments now use own toJSON opts #1376 [ebensing](https://github.com/ebensing) + * fixed; model#geoNear fulfills promise when results empty #1658 [ebensing](https://github.com/ebensing) + * fixed; utils.merge no longer overrides props and methods #1655 [j](https://github.com/j) + * fixed; subdocuments now use their own transform #1412 [ebensing](https://github.com/ebensing) + * make; suppress warning msg in test + * docs; state which branch is stable/unstable + * docs; mention that middleware does not run on Models + * tests; add script for continuously running tests + * tests; fixed versioning tests + * benchmarks; updated for pull requests + +3.7.2 (unstable) / 2013-08-15 +================== + + * fixed; model.remove() removes only what is necessary #1649 + * fixed; update() now only runs with cb or explicit true #1644 + * tests; race conditions in tests + * website; update guide + +3.7.1 (unstable) / 2013-08-13 +============================= + + * updated; driver to 1.3.18 (fixes memory leak) + * added; connection.useDb() #1124 [ebensing](https://github.com/ebensing) + * added; promise support to model.mapReduce() + * added; promise support to model.ensureIndexes() + * added; promise support to model.populate() + * fixed; casting ref docs on creation #1606 [ebensing](https://github.com/ebensing) + * fixed; model.update "overwrite" option works as documented + * fixed; query#remove() works as documented + * fixed; "limit" correctly applies to individual items on population #1490 [ebensing](https://github.com/ebensing) + * fixed; issue with positional operator on ref docs #1572 [ebensing](https://github.com/ebensing) + * fixed; benchmarks to actually output valid json + * tests; added for nested and/or queries + * tests; close some test connections + * tests; validate db contents + * tests; remove .only + * tests; close some test connections + * tests; validate db contents + * tests; remove .only + * tests; replace deprecated method names + * tests; convert id to string + * docs; promise.fulfill() + +3.7.0 (unstable) / 2013-08-05 +=================== + + * changed; query.within getter is now a method -> query.within() + * changed; query.intersects getter is now a method -> query.intersects() + * deprecated; promise#addBack (use promise#onResolve) + * deprecated; promise#complete (use promise#fulfill) + * deprecated; promise#addCallback (use promise#onFulFill) + * deprecated; promise#addErrback (use promise#onReject) + * deprecated; query.nearSphere() (use query.near) + * deprecated; query.center() (use query.circle) + * deprecated; query.centerSphere() (use query.circle) + * deprecated; query#slaveOk (use query#read) + * removed; namedscope (undocumented and broken) #679 #642 #455 #379 + * added; benchmarks [ebensing](https://github.com/ebensing) + * added; publicly exposed connection states #1585 + * added; $geoWithin support #1529 $1455 [ebensing](https://github.com/ebensing) + * added; query method chain validation + * added; model.update `overwrite` option + * added; model.geoNear() support #1563 [ebensing](https://github.com/ebensing) + * added; model.geoSearch() support #1560 [ebensing](https://github.com/ebensing) + * added; MongooseBuffer#subtype() + * added; model.create() now returns a promise #1340 + * added; support for `awaitdata` query option + * added; pass the doc to doc.remove() callback #1419 [JoeWagner](https://github.com/JoeWagner) + * added; aggregation query builder #1404 [njoyard](https://github.com/njoyard) + * updated; integrate mquery #1562 [ebensing](https://github.com/ebensing) + * updated; error msg in doc.save() #1595 + * updated; bump driver to 1.3.15 + * updated; mpromise 0.3.0 + * updated; sliced 0.0.5 + * tests; fix sharding tests for MongoDB 2.4.5 + * tests; now 4-5 seconds faster + * tests; fix race condition + * docs; fix readme spelling #1483 [yorchopolis](https://github.com/yorchopolis) + * docs; fixed up the README and examples [ebensing](https://github.com/ebensing) + * website; add unstable docs + * website; many improvements + * website; fix copyright #1439 + * website; server.js -> static.js #1546 [nikmartin](https://github.com/nikmartin) + * examples; improved and expanded [ebensing](https://github.com/ebensing) + +3.6.20 (stable) / 2013-09-23 +=================== + + * fixed; repopulating modified populated paths #1697 + * fixed; doc.equals w/ _id false #1687 + * fixed; strict mode warning #1686 + * docs; near/nearSphere + +3.6.19 (stable) / 2013-09-04 +================== + + * fixed; population field selection w/ strings #1669 + * docs; Date method caveats #1598 + +3.6.18 (stable) / 2013-08-22 +=================== + + * updated; warn when using an unstable version of mongoose + * updated; mocha to 1.12.0 + * updated; mongodb driver to 1.3.19 (fix error swallowing behavior) + * fixed; setters not firing on null values #1445 [ebensing](https://github.com/ebensing) + * fixed; properly exclude subdocument fields #1280 [ebensing](https://github.com/ebensing) + * fixed; cast error in findAndModify #1643 [aheuermann](https://github.com/aheuermann) + * website; update guide + * website; added documentation for safe:false and versioning interaction + * docs; mention that middleware dont run on Models + * docs; fix indexes link + * make; suppress warning msg in test + * tests; moar + +3.6.17 / 2013-08-13 +=================== + + * updated; driver to 1.3.18 (fixes memory leak) + * fixed; casting ref docs on creation #1606 + * docs; query options + +3.6.16 / 2013-08-08 +=================== + + * added; publicly expose connection states #1585 + * fixed; limit applies to individual items on population #1490 [ebensing](https://github.com/ebensing) + * fixed; positional operator casting in updates #1572 [ebensing](https://github.com/ebensing) + * updated; MongoDB driver to 1.3.17 + * updated; sliced to 0.0.5 + * website; tweak homepage + * tests; fixed + added + * docs; fix some examples + * docs; multi-mongos support details + * docs; auto open browser after starting static server + +3.6.15 / 2013-07-16 +================== + + * added; mongos failover support #1037 + * updated; make schematype return vals return self #1580 + * docs; add note to model.update #571 + * docs; document third param to document.save callback #1536 + * tests; tweek mongos test timeout + +3.6.14 / 2013-07-05 +=================== + + * updated; driver to 1.3.11 + * fixed; issue with findOneAndUpdate not returning null on upserts #1533 [ebensing](https://github.com/ebensing) + * fixed; missing return statement in SchemaArray#$geoIntersects() #1498 [bsrykt](https://github.com/bsrykt) + * fixed; wrong isSelected() behavior #1521 [kyano](https://github.com/kyano) + * docs; note about toObject behavior during save() + * docs; add callbacks details #1547 [nikmartin](https://github.com/nikmartin) + +3.6.13 / 2013-06-27 +=================== + + * fixed; calling model.distinct without conditions #1541 + * fixed; regression in Query#count() #1542 + * now working on 3.6.13 + +3.6.12 / 2013-06-25 +=================== + + * updated; driver to 1.3.10 + * updated; clearer capped collection error message #1509 [bitmage](https://github.com/bitmage) + * fixed; MongooseBuffer subtype loss during casting #1517 [zedgu](https://github.com/zedgu) + * fixed; docArray#id when doc.id is disabled #1492 + * fixed; docArray#id now supports matches on populated arrays #1492 [pgherveou](https://github.com/pgherveou) + * website; fix example + * website; improve _id disabling example + * website; fix typo #1494 [dejj](https://github.com/dejj) + * docs; added a 'Requesting new features' section #1504 [shovon](https://github.com/shovon) + * docs; improve subtypes description + * docs; clarify _id disabling + * docs: display by alphabetical order the methods list #1508 [nicolasleger](https://github.com/nicolasleger) + * tests; refactor isSelected checks + * tests; remove pointless test + * tests; fixed timeouts + +3.6.11 / 2013-05-15 +=================== + + * updated; driver to 1.3.5 + * fixed; compat w/ Object.create(null) #1484 #1485 + * fixed; cloning objects w/ missing constructors + * fixed; prevent multiple min number validators #1481 [nrako](https://github.com/nrako) + * docs; add doc.increment() example + * docs; add $size example + * docs; add "distinct" example + +3.6.10 / 2013-05-09 +================== + + * update driver to 1.3.3 + * fixed; increment() works without other changes #1475 + * website; fix links to posterous + * docs; fix link #1472 + +3.6.9 / 2013-05-02 +================== + + * fixed; depopulation of mixed documents #1471 + * fixed; use of $options in array #1462 + * tests; fix race condition + * docs; fix default example + +3.6.8 / 2013-04-25 +================== + + * updated; driver to 1.3.0 + * fixed; connection.model should retain options #1458 [vedmalex](https://github.com/vedmalex) + * tests; 4-5 seconds faster + +3.6.7 / 2013-04-19 +================== + + * fixed; population regression in 3.6.6 #1444 + +3.6.6 / 2013-04-18 +================== + + * fixed; saving populated new documents #1442 + * fixed; population regession in 3.6.5 #1441 + * website; fix copyright #1439 + +3.6.5 / 2013-04-15 +================== + + * fixed; strict:throw edge case using .set(path, val) + * fixed; schema.pathType() on some numbericAlpha paths + * fixed; numbericAlpha path versioning + * fixed; setting nested mixed paths #1418 + * fixed; setting nested objects with null prop #1326 + * fixed; regression in v3.6 population performance #1426 [vedmalex](https://github.com/vedmalex) + * fixed; read pref typos #1422 [kyano](https://github.com/kyano) + * docs; fix method example + * website; update faq + * website; add more deep links + * website; update poolSize docs + * website; add 3.6 release notes + * website; note about keepAlive + +3.6.4 / 2013-04-03 +================== + + * fixed; +field conflict with $slice #1370 + * fixed; nested deselection conflict #1333 + * fixed; RangeError in ValidationError.toString() #1296 + * fixed; do not save user defined transforms #1415 + * tests; fix race condition + +3.6.3 / 2013-04-02 +================== + + * fixed; setting subdocuments deeply nested fields #1394 + * fixed; regression: populated streams #1411 + * docs; mention hooks/validation with findAndModify + * docs; mention auth + * docs; add more links + * examples; add document methods example + * website; display "see" links for properties + * website; clean up homepage + +3.6.2 / 2013-03-29 +================== + + * fixed; corrupted sub-doc array #1408 + * fixed; document#update returns a Query #1397 + * docs; readpref strategy + +3.6.1 / 2013-03-27 +================== + + * added; populate support to findAndModify varients #1395 + * added; text index type to schematypes + * expose allowed index types as Schema.indexTypes + * fixed; use of `setMaxListeners` as path + * fixed; regression in node 0.6 on docs with > 10 arrays + * fixed; do not alter schema arguments #1364 + * fixed; subdoc#ownerDocument() #1385 + * website; change search id + * website; add search from google [jackdbernier](https://github.com/jackdbernier) + * website; fix link + * website; add 3.5.x docs release + * website; fix link + * docs; fix geometry + * docs; hide internal constructor + * docs; aggregation does not cast arguments #1399 + * docs; querystream options + * examples; added for population + +3.6.0 / 2013-03-18 +================== + + * changed; cast 'true'/'false' to boolean #1282 [mgrach](https://github.com/mgrach) + * changed; Buffer arrays can now contain nulls + * added; QueryStream transform option + * added; support for authSource driver option + * added; {mongoose,db}.modelNames() + * added; $push w/ $slice,$sort support (MongoDB 2.4) + * added; hashed index type (MongoDB 2.4) + * added; support for mongodb 2.4 geojson (MongoDB 2.4) + * added; value at time of validation error + * added; support for object literal schemas + * added; bufferCommands schema option + * added; allow auth option in connections #1360 [geoah](https://github.com/geoah) + * added; performance improvements to populate() [263ece9](https://github.com/LearnBoost/mongoose/commit/263ece9) + * added; allow adding uncasted docs to populated arrays and properties #570 + * added; doc#populated(path) stores original populated _ids + * added; lean population #1260 + * added; query.populate() now accepts an options object + * added; document#populate(opts, callback) + * added; Model.populate(docs, opts, callback) + * added; support for rich nested path population + * added; doc.array.remove(value) subdoc with _id value support #1278 + * added; optionally allow non-strict sets and updates + * added; promises/A+ comformancy with [mpromise](https://github.com/aheckmann/mpromise) + * added; promise#then + * added; promise#end + * fixed; use of `model` as doc property + * fixed; lean population #1382 + * fixed; empty object mixed defaults #1380 + * fixed; populate w/ deselected _id using string syntax + * fixed; attempted save of divergent populated arrays #1334 related + * fixed; better error msg when attempting toObject as property name + * fixed; non population buffer casting from doc + * fixed; setting populated paths #570 + * fixed; casting when added docs to populated arrays #570 + * fixed; prohibit updating arrays selected with $elemMatch #1334 + * fixed; pull / set subdoc combination #1303 + * fixed; multiple bg index creation #1365 + * fixed; manual reconnection to single mongod + * fixed; Constructor / version exposure #1124 + * fixed; CastError race condition + * fixed; no longer swallowing misuse of subdoc#invalidate() + * fixed; utils.clone retains RegExp opts + * fixed; population of non-schema property + * fixed; allow updating versionKey #1265 + * fixed; add EventEmitter props to reserved paths #1338 + * fixed; can now deselect populated doc _ids #1331 + * fixed; properly pass subtype to Binary in MongooseBuffer + * fixed; casting _id from document with non-ObjectId _id + * fixed; specifying schema type edge case { path: [{type: "String" }] } + * fixed; typo in schemdate #1329 [jplock](https://github.com/jplock) + * updated; driver to 1.2.14 + * updated; muri to 0.3.1 + * updated; mpromise to 0.2.1 + * updated; mocha 1.8.1 + * updated; mpath to 0.1.1 + * deprecated; pluralization will die in 4.x + * refactor; rename private methods to something unusable as doc properties + * refactor MongooseArray#remove + * refactor; move expires index to SchemaDate #1328 + * refactor; internal document properties #1171 #1184 + * tests; added + * docs; indexes + * docs; validation + * docs; populate + * docs; populate + * docs; add note about stream compatibility with node 0.8 + * docs; fix for private names + * docs; Buffer -> mongodb.Binary #1363 + * docs; auth options + * docs; improved + * website; update FAQ + * website; add more api links + * website; add 3.5.x docs to prior releases + * website; Change mongoose-types to an active repo [jackdbernier](https://github.com/jackdbernier) + * website; compat with node 0.10 + * website; add news section + * website; use T for generic type + * benchmark; make adjustable + +3.6.0rc1 / 2013-03-12 +====================== + + * refactor; rename private methods to something unusable as doc properties + * added; {mongoose,db}.modelNames() + * added; $push w/ $slice,$sort support (MongoDB 2.4) + * added; hashed index type (MongoDB 2.4) + * added; support for mongodb 2.4 geojson (MongoDB 2.4) + * added; value at time of validation error + * added; support for object literal schemas + * added; bufferCommands schema option + * added; allow auth option in connections #1360 [geoah](https://github.com/geoah) + * fixed; lean population #1382 + * fixed; empty object mixed defaults #1380 + * fixed; populate w/ deselected _id using string syntax + * fixed; attempted save of divergent populated arrays #1334 related + * fixed; better error msg when attempting toObject as property name + * fixed; non population buffer casting from doc + * fixed; setting populated paths #570 + * fixed; casting when added docs to populated arrays #570 + * fixed; prohibit updating arrays selected with $elemMatch #1334 + * fixed; pull / set subdoc combination #1303 + * fixed; multiple bg index creation #1365 + * fixed; manual reconnection to single mongod + * fixed; Constructor / version exposure #1124 + * fixed; CastError race condition + * fixed; no longer swallowing misuse of subdoc#invalidate() + * fixed; utils.clone retains RegExp opts + * fixed; population of non-schema property + * fixed; allow updating versionKey #1265 + * fixed; add EventEmitter props to reserved paths #1338 + * fixed; can now deselect populated doc _ids #1331 + * updated; muri to 0.3.1 + * updated; driver to 1.2.12 + * updated; mpromise to 0.2.1 + * deprecated; pluralization will die in 4.x + * docs; Buffer -> mongodb.Binary #1363 + * docs; auth options + * docs; improved + * website; add news section + * benchmark; make adjustable + +3.6.0rc0 / 2013-02-03 +====================== + + * changed; cast 'true'/'false' to boolean #1282 [mgrach](https://github.com/mgrach) + * changed; Buffer arrays can now contain nulls + * fixed; properly pass subtype to Binary in MongooseBuffer + * fixed; casting _id from document with non-ObjectId _id + * fixed; specifying schema type edge case { path: [{type: "String" }] } + * fixed; typo in schemdate #1329 [jplock](https://github.com/jplock) + * refactor; move expires index to SchemaDate #1328 + * refactor; internal document properties #1171 #1184 + * added; performance improvements to populate() [263ece9](https://github.com/LearnBoost/mongoose/commit/263ece9) + * added; allow adding uncasted docs to populated arrays and properties #570 + * added; doc#populated(path) stores original populated _ids + * added; lean population #1260 + * added; query.populate() now accepts an options object + * added; document#populate(opts, callback) + * added; Model.populate(docs, opts, callback) + * added; support for rich nested path population + * added; doc.array.remove(value) subdoc with _id value support #1278 + * added; optionally allow non-strict sets and updates + * added; promises/A+ comformancy with [mpromise](https://github.com/aheckmann/mpromise) + * added; promise#then + * added; promise#end + * updated; mocha 1.8.1 + * updated; muri to 0.3.0 + * updated; mpath to 0.1.1 + * updated; docs + +3.5.16 / 2013-08-13 +=================== + + * updated; driver to 1.3.18 + +3.5.15 / 2013-07-26 +================== + + * updated; sliced to 0.0.5 + * updated; driver to 1.3.12 + * fixed; regression in Query#count() due to driver change + * tests; fixed timeouts + * tests; handle differing test uris + +3.5.14 / 2013-05-15 +=================== + + * updated; driver to 1.3.5 + * fixed; compat w/ Object.create(null) #1484 #1485 + * fixed; cloning objects missing constructors + * fixed; prevent multiple min number validators #1481 [nrako](https://github.com/nrako) + +3.5.13 / 2013-05-09 +================== + + * update driver to 1.3.3 + * fixed; use of $options in array #1462 + +3.5.12 / 2013-04-25 +=================== + + * updated; driver to 1.3.0 + * fixed; connection.model should retain options #1458 [vedmalex](https://github.com/vedmalex) + * fixed; read pref typos #1422 [kyano](https://github.com/kyano) + +3.5.11 / 2013-04-03 +================== + + * fixed; +field conflict with $slice #1370 + * fixed; RangeError in ValidationError.toString() #1296 + * fixed; nested deselection conflict #1333 + * remove time from Makefile + +3.5.10 / 2013-04-02 +================== + + * fixed; setting subdocuments deeply nested fields #1394 + * fixed; do not alter schema arguments #1364 + +3.5.9 / 2013-03-15 +================== + + * updated; driver to 1.2.14 + * added; support for authSource driver option (mongodb 2.4) + * added; QueryStream transform option (node 0.10 helper) + * fixed; backport for saving required populated buffers + * fixed; pull / set subdoc combination #1303 + * fixed; multiple bg index creation #1365 + * test; added for saveable required populated buffers + * test; added for #1365 + * test; add authSource test + +3.5.8 / 2013-03-12 +================== + + * added; auth option in connection [geoah](https://github.com/geoah) + * fixed; CastError race condition + * docs; add note about stream compatibility with node 0.8 + +3.5.7 / 2013-02-22 +================== + + * updated; driver to 1.2.13 + * updated; muri to 0.3.1 #1347 + * fixed; utils.clone retains RegExp opts #1355 + * fixed; deepEquals RegExp support + * tests; fix a connection test + * website; clean up docs [afshinm](https://github.com/afshinm) + * website; update homepage + * website; migragtion: emphasize impact of strict docs #1264 + +3.5.6 / 2013-02-14 +================== + + * updated; driver to 1.2.12 + * fixed; properly pass Binary subtype + * fixed; add EventEmitter props to reserved paths #1338 + * fixed; use correct node engine version + * fixed; display empty docs as {} in log output #953 follow up + * improved; "bad $within $box argument" error message + * populate; add unscientific benchmark + * website; add stack overflow to help section + * website; use better code font #1336 [risseraka](https://github.com/risseraka) + * website; clarify where help is available + * website; fix source code links #1272 [floatingLomas](https://github.com/floatingLomas) + * docs; be specific about _id schema option #1103 + * docs; add ensureIndex error handling example + * docs; README + * docs; CONTRIBUTING.md + +3.5.5 / 2013-01-29 +================== + + * updated; driver to 1.2.11 + * removed; old node < 0.6x shims + * fixed; documents with Buffer _ids equality + * fixed; MongooseBuffer properly casts numbers + * fixed; reopening closed connection on alt host/port #1287 + * docs; fixed typo in Readme #1298 [rened](https://github.com/rened) + * docs; fixed typo in migration docs [Prinzhorn](https://github.com/Prinzhorn) + * docs; fixed incorrect annotation in SchemaNumber#min [bilalq](https://github.com/bilalq) + * docs; updated + +3.5.4 / 2013-01-07 +================== + + * changed; "_pres" & "_posts" are now reserved pathnames #1261 + * updated; driver to 1.2.8 + * fixed; exception when reopening a replica set. #1263 [ethankan](https://github.com/ethankan) + * website; updated + +3.5.3 / 2012-12-26 +================== + + * added; support for geo object notation #1257 + * fixed; $within query casting with arrays + * fixed; unix domain socket support #1254 + * updated; driver to 1.2.7 + * updated; muri to 0.0.5 + +3.5.2 / 2012-12-17 +================== + + * fixed; using auth with replica sets #1253 + +3.5.1 / 2012-12-12 +================== + + * fixed; regression when using subdoc with `path` as pathname #1245 [daeq](https://github.com/daeq) + * fixed; safer db option checks + * updated; driver to 1.2.5 + * website; add more examples + * website; clean up old docs + * website; fix prev release urls + * docs; clarify streaming with HTTP responses + +3.5.0 / 2012-12-10 +================== + + * added; paths to CastErrors #1239 + * added; support for mongodb connection string spec #1187 + * added; post validate event + * added; Schema#get (to retrieve schema options) + * added; VersionError #1071 + * added; npmignore [hidekiy](https://github.com/hidekiy) + * update; driver to 1.2.3 + * fixed; stackoverflow in setter #1234 + * fixed; utils.isObject() + * fixed; do not clobber user specified driver writeConcern #1227 + * fixed; always pass current document to post hooks + * fixed; throw error when user attempts to overwrite a model + * fixed; connection.model only caches on connection #1209 + * fixed; respect conn.model() creation when matching global model exists #1209 + * fixed; passing model name + collection name now always honors collection name + * fixed; setting virtual field to an empty object #1154 + * fixed; subclassed MongooseErrors exposure, now available in mongoose.Error.xxxx + * fixed; model.remove() ignoring callback when executed twice [daeq](https://github.com/daeq) #1210 + * docs; add collection option to schema api docs #1222 + * docs; NOTE about db safe options + * docs; add post hooks docs + * docs; connection string options + * docs; middleware is not executed with Model.remove #1241 + * docs; {g,s}etter introspection #777 + * docs; update validation docs + * docs; add link to plugins page + * docs; clarify error returned by unique indexes #1225 + * docs; more detail about disabling autoIndex behavior + * docs; add homepage section to package (npm docs mongoose) + * docs; more detail around collection name pluralization #1193 + * website; add .important css + * website; update models page + * website; update getting started + * website; update quick start + +3.4.0 / 2012-11-10 +================== + + * added; support for generic toJSON/toObject transforms #1160 #1020 #1197 + * added; doc.set() merge support #1148 [NuORDER](https://github.com/NuORDER) + * added; query#add support #1188 [aleclofabbro](https://github.com/aleclofabbro) + * changed; adding invalid nested paths to non-objects throws 4216f14 + * changed; fixed; stop invalid function cloning (internal fix) + * fixed; add query $and casting support #1180 [anotheri](https://github.com/anotheri) + * fixed; overwriting of query arguments #1176 + * docs; fix expires examples + * docs; transforms + * docs; schema `collection` option docs [hermanjunge](https://github.com/hermanjunge) + * website; updated + * tests; added + +3.3.1 / 2012-10-11 +================== + + * fixed; allow goose.connect(uris, dbname, opts) #1144 + * docs; persist API private checked state across page loads + +3.3.0 / 2012-10-10 +================== + + * fixed; passing options as 2nd arg to connect() #1144 + * fixed; race condition after no-op save #1139 + * fixed; schema field selection application in findAndModify #1150 + * fixed; directly setting arrays #1126 + * updated; driver to 1.1.11 + * updated; collection pluralization rules [mrickard](https://github.com/mrickard) + * tests; added + * docs; updated + +3.2.2 / 2012-10-08 +================== + + * updated; driver to 1.1.10 #1143 + * updated; use sliced 0.0.3 + * fixed; do not recast embedded docs unnecessarily + * fixed; expires schema option helper #1132 + * fixed; built in string setters #1131 + * fixed; debug output for Dates/ObjectId properties #1129 + * docs; fixed Javascript syntax error in example [olalonde](https://github.com/olalonde) + * docs; fix toJSON example #1137 + * docs; add ensureIndex production notes + * docs; fix spelling + * docs; add blogposts about v3 + * website; updated + * removed; undocumented inGroupsOf util + * tests; added + +3.2.1 / 2012-09-28 +================== + + * fixed; remove query batchSize option default of 1000 https://github.com/learnboost/mongoose/commit/3edaa8651 + * docs; updated + * website; updated + +3.2.0 / 2012-09-27 +================== + + * added; direct array index assignment with casting support `doc.array.set(index, value)` + * fixed; QueryStream#resume within same tick as pause() #1116 + * fixed; default value validatation #1109 + * fixed; array splice() not casting #1123 + * fixed; default array construction edge case #1108 + * fixed; query casting for inequalities in arrays #1101 [dpatti](https://github.com/dpatti) + * tests; added + * website; more documentation + * website; fixed layout issue #1111 [SlashmanX](https://github.com/SlashmanX) + * website; refactored [guille](https://github.com/guille) + +3.1.2 / 2012-09-10 +================== + + * added; ReadPreferrence schema option #1097 + * updated; driver to 1.1.7 + * updated; default query batchSize to 1000 + * fixed; we now cast the mapReduce query option #1095 + * fixed; $elemMatch+$in with field selection #1091 + * fixed; properly cast $elemMatch+$in conditions #1100 + * fixed; default field application of subdocs #1027 + * fixed; querystream prematurely dying #1092 + * fixed; querystream never resumes when paused at getMore boundries #1092 + * fixed; querystream occasionally emits data events after destroy #1092 + * fixed; remove unnecessary ObjectId creation in querystream + * fixed; allow ne(boolean) again #1093 + * docs; add populate/field selection syntax notes + * docs; add toObject/toJSON options detail + * docs; `read` schema option + +3.1.1 / 2012-08-31 +================== + + * updated; driver to 1.1.6 + +3.1.0 / 2012-08-29 +================== + + * changed; fixed; directly setting nested objects now overwrites entire object (previously incorrectly merged them) + * added; read pref support (mongodb 2.2) 205a709c + * added; aggregate support (mongodb 2.2) f3a5bd3d + * added; virtual {g,s}etter introspection (#1070) + * updated; docs [brettz9](https://github.com/brettz9) + * updated; driver to 1.1.5 + * fixed; retain virtual setter return values (#1069) + +3.0.3 / 2012-08-23 +================== + + * fixed; use of nested paths beginning w/ numbers #1062 + * fixed; query population edge case #1053 #1055 [jfremy](https://github.com/jfremy) + * fixed; simultaneous top and sub level array modifications #1073 + * added; id and _id schema option aliases + tests + * improve debug formatting to allow copy/paste logged queries into mongo shell [eknkc](https://github.com/eknkc) + * docs + +3.0.2 / 2012-08-17 +================== + + * added; missing support for v3 sort/select syntax to findAndModify helpers (#1058) + * fixed; replset fullsetup event emission + * fixed; reconnected event for replsets + * fixed; server reconnection setting discovery + * fixed; compat with non-schema path props using positional notation (#1048) + * fixed; setter/casting order (#665) + * docs; updated + +3.0.1 / 2012-08-11 +================== + + * fixed; throw Error on bad validators (1044) + * fixed; typo in EmbeddedDocument#parentArray [lackac] + * fixed; repair mongoose.SchemaTypes alias + * updated; docs + +3.0.0 / 2012-08-07 +================== + + * removed; old subdocument#commit method + * fixed; setting arrays of matching docs [6924cbc2] + * fixed; doc!remove event now emits in save order as save for consistency + * fixed; pre-save hooks no longer fire on subdocuments when validation fails + * added; subdoc#parent() and subdoc#parentArray() to access subdocument parent objects + * added; query#lean() helper + +3.0.0rc0 / 2012-08-01 +===================== + + * fixed; allow subdoc literal declarations containing "type" pathname (#993) + * fixed; unsetting a default array (#758) + * fixed; boolean $in queries (#998) + * fixed; allow use of `options` as a pathname (#529) + * fixed; `model` is again a permitted schema path name + * fixed; field selection option on subdocs (#1022) + * fixed; handle another edge case with subdoc saving (#975) + * added; emit save err on model if listening + * added; MongoDB TTL collection support (#1006) + * added; $center options support + * added; $nearSphere and $polygon support + * updated; driver version to 1.1.2 + +3.0.0alpha2 / 2012-07-18 +========================= + + * changed; index errors are now emitted on their model and passed to an optional callback (#984) + * fixed; specifying index along with sparse/unique option no longer overwrites (#1004) + * fixed; never swallow connection errors (#618) + * fixed; creating object from model with emded object no longer overwrites defaults [achurkin] (#859) + * fixed; stop needless validation of unchanged/unselected fields (#891) + * fixed; document#equals behavior of objectids (#974) + * fixed; honor the minimize schema option (#978) + * fixed; provide helpful error msgs when reserved schema path is used (#928) + * fixed; callback to conn#disconnect is optional (#875) + * fixed; handle missing protocols in connection urls (#987) + * fixed; validate args to query#where (#969) + * fixed; saving modified/removed subdocs (#975) + * fixed; update with $pull from Mixed array (#735) + * fixed; error with null shard key value + * fixed; allow unsetting enums (#967) + * added; support for manual index creation (#984) + * added; support for disabled auto-indexing (#984) + * added; support for preserving MongooseArray#sort changes (#752) + * added; emit state change events on connection + * added; support for specifying BSON subtype in MongooseBuffer#toObject [jcrugzz] + * added; support for disabled versioning (#977) + * added; implicit "new" support for models and Schemas + +3.0.0alpha1 / 2012-06-15 +========================= + + * removed; doc#commit (use doc#markModified) + * removed; doc.modified getter (#950) + * removed; mongoose{connectSet,createSetConnection}. use connect,createConnection instead + * removed; query alias methods 1149804c + * removed; MongooseNumber + * changed; now creating indexes in background by default + * changed; strict mode now enabled by default (#952) + * changed; doc#modifiedPaths is now a method (#950) + * changed; getters no longer cast (#820); casting happens during set + * fixed; no need to pass updateArg to findOneAndUpdate (#931) + * fixed: utils.merge bug when merging nested non-objects. [treygriffith] + * fixed; strict:throw should produce errors in findAndModify (#963) + * fixed; findAndUpdate no longer overwrites document (#962) + * fixed; setting default DocumentArrays (#953) + * fixed; selection of _id with schema deselection (#954) + * fixed; ensure promise#error emits instanceof Error + * fixed; CursorStream: No stack overflow on any size result (#929) + * fixed; doc#remove now passes safe options + * fixed; invalid use of $set during $pop + * fixed; array#{$pop,$shift} mirror MongoDB behavior + * fixed; no longer test non-required vals in string match (#934) + * fixed; edge case with doc#inspect + * fixed; setter order (#665) + * fixed; setting invalid paths in strict mode (#916) + * fixed; handle docs without id in DocumentArray#id method (#897) + * fixed; do not save virtuals during model.update (#894) + * fixed; sub doc toObject virtuals application (#889) + * fixed; MongooseArray#pull of ObjectId (#881) + * fixed; handle passing db name with any repl set string + * fixed; default application of selected fields (#870) + * fixed; subdoc paths reported in validation errors (#725) + * fixed; incorrect reported num of affected docs in update ops (#862) + * fixed; connection assignment in Model#model (#853) + * fixed; stringifying arrays of docs (#852) + * fixed; modifying subdoc and parent array works (#842) + * fixed; passing undefined to next hook (#785) + * fixed; Query#{update,remove}() works without callbacks (#788) + * fixed; set/updating nested objects by parent pathname (#843) + * fixed; allow null in number arrays (#840) + * fixed; isNew on sub doc after insertion error (#837) + * fixed; if an insert fails, set isNew back to false [boutell] + * fixed; isSelected when only _id is selected (#730) + * fixed; setting an unset default value (#742) + * fixed; query#sort error messaging (#671) + * fixed; support for passing $options with $regex + * added; array of object literal notation in schema creates DocumentArrays + * added; gt,gte,lt,lte query support for arrays (#902) + * added; capped collection support (#938) + * added; document versioning support + * added; inclusion of deselected schema path (#786) + * added; non-atomic array#pop + * added; EmbeddedDocument constructor is now exposed in DocArray#create 7cf8beec + * added; mapReduce support (#678) + * added; support for a configurable minimize option #to{Object,JSON}(option) (#848) + * added; support for strict: `throws` [regality] + * added; support for named schema types (#795) + * added; to{Object,JSON} schema options (#805) + * added; findByIdAnd{Update,Remove}() + * added; findOneAnd{Update,Remove}() + * added; query.setOptions() + * added; instance.update() (#794) + * added; support specifying model in populate() [DanielBaulig] + * added; `lean` query option [gitfy] + * added; multi-atomic support to MongooseArray#nonAtomicPush + * added; support for $set + other $atomic ops on single array + * added; tests + * updated; driver to 1.0.2 + * updated; query.sort() syntax to mirror query.select() + * updated; clearer cast error msg for array numbers + * updated; docs + * updated; doc.clone 3x faster (#950) + * updated; only create _id if necessary (#950) + +2.7.3 / 2012-08-01 +================== + + * fixed; boolean $in queries (#998) + * fixed field selection option on subdocs (#1022) + +2.7.2 / 2012-07-18 +================== + + * fixed; callback to conn#disconnect is optional (#875) + * fixed; handle missing protocols in connection urls (#987) + * fixed; saving modified/removed subdocs (#975) + * updated; tests + +2.7.1 / 2012-06-26 +=================== + + * fixed; sharding: when a document holds a null as a value of the shard key + * fixed; update() using $pull on an array of Mixed (gh-735) + * deprecated; MongooseNumber#{inc, increment, decrement} methods + * tests; now using mocha + +2.7.0 / 2012-06-14 +=================== + + * added; deprecation warnings to methods being removed in 3.x + +2.6.8 / 2012-06-14 +=================== + + * fixed; edge case when using 'options' as a path name (#961) + +2.6.7 / 2012-06-08 +=================== + + * fixed; ensure promise#error always emits instanceof Error + * fixed; selection of _id w/ another excluded path (#954) + * fixed; setting default DocumentArrays (#953) + +2.6.6 / 2012-06-06 +=================== + + * fixed; stack overflow in query stream with large result sets (#929) + * added; $gt, $gte, $lt, $lte support to arrays (#902) + * fixed; pass option `safe` along to doc#remove() calls + +2.6.5 / 2012-05-24 +=================== + + * fixed; do not save virtuals in Model.update (#894) + * added; missing $ prefixed query aliases (going away in 3.x) (#884) [timoxley] + * fixed; setting invalid paths in strict mode (#916) + * fixed; resetting isNew after insert failure (#837) [boutell] + +2.6.4 / 2012-05-15 +=================== + + * updated; backport string regex $options to 2.x + * updated; use driver 1.0.2 (performance improvements) (#914) + * fixed; calling MongooseDocumentArray#id when the doc has no _id (#897) + +2.6.3 / 2012-05-03 +=================== + + * fixed; repl-set connectivity issues during failover on MongoDB 2.0.1 + * updated; driver to 1.0.0 + * fixed; virtuals application of subdocs when using toObject({ virtuals: true }) (#889) + * fixed; MongooseArray#pull of ObjectId correctly updates the array itself (#881) + +2.6.2 / 2012-04-30 +=================== + + * fixed; default field application of selected fields (#870) + +2.6.1 / 2012-04-30 +=================== + + * fixed; connection assignment in mongoose#model (#853, #877) + * fixed; incorrect reported num of affected docs in update ops (#862) + +2.6.0 / 2012-04-19 +=================== + + * updated; hooks.js to 0.2.1 + * fixed; issue with passing undefined to a hook callback. thanks to [chrisleishman] for reporting. + * fixed; updating/setting nested objects in strict schemas (#843) as reported by [kof] + * fixed; Query#{update,remove}() work without callbacks again (#788) + * fixed; modifying subdoc along with parent array $atomic op (#842) + +2.5.14 / 2012-04-13 +=================== + + * fixed; setting an unset default value (#742) + * fixed; doc.isSelected(otherpath) when only _id is selected (#730) + * updated; docs + +2.5.13 / 2012-03-22 +=================== + + * fixed; failing validation of unselected required paths (#730,#713) + * fixed; emitting connection error when only one listener (#759) + * fixed; MongooseArray#splice was not returning values (#784) [chrisleishman] + +2.5.12 / 2012-03-21 +=================== + + * fixed; honor the `safe` option in all ensureIndex calls + * updated; node-mongodb-native driver to 0.9.9-7 + +2.5.11 / 2012-03-15 +=================== + + * added; introspection for getters/setters (#745) + * updated; node-mongodb-driver to 0.9.9-5 + * added; tailable method to Query (#769) [holic] + * fixed; Number min/max validation of null (#764) [btamas] + * added; more flexible user/password connection options (#738) [KarneAsada] + +2.5.10 / 2012-03-06 +=================== + + * updated; node-mongodb-native driver to 0.9.9-4 + * added; Query#comment() + * fixed; allow unsetting arrays + * fixed; hooking the set method of subdocuments (#746) + * fixed; edge case in hooks + * fixed; allow $id and $ref in queries (fixes compatibility with mongoose-dbref) (#749) [richtera] + * added; default path selection to SchemaTypes + +2.5.9 / 2012-02-22 +=================== + + * fixed; properly cast nested atomic update operators for sub-documents + +2.5.8 / 2012-02-21 +=================== + + * added; post 'remove' middleware includes model that was removed (#729) [timoxley] + +2.5.7 / 2012-02-09 +=================== + + * fixed; RegExp validators on node >= v0.6.x + +2.5.6 / 2012-02-09 +=================== + + * fixed; emit errors returned from db.collection() on the connection (were being swallowed) + * added; can add multiple validators in your schema at once (#718) [diogogmt] + * fixed; strict embedded documents (#717) + * updated; docs [niemyjski] + * added; pass number of affected docs back in model.update/save + +2.5.5 / 2012-02-03 +=================== + + * fixed; RangeError: maximum call stack exceed error when removing docs with Number _id (#714) + +2.5.4 / 2012-02-03 +=================== + + * fixed; RangeError: maximum call stack exceed error (#714) + +2.5.3 / 2012-02-02 +=================== + + * added; doc#isSelected(path) + * added; query#equals() + * added; beta sharding support + * added; more descript error msgs (#700) [obeleh] + * added; document.modifiedPaths (#709) [ljharb] + * fixed; only functions can be added as getters/setters (#707,704) [ljharb] + +2.5.2 / 2012-01-30 +=================== + + * fixed; rollback -native driver to 0.9.7-3-5 (was causing timeouts and other replica set weirdness) + * deprecated; MongooseNumber (will be moved to a separate repo for 3.x) + * added; init event is emitted on schemas + +2.5.1 / 2012-01-27 +=================== + + * fixed; honor strict schemas in Model.update (#699) + +2.5.0 / 2012-01-26 +=================== + + * added; doc.toJSON calls toJSON on embedded docs when exists [jerem] + * added; populate support for refs of type Buffer (#686) [jerem] + * added; $all support for ObjectIds and Dates (#690) + * fixed; virtual setter calling on instantiation when strict: true (#682) [hunterloftis] + * fixed; doc construction triggering getters (#685) + * fixed; MongooseBuffer check in deepEquals (#688) + * fixed; range error when using Number _ids with `instance.save()` (#691) + * fixed; isNew on embedded docs edge case (#680) + * updated; driver to 0.9.8-3 + * updated; expose `model()` method within static methods + +2.4.10 / 2012-01-10 +=================== + + * added; optional getter application in .toObject()/.toJSON() (#412) + * fixed; nested $operators in $all queries (#670) + * added; $nor support (#674) + * fixed; bug when adding nested schema (#662) [paulwe] + +2.4.9 / 2012-01-04 +=================== + + * updated; driver to 0.9.7-3-5 to fix Linux performance degradation on some boxes + +2.4.8 / 2011-12-22 +=================== + + * updated; bump -native to 0.9.7.2-5 + * fixed; compatibility with date.js (#646) [chrisleishman] + * changed; undocumented schema "lax" option to "strict" + * fixed; default value population for strict schemas + * updated; the nextTick helper for small performance gain. 1bee2a2 + +2.4.7 / 2011-12-16 +=================== + + * fixed; bug in 2.4.6 with path setting + * updated; bump -native to 0.9.7.2-1 + * added; strict schema option [nw] + +2.4.6 / 2011-12-16 +=================== + + * fixed; conflicting mods on update bug [sirlantis] + * improved; doc.id getter performance + +2.4.5 / 2011-12-14 +=================== + + * fixed; bad MongooseArray behavior in 2.4.2 - 2.4.4 + +2.4.4 / 2011-12-14 +=================== + + * fixed; MongooseArray#doAtomics throwing after sliced + +2.4.3 / 2011-12-14 +=================== + + * updated; system.profile schema for MongoDB 2x + +2.4.2 / 2011-12-12 +=================== + + * fixed; partially populating multiple children of subdocs (#639) [kenpratt] + * fixed; allow Update of numbers to null (#640) [jerem] + +2.4.1 / 2011-12-02 +=================== + + * added; options support for populate() queries + * updated; -native driver to 0.9.7-1.4 + +2.4.0 / 2011-11-29 +=================== + + * added; QueryStreams (#614) + * added; debug print mode for development + * added; $within support to Array queries (#586) [ggoodale] + * added; $centerSphere query support + * fixed; $within support + * added; $unset is now used when setting a path to undefined (#519) + * added; query#batchSize support + * updated; docs + * updated; -native driver to 0.9.7-1.3 (provides Windows support) + +2.3.13 / 2011-11-15 +=================== + + * fixed; required validation for Refs (#612) [ded] + * added; $nearSphere support for Arrays (#610) + +2.3.12 / 2011-11-09 +=================== + + * fixed; regression, objects passed to Model.update should not be changed (#605) + * fixed; regression, empty Model.update should not be executed + +2.3.11 / 2011-11-08 +=================== + + * fixed; using $elemMatch on arrays of Mixed types (#591) + * fixed; allow using $regex when querying Arrays (#599) + * fixed; calling Model.update with no atomic keys (#602) + +2.3.10 / 2011-11-05 +=================== + + * fixed; model.update casting for nested paths works (#542) + +2.3.9 / 2011-11-04 +================== + + * fixed; deepEquals check for MongooseArray returned false + * fixed; reset modified flags of embedded docs after save [gitfy] + * fixed; setting embedded doc with identical values no longer marks modified [gitfy] + * updated; -native driver to 0.9.6.23 [mlazarov] + * fixed; Model.update casting (#542, #545, #479) + * fixed; populated refs no longer fail required validators (#577) + * fixed; populating refs of objects with custom ids works + * fixed; $pop & $unset work with Model.update (#574) + * added; more helpful debugging message for Schema#add (#578) + * fixed; accessing .id when no _id exists now returns null (#590) + +2.3.8 / 2011-10-26 +================== + + * added; callback to query#findOne is now optional (#581) + +2.3.7 / 2011-10-24 +================== + + * fixed; wrapped save/remove callbacks in nextTick to mitigate -native swallowing thrown errors + +2.3.6 / 2011-10-21 +================== + + * fixed; exclusion of embedded doc _id from query results (#541) + +2.3.5 / 2011-10-19 +================== + + * fixed; calling queries without passing a callback works (#569) + * fixed; populate() works with String and Number _ids too (#568) + +2.3.4 / 2011-10-18 +================== + + * added; Model.create now accepts an array as a first arg + * fixed; calling toObject on a DocumentArray with nulls no longer throws + * fixed; calling inspect on a DocumentArray with nulls no longer throws + * added; MongooseArray#unshift support + * fixed; save hooks now fire on embedded documents [gitfy] (#456) + * updated; -native driver to 0.9.6-22 + * fixed; correctly pass $addToSet op instead of $push + * fixed; $addToSet properly detects dates + * fixed; $addToSet with multiple items works + * updated; better node 0.6 Buffer support + +2.3.3 / 2011-10-12 +================== + + * fixed; population conditions in multi-query settings [vedmalex] (#563) + * fixed; now compatible with Node v0.5.x + +2.3.2 / 2011-10-11 +================== + + * fixed; population of null subdoc properties no longer hangs (#561) + +2.3.1 / 2011-10-10 +================== + + * added; support for Query filters to populate() [eneko] + * fixed; querying with number no longer crashes mongodb (#555) [jlbyrey] + * updated; version of -native driver to 0.9.6-21 + * fixed; prevent query callbacks that throw errors from corrupting -native connection state + +2.3.0 / 2011-10-04 +================== + + * fixed; nulls as default values for Boolean now works as expected + * updated; version of -native driver to 0.9.6-20 + +2.2.4 / 2011-10-03 +================== + + * fixed; populate() works when returned array contains undefined/nulls + +2.2.3 / 2011-09-29 +================== + + * updated; version of -native driver to 0.9.6-19 + +2.2.2 / 2011-09-28 +================== + + * added; $regex support to String [davidandrewcope] + * added; support for other contexts like repl etc (#535) + * fixed; clear modified state properly after saving + * added; $addToSet support to Array + +2.2.1 / 2011-09-22 +================== + + * more descript error when casting undefined to string + * updated; version of -native driver to 0.9.6-18 + +2.2.0 / 2011-09-22 +================== + + * fixed; maxListeners warning on schemas with many arrays (#530) + * changed; return / apply defaults based on fields selected in query (#423) + * fixed; correctly detect Mixed types within schema arrays (#532) + +2.1.4 / 2011-09-20 +================== + + * fixed; new private methods that stomped on users code + * changed; finished removing old "compat" support which did nothing + +2.1.3 / 2011-09-16 +================== + + * updated; version of -native driver to 0.9.6-15 + * added; emit `error` on connection when open fails [edwardhotchkiss] + * added; index support to Buffers (thanks justmoon for helping track this down) + * fixed; passing collection name via schema in conn.model() now works (thanks vedmalex for reporting) + +2.1.2 / 2011-09-07 +================== + + * fixed; Query#find with no args no longer throws + +2.1.1 / 2011-09-07 +================== + + * added; support Model.count(fn) + * fixed; compatibility with node >=0.4.0 < 0.4.3 + * added; pass model.options.safe through with .save() so w:2, wtimeout:5000 options work [andrewjstone] + * added; support for $type queries + * added; support for Query#or + * added; more tests + * optimized populate queries + +2.1.0 / 2011-09-01 +================== + + * changed; document#validate is a public method + * fixed; setting number to same value no longer marks modified (#476) [gitfy] + * fixed; Buffers shouldn't have default vals + * added; allow specifying collection name in schema (#470) [ixti] + * fixed; reset modified paths and atomics after saved (#459) + * fixed; set isNew on embedded docs to false after save + * fixed; use self to ensure proper scope of options in doOpenSet (#483) [andrewjstone] + +2.0.4 / 2011-08-29 +================== + + * Fixed; Only send the depopulated ObjectId instead of the entire doc on save (DBRefs) + * Fixed; Properly cast nested array values in Model.update (the data was stored in Mongo incorrectly but recast on document fetch was "fixing" it) + +2.0.3 / 2011-08-28 +================== + + * Fixed; manipulating a populated array no longer causes infinite loop in BSON serializer during save (#477) + * Fixed; populating an empty array no longer hangs foreeeeeeeever (#481) + +2.0.2 / 2011-08-25 +================== + + * Fixed; Maintain query option key order (fixes 'bad hint' error from compound query hints) + +2.0.1 / 2011-08-25 +================== + + * Fixed; do not over-write the doc when no valide props exist in Model.update (#473) + +2.0.0 / 2011-08-24 +=================== + + * Added; support for Buffers [justmoon] + * Changed; improved error handling [maelstrom] + * Removed: unused utils.erase + * Fixed; support for passing other context object into Schemas (#234) [Sija] + * Fixed; getters are no longer circular refs to themselves (#366) + * Removed; unused compat.js + * Fixed; getter/setter scopes are set properly + * Changed; made several private properties more obvious by prefixing _ + * Added; DBRef support [guille] + * Changed; removed support for multiple collection names per model + * Fixed; no longer applying setters when document returned from db + * Changed; default auto_reconnect to true + * Changed; Query#bind no longer clones the query + * Fixed; Model.update now accepts $pull, $inc and friends (#404) + * Added; virtual type option support [nw] + +1.8.4 / 2011-08-21 +=================== + + * Fixed; validation bug when instantiated with non-schema properties (#464) [jmreidy] + +1.8.3 / 2011-08-19 +=================== + + * Fixed; regression in connection#open [jshaw86] + +1.8.2 / 2011-08-17 +=================== + + * fixed; reset connection.readyState after failure [tomseago] + * fixed; can now query positionally for non-embedded docs (arrays of numbers/strings etc) + * fixed; embedded document query casting + * added; support for passing options to node-mongo-native db, server, and replsetserver [tomseago] + +1.8.1 / 2011-08-10 +=================== + + * fixed; ObjectIds were always marked modified + * fixed; can now query using document instances + * fixed; can now query/update using documents with subdocs + +1.8.0 / 2011-08-04 +=================== + + * fixed; can now use $all with String and Number + * fixed; can query subdoc array with $ne: null + * fixed; instance.subdocs#id now works with custom _ids + * fixed; do not apply setters when doc returned from db (change in bad behavior) + +1.7.4 / 2011-07-25 +=================== + + * fixed; sparse now a valid seperate schema option + * fixed; now catching cast errors in queries + * fixed; calling new Schema with object created in vm.runInNewContext now works (#384) [Sija] + * fixed; String enum was disallowing null + * fixed; Find by nested document _id now works (#389) + +1.7.3 / 2011-07-16 +=================== + + * fixed; MongooseArray#indexOf now works with ObjectIds + * fixed; validation scope now set properly (#418) + * fixed; added missing colors dependency (#398) + +1.7.2 / 2011-07-13 +=================== + + * changed; node-mongodb-native driver to v0.9.6.7 + +1.7.1 / 2011-07-12 +=================== + + * changed; roll back node-mongodb-native driver to v0.9.6.4 + +1.7.0 / 2011-07-12 +=================== + + * fixed; collection name misspelling [mathrawka] + * fixed; 2nd param is required for ReplSetServers [kevinmarvin] + * fixed; MongooseArray behaves properly with Object.keys + * changed; node-mongodb-native driver to v0.9.6.6 + * fixed/changed; Mongodb segfault when passed invalid ObjectId (#407) + - This means invalid data passed to the ObjectId constructor will now error + +1.6.0 / 2011-07-07 +=================== + + * changed; .save() errors are now emitted on the instances db instead of the instance 9782463fc + * fixed; errors occurring when creating indexes now properly emit on db + * added; $maxDistance support to MongooseArrays + * fixed; RegExps now work with $all + * changed; node-mongodb-native driver to v0.9.6.4 + * fixed; model names are now accessible via .modelName + * added; Query#slaveOk support + +1.5.0 / 2011-06-27 +=================== + + * changed; saving without a callback no longer ignores the error (@bnoguchi) + * changed; hook-js version bump to 0.1.9 + * changed; node-mongodb-native version bumped to 0.9.6.1 - When .remove() doesn't + return an error, null is no longer passed. + * fixed; two memory leaks (@justmoon) + * added; sparse index support + * added; more ObjectId conditionals (gt, lt, gte, lte) (@phillyqueso) + * added; options are now passed in model#remote (@JerryLuke) + +1.4.0 / 2011-06-10 +=================== + + * bumped hooks-js dependency (fixes issue passing null as first arg to next()) + * fixed; document#inspect now works properly with nested docs + * fixed; 'set' now works as a schema attribute (GH-365) + * fixed; _id is now set properly within pre-init hooks (GH-289) + * added; Query#distinct / Model#distinct support (GH-155) + * fixed; embedded docs now can use instance methods (GH-249) + * fixed; can now overwrite strings conflicting with schema type + +1.3.7 / 2011-06-03 +=================== + + * added MongooseArray#splice support + * fixed; 'path' is now a valid Schema pathname + * improved hooks (utilizing https://github.com/bnoguchi/hooks-js) + * fixed; MongooseArray#$shift now works (never did) + * fixed; Document.modified no longer throws + * fixed; modifying subdoc property sets modified paths for subdoc and parent doc + * fixed; marking subdoc path as modified properly persists the value to the db + * fixed; RexExps can again be saved ( #357 ) + +1.3.6 / 2011-05-18 +=================== + + * fixed; corrected casting for queries against array types + * added; Document#set now accepts Document instances + +1.3.5 / 2011-05-17 +=================== + + * fixed; $ne queries work properly with single vals + * added; #inspect() methods to improve console.log output + +1.3.4 / 2011-05-17 +=================== + + * fixed; find by Date works as expected (#336) + * added; geospatial 2d index support + * added; support for $near (#309) + * updated; node-mongodb-native driver + * fixed; updating numbers work (#342) + * added; better error msg when try to remove an embedded doc without an _id (#307) + * added; support for 'on-the-fly' schemas (#227) + * changed; virtual id getters can now be skipped + * fixed; .index() called on subdoc schema now works as expected + * fixed; db.setProfile() now buffers until the db is open (#340) + +1.3.3 / 2011-04-27 +=================== + + * fixed; corrected query casting on nested mixed types + +1.3.2 / 2011-04-27 +=================== + + * fixed; query hints now retain key order + +1.3.1 / 2011-04-27 +=================== + + * fixed; setting a property on an embedded array no longer overwrites entire array (GH-310) + * fixed; setting nested properties works when sibling prop is named "type" + * fixed; isModified is now much finer grained when .set() is used (GH-323) + * fixed; mongoose.model() and connection.model() now return the Model (GH-308, GH-305) + * fixed; can now use $gt, $lt, $gte, $lte with String schema types (GH-317) + * fixed; .lowercase() -> .toLowerCase() in pluralize() + * fixed; updating an embedded document by index works (GH-334) + * changed; .save() now passes the instance to the callback (GH-294, GH-264) + * added; can now query system.profile and system.indexes collections + * added; db.model('system.profile') is now included as a default Schema + * added; db.setProfiling(level, ms, callback) + * added; Query#hint() support + * added; more tests + * updated node-mongodb-native to 0.9.3 + +1.3.0 / 2011-04-19 +=================== + + * changed; save() callbacks now fire only once on failed validation + * changed; Errors returned from save() callbacks now instances of ValidationError + * fixed; MongooseArray#indexOf now works properly + +1.2.0 / 2011-04-11 +=================== + + * changed; MongooseNumber now casts empty string to null + +1.1.25 / 2011-04-08 +=================== + + * fixed; post init now fires at proper time + +1.1.24 / 2011-04-03 +=================== + + * fixed; pushing an array onto an Array works on existing docs + +1.1.23 / 2011-04-01 +=================== + + * Added Model#model + +1.1.22 / 2011-03-31 +=================== + + * Fixed; $in queries on mixed types now work + +1.1.21 / 2011-03-31 +=================== + + * Fixed; setting object root to null/undefined works + +1.1.20 / 2011-03-31 +=================== + + * Fixed; setting multiple props on null field works + +1.1.19 / 2011-03-31 +=================== + + * Fixed; no longer using $set on paths to an unexisting fields + +1.1.18 / 2011-03-30 +=================== + + * Fixed; non-mixed type object setters work after initd from null + +1.1.17 / 2011-03-30 +=================== + + * Fixed; nested object property access works when root initd with null value + +1.1.16 / 2011-03-28 +=================== + + * Fixed; empty arrays are now saved + +1.1.15 / 2011-03-28 +=================== + + * Fixed; `null` and `undefined` are set atomically. + +1.1.14 / 2011-03-28 +=================== + + * Changed; more forgiving date casting, accepting '' as null. + +1.1.13 / 2011-03-26 +=================== + + * Fixed setting values as `undefined`. + +1.1.12 / 2011-03-26 +=================== + + * Fixed; nested objects now convert to JSON properly + * Fixed; setting nested objects directly now works + * Update node-mongodb-native + +1.1.11 / 2011-03-25 +=================== + + * Fixed for use of `type` as a key. + +1.1.10 / 2011-03-23 +=================== + + * Changed; Make sure to only ensure indexes while connected + +1.1.9 / 2011-03-2 +================== + + * Fixed; Mixed can now default to empty arrays + * Fixed; keys by the name 'type' are now valid + * Fixed; null values retrieved from the database are hydrated as null values. + * Fixed repeated atomic operations when saving a same document twice. + +1.1.8 / 2011-03-23 +================== + + * Fixed 'id' overriding. [bnoguchi] + +1.1.7 / 2011-03-22 +================== + + * Fixed RegExp query casting when querying against an Array of Strings [bnoguchi] + * Fixed getters/setters for nested virtualsl. [bnoguchi] + +1.1.6 / 2011-03-22 +================== + + * Only doValidate when path exists in Schema [aheckmann] + * Allow function defaults for Array types [aheckmann] + * Fix validation hang [aheckmann] + * Fix setting of isRequired of SchemaType [aheckmann] + * Fix SchemaType#required(false) filter [aheckmann] + * More backwards compatibility [aheckmann] + * More tests [aheckmann] + +1.1.5 / 2011-03-14 +================== + + * Added support for `uri, db, fn` and `uri, fn` signatures for replica sets. + * Improved/extended replica set tests. + +1.1.4 / 2011-03-09 +================== + + * Fixed; running an empty Query doesn't throw. [aheckmann] + * Changed; Promise#addBack returns promise. [aheckmann] + * Added streaming cursor support. [aheckmann] + * Changed; Query#update defaults to use$SetOnSave now. [brian] + * Added more docs. + +1.1.3 / 2011-03-04 +================== + + * Added Promise#resolve [aheckmann] + * Fixed backward compatibility with nulls [aheckmann] + * Changed; Query#{run,exec} return promises [aheckmann] + +1.1.2 / 2011-03-03 +================== + + * Restored Query#exec and added notion of default operation [brian] + * Fixed ValidatorError messages [brian] + +1.1.1 / 2011-03-01 +================== + + * Added SchemaType String `lowercase`, `uppercase`, `trim`. + * Public exports (`Model`, `Document`) and tests. + * Added ObjectId casting support for `Document`s. + +1.1.0 / 2011-02-25 +================== + + * Added support for replica sets. + +1.0.16 / 2011-02-18 +=================== + + * Added $nin as another whitelisted $conditional for SchemaArray [brian] + * Changed #with to #where [brian] + * Added ability to use $in conditional with Array types [brian] + +1.0.15 / 2011-02-18 +=================== + + * Added `id` virtual getter for documents to easily access the hexString of + the `_id`. + +1.0.14 / 2011-02-17 +=================== + + * Fix for arrays within subdocuments [brian] + +1.0.13 / 2011-02-16 +=================== + + * Fixed embedded documents saving. + +1.0.12 / 2011-02-14 +=================== + + * Minor refactorings [brian] + +1.0.11 / 2011-02-14 +=================== + + * Query refactor and $ne, $slice, $or, $size, $elemMatch, $nin, $exists support [brian] + * Named scopes sugar [brian] + +1.0.10 / 2011-02-11 +=================== + + * Updated node-mongodb-native driver [thanks John Allen] + +1.0.9 / 2011-02-09 +================== + + * Fixed single member arrays as defaults [brian] + +1.0.8 / 2011-02-09 +================== + + * Fixed for collection-level buffering of commands [gitfy] + * Fixed `Document#toJSON` [dalejefferson] + * Fixed `Connection` authentication [robrighter] + * Fixed clash of accessors in getters/setters [eirikurn] + * Improved `Model#save` promise handling + +1.0.7 / 2011-02-05 +================== + + * Fixed memory leak warnings for test suite on 0.3 + * Fixed querying documents that have an array that contain at least one + specified member. [brian] + * Fixed default value for Array types (fixes GH-210). [brian] + * Fixed example code. + +1.0.6 / 2011-02-03 +================== + + * Fixed `post` middleware + * Fixed; it's now possible to instantiate a model even when one of the paths maps + to an undefined value [brian] + +1.0.5 / 2011-02-02 +================== + + * Fixed; combo $push and $pushAll auto-converts into a $pushAll [brian] + * Fixed; combo $pull and $pullAll auto-converts to a single $pullAll [brian] + * Fixed; $pullAll now removes said members from array before save (so it acts just + like pushAll) [brian] + * Fixed; multiple $pulls and $pushes become a single $pullAll and $pushAll. + Moreover, $pull now modifies the array before save to reflect the immediate + change [brian] + * Added tests for nested shortcut getters [brian] + * Added tests that show that Schemas with nested Arrays don't apply defaults + [brian] + +1.0.4 / 2011-02-02 +================== + + * Added MongooseNumber#toString + * Added MongooseNumber unit tests + +1.0.3 / 2011-02-02 +================== + + * Make sure safe mode works with Model#save + * Changed Schema options: safe mode is now the default + * Updated node-mongodb-native to HEAD + +1.0.2 / 2011-02-02 +================== + + * Added a Model.create shortcut for creating documents. [brian] + * Fixed; we can now instantiate models with hashes that map to at least one + null value. [brian] + * Fixed Schema with more than 2 nested levels. [brian] + +1.0.1 / 2011-02-02 +================== + + * Improved `MongooseNumber`, works almost like the native except for `typeof` + not being `'number'`. diff --git a/node_modules/mongoose/README.md b/node_modules/mongoose/README.md new file mode 100644 index 0000000..550da7b --- /dev/null +++ b/node_modules/mongoose/README.md @@ -0,0 +1,321 @@ +# Mongoose + +Mongoose is a [MongoDB](https://www.mongodb.org/) object modeling tool designed to work in an asynchronous environment. + +[![Slack Status](http://slack.mongoosejs.io/badge.svg)](http://slack.mongoosejs.io) +[![Build Status](https://api.travis-ci.org/Automattic/mongoose.svg?branch=master)](https://travis-ci.org/Automattic/mongoose) +[![NPM version](https://badge.fury.io/js/mongoose.svg)](http://badge.fury.io/js/mongoose) +[![Dependency Status](https://gemnasium.com/Automattic/mongoose.svg)](https://gemnasium.com/Automattic/mongoose) + +## Documentation + +[mongoosejs.com](http://mongoosejs.com/) + +## Support + + - [Stack Overflow](http://stackoverflow.com/questions/tagged/mongoose) + - [Bug Reports](https://github.com/Automattic/mongoose/issues/) + - [Mongoose Slack Channel](http://slack.mongoosejs.io/) + - [Help Forum](http://groups.google.com/group/mongoose-orm) + - [MongoDB Support](https://docs.mongodb.org/manual/support/) + +## Plugins + +Check out the [plugins search site](http://plugins.mongoosejs.io/) to see hundreds of related modules from the community. + +Build your own Mongoose plugin through [generator-mongoose-plugin](https://github.com/huei90/generator-mongoose-plugin). + +## Contributors + +View all 200+ [contributors](https://github.com/Automattic/mongoose/graphs/contributors). Stand up and be counted as a [contributor](https://github.com/Automattic/mongoose/blob/master/CONTRIBUTING.md) too! + +## Live Examples + + +## Installation + +First install [node.js](http://nodejs.org/) and [mongodb](https://www.mongodb.org/downloads). Then: + +```sh +$ npm install mongoose +``` + +## Stability + +The current stable branch is [master](https://github.com/Automattic/mongoose/tree/master). The [3.8.x](https://github.com/Automattic/mongoose/tree/3.8.x) branch contains legacy support for the 3.x release series, which is no longer under active development as of September 2015. The [3.8.x docs](http://mongoosejs.com/docs/3.8.x/) are still available. + +## Overview + +### Connecting to MongoDB + +First, we need to define a connection. If your app uses only one database, you should use `mongoose.connect`. If you need to create additional connections, use `mongoose.createConnection`. + +Both `connect` and `createConnection` take a `mongodb://` URI, or the parameters `host, database, port, options`. + +```js +var mongoose = require('mongoose'); + +mongoose.connect('mongodb://localhost/my_database'); +``` + +Once connected, the `open` event is fired on the `Connection` instance. If you're using `mongoose.connect`, the `Connection` is `mongoose.connection`. Otherwise, `mongoose.createConnection` return value is a `Connection`. + +**Note:** _If the local connection fails then try using 127.0.0.1 instead of localhost. Sometimes issues may arise when the local hostname has been changed._ + +**Important!** Mongoose buffers all the commands until it's connected to the database. This means that you don't have to wait until it connects to MongoDB in order to define models, run queries, etc. + +### Defining a Model + +Models are defined through the `Schema` interface. + +```js +var Schema = mongoose.Schema, + ObjectId = Schema.ObjectId; + +var BlogPost = new Schema({ + author : ObjectId, + title : String, + body : String, + date : Date +}); +``` + +Aside from defining the structure of your documents and the types of data you're storing, a Schema handles the definition of: + +* [Validators](http://mongoosejs.com/docs/validation.html) (async and sync) +* [Defaults](http://mongoosejs.com/docs/api.html#schematype_SchemaType-default) +* [Getters](http://mongoosejs.com/docs/api.html#schematype_SchemaType-get) +* [Setters](http://mongoosejs.com/docs/api.html#schematype_SchemaType-set) +* [Indexes](http://mongoosejs.com/docs/guide.html#indexes) +* [Middleware](http://mongoosejs.com/docs/middleware.html) +* [Methods](http://mongoosejs.com/docs/guide.html#methods) definition +* [Statics](http://mongoosejs.com/docs/guide.html#statics) definition +* [Plugins](http://mongoosejs.com/docs/plugins.html) +* [pseudo-JOINs](http://mongoosejs.com/docs/populate.html) + +The following example shows some of these features: + +```js +var Comment = new Schema({ + name: { type: String, default: 'hahaha' }, + age: { type: Number, min: 18, index: true }, + bio: { type: String, match: /[a-z]/ }, + date: { type: Date, default: Date.now }, + buff: Buffer +}); + +// a setter +Comment.path('name').set(function (v) { + return capitalize(v); +}); + +// middleware +Comment.pre('save', function (next) { + notify(this.get('email')); + next(); +}); +``` + +Take a look at the example in `examples/schema.js` for an end-to-end example of a typical setup. + +### Accessing a Model + +Once we define a model through `mongoose.model('ModelName', mySchema)`, we can access it through the same function + +```js +var myModel = mongoose.model('ModelName'); +``` + +Or just do it all at once + +```js +var MyModel = mongoose.model('ModelName', mySchema); +``` + +The first argument is the _singular_ name of the collection your model is for. **Mongoose automatically looks for the _plural_ version of your model name.** For example, if you use + +```js +var MyModel = mongoose.model('Ticket', mySchema); +``` + +Then Mongoose will create the model for your __tickets__ collection, not your __ticket__ collection. + +Once we have our model, we can then instantiate it, and save it: + +```js +var instance = new MyModel(); +instance.my.key = 'hello'; +instance.save(function (err) { + // +}); +``` + +Or we can find documents from the same collection + +```js +MyModel.find({}, function (err, docs) { + // docs.forEach +}); +``` + +You can also `findOne`, `findById`, `update`, etc. For more details check out [the docs](http://mongoosejs.com/docs/queries.html). + +**Important!** If you opened a separate connection using `mongoose.createConnection()` but attempt to access the model through `mongoose.model('ModelName')` it will not work as expected since it is not hooked up to an active db connection. In this case access your model through the connection you created: + +```js +var conn = mongoose.createConnection('your connection string'), + MyModel = conn.model('ModelName', schema), + m = new MyModel; +m.save(); // works +``` + +vs + +```js +var conn = mongoose.createConnection('your connection string'), + MyModel = mongoose.model('ModelName', schema), + m = new MyModel; +m.save(); // does not work b/c the default connection object was never connected +``` + +### Embedded Documents + +In the first example snippet, we defined a key in the Schema that looks like: + +``` +comments: [Comment] +``` + +Where `Comment` is a `Schema` we created. This means that creating embedded documents is as simple as: + +```js +// retrieve my model +var BlogPost = mongoose.model('BlogPost'); + +// create a blog post +var post = new BlogPost(); + +// create a comment +post.comments.push({ title: 'My comment' }); + +post.save(function (err) { + if (!err) console.log('Success!'); +}); +``` + +The same goes for removing them: + +```js +BlogPost.findById(myId, function (err, post) { + if (!err) { + post.comments[0].remove(); + post.save(function (err) { + // do something + }); + } +}); +``` + +Embedded documents enjoy all the same features as your models. Defaults, validators, middleware. Whenever an error occurs, it's bubbled to the `save()` error callback, so error handling is a snap! + + +### Middleware + +See the [docs](http://mongoosejs.com/docs/middleware.html) page. + +#### Intercepting and mutating method arguments + +You can intercept method arguments via middleware. + +For example, this would allow you to broadcast changes about your Documents every time someone `set`s a path in your Document to a new value: + +```js +schema.pre('set', function (next, path, val, typel) { + // `this` is the current Document + this.emit('set', path, val); + + // Pass control to the next pre + next(); +}); +``` + +Moreover, you can mutate the incoming `method` arguments so that subsequent middleware see different values for those arguments. To do so, just pass the new values to `next`: + +```js +.pre(method, function firstPre (next, methodArg1, methodArg2) { + // Mutate methodArg1 + next("altered-" + methodArg1.toString(), methodArg2); +}); + +// pre declaration is chainable +.pre(method, function secondPre (next, methodArg1, methodArg2) { + console.log(methodArg1); + // => 'altered-originalValOfMethodArg1' + + console.log(methodArg2); + // => 'originalValOfMethodArg2' + + // Passing no arguments to `next` automatically passes along the current argument values + // i.e., the following `next()` is equivalent to `next(methodArg1, methodArg2)` + // and also equivalent to, with the example method arg + // values, `next('altered-originalValOfMethodArg1', 'originalValOfMethodArg2')` + next(); +}); +``` + +#### Schema gotcha + +`type`, when used in a schema has special meaning within Mongoose. If your schema requires using `type` as a nested property you must use object notation: + +```js +new Schema({ + broken: { type: Boolean }, + asset: { + name: String, + type: String // uh oh, it broke. asset will be interpreted as String + } +}); + +new Schema({ + works: { type: Boolean }, + asset: { + name: String, + type: { type: String } // works. asset is an object with a type property + } +}); +``` + +### Driver Access + +Mongoose is built on top of the [official MongoDB Node.js driver](https://github.com/mongodb/node-mongodb-native). Each mongoose model keeps a reference to a [native MongoDB driver collection](http://mongodb.github.io/node-mongodb-native/2.1/api/Collection.html). The collection object can be accessed using `YourModel.collection`. However, using the collection object directly bypasses all mongoose features, including hooks, validation, etc. The one +notable exception that `YourModel.collection` still buffers +commands. As such, `YourModel.collection.find()` will **not** +return a cursor. + +## API Docs + +Find the API docs [here](http://mongoosejs.com/docs/api.html), generated using [dox](https://github.com/tj/dox) +and [acquit](https://github.com/vkarpov15/acquit). + +## License + +Copyright (c) 2010 LearnBoost <dev@learnboost.com> + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/mongoose/examples/README.md b/node_modules/mongoose/examples/README.md new file mode 100644 index 0000000..cb32898 --- /dev/null +++ b/node_modules/mongoose/examples/README.md @@ -0,0 +1,41 @@ +This directory contains runnable sample mongoose programs. + +To run: + + - first install [Node.js](http://nodejs.org/) + - from the root of the project, execute `npm install -d` + - in the example directory, run `npm install -d` + - from the command line, execute: `node example.js`, replacing "example.js" with the name of a program. + + +Goal is to show: + +- ~~global schemas~~ +- ~~GeoJSON schemas / use (with crs)~~ +- text search (once MongoDB removes the "Experimental/beta" label) +- ~~lean queries~~ +- ~~statics~~ +- methods and statics on subdocs +- custom types +- ~~querybuilder~~ +- ~~promises~~ +- accessing driver collection, db +- ~~connecting to replica sets~~ +- connecting to sharded clusters +- enabling a fail fast mode +- on the fly schemas +- storing files +- ~~map reduce~~ +- ~~aggregation~~ +- advanced hooks +- using $elemMatch to return a subset of an array +- query casting +- upserts +- pagination +- express + mongoose session handling +- ~~group by (use aggregation)~~ +- authentication +- schema migration techniques +- converting documents to plain objects (show transforms) +- how to $unset + diff --git a/node_modules/mongoose/examples/aggregate/aggregate.js b/node_modules/mongoose/examples/aggregate/aggregate.js new file mode 100644 index 0000000..793c8cb --- /dev/null +++ b/node_modules/mongoose/examples/aggregate/aggregate.js @@ -0,0 +1,103 @@ + +// import async to make control flow simplier +var async = require('async'); + +// import the rest of the normal stuff +var mongoose = require('../../lib'); + +require('./person.js')(); + +var Person = mongoose.model('Person'); + +// define some dummy data +var data = [ + { + name: 'bill', + age: 25, + birthday: new Date().setFullYear((new Date().getFullYear() - 25)), + gender: 'Male', + likes: ['movies', 'games', 'dogs'] + }, + { + name: 'mary', + age: 30, + birthday: new Date().setFullYear((new Date().getFullYear() - 30)), + gender: 'Female', + likes: ['movies', 'birds', 'cats'] + }, + { + name: 'bob', + age: 21, + birthday: new Date().setFullYear((new Date().getFullYear() - 21)), + gender: 'Male', + likes: ['tv', 'games', 'rabbits'] + }, + { + name: 'lilly', + age: 26, + birthday: new Date().setFullYear((new Date().getFullYear() - 26)), + gender: 'Female', + likes: ['books', 'cats', 'dogs'] + }, + { + name: 'alucard', + age: 1000, + birthday: new Date().setFullYear((new Date().getFullYear() - 1000)), + gender: 'Male', + likes: ['glasses', 'wine', 'the night'] + } +]; + + +mongoose.connect('mongodb://localhost/persons', function(err) { + if (err) throw err; + + // create all of the dummy people + async.each(data, function(item, cb) { + Person.create(item, cb); + }, function(err) { + if (err) { + // handle error + } + + // run an aggregate query that will get all of the people who like a given + // item. To see the full documentation on ways to use the aggregate + // framework, see http://docs.mongodb.org/manual/core/aggregation/ + Person.aggregate( + // select the fields we want to deal with + {$project: {name: 1, likes: 1}}, + // unwind 'likes', which will create a document for each like + {$unwind: '$likes'}, + // group everything by the like and then add each name with that like to + // the set for the like + {$group: { + _id: {likes: '$likes'}, + likers: {$addToSet: '$name'} + }}, + function(err, result) { + if (err) throw err; + console.log(result); + /* [ + { _id: { likes: 'the night' }, likers: [ 'alucard' ] }, + { _id: { likes: 'wine' }, likers: [ 'alucard' ] }, + { _id: { likes: 'books' }, likers: [ 'lilly' ] }, + { _id: { likes: 'glasses' }, likers: [ 'alucard' ] }, + { _id: { likes: 'birds' }, likers: [ 'mary' ] }, + { _id: { likes: 'rabbits' }, likers: [ 'bob' ] }, + { _id: { likes: 'cats' }, likers: [ 'lilly', 'mary' ] }, + { _id: { likes: 'dogs' }, likers: [ 'lilly', 'bill' ] }, + { _id: { likes: 'tv' }, likers: [ 'bob' ] }, + { _id: { likes: 'games' }, likers: [ 'bob', 'bill' ] }, + { _id: { likes: 'movies' }, likers: [ 'mary', 'bill' ] } + ] */ + + cleanup(); + }); + }); +}); + +function cleanup() { + Person.remove(function() { + mongoose.disconnect(); + }); +} diff --git a/node_modules/mongoose/examples/aggregate/package.json b/node_modules/mongoose/examples/aggregate/package.json new file mode 100644 index 0000000..53ed2e1 --- /dev/null +++ b/node_modules/mongoose/examples/aggregate/package.json @@ -0,0 +1,14 @@ +{ + "name": "aggregate-example", + "private": "true", + "version": "0.0.0", + "description": "deps for aggregate example", + "main": "aggregate.js", + "scripts": { + "test": "echo \"Error: no test specified\" && exit 1" + }, + "dependencies": { "async": "*" }, + "repository": "", + "author": "", + "license": "BSD" +} diff --git a/node_modules/mongoose/examples/aggregate/person.js b/node_modules/mongoose/examples/aggregate/person.js new file mode 100644 index 0000000..607bb07 --- /dev/null +++ b/node_modules/mongoose/examples/aggregate/person.js @@ -0,0 +1,17 @@ + +// import the necessary modules +var mongoose = require('../../lib'); +var Schema = mongoose.Schema; + +// create an export function to encapsulate the model creation +module.exports = function() { + // define schema + var PersonSchema = new Schema({ + name: String, + age: Number, + birthday: Date, + gender: String, + likes: [String] + }); + mongoose.model('Person', PersonSchema); +}; diff --git a/node_modules/mongoose/examples/doc-methods.js b/node_modules/mongoose/examples/doc-methods.js new file mode 100644 index 0000000..1f648b9 --- /dev/null +++ b/node_modules/mongoose/examples/doc-methods.js @@ -0,0 +1,77 @@ + +var mongoose = require('mongoose'); +var Schema = mongoose.Schema; + +console.log('Running mongoose version %s', mongoose.version); + +/** + * Schema + */ + +var CharacterSchema = Schema({ + name: { + type: String, + required: true + }, + health: { + type: Number, + min: 0, + max: 100 + } +}); + +/** + * Methods + */ + +CharacterSchema.methods.attack = function() { + console.log('%s is attacking', this.name); +}; + +/** + * Character model + */ + +var Character = mongoose.model('Character', CharacterSchema); + +/** + * Connect to the database on localhost with + * the default port (27017) + */ + +var dbname = 'mongoose-example-doc-methods-' + ((Math.random() * 10000) | 0); +var uri = 'mongodb://localhost/' + dbname; + +console.log('connecting to %s', uri); + +mongoose.connect(uri, function(err) { + // if we failed to connect, abort + if (err) throw err; + + // we connected ok + example(); +}); + +/** + * Use case + */ + +function example() { + Character.create({name: 'Link', health: 100}, function(err, link) { + if (err) return done(err); + console.log('found', link); + link.attack(); // 'Link is attacking' + done(); + }); +} + +/** + * Clean up + */ + +function done(err) { + if (err) console.error(err); + mongoose.connection.db.dropDatabase(function() { + mongoose.disconnect(); + }); +} diff --git a/node_modules/mongoose/examples/express/README.md b/node_modules/mongoose/examples/express/README.md new file mode 100644 index 0000000..7ba07b8 --- /dev/null +++ b/node_modules/mongoose/examples/express/README.md @@ -0,0 +1 @@ +Mongoose + Express examples diff --git a/node_modules/mongoose/examples/express/connection-sharing/README.md b/node_modules/mongoose/examples/express/connection-sharing/README.md new file mode 100644 index 0000000..fc709a3 --- /dev/null +++ b/node_modules/mongoose/examples/express/connection-sharing/README.md @@ -0,0 +1,6 @@ + +To run: + +- Execute `npm install` from this directory +- Execute `node app.js` +- Navigate to `localhost:8000` diff --git a/node_modules/mongoose/examples/express/connection-sharing/app.js b/node_modules/mongoose/examples/express/connection-sharing/app.js new file mode 100644 index 0000000..8fb2fee --- /dev/null +++ b/node_modules/mongoose/examples/express/connection-sharing/app.js @@ -0,0 +1,17 @@ + +var express = require('express'); +var mongoose = require('../../../lib'); + +var uri = 'mongodb://localhost/mongoose-shared-connection'; +global.db = mongoose.createConnection(uri); + +var routes = require('./routes'); + +var app = express(); +app.get('/', routes.home); +app.get('/insert', routes.insert); +app.get('/name', routes.modelName); + +app.listen(8000, function() { + console.log('listening on http://localhost:8000'); +}); diff --git a/node_modules/mongoose/examples/express/connection-sharing/modelA.js b/node_modules/mongoose/examples/express/connection-sharing/modelA.js new file mode 100644 index 0000000..78f9ff6 --- /dev/null +++ b/node_modules/mongoose/examples/express/connection-sharing/modelA.js @@ -0,0 +1,5 @@ +var Schema = require('../../../lib').Schema; +var mySchema = Schema({name: String}); + +/* global db */ +module.exports = db.model('MyModel', mySchema); diff --git a/node_modules/mongoose/examples/express/connection-sharing/package.json b/node_modules/mongoose/examples/express/connection-sharing/package.json new file mode 100644 index 0000000..e326165 --- /dev/null +++ b/node_modules/mongoose/examples/express/connection-sharing/package.json @@ -0,0 +1,14 @@ +{ + "name": "connection-sharing", + "private": "true", + "version": "0.0.0", + "description": "ERROR: No README.md file found!", + "main": "app.js", + "scripts": { + "test": "echo \"Error: no test specified\" && exit 1" + }, + "dependencies": { "express": "3.1.1" }, + "repository": "", + "author": "", + "license": "BSD" +} diff --git a/node_modules/mongoose/examples/express/connection-sharing/routes.js b/node_modules/mongoose/examples/express/connection-sharing/routes.js new file mode 100644 index 0000000..35e4f8f --- /dev/null +++ b/node_modules/mongoose/examples/express/connection-sharing/routes.js @@ -0,0 +1,20 @@ + +var model = require('./modelA'); + +exports.home = function(req, res, next) { + model.find(function(err, docs) { + if (err) return next(err); + res.send(docs); + }); +}; + +exports.modelName = function(req, res) { + res.send('my model name is ' + model.modelName); +}; + +exports.insert = function(req, res, next) { + model.create({name: 'inserting ' + Date.now()}, function(err, doc) { + if (err) return next(err); + res.send(doc); + }); +}; diff --git a/node_modules/mongoose/examples/geospatial/geoJSONSchema.js b/node_modules/mongoose/examples/geospatial/geoJSONSchema.js new file mode 100644 index 0000000..f950dea --- /dev/null +++ b/node_modules/mongoose/examples/geospatial/geoJSONSchema.js @@ -0,0 +1,22 @@ + +// import the necessary modules +var mongoose = require('../../lib'); +var Schema = mongoose.Schema; + +// create an export function to encapsulate the model creation +module.exports = function() { + // define schema + // NOTE : This object must conform *precisely* to the geoJSON specification + // you cannot embed a geoJSON doc inside a model or anything like that- IT + // MUST BE VANILLA + var LocationObject = new Schema({ + loc: { + type: {type: String}, + coordinates: [] + } + }); + // define the index + LocationObject.index({loc: '2dsphere'}); + + mongoose.model('Location', LocationObject); +}; diff --git a/node_modules/mongoose/examples/geospatial/geoJSONexample.js b/node_modules/mongoose/examples/geospatial/geoJSONexample.js new file mode 100644 index 0000000..8e5dd2b --- /dev/null +++ b/node_modules/mongoose/examples/geospatial/geoJSONexample.js @@ -0,0 +1,56 @@ +// import async to make control flow simplier +var async = require('async'); + +// import the rest of the normal stuff +var mongoose = require('../../lib'); + +require('./geoJSONSchema.js')(); + +var Location = mongoose.model('Location'); + +// define some dummy data +// note: the type can be Point, LineString, or Polygon +var data = [ + {loc: {type: 'Point', coordinates: [-20.0, 5.0]}}, + {loc: {type: 'Point', coordinates: [6.0, 10.0]}}, + {loc: {type: 'Point', coordinates: [34.0, -50.0]}}, + {loc: {type: 'Point', coordinates: [-100.0, 70.0]}}, + {loc: {type: 'Point', coordinates: [38.0, 38.0]}} +]; + + +mongoose.connect('mongodb://localhost/locations', function(err) { + if (err) { + throw err; + } + + Location.on('index', function(err) { + if (err) { + throw err; + } + // create all of the dummy locations + async.each(data, function(item, cb) { + Location.create(item, cb); + }, function(err) { + if (err) { + throw err; + } + // create the location we want to search for + var coords = {type: 'Point', coordinates: [-5, 5]}; + // search for it + Location.find({loc: {$near: coords}}).limit(1).exec(function(err, res) { + if (err) { + throw err; + } + console.log('Closest to %s is %s', JSON.stringify(coords), res); + cleanup(); + }); + }); + }); +}); + +function cleanup() { + Location.remove(function() { + mongoose.disconnect(); + }); +} diff --git a/node_modules/mongoose/examples/geospatial/geospatial.js b/node_modules/mongoose/examples/geospatial/geospatial.js new file mode 100644 index 0000000..3ff8c0b --- /dev/null +++ b/node_modules/mongoose/examples/geospatial/geospatial.js @@ -0,0 +1,100 @@ +// import async to make control flow simplier +var async = require('async'); + +// import the rest of the normal stuff +var mongoose = require('../../lib'); + +require('./person.js')(); + +var Person = mongoose.model('Person'); + +// define some dummy data +var data = [ + { + name: 'bill', + age: 25, + birthday: new Date().setFullYear((new Date().getFullYear() - 25)), + gender: 'Male', + likes: ['movies', 'games', 'dogs'], + loc: [0, 0] + }, + { + name: 'mary', + age: 30, + birthday: new Date().setFullYear((new Date().getFullYear() - 30)), + gender: 'Female', + likes: ['movies', 'birds', 'cats'], + loc: [1, 1] + }, + { + name: 'bob', + age: 21, + birthday: new Date().setFullYear((new Date().getFullYear() - 21)), + gender: 'Male', + likes: ['tv', 'games', 'rabbits'], + loc: [3, 3] + }, + { + name: 'lilly', + age: 26, + birthday: new Date().setFullYear((new Date().getFullYear() - 26)), + gender: 'Female', + likes: ['books', 'cats', 'dogs'], + loc: [6, 6] + }, + { + name: 'alucard', + age: 1000, + birthday: new Date().setFullYear((new Date().getFullYear() - 1000)), + gender: 'Male', + likes: ['glasses', 'wine', 'the night'], + loc: [10, 10] + } +]; + + +mongoose.connect('mongodb://localhost/persons', function(err) { + if (err) { + throw err; + } + + // create all of the dummy people + async.each(data, function(item, cb) { + Person.create(item, cb); + }, function(err) { + if (err) { + // handler error + } + + // let's find the closest person to bob + Person.find({name: 'bob'}, function(err, res) { + if (err) { + throw err; + } + + res[0].findClosest(function(err, closest) { + if (err) { + throw err; + } + + console.log('%s is closest to %s', res[0].name, closest); + + + // we can also just query straight off of the model. For more + // information about geospatial queries and indexes, see + // http://docs.mongodb.org/manual/applications/geospatial-indexes/ + var coords = [7, 7]; + Person.find({loc: {$nearSphere: coords}}).limit(1).exec(function(err, res) { + console.log('Closest to %s is %s', coords, res); + cleanup(); + }); + }); + }); + }); +}); + +function cleanup() { + Person.remove(function() { + mongoose.disconnect(); + }); +} diff --git a/node_modules/mongoose/examples/geospatial/package.json b/node_modules/mongoose/examples/geospatial/package.json new file mode 100644 index 0000000..75c2a0e --- /dev/null +++ b/node_modules/mongoose/examples/geospatial/package.json @@ -0,0 +1,14 @@ +{ + "name": "geospatial-example", + "private": "true", + "version": "0.0.0", + "description": "deps for geospatial example", + "main": "geospatial.js", + "scripts": { + "test": "echo \"Error: no test specified\" && exit 1" + }, + "dependencies": { "async": "*" }, + "repository": "", + "author": "", + "license": "BSD" +} diff --git a/node_modules/mongoose/examples/geospatial/person.js b/node_modules/mongoose/examples/geospatial/person.js new file mode 100644 index 0000000..e816637 --- /dev/null +++ b/node_modules/mongoose/examples/geospatial/person.js @@ -0,0 +1,27 @@ +// import the necessary modules +var mongoose = require('../../lib'); +var Schema = mongoose.Schema; + +// create an export function to encapsulate the model creation +module.exports = function() { + // define schema + var PersonSchema = new Schema({ + name: String, + age: Number, + birthday: Date, + gender: String, + likes: [String], + // define the geospatial field + loc: {type: [Number], index: '2d'} + }); + + // define a method to find the closest person + PersonSchema.methods.findClosest = function(cb) { + return this.model('Person').find({ + loc: {$nearSphere: this.loc}, + name: {$ne: this.name} + }).limit(1).exec(cb); + }; + + mongoose.model('Person', PersonSchema); +}; diff --git a/node_modules/mongoose/examples/globalschemas/gs_example.js b/node_modules/mongoose/examples/globalschemas/gs_example.js new file mode 100644 index 0000000..af9ff11 --- /dev/null +++ b/node_modules/mongoose/examples/globalschemas/gs_example.js @@ -0,0 +1,47 @@ +var mongoose = require('../../lib'); + + +// import the global schema, this can be done in any file that needs the model +require('./person.js')(); + +// grab the person model object +var Person = mongoose.model('Person'); + +// connect to a server to do a quick write / read example + +mongoose.connect('mongodb://localhost/persons', function(err) { + if (err) { + throw err; + } + + Person.create({ + name: 'bill', + age: 25, + birthday: new Date().setFullYear((new Date().getFullYear() - 25)) + }, function(err, bill) { + if (err) { + throw err; + } + console.log('People added to db: %s', bill.toString()); + Person.find({}, function(err, people) { + if (err) { + throw err; + } + + people.forEach(function(person) { + console.log('People in the db: %s', person.toString()); + }); + + // make sure to clean things up after we're done + setTimeout(function() { + cleanup(); + }, 2000); + }); + }); +}); + +function cleanup() { + Person.remove(function() { + mongoose.disconnect(); + }); +} diff --git a/node_modules/mongoose/examples/globalschemas/person.js b/node_modules/mongoose/examples/globalschemas/person.js new file mode 100644 index 0000000..39ae725 --- /dev/null +++ b/node_modules/mongoose/examples/globalschemas/person.js @@ -0,0 +1,14 @@ +// import the necessary modules +var mongoose = require('../../lib'); +var Schema = mongoose.Schema; + +// create an export function to encapsulate the model creation +module.exports = function() { + // define schema + var PersonSchema = new Schema({ + name: String, + age: Number, + birthday: Date + }); + mongoose.model('Person', PersonSchema); +}; diff --git a/node_modules/mongoose/examples/lean/lean.js b/node_modules/mongoose/examples/lean/lean.js new file mode 100644 index 0000000..763367f --- /dev/null +++ b/node_modules/mongoose/examples/lean/lean.js @@ -0,0 +1,84 @@ + +// import async to make control flow simplier +var async = require('async'); + +// import the rest of the normal stuff +var mongoose = require('../../lib'); + +require('./person.js')(); + +var Person = mongoose.model('Person'); + +// define some dummy data +var data = [ + { + name: 'bill', + age: 25, + birthday: new Date().setFullYear((new Date().getFullYear() - 25)), + gender: 'Male', + likes: ['movies', 'games', 'dogs'] + }, + { + name: 'mary', + age: 30, + birthday: new Date().setFullYear((new Date().getFullYear() - 30)), + gender: 'Female', + likes: ['movies', 'birds', 'cats'] + }, + { + name: 'bob', + age: 21, + birthday: new Date().setFullYear((new Date().getFullYear() - 21)), + gender: 'Male', + likes: ['tv', 'games', 'rabbits'] + }, + { + name: 'lilly', + age: 26, + birthday: new Date().setFullYear((new Date().getFullYear() - 26)), + gender: 'Female', + likes: ['books', 'cats', 'dogs'] + }, + { + name: 'alucard', + age: 1000, + birthday: new Date().setFullYear((new Date().getFullYear() - 1000)), + gender: 'Male', + likes: ['glasses', 'wine', 'the night'] + } +]; + + +mongoose.connect('mongodb://localhost/persons', function(err) { + if (err) throw err; + + // create all of the dummy people + async.each(data, function(item, cb) { + Person.create(item, cb); + }, function(err) { + if (err) { + // handle error + } + + // lean queries return just plain javascript objects, not + // MongooseDocuments. This makes them good for high performance read + // situations + + // when using .lean() the default is true, but you can explicitly set the + // value by passing in a boolean value. IE. .lean(false) + var q = Person.find({age: {$lt: 1000}}).sort('age').limit(2).lean(); + q.exec(function(err, results) { + if (err) throw err; + console.log('Are the results MongooseDocuments?: %s', results[0] instanceof mongoose.Document); + + console.log(results); + cleanup(); + }); + }); +}); + +function cleanup() { + Person.remove(function() { + mongoose.disconnect(); + }); +} diff --git a/node_modules/mongoose/examples/lean/package.json b/node_modules/mongoose/examples/lean/package.json new file mode 100644 index 0000000..6ee511d --- /dev/null +++ b/node_modules/mongoose/examples/lean/package.json @@ -0,0 +1,14 @@ +{ + "name": "lean-example", + "private": "true", + "version": "0.0.0", + "description": "deps for lean example", + "main": "lean.js", + "scripts": { + "test": "echo \"Error: no test specified\" && exit 1" + }, + "dependencies": { "async": "*" }, + "repository": "", + "author": "", + "license": "BSD" +} diff --git a/node_modules/mongoose/examples/lean/person.js b/node_modules/mongoose/examples/lean/person.js new file mode 100644 index 0000000..b0bd2ed --- /dev/null +++ b/node_modules/mongoose/examples/lean/person.js @@ -0,0 +1,16 @@ +// import the necessary modules +var mongoose = require('../../lib'); +var Schema = mongoose.Schema; + +// create an export function to encapsulate the model creation +module.exports = function() { + // define schema + var PersonSchema = new Schema({ + name: String, + age: Number, + birthday: Date, + gender: String, + likes: [String] + }); + mongoose.model('Person', PersonSchema); +}; diff --git a/node_modules/mongoose/examples/mapreduce/mapreduce.js b/node_modules/mongoose/examples/mapreduce/mapreduce.js new file mode 100644 index 0000000..6d67fbf --- /dev/null +++ b/node_modules/mongoose/examples/mapreduce/mapreduce.js @@ -0,0 +1,100 @@ +// import async to make control flow simplier +var async = require('async'); + +// import the rest of the normal stuff +var mongoose = require('../../lib'); + +require('./person.js')(); + +var Person = mongoose.model('Person'); + +// define some dummy data +var data = [ + { + name: 'bill', + age: 25, + birthday: new Date().setFullYear((new Date().getFullYear() - 25)), + gender: 'Male' + }, + { + name: 'mary', + age: 30, + birthday: new Date().setFullYear((new Date().getFullYear() - 30)), + gender: 'Female' + }, + { + name: 'bob', + age: 21, + birthday: new Date().setFullYear((new Date().getFullYear() - 21)), + gender: 'Male' + }, + { + name: 'lilly', + age: 26, + birthday: new Date().setFullYear((new Date().getFullYear() - 26)), + gender: 'Female' + }, + { + name: 'alucard', + age: 1000, + birthday: new Date().setFullYear((new Date().getFullYear() - 1000)), + gender: 'Male' + } +]; + + +mongoose.connect('mongodb://localhost/persons', function(err) { + if (err) throw err; + + // create all of the dummy people + async.each(data, function(item, cb) { + Person.create(item, cb); + }, function(err) { + if (err) { + // handle error + } + + // alright, simple map reduce example. We will find the total ages of each + // gender + + // create the options object + var o = {}; + + o.map = function() { + // in this function, 'this' refers to the current document being + // processed. Return the (gender, age) tuple using + /* global emit */ + emit(this.gender, this.age); + }; + + // the reduce function receives the array of ages that are grouped by the + // id, which in this case is the gender + o.reduce = function(id, ages) { + return Array.sum(ages); + }; + + // other options that can be specified + + // o.query = { age : { $lt : 1000 }}; // the query object + // o.limit = 3; // max number of documents + // o.keeptemp = true; // default is false, specifies whether to keep temp data + // o.finalize = someFunc; // function called after reduce + // o.scope = {}; // the scope variable exposed to map/reduce/finalize + // o.jsMode = true; // default is false, force execution to stay in JS + o.verbose = true; // default is false, provide stats on the job + // o.out = {}; // objects to specify where output goes, by default is + // returned, but can also be stored in a new collection + // see: http://mongoosejs.com/docs/api.html#model_Model.mapReduce + Person.mapReduce(o, function(err, results, stats) { + console.log('map reduce took %d ms', stats.processtime); + console.log(results); + cleanup(); + }); + }); +}); + +function cleanup() { + Person.remove(function() { + mongoose.disconnect(); + }); +} diff --git a/node_modules/mongoose/examples/mapreduce/package.json b/node_modules/mongoose/examples/mapreduce/package.json new file mode 100644 index 0000000..4240068 --- /dev/null +++ b/node_modules/mongoose/examples/mapreduce/package.json @@ -0,0 +1,14 @@ +{ + "name": "map-reduce-example", + "private": "true", + "version": "0.0.0", + "description": "deps for map reduce example", + "main": "mapreduce.js", + "scripts": { + "test": "echo \"Error: no test specified\" && exit 1" + }, + "dependencies": { "async": "*" }, + "repository": "", + "author": "", + "license": "BSD" +} diff --git a/node_modules/mongoose/examples/mapreduce/person.js b/node_modules/mongoose/examples/mapreduce/person.js new file mode 100644 index 0000000..9e2f084 --- /dev/null +++ b/node_modules/mongoose/examples/mapreduce/person.js @@ -0,0 +1,16 @@ + +// import the necessary modules +var mongoose = require('../../lib'); +var Schema = mongoose.Schema; + +// create an export function to encapsulate the model creation +module.exports = function() { + // define schema + var PersonSchema = new Schema({ + name: String, + age: Number, + birthday: Date, + gender: String + }); + mongoose.model('Person', PersonSchema); +}; diff --git a/node_modules/mongoose/examples/population/population-across-three-collections.js b/node_modules/mongoose/examples/population/population-across-three-collections.js new file mode 100644 index 0000000..fe6de72 --- /dev/null +++ b/node_modules/mongoose/examples/population/population-across-three-collections.js @@ -0,0 +1,134 @@ + +var assert = require('assert'); +var mongoose = require('../../lib'); +var Schema = mongoose.Schema; +var ObjectId = mongoose.Types.ObjectId; + +/** + * Connect to the db + */ + +var dbname = 'testing_populateAdInfinitum_' + require('../../lib/utils').random(); +mongoose.connect('localhost', dbname); +mongoose.connection.on('error', function() { + console.error('connection error', arguments); +}); + +/** + * Schemas + */ + +var user = new Schema({ + name: String, + friends: [{ + type: Schema.ObjectId, + ref: 'User' + }] +}); +var User = mongoose.model('User', user); + +var blogpost = Schema({ + title: String, + tags: [String], + author: { + type: Schema.ObjectId, + ref: 'User' + } +}); +var BlogPost = mongoose.model('BlogPost', blogpost); + +/** + * example + */ + +mongoose.connection.on('open', function() { + /** + * Generate data + */ + + var userIds = [new ObjectId, new ObjectId, new ObjectId, new ObjectId]; + var users = []; + + users.push({ + _id: userIds[0], + name: 'mary', + friends: [userIds[1], userIds[2], userIds[3]] + }); + users.push({ + _id: userIds[1], + name: 'bob', + friends: [userIds[0], userIds[2], userIds[3]] + }); + users.push({ + _id: userIds[2], + name: 'joe', + friends: [userIds[0], userIds[1], userIds[3]] + }); + users.push({ + _id: userIds[3], + name: 'sally', + friends: [userIds[0], userIds[1], userIds[2]] + }); + + User.create(users, function(err) { + assert.ifError(err); + + var blogposts = []; + blogposts.push({ + title: 'blog 1', + tags: ['fun', 'cool'], + author: userIds[3] + }); + blogposts.push({ + title: 'blog 2', + tags: ['cool'], + author: userIds[1] + }); + blogposts.push({ + title: 'blog 3', + tags: ['fun', 'odd'], + author: userIds[2] + }); + + BlogPost.create(blogposts, function(err) { + assert.ifError(err); + + /** + * Population + */ + + BlogPost + .find({tags: 'fun'}) + .lean() + .populate('author') + .exec(function(err, docs) { + assert.ifError(err); + + /** + * Populate the populated documents + */ + + var opts = { + path: 'author.friends', + select: 'name', + options: {limit: 2} + }; + + BlogPost.populate(docs, opts, function(err, docs) { + assert.ifError(err); + console.log('populated'); + var s = require('util').inspect(docs, {depth: null, colors: true}); + console.log(s); + done(); + }); + }); + }); + }); +}); + +function done(err) { + if (err) console.error(err.stack); + mongoose.connection.db.dropDatabase(function() { + mongoose.connection.close(); + }); +} diff --git a/node_modules/mongoose/examples/population/population-basic.js b/node_modules/mongoose/examples/population/population-basic.js new file mode 100644 index 0000000..252cc53 --- /dev/null +++ b/node_modules/mongoose/examples/population/population-basic.js @@ -0,0 +1,103 @@ + +var mongoose = require('../../lib'); +var Schema = mongoose.Schema; + +console.log('Running mongoose version %s', mongoose.version); + +/** + * Console schema + */ + +var consoleSchema = Schema({ + name: String, + manufacturer: String, + released: Date +}); +var Console = mongoose.model('Console', consoleSchema); + +/** + * Game schema + */ + +var gameSchema = Schema({ + name: String, + developer: String, + released: Date, + consoles: [{ + type: Schema.Types.ObjectId, + ref: 'Console' + }] +}); +var Game = mongoose.model('Game', gameSchema); + +/** + * Connect to the console database on localhost with + * the default port (27017) + */ + +mongoose.connect('mongodb://localhost/console', function(err) { + // if we failed to connect, abort + if (err) throw err; + + // we connected ok + createData(); +}); + +/** + * Data generation + */ + +function createData() { + Console.create( + { + name: 'Nintendo 64', + manufacturer: 'Nintendo', + released: 'September 29, 1996' + }, + function(err, nintendo64) { + if (err) return done(err); + + Game.create({ + name: 'Legend of Zelda: Ocarina of Time', + developer: 'Nintendo', + released: new Date('November 21, 1998'), + consoles: [nintendo64] + }, + function(err) { + if (err) return done(err); + example(); + }); + } + ); +} + +/** + * Population + */ + +function example() { + Game + .findOne({name: /^Legend of Zelda/}) + .populate('consoles') + .exec(function(err, ocinara) { + if (err) return done(err); + + console.log( + '"%s" was released for the %s on %s', + ocinara.name, + ocinara.consoles[0].name, + ocinara.released.toLocaleDateString() + ); + + done(); + }); +} + +function done(err) { + if (err) console.error(err); + Console.remove(function() { + Game.remove(function() { + mongoose.disconnect(); + }); + }); +} diff --git a/node_modules/mongoose/examples/population/population-of-existing-doc.js b/node_modules/mongoose/examples/population/population-of-existing-doc.js new file mode 100644 index 0000000..c7eadfe --- /dev/null +++ b/node_modules/mongoose/examples/population/population-of-existing-doc.js @@ -0,0 +1,109 @@ + +var mongoose = require('../../lib'); +var Schema = mongoose.Schema; + +console.log('Running mongoose version %s', mongoose.version); + +/** + * Console schema + */ + +var consoleSchema = Schema({ + name: String, + manufacturer: String, + released: Date +}); +var Console = mongoose.model('Console', consoleSchema); + +/** + * Game schema + */ + +var gameSchema = Schema({ + name: String, + developer: String, + released: Date, + consoles: [{ + type: Schema.Types.ObjectId, + ref: 'Console' + }] +}); +var Game = mongoose.model('Game', gameSchema); + +/** + * Connect to the console database on localhost with + * the default port (27017) + */ + +mongoose.connect('mongodb://localhost/console', function(err) { + // if we failed to connect, abort + if (err) throw err; + + // we connected ok + createData(); +}); + +/** + * Data generation + */ + +function createData() { + Console.create( + { + name: 'Nintendo 64', + manufacturer: 'Nintendo', + released: 'September 29, 1996' + }, + function(err, nintendo64) { + if (err) return done(err); + + Game.create({ + name: 'Legend of Zelda: Ocarina of Time', + developer: 'Nintendo', + released: new Date('November 21, 1998'), + consoles: [nintendo64] + }, + function(err) { + if (err) return done(err); + example(); + }); + } + ); +} + +/** + * Population + */ + +function example() { + Game + .findOne({name: /^Legend of Zelda/}) + .exec(function(err, ocinara) { + if (err) return done(err); + + console.log('"%s" console _id: %s', ocinara.name, ocinara.consoles[0]); + + // population of existing document + ocinara.populate('consoles', function(err) { + if (err) return done(err); + + console.log( + '"%s" was released for the %s on %s', + ocinara.name, + ocinara.consoles[0].name, + ocinara.released.toLocaleDateString() + ); + + done(); + }); + }); +} + +function done(err) { + if (err) console.error(err); + Console.remove(function() { + Game.remove(function() { + mongoose.disconnect(); + }); + }); +} diff --git a/node_modules/mongoose/examples/population/population-of-multiple-existing-docs.js b/node_modules/mongoose/examples/population/population-of-multiple-existing-docs.js new file mode 100644 index 0000000..61b4e85 --- /dev/null +++ b/node_modules/mongoose/examples/population/population-of-multiple-existing-docs.js @@ -0,0 +1,124 @@ + +var mongoose = require('../../lib'); +var Schema = mongoose.Schema; + +console.log('Running mongoose version %s', mongoose.version); + +/** + * Console schema + */ + +var consoleSchema = Schema({ + name: String, + manufacturer: String, + released: Date +}); +var Console = mongoose.model('Console', consoleSchema); + +/** + * Game schema + */ + +var gameSchema = Schema({ + name: String, + developer: String, + released: Date, + consoles: [{ + type: Schema.Types.ObjectId, + ref: 'Console' + }] +}); +var Game = mongoose.model('Game', gameSchema); + +/** + * Connect to the console database on localhost with + * the default port (27017) + */ + +mongoose.connect('mongodb://localhost/console', function(err) { + // if we failed to connect, abort + if (err) throw err; + + // we connected ok + createData(); +}); + +/** + * Data generation + */ + +function createData() { + Console.create( + { + name: 'Nintendo 64', + manufacturer: 'Nintendo', + released: 'September 29, 1996' + }, + { + name: 'Super Nintendo', + manufacturer: 'Nintendo', + released: 'August 23, 1991' + }, + function(err, nintendo64, superNintendo) { + if (err) return done(err); + + Game.create( + { + name: 'Legend of Zelda: Ocarina of Time', + developer: 'Nintendo', + released: new Date('November 21, 1998'), + consoles: [nintendo64] + }, + { + name: 'Mario Kart', + developer: 'Nintendo', + released: 'September 1, 1992', + consoles: [superNintendo] + }, + function(err) { + if (err) return done(err); + example(); + } + ); + } + ); +} + +/** + * Population + */ + +function example() { + Game + .find({}) + .exec(function(err, games) { + if (err) return done(err); + + console.log('found %d games', games.length); + + var options = {path: 'consoles', select: 'name released -_id'}; + Game.populate(games, options, function(err, games) { + if (err) return done(err); + + games.forEach(function(game) { + console.log( + '"%s" was released for the %s on %s', + game.name, + game.consoles[0].name, + game.released.toLocaleDateString() + ); + }); + + done(); + }); + }); +} + +function done(err) { + if (err) console.error(err); + Console.remove(function() { + Game.remove(function() { + mongoose.disconnect(); + }); + }); +} diff --git a/node_modules/mongoose/examples/population/population-options.js b/node_modules/mongoose/examples/population/population-options.js new file mode 100644 index 0000000..59cfd1e --- /dev/null +++ b/node_modules/mongoose/examples/population/population-options.js @@ -0,0 +1,138 @@ + +var mongoose = require('../../lib'); +var Schema = mongoose.Schema; + +console.log('Running mongoose version %s', mongoose.version); + +/** + * Console schema + */ + +var consoleSchema = Schema({ + name: String, + manufacturer: String, + released: Date +}); +var Console = mongoose.model('Console', consoleSchema); + +/** + * Game schema + */ + +var gameSchema = Schema({ + name: String, + developer: String, + released: Date, + consoles: [{ + type: Schema.Types.ObjectId, + ref: 'Console' + }] +}); +var Game = mongoose.model('Game', gameSchema); + +/** + * Connect to the console database on localhost with + * the default port (27017) + */ + +mongoose.connect('mongodb://localhost/console', function(err) { + // if we failed to connect, abort + if (err) throw err; + + // we connected ok + createData(); +}); + +/** + * Data generation + */ + +function createData() { + Console.create( + { + name: 'Nintendo 64', + manufacturer: 'Nintendo', + released: 'September 29, 1996' + }, + { + name: 'Super Nintendo', + manufacturer: 'Nintendo', + released: 'August 23, 1991' + }, + { + name: 'XBOX 360', + manufacturer: 'Microsoft', + released: 'November 22, 2005' + }, + function(err, nintendo64, superNintendo, xbox360) { + if (err) return done(err); + + Game.create( + { + name: 'Legend of Zelda: Ocarina of Time', + developer: 'Nintendo', + released: new Date('November 21, 1998'), + consoles: [nintendo64] + }, + { + name: 'Mario Kart', + developer: 'Nintendo', + released: 'September 1, 1992', + consoles: [superNintendo] + }, + { + name: 'Perfect Dark Zero', + developer: 'Rare', + released: 'November 17, 2005', + consoles: [xbox360] + }, + function(err) { + if (err) return done(err); + example(); + } + ); + } + ); +} + +/** + * Population + */ + +function example() { + Game + .find({}) + .populate({ + path: 'consoles', + match: {manufacturer: 'Nintendo'}, + select: 'name', + options: {comment: 'population'} + }) + .exec(function(err, games) { + if (err) return done(err); + + games.forEach(function(game) { + console.log( + '"%s" was released for the %s on %s', + game.name, + game.consoles.length ? game.consoles[0].name : '??', + game.released.toLocaleDateString() + ); + }); + + return done(); + }); +} + +/** + * Clean up + */ + +function done(err) { + if (err) console.error(err); + Console.remove(function() { + Game.remove(function() { + mongoose.disconnect(); + }); + }); +} diff --git a/node_modules/mongoose/examples/population/population-plain-objects.js b/node_modules/mongoose/examples/population/population-plain-objects.js new file mode 100644 index 0000000..ba849dc --- /dev/null +++ b/node_modules/mongoose/examples/population/population-plain-objects.js @@ -0,0 +1,106 @@ + +var mongoose = require('../../lib'); +var Schema = mongoose.Schema; + +console.log('Running mongoose version %s', mongoose.version); + +/** + * Console schema + */ + +var consoleSchema = Schema({ + name: String, + manufacturer: String, + released: Date +}); +var Console = mongoose.model('Console', consoleSchema); + +/** + * Game schema + */ + +var gameSchema = Schema({ + name: String, + developer: String, + released: Date, + consoles: [{ + type: Schema.Types.ObjectId, + ref: 'Console' + }] +}); +var Game = mongoose.model('Game', gameSchema); + +/** + * Connect to the console database on localhost with + * the default port (27017) + */ + +mongoose.connect('mongodb://localhost/console', function(err) { + // if we failed to connect, abort + if (err) throw err; + + // we connected ok + createData(); +}); + +/** + * Data generation + */ + +function createData() { + Console.create( + { + name: 'Nintendo 64', + manufacturer: 'Nintendo', + released: 'September 29, 1996' + }, + function(err, nintendo64) { + if (err) return done(err); + + Game.create( + { + name: 'Legend of Zelda: Ocarina of Time', + developer: 'Nintendo', + released: new Date('November 21, 1998'), + consoles: [nintendo64] + }, + function(err) { + if (err) return done(err); + example(); + } + ); + } + ); +} + +/** + * Population + */ + +function example() { + Game + .findOne({name: /^Legend of Zelda/}) + .populate('consoles') + .lean() // just return plain objects, not documents wrapped by mongoose + .exec(function(err, ocinara) { + if (err) return done(err); + + console.log( + '"%s" was released for the %s on %s', + ocinara.name, + ocinara.consoles[0].name, + ocinara.released.toLocaleDateString() + ); + + done(); + }); +} + +function done(err) { + if (err) console.error(err); + Console.remove(function() { + Game.remove(function() { + mongoose.disconnect(); + }); + }); +} diff --git a/node_modules/mongoose/examples/promises/package.json b/node_modules/mongoose/examples/promises/package.json new file mode 100644 index 0000000..1983250 --- /dev/null +++ b/node_modules/mongoose/examples/promises/package.json @@ -0,0 +1,14 @@ +{ + "name": "promise-example", + "private": "true", + "version": "0.0.0", + "description": "deps for promise example", + "main": "promise.js", + "scripts": { + "test": "echo \"Error: no test specified\" && exit 1" + }, + "dependencies": { "async": "*" }, + "repository": "", + "author": "", + "license": "BSD" +} diff --git a/node_modules/mongoose/examples/promises/person.js b/node_modules/mongoose/examples/promises/person.js new file mode 100644 index 0000000..40e2bf1 --- /dev/null +++ b/node_modules/mongoose/examples/promises/person.js @@ -0,0 +1,15 @@ + +// import the necessary modules +var mongoose = require('../../lib'); +var Schema = mongoose.Schema; + +// create an export function to encapsulate the model creation +module.exports = function() { + // define schema + var PersonSchema = new Schema({ + name: String, + age: Number, + birthday: Date + }); + mongoose.model('Person', PersonSchema); +}; diff --git a/node_modules/mongoose/examples/promises/promise.js b/node_modules/mongoose/examples/promises/promise.js new file mode 100644 index 0000000..3f17206 --- /dev/null +++ b/node_modules/mongoose/examples/promises/promise.js @@ -0,0 +1,94 @@ +// import async to make control flow simplier +var async = require('async'); + +// import the rest of the normal stuff +var mongoose = require('../../lib'); + +require('./person.js')(); + +var Person = mongoose.model('Person'); + +// define some dummy data +var data = [ + { + name: 'bill', + age: 25, + birthday: new Date().setFullYear((new Date().getFullYear() - 25)) + }, + { + name: 'mary', + age: 30, + birthday: new Date().setFullYear((new Date().getFullYear() - 30)) + }, + { + name: 'bob', + age: 21, + birthday: new Date().setFullYear((new Date().getFullYear() - 21)) + }, + { + name: 'lilly', + age: 26, + birthday: new Date().setFullYear((new Date().getFullYear() - 26)) + }, + { + name: 'alucard', + age: 1000, + birthday: new Date().setFullYear((new Date().getFullYear() - 1000)) + } +]; + + +mongoose.connect('mongodb://localhost/persons', function(err) { + if (err) { + throw err; + } + + // create all of the dummy people + async.each(data, function(item, cb) { + Person.create(item, cb); + }, function(err) { + if (err) { + // handle error + } + + // create a promise (get one from the query builder) + var prom = Person.find({age: {$lt: 1000}}).exec(); + + // add a callback on the promise. This will be called on both error and + // complete + prom.addBack(function() { + console.log('completed'); + }); + + // add a callback that is only called on complete (success) events + prom.addCallback(function() { + console.log('Successful Completion!'); + }); + + // add a callback that is only called on err (rejected) events + prom.addErrback(function() { + console.log('Fail Boat'); + }); + + // you can chain things just like in the promise/A+ spec + // note: each then() is returning a new promise, so the above methods + // that we defined will all fire after the initial promise is fulfilled + prom.then(function(people) { + // just getting the stuff for the next query + var ids = people.map(function(p) { + return p._id; + }); + + // return the next promise + return Person.find({_id: {$nin: ids}}).exec(); + }).then(function(oldest) { + console.log('Oldest person is: %s', oldest); + }).then(cleanup); + }); +}); + +function cleanup() { + Person.remove(function() { + mongoose.disconnect(); + }); +} diff --git a/node_modules/mongoose/examples/querybuilder/package.json b/node_modules/mongoose/examples/querybuilder/package.json new file mode 100644 index 0000000..1a3450a --- /dev/null +++ b/node_modules/mongoose/examples/querybuilder/package.json @@ -0,0 +1,14 @@ +{ + "name": "query-builder-example", + "private": "true", + "version": "0.0.0", + "description": "deps for query builder example", + "main": "querybuilder.js", + "scripts": { + "test": "echo \"Error: no test specified\" && exit 1" + }, + "dependencies": { "async": "*" }, + "repository": "", + "author": "", + "license": "BSD" +} diff --git a/node_modules/mongoose/examples/querybuilder/person.js b/node_modules/mongoose/examples/querybuilder/person.js new file mode 100644 index 0000000..40e2bf1 --- /dev/null +++ b/node_modules/mongoose/examples/querybuilder/person.js @@ -0,0 +1,15 @@ + +// import the necessary modules +var mongoose = require('../../lib'); +var Schema = mongoose.Schema; + +// create an export function to encapsulate the model creation +module.exports = function() { + // define schema + var PersonSchema = new Schema({ + name: String, + age: Number, + birthday: Date + }); + mongoose.model('Person', PersonSchema); +}; diff --git a/node_modules/mongoose/examples/querybuilder/querybuilder.js b/node_modules/mongoose/examples/querybuilder/querybuilder.js new file mode 100644 index 0000000..6f8645b --- /dev/null +++ b/node_modules/mongoose/examples/querybuilder/querybuilder.js @@ -0,0 +1,79 @@ + +// import async to make control flow simplier +var async = require('async'); + +// import the rest of the normal stuff +var mongoose = require('../../lib'); + +require('./person.js')(); + +var Person = mongoose.model('Person'); + +// define some dummy data +var data = [ + { + name: 'bill', + age: 25, + birthday: new Date().setFullYear((new Date().getFullYear() - 25)) + }, + { + name: 'mary', + age: 30, + birthday: new Date().setFullYear((new Date().getFullYear() - 30)) + }, + { + name: 'bob', + age: 21, + birthday: new Date().setFullYear((new Date().getFullYear() - 21)) + }, + { + name: 'lilly', + age: 26, + birthday: new Date().setFullYear((new Date().getFullYear() - 26)) + }, + { + name: 'alucard', + age: 1000, + birthday: new Date().setFullYear((new Date().getFullYear() - 1000)) + } +]; + + +mongoose.connect('mongodb://localhost/persons', function(err) { + if (err) throw err; + + // create all of the dummy people + async.each(data, function(item, cb) { + Person.create(item, cb); + }, function(err) { + if (err) throw err; + + // when querying data, instead of providing a callback, you can instead + // leave that off and get a query object returned + var query = Person.find({age: {$lt: 1000}}); + + // this allows you to continue applying modifiers to it + query.sort('birthday'); + query.select('name'); + + // you can chain them together as well + // a full list of methods can be found: + // http://mongoosejs.com/docs/api.html#query-js + query.where('age').gt(21); + + // finally, when ready to execute the query, call the exec() function + query.exec(function(err, results) { + if (err) throw err; + + console.log(results); + + cleanup(); + }); + }); +}); + +function cleanup() { + Person.remove(function() { + mongoose.disconnect(); + }); +} diff --git a/node_modules/mongoose/examples/replicasets/package.json b/node_modules/mongoose/examples/replicasets/package.json new file mode 100644 index 0000000..927dfd2 --- /dev/null +++ b/node_modules/mongoose/examples/replicasets/package.json @@ -0,0 +1,14 @@ +{ + "name": "replica-set-example", + "private": "true", + "version": "0.0.0", + "description": "deps for replica set example", + "main": "querybuilder.js", + "scripts": { + "test": "echo \"Error: no test specified\" && exit 1" + }, + "dependencies": { "async": "*" }, + "repository": "", + "author": "", + "license": "BSD" +} diff --git a/node_modules/mongoose/examples/replicasets/person.js b/node_modules/mongoose/examples/replicasets/person.js new file mode 100644 index 0000000..40e2bf1 --- /dev/null +++ b/node_modules/mongoose/examples/replicasets/person.js @@ -0,0 +1,15 @@ + +// import the necessary modules +var mongoose = require('../../lib'); +var Schema = mongoose.Schema; + +// create an export function to encapsulate the model creation +module.exports = function() { + // define schema + var PersonSchema = new Schema({ + name: String, + age: Number, + birthday: Date + }); + mongoose.model('Person', PersonSchema); +}; diff --git a/node_modules/mongoose/examples/replicasets/replica-sets.js b/node_modules/mongoose/examples/replicasets/replica-sets.js new file mode 100644 index 0000000..9ebac1b --- /dev/null +++ b/node_modules/mongoose/examples/replicasets/replica-sets.js @@ -0,0 +1,71 @@ + +// import async to make control flow simplier +var async = require('async'); + +// import the rest of the normal stuff +var mongoose = require('../../lib'); + +require('./person.js')(); + +var Person = mongoose.model('Person'); + +// define some dummy data +var data = [ + { + name: 'bill', + age: 25, + birthday: new Date().setFullYear((new Date().getFullYear() - 25)) + }, + { + name: 'mary', + age: 30, + birthday: new Date().setFullYear((new Date().getFullYear() - 30)) + }, + { + name: 'bob', + age: 21, + birthday: new Date().setFullYear((new Date().getFullYear() - 21)) + }, + { + name: 'lilly', + age: 26, + birthday: new Date().setFullYear((new Date().getFullYear() - 26)) + }, + { + name: 'alucard', + age: 1000, + birthday: new Date().setFullYear((new Date().getFullYear() - 1000)) + } +]; + + +// to connect to a replica set, pass in the comma delimited uri and optionally +// any connection options such as the rs_name. +var opts = { + replSet: {rs_name: 'rs0'} +}; +mongoose.connect('mongodb://localhost:27018/persons,localhost:27019,localhost:27020', opts, function(err) { + if (err) throw err; + + // create all of the dummy people + async.each(data, function(item, cb) { + Person.create(item, cb); + }, function(err) { + if (err) { + // handle error + } + + // create and delete some data + var prom = Person.find({age: {$lt: 1000}}).exec(); + + prom.then(function(people) { + console.log('young people: %s', people); + }).then(cleanup); + }); +}); + +function cleanup() { + Person.remove(function() { + mongoose.disconnect(); + }); +} diff --git a/node_modules/mongoose/examples/schema/schema.js b/node_modules/mongoose/examples/schema/schema.js new file mode 100644 index 0000000..5bc99ae --- /dev/null +++ b/node_modules/mongoose/examples/schema/schema.js @@ -0,0 +1,119 @@ +/** + * Module dependencies. + */ + +var mongoose = require('../../lib'), + Schema = mongoose.Schema; + +/** + * Schema definition + */ + +// recursive embedded-document schema + +var Comment = new Schema(); + +Comment.add({ + title: { + type: String, + index: true + }, + date: Date, + body: String, + comments: [Comment] +}); + +var BlogPost = new Schema({ + title: { + type: String, + index: true + }, + slug: { + type: String, + lowercase: true, + trim: true + }, + date: Date, + buf: Buffer, + comments: [Comment], + creator: Schema.ObjectId +}); + +var Person = new Schema({ + name: { + first: String, + last: String + }, + email: { + type: String, + required: true, + index: { + unique: true, + sparse: true + } + }, + alive: Boolean +}); + +/** + * Accessing a specific schema type by key + */ + +BlogPost.path('date') +.default(function() { + return new Date(); +}) +.set(function(v) { + return v === 'now' ? new Date() : v; +}); + +/** + * Pre hook. + */ + +BlogPost.pre('save', function(next, done) { + /* global emailAuthor */ + emailAuthor(done); // some async function + next(); +}); + +/** + * Methods + */ + +BlogPost.methods.findCreator = function(callback) { + return this.db.model('Person').findById(this.creator, callback); +}; + +BlogPost.statics.findByTitle = function(title, callback) { + return this.find({title: title}, callback); +}; + +BlogPost.methods.expressiveQuery = function(creator, date, callback) { + return this.find('creator', creator).where('date').gte(date).run(callback); +}; + +/** + * Plugins + */ + +function slugGenerator(options) { + options = options || {}; + var key = options.key || 'title'; + + return function slugGenerator(schema) { + schema.path(key).set(function(v) { + this.slug = v.toLowerCase().replace(/[^a-z0-9]/g, '').replace(/-+/g, ''); + return v; + }); + }; +} + +BlogPost.plugin(slugGenerator()); + +/** + * Define model. + */ + +mongoose.model('BlogPost', BlogPost); +mongoose.model('Person', Person); diff --git a/node_modules/mongoose/examples/schema/storing-schemas-as-json/index.js b/node_modules/mongoose/examples/schema/storing-schemas-as-json/index.js new file mode 100644 index 0000000..284b478 --- /dev/null +++ b/node_modules/mongoose/examples/schema/storing-schemas-as-json/index.js @@ -0,0 +1,27 @@ + +// modules +var mongoose = require('../../../lib'); +var Schema = mongoose.Schema; + +// parse json +var raw = require('./schema.json'); + +// create a schema +var timeSignatureSchema = Schema(raw); + +// compile the model +var TimeSignature = mongoose.model('TimeSignatures', timeSignatureSchema); + +// create a TimeSignature document +var threeFour = new TimeSignature({ + count: 3, + unit: 4, + description: '3/4', + additive: false, + created: new Date, + links: ['http://en.wikipedia.org/wiki/Time_signature'], + user_id: '518d31a0ef32bbfa853a9814' +}); + +// print its description +console.log(threeFour); diff --git a/node_modules/mongoose/examples/schema/storing-schemas-as-json/schema.json b/node_modules/mongoose/examples/schema/storing-schemas-as-json/schema.json new file mode 100644 index 0000000..5afc626 --- /dev/null +++ b/node_modules/mongoose/examples/schema/storing-schemas-as-json/schema.json @@ -0,0 +1,9 @@ +{ + "count": "number", + "unit": "number", + "description": "string", + "links": ["string"], + "created": "date", + "additive": "boolean", + "user_id": "ObjectId" +} diff --git a/node_modules/mongoose/examples/statics/person.js b/node_modules/mongoose/examples/statics/person.js new file mode 100644 index 0000000..a93b8c6 --- /dev/null +++ b/node_modules/mongoose/examples/statics/person.js @@ -0,0 +1,20 @@ +// import the necessary modules +var mongoose = require('../../lib'); +var Schema = mongoose.Schema; + +// create an export function to encapsulate the model creation +module.exports = function() { + // define schema + var PersonSchema = new Schema({ + name: String, + age: Number, + birthday: Date + }); + + // define a static + PersonSchema.statics.findPersonByName = function(name, cb) { + this.find({name: new RegExp(name, 'i')}, cb); + }; + + mongoose.model('Person', PersonSchema); +}; diff --git a/node_modules/mongoose/examples/statics/statics.js b/node_modules/mongoose/examples/statics/statics.js new file mode 100644 index 0000000..610b2aa --- /dev/null +++ b/node_modules/mongoose/examples/statics/statics.js @@ -0,0 +1,41 @@ +var mongoose = require('../../lib'); + + +// import the schema +require('./person.js')(); + +// grab the person model object +var Person = mongoose.model('Person'); + +// connect to a server to do a quick write / read example + +mongoose.connect('mongodb://localhost/persons', function(err) { + if (err) { + throw err; + } + + Person.create({name: 'bill', age: 25, birthday: new Date().setFullYear((new Date().getFullYear() - 25))}, + function(err, bill) { + if (err) { + throw err; + } + console.log('People added to db: %s', bill.toString()); + + // using the static + Person.findPersonByName('bill', function(err, result) { + if (err) { + throw err; + } + + console.log(result); + cleanup(); + }); + } + ); +}); + +function cleanup() { + Person.remove(function() { + mongoose.disconnect(); + }); +} diff --git a/node_modules/mongoose/index.js b/node_modules/mongoose/index.js new file mode 100644 index 0000000..e7e6278 --- /dev/null +++ b/node_modules/mongoose/index.js @@ -0,0 +1,7 @@ + +/** + * Export lib/mongoose + * + */ + +module.exports = require('./lib/'); diff --git a/node_modules/mongoose/lib/ES6Promise.js b/node_modules/mongoose/lib/ES6Promise.js new file mode 100644 index 0000000..13371ac --- /dev/null +++ b/node_modules/mongoose/lib/ES6Promise.js @@ -0,0 +1,26 @@ +/** + * ES6 Promise wrapper constructor. + * + * Promises are returned from executed queries. Example: + * + * var query = Candy.find({ bar: true }); + * var promise = query.exec(); + * + * DEPRECATED. Mongoose 5.0 will use native promises by default (or bluebird, + * if native promises are not present) but still + * support plugging in your own ES6-compatible promises library. Mongoose 5.0 + * will **not** support mpromise. + * + * @param {Function} fn a function which will be called when the promise is resolved that accepts `fn(err, ...){}` as signature + * @api public + */ + +function ES6Promise() { + throw new Error('Can\'t use ES6 promise with mpromise style constructor'); +} + +ES6Promise.use = function(Promise) { + ES6Promise.ES6 = Promise; +}; + +module.exports = ES6Promise; diff --git a/node_modules/mongoose/lib/aggregate.js b/node_modules/mongoose/lib/aggregate.js new file mode 100644 index 0000000..bb24e88 --- /dev/null +++ b/node_modules/mongoose/lib/aggregate.js @@ -0,0 +1,685 @@ +/*! + * Module dependencies + */ + +var util = require('util'); +var utils = require('./utils'); +var PromiseProvider = require('./promise_provider'); +var Query = require('./query'); +var read = Query.prototype.read; + +/** + * Aggregate constructor used for building aggregation pipelines. + * + * ####Example: + * + * new Aggregate(); + * new Aggregate({ $project: { a: 1, b: 1 } }); + * new Aggregate({ $project: { a: 1, b: 1 } }, { $skip: 5 }); + * new Aggregate([{ $project: { a: 1, b: 1 } }, { $skip: 5 }]); + * + * Returned when calling Model.aggregate(). + * + * ####Example: + * + * Model + * .aggregate({ $match: { age: { $gte: 21 }}}) + * .unwind('tags') + * .exec(callback) + * + * ####Note: + * + * - The documents returned are plain javascript objects, not mongoose documents (since any shape of document can be returned). + * - Requires MongoDB >= 2.1 + * - Mongoose does **not** cast pipeline stages. `new Aggregate({ $match: { _id: '00000000000000000000000a' } });` will not work unless `_id` is a string in the database. Use `new Aggregate({ $match: { _id: mongoose.Types.ObjectId('00000000000000000000000a') } });` instead. + * + * @see MongoDB http://docs.mongodb.org/manual/applications/aggregation/ + * @see driver http://mongodb.github.com/node-mongodb-native/api-generated/collection.html#aggregate + * @param {Object|Array} [ops] aggregation operator(s) or operator array + * @api public + */ + +function Aggregate() { + this._pipeline = []; + this._model = undefined; + this.options = undefined; + + if (arguments.length === 1 && util.isArray(arguments[0])) { + this.append.apply(this, arguments[0]); + } else { + this.append.apply(this, arguments); + } +} + +/** + * Binds this aggregate to a model. + * + * @param {Model} model the model to which the aggregate is to be bound + * @return {Aggregate} + * @api public + */ + +Aggregate.prototype.model = function(model) { + this._model = model; + return this; +}; + +/** + * Appends new operators to this aggregate pipeline + * + * ####Examples: + * + * aggregate.append({ $project: { field: 1 }}, { $limit: 2 }); + * + * // or pass an array + * var pipeline = [{ $match: { daw: 'Logic Audio X' }} ]; + * aggregate.append(pipeline); + * + * @param {Object} ops operator(s) to append + * @return {Aggregate} + * @api public + */ + +Aggregate.prototype.append = function() { + var args = (arguments.length === 1 && util.isArray(arguments[0])) + ? arguments[0] + : utils.args(arguments); + + if (!args.every(isOperator)) { + throw new Error('Arguments must be aggregate pipeline operators'); + } + + this._pipeline = this._pipeline.concat(args); + + return this; +}; + +/** + * Appends a new $project operator to this aggregate pipeline. + * + * Mongoose query [selection syntax](#query_Query-select) is also supported. + * + * ####Examples: + * + * // include a, include b, exclude _id + * aggregate.project("a b -_id"); + * + * // or you may use object notation, useful when + * // you have keys already prefixed with a "-" + * aggregate.project({a: 1, b: 1, _id: 0}); + * + * // reshaping documents + * aggregate.project({ + * newField: '$b.nested' + * , plusTen: { $add: ['$val', 10]} + * , sub: { + * name: '$a' + * } + * }) + * + * // etc + * aggregate.project({ salary_k: { $divide: [ "$salary", 1000 ] } }); + * + * @param {Object|String} arg field specification + * @see projection http://docs.mongodb.org/manual/reference/aggregation/project/ + * @return {Aggregate} + * @api public + */ + +Aggregate.prototype.project = function(arg) { + var fields = {}; + + if (typeof arg === 'object' && !util.isArray(arg)) { + Object.keys(arg).forEach(function(field) { + fields[field] = arg[field]; + }); + } else if (arguments.length === 1 && typeof arg === 'string') { + arg.split(/\s+/).forEach(function(field) { + if (!field) { + return; + } + var include = field[0] === '-' ? 0 : 1; + if (include === 0) { + field = field.substring(1); + } + fields[field] = include; + }); + } else { + throw new Error('Invalid project() argument. Must be string or object'); + } + + return this.append({$project: fields}); +}; + +/** + * Appends a new custom $group operator to this aggregate pipeline. + * + * ####Examples: + * + * aggregate.group({ _id: "$department" }); + * + * @see $group http://docs.mongodb.org/manual/reference/aggregation/group/ + * @method group + * @memberOf Aggregate + * @param {Object} arg $group operator contents + * @return {Aggregate} + * @api public + */ + +/** + * Appends a new custom $match operator to this aggregate pipeline. + * + * ####Examples: + * + * aggregate.match({ department: { $in: [ "sales", "engineering" } } }); + * + * @see $match http://docs.mongodb.org/manual/reference/aggregation/match/ + * @method match + * @memberOf Aggregate + * @param {Object} arg $match operator contents + * @return {Aggregate} + * @api public + */ + +/** + * Appends a new $skip operator to this aggregate pipeline. + * + * ####Examples: + * + * aggregate.skip(10); + * + * @see $skip http://docs.mongodb.org/manual/reference/aggregation/skip/ + * @method skip + * @memberOf Aggregate + * @param {Number} num number of records to skip before next stage + * @return {Aggregate} + * @api public + */ + +/** + * Appends a new $limit operator to this aggregate pipeline. + * + * ####Examples: + * + * aggregate.limit(10); + * + * @see $limit http://docs.mongodb.org/manual/reference/aggregation/limit/ + * @method limit + * @memberOf Aggregate + * @param {Number} num maximum number of records to pass to the next stage + * @return {Aggregate} + * @api public + */ + +/** + * Appends a new $geoNear operator to this aggregate pipeline. + * + * ####NOTE: + * + * **MUST** be used as the first operator in the pipeline. + * + * ####Examples: + * + * aggregate.near({ + * near: [40.724, -73.997], + * distanceField: "dist.calculated", // required + * maxDistance: 0.008, + * query: { type: "public" }, + * includeLocs: "dist.location", + * uniqueDocs: true, + * num: 5 + * }); + * + * @see $geoNear http://docs.mongodb.org/manual/reference/aggregation/geoNear/ + * @method near + * @memberOf Aggregate + * @param {Object} parameters + * @return {Aggregate} + * @api public + */ + +Aggregate.prototype.near = function(arg) { + var op = {}; + op.$geoNear = arg; + return this.append(op); +}; + +/*! + * define methods + */ + +'group match skip limit out'.split(' ').forEach(function($operator) { + Aggregate.prototype[$operator] = function(arg) { + var op = {}; + op['$' + $operator] = arg; + return this.append(op); + }; +}); + +/** + * Appends new custom $unwind operator(s) to this aggregate pipeline. + * + * Note that the `$unwind` operator requires the path name to start with '$'. + * Mongoose will prepend '$' if the specified field doesn't start '$'. + * + * ####Examples: + * + * aggregate.unwind("tags"); + * aggregate.unwind("a", "b", "c"); + * + * @see $unwind http://docs.mongodb.org/manual/reference/aggregation/unwind/ + * @param {String} fields the field(s) to unwind + * @return {Aggregate} + * @api public + */ + +Aggregate.prototype.unwind = function() { + var args = utils.args(arguments); + + var res = []; + for (var i = 0; i < args.length; ++i) { + var arg = args[i]; + if (arg && typeof arg === 'object') { + res.push({ $unwind: arg }); + } else if (typeof arg === 'string') { + res.push({ + $unwind: (arg && arg.charAt(0) === '$') ? arg : '$' + arg + }); + } else { + throw new Error('Invalid arg "' + arg + '" to unwind(), ' + + 'must be string or object'); + } + } + + return this.append.apply(this, res); +}; + +/** + * Appends new custom $lookup operator(s) to this aggregate pipeline. + * + * ####Examples: + * + * aggregate.lookup({ from: 'users', localField: 'userId', foreignField: '_id', as: 'users' }); + * + * @see $lookup https://docs.mongodb.org/manual/reference/operator/aggregation/lookup/#pipe._S_lookup + * @param {Object} options to $lookup as described in the above link + * @return {Aggregate} + * @api public + */ + +Aggregate.prototype.lookup = function(options) { + return this.append({$lookup: options}); +}; + +/** + * Appends new custom $sample operator(s) to this aggregate pipeline. + * + * ####Examples: + * + * aggregate.sample(3); // Add a pipeline that picks 3 random documents + * + * @see $sample https://docs.mongodb.org/manual/reference/operator/aggregation/sample/#pipe._S_sample + * @param {Number} size number of random documents to pick + * @return {Aggregate} + * @api public + */ + +Aggregate.prototype.sample = function(size) { + return this.append({$sample: {size: size}}); +}; + +/** + * Appends a new $sort operator to this aggregate pipeline. + * + * If an object is passed, values allowed are `asc`, `desc`, `ascending`, `descending`, `1`, and `-1`. + * + * If a string is passed, it must be a space delimited list of path names. The sort order of each path is ascending unless the path name is prefixed with `-` which will be treated as descending. + * + * ####Examples: + * + * // these are equivalent + * aggregate.sort({ field: 'asc', test: -1 }); + * aggregate.sort('field -test'); + * + * @see $sort http://docs.mongodb.org/manual/reference/aggregation/sort/ + * @param {Object|String} arg + * @return {Aggregate} this + * @api public + */ + +Aggregate.prototype.sort = function(arg) { + // TODO refactor to reuse the query builder logic + + var sort = {}; + + if (arg.constructor.name === 'Object') { + var desc = ['desc', 'descending', -1]; + Object.keys(arg).forEach(function(field) { + sort[field] = desc.indexOf(arg[field]) === -1 ? 1 : -1; + }); + } else if (arguments.length === 1 && typeof arg === 'string') { + arg.split(/\s+/).forEach(function(field) { + if (!field) { + return; + } + var ascend = field[0] === '-' ? -1 : 1; + if (ascend === -1) { + field = field.substring(1); + } + sort[field] = ascend; + }); + } else { + throw new TypeError('Invalid sort() argument. Must be a string or object.'); + } + + return this.append({$sort: sort}); +}; + +/** + * Sets the readPreference option for the aggregation query. + * + * ####Example: + * + * Model.aggregate(..).read('primaryPreferred').exec(callback) + * + * @param {String} pref one of the listed preference options or their aliases + * @param {Array} [tags] optional tags for this query + * @see mongodb http://docs.mongodb.org/manual/applications/replication/#read-preference + * @see driver http://mongodb.github.com/node-mongodb-native/driver-articles/anintroductionto1_1and2_2.html#read-preferences + */ + +Aggregate.prototype.read = function(pref, tags) { + if (!this.options) { + this.options = {}; + } + read.call(this, pref, tags); + return this; +}; + +/** + * Execute the aggregation with explain + * + * ####Example: + * + * Model.aggregate(..).explain(callback) + * + * @param {Function} callback + * @return {Promise} + */ + +Aggregate.prototype.explain = function(callback) { + var _this = this; + var Promise = PromiseProvider.get(); + return new Promise.ES6(function(resolve, reject) { + if (!_this._pipeline.length) { + var err = new Error('Aggregate has empty pipeline'); + if (callback) { + callback(err); + } + reject(err); + return; + } + + prepareDiscriminatorPipeline(_this); + + _this._model + .collection + .aggregate(_this._pipeline, _this.options || {}) + .explain(function(error, result) { + if (error) { + if (callback) { + callback(error); + } + reject(error); + return; + } + + if (callback) { + callback(null, result); + } + resolve(result); + }); + }); +}; + +/** + * Sets the allowDiskUse option for the aggregation query (ignored for < 2.6.0) + * + * ####Example: + * + * Model.aggregate(..).allowDiskUse(true).exec(callback) + * + * @param {Boolean} value Should tell server it can use hard drive to store data during aggregation. + * @param {Array} [tags] optional tags for this query + * @see mongodb http://docs.mongodb.org/manual/reference/command/aggregate/ + */ + +Aggregate.prototype.allowDiskUse = function(value) { + if (!this.options) { + this.options = {}; + } + this.options.allowDiskUse = value; + return this; +}; + +/** + * Sets the cursor option option for the aggregation query (ignored for < 2.6.0). + * Note the different syntax below: .exec() returns a cursor object, and no callback + * is necessary. + * + * ####Example: + * + * var cursor = Model.aggregate(..).cursor({ batchSize: 1000 }).exec(); + * cursor.each(function(error, doc) { + * // use doc + * }); + * + * @param {Object} options set the cursor batch size + * @see mongodb http://mongodb.github.io/node-mongodb-native/2.0/api/AggregationCursor.html + */ + +Aggregate.prototype.cursor = function(options) { + if (!this.options) { + this.options = {}; + } + this.options.cursor = options || {}; + return this; +}; + +/** + * Adds a [cursor flag](http://mongodb.github.io/node-mongodb-native/2.1/api/Cursor.html#addCursorFlag) + * + * ####Example: + * + * var cursor = Model.aggregate(..).cursor({ batchSize: 1000 }).exec(); + * cursor.each(function(error, doc) { + * // use doc + * }); + * + * @param {String} flag + * @param {Boolean} value + * @see mongodb http://mongodb.github.io/node-mongodb-native/2.1/api/Cursor.html#addCursorFlag + */ + +Aggregate.prototype.addCursorFlag = function(flag, value) { + if (!this.options) { + this.options = {}; + } + this.options[flag] = value; + return this; +}; + +/** + * Executes the aggregate pipeline on the currently bound Model. + * + * ####Example: + * + * aggregate.exec(callback); + * + * // Because a promise is returned, the `callback` is optional. + * var promise = aggregate.exec(); + * promise.then(..); + * + * @see Promise #promise_Promise + * @param {Function} [callback] + * @return {Promise} + * @api public + */ + +Aggregate.prototype.exec = function(callback) { + if (!this._model) { + throw new Error('Aggregate not bound to any Model'); + } + var _this = this; + var Promise = PromiseProvider.get(); + var options = utils.clone(this.options); + + if (options && options.cursor) { + if (options.cursor.async) { + delete options.cursor.async; + return new Promise.ES6(function(resolve) { + if (!_this._model.collection.buffer) { + process.nextTick(function() { + var cursor = _this._model.collection. + aggregate(_this._pipeline, options || {}); + resolve(cursor); + callback && callback(null, cursor); + }); + return; + } + _this._model.collection.emitter.once('queue', function() { + var cursor = _this._model.collection. + aggregate(_this._pipeline, options || {}); + resolve(cursor); + callback && callback(null, cursor); + }); + }); + } + return this._model.collection. + aggregate(this._pipeline, this.options || {}); + } + + return new Promise.ES6(function(resolve, reject) { + if (!_this._pipeline.length) { + var err = new Error('Aggregate has empty pipeline'); + if (callback) { + callback(err); + } + reject(err); + return; + } + + prepareDiscriminatorPipeline(_this); + + _this._model + .collection + .aggregate(_this._pipeline, _this.options || {}, function(error, result) { + if (error) { + if (callback) { + callback(error); + } + reject(error); + return; + } + + if (callback) { + callback(null, result); + } + resolve(result); + }); + }); +}; + +/** + * Provides promise for aggregate. + * + * ####Example: + * + * Model.aggregate(..).then(successCallback, errorCallback); + * + * @see Promise #promise_Promise + * @param {Function} [resolve] successCallback + * @param {Function} [reject] errorCallback + * @return {Promise} + */ +Aggregate.prototype.then = function(resolve, reject) { + var _this = this; + var Promise = PromiseProvider.get(); + var promise = new Promise.ES6(function(success, error) { + _this.exec(function(err, val) { + if (err) error(err); + else success(val); + }); + }); + return promise.then(resolve, reject); +}; + +/*! + * Helpers + */ + +/** + * Checks whether an object is likely a pipeline operator + * + * @param {Object} obj object to check + * @return {Boolean} + * @api private + */ + +function isOperator(obj) { + var k; + + if (typeof obj !== 'object') { + return false; + } + + k = Object.keys(obj); + + return k.length === 1 && k + .some(function(key) { + return key[0] === '$'; + }); +} + +/*! + * Adds the appropriate `$match` pipeline step to the top of an aggregate's + * pipeline, should it's model is a non-root discriminator type. This is + * analogous to the `prepareDiscriminatorCriteria` function in `lib/query.js`. + * + * @param {Aggregate} aggregate Aggregate to prepare + */ + +function prepareDiscriminatorPipeline(aggregate) { + var schema = aggregate._model.schema, + discriminatorMapping = schema && schema.discriminatorMapping; + + if (discriminatorMapping && !discriminatorMapping.isRoot) { + var originalPipeline = aggregate._pipeline, + discriminatorKey = discriminatorMapping.key, + discriminatorValue = discriminatorMapping.value; + + // If the first pipeline stage is a match and it doesn't specify a `__t` + // key, add the discriminator key to it. This allows for potential + // aggregation query optimizations not to be disturbed by this feature. + if (originalPipeline[0] && originalPipeline[0].$match && !originalPipeline[0].$match[discriminatorKey]) { + originalPipeline[0].$match[discriminatorKey] = discriminatorValue; + // `originalPipeline` is a ref, so there's no need for + // aggregate._pipeline = originalPipeline + } else if (originalPipeline[0] && originalPipeline[0].$geoNear) { + originalPipeline[0].$geoNear.query = + originalPipeline[0].$geoNear.query || {}; + originalPipeline[0].$geoNear.query[discriminatorKey] = discriminatorValue; + } else { + var match = {}; + match[discriminatorKey] = discriminatorValue; + aggregate._pipeline = [{$match: match}].concat(originalPipeline); + } + } +} + + +/*! + * Exports + */ + +module.exports = Aggregate; diff --git a/node_modules/mongoose/lib/browser.js b/node_modules/mongoose/lib/browser.js new file mode 100644 index 0000000..74a7b6e --- /dev/null +++ b/node_modules/mongoose/lib/browser.js @@ -0,0 +1,99 @@ +/* eslint-env browser */ + +/** + * The [MongooseError](#error_MongooseError) constructor. + * + * @method Error + * @api public + */ + +exports.Error = require('./error'); + +/** + * The Mongoose [Schema](#schema_Schema) constructor + * + * ####Example: + * + * var mongoose = require('mongoose'); + * var Schema = mongoose.Schema; + * var CatSchema = new Schema(..); + * + * @method Schema + * @api public + */ + +exports.Schema = require('./schema'); + +/** + * The various Mongoose Types. + * + * ####Example: + * + * var mongoose = require('mongoose'); + * var array = mongoose.Types.Array; + * + * ####Types: + * + * - [ObjectId](#types-objectid-js) + * - [Buffer](#types-buffer-js) + * - [SubDocument](#types-embedded-js) + * - [Array](#types-array-js) + * - [DocumentArray](#types-documentarray-js) + * + * Using this exposed access to the `ObjectId` type, we can construct ids on demand. + * + * var ObjectId = mongoose.Types.ObjectId; + * var id1 = new ObjectId; + * + * @property Types + * @api public + */ +exports.Types = require('./types'); + +/** + * The Mongoose [VirtualType](#virtualtype_VirtualType) constructor + * + * @method VirtualType + * @api public + */ +exports.VirtualType = require('./virtualtype'); + +/** + * The various Mongoose SchemaTypes. + * + * ####Note: + * + * _Alias of mongoose.Schema.Types for backwards compatibility._ + * + * @property SchemaTypes + * @see Schema.SchemaTypes #schema_Schema.Types + * @api public + */ + +exports.SchemaType = require('./schematype.js'); + +/** + * Internal utils + * + * @property utils + * @api private + */ + +exports.utils = require('./utils.js'); + +/** + * The Mongoose browser [Document](#document-js) constructor. + * + * @method Document + * @api public + */ +exports.Document = require('./document_provider.js')(); + +/*! + * Module exports. + */ + +if (typeof window !== 'undefined') { + window.mongoose = module.exports; + window.Buffer = Buffer; +} diff --git a/node_modules/mongoose/lib/browserDocument.js b/node_modules/mongoose/lib/browserDocument.js new file mode 100644 index 0000000..6c87d19 --- /dev/null +++ b/node_modules/mongoose/lib/browserDocument.js @@ -0,0 +1,103 @@ +/*! + * Module dependencies. + */ + +var NodeJSDocument = require('./document'), + EventEmitter = require('events').EventEmitter, + MongooseError = require('./error'), + Schema = require('./schema'), + ObjectId = require('./types/objectid'), + utils = require('./utils'), + ValidationError = MongooseError.ValidationError, + InternalCache = require('./internal'); + +/** + * Document constructor. + * + * @param {Object} obj the values to set + * @param {Object} [fields] optional object containing the fields which were selected in the query returning this document and any populated paths data + * @param {Boolean} [skipId] bool, should we auto create an ObjectId _id + * @inherits NodeJS EventEmitter http://nodejs.org/api/events.html#events_class_events_eventemitter + * @event `init`: Emitted on a document after it has was retrieved from the db and fully hydrated by Mongoose. + * @event `save`: Emitted when the document is successfully saved + * @api private + */ + +function Document(obj, schema, fields, skipId, skipInit) { + if (!(this instanceof Document)) { + return new Document(obj, schema, fields, skipId, skipInit); + } + + + if (utils.isObject(schema) && !schema.instanceOfSchema) { + schema = new Schema(schema); + } + + // When creating EmbeddedDocument, it already has the schema and he doesn't need the _id + schema = this.schema || schema; + + // Generate ObjectId if it is missing, but it requires a scheme + if (!this.schema && schema.options._id) { + obj = obj || {}; + + if (obj._id === undefined) { + obj._id = new ObjectId(); + } + } + + if (!schema) { + throw new MongooseError.MissingSchemaError(); + } + + this.$__setSchema(schema); + + this.$__ = new InternalCache; + this.$__.emitter = new EventEmitter(); + this.isNew = true; + this.errors = undefined; + + // var schema = this.schema; + + if (typeof fields === 'boolean') { + this.$__.strictMode = fields; + fields = undefined; + } else { + this.$__.strictMode = this.schema.options && this.schema.options.strict; + this.$__.selected = fields; + } + + var required = this.schema.requiredPaths(); + for (var i = 0; i < required.length; ++i) { + this.$__.activePaths.require(required[i]); + } + + this.$__.emitter.setMaxListeners(0); + this._doc = this.$__buildDoc(obj, fields, skipId); + + if (!skipInit && obj) { + this.init(obj); + } + + this.$__registerHooksFromSchema(); + + // apply methods + for (var m in schema.methods) { + this[m] = schema.methods[m]; + } + // apply statics + for (var s in schema.statics) { + this[s] = schema.statics[s]; + } +} + +/*! + * Inherit from the NodeJS document + */ +Document.prototype = Object.create(NodeJSDocument.prototype); +Document.prototype.constructor = Document; + +/*! + * Module exports. + */ +Document.ValidationError = ValidationError; +module.exports = exports = Document; diff --git a/node_modules/mongoose/lib/cast.js b/node_modules/mongoose/lib/cast.js new file mode 100644 index 0000000..3f687d0 --- /dev/null +++ b/node_modules/mongoose/lib/cast.js @@ -0,0 +1,255 @@ +/*! + * Module dependencies. + */ + +var utils = require('./utils'); +var Types = require('./schema/index'); + +var ALLOWED_GEOWITHIN_GEOJSON_TYPES = ['Polygon', 'MultiPolygon']; + +/** + * Handles internal casting for queries + * + * @param {Schema} schema + * @param {Object} obj Object to cast + * @api private + */ +module.exports = function cast(schema, obj) { + var paths = Object.keys(obj), + i = paths.length, + _keys, + any$conditionals, + schematype, + nested, + path, + type, + val; + + while (i--) { + path = paths[i]; + val = obj[path]; + + if (path === '$or' || path === '$nor' || path === '$and') { + var k = val.length; + + while (k--) { + val[k] = cast(schema, val[k]); + } + } else if (path === '$where') { + type = typeof val; + + if (type !== 'string' && type !== 'function') { + throw new Error('Must have a string or function for $where'); + } + + if (type === 'function') { + obj[path] = val.toString(); + } + + continue; + } else if (path === '$elemMatch') { + val = cast(schema, val); + } else { + if (!schema) { + // no casting for Mixed types + continue; + } + + schematype = schema.path(path); + + if (!schematype) { + // Handle potential embedded array queries + var split = path.split('.'), + j = split.length, + pathFirstHalf, + pathLastHalf, + remainingConds; + + // Find the part of the var path that is a path of the Schema + while (j--) { + pathFirstHalf = split.slice(0, j).join('.'); + schematype = schema.path(pathFirstHalf); + if (schematype) { + break; + } + } + + // If a substring of the input path resolves to an actual real path... + if (schematype) { + // Apply the casting; similar code for $elemMatch in schema/array.js + if (schematype.caster && schematype.caster.schema) { + remainingConds = {}; + pathLastHalf = split.slice(j).join('.'); + remainingConds[pathLastHalf] = val; + obj[path] = cast(schematype.caster.schema, remainingConds)[pathLastHalf]; + } else { + obj[path] = val; + } + continue; + } + + if (utils.isObject(val)) { + // handle geo schemas that use object notation + // { loc: { long: Number, lat: Number } + + var geo = ''; + if (val.$near) { + geo = '$near'; + } else if (val.$nearSphere) { + geo = '$nearSphere'; + } else if (val.$within) { + geo = '$within'; + } else if (val.$geoIntersects) { + geo = '$geoIntersects'; + } else if (val.$geoWithin) { + geo = '$geoWithin'; + } + + if (!geo) { + continue; + } + + var numbertype = new Types.Number('__QueryCasting__'); + var value = val[geo]; + + if (val.$maxDistance != null) { + val.$maxDistance = numbertype.castForQuery(val.$maxDistance); + } + if (val.$minDistance != null) { + val.$minDistance = numbertype.castForQuery(val.$minDistance); + } + + if (geo === '$within') { + var withinType = value.$center + || value.$centerSphere + || value.$box + || value.$polygon; + + if (!withinType) { + throw new Error('Bad $within paramater: ' + JSON.stringify(val)); + } + + value = withinType; + } else if (geo === '$near' && + typeof value.type === 'string' && Array.isArray(value.coordinates)) { + // geojson; cast the coordinates + value = value.coordinates; + } else if ((geo === '$near' || geo === '$nearSphere' || geo === '$geoIntersects') && + value.$geometry && typeof value.$geometry.type === 'string' && + Array.isArray(value.$geometry.coordinates)) { + if (value.$maxDistance != null) { + value.$maxDistance = numbertype.castForQuery(value.$maxDistance); + } + if (value.$minDistance != null) { + value.$minDistance = numbertype.castForQuery(value.$minDistance); + } + if (utils.isMongooseObject(value.$geometry)) { + value.$geometry = value.$geometry.toObject({ transform: false }); + } + value = value.$geometry.coordinates; + } else if (geo === '$geoWithin') { + if (value.$geometry) { + if (utils.isMongooseObject(value.$geometry)) { + value.$geometry = value.$geometry.toObject({ virtuals: false }); + } + var geoWithinType = value.$geometry.type; + if (ALLOWED_GEOWITHIN_GEOJSON_TYPES.indexOf(geoWithinType) === -1) { + throw new Error('Invalid geoJSON type for $geoWithin "' + + geoWithinType + '", must be "Polygon" or "MultiPolygon"'); + } + value = value.$geometry.coordinates; + } else { + value = value.$box || value.$polygon || value.$center || + value.$centerSphere; + if (utils.isMongooseObject(value)) { + value = value.toObject({ virtuals: false }); + } + } + } + + _cast(value, numbertype); + } + } else if (val === null || val === undefined) { + obj[path] = null; + continue; + } else if (val.constructor.name === 'Object') { + any$conditionals = Object.keys(val).some(function(k) { + return k.charAt(0) === '$' && k !== '$id' && k !== '$ref'; + }); + + if (!any$conditionals) { + obj[path] = schematype.castForQuery(val); + } else { + var ks = Object.keys(val), + $cond; + + k = ks.length; + + while (k--) { + $cond = ks[k]; + nested = val[$cond]; + + if ($cond === '$exists') { + if (typeof nested !== 'boolean') { + throw new Error('$exists parameter must be Boolean'); + } + continue; + } + + if ($cond === '$type') { + if (typeof nested !== 'number' && typeof nested !== 'string') { + throw new Error('$type parameter must be number or string'); + } + continue; + } + + if ($cond === '$not') { + if (nested && schematype && !schematype.caster) { + _keys = Object.keys(nested); + if (_keys.length && _keys[0].charAt(0) === '$') { + for (var key in nested) { + nested[key] = schematype.castForQuery(key, nested[key]); + } + } else { + val[$cond] = schematype.castForQuery($cond, nested); + } + continue; + } + cast(schematype.caster ? schematype.caster.schema : schema, nested); + } else { + val[$cond] = schematype.castForQuery($cond, nested); + } + } + } + } else { + obj[path] = schematype.castForQuery(val); + } + } + } + + return obj; +}; + +function _cast(val, numbertype) { + if (Array.isArray(val)) { + val.forEach(function(item, i) { + if (Array.isArray(item) || utils.isObject(item)) { + return _cast(item, numbertype); + } + val[i] = numbertype.castForQuery(item); + }); + } else { + var nearKeys = Object.keys(val); + var nearLen = nearKeys.length; + while (nearLen--) { + var nkey = nearKeys[nearLen]; + var item = val[nkey]; + if (Array.isArray(item) || utils.isObject(item)) { + _cast(item, numbertype); + val[nkey] = item; + } else { + val[nkey] = numbertype.castForQuery(item); + } + } + } +} diff --git a/node_modules/mongoose/lib/collection.js b/node_modules/mongoose/lib/collection.js new file mode 100644 index 0000000..3aee0aa --- /dev/null +++ b/node_modules/mongoose/lib/collection.js @@ -0,0 +1,206 @@ +/*! + * Module dependencies. + */ + +var EventEmitter = require('events').EventEmitter; +var STATES = require('./connectionstate'); + +/** + * Abstract Collection constructor + * + * This is the base class that drivers inherit from and implement. + * + * @param {String} name name of the collection + * @param {Connection} conn A MongooseConnection instance + * @param {Object} opts optional collection options + * @api public + */ + +function Collection(name, conn, opts) { + if (opts === void 0) { + opts = {}; + } + if (opts.capped === void 0) { + opts.capped = {}; + } + + opts.bufferCommands = undefined === opts.bufferCommands + ? true + : opts.bufferCommands; + + if (typeof opts.capped === 'number') { + opts.capped = {size: opts.capped}; + } + + this.opts = opts; + this.name = name; + this.collectionName = name; + this.conn = conn; + this.queue = []; + this.buffer = this.opts.bufferCommands; + this.emitter = new EventEmitter(); + + if (STATES.connected === this.conn.readyState) { + this.onOpen(); + } +} + +/** + * The collection name + * + * @api public + * @property name + */ + +Collection.prototype.name; + +/** + * The collection name + * + * @api public + * @property collectionName + */ + +Collection.prototype.collectionName; + +/** + * The Connection instance + * + * @api public + * @property conn + */ + +Collection.prototype.conn; + +/** + * Called when the database connects + * + * @api private + */ + +Collection.prototype.onOpen = function() { + this.buffer = false; + this.doQueue(); +}; + +/** + * Called when the database disconnects + * + * @api private + */ + +Collection.prototype.onClose = function() { + if (this.opts.bufferCommands) { + this.buffer = true; + } +}; + +/** + * Queues a method for later execution when its + * database connection opens. + * + * @param {String} name name of the method to queue + * @param {Array} args arguments to pass to the method when executed + * @api private + */ + +Collection.prototype.addQueue = function(name, args) { + this.queue.push([name, args]); + return this; +}; + +/** + * Executes all queued methods and clears the queue. + * + * @api private + */ + +Collection.prototype.doQueue = function() { + for (var i = 0, l = this.queue.length; i < l; i++) { + this[this.queue[i][0]].apply(this, this.queue[i][1]); + } + this.queue = []; + var _this = this; + process.nextTick(function() { + _this.emitter.emit('queue'); + }); + return this; +}; + +/** + * Abstract method that drivers must implement. + */ + +Collection.prototype.ensureIndex = function() { + throw new Error('Collection#ensureIndex unimplemented by driver'); +}; + +/** + * Abstract method that drivers must implement. + */ + +Collection.prototype.findAndModify = function() { + throw new Error('Collection#findAndModify unimplemented by driver'); +}; + +/** + * Abstract method that drivers must implement. + */ + +Collection.prototype.findOne = function() { + throw new Error('Collection#findOne unimplemented by driver'); +}; + +/** + * Abstract method that drivers must implement. + */ + +Collection.prototype.find = function() { + throw new Error('Collection#find unimplemented by driver'); +}; + +/** + * Abstract method that drivers must implement. + */ + +Collection.prototype.insert = function() { + throw new Error('Collection#insert unimplemented by driver'); +}; + +/** + * Abstract method that drivers must implement. + */ + +Collection.prototype.save = function() { + throw new Error('Collection#save unimplemented by driver'); +}; + +/** + * Abstract method that drivers must implement. + */ + +Collection.prototype.update = function() { + throw new Error('Collection#update unimplemented by driver'); +}; + +/** + * Abstract method that drivers must implement. + */ + +Collection.prototype.getIndexes = function() { + throw new Error('Collection#getIndexes unimplemented by driver'); +}; + +/** + * Abstract method that drivers must implement. + */ + +Collection.prototype.mapReduce = function() { + throw new Error('Collection#mapReduce unimplemented by driver'); +}; + +/*! + * Module exports. + */ + +module.exports = Collection; diff --git a/node_modules/mongoose/lib/connection.js b/node_modules/mongoose/lib/connection.js new file mode 100644 index 0000000..796ebd2 --- /dev/null +++ b/node_modules/mongoose/lib/connection.js @@ -0,0 +1,796 @@ +/*! + * Module dependencies. + */ + +var utils = require('./utils'); +var EventEmitter = require('events').EventEmitter; +var driver = global.MONGOOSE_DRIVER_PATH || './drivers/node-mongodb-native'; +var Schema = require('./schema'); +var Collection = require(driver + '/collection'); +var STATES = require('./connectionstate'); +var MongooseError = require('./error'); +var muri = require('muri'); +var PromiseProvider = require('./promise_provider'); + +/*! + * Protocol prefix regexp. + * + * @api private + */ + +var rgxProtocol = /^(?:.)+:\/\//; + +/*! + * A list of authentication mechanisms that don't require a password for authentication. + * This is used by the authMechanismDoesNotRequirePassword method. + * + * @api private + */ +var authMechanismsWhichDontRequirePassword = [ + 'MONGODB-X509' +]; + +/** + * Connection constructor + * + * For practical reasons, a Connection equals a Db. + * + * @param {Mongoose} base a mongoose instance + * @inherits NodeJS EventEmitter http://nodejs.org/api/events.html#events_class_events_eventemitter + * @event `connecting`: Emitted when `connection.{open,openSet}()` is executed on this connection. + * @event `connected`: Emitted when this connection successfully connects to the db. May be emitted _multiple_ times in `reconnected` scenarios. + * @event `open`: Emitted after we `connected` and `onOpen` is executed on all of this connections models. + * @event `disconnecting`: Emitted when `connection.close()` was executed. + * @event `disconnected`: Emitted after getting disconnected from the db. + * @event `close`: Emitted after we `disconnected` and `onClose` executed on all of this connections models. + * @event `reconnected`: Emitted after we `connected` and subsequently `disconnected`, followed by successfully another successfull connection. + * @event `error`: Emitted when an error occurs on this connection. + * @event `fullsetup`: Emitted in a replica-set scenario, when primary and at least one seconaries specified in the connection string are connected. + * @event `all`: Emitted in a replica-set scenario, when all nodes specified in the connection string are connected. + * @api public + */ + +function Connection(base) { + this.base = base; + this.collections = {}; + this.models = {}; + this.config = {autoIndex: true}; + this.replica = false; + this.hosts = null; + this.host = null; + this.port = null; + this.user = null; + this.pass = null; + this.name = null; + this.options = null; + this.otherDbs = []; + this._readyState = STATES.disconnected; + this._closeCalled = false; + this._hasOpened = false; +} + +/*! + * Inherit from EventEmitter + */ + +Connection.prototype.__proto__ = EventEmitter.prototype; + +/** + * Connection ready state + * + * - 0 = disconnected + * - 1 = connected + * - 2 = connecting + * - 3 = disconnecting + * + * Each state change emits its associated event name. + * + * ####Example + * + * conn.on('connected', callback); + * conn.on('disconnected', callback); + * + * @property readyState + * @api public + */ + +Object.defineProperty(Connection.prototype, 'readyState', { + get: function() { + return this._readyState; + }, + set: function(val) { + if (!(val in STATES)) { + throw new Error('Invalid connection state: ' + val); + } + + if (this._readyState !== val) { + this._readyState = val; + // loop over the otherDbs on this connection and change their state + for (var i = 0; i < this.otherDbs.length; i++) { + this.otherDbs[i].readyState = val; + } + + if (STATES.connected === val) { + this._hasOpened = true; + } + + this.emit(STATES[val]); + } + } +}); + +/** + * A hash of the collections associated with this connection + * + * @property collections + */ + +Connection.prototype.collections; + +/** + * The mongodb.Db instance, set when the connection is opened + * + * @property db + */ + +Connection.prototype.db; + +/** + * A hash of the global options that are associated with this connection + * + * @property config + */ + +Connection.prototype.config; + +/** + * Opens the connection to MongoDB. + * + * `options` is a hash with the following possible properties: + * + * config - passed to the connection config instance + * db - passed to the connection db instance + * server - passed to the connection server instance(s) + * replset - passed to the connection ReplSet instance + * user - username for authentication + * pass - password for authentication + * auth - options for authentication (see http://mongodb.github.com/node-mongodb-native/api-generated/db.html#authenticate) + * + * ####Notes: + * + * Mongoose forces the db option `forceServerObjectId` false and cannot be overridden. + * Mongoose defaults the server `auto_reconnect` options to true which can be overridden. + * See the node-mongodb-native driver instance for options that it understands. + * + * _Options passed take precedence over options included in connection strings._ + * + * @param {String} connection_string mongodb://uri or the host to which you are connecting + * @param {String} [database] database name + * @param {Number} [port] database port + * @param {Object} [options] options + * @param {Function} [callback] + * @see node-mongodb-native https://github.com/mongodb/node-mongodb-native + * @see http://mongodb.github.com/node-mongodb-native/api-generated/db.html#authenticate + * @api public + */ + +Connection.prototype.open = function(host, database, port, options, callback) { + var parsed; + + if (typeof database === 'string') { + switch (arguments.length) { + case 2: + port = 27017; + break; + case 3: + switch (typeof port) { + case 'function': + callback = port; + port = 27017; + break; + case 'object': + options = port; + port = 27017; + break; + } + break; + case 4: + if (typeof options === 'function') { + callback = options; + options = {}; + } + } + } else { + switch (typeof database) { + case 'function': + callback = database; + database = undefined; + break; + case 'object': + options = database; + database = undefined; + callback = port; + break; + } + + if (!rgxProtocol.test(host)) { + host = 'mongodb://' + host; + } + + try { + parsed = muri(host); + } catch (err) { + this.error(err, callback); + return this; + } + + database = parsed.db; + host = parsed.hosts[0].host || parsed.hosts[0].ipc; + port = parsed.hosts[0].port || 27017; + } + + this.options = this.parseOptions(options, parsed && parsed.options); + + // make sure we can open + if (STATES.disconnected !== this.readyState) { + var err = new Error('Trying to open unclosed connection.'); + err.state = this.readyState; + this.error(err, callback); + return this; + } + + if (!host) { + this.error(new Error('Missing hostname.'), callback); + return this; + } + + if (!database) { + this.error(new Error('Missing database name.'), callback); + return this; + } + + // authentication + if (this.optionsProvideAuthenticationData(options)) { + this.user = options.user; + this.pass = options.pass; + } else if (parsed && parsed.auth) { + this.user = parsed.auth.user; + this.pass = parsed.auth.pass; + + // Check hostname for user/pass + } else if (/@/.test(host) && /:/.test(host.split('@')[0])) { + host = host.split('@'); + var auth = host.shift().split(':'); + host = host.pop(); + this.user = auth[0]; + this.pass = auth[1]; + } else { + this.user = this.pass = undefined; + } + + // global configuration options + if (options && options.config) { + this.config.autoIndex = options.config.autoIndex !== false; + } + + this.name = database; + this.host = host; + this.port = port; + + var _this = this; + var Promise = PromiseProvider.get(); + var promise = new Promise.ES6(function(resolve, reject) { + _this._open(true, function(error) { + callback && callback(error); + if (error) { + reject(error); + if (!callback && !promise.$hasHandler) { + _this.emit('error', error); + } + return; + } + resolve(); + }); + }); + return promise; +}; + +/** + * Opens the connection to a replica set. + * + * ####Example: + * + * var db = mongoose.createConnection(); + * db.openSet("mongodb://user:pwd@localhost:27020/testing,mongodb://example.com:27020,mongodb://localhost:27019"); + * + * The database name and/or auth need only be included in one URI. + * The `options` is a hash which is passed to the internal driver connection object. + * + * Valid `options` + * + * db - passed to the connection db instance + * server - passed to the connection server instance(s) + * replset - passed to the connection ReplSetServer instance + * user - username for authentication + * pass - password for authentication + * auth - options for authentication (see http://mongodb.github.com/node-mongodb-native/api-generated/db.html#authenticate) + * mongos - Boolean - if true, enables High Availability support for mongos + * + * _Options passed take precedence over options included in connection strings._ + * + * ####Notes: + * + * _If connecting to multiple mongos servers, set the `mongos` option to true._ + * + * conn.open('mongodb://mongosA:27501,mongosB:27501', { mongos: true }, cb); + * + * Mongoose forces the db option `forceServerObjectId` false and cannot be overridden. + * Mongoose defaults the server `auto_reconnect` options to true which can be overridden. + * See the node-mongodb-native driver instance for options that it understands. + * + * _Options passed take precedence over options included in connection strings._ + * + * @param {String} uris comma-separated mongodb:// `URI`s + * @param {String} [database] database name if not included in `uris` + * @param {Object} [options] passed to the internal driver + * @param {Function} [callback] + * @see node-mongodb-native https://github.com/mongodb/node-mongodb-native + * @see http://mongodb.github.com/node-mongodb-native/api-generated/db.html#authenticate + * @api public + */ + +Connection.prototype.openSet = function(uris, database, options, callback) { + if (!rgxProtocol.test(uris)) { + uris = 'mongodb://' + uris; + } + + switch (arguments.length) { + case 3: + switch (typeof database) { + case 'string': + this.name = database; + break; + case 'object': + callback = options; + options = database; + database = null; + break; + } + + if (typeof options === 'function') { + callback = options; + options = {}; + } + break; + case 2: + switch (typeof database) { + case 'string': + this.name = database; + break; + case 'function': + callback = database; + database = null; + break; + case 'object': + options = database; + database = null; + break; + } + } + + var parsed; + try { + parsed = muri(uris); + } catch (err) { + this.error(err, callback); + return this; + } + + if (!this.name) { + this.name = parsed.db; + } + + this.hosts = parsed.hosts; + this.options = this.parseOptions(options, parsed && parsed.options); + this.replica = true; + + if (!this.name) { + this.error(new Error('No database name provided for replica set'), callback); + return this; + } + + // authentication + if (this.optionsProvideAuthenticationData(options)) { + this.user = options.user; + this.pass = options.pass; + } else if (parsed && parsed.auth) { + this.user = parsed.auth.user; + this.pass = parsed.auth.pass; + } else { + this.user = this.pass = undefined; + } + + // global configuration options + if (options && options.config) { + this.config.autoIndex = options.config.autoIndex !== false; + } + + var _this = this; + var Promise = PromiseProvider.get(); + var emitted = false; + var promise = new Promise.ES6(function(resolve, reject) { + _this._open(true, function(error) { + callback && callback(error); + if (error) { + reject(error); + if (!callback && !promise.$hasHandler && !emitted) { + emitted = true; + _this.emit('error', error); + } + return; + } + resolve(); + }); + }); + return promise; +}; + +/** + * error + * + * Graceful error handling, passes error to callback + * if available, else emits error on the connection. + * + * @param {Error} err + * @param {Function} callback optional + * @api private + */ + +Connection.prototype.error = function(err, callback) { + if (callback) { + return callback(err); + } + this.emit('error', err); +}; + +/** + * Handles opening the connection with the appropriate method based on connection type. + * + * @param {Function} callback + * @api private + */ + +Connection.prototype._open = function(emit, callback) { + this.readyState = STATES.connecting; + this._closeCalled = false; + + var _this = this; + + var method = this.replica + ? 'doOpenSet' + : 'doOpen'; + + // open connection + this[method](function(err) { + if (err) { + _this.readyState = STATES.disconnected; + if (_this._hasOpened) { + if (callback) { + callback(err); + } + } else { + _this.error(err, emit && callback); + } + return; + } + + _this.onOpen(callback); + }); +}; + +/** + * Called when the connection is opened + * + * @api private + */ + +Connection.prototype.onOpen = function(callback) { + var _this = this; + + function open(err, isAuth) { + if (err) { + _this.readyState = isAuth ? STATES.unauthorized : STATES.disconnected; + _this.error(err, callback); + return; + } + + _this.readyState = STATES.connected; + + // avoid having the collection subscribe to our event emitter + // to prevent 0.3 warning + for (var i in _this.collections) { + if (utils.object.hasOwnProperty(_this.collections, i)) { + _this.collections[i].onOpen(); + } + } + + callback && callback(); + _this.emit('open'); + } + + // re-authenticate if we're not already connected #3871 + if (this._readyState !== STATES.connected && this.shouldAuthenticate()) { + _this.db.authenticate(_this.user, _this.pass, _this.options.auth, function(err) { + open(err, true); + }); + } else { + open(); + } +}; + +/** + * Closes the connection + * + * @param {Function} [callback] optional + * @return {Connection} self + * @api public + */ + +Connection.prototype.close = function(callback) { + var _this = this; + var Promise = PromiseProvider.get(); + return new Promise.ES6(function(resolve, reject) { + _this._close(function(error) { + callback && callback(error); + if (error) { + reject(error); + return; + } + resolve(); + }); + }); +}; + +/** + * Handles closing the connection + * + * @param {Function} callback + * @api private + */ +Connection.prototype._close = function(callback) { + var _this = this; + this._closeCalled = true; + + switch (this.readyState) { + case 0: // disconnected + callback && callback(); + break; + + case 1: // connected + case 4: // unauthorized + this.readyState = STATES.disconnecting; + this.doClose(function(err) { + if (err) { + _this.error(err, callback); + } else { + _this.onClose(); + callback && callback(); + } + }); + break; + + case 2: // connecting + this.once('open', function() { + _this.close(callback); + }); + break; + + case 3: // disconnecting + if (!callback) { + break; + } + this.once('close', function() { + callback(); + }); + break; + } + + return this; +}; + +/** + * Called when the connection closes + * + * @api private + */ + +Connection.prototype.onClose = function() { + this.readyState = STATES.disconnected; + + // avoid having the collection subscribe to our event emitter + // to prevent 0.3 warning + for (var i in this.collections) { + if (utils.object.hasOwnProperty(this.collections, i)) { + this.collections[i].onClose(); + } + } + + this.emit('close'); +}; + +/** + * Retrieves a collection, creating it if not cached. + * + * Not typically needed by applications. Just talk to your collection through your model. + * + * @param {String} name of the collection + * @param {Object} [options] optional collection options + * @return {Collection} collection instance + * @api public + */ + +Connection.prototype.collection = function(name, options) { + if (!(name in this.collections)) { + this.collections[name] = new Collection(name, this, options); + } + return this.collections[name]; +}; + +/** + * Defines or retrieves a model. + * + * var mongoose = require('mongoose'); + * var db = mongoose.createConnection(..); + * db.model('Venue', new Schema(..)); + * var Ticket = db.model('Ticket', new Schema(..)); + * var Venue = db.model('Venue'); + * + * _When no `collection` argument is passed, Mongoose produces a collection name by passing the model `name` to the [utils.toCollectionName](#utils_exports.toCollectionName) method. This method pluralizes the name. If you don't like this behavior, either pass a collection name or set your schemas collection name option._ + * + * ####Example: + * + * var schema = new Schema({ name: String }, { collection: 'actor' }); + * + * // or + * + * schema.set('collection', 'actor'); + * + * // or + * + * var collectionName = 'actor' + * var M = conn.model('Actor', schema, collectionName) + * + * @param {String} name the model name + * @param {Schema} [schema] a schema. necessary when defining a model + * @param {String} [collection] name of mongodb collection (optional) if not given it will be induced from model name + * @see Mongoose#model #index_Mongoose-model + * @return {Model} The compiled model + * @api public + */ + +Connection.prototype.model = function(name, schema, collection) { + // collection name discovery + if (typeof schema === 'string') { + collection = schema; + schema = false; + } + + if (utils.isObject(schema) && !schema.instanceOfSchema) { + schema = new Schema(schema); + } + + if (this.models[name] && !collection) { + // model exists but we are not subclassing with custom collection + if (schema && schema.instanceOfSchema && schema !== this.models[name].schema) { + throw new MongooseError.OverwriteModelError(name); + } + return this.models[name]; + } + + var opts = {cache: false, connection: this}; + var model; + + if (schema && schema.instanceOfSchema) { + // compile a model + model = this.base.model(name, schema, collection, opts); + + // only the first model with this name is cached to allow + // for one-offs with custom collection names etc. + if (!this.models[name]) { + this.models[name] = model; + } + + model.init(); + return model; + } + + if (this.models[name] && collection) { + // subclassing current model with alternate collection + model = this.models[name]; + schema = model.prototype.schema; + var sub = model.__subclass(this, schema, collection); + // do not cache the sub model + return sub; + } + + // lookup model in mongoose module + model = this.base.models[name]; + + if (!model) { + throw new MongooseError.MissingSchemaError(name); + } + + if (this === model.prototype.db + && (!collection || collection === model.collection.name)) { + // model already uses this connection. + + // only the first model with this name is cached to allow + // for one-offs with custom collection names etc. + if (!this.models[name]) { + this.models[name] = model; + } + + return model; + } + this.models[name] = model.__subclass(this, schema, collection); + return this.models[name]; +}; + +/** + * Returns an array of model names created on this connection. + * @api public + * @return {Array} + */ + +Connection.prototype.modelNames = function() { + return Object.keys(this.models); +}; + +/** + * @brief Returns if the connection requires authentication after it is opened. Generally if a + * username and password are both provided than authentication is needed, but in some cases a + * password is not required. + * @api private + * @return {Boolean} true if the connection should be authenticated after it is opened, otherwise false. + */ +Connection.prototype.shouldAuthenticate = function() { + return (this.user !== null && this.user !== void 0) && + ((this.pass !== null || this.pass !== void 0) || this.authMechanismDoesNotRequirePassword()); +}; + +/** + * @brief Returns a boolean value that specifies if the current authentication mechanism needs a + * password to authenticate according to the auth objects passed into the open/openSet methods. + * @api private + * @return {Boolean} true if the authentication mechanism specified in the options object requires + * a password, otherwise false. + */ +Connection.prototype.authMechanismDoesNotRequirePassword = function() { + if (this.options && this.options.auth) { + return authMechanismsWhichDontRequirePassword.indexOf(this.options.auth.authMechanism) >= 0; + } + return true; +}; + +/** + * @brief Returns a boolean value that specifies if the provided objects object provides enough + * data to authenticate with. Generally this is true if the username and password are both specified + * but in some authentication methods, a password is not required for authentication so only a username + * is required. + * @param {Object} [options] the options object passed into the open/openSet methods. + * @api private + * @return {Boolean} true if the provided options object provides enough data to authenticate with, + * otherwise false. + */ +Connection.prototype.optionsProvideAuthenticationData = function(options) { + return (options) && + (options.user) && + ((options.pass) || this.authMechanismDoesNotRequirePassword()); +}; + +/*! + * Module exports. + */ + +Connection.STATES = STATES; +module.exports = Connection; diff --git a/node_modules/mongoose/lib/connectionstate.js b/node_modules/mongoose/lib/connectionstate.js new file mode 100644 index 0000000..b9d1baf --- /dev/null +++ b/node_modules/mongoose/lib/connectionstate.js @@ -0,0 +1,27 @@ + +/*! + * Connection states + */ + +var STATES = module.exports = exports = Object.create(null); + +var disconnected = 'disconnected'; +var connected = 'connected'; +var connecting = 'connecting'; +var disconnecting = 'disconnecting'; +var unauthorized = 'unauthorized'; +var uninitialized = 'uninitialized'; + +STATES[0] = disconnected; +STATES[1] = connected; +STATES[2] = connecting; +STATES[3] = disconnecting; +STATES[4] = unauthorized; +STATES[99] = uninitialized; + +STATES[disconnected] = 0; +STATES[connected] = 1; +STATES[connecting] = 2; +STATES[disconnecting] = 3; +STATES[unauthorized] = 4; +STATES[uninitialized] = 99; diff --git a/node_modules/mongoose/lib/document.js b/node_modules/mongoose/lib/document.js new file mode 100644 index 0000000..91f73c1 --- /dev/null +++ b/node_modules/mongoose/lib/document.js @@ -0,0 +1,2558 @@ +/*! + * Module dependencies. + */ + +var EventEmitter = require('events').EventEmitter; +var MongooseError = require('./error'); +var MixedSchema = require('./schema/mixed'); +var Schema = require('./schema'); +var ObjectExpectedError = require('./error/objectExpected'); +var StrictModeError = require('./error/strict'); +var ValidatorError = require('./schematype').ValidatorError; +var VersionError = require('./error').VersionError; +var utils = require('./utils'); +var clone = utils.clone; +var isMongooseObject = utils.isMongooseObject; +var inspect = require('util').inspect; +var ValidationError = MongooseError.ValidationError; +var InternalCache = require('./internal'); +var deepEqual = utils.deepEqual; +var hooks = require('hooks-fixed'); +var PromiseProvider = require('./promise_provider'); +var DocumentArray; +var MongooseArray; +var Embedded; +var flatten = require('./services/common').flatten; + +/** + * Document constructor. + * + * @param {Object} obj the values to set + * @param {Object} [fields] optional object containing the fields which were selected in the query returning this document and any populated paths data + * @param {Boolean} [skipId] bool, should we auto create an ObjectId _id + * @inherits NodeJS EventEmitter http://nodejs.org/api/events.html#events_class_events_eventemitter + * @event `init`: Emitted on a document after it has was retreived from the db and fully hydrated by Mongoose. + * @event `save`: Emitted when the document is successfully saved + * @api private + */ + +function Document(obj, fields, skipId) { + this.$__ = new InternalCache; + this.$__.emitter = new EventEmitter(); + this.isNew = true; + this.errors = undefined; + + var schema = this.schema; + + if (typeof fields === 'boolean') { + this.$__.strictMode = fields; + fields = undefined; + } else { + this.$__.strictMode = schema.options && schema.options.strict; + this.$__.selected = fields; + } + + var required = schema.requiredPaths(true); + for (var i = 0; i < required.length; ++i) { + this.$__.activePaths.require(required[i]); + } + + this.$__.emitter.setMaxListeners(0); + this._doc = this.$__buildDoc(obj, fields, skipId); + + if (obj) { + if (obj instanceof Document) { + this.isNew = obj.isNew; + } + this.set(obj, undefined, true); + } + + if (!schema.options.strict && obj) { + var _this = this, + keys = Object.keys(this._doc); + + keys.forEach(function(key) { + if (!(key in schema.tree)) { + defineKey(key, null, _this); + } + }); + } + + this.$__registerHooksFromSchema(); +} + +/*! + * Document exposes the NodeJS event emitter API, so you can use + * `on`, `once`, etc. + */ +utils.each( + ['on', 'once', 'emit', 'listeners', 'removeListener', 'setMaxListeners', + 'removeAllListeners', 'addListener'], + function(emitterFn) { + Document.prototype[emitterFn] = function() { + return this.$__.emitter[emitterFn].apply(this.$__.emitter, arguments); + }; + }); + +Document.prototype.constructor = Document; + +/** + * The documents schema. + * + * @api public + * @property schema + */ + +Document.prototype.schema; + +/** + * Boolean flag specifying if the document is new. + * + * @api public + * @property isNew + */ + +Document.prototype.isNew; + +/** + * The string version of this documents _id. + * + * ####Note: + * + * This getter exists on all documents by default. The getter can be disabled by setting the `id` [option](/docs/guide.html#id) of its `Schema` to false at construction time. + * + * new Schema({ name: String }, { id: false }); + * + * @api public + * @see Schema options /docs/guide.html#options + * @property id + */ + +Document.prototype.id; + +/** + * Hash containing current validation errors. + * + * @api public + * @property errors + */ + +Document.prototype.errors; + +/** + * Builds the default doc structure + * + * @param {Object} obj + * @param {Object} [fields] + * @param {Boolean} [skipId] + * @return {Object} + * @api private + * @method $__buildDoc + * @memberOf Document + */ + +Document.prototype.$__buildDoc = function(obj, fields, skipId) { + var doc = {}; + var exclude = null; + var keys; + var ki; + var _this = this; + + // determine if this doc is a result of a query with + // excluded fields + + if (fields && utils.getFunctionName(fields.constructor) === 'Object') { + keys = Object.keys(fields); + ki = keys.length; + + if (ki === 1 && keys[0] === '_id') { + exclude = !!fields[keys[ki]]; + } else { + while (ki--) { + if (keys[ki] !== '_id' && + (!fields[keys[ki]] || typeof fields[keys[ki]] !== 'object')) { + exclude = !fields[keys[ki]]; + break; + } + } + } + } + + var paths = Object.keys(this.schema.paths), + plen = paths.length, + ii = 0; + + for (; ii < plen; ++ii) { + var p = paths[ii]; + + if (p === '_id') { + if (skipId) { + continue; + } + if (obj && '_id' in obj) { + continue; + } + } + + var type = this.schema.paths[p]; + var path = p.split('.'); + var len = path.length; + var last = len - 1; + var curPath = ''; + var doc_ = doc; + var i = 0; + var included = false; + + for (; i < len; ++i) { + var piece = path[i], + def; + + curPath += piece; + + // support excluding intermediary levels + if (exclude === true) { + if (curPath in fields) { + break; + } + } else if (fields && curPath in fields) { + included = true; + } + + if (i === last) { + if (fields && exclude !== null) { + if (exclude === true) { + // apply defaults to all non-excluded fields + if (p in fields) { + continue; + } + + def = type.getDefault(_this, false); + if (typeof def !== 'undefined') { + doc_[piece] = def; + _this.$__.activePaths.default(p); + } + } else if (included) { + // selected field + def = type.getDefault(_this, false); + if (typeof def !== 'undefined') { + doc_[piece] = def; + _this.$__.activePaths.default(p); + } + } + } else { + def = type.getDefault(_this, false); + if (typeof def !== 'undefined') { + doc_[piece] = def; + _this.$__.activePaths.default(p); + } + } + } else { + doc_ = doc_[piece] || (doc_[piece] = {}); + curPath += '.'; + } + } + } + + return doc; +}; + +/** + * Initializes the document without setters or marking anything modified. + * + * Called internally after a document is returned from mongodb. + * + * @param {Object} doc document returned by mongo + * @param {Function} fn callback + * @api public + */ + +Document.prototype.init = function(doc, opts, fn) { + // do not prefix this method with $__ since its + // used by public hooks + + if (typeof opts === 'function') { + fn = opts; + opts = null; + } + + this.isNew = false; + + // handle docs with populated paths + // If doc._id is not null or undefined + if (doc._id !== null && doc._id !== undefined && + opts && opts.populated && opts.populated.length) { + var id = String(doc._id); + for (var i = 0; i < opts.populated.length; ++i) { + var item = opts.populated[i]; + this.populated(item.path, item._docs[id], item); + } + } + + init(this, doc, this._doc); + this.$__storeShard(); + + this.emit('init', this); + if (fn) { + fn(null); + } + return this; +}; + +/*! + * Init helper. + * + * @param {Object} self document instance + * @param {Object} obj raw mongodb doc + * @param {Object} doc object we are initializing + * @api private + */ + +function init(self, obj, doc, prefix) { + prefix = prefix || ''; + + var keys = Object.keys(obj), + len = keys.length, + schema, + path, + i; + + while (len--) { + i = keys[len]; + path = prefix + i; + schema = self.schema.path(path); + + if (!schema && utils.isObject(obj[i]) && + (!obj[i].constructor || utils.getFunctionName(obj[i].constructor) === 'Object')) { + // assume nested object + if (!doc[i]) { + doc[i] = {}; + } + init(self, obj[i], doc[i], path + '.'); + } else { + if (obj[i] === null) { + doc[i] = null; + } else if (obj[i] !== undefined) { + if (schema) { + try { + doc[i] = schema.cast(obj[i], self, true); + } catch (e) { + self.invalidate(e.path, new ValidatorError({ + path: e.path, + message: e.message, + type: 'cast', + value: e.value + })); + } + } else { + doc[i] = obj[i]; + } + } + // mark as hydrated + if (!self.isModified(path)) { + self.$__.activePaths.init(path); + } + } + } +} + +/** + * Stores the current values of the shard keys. + * + * ####Note: + * + * _Shard key values do not / are not allowed to change._ + * + * @api private + * @method $__storeShard + * @memberOf Document + */ + +Document.prototype.$__storeShard = function() { + // backwards compat + var key = this.schema.options.shardKey || this.schema.options.shardkey; + if (!(key && utils.getFunctionName(key.constructor) === 'Object')) { + return; + } + + var orig = this.$__.shardval = {}, + paths = Object.keys(key), + len = paths.length, + val; + + for (var i = 0; i < len; ++i) { + val = this.getValue(paths[i]); + if (isMongooseObject(val)) { + orig[paths[i]] = val.toObject({depopulate: true}); + } else if (val !== null && val !== undefined && val.valueOf && + // Explicitly don't take value of dates + (!val.constructor || utils.getFunctionName(val.constructor) !== 'Date')) { + orig[paths[i]] = val.valueOf(); + } else { + orig[paths[i]] = val; + } + } +}; + +/*! + * Set up middleware support + */ + +for (var k in hooks) { + if (k === 'pre' || k === 'post') { + Document.prototype['$' + k] = Document['$' + k] = hooks[k]; + } else { + Document.prototype[k] = Document[k] = hooks[k]; + } +} + +/** + * Sends an update command with this document `_id` as the query selector. + * + * ####Example: + * + * weirdCar.update({$inc: {wheels:1}}, { w: 1 }, callback); + * + * ####Valid options: + * + * - same as in [Model.update](#model_Model.update) + * + * @see Model.update #model_Model.update + * @param {Object} doc + * @param {Object} options + * @param {Function} callback + * @return {Query} + * @api public + */ + +Document.prototype.update = function update() { + var args = utils.args(arguments); + args.unshift({_id: this._id}); + return this.constructor.update.apply(this.constructor, args); +}; + +/** + * Sets the value of a path, or many paths. + * + * ####Example: + * + * // path, value + * doc.set(path, value) + * + * // object + * doc.set({ + * path : value + * , path2 : { + * path : value + * } + * }) + * + * // on-the-fly cast to number + * doc.set(path, value, Number) + * + * // on-the-fly cast to string + * doc.set(path, value, String) + * + * // changing strict mode behavior + * doc.set(path, value, { strict: false }); + * + * @param {String|Object} path path or object of key/vals to set + * @param {Any} val the value to set + * @param {Schema|String|Number|Buffer|*} [type] optionally specify a type for "on-the-fly" attributes + * @param {Object} [options] optionally specify options that modify the behavior of the set + * @api public + */ + +Document.prototype.set = function(path, val, type, options) { + if (type && utils.getFunctionName(type.constructor) === 'Object') { + options = type; + type = undefined; + } + + var merge = options && options.merge, + adhoc = type && type !== true, + constructing = type === true, + adhocs; + + var strict = options && 'strict' in options + ? options.strict + : this.$__.strictMode; + + if (adhoc) { + adhocs = this.$__.adhocPaths || (this.$__.adhocPaths = {}); + adhocs[path] = Schema.interpretAsType(path, type, this.schema.options); + } + + if (typeof path !== 'string') { + // new Document({ key: val }) + + if (path === null || path === void 0) { + var _ = path; + path = val; + val = _; + } else { + var prefix = val + ? val + '.' + : ''; + + if (path instanceof Document) { + if (path.$__isNested) { + path = path.toObject(); + } else { + path = path._doc; + } + } + + var keys = Object.keys(path); + var i = keys.length; + var pathtype; + var key; + + if (i === 0 && !this.schema.options.minimize) { + if (val) { + this.set(val, {}); + } + return this; + } + + while (i--) { + key = keys[i]; + var pathName = prefix + key; + pathtype = this.schema.pathType(pathName); + + if (path[key] !== null + && path[key] !== void 0 + // need to know if plain object - no Buffer, ObjectId, ref, etc + && utils.isObject(path[key]) + && (!path[key].constructor || utils.getFunctionName(path[key].constructor) === 'Object') + && pathtype !== 'virtual' + && pathtype !== 'real' + && !(this.$__path(pathName) instanceof MixedSchema) + && !(this.schema.paths[pathName] && + this.schema.paths[pathName].options && + this.schema.paths[pathName].options.ref)) { + this.set(path[key], prefix + key, constructing); + } else if (strict) { + // Don't overwrite defaults with undefined keys (gh-3981) + if (constructing && path[key] === void 0 && + this.get(key) !== void 0) { + continue; + } + + if (pathtype === 'real' || pathtype === 'virtual') { + // Check for setting single embedded schema to document (gh-3535) + if (this.schema.paths[pathName] && + this.schema.paths[pathName].$isSingleNested && + path[key] instanceof Document) { + path[key] = path[key].toObject({virtuals: false}); + } + this.set(prefix + key, path[key], constructing); + } else if (pathtype === 'nested' && path[key] instanceof Document) { + this.set(prefix + key, + path[key].toObject({transform: false}), constructing); + } else if (strict === 'throw') { + if (pathtype === 'nested') { + throw new ObjectExpectedError(key, path[key]); + } else { + throw new StrictModeError(key); + } + } + } else if (path[key] !== void 0) { + this.set(prefix + key, path[key], constructing); + } + } + + return this; + } + } + + // ensure _strict is honored for obj props + // docschema = new Schema({ path: { nest: 'string' }}) + // doc.set('path', obj); + var pathType = this.schema.pathType(path); + if (pathType === 'nested' && val) { + if (utils.isObject(val) && + (!val.constructor || utils.getFunctionName(val.constructor) === 'Object')) { + if (!merge) { + this.setValue(path, null); + cleanModifiedSubpaths(this, path); + } + + if (Object.keys(val).length === 0) { + this.setValue(path, {}); + this.markModified(path); + cleanModifiedSubpaths(this, path); + } else { + this.set(val, path, constructing); + } + return this; + } + this.invalidate(path, new MongooseError.CastError('Object', val, path)); + return this; + } + + var schema; + var parts = path.split('.'); + + if (pathType === 'adhocOrUndefined' && strict) { + // check for roots that are Mixed types + var mixed; + + for (i = 0; i < parts.length; ++i) { + var subpath = parts.slice(0, i + 1).join('.'); + schema = this.schema.path(subpath); + if (schema instanceof MixedSchema) { + // allow changes to sub paths of mixed types + mixed = true; + break; + } + } + + if (!mixed) { + if (strict === 'throw') { + throw new StrictModeError(path); + } + return this; + } + } else if (pathType === 'virtual') { + schema = this.schema.virtualpath(path); + schema.applySetters(val, this); + return this; + } else { + schema = this.$__path(path); + } + + var pathToMark; + + // When using the $set operator the path to the field must already exist. + // Else mongodb throws: "LEFT_SUBFIELD only supports Object" + + if (parts.length <= 1) { + pathToMark = path; + } else { + for (i = 0; i < parts.length; ++i) { + subpath = parts.slice(0, i + 1).join('.'); + if (this.isDirectModified(subpath) // earlier prefixes that are already + // marked as dirty have precedence + || this.get(subpath) === null) { + pathToMark = subpath; + break; + } + } + + if (!pathToMark) { + pathToMark = path; + } + } + + // if this doc is being constructed we should not trigger getters + var priorVal = constructing + ? undefined + : this.getValue(path); + + if (!schema) { + this.$__set(pathToMark, path, constructing, parts, schema, val, priorVal); + return this; + } + + var shouldSet = true; + try { + // If the user is trying to set a ref path to a document with + // the correct model name, treat it as populated + var didPopulate = false; + if (schema.options && + schema.options.ref && + val instanceof Document && + schema.options.ref === val.constructor.modelName) { + if (this.ownerDocument) { + this.ownerDocument().populated(this.$__fullPath(path), + val._id, {model: val.constructor}); + } else { + this.populated(path, val._id, {model: val.constructor}); + } + didPopulate = true; + } + + var popOpts; + if (schema.options && + Array.isArray(schema.options.type) && + schema.options.type.length && + schema.options.type[0].ref && + Array.isArray(val) && + val.length > 0 && + val[0] instanceof Document && + val[0].constructor.modelName && + schema.options.type[0].ref === val[0].constructor.modelName) { + if (this.ownerDocument) { + popOpts = { model: val[0].constructor }; + this.ownerDocument().populated(this.$__fullPath(path), + val.map(function(v) { return v._id; }), popOpts); + } else { + popOpts = { model: val[0].constructor }; + this.populated(path, val.map(function(v) { return v._id; }), popOpts); + } + didPopulate = true; + } + val = schema.applySetters(val, this, false, priorVal); + + if (!didPopulate && this.$__.populated) { + delete this.$__.populated[path]; + } + + this.$markValid(path); + } catch (e) { + this.invalidate(path, + new MongooseError.CastError(schema.instance, val, path, e)); + shouldSet = false; + } + + if (schema.$isSingleNested) { + cleanModifiedSubpaths(this, path); + } + + if (shouldSet) { + this.$__set(pathToMark, path, constructing, parts, schema, val, priorVal); + } + + return this; +}; + +/*! + * ignore + */ + +function cleanModifiedSubpaths(doc, path) { + var _modifiedPaths = Object.keys(doc.$__.activePaths.states.modify); + var _numModifiedPaths = _modifiedPaths.length; + for (var j = 0; j < _numModifiedPaths; ++j) { + if (_modifiedPaths[j].indexOf(path + '.') === 0) { + delete doc.$__.activePaths.states.modify[_modifiedPaths[j]]; + } + } +} + +/** + * Determine if we should mark this change as modified. + * + * @return {Boolean} + * @api private + * @method $__shouldModify + * @memberOf Document + */ + +Document.prototype.$__shouldModify = function(pathToMark, path, constructing, parts, schema, val, priorVal) { + if (this.isNew) { + return true; + } + + if (undefined === val && !this.isSelected(path)) { + // when a path is not selected in a query, its initial + // value will be undefined. + return true; + } + + if (undefined === val && path in this.$__.activePaths.states.default) { + // we're just unsetting the default value which was never saved + return false; + } + + // gh-3992: if setting a populated field to a doc, don't mark modified + // if they have the same _id + if (this.populated(path) && + val instanceof Document && + deepEqual(val._id, priorVal)) { + return false; + } + + if (!deepEqual(val, priorVal || this.get(path))) { + return true; + } + + if (!constructing && + val !== null && + val !== undefined && + path in this.$__.activePaths.states.default && + deepEqual(val, schema.getDefault(this, constructing))) { + // a path with a default was $unset on the server + // and the user is setting it to the same value again + return true; + } + return false; +}; + +/** + * Handles the actual setting of the value and marking the path modified if appropriate. + * + * @api private + * @method $__set + * @memberOf Document + */ + +Document.prototype.$__set = function(pathToMark, path, constructing, parts, schema, val, priorVal) { + Embedded = Embedded || require('./types/embedded'); + + var shouldModify = this.$__shouldModify(pathToMark, path, constructing, parts, + schema, val, priorVal); + var _this = this; + + if (shouldModify) { + this.markModified(pathToMark, val); + + // handle directly setting arrays (gh-1126) + MongooseArray || (MongooseArray = require('./types/array')); + if (val && val.isMongooseArray) { + val._registerAtomic('$set', val); + + // Small hack for gh-1638: if we're overwriting the entire array, ignore + // paths that were modified before the array overwrite + this.$__.activePaths.forEach(function(modifiedPath) { + if (modifiedPath.indexOf(path + '.') === 0) { + _this.$__.activePaths.ignore(modifiedPath); + } + }); + } + } + + var obj = this._doc; + var i = 0; + var l = parts.length; + var cur = ''; + + for (; i < l; i++) { + var next = i + 1; + var last = next === l; + cur += (cur ? '.' + parts[i] : parts[i]); + + if (last) { + obj[parts[i]] = val; + } else { + if (obj[parts[i]] && utils.getFunctionName(obj[parts[i]].constructor) === 'Object') { + obj = obj[parts[i]]; + } else if (obj[parts[i]] && obj[parts[i]] instanceof Embedded) { + obj = obj[parts[i]]; + } else if (obj[parts[i]] && obj[parts[i]].$isSingleNested) { + obj = obj[parts[i]]; + } else if (obj[parts[i]] && Array.isArray(obj[parts[i]])) { + obj = obj[parts[i]]; + } else { + this.set(cur, {}); + obj = obj[parts[i]]; + } + } + } +}; + +/** + * Gets a raw value from a path (no getters) + * + * @param {String} path + * @api private + */ + +Document.prototype.getValue = function(path) { + return utils.getValue(path, this._doc); +}; + +/** + * Sets a raw value for a path (no casting, setters, transformations) + * + * @param {String} path + * @param {Object} value + * @api private + */ + +Document.prototype.setValue = function(path, val) { + utils.setValue(path, val, this._doc); + return this; +}; + +/** + * Returns the value of a path. + * + * ####Example + * + * // path + * doc.get('age') // 47 + * + * // dynamic casting to a string + * doc.get('age', String) // "47" + * + * @param {String} path + * @param {Schema|String|Number|Buffer|*} [type] optionally specify a type for on-the-fly attributes + * @api public + */ + +Document.prototype.get = function(path, type) { + var adhoc; + if (type) { + adhoc = Schema.interpretAsType(path, type, this.schema.options); + } + + var schema = this.$__path(path) || this.schema.virtualpath(path), + pieces = path.split('.'), + obj = this._doc; + + for (var i = 0, l = pieces.length; i < l; i++) { + obj = obj === null || obj === void 0 + ? undefined + : obj[pieces[i]]; + } + + if (adhoc) { + obj = adhoc.cast(obj); + } + + // Check if this path is populated - don't apply getters if it is, + // because otherwise its a nested object. See gh-3357 + if (schema && !this.populated(path)) { + obj = schema.applyGetters(obj, this); + } + + return obj; +}; + +/** + * Returns the schematype for the given `path`. + * + * @param {String} path + * @api private + * @method $__path + * @memberOf Document + */ + +Document.prototype.$__path = function(path) { + var adhocs = this.$__.adhocPaths, + adhocType = adhocs && adhocs[path]; + + if (adhocType) { + return adhocType; + } + return this.schema.path(path); +}; + +/** + * Marks the path as having pending changes to write to the db. + * + * _Very helpful when using [Mixed](./schematypes.html#mixed) types._ + * + * ####Example: + * + * doc.mixed.type = 'changed'; + * doc.markModified('mixed.type'); + * doc.save() // changes to mixed.type are now persisted + * + * @param {String} path the path to mark modified + * @api public + */ + +Document.prototype.markModified = function(path) { + this.$__.activePaths.modify(path); +}; + +/** + * Clears the modified state on the specified path. + * + * ####Example: + * + * doc.foo = 'bar'; + * doc.unmarkModified('foo'); + * doc.save() // changes to foo will not be persisted + * + * @param {String} path the path to unmark modified + * @api public + */ + +Document.prototype.unmarkModified = function(path) { + this.$__.activePaths.init(path); +}; + +/** + * Don't run validation on this path or persist changes to this path. + * + * ####Example: + * + * doc.foo = null; + * doc.$ignore('foo'); + * doc.save() // changes to foo will not be persisted and validators won't be run + * + * @param {String} path the path to ignore + * @api public + */ + +Document.prototype.$ignore = function(path) { + this.$__.activePaths.ignore(path); +}; + +/** + * Returns the list of paths that have been modified. + * + * @return {Array} + * @api public + */ + +Document.prototype.modifiedPaths = function() { + var directModifiedPaths = Object.keys(this.$__.activePaths.states.modify); + return directModifiedPaths.reduce(function(list, path) { + var parts = path.split('.'); + return list.concat(parts.reduce(function(chains, part, i) { + return chains.concat(parts.slice(0, i).concat(part).join('.')); + }, []).filter(function(chain) { + return (list.indexOf(chain) === -1); + })); + }, []); +}; + +/** + * Returns true if this document was modified, else false. + * + * If `path` is given, checks if a path or any full path containing `path` as part of its path chain has been modified. + * + * ####Example + * + * doc.set('documents.0.title', 'changed'); + * doc.isModified() // true + * doc.isModified('documents') // true + * doc.isModified('documents.0.title') // true + * doc.isModified('documents otherProp') // true + * doc.isDirectModified('documents') // false + * + * @param {String} [path] optional + * @return {Boolean} + * @api public + */ + +Document.prototype.isModified = function(paths) { + if (paths) { + if (!Array.isArray(paths)) { + paths = paths.split(' '); + } + var modified = this.modifiedPaths(); + return paths.some(function(path) { + return !!~modified.indexOf(path); + }); + } + return this.$__.activePaths.some('modify'); +}; + +/** + * Checks if a path is set to its default. + * + * ####Example + * + * MyModel = mongoose.model('test', { name: { type: String, default: 'Val '} }); + * var m = new MyModel(); + * m.$isDefault('name'); // true + * + * @param {String} [path] + * @return {Boolean} + * @method $isDefault + * @api public + */ + +Document.prototype.$isDefault = function(path) { + return (path in this.$__.activePaths.states.default); +}; + +/** + * Returns true if `path` was directly set and modified, else false. + * + * ####Example + * + * doc.set('documents.0.title', 'changed'); + * doc.isDirectModified('documents.0.title') // true + * doc.isDirectModified('documents') // false + * + * @param {String} path + * @return {Boolean} + * @api public + */ + +Document.prototype.isDirectModified = function(path) { + return (path in this.$__.activePaths.states.modify); +}; + +/** + * Checks if `path` was initialized. + * + * @param {String} path + * @return {Boolean} + * @api public + */ + +Document.prototype.isInit = function(path) { + return (path in this.$__.activePaths.states.init); +}; + +/** + * Checks if `path` was selected in the source query which initialized this document. + * + * ####Example + * + * Thing.findOne().select('name').exec(function (err, doc) { + * doc.isSelected('name') // true + * doc.isSelected('age') // false + * }) + * + * @param {String} path + * @return {Boolean} + * @api public + */ + +Document.prototype.isSelected = function isSelected(path) { + if (this.$__.selected) { + if (path === '_id') { + return this.$__.selected._id !== 0; + } + + var paths = Object.keys(this.$__.selected), + i = paths.length, + inclusive = false, + cur; + + if (i === 1 && paths[0] === '_id') { + // only _id was selected. + return this.$__.selected._id === 0; + } + + while (i--) { + cur = paths[i]; + if (cur === '_id') { + continue; + } + inclusive = !!this.$__.selected[cur]; + break; + } + + if (path in this.$__.selected) { + return inclusive; + } + + i = paths.length; + var pathDot = path + '.'; + + while (i--) { + cur = paths[i]; + if (cur === '_id') { + continue; + } + + if (cur.indexOf(pathDot) === 0) { + return inclusive; + } + + if (pathDot.indexOf(cur + '.') === 0) { + return inclusive; + } + } + + return !inclusive; + } + + return true; +}; + +/** + * Executes registered validation rules for this document. + * + * ####Note: + * + * This method is called `pre` save and if a validation rule is violated, [save](#model_Model-save) is aborted and the error is returned to your `callback`. + * + * ####Example: + * + * doc.validate(function (err) { + * if (err) handleError(err); + * else // validation passed + * }); + * + * @param {Object} optional options internal options + * @param {Function} callback optional callback called after validation completes, passing an error if one occurred + * @return {Promise} Promise + * @api public + */ + +Document.prototype.validate = function(options, callback) { + if (typeof options === 'function') { + callback = options; + options = null; + } + + this.$__validate(callback); +}; + +/*! + * ignore + */ + +function _getPathsToValidate(doc) { + // only validate required fields when necessary + var paths = Object.keys(doc.$__.activePaths.states.require).filter(function(path) { + if (!doc.isSelected(path) && !doc.isModified(path)) { + return false; + } + var p = doc.schema.path(path); + if (typeof p.originalRequiredValue === 'function') { + return p.originalRequiredValue.call(doc); + } + return true; + }); + + paths = paths.concat(Object.keys(doc.$__.activePaths.states.init)); + paths = paths.concat(Object.keys(doc.$__.activePaths.states.modify)); + paths = paths.concat(Object.keys(doc.$__.activePaths.states.default)); + + // gh-661: if a whole array is modified, make sure to run validation on all + // the children as well + for (var i = 0; i < paths.length; ++i) { + var path = paths[i]; + var val = doc.getValue(path); + if (val && val.isMongooseArray && !Buffer.isBuffer(val) && !val.isMongooseDocumentArray) { + var numElements = val.length; + for (var j = 0; j < numElements; ++j) { + paths.push(path + '.' + j); + } + } + } + + var flattenOptions = { skipArrays: true }; + for (i = 0; i < paths.length; ++i) { + var pathToCheck = paths[i]; + if (doc.schema.nested[pathToCheck]) { + var _v = doc.getValue(pathToCheck); + if (isMongooseObject(_v)) { + _v = _v.toObject({ transform: false }); + } + var flat = flatten(_v, '', flattenOptions); + var _subpaths = Object.keys(flat).map(function(p) { + return pathToCheck + '.' + p; + }); + paths = paths.concat(_subpaths); + } + } + + return paths; +} + +/*! + * ignore + */ + +Document.prototype.$__validate = function(callback) { + var _this = this; + var _complete = function() { + var err = _this.$__.validationError; + _this.$__.validationError = undefined; + _this.emit('validate', _this); + if (err) { + for (var key in err.errors) { + // Make sure cast errors persist + if (!_this.__parent && err.errors[key] instanceof MongooseError.CastError) { + _this.invalidate(key, err.errors[key]); + } + } + + return err; + } + }; + + // only validate required fields when necessary + var paths = _getPathsToValidate(this); + + if (paths.length === 0) { + process.nextTick(function() { + var err = _complete(); + if (err) { + callback(err); + return; + } + callback(); + }); + } + + var validating = {}, + total = 0; + + var complete = function() { + var err = _complete(); + if (err) { + callback(err); + return; + } + callback(); + }; + + var validatePath = function(path) { + if (validating[path]) { + return; + } + + validating[path] = true; + total++; + + process.nextTick(function() { + var p = _this.schema.path(path); + if (!p) { + return --total || complete(); + } + + // If user marked as invalid or there was a cast error, don't validate + if (!_this.$isValid(path)) { + --total || complete(); + return; + } + + var val = _this.getValue(path); + p.doValidate(val, function(err) { + if (err) { + _this.invalidate(path, err, undefined, true); + } + --total || complete(); + }, _this); + }); + }; + + paths.forEach(validatePath); +}; + +/** + * Executes registered validation rules (skipping asynchronous validators) for this document. + * + * ####Note: + * + * This method is useful if you need synchronous validation. + * + * ####Example: + * + * var err = doc.validateSync(); + * if ( err ){ + * handleError( err ); + * } else { + * // validation passed + * } + * + * @param {Array|string} pathsToValidate only validate the given paths + * @return {MongooseError|undefined} MongooseError if there are errors during validation, or undefined if there is no error. + * @api public + */ + +Document.prototype.validateSync = function(pathsToValidate) { + var _this = this; + + if (typeof pathsToValidate === 'string') { + pathsToValidate = pathsToValidate.split(' '); + } + + // only validate required fields when necessary + var paths = _getPathsToValidate(this); + + if (pathsToValidate && pathsToValidate.length) { + var tmp = []; + for (var i = 0; i < paths.length; ++i) { + if (pathsToValidate.indexOf(paths[i]) !== -1) { + tmp.push(paths[i]); + } + } + paths = tmp; + } + + var validating = {}; + + paths.forEach(function(path) { + if (validating[path]) { + return; + } + + validating[path] = true; + + var p = _this.schema.path(path); + if (!p) { + return; + } + if (!_this.$isValid(path)) { + return; + } + + var val = _this.getValue(path); + var err = p.doValidateSync(val, _this); + if (err) { + _this.invalidate(path, err, undefined, true); + } + }); + + var err = _this.$__.validationError; + _this.$__.validationError = undefined; + _this.emit('validate', _this); + + if (err) { + for (var key in err.errors) { + // Make sure cast errors persist + if (err.errors[key] instanceof MongooseError.CastError) { + _this.invalidate(key, err.errors[key]); + } + } + } + + return err; +}; + +/** + * Marks a path as invalid, causing validation to fail. + * + * The `errorMsg` argument will become the message of the `ValidationError`. + * + * The `value` argument (if passed) will be available through the `ValidationError.value` property. + * + * doc.invalidate('size', 'must be less than 20', 14); + + * doc.validate(function (err) { + * console.log(err) + * // prints + * { message: 'Validation failed', + * name: 'ValidationError', + * errors: + * { size: + * { message: 'must be less than 20', + * name: 'ValidatorError', + * path: 'size', + * type: 'user defined', + * value: 14 } } } + * }) + * + * @param {String} path the field to invalidate + * @param {String|Error} errorMsg the error which states the reason `path` was invalid + * @param {Object|String|Number|any} value optional invalid value + * @param {String} [kind] optional `kind` property for the error + * @return {ValidationError} the current ValidationError, with all currently invalidated paths + * @api public + */ + +Document.prototype.invalidate = function(path, err, val, kind) { + if (!this.$__.validationError) { + this.$__.validationError = new ValidationError(this); + } + + if (this.$__.validationError.errors[path]) { + return; + } + + if (!err || typeof err === 'string') { + err = new ValidatorError({ + path: path, + message: err, + type: kind || 'user defined', + value: val + }); + } + + if (this.$__.validationError === err) { + return this.$__.validationError; + } + + this.$__.validationError.errors[path] = err; + return this.$__.validationError; +}; + +/** + * Marks a path as valid, removing existing validation errors. + * + * @param {String} path the field to mark as valid + * @api private + * @method $markValid + * @receiver Document + */ + +Document.prototype.$markValid = function(path) { + if (!this.$__.validationError || !this.$__.validationError.errors[path]) { + return; + } + + delete this.$__.validationError.errors[path]; + if (Object.keys(this.$__.validationError.errors).length === 0) { + this.$__.validationError = null; + } +}; + +/** + * Checks if a path is invalid + * + * @param {String} path the field to check + * @method $isValid + * @api private + * @receiver Document + */ + +Document.prototype.$isValid = function(path) { + return !this.$__.validationError || !this.$__.validationError.errors[path]; +}; + +/** + * Resets the internal modified state of this document. + * + * @api private + * @return {Document} + * @method $__reset + * @memberOf Document + */ + +Document.prototype.$__reset = function reset() { + var _this = this; + DocumentArray || (DocumentArray = require('./types/documentarray')); + + this.$__.activePaths + .map('init', 'modify', function(i) { + return _this.getValue(i); + }) + .filter(function(val) { + return val && val instanceof Array && val.isMongooseDocumentArray && val.length; + }) + .forEach(function(array) { + var i = array.length; + while (i--) { + var doc = array[i]; + if (!doc) { + continue; + } + doc.$__reset(); + } + }); + + // clear atomics + this.$__dirty().forEach(function(dirt) { + var type = dirt.value; + if (type && type._atomics) { + type._atomics = {}; + } + }); + + // Clear 'dirty' cache + this.$__.activePaths.clear('modify'); + this.$__.activePaths.clear('default'); + this.$__.validationError = undefined; + this.errors = undefined; + _this = this; + this.schema.requiredPaths().forEach(function(path) { + _this.$__.activePaths.require(path); + }); + + return this; +}; + +/** + * Returns this documents dirty paths / vals. + * + * @api private + * @method $__dirty + * @memberOf Document + */ + +Document.prototype.$__dirty = function() { + var _this = this; + + var all = this.$__.activePaths.map('modify', function(path) { + return { + path: path, + value: _this.getValue(path), + schema: _this.$__path(path) + }; + }); + + // gh-2558: if we had to set a default and the value is not undefined, + // we have to save as well + all = all.concat(this.$__.activePaths.map('default', function(path) { + if (path === '_id' || !_this.getValue(path)) { + return; + } + return { + path: path, + value: _this.getValue(path), + schema: _this.$__path(path) + }; + })); + + // Sort dirty paths in a flat hierarchy. + all.sort(function(a, b) { + return (a.path < b.path ? -1 : (a.path > b.path ? 1 : 0)); + }); + + // Ignore "foo.a" if "foo" is dirty already. + var minimal = [], + lastPath, + top; + + all.forEach(function(item) { + if (!item) { + return; + } + if (item.path.indexOf(lastPath) !== 0) { + lastPath = item.path + '.'; + minimal.push(item); + top = item; + } else { + // special case for top level MongooseArrays + if (top.value && top.value._atomics && top.value.hasAtomics()) { + // the `top` array itself and a sub path of `top` are being modified. + // the only way to honor all of both modifications is through a $set + // of entire array. + top.value._atomics = {}; + top.value._atomics.$set = top.value; + } + } + }); + + top = lastPath = null; + return minimal; +}; + +/*! + * Compiles schemas. + */ + +function compile(tree, proto, prefix, options) { + var keys = Object.keys(tree), + i = keys.length, + limb, + key; + + while (i--) { + key = keys[i]; + limb = tree[key]; + + defineKey(key, + ((utils.getFunctionName(limb.constructor) === 'Object' + && Object.keys(limb).length) + && (!limb[options.typeKey] || (options.typeKey === 'type' && limb.type.type)) + ? limb + : null) + , proto + , prefix + , keys + , options); + } +} + +// gets descriptors for all properties of `object` +// makes all properties non-enumerable to match previous behavior to #2211 +function getOwnPropertyDescriptors(object) { + var result = {}; + + Object.getOwnPropertyNames(object).forEach(function(key) { + result[key] = Object.getOwnPropertyDescriptor(object, key); + result[key].enumerable = true; + }); + + return result; +} + +/*! + * Defines the accessor named prop on the incoming prototype. + */ + +function defineKey(prop, subprops, prototype, prefix, keys, options) { + var path = (prefix ? prefix + '.' : '') + prop; + prefix = prefix || ''; + + if (subprops) { + Object.defineProperty(prototype, prop, { + enumerable: true, + configurable: true, + get: function() { + var _this = this; + if (!this.$__.getters) { + this.$__.getters = {}; + } + + if (!this.$__.getters[path]) { + var nested = Object.create(Object.getPrototypeOf(this), getOwnPropertyDescriptors(this)); + + // save scope for nested getters/setters + if (!prefix) { + nested.$__.scope = this; + } + + // shadow inherited getters from sub-objects so + // thing.nested.nested.nested... doesn't occur (gh-366) + var i = 0, + len = keys.length; + + for (; i < len; ++i) { + // over-write the parents getter without triggering it + Object.defineProperty(nested, keys[i], { + enumerable: false, // It doesn't show up. + writable: true, // We can set it later. + configurable: true, // We can Object.defineProperty again. + value: undefined // It shadows its parent. + }); + } + + Object.defineProperty(nested, 'toObject', { + enumerable: true, + configurable: true, + writable: false, + value: function() { + return _this.get(path); + } + }); + + Object.defineProperty(nested, 'toJSON', { + enumerable: true, + configurable: true, + writable: false, + value: function() { + return _this.get(path); + } + }); + + Object.defineProperty(nested, '$__isNested', { + enumerable: true, + configurable: true, + writable: false, + value: true + }); + + compile(subprops, nested, path, options); + this.$__.getters[path] = nested; + } + + return this.$__.getters[path]; + }, + set: function(v) { + if (v instanceof Document) { + v = v.toObject({ transform: false }); + } + return (this.$__.scope || this).set(path, v); + } + }); + } else { + Object.defineProperty(prototype, prop, { + enumerable: true, + configurable: true, + get: function() { + return this.get.call(this.$__.scope || this, path); + }, + set: function(v) { + return this.set.call(this.$__.scope || this, path, v); + } + }); + } +} + +/** + * Assigns/compiles `schema` into this documents prototype. + * + * @param {Schema} schema + * @api private + * @method $__setSchema + * @memberOf Document + */ + +Document.prototype.$__setSchema = function(schema) { + compile(schema.tree, this, undefined, schema.options); + this.schema = schema; +}; + + +/** + * Get active path that were changed and are arrays + * + * @api private + * @method $__getArrayPathsToValidate + * @memberOf Document + */ + +Document.prototype.$__getArrayPathsToValidate = function() { + DocumentArray || (DocumentArray = require('./types/documentarray')); + + // validate all document arrays. + return this.$__.activePaths + .map('init', 'modify', function(i) { + return this.getValue(i); + }.bind(this)) + .filter(function(val) { + return val && val instanceof Array && val.isMongooseDocumentArray && val.length; + }).reduce(function(seed, array) { + return seed.concat(array); + }, []) + .filter(function(doc) { + return doc; + }); +}; + + +/** + * Get all subdocs (by bfs) + * + * @api private + * @method $__getAllSubdocs + * @memberOf Document + */ + +Document.prototype.$__getAllSubdocs = function() { + DocumentArray || (DocumentArray = require('./types/documentarray')); + Embedded = Embedded || require('./types/embedded'); + + function docReducer(seed, path) { + var val = this[path]; + + if (val instanceof Embedded) { + seed.push(val); + } + if (val && val.$isSingleNested) { + seed = Object.keys(val._doc).reduce(docReducer.bind(val._doc), seed); + seed.push(val); + } + if (val && val.isMongooseDocumentArray) { + val.forEach(function _docReduce(doc) { + if (!doc || !doc._doc) { + return; + } + if (doc instanceof Embedded) { + seed.push(doc); + } + seed = Object.keys(doc._doc).reduce(docReducer.bind(doc._doc), seed); + }); + } else if (val instanceof Document && val.$__isNested) { + val = val.toObject(); + if (val) { + seed = Object.keys(val).reduce(docReducer.bind(val), seed); + } + } + return seed; + } + + var subDocs = Object.keys(this._doc).reduce(docReducer.bind(this), []); + + return subDocs; +}; + +/** + * Executes methods queued from the Schema definition + * + * @api private + * @method $__registerHooksFromSchema + * @memberOf Document + */ + +Document.prototype.$__registerHooksFromSchema = function() { + Embedded = Embedded || require('./types/embedded'); + var Promise = PromiseProvider.get(); + + var _this = this; + var q = _this.schema && _this.schema.callQueue; + if (!q.length) { + return _this; + } + + // we are only interested in 'pre' hooks, and group by point-cut + var toWrap = q.reduce(function(seed, pair) { + if (pair[0] !== 'pre' && pair[0] !== 'post' && pair[0] !== 'on') { + _this[pair[0]].apply(_this, pair[1]); + return seed; + } + var args = [].slice.call(pair[1]); + var pointCut = pair[0] === 'on' ? 'post' : args[0]; + if (!(pointCut in seed)) { + seed[pointCut] = {post: [], pre: []}; + } + if (pair[0] === 'post') { + seed[pointCut].post.push(args); + } else if (pair[0] === 'on') { + seed[pointCut].push(args); + } else { + seed[pointCut].pre.push(args); + } + return seed; + }, {post: []}); + + // 'post' hooks are simpler + toWrap.post.forEach(function(args) { + _this.on.apply(_this, args); + }); + delete toWrap.post; + + // 'init' should be synchronous on subdocuments + if (toWrap.init && _this instanceof Embedded) { + if (toWrap.init.pre) { + toWrap.init.pre.forEach(function(args) { + _this.$pre.apply(_this, args); + }); + } + if (toWrap.init.post) { + toWrap.init.post.forEach(function(args) { + _this.$post.apply(_this, args); + }); + } + delete toWrap.init; + } else if (toWrap.set) { + // Set hooks also need to be sync re: gh-3479 + if (toWrap.set.pre) { + toWrap.set.pre.forEach(function(args) { + _this.$pre.apply(_this, args); + }); + } + if (toWrap.set.post) { + toWrap.set.post.forEach(function(args) { + _this.$post.apply(_this, args); + }); + } + delete toWrap.set; + } + + Object.keys(toWrap).forEach(function(pointCut) { + // this is so we can wrap everything into a promise; + var newName = ('$__original_' + pointCut); + if (!_this[pointCut]) { + return; + } + _this[newName] = _this[pointCut]; + _this[pointCut] = function wrappedPointCut() { + var args = [].slice.call(arguments); + var lastArg = args.pop(); + var fn; + var originalStack = new Error().stack; + var $results; + if (lastArg && typeof lastArg !== 'function') { + args.push(lastArg); + } else { + fn = lastArg; + } + + var promise = new Promise.ES6(function(resolve, reject) { + args.push(function(error) { + if (error) { + // gh-2633: since VersionError is very generic, take the + // stack trace of the original save() function call rather + // than the async trace + if (error instanceof VersionError) { + error.stack = originalStack; + } + _this.$__handleReject(error); + reject(error); + return; + } + + // There may be multiple results and promise libs other than + // mpromise don't support passing multiple values to `resolve()` + $results = Array.prototype.slice.call(arguments, 1); + resolve.apply(promise, $results); + }); + + _this[newName].apply(_this, args); + }); + if (fn) { + if (_this.constructor.$wrapCallback) { + fn = _this.constructor.$wrapCallback(fn); + } + return promise.then( + function() { + process.nextTick(function() { + fn.apply(null, [null].concat($results)); + }); + }, + function(error) { + process.nextTick(function() { + fn(error); + }); + }); + } + return promise; + }; + + toWrap[pointCut].pre.forEach(function(args) { + args[0] = newName; + _this.$pre.apply(_this, args); + }); + toWrap[pointCut].post.forEach(function(args) { + args[0] = newName; + _this.$post.apply(_this, args); + }); + }); + return _this; +}; + +Document.prototype.$__handleReject = function handleReject(err) { + // emit on the Model if listening + if (this.listeners('error').length) { + this.emit('error', err); + } else if (this.constructor.listeners && this.constructor.listeners('error').length) { + this.constructor.emit('error', err); + } else if (this.listeners && this.listeners('error').length) { + this.emit('error', err); + } +}; + +/** + * Internal helper for toObject() and toJSON() that doesn't manipulate options + * + * @api private + * @method $toObject + * @memberOf Document + */ + +Document.prototype.$toObject = function(options, json) { + var defaultOptions = {transform: true, json: json}; + + if (options && options.depopulate && !options._skipDepopulateTopLevel && this.$__.wasPopulated) { + // populated paths that we set to a document + return clone(this._id, options); + } + + // If we're calling toObject on a populated doc, we may want to skip + // depopulated on the top level + if (options && options._skipDepopulateTopLevel) { + options._skipDepopulateTopLevel = false; + } + + // When internally saving this document we always pass options, + // bypassing the custom schema options. + if (!(options && utils.getFunctionName(options.constructor) === 'Object') || + (options && options._useSchemaOptions)) { + if (json) { + options = this.schema.options.toJSON ? + clone(this.schema.options.toJSON) : + {}; + options.json = true; + options._useSchemaOptions = true; + } else { + options = this.schema.options.toObject ? + clone(this.schema.options.toObject) : + {}; + options.json = false; + options._useSchemaOptions = true; + } + } + + for (var key in defaultOptions) { + if (options[key] === undefined) { + options[key] = defaultOptions[key]; + } + } + + ('minimize' in options) || (options.minimize = this.schema.options.minimize); + + // remember the root transform function + // to save it from being overwritten by sub-transform functions + var originalTransform = options.transform; + + var ret = clone(this._doc, options) || {}; + + if (options.getters) { + applyGetters(this, ret, 'paths', options); + // applyGetters for paths will add nested empty objects; + // if minimize is set, we need to remove them. + if (options.minimize) { + ret = minimize(ret) || {}; + } + } + + if (options.virtuals || options.getters && options.virtuals !== false) { + applyGetters(this, ret, 'virtuals', options); + } + + if (options.versionKey === false && this.schema.options.versionKey) { + delete ret[this.schema.options.versionKey]; + } + + var transform = options.transform; + + // In the case where a subdocument has its own transform function, we need to + // check and see if the parent has a transform (options.transform) and if the + // child schema has a transform (this.schema.options.toObject) In this case, + // we need to adjust options.transform to be the child schema's transform and + // not the parent schema's + if (transform === true || + (this.schema.options.toObject && transform)) { + var opts = options.json ? this.schema.options.toJSON : this.schema.options.toObject; + + if (opts) { + transform = (typeof options.transform === 'function' ? options.transform : opts.transform); + } + } else { + options.transform = originalTransform; + } + + if (typeof transform === 'function') { + var xformed = transform(this, ret, options); + if (typeof xformed !== 'undefined') { + ret = xformed; + } + } + + return ret; +}; + +/** + * Converts this document into a plain javascript object, ready for storage in MongoDB. + * + * Buffers are converted to instances of [mongodb.Binary](http://mongodb.github.com/node-mongodb-native/api-bson-generated/binary.html) for proper storage. + * + * ####Options: + * + * - `getters` apply all getters (path and virtual getters) + * - `virtuals` apply virtual getters (can override `getters` option) + * - `minimize` remove empty objects (defaults to true) + * - `transform` a transform function to apply to the resulting document before returning + * - `depopulate` depopulate any populated paths, replacing them with their original refs (defaults to false) + * - `versionKey` whether to include the version key (defaults to true) + * - `retainKeyOrder` keep the order of object keys. If this is set to true, `Object.keys(new Doc({ a: 1, b: 2}).toObject())` will always produce `['a', 'b']` (defaults to false) + * + * ####Getters/Virtuals + * + * Example of only applying path getters + * + * doc.toObject({ getters: true, virtuals: false }) + * + * Example of only applying virtual getters + * + * doc.toObject({ virtuals: true }) + * + * Example of applying both path and virtual getters + * + * doc.toObject({ getters: true }) + * + * To apply these options to every document of your schema by default, set your [schemas](#schema_Schema) `toObject` option to the same argument. + * + * schema.set('toObject', { virtuals: true }) + * + * ####Transform + * + * We may need to perform a transformation of the resulting object based on some criteria, say to remove some sensitive information or return a custom object. In this case we set the optional `transform` function. + * + * Transform functions receive three arguments + * + * function (doc, ret, options) {} + * + * - `doc` The mongoose document which is being converted + * - `ret` The plain object representation which has been converted + * - `options` The options in use (either schema options or the options passed inline) + * + * ####Example + * + * // specify the transform schema option + * if (!schema.options.toObject) schema.options.toObject = {}; + * schema.options.toObject.transform = function (doc, ret, options) { + * // remove the _id of every document before returning the result + * delete ret._id; + * return ret; + * } + * + * // without the transformation in the schema + * doc.toObject(); // { _id: 'anId', name: 'Wreck-it Ralph' } + * + * // with the transformation + * doc.toObject(); // { name: 'Wreck-it Ralph' } + * + * With transformations we can do a lot more than remove properties. We can even return completely new customized objects: + * + * if (!schema.options.toObject) schema.options.toObject = {}; + * schema.options.toObject.transform = function (doc, ret, options) { + * return { movie: ret.name } + * } + * + * // without the transformation in the schema + * doc.toObject(); // { _id: 'anId', name: 'Wreck-it Ralph' } + * + * // with the transformation + * doc.toObject(); // { movie: 'Wreck-it Ralph' } + * + * _Note: if a transform function returns `undefined`, the return value will be ignored._ + * + * Transformations may also be applied inline, overridding any transform set in the options: + * + * function xform (doc, ret, options) { + * return { inline: ret.name, custom: true } + * } + * + * // pass the transform as an inline option + * doc.toObject({ transform: xform }); // { inline: 'Wreck-it Ralph', custom: true } + * + * _Note: if you call `toObject` and pass any options, the transform declared in your schema options will __not__ be applied. To force its application pass `transform: true`_ + * + * if (!schema.options.toObject) schema.options.toObject = {}; + * schema.options.toObject.hide = '_id'; + * schema.options.toObject.transform = function (doc, ret, options) { + * if (options.hide) { + * options.hide.split(' ').forEach(function (prop) { + * delete ret[prop]; + * }); + * } + * return ret; + * } + * + * var doc = new Doc({ _id: 'anId', secret: 47, name: 'Wreck-it Ralph' }); + * doc.toObject(); // { secret: 47, name: 'Wreck-it Ralph' } + * doc.toObject({ hide: 'secret _id' }); // { _id: 'anId', secret: 47, name: 'Wreck-it Ralph' } + * doc.toObject({ hide: 'secret _id', transform: true }); // { name: 'Wreck-it Ralph' } + * + * Transforms are applied _only to the document and are not applied to sub-documents_. + * + * Transforms, like all of these options, are also available for `toJSON`. + * + * See [schema options](/docs/guide.html#toObject) for some more details. + * + * _During save, no custom options are applied to the document before being sent to the database._ + * + * @param {Object} [options] + * @return {Object} js object + * @see mongodb.Binary http://mongodb.github.com/node-mongodb-native/api-bson-generated/binary.html + * @api public + */ + +Document.prototype.toObject = function(options) { + return this.$toObject(options); +}; + +/*! + * Minimizes an object, removing undefined values and empty objects + * + * @param {Object} object to minimize + * @return {Object} + */ + +function minimize(obj) { + var keys = Object.keys(obj), + i = keys.length, + hasKeys, + key, + val; + + while (i--) { + key = keys[i]; + val = obj[key]; + + if (utils.isObject(val)) { + obj[key] = minimize(val); + } + + if (undefined === obj[key]) { + delete obj[key]; + continue; + } + + hasKeys = true; + } + + return hasKeys + ? obj + : undefined; +} + +/*! + * Applies virtuals properties to `json`. + * + * @param {Document} self + * @param {Object} json + * @param {String} type either `virtuals` or `paths` + * @return {Object} `json` + */ + +function applyGetters(self, json, type, options) { + var schema = self.schema, + paths = Object.keys(schema[type]), + i = paths.length, + path; + + while (i--) { + path = paths[i]; + + var parts = path.split('.'), + plen = parts.length, + last = plen - 1, + branch = json, + part; + + for (var ii = 0; ii < plen; ++ii) { + part = parts[ii]; + if (ii === last) { + branch[part] = clone(self.get(path), options); + } else { + branch = branch[part] || (branch[part] = {}); + } + } + } + + return json; +} + +/** + * The return value of this method is used in calls to JSON.stringify(doc). + * + * This method accepts the same options as [Document#toObject](#document_Document-toObject). To apply the options to every document of your schema by default, set your [schemas](#schema_Schema) `toJSON` option to the same argument. + * + * schema.set('toJSON', { virtuals: true }) + * + * See [schema options](/docs/guide.html#toJSON) for details. + * + * @param {Object} options + * @return {Object} + * @see Document#toObject #document_Document-toObject + * @api public + */ + +Document.prototype.toJSON = function(options) { + return this.$toObject(options, true); +}; + +/** + * Helper for console.log + * + * @api public + */ + +Document.prototype.inspect = function(options) { + var isPOJO = options && + utils.getFunctionName(options.constructor) === 'Object'; + var opts; + if (isPOJO) { + opts = options; + opts.minimize = false; + opts.retainKeyOrder = true; + } + return this.toObject(opts); +}; + +/** + * Helper for console.log + * + * @api public + * @method toString + */ + +Document.prototype.toString = function() { + return inspect(this.inspect()); +}; + +/** + * Returns true if the Document stores the same data as doc. + * + * Documents are considered equal when they have matching `_id`s, unless neither + * document has an `_id`, in which case this function falls back to using + * `deepEqual()`. + * + * @param {Document} doc a document to compare + * @return {Boolean} + * @api public + */ + +Document.prototype.equals = function(doc) { + if (!doc) { + return false; + } + + var tid = this.get('_id'); + var docid = doc.get ? doc.get('_id') : doc; + if (!tid && !docid) { + return deepEqual(this, doc); + } + return tid && tid.equals + ? tid.equals(docid) + : tid === docid; +}; + +/** + * Populates document references, executing the `callback` when complete. + * If you want to use promises instead, use this function with + * [`execPopulate()`](#document_Document-execPopulate) + * + * ####Example: + * + * doc + * .populate('company') + * .populate({ + * path: 'notes', + * match: /airline/, + * select: 'text', + * model: 'modelName' + * options: opts + * }, function (err, user) { + * assert(doc._id === user._id) // the document itself is passed + * }) + * + * // summary + * doc.populate(path) // not executed + * doc.populate(options); // not executed + * doc.populate(path, callback) // executed + * doc.populate(options, callback); // executed + * doc.populate(callback); // executed + * doc.populate(options).execPopulate() // executed, returns promise + * + * + * ####NOTE: + * + * Population does not occur unless a `callback` is passed *or* you explicitly + * call `execPopulate()`. + * Passing the same path a second time will overwrite the previous path options. + * See [Model.populate()](#model_Model.populate) for explaination of options. + * + * @see Model.populate #model_Model.populate + * @see Document.execPopulate #document_Document-execPopulate + * @param {String|Object} [path] The path to populate or an options object + * @param {Function} [callback] When passed, population is invoked + * @api public + * @return {Document} this + */ + +Document.prototype.populate = function populate() { + if (arguments.length === 0) { + return this; + } + + var pop = this.$__.populate || (this.$__.populate = {}); + var args = utils.args(arguments); + var fn; + + if (typeof args[args.length - 1] === 'function') { + fn = args.pop(); + } + + // allow `doc.populate(callback)` + if (args.length) { + // use hash to remove duplicate paths + var res = utils.populate.apply(null, args); + for (var i = 0; i < res.length; ++i) { + pop[res[i].path] = res[i]; + } + } + + if (fn) { + var paths = utils.object.vals(pop); + this.$__.populate = undefined; + paths.__noPromise = true; + this.constructor.populate(this, paths, fn); + } + + return this; +}; + +/** + * Explicitly executes population and returns a promise. Useful for ES2015 + * integration. + * + * ####Example: + * + * var promise = doc. + * populate('company'). + * populate({ + * path: 'notes', + * match: /airline/, + * select: 'text', + * model: 'modelName' + * options: opts + * }). + * execPopulate(); + * + * // summary + * doc.execPopulate().then(resolve, reject); + * + * + * @see Document.populate #document_Document-populate + * @api public + * @return {Promise} promise that resolves to the document when population is done + */ + +Document.prototype.execPopulate = function() { + var Promise = PromiseProvider.get(); + var _this = this; + return new Promise.ES6(function(resolve, reject) { + _this.populate(function(error, res) { + if (error) { + reject(error); + } else { + resolve(res); + } + }); + }); +}; + +/** + * Gets _id(s) used during population of the given `path`. + * + * ####Example: + * + * Model.findOne().populate('author').exec(function (err, doc) { + * console.log(doc.author.name) // Dr.Seuss + * console.log(doc.populated('author')) // '5144cf8050f071d979c118a7' + * }) + * + * If the path was not populated, undefined is returned. + * + * @param {String} path + * @return {Array|ObjectId|Number|Buffer|String|undefined} + * @api public + */ + +Document.prototype.populated = function(path, val, options) { + // val and options are internal + + if (val === null || val === void 0) { + if (!this.$__.populated) { + return undefined; + } + var v = this.$__.populated[path]; + if (v) { + return v.value; + } + return undefined; + } + + // internal + + if (val === true) { + if (!this.$__.populated) { + return undefined; + } + return this.$__.populated[path]; + } + + this.$__.populated || (this.$__.populated = {}); + this.$__.populated[path] = {value: val, options: options}; + return val; +}; + +/** + * Takes a populated field and returns it to its unpopulated state. + * + * ####Example: + * + * Model.findOne().populate('author').exec(function (err, doc) { + * console.log(doc.author.name); // Dr.Seuss + * console.log(doc.depopulate('author')); + * console.log(doc.author); // '5144cf8050f071d979c118a7' + * }) + * + * If the path was not populated, this is a no-op. + * + * @param {String} path + * @see Document.populate #document_Document-populate + * @api public + */ + +Document.prototype.depopulate = function(path) { + var populatedIds = this.populated(path); + if (!populatedIds) { + return; + } + delete this.$__.populated[path]; + this.set(path, populatedIds); +}; + + +/** + * Returns the full path to this document. + * + * @param {String} [path] + * @return {String} + * @api private + * @method $__fullPath + * @memberOf Document + */ + +Document.prototype.$__fullPath = function(path) { + // overridden in SubDocuments + return path || ''; +}; + +/*! + * Module exports. + */ + +Document.ValidationError = ValidationError; +module.exports = exports = Document; diff --git a/node_modules/mongoose/lib/document_provider.js b/node_modules/mongoose/lib/document_provider.js new file mode 100644 index 0000000..10087cc --- /dev/null +++ b/node_modules/mongoose/lib/document_provider.js @@ -0,0 +1,21 @@ +'use strict'; + +/* eslint-env browser */ + +/*! + * Module dependencies. + */ +var Document = require('./document.js'); +var BrowserDocument = require('./browserDocument.js'); + +/** + * Returns the Document constructor for the current context + * + * @api private + */ +module.exports = function() { + if (typeof window !== 'undefined' && typeof document !== 'undefined' && document === window.document) { + return BrowserDocument; + } + return Document; +}; diff --git a/node_modules/mongoose/lib/document_provider.web.js b/node_modules/mongoose/lib/document_provider.web.js new file mode 100644 index 0000000..4223fc3 --- /dev/null +++ b/node_modules/mongoose/lib/document_provider.web.js @@ -0,0 +1,17 @@ +'use strict'; + +/* eslint-env browser */ + +/*! + * Module dependencies. + */ +var BrowserDocument = require('./browserDocument.js'); + +/** + * Returns the Document constructor for the current context + * + * @api private + */ +module.exports = function() { + return BrowserDocument; +}; diff --git a/node_modules/mongoose/lib/drivers/SPEC.md b/node_modules/mongoose/lib/drivers/SPEC.md new file mode 100644 index 0000000..6464693 --- /dev/null +++ b/node_modules/mongoose/lib/drivers/SPEC.md @@ -0,0 +1,4 @@ + +# Driver Spec + +TODO diff --git a/node_modules/mongoose/lib/drivers/browser/ReadPreference.js b/node_modules/mongoose/lib/drivers/browser/ReadPreference.js new file mode 100644 index 0000000..f20cd6c --- /dev/null +++ b/node_modules/mongoose/lib/drivers/browser/ReadPreference.js @@ -0,0 +1,5 @@ +/*! + * ignore + */ + +module.exports = function() {}; diff --git a/node_modules/mongoose/lib/drivers/browser/binary.js b/node_modules/mongoose/lib/drivers/browser/binary.js new file mode 100644 index 0000000..4d7a395 --- /dev/null +++ b/node_modules/mongoose/lib/drivers/browser/binary.js @@ -0,0 +1,12 @@ + +/*! + * Module dependencies. + */ + +var Binary = require('bson').Binary; + +/*! + * Module exports. + */ + +module.exports = exports = Binary; diff --git a/node_modules/mongoose/lib/drivers/browser/index.js b/node_modules/mongoose/lib/drivers/browser/index.js new file mode 100644 index 0000000..fa5dbb4 --- /dev/null +++ b/node_modules/mongoose/lib/drivers/browser/index.js @@ -0,0 +1,7 @@ +/*! + * Module exports. + */ + +exports.Binary = require('./binary'); +exports.ObjectId = require('./objectid'); +exports.ReadPreference = require('./ReadPreference'); diff --git a/node_modules/mongoose/lib/drivers/browser/objectid.js b/node_modules/mongoose/lib/drivers/browser/objectid.js new file mode 100644 index 0000000..e63c04a --- /dev/null +++ b/node_modules/mongoose/lib/drivers/browser/objectid.js @@ -0,0 +1,14 @@ + +/*! + * [node-mongodb-native](https://github.com/mongodb/node-mongodb-native) ObjectId + * @constructor NodeMongoDbObjectId + * @see ObjectId + */ + +var ObjectId = require('bson').ObjectID; + +/*! + * ignore + */ + +module.exports = exports = ObjectId; diff --git a/node_modules/mongoose/lib/drivers/index.js b/node_modules/mongoose/lib/drivers/index.js new file mode 100644 index 0000000..5a842ba --- /dev/null +++ b/node_modules/mongoose/lib/drivers/index.js @@ -0,0 +1,17 @@ +/*! + * ignore + */ + +var driver; + +if (typeof window === 'undefined') { + driver = require(global.MONGOOSE_DRIVER_PATH || './node-mongodb-native'); +} else { + driver = require('./browser'); +} + +/*! + * ignore + */ + +module.exports = driver; diff --git a/node_modules/mongoose/lib/drivers/index.web.js b/node_modules/mongoose/lib/drivers/index.web.js new file mode 100644 index 0000000..f833eb2 --- /dev/null +++ b/node_modules/mongoose/lib/drivers/index.web.js @@ -0,0 +1,5 @@ +/*! + * ignore + */ + +module.exports = require('./browser'); diff --git a/node_modules/mongoose/lib/drivers/node-mongodb-native/ReadPreference.js b/node_modules/mongoose/lib/drivers/node-mongodb-native/ReadPreference.js new file mode 100644 index 0000000..e921d60 --- /dev/null +++ b/node_modules/mongoose/lib/drivers/node-mongodb-native/ReadPreference.js @@ -0,0 +1,45 @@ +/*! + * Module dependencies. + */ + +var mongodb = require('mongodb'); +var ReadPref = mongodb.ReadPreference; + +/*! + * Converts arguments to ReadPrefs the driver + * can understand. + * + * @param {String|Array} pref + * @param {Array} [tags] + */ + +module.exports = function readPref(pref, tags) { + if (Array.isArray(pref)) { + tags = pref[1]; + pref = pref[0]; + } + + if (pref instanceof ReadPref) { + return pref; + } + + switch (pref) { + case 'p': + pref = 'primary'; + break; + case 'pp': + pref = 'primaryPreferred'; + break; + case 's': + pref = 'secondary'; + break; + case 'sp': + pref = 'secondaryPreferred'; + break; + case 'n': + pref = 'nearest'; + break; + } + + return new ReadPref(pref, tags); +}; diff --git a/node_modules/mongoose/lib/drivers/node-mongodb-native/binary.js b/node_modules/mongoose/lib/drivers/node-mongodb-native/binary.js new file mode 100644 index 0000000..657efde --- /dev/null +++ b/node_modules/mongoose/lib/drivers/node-mongodb-native/binary.js @@ -0,0 +1,8 @@ + +/*! + * Module dependencies. + */ + +var Binary = require('mongodb').Binary; + +module.exports = exports = Binary; diff --git a/node_modules/mongoose/lib/drivers/node-mongodb-native/collection.js b/node_modules/mongoose/lib/drivers/node-mongodb-native/collection.js new file mode 100644 index 0000000..c8e01e7 --- /dev/null +++ b/node_modules/mongoose/lib/drivers/node-mongodb-native/collection.js @@ -0,0 +1,259 @@ +/*! + * Module dependencies. + */ + +var MongooseCollection = require('../../collection'), + Collection = require('mongodb').Collection, + utils = require('../../utils'); + +/** + * A [node-mongodb-native](https://github.com/mongodb/node-mongodb-native) collection implementation. + * + * All methods methods from the [node-mongodb-native](https://github.com/mongodb/node-mongodb-native) driver are copied and wrapped in queue management. + * + * @inherits Collection + * @api private + */ + +function NativeCollection() { + this.collection = null; + MongooseCollection.apply(this, arguments); +} + +/*! + * Inherit from abstract Collection. + */ + +NativeCollection.prototype.__proto__ = MongooseCollection.prototype; + +/** + * Called when the connection opens. + * + * @api private + */ + +NativeCollection.prototype.onOpen = function() { + var _this = this; + + // always get a new collection in case the user changed host:port + // of parent db instance when re-opening the connection. + + if (!_this.opts.capped.size) { + // non-capped + return _this.conn.db.collection(_this.name, callback); + } + + // capped + return _this.conn.db.collection(_this.name, function(err, c) { + if (err) return callback(err); + + // discover if this collection exists and if it is capped + _this.conn.db.listCollections({name: _this.name}).toArray(function(err, docs) { + if (err) { + return callback(err); + } + var doc = docs[0]; + var exists = !!doc; + + if (exists) { + if (doc.options && doc.options.capped) { + callback(null, c); + } else { + var msg = 'A non-capped collection exists with the name: ' + _this.name + '\n\n' + + ' To use this collection as a capped collection, please ' + + 'first convert it.\n' + + ' http://www.mongodb.org/display/DOCS/Capped+Collections#CappedCollections-Convertingacollectiontocapped'; + err = new Error(msg); + callback(err); + } + } else { + // create + var opts = utils.clone(_this.opts.capped); + opts.capped = true; + _this.conn.db.createCollection(_this.name, opts, callback); + } + }); + }); + + function callback(err, collection) { + if (err) { + // likely a strict mode error + _this.conn.emit('error', err); + } else { + _this.collection = collection; + MongooseCollection.prototype.onOpen.call(_this); + } + } +}; + +/** + * Called when the connection closes + * + * @api private + */ + +NativeCollection.prototype.onClose = function() { + MongooseCollection.prototype.onClose.call(this); +}; + +/*! + * Copy the collection methods and make them subject to queues + */ + +function iter(i) { + NativeCollection.prototype[i] = function() { + if (this.buffer) { + this.addQueue(i, arguments); + return; + } + + var collection = this.collection, + args = arguments, + _this = this, + debug = _this.conn.base.options.debug; + + if (debug) { + if (typeof debug === 'function') { + debug.apply(debug, + [_this.name, i].concat(utils.args(args, 0, args.length - 1))); + } else { + this.$print(_this.name, i, args); + } + } + + try { + return collection[i].apply(collection, args); + } catch (error) { + // Collection operation may throw because of max bson size, catch it here + // See gh-3906 + if (args.length > 0 && + typeof args[args.length - 1] === 'function') { + args[args.length - 1](error); + } else { + throw error; + } + } + }; +} + +for (var i in Collection.prototype) { + // Janky hack to work around gh-3005 until we can get rid of the mongoose + // collection abstraction + try { + if (typeof Collection.prototype[i] !== 'function') { + continue; + } + } catch (e) { + continue; + } + + iter(i); +} + +/** + * Debug print helper + * + * @api public + * @method $print + */ + +NativeCollection.prototype.$print = function(name, i, args) { + var moduleName = '\x1B[0;36mMongoose:\x1B[0m '; + var functionCall = [name, i].join('.'); + var _args = []; + for (var j = args.length - 1; j >= 0; --j) { + if (this.$format(args[j]) || _args.length) { + _args.unshift(this.$format(args[j])); + } + } + var params = '(' + _args.join(', ') + ')'; + + console.error(moduleName + functionCall + params); +}; + +/** + * Formatter for debug print args + * + * @api public + * @method $format + */ + +NativeCollection.prototype.$format = function(arg) { + var type = typeof arg; + if (type === 'function' || type === 'undefined') return ''; + return format(arg); +}; + +/*! + * Debug print helper + */ + +function map(o) { + return format(o, true); +} +function formatObjectId(x, key) { + var representation = 'ObjectId("' + x[key].toHexString() + '")'; + x[key] = {inspect: function() { return representation; }}; +} +function formatDate(x, key) { + var representation = 'new Date("' + x[key].toUTCString() + '")'; + x[key] = {inspect: function() { return representation; }}; +} +function format(obj, sub) { + var x = utils.clone(obj, {retainKeyOrder: 1, transform: false}); + var representation; + + if (x != null) { + if (x.constructor.name === 'Binary') { + x = '[object Buffer]'; + } else if (x.constructor.name === 'ObjectID') { + representation = 'ObjectId("' + x.toHexString() + '")'; + x = {inspect: function() { return representation; }}; + } else if (x.constructor.name === 'Date') { + representation = 'new Date("' + x.toUTCString() + '")'; + x = {inspect: function() { return representation; }}; + } else if (x.constructor.name === 'Object') { + var keys = Object.keys(x); + var numKeys = keys.length; + var key; + for (var i = 0; i < numKeys; ++i) { + key = keys[i]; + if (x[key]) { + if (x[key].constructor.name === 'Binary') { + x[key] = '[object Buffer]'; + } else if (x[key].constructor.name === 'Object') { + x[key] = format(x[key], true); + } else if (x[key].constructor.name === 'ObjectID') { + formatObjectId(x, key); + } else if (x[key].constructor.name === 'Date') { + formatDate(x, key); + } else if (Array.isArray(x[key])) { + x[key] = x[key].map(map); + } + } + } + } + if (sub) return x; + } + + return require('util') + .inspect(x, false, 10, true) + .replace(/\n/g, '') + .replace(/\s{2,}/g, ' '); +} + +/** + * Retreives information about this collections indexes. + * + * @param {Function} callback + * @method getIndexes + * @api public + */ + +NativeCollection.prototype.getIndexes = NativeCollection.prototype.indexInformation; + +/*! + * Module exports. + */ + +module.exports = NativeCollection; diff --git a/node_modules/mongoose/lib/drivers/node-mongodb-native/connection.js b/node_modules/mongoose/lib/drivers/node-mongodb-native/connection.js new file mode 100644 index 0000000..36d0207 --- /dev/null +++ b/node_modules/mongoose/lib/drivers/node-mongodb-native/connection.js @@ -0,0 +1,386 @@ +/*! + * Module dependencies. + */ + +var MongooseConnection = require('../../connection'); +var mongo = require('mongodb'); +var Db = mongo.Db; +var Server = mongo.Server; +var Mongos = mongo.Mongos; +var STATES = require('../../connectionstate'); +var ReplSetServers = mongo.ReplSet; +var DisconnectedError = require('../../error/disconnected'); + +/** + * A [node-mongodb-native](https://github.com/mongodb/node-mongodb-native) connection implementation. + * + * @inherits Connection + * @api private + */ + +function NativeConnection() { + MongooseConnection.apply(this, arguments); + this._listening = false; +} + +/** + * Expose the possible connection states. + * @api public + */ + +NativeConnection.STATES = STATES; + +/*! + * Inherits from Connection. + */ + +NativeConnection.prototype.__proto__ = MongooseConnection.prototype; + +/** + * Opens the connection to MongoDB. + * + * @param {Function} fn + * @return {Connection} this + * @api private + */ + +NativeConnection.prototype.doOpen = function(fn) { + var _this = this; + var server = new Server(this.host, this.port, this.options.server); + + if (this.options && this.options.mongos) { + var mongos = new Mongos([server], this.options.mongos); + this.db = new Db(this.name, mongos, this.options.db); + } else { + this.db = new Db(this.name, server, this.options.db); + } + + this.db.open(function(err) { + listen(_this); + + if (!mongos) { + server.s.server.on('error', function(error) { + if (/after \d+ retries/.test(error.message)) { + _this.emit('error', new DisconnectedError(server.s.server.name)); + } + }); + } + + if (err) return fn(err); + + fn(); + }); + + return this; +}; + +/** + * Switches to a different database using the same connection pool. + * + * Returns a new connection object, with the new db. + * + * @param {String} name The database name + * @return {Connection} New Connection Object + * @api public + */ + +NativeConnection.prototype.useDb = function(name) { + // we have to manually copy all of the attributes... + var newConn = new this.constructor(); + newConn.name = name; + newConn.base = this.base; + newConn.collections = {}; + newConn.models = {}; + newConn.replica = this.replica; + newConn.hosts = this.hosts; + newConn.host = this.host; + newConn.port = this.port; + newConn.user = this.user; + newConn.pass = this.pass; + newConn.options = this.options; + newConn._readyState = this._readyState; + newConn._closeCalled = this._closeCalled; + newConn._hasOpened = this._hasOpened; + newConn._listening = false; + + // First, when we create another db object, we are not guaranteed to have a + // db object to work with. So, in the case where we have a db object and it + // is connected, we can just proceed with setting everything up. However, if + // we do not have a db or the state is not connected, then we need to wait on + // the 'open' event of the connection before doing the rest of the setup + // the 'connected' event is the first time we'll have access to the db object + + var _this = this; + + if (this.db && this._readyState === STATES.connected) { + wireup(); + } else { + this.once('connected', wireup); + } + + function wireup() { + newConn.db = _this.db.db(name); + newConn.onOpen(); + // setup the events appropriately + listen(newConn); + } + + newConn.name = name; + + // push onto the otherDbs stack, this is used when state changes + this.otherDbs.push(newConn); + newConn.otherDbs.push(this); + + return newConn; +}; + +/*! + * Register listeners for important events and bubble appropriately. + */ + +function listen(conn) { + if (conn.db._listening) { + return; + } + conn.db._listening = true; + + conn.db.on('close', function() { + if (conn._closeCalled) return; + + // the driver never emits an `open` event. auto_reconnect still + // emits a `close` event but since we never get another + // `open` we can't emit close + if (conn.db.serverConfig.autoReconnect) { + conn.readyState = STATES.disconnected; + conn.emit('close'); + return; + } + conn.onClose(); + }); + conn.db.on('error', function(err) { + conn.emit('error', err); + }); + conn.db.on('reconnect', function() { + conn.readyState = STATES.connected; + conn.emit('reconnected'); + }); + conn.db.on('timeout', function(err) { + var error = new Error(err && err.err || 'connection timeout'); + conn.emit('error', error); + }); + conn.db.on('open', function(err, db) { + if (STATES.disconnected === conn.readyState && db && db.databaseName) { + conn.readyState = STATES.connected; + conn.emit('reconnected'); + } + }); + conn.db.on('parseError', function(err) { + conn.emit('parseError', err); + }); +} + +/** + * Opens a connection to a MongoDB ReplicaSet. + * + * See description of [doOpen](#NativeConnection-doOpen) for server options. In this case `options.replset` is also passed to ReplSetServers. + * + * @param {Function} fn + * @api private + * @return {Connection} this + */ + +NativeConnection.prototype.doOpenSet = function(fn) { + var servers = [], + _this = this; + + this.hosts.forEach(function(server) { + var host = server.host || server.ipc; + var port = server.port || 27017; + servers.push(new Server(host, port, _this.options.server)); + }); + + var server = this.options.mongos + ? new Mongos(servers, this.options.mongos) + : new ReplSetServers(servers, this.options.replset || this.options.replSet); + this.db = new Db(this.name, server, this.options.db); + + this.db.on('fullsetup', function() { + _this.emit('fullsetup'); + }); + + this.db.on('all', function() { + _this.emit('all'); + }); + + this.db.open(function(err) { + if (err) return fn(err); + fn(); + listen(_this); + }); + + return this; +}; + +/** + * Closes the connection + * + * @param {Function} fn + * @return {Connection} this + * @api private + */ + +NativeConnection.prototype.doClose = function(fn) { + this.db.close(fn); + return this; +}; + +/** + * Prepares default connection options for the node-mongodb-native driver. + * + * _NOTE: `passed` options take precedence over connection string options._ + * + * @param {Object} passed options that were passed directly during connection + * @param {Object} [connStrOptions] options that were passed in the connection string + * @api private + */ + +NativeConnection.prototype.parseOptions = function(passed, connStrOpts) { + var o = passed || {}; + o.db || (o.db = {}); + o.auth || (o.auth = {}); + o.server || (o.server = {}); + o.replset || (o.replset = o.replSet) || (o.replset = {}); + o.server.socketOptions || (o.server.socketOptions = {}); + o.replset.socketOptions || (o.replset.socketOptions = {}); + o.mongos || (o.mongos = (connStrOpts && connStrOpts.mongos)); + (o.mongos === true) && (o.mongos = {}); + + var opts = connStrOpts || {}; + Object.keys(opts).forEach(function(name) { + switch (name) { + case 'ssl': + o.server.ssl = opts.ssl; + o.replset.ssl = opts.ssl; + o.mongos && (o.mongos.ssl = opts.ssl); + break; + case 'poolSize': + if (typeof o.server[name] === 'undefined') { + o.server[name] = o.replset[name] = opts[name]; + } + break; + case 'slaveOk': + if (typeof o.server.slave_ok === 'undefined') { + o.server.slave_ok = opts[name]; + } + break; + case 'autoReconnect': + if (typeof o.server.auto_reconnect === 'undefined') { + o.server.auto_reconnect = opts[name]; + } + break; + case 'socketTimeoutMS': + case 'connectTimeoutMS': + if (typeof o.server.socketOptions[name] === 'undefined') { + o.server.socketOptions[name] = o.replset.socketOptions[name] = opts[name]; + } + break; + case 'authdb': + if (typeof o.auth.authdb === 'undefined') { + o.auth.authdb = opts[name]; + } + break; + case 'authSource': + if (typeof o.auth.authSource === 'undefined') { + o.auth.authSource = opts[name]; + } + break; + case 'retries': + case 'reconnectWait': + case 'rs_name': + if (typeof o.replset[name] === 'undefined') { + o.replset[name] = opts[name]; + } + break; + case 'replicaSet': + if (typeof o.replset.rs_name === 'undefined') { + o.replset.rs_name = opts[name]; + } + break; + case 'readSecondary': + if (typeof o.replset.read_secondary === 'undefined') { + o.replset.read_secondary = opts[name]; + } + break; + case 'nativeParser': + if (typeof o.db.native_parser === 'undefined') { + o.db.native_parser = opts[name]; + } + break; + case 'w': + case 'safe': + case 'fsync': + case 'journal': + case 'wtimeoutMS': + if (typeof o.db[name] === 'undefined') { + o.db[name] = opts[name]; + } + break; + case 'readPreference': + if (typeof o.db.readPreference === 'undefined') { + o.db.readPreference = opts[name]; + } + break; + case 'readPreferenceTags': + if (typeof o.db.read_preference_tags === 'undefined') { + o.db.read_preference_tags = opts[name]; + } + break; + case 'sslValidate': + o.server.sslValidate = opts.sslValidate; + o.replset.sslValidate = opts.sslValidate; + o.mongos && (o.mongos.sslValidate = opts.sslValidate); + } + }); + + if (!('auto_reconnect' in o.server)) { + o.server.auto_reconnect = true; + } + + // mongoose creates its own ObjectIds + o.db.forceServerObjectId = false; + + // default safe using new nomenclature + if (!('journal' in o.db || 'j' in o.db || + 'fsync' in o.db || 'safe' in o.db || 'w' in o.db)) { + o.db.w = 1; + } + + if (o.promiseLibrary) { + o.db.promiseLibrary = o.promiseLibrary; + } + + validate(o); + return o; +}; + +/*! + * Validates the driver db options. + * + * @param {Object} o + */ + +function validate(o) { + if (o.db.w === -1 || o.db.w === 0) { + if (o.db.journal || o.db.fsync || o.db.safe) { + throw new Error( + 'Invalid writeConcern: ' + + 'w set to -1 or 0 cannot be combined with safe|fsync|journal'); + } + } +} + +/*! + * Module exports. + */ + +module.exports = NativeConnection; diff --git a/node_modules/mongoose/lib/drivers/node-mongodb-native/index.js b/node_modules/mongoose/lib/drivers/node-mongodb-native/index.js new file mode 100644 index 0000000..fa5dbb4 --- /dev/null +++ b/node_modules/mongoose/lib/drivers/node-mongodb-native/index.js @@ -0,0 +1,7 @@ +/*! + * Module exports. + */ + +exports.Binary = require('./binary'); +exports.ObjectId = require('./objectid'); +exports.ReadPreference = require('./ReadPreference'); diff --git a/node_modules/mongoose/lib/drivers/node-mongodb-native/objectid.js b/node_modules/mongoose/lib/drivers/node-mongodb-native/objectid.js new file mode 100644 index 0000000..69fc08f --- /dev/null +++ b/node_modules/mongoose/lib/drivers/node-mongodb-native/objectid.js @@ -0,0 +1,14 @@ + +/*! + * [node-mongodb-native](https://github.com/mongodb/node-mongodb-native) ObjectId + * @constructor NodeMongoDbObjectId + * @see ObjectId + */ + +var ObjectId = require('mongodb').ObjectId; + +/*! + * ignore + */ + +module.exports = exports = ObjectId; diff --git a/node_modules/mongoose/lib/error.js b/node_modules/mongoose/lib/error.js new file mode 100644 index 0000000..b084e76 --- /dev/null +++ b/node_modules/mongoose/lib/error.js @@ -0,0 +1,55 @@ + +/** + * MongooseError constructor + * + * @param {String} msg Error message + * @inherits Error https://developer.mozilla.org/en/JavaScript/Reference/Global_Objects/Error + */ + +function MongooseError(msg) { + Error.call(this); + if (Error.captureStackTrace) { + Error.captureStackTrace(this); + } else { + this.stack = new Error().stack; + } + this.message = msg; + this.name = 'MongooseError'; +} + +/*! + * Inherits from Error. + */ + +MongooseError.prototype = Object.create(Error.prototype); +MongooseError.prototype.constructor = Error; + +/*! + * Module exports. + */ + +module.exports = exports = MongooseError; + +/** + * The default built-in validator error messages. + * + * @see Error.messages #error_messages_MongooseError-messages + * @api public + */ + +MongooseError.messages = require('./error/messages'); + +// backward compat +MongooseError.Messages = MongooseError.messages; + +/*! + * Expose subclasses + */ + +MongooseError.CastError = require('./error/cast'); +MongooseError.ValidationError = require('./error/validation'); +MongooseError.ValidatorError = require('./error/validator'); +MongooseError.VersionError = require('./error/version'); +MongooseError.OverwriteModelError = require('./error/overwriteModel'); +MongooseError.MissingSchemaError = require('./error/missingSchema'); +MongooseError.DivergentArrayError = require('./error/divergentArray'); diff --git a/node_modules/mongoose/lib/error/browserMissingSchema.js b/node_modules/mongoose/lib/error/browserMissingSchema.js new file mode 100644 index 0000000..1c7892e --- /dev/null +++ b/node_modules/mongoose/lib/error/browserMissingSchema.js @@ -0,0 +1,32 @@ +/*! + * Module dependencies. + */ + +var MongooseError = require('../error.js'); + +/*! + * MissingSchema Error constructor. + * + * @inherits MongooseError + */ + +function MissingSchemaError() { + var msg = 'Schema hasn\'t been registered for document.\n' + + 'Use mongoose.Document(name, schema)'; + MongooseError.call(this, msg); + Error.captureStackTrace && Error.captureStackTrace(this, arguments.callee); + this.name = 'MissingSchemaError'; +} + +/*! + * Inherits from MongooseError. + */ + +MissingSchemaError.prototype = Object.create(MongooseError.prototype); +MissingSchemaError.prototype.constructor = MongooseError; + +/*! + * exports + */ + +module.exports = MissingSchemaError; diff --git a/node_modules/mongoose/lib/error/cast.js b/node_modules/mongoose/lib/error/cast.js new file mode 100644 index 0000000..d42d6e8 --- /dev/null +++ b/node_modules/mongoose/lib/error/cast.js @@ -0,0 +1,49 @@ +/*! + * Module dependencies. + */ + +var MongooseError = require('../error.js'); +var util = require('util'); + +/** + * Casting Error constructor. + * + * @param {String} type + * @param {String} value + * @inherits MongooseError + * @api private + */ + +function CastError(type, value, path, reason) { + var stringValue = util.inspect(value); + stringValue = stringValue.replace(/^'/, '"').replace(/'$/, '"'); + if (stringValue.charAt(0) !== '"') { + stringValue = '"' + stringValue + '"'; + } + MongooseError.call(this, 'Cast to ' + type + ' failed for value ' + + stringValue + ' at path "' + path + '"'); + if (Error.captureStackTrace) { + Error.captureStackTrace(this); + } else { + this.stack = new Error().stack; + } + this.name = 'CastError'; + this.kind = type; + this.value = value; + this.path = path; + this.reason = reason; +} + +/*! + * Inherits from MongooseError. + */ + +CastError.prototype = Object.create(MongooseError.prototype); +CastError.prototype.constructor = MongooseError; + + +/*! + * exports + */ + +module.exports = CastError; diff --git a/node_modules/mongoose/lib/error/disconnected.js b/node_modules/mongoose/lib/error/disconnected.js new file mode 100644 index 0000000..b4eece1 --- /dev/null +++ b/node_modules/mongoose/lib/error/disconnected.js @@ -0,0 +1,40 @@ +/*! + * Module dependencies. + */ + +var MongooseError = require('../error.js'); + +/** + * Casting Error constructor. + * + * @param {String} type + * @param {String} value + * @inherits MongooseError + * @api private + */ + +function DisconnectedError(connectionString) { + MongooseError.call(this, 'Ran out of retries trying to reconnect to "' + + connectionString + '". Try setting `server.reconnectTries` and ' + + '`server.reconnectInterval` to something higher.'); + if (Error.captureStackTrace) { + Error.captureStackTrace(this); + } else { + this.stack = new Error().stack; + } + this.name = 'DisconnectedError'; +} + +/*! + * Inherits from MongooseError. + */ + +DisconnectedError.prototype = Object.create(MongooseError.prototype); +DisconnectedError.prototype.constructor = MongooseError; + + +/*! + * exports + */ + +module.exports = DisconnectedError; diff --git a/node_modules/mongoose/lib/error/divergentArray.js b/node_modules/mongoose/lib/error/divergentArray.js new file mode 100644 index 0000000..1cbaa25 --- /dev/null +++ b/node_modules/mongoose/lib/error/divergentArray.js @@ -0,0 +1,42 @@ + +/*! + * Module dependencies. + */ + +var MongooseError = require('../error.js'); + +/*! + * DivergentArrayError constructor. + * + * @inherits MongooseError + */ + +function DivergentArrayError(paths) { + var msg = 'For your own good, using `document.save()` to update an array ' + + 'which was selected using an $elemMatch projection OR ' + + 'populated using skip, limit, query conditions, or exclusion of ' + + 'the _id field when the operation results in a $pop or $set of ' + + 'the entire array is not supported. The following ' + + 'path(s) would have been modified unsafely:\n' + + ' ' + paths.join('\n ') + '\n' + + 'Use Model.update() to update these arrays instead.'; + // TODO write up a docs page (FAQ) and link to it + + MongooseError.call(this, msg); + Error.captureStackTrace && Error.captureStackTrace(this, arguments.callee); + this.name = 'DivergentArrayError'; +} + +/*! + * Inherits from MongooseError. + */ + +DivergentArrayError.prototype = Object.create(MongooseError.prototype); +DivergentArrayError.prototype.constructor = MongooseError; + + +/*! + * exports + */ + +module.exports = DivergentArrayError; diff --git a/node_modules/mongoose/lib/error/messages.js b/node_modules/mongoose/lib/error/messages.js new file mode 100644 index 0000000..88ddf6e --- /dev/null +++ b/node_modules/mongoose/lib/error/messages.js @@ -0,0 +1,42 @@ + +/** + * The default built-in validator error messages. These may be customized. + * + * // customize within each schema or globally like so + * var mongoose = require('mongoose'); + * mongoose.Error.messages.String.enum = "Your custom message for {PATH}."; + * + * As you might have noticed, error messages support basic templating + * + * - `{PATH}` is replaced with the invalid document path + * - `{VALUE}` is replaced with the invalid value + * - `{TYPE}` is replaced with the validator type such as "regexp", "min", or "user defined" + * - `{MIN}` is replaced with the declared min value for the Number.min validator + * - `{MAX}` is replaced with the declared max value for the Number.max validator + * + * Click the "show code" link below to see all defaults. + * + * @static messages + * @receiver MongooseError + * @api public + */ + +var msg = module.exports = exports = {}; + +msg.general = {}; +msg.general.default = 'Validator failed for path `{PATH}` with value `{VALUE}`'; +msg.general.required = 'Path `{PATH}` is required.'; + +msg.Number = {}; +msg.Number.min = 'Path `{PATH}` ({VALUE}) is less than minimum allowed value ({MIN}).'; +msg.Number.max = 'Path `{PATH}` ({VALUE}) is more than maximum allowed value ({MAX}).'; + +msg.Date = {}; +msg.Date.min = 'Path `{PATH}` ({VALUE}) is before minimum allowed value ({MIN}).'; +msg.Date.max = 'Path `{PATH}` ({VALUE}) is after maximum allowed value ({MAX}).'; + +msg.String = {}; +msg.String.enum = '`{VALUE}` is not a valid enum value for path `{PATH}`.'; +msg.String.match = 'Path `{PATH}` is invalid ({VALUE}).'; +msg.String.minlength = 'Path `{PATH}` (`{VALUE}`) is shorter than the minimum allowed length ({MINLENGTH}).'; +msg.String.maxlength = 'Path `{PATH}` (`{VALUE}`) is longer than the maximum allowed length ({MAXLENGTH}).'; diff --git a/node_modules/mongoose/lib/error/missingSchema.js b/node_modules/mongoose/lib/error/missingSchema.js new file mode 100644 index 0000000..25eabfa --- /dev/null +++ b/node_modules/mongoose/lib/error/missingSchema.js @@ -0,0 +1,33 @@ + +/*! + * Module dependencies. + */ + +var MongooseError = require('../error.js'); + +/*! + * MissingSchema Error constructor. + * + * @inherits MongooseError + */ + +function MissingSchemaError(name) { + var msg = 'Schema hasn\'t been registered for model "' + name + '".\n' + + 'Use mongoose.model(name, schema)'; + MongooseError.call(this, msg); + Error.captureStackTrace && Error.captureStackTrace(this, arguments.callee); + this.name = 'MissingSchemaError'; +} + +/*! + * Inherits from MongooseError. + */ + +MissingSchemaError.prototype = Object.create(MongooseError.prototype); +MissingSchemaError.prototype.constructor = MongooseError; + +/*! + * exports + */ + +module.exports = MissingSchemaError; diff --git a/node_modules/mongoose/lib/error/objectExpected.js b/node_modules/mongoose/lib/error/objectExpected.js new file mode 100644 index 0000000..fa863bc --- /dev/null +++ b/node_modules/mongoose/lib/error/objectExpected.js @@ -0,0 +1,35 @@ +/*! + * Module dependencies. + */ + +var MongooseError = require('../error.js'); + +/** + * Strict mode error constructor + * + * @param {String} type + * @param {String} value + * @inherits MongooseError + * @api private + */ + +function ObjectExpectedError(path, val) { + MongooseError.call(this, 'Tried to set nested object field `' + path + + '` to primitive value `' + val + '` and strict mode is set to throw.'); + if (Error.captureStackTrace) { + Error.captureStackTrace(this); + } else { + this.stack = new Error().stack; + } + this.name = 'ObjectExpectedError'; + this.path = path; +} + +/*! + * Inherits from MongooseError. + */ + +ObjectExpectedError.prototype = Object.create(MongooseError.prototype); +ObjectExpectedError.prototype.constructor = MongooseError; + +module.exports = ObjectExpectedError; diff --git a/node_modules/mongoose/lib/error/overwriteModel.js b/node_modules/mongoose/lib/error/overwriteModel.js new file mode 100644 index 0000000..c14ae7f --- /dev/null +++ b/node_modules/mongoose/lib/error/overwriteModel.js @@ -0,0 +1,31 @@ + +/*! + * Module dependencies. + */ + +var MongooseError = require('../error.js'); + +/*! + * OverwriteModel Error constructor. + * + * @inherits MongooseError + */ + +function OverwriteModelError(name) { + MongooseError.call(this, 'Cannot overwrite `' + name + '` model once compiled.'); + Error.captureStackTrace && Error.captureStackTrace(this, arguments.callee); + this.name = 'OverwriteModelError'; +} + +/*! + * Inherits from MongooseError. + */ + +OverwriteModelError.prototype = Object.create(MongooseError.prototype); +OverwriteModelError.prototype.constructor = MongooseError; + +/*! + * exports + */ + +module.exports = OverwriteModelError; diff --git a/node_modules/mongoose/lib/error/strict.js b/node_modules/mongoose/lib/error/strict.js new file mode 100644 index 0000000..6e34431 --- /dev/null +++ b/node_modules/mongoose/lib/error/strict.js @@ -0,0 +1,35 @@ +/*! + * Module dependencies. + */ + +var MongooseError = require('../error.js'); + +/** + * Strict mode error constructor + * + * @param {String} type + * @param {String} value + * @inherits MongooseError + * @api private + */ + +function StrictModeError(path) { + MongooseError.call(this, 'Field `' + path + '` is not in schema and strict ' + + 'mode is set to throw.'); + if (Error.captureStackTrace) { + Error.captureStackTrace(this); + } else { + this.stack = new Error().stack; + } + this.name = 'StrictModeError'; + this.path = path; +} + +/*! + * Inherits from MongooseError. + */ + +StrictModeError.prototype = Object.create(MongooseError.prototype); +StrictModeError.prototype.constructor = MongooseError; + +module.exports = StrictModeError; diff --git a/node_modules/mongoose/lib/error/validation.js b/node_modules/mongoose/lib/error/validation.js new file mode 100644 index 0000000..bcbad61 --- /dev/null +++ b/node_modules/mongoose/lib/error/validation.js @@ -0,0 +1,63 @@ +/*! + * Module requirements + */ + +var MongooseError = require('../error.js'); + +/** + * Document Validation Error + * + * @api private + * @param {Document} instance + * @inherits MongooseError + */ + +function ValidationError(instance) { + if (instance && instance.constructor.name === 'model') { + MongooseError.call(this, instance.constructor.modelName + ' validation failed'); + } else { + MongooseError.call(this, 'Validation failed'); + } + if (Error.captureStackTrace) { + Error.captureStackTrace(this); + } else { + this.stack = new Error().stack; + } + this.name = 'ValidationError'; + this.errors = {}; + if (instance) { + instance.errors = this.errors; + } +} + +/*! + * Inherits from MongooseError. + */ + +ValidationError.prototype = Object.create(MongooseError.prototype); +ValidationError.prototype.constructor = MongooseError; + + +/** + * Console.log helper + */ + +ValidationError.prototype.toString = function() { + var ret = this.name + ': '; + var msgs = []; + + Object.keys(this.errors).forEach(function(key) { + if (this === this.errors[key]) { + return; + } + msgs.push(String(this.errors[key])); + }, this); + + return ret + msgs.join(', '); +}; + +/*! + * Module exports + */ + +module.exports = exports = ValidationError; diff --git a/node_modules/mongoose/lib/error/validator.js b/node_modules/mongoose/lib/error/validator.js new file mode 100644 index 0000000..96a3ba1 --- /dev/null +++ b/node_modules/mongoose/lib/error/validator.js @@ -0,0 +1,81 @@ +/*! + * Module dependencies. + */ + +var MongooseError = require('../error.js'); + +/** + * Schema validator error + * + * @param {Object} properties + * @inherits MongooseError + * @api private + */ + +function ValidatorError(properties) { + var msg = properties.message; + if (!msg) { + msg = MongooseError.messages.general.default; + } + + var message = this.formatMessage(msg, properties); + MongooseError.call(this, message); + if (Error.captureStackTrace) { + Error.captureStackTrace(this); + } else { + this.stack = new Error().stack; + } + this.properties = properties; + this.name = 'ValidatorError'; + this.kind = properties.type; + this.path = properties.path; + this.value = properties.value; +} + +/*! + * Inherits from MongooseError + */ + +ValidatorError.prototype = Object.create(MongooseError.prototype); +ValidatorError.prototype.constructor = MongooseError; + +/*! + * The object used to define this validator. Not enumerable to hide + * it from `require('util').inspect()` output re: gh-3925 + */ + +Object.defineProperty(ValidatorError.prototype, 'properties', { + enumerable: false, + writable: true, + value: null +}); + +/*! + * Formats error messages + */ + +ValidatorError.prototype.formatMessage = function(msg, properties) { + var propertyNames = Object.keys(properties); + for (var i = 0; i < propertyNames.length; ++i) { + var propertyName = propertyNames[i]; + if (propertyName === 'message') { + continue; + } + msg = msg.replace('{' + propertyName.toUpperCase() + '}', properties[propertyName]); + } + return msg; +}; + +/*! + * toString helper + */ + +ValidatorError.prototype.toString = function() { + return this.message; +}; + +/*! + * exports + */ + +module.exports = ValidatorError; diff --git a/node_modules/mongoose/lib/error/version.js b/node_modules/mongoose/lib/error/version.js new file mode 100644 index 0000000..e509b9b --- /dev/null +++ b/node_modules/mongoose/lib/error/version.js @@ -0,0 +1,33 @@ +'use strict'; + +/*! + * Module dependencies. + */ + +var MongooseError = require('../error.js'); + +/** + * Version Error constructor. + * + * @inherits MongooseError + * @api private + */ + +function VersionError(doc) { + MongooseError.call(this, 'No matching document found for id "' + doc._id + + '"'); + this.name = 'VersionError'; +} + +/*! + * Inherits from MongooseError. + */ + +VersionError.prototype = Object.create(MongooseError.prototype); +VersionError.prototype.constructor = MongooseError; + +/*! + * exports + */ + +module.exports = VersionError; diff --git a/node_modules/mongoose/lib/index.js b/node_modules/mongoose/lib/index.js new file mode 100644 index 0000000..be9aacd --- /dev/null +++ b/node_modules/mongoose/lib/index.js @@ -0,0 +1,803 @@ +'use strict'; + +/*! + * Module dependencies. + */ + +var Schema = require('./schema'), + SchemaType = require('./schematype'), + VirtualType = require('./virtualtype'), + STATES = require('./connectionstate'), + Types = require('./types'), + Query = require('./query'), + Model = require('./model'), + Document = require('./document'), + utils = require('./utils'), + format = utils.toCollectionName, + pkg = require('../package.json'); + +var querystring = require('querystring'); + +var Aggregate = require('./aggregate'); +var PromiseProvider = require('./promise_provider'); + +/** + * Mongoose constructor. + * + * The exports object of the `mongoose` module is an instance of this class. + * Most apps will only use this one instance. + * + * @api public + */ + +function Mongoose() { + this.connections = []; + this.plugins = []; + this.models = {}; + this.modelSchemas = {}; + // default global options + this.options = { + pluralization: true + }; + var conn = this.createConnection(); // default connection + conn.models = this.models; +} + +/** + * Expose connection states for user-land + * + */ +Mongoose.prototype.STATES = STATES; + +/** + * Sets mongoose options + * + * ####Example: + * + * mongoose.set('test', value) // sets the 'test' option to `value` + * + * mongoose.set('debug', true) // enable logging collection methods + arguments to the console + * + * mongoose.set('debug', function(collectionName, methodName, arg1, arg2...) {}); // use custom function to log collection methods + arguments + * + * @param {String} key + * @param {String|Function} value + * @api public + */ + +Mongoose.prototype.set = function(key, value) { + if (arguments.length === 1) { + return this.options[key]; + } + + this.options[key] = value; + return this; +}; +Mongoose.prototype.set.$hasSideEffects = true; + +/** + * Gets mongoose options + * + * ####Example: + * + * mongoose.get('test') // returns the 'test' value + * + * @param {String} key + * @method get + * @api public + */ + +Mongoose.prototype.get = Mongoose.prototype.set; + +/*! + * ReplSet connection string check. + */ + +var rgxReplSet = /^.+,.+$/; + +/** + * Checks if ?replicaSet query parameter is specified in URI + * + * ####Example: + * + * checkReplicaSetInUri('localhost:27000?replicaSet=rs0'); // true + * + * @param {String} uri + * @return {boolean} + * @api private + */ + +var checkReplicaSetInUri = function(uri) { + if (!uri) { + return false; + } + + var queryStringStart = uri.indexOf('?'); + var isReplicaSet = false; + if (queryStringStart !== -1) { + try { + var obj = querystring.parse(uri.substr(queryStringStart + 1)); + if (obj && obj.replicaSet) { + isReplicaSet = true; + } + } catch (e) { + return false; + } + } + + return isReplicaSet; +}; + +/** + * Creates a Connection instance. + * + * Each `connection` instance maps to a single database. This method is helpful when mangaging multiple db connections. + * + * If arguments are passed, they are proxied to either [Connection#open](#connection_Connection-open) or [Connection#openSet](#connection_Connection-openSet) appropriately. This means we can pass `db`, `server`, and `replset` options to the driver. _Note that the `safe` option specified in your schema will overwrite the `safe` db option specified here unless you set your schemas `safe` option to `undefined`. See [this](/docs/guide.html#safe) for more information._ + * + * _Options passed take precedence over options included in connection strings._ + * + * ####Example: + * + * // with mongodb:// URI + * db = mongoose.createConnection('mongodb://user:pass@localhost:port/database'); + * + * // and options + * var opts = { db: { native_parser: true }} + * db = mongoose.createConnection('mongodb://user:pass@localhost:port/database', opts); + * + * // replica sets + * db = mongoose.createConnection('mongodb://user:pass@localhost:port,anotherhost:port,yetanother:port/database'); + * + * // and options + * var opts = { replset: { strategy: 'ping', rs_name: 'testSet' }} + * db = mongoose.createConnection('mongodb://user:pass@localhost:port,anotherhost:port,yetanother:port/database', opts); + * + * // with [host, database_name[, port] signature + * db = mongoose.createConnection('localhost', 'database', port) + * + * // and options + * var opts = { server: { auto_reconnect: false }, user: 'username', pass: 'mypassword' } + * db = mongoose.createConnection('localhost', 'database', port, opts) + * + * // initialize now, connect later + * db = mongoose.createConnection(); + * db.open('localhost', 'database', port, [opts]); + * + * @param {String} [uri] a mongodb:// URI + * @param {Object} [options] options to pass to the driver + * @param {Object} [options.config] mongoose-specific options + * @param {Boolean} [options.config.autoIndex] set to false to disable automatic index creation for all models associated with this connection. + * @see Connection#open #connection_Connection-open + * @see Connection#openSet #connection_Connection-openSet + * @return {Connection} the created Connection object + * @api public + */ + +Mongoose.prototype.createConnection = function(uri, options) { + var conn = new Connection(this); + this.connections.push(conn); + + var rsOption = options && (options.replset || options.replSet); + if (arguments.length) { + if (rgxReplSet.test(arguments[0]) || checkReplicaSetInUri(arguments[0])) { + conn.openSet.apply(conn, arguments); + } else if (rsOption && + (rsOption.replicaSet || rsOption.rs_name)) { + conn.openSet.apply(conn, arguments); + } else { + conn.open.apply(conn, arguments); + } + } + + return conn; +}; +Mongoose.prototype.createConnection.$hasSideEffects = true; + +/** + * Opens the default mongoose connection. + * + * If arguments are passed, they are proxied to either + * [Connection#open](#connection_Connection-open) or + * [Connection#openSet](#connection_Connection-openSet) appropriately. + * + * _Options passed take precedence over options included in connection strings._ + * + * ####Example: + * + * mongoose.connect('mongodb://user:pass@localhost:port/database'); + * + * // replica sets + * var uri = 'mongodb://user:pass@localhost:port,anotherhost:port,yetanother:port/mydatabase'; + * mongoose.connect(uri); + * + * // with options + * mongoose.connect(uri, options); + * + * // connecting to multiple mongos + * var uri = 'mongodb://hostA:27501,hostB:27501'; + * var opts = { mongos: true }; + * mongoose.connect(uri, opts); + * + * // optional callback that gets fired when initial connection completed + * var uri = 'mongodb://nonexistent.domain:27000'; + * mongoose.connect(uri, function(error) { + * // if error is truthy, the initial connection failed. + * }) + * + * @param {String} uri(s) + * @param {Object} [options] + * @param {Function} [callback] + * @see Mongoose#createConnection #index_Mongoose-createConnection + * @api public + * @return {MongooseThenable} pseudo-promise wrapper around this + */ + +Mongoose.prototype.connect = function() { + var conn = this.connection; + if (rgxReplSet.test(arguments[0]) || checkReplicaSetInUri(arguments[0])) { + return new MongooseThenable(this, conn.openSet.apply(conn, arguments)); + } + + return new MongooseThenable(this, conn.open.apply(conn, arguments)); +}; +Mongoose.prototype.connect.$hasSideEffects = true; + +/** + * Disconnects all connections. + * + * @param {Function} [fn] called after all connection close. + * @return {MongooseThenable} pseudo-promise wrapper around this + * @api public + */ + +Mongoose.prototype.disconnect = function(fn) { + var error; + this.connections.forEach(function(conn) { + conn.close(function(err) { + if (error) { + return; + } + if (err) { + error = err; + } + }); + }); + + var Promise = PromiseProvider.get(); + return new MongooseThenable(this, new Promise.ES6(function(resolve, reject) { + fn && fn(error); + if (error) { + reject(error); + return; + } + resolve(); + })); +}; +Mongoose.prototype.disconnect.$hasSideEffects = true; + +/** + * Defines a model or retrieves it. + * + * Models defined on the `mongoose` instance are available to all connection created by the same `mongoose` instance. + * + * ####Example: + * + * var mongoose = require('mongoose'); + * + * // define an Actor model with this mongoose instance + * mongoose.model('Actor', new Schema({ name: String })); + * + * // create a new connection + * var conn = mongoose.createConnection(..); + * + * // retrieve the Actor model + * var Actor = conn.model('Actor'); + * + * _When no `collection` argument is passed, Mongoose produces a collection name by passing the model `name` to the [utils.toCollectionName](#utils_exports.toCollectionName) method. This method pluralizes the name. If you don't like this behavior, either pass a collection name or set your schemas collection name option._ + * + * ####Example: + * + * var schema = new Schema({ name: String }, { collection: 'actor' }); + * + * // or + * + * schema.set('collection', 'actor'); + * + * // or + * + * var collectionName = 'actor' + * var M = mongoose.model('Actor', schema, collectionName) + * + * @param {String} name model name + * @param {Schema} [schema] + * @param {String} [collection] name (optional, induced from model name) + * @param {Boolean} [skipInit] whether to skip initialization (defaults to false) + * @api public + */ + +Mongoose.prototype.model = function(name, schema, collection, skipInit) { + if (typeof schema === 'string') { + collection = schema; + schema = false; + } + + if (utils.isObject(schema) && !(schema.instanceOfSchema)) { + schema = new Schema(schema); + } + + if (typeof collection === 'boolean') { + skipInit = collection; + collection = null; + } + + // handle internal options from connection.model() + var options; + if (skipInit && utils.isObject(skipInit)) { + options = skipInit; + skipInit = true; + } else { + options = {}; + } + + // look up schema for the collection. + if (!this.modelSchemas[name]) { + if (schema) { + // cache it so we only apply plugins once + this.modelSchemas[name] = schema; + this._applyPlugins(schema); + } else { + throw new mongoose.Error.MissingSchemaError(name); + } + } + + var model; + var sub; + + // connection.model() may be passing a different schema for + // an existing model name. in this case don't read from cache. + if (this.models[name] && options.cache !== false) { + if (schema && schema.instanceOfSchema && schema !== this.models[name].schema) { + throw new mongoose.Error.OverwriteModelError(name); + } + + if (collection) { + // subclass current model with alternate collection + model = this.models[name]; + schema = model.prototype.schema; + sub = model.__subclass(this.connection, schema, collection); + // do not cache the sub model + return sub; + } + + return this.models[name]; + } + + // ensure a schema exists + if (!schema) { + schema = this.modelSchemas[name]; + if (!schema) { + throw new mongoose.Error.MissingSchemaError(name); + } + } + + // Apply relevant "global" options to the schema + if (!('pluralization' in schema.options)) schema.options.pluralization = this.options.pluralization; + + + if (!collection) { + collection = schema.get('collection') || format(name, schema.options); + } + + var connection = options.connection || this.connection; + model = this.Model.compile(name, schema, collection, connection, this); + + if (!skipInit) { + model.init(); + } + + if (options.cache === false) { + return model; + } + + this.models[name] = model; + return this.models[name]; +}; +Mongoose.prototype.model.$hasSideEffects = true; + +/** + * Returns an array of model names created on this instance of Mongoose. + * + * ####Note: + * + * _Does not include names of models created using `connection.model()`._ + * + * @api public + * @return {Array} + */ + +Mongoose.prototype.modelNames = function() { + var names = Object.keys(this.models); + return names; +}; +Mongoose.prototype.modelNames.$hasSideEffects = true; + +/** + * Applies global plugins to `schema`. + * + * @param {Schema} schema + * @api private + */ + +Mongoose.prototype._applyPlugins = function(schema) { + if (schema.$globalPluginsApplied) { + return; + } + var i; + var len; + for (i = 0, len = this.plugins.length; i < len; ++i) { + schema.plugin(this.plugins[i][0], this.plugins[i][1]); + } + schema.$globalPluginsApplied = true; + for (i = 0, len = schema.childSchemas.length; i < len; ++i) { + this._applyPlugins(schema.childSchemas[i]); + } +}; +Mongoose.prototype._applyPlugins.$hasSideEffects = true; + +/** + * Declares a global plugin executed on all Schemas. + * + * Equivalent to calling `.plugin(fn)` on each Schema you create. + * + * @param {Function} fn plugin callback + * @param {Object} [opts] optional options + * @return {Mongoose} this + * @see plugins ./plugins.html + * @api public + */ + +Mongoose.prototype.plugin = function(fn, opts) { + this.plugins.push([fn, opts]); + return this; +}; +Mongoose.prototype.plugin.$hasSideEffects = true; + +/** + * The default connection of the mongoose module. + * + * ####Example: + * + * var mongoose = require('mongoose'); + * mongoose.connect(...); + * mongoose.connection.on('error', cb); + * + * This is the connection used by default for every model created using [mongoose.model](#index_Mongoose-model). + * + * @property connection + * @return {Connection} + * @api public + */ + +Mongoose.prototype.__defineGetter__('connection', function() { + return this.connections[0]; +}); + +Mongoose.prototype.__defineSetter__('connection', function(v) { + this.connections[0] = v; +}); + +/*! + * Driver depentend APIs + */ + +var driver = global.MONGOOSE_DRIVER_PATH || './drivers/node-mongodb-native'; + +/*! + * Connection + */ + +var Connection = require(driver + '/connection'); + +/*! + * Collection + */ + +var Collection = require(driver + '/collection'); + +/** + * The Mongoose Aggregate constructor + * + * @method Aggregate + * @api public + */ + +Mongoose.prototype.Aggregate = Aggregate; + +/** + * The Mongoose Collection constructor + * + * @method Collection + * @api public + */ + +Mongoose.prototype.Collection = Collection; + +/** + * The Mongoose [Connection](#connection_Connection) constructor + * + * @method Connection + * @api public + */ + +Mongoose.prototype.Connection = Connection; + +/** + * The Mongoose version + * + * @property version + * @api public + */ + +Mongoose.prototype.version = pkg.version; + +/** + * The Mongoose constructor + * + * The exports of the mongoose module is an instance of this class. + * + * ####Example: + * + * var mongoose = require('mongoose'); + * var mongoose2 = new mongoose.Mongoose(); + * + * @method Mongoose + * @api public + */ + +Mongoose.prototype.Mongoose = Mongoose; + +/** + * The Mongoose [Schema](#schema_Schema) constructor + * + * ####Example: + * + * var mongoose = require('mongoose'); + * var Schema = mongoose.Schema; + * var CatSchema = new Schema(..); + * + * @method Schema + * @api public + */ + +Mongoose.prototype.Schema = Schema; + +/** + * The Mongoose [SchemaType](#schematype_SchemaType) constructor + * + * @method SchemaType + * @api public + */ + +Mongoose.prototype.SchemaType = SchemaType; + +/** + * The various Mongoose SchemaTypes. + * + * ####Note: + * + * _Alias of mongoose.Schema.Types for backwards compatibility._ + * + * @property SchemaTypes + * @see Schema.SchemaTypes #schema_Schema.Types + * @api public + */ + +Mongoose.prototype.SchemaTypes = Schema.Types; + +/** + * The Mongoose [VirtualType](#virtualtype_VirtualType) constructor + * + * @method VirtualType + * @api public + */ + +Mongoose.prototype.VirtualType = VirtualType; + +/** + * The various Mongoose Types. + * + * ####Example: + * + * var mongoose = require('mongoose'); + * var array = mongoose.Types.Array; + * + * ####Types: + * + * - [ObjectId](#types-objectid-js) + * - [Buffer](#types-buffer-js) + * - [SubDocument](#types-embedded-js) + * - [Array](#types-array-js) + * - [DocumentArray](#types-documentarray-js) + * + * Using this exposed access to the `ObjectId` type, we can construct ids on demand. + * + * var ObjectId = mongoose.Types.ObjectId; + * var id1 = new ObjectId; + * + * @property Types + * @api public + */ + +Mongoose.prototype.Types = Types; + +/** + * The Mongoose [Query](#query_Query) constructor. + * + * @method Query + * @api public + */ + +Mongoose.prototype.Query = Query; + +/** + * The Mongoose [Promise](#promise_Promise) constructor. + * + * @method Promise + * @api public + */ + +Object.defineProperty(Mongoose.prototype, 'Promise', { + get: function() { + return PromiseProvider.get(); + }, + set: function(lib) { + PromiseProvider.set(lib); + } +}); + +/** + * Storage layer for mongoose promises + * + * @method PromiseProvider + * @api public + */ + +Mongoose.prototype.PromiseProvider = PromiseProvider; + +/** + * The Mongoose [Model](#model_Model) constructor. + * + * @method Model + * @api public + */ + +Mongoose.prototype.Model = Model; + +/** + * The Mongoose [Document](#document-js) constructor. + * + * @method Document + * @api public + */ + +Mongoose.prototype.Document = Document; + +/** + * The Mongoose DocumentProvider constructor. + * + * @method DocumentProvider + * @api public + */ + +Mongoose.prototype.DocumentProvider = require('./document_provider'); + +/** + * The [MongooseError](#error_MongooseError) constructor. + * + * @method Error + * @api public + */ + +Mongoose.prototype.Error = require('./error'); + +/** + * The Mongoose CastError constructor + * + * @method CastError + * @param {String} type The name of the type + * @param {Any} value The value that failed to cast + * @param {String} path The path `a.b.c` in the doc where this cast error occurred + * @param {Error} [reason] The original error that was thrown + * @api public + */ + +Mongoose.prototype.CastError = require('./error/cast'); + +/** + * The [node-mongodb-native](https://github.com/mongodb/node-mongodb-native) driver Mongoose uses. + * + * @property mongo + * @api public + */ + +Mongoose.prototype.mongo = require('mongodb'); + +/** + * The [mquery](https://github.com/aheckmann/mquery) query builder Mongoose uses. + * + * @property mquery + * @api public + */ + +Mongoose.prototype.mquery = require('mquery'); + +/** + * Wraps the given Mongoose instance into a thenable (pseudo-promise). This + * is so `connect()` and `disconnect()` can return a thenable while maintaining + * backwards compatibility. + * + * @api private + */ + +function MongooseThenable(mongoose, promise) { + var _this = this; + for (var key in mongoose) { + if (typeof mongoose[key] === 'function' && mongoose[key].$hasSideEffects) { + (function(key) { + _this[key] = function() { + return mongoose[key].apply(mongoose, arguments); + }; + })(key); + } else if (['connection', 'connections'].indexOf(key) !== -1) { + _this[key] = mongoose[key]; + } + } + this.$opPromise = promise; +} + +MongooseThenable.prototype = new Mongoose; + +/** + * Ability to use mongoose object as a pseudo-promise so `.connect().then()` + * and `.disconnect().then()` are viable. + * + * @param {Function} onFulfilled + * @param {Function} onRejected + * @return {Promise} + * @api private + */ + +MongooseThenable.prototype.then = function(onFulfilled, onRejected) { + var Promise = PromiseProvider.get(); + if (!this.$opPromise) { + return new Promise.ES6(function(resolve, reject) { + reject(new Error('Can only call `.then()` if connect() or disconnect() ' + + 'has been called')); + }).then(onFulfilled, onRejected); + } + this.$opPromise.$hasHandler = true; + return this.$opPromise.then(onFulfilled, onRejected); +}; + +/** + * Ability to use mongoose object as a pseudo-promise so `.connect().then()` + * and `.disconnect().then()` are viable. + * + * @param {Function} onFulfilled + * @param {Function} onRejected + * @return {Promise} + * @api private + */ + +MongooseThenable.prototype.catch = function(onRejected) { + return this.then(null, onRejected); +}; + +/*! + * The exports object is an instance of Mongoose. + * + * @api public + */ + +var mongoose = module.exports = exports = new Mongoose; diff --git a/node_modules/mongoose/lib/internal.js b/node_modules/mongoose/lib/internal.js new file mode 100644 index 0000000..edf3338 --- /dev/null +++ b/node_modules/mongoose/lib/internal.js @@ -0,0 +1,31 @@ +/*! + * Dependencies + */ + +var StateMachine = require('./statemachine'); +var ActiveRoster = StateMachine.ctor('require', 'modify', 'init', 'default', 'ignore'); + +module.exports = exports = InternalCache; + +function InternalCache() { + this.strictMode = undefined; + this.selected = undefined; + this.shardval = undefined; + this.saveError = undefined; + this.validationError = undefined; + this.adhocPaths = undefined; + this.removing = undefined; + this.inserting = undefined; + this.version = undefined; + this.getters = {}; + this._id = undefined; + this.populate = undefined; // what we want to populate in this doc + this.populated = undefined;// the _ids that have been populated + this.wasPopulated = false; // if this doc was the result of a population + this.scope = undefined; + this.activePaths = new ActiveRoster; + + // embedded docs + this.ownerDocument = undefined; + this.fullPath = undefined; +} diff --git a/node_modules/mongoose/lib/model.js b/node_modules/mongoose/lib/model.js new file mode 100644 index 0000000..e431578 --- /dev/null +++ b/node_modules/mongoose/lib/model.js @@ -0,0 +1,3354 @@ +/*! + * Module dependencies. + */ + +var Document = require('./document'); +var MongooseError = require('./error'); +var VersionError = MongooseError.VersionError; +var DivergentArrayError = MongooseError.DivergentArrayError; +var Query = require('./query'); +var Aggregate = require('./aggregate'); +var Schema = require('./schema'); +var utils = require('./utils'); +var hasOwnProperty = utils.object.hasOwnProperty; +var isMongooseObject = utils.isMongooseObject; +var EventEmitter = require('events').EventEmitter; +var util = require('util'); +var tick = utils.tick; + +var parallel = require('async/parallel'); +var PromiseProvider = require('./promise_provider'); + +var VERSION_WHERE = 1, + VERSION_INC = 2, + VERSION_ALL = VERSION_WHERE | VERSION_INC; + +/** + * Model constructor + * + * Provides the interface to MongoDB collections as well as creates document instances. + * + * @param {Object} doc values with which to create the document + * @inherits Document http://mongoosejs.com/docs/api.html#document-js + * @event `error`: If listening to this event, it is emitted when a document was saved without passing a callback and an `error` occurred. If not listening, the event bubbles to the connection used to create this Model. + * @event `index`: Emitted after `Model#ensureIndexes` completes. If an error occurred it is passed with the event. + * @event `index-single-start`: Emitted when an individual index starts within `Model#ensureIndexes`. The fields and options being used to build the index are also passed with the event. + * @event `index-single-done`: Emitted when an individual index finishes within `Model#ensureIndexes`. If an error occurred it is passed with the event. The fields, options, and index name are also passed. + * @api public + */ + +function Model(doc, fields, skipId) { + Document.call(this, doc, fields, skipId); +} + +/*! + * Inherits from Document. + * + * All Model.prototype features are available on + * top level (non-sub) documents. + */ + +Model.prototype.__proto__ = Document.prototype; + +/** + * Connection the model uses. + * + * @api public + * @property db + */ + +Model.prototype.db; + +/** + * Collection the model uses. + * + * @api public + * @property collection + */ + +Model.prototype.collection; + +/** + * The name of the model + * + * @api public + * @property modelName + */ + +Model.prototype.modelName; + +/** + * If this is a discriminator model, `baseModelName` is the name of + * the base model. + * + * @api public + * @property baseModelName + */ + +Model.prototype.baseModelName; + +Model.prototype.$__handleSave = function(options, callback) { + var _this = this; + if (!options.safe && this.schema.options.safe) { + options.safe = this.schema.options.safe; + } + if (typeof options.safe === 'boolean') { + options.safe = null; + } + + if (this.isNew) { + // send entire doc + var toObjectOptions = {}; + if (this.schema.options.toObject && + this.schema.options.toObject.retainKeyOrder) { + toObjectOptions.retainKeyOrder = true; + } + + toObjectOptions.depopulate = 1; + toObjectOptions._skipDepopulateTopLevel = true; + toObjectOptions.transform = false; + + var obj = this.toObject(toObjectOptions); + + if (!utils.object.hasOwnProperty(obj || {}, '_id')) { + // documents must have an _id else mongoose won't know + // what to update later if more changes are made. the user + // wouldn't know what _id was generated by mongodb either + // nor would the ObjectId generated my mongodb necessarily + // match the schema definition. + setTimeout(function() { + callback(new Error('document must have an _id before saving')); + }, 0); + return; + } + + this.$__version(true, obj); + this.collection.insert(obj, options.safe, function(err, ret) { + if (err) { + _this.isNew = true; + _this.emit('isNew', true); + + callback(err); + return; + } + + callback(null, ret); + }); + this.$__reset(); + this.isNew = false; + this.emit('isNew', false); + // Make it possible to retry the insert + this.$__.inserting = true; + } else { + // Make sure we don't treat it as a new object on error, + // since it already exists + this.$__.inserting = false; + + var delta = this.$__delta(); + + if (delta) { + if (delta instanceof Error) { + callback(delta); + return; + } + var where = this.$__where(delta[0]); + + if (where instanceof Error) { + callback(where); + return; + } + + this.collection.update(where, delta[1], options.safe, function(err, ret) { + if (err) { + callback(err); + return; + } + callback(null, ret); + }); + } else { + this.$__reset(); + callback(); + return; + } + + this.emit('isNew', false); + } +}; + +/*! + * ignore + */ + +Model.prototype.$__save = function(options, callback) { + var _this = this; + + _this.$__handleSave(options, function(error, result) { + if (error) { + return _this.schema.s.hooks.execPost('save:error', _this, [_this], { error: error }, function(error) { + callback(error); + }); + } + + _this.$__reset(); + _this.$__storeShard(); + + var numAffected = 0; + if (result) { + if (Array.isArray(result)) { + numAffected = result.length; + } else if (result.result && result.result.n !== undefined) { + numAffected = result.result.n; + } else if (result.result && result.result.nModified !== undefined) { + numAffected = result.result.nModified; + } else { + numAffected = result; + } + } + + // was this an update that required a version bump? + if (_this.$__.version && !_this.$__.inserting) { + var doIncrement = VERSION_INC === (VERSION_INC & _this.$__.version); + _this.$__.version = undefined; + + if (numAffected <= 0) { + // the update failed. pass an error back + var err = new VersionError(_this); + return callback(err); + } + + // increment version if was successful + if (doIncrement) { + var key = _this.schema.options.versionKey; + var version = _this.getValue(key) | 0; + _this.setValue(key, version + 1); + } + } + + _this.emit('save', _this, numAffected); + callback(null, _this, numAffected); + }); +}; + +/** + * Saves this document. + * + * ####Example: + * + * product.sold = Date.now(); + * product.save(function (err, product, numAffected) { + * if (err) .. + * }) + * + * The callback will receive three parameters + * + * 1. `err` if an error occurred + * 2. `product` which is the saved `product` + * 3. `numAffected` will be 1 when the document was successfully persisted to MongoDB, otherwise 0. Unless you tweak mongoose's internals, you don't need to worry about checking this parameter for errors - checking `err` is sufficient to make sure your document was properly saved. + * + * As an extra measure of flow control, save will return a Promise. + * ####Example: + * product.save().then(function(product) { + * ... + * }); + * + * For legacy reasons, mongoose stores object keys in reverse order on initial + * save. That is, `{ a: 1, b: 2 }` will be saved as `{ b: 2, a: 1 }` in + * MongoDB. To override this behavior, set + * [the `toObject.retainKeyOrder` option](http://mongoosejs.com/docs/api.html#document_Document-toObject) + * to true on your schema. + * + * @param {Object} [options] options optional options + * @param {Object} [options.safe] overrides [schema's safe option](http://mongoosejs.com//docs/guide.html#safe) + * @param {Boolean} [options.validateBeforeSave] set to false to save without validating. + * @param {Function} [fn] optional callback + * @return {Promise} Promise + * @api public + * @see middleware http://mongoosejs.com/docs/middleware.html + */ + +Model.prototype.save = function(options, fn) { + if (typeof options === 'function') { + fn = options; + options = undefined; + } + + if (!options) { + options = {}; + } + + if (fn) { + fn = this.constructor.$wrapCallback(fn); + } + + return this.$__save(options, fn); +}; + +/*! + * Determines whether versioning should be skipped for the given path + * + * @param {Document} self + * @param {String} path + * @return {Boolean} true if versioning should be skipped for the given path + */ +function shouldSkipVersioning(self, path) { + var skipVersioning = self.schema.options.skipVersioning; + if (!skipVersioning) return false; + + // Remove any array indexes from the path + path = path.replace(/\.\d+\./, '.'); + + return skipVersioning[path]; +} + +/*! + * Apply the operation to the delta (update) clause as + * well as track versioning for our where clause. + * + * @param {Document} self + * @param {Object} where + * @param {Object} delta + * @param {Object} data + * @param {Mixed} val + * @param {String} [operation] + */ + +function operand(self, where, delta, data, val, op) { + // delta + op || (op = '$set'); + if (!delta[op]) delta[op] = {}; + delta[op][data.path] = val; + + // disabled versioning? + if (self.schema.options.versionKey === false) return; + + // path excluded from versioning? + if (shouldSkipVersioning(self, data.path)) return; + + // already marked for versioning? + if (VERSION_ALL === (VERSION_ALL & self.$__.version)) return; + + switch (op) { + case '$set': + case '$unset': + case '$pop': + case '$pull': + case '$pullAll': + case '$push': + case '$pushAll': + case '$addToSet': + break; + default: + // nothing to do + return; + } + + // ensure updates sent with positional notation are + // editing the correct array element. + // only increment the version if an array position changes. + // modifying elements of an array is ok if position does not change. + + if (op === '$push' || op === '$pushAll' || op === '$addToSet') { + self.$__.version = VERSION_INC; + } else if (/^\$p/.test(op)) { + // potentially changing array positions + self.increment(); + } else if (Array.isArray(val)) { + // $set an array + self.increment(); + } else if (/\.\d+\.|\.\d+$/.test(data.path)) { + // now handling $set, $unset + // subpath of array + self.$__.version = VERSION_WHERE; + } +} + +/*! + * Compiles an update and where clause for a `val` with _atomics. + * + * @param {Document} self + * @param {Object} where + * @param {Object} delta + * @param {Object} data + * @param {Array} value + */ + +function handleAtomics(self, where, delta, data, value) { + if (delta.$set && delta.$set[data.path]) { + // $set has precedence over other atomics + return; + } + + if (typeof value.$__getAtomics === 'function') { + value.$__getAtomics().forEach(function(atomic) { + var op = atomic[0]; + var val = atomic[1]; + operand(self, where, delta, data, val, op); + }); + return; + } + + // legacy support for plugins + + var atomics = value._atomics, + ops = Object.keys(atomics), + i = ops.length, + val, + op; + + if (i === 0) { + // $set + + if (isMongooseObject(value)) { + value = value.toObject({depopulate: 1}); + } else if (value.valueOf) { + value = value.valueOf(); + } + + return operand(self, where, delta, data, value); + } + + function iter(mem) { + return isMongooseObject(mem) + ? mem.toObject({depopulate: 1}) + : mem; + } + + while (i--) { + op = ops[i]; + val = atomics[op]; + + if (isMongooseObject(val)) { + val = val.toObject({depopulate: 1}); + } else if (Array.isArray(val)) { + val = val.map(iter); + } else if (val.valueOf) { + val = val.valueOf(); + } + + if (op === '$addToSet') { + val = {$each: val}; + } + + operand(self, where, delta, data, val, op); + } +} + +/** + * Produces a special query document of the modified properties used in updates. + * + * @api private + * @method $__delta + * @memberOf Model + */ + +Model.prototype.$__delta = function() { + var dirty = this.$__dirty(); + if (!dirty.length && VERSION_ALL !== this.$__.version) return; + + var where = {}, + delta = {}, + len = dirty.length, + divergent = [], + d = 0; + + where._id = this._doc._id; + + for (; d < len; ++d) { + var data = dirty[d]; + var value = data.value; + + var match = checkDivergentArray(this, data.path, value); + if (match) { + divergent.push(match); + continue; + } + + var pop = this.populated(data.path, true); + if (!pop && this.$__.selected) { + // If any array was selected using an $elemMatch projection, we alter the path and where clause + // NOTE: MongoDB only supports projected $elemMatch on top level array. + var pathSplit = data.path.split('.'); + var top = pathSplit[0]; + if (this.$__.selected[top] && this.$__.selected[top].$elemMatch) { + // If the selected array entry was modified + if (pathSplit.length > 1 && pathSplit[1] == 0 && typeof where[top] === 'undefined') { + where[top] = this.$__.selected[top]; + pathSplit[1] = '$'; + data.path = pathSplit.join('.'); + } + // if the selected array was modified in any other way throw an error + else { + divergent.push(data.path); + continue; + } + } + } + + if (divergent.length) continue; + + if (undefined === value) { + operand(this, where, delta, data, 1, '$unset'); + } else if (value === null) { + operand(this, where, delta, data, null); + } else if (value._path && value._atomics) { + // arrays and other custom types (support plugins etc) + handleAtomics(this, where, delta, data, value); + } else if (value._path && Buffer.isBuffer(value)) { + // MongooseBuffer + value = value.toObject(); + operand(this, where, delta, data, value); + } else { + value = utils.clone(value, {depopulate: 1}); + operand(this, where, delta, data, value); + } + } + + if (divergent.length) { + return new DivergentArrayError(divergent); + } + + if (this.$__.version) { + this.$__version(where, delta); + } + + return [where, delta]; +}; + +/*! + * Determine if array was populated with some form of filter and is now + * being updated in a manner which could overwrite data unintentionally. + * + * @see https://github.com/Automattic/mongoose/issues/1334 + * @param {Document} doc + * @param {String} path + * @return {String|undefined} + */ + +function checkDivergentArray(doc, path, array) { + // see if we populated this path + var pop = doc.populated(path, true); + + if (!pop && doc.$__.selected) { + // If any array was selected using an $elemMatch projection, we deny the update. + // NOTE: MongoDB only supports projected $elemMatch on top level array. + var top = path.split('.')[0]; + if (doc.$__.selected[top + '.$']) { + return top; + } + } + + if (!(pop && array && array.isMongooseArray)) return; + + // If the array was populated using options that prevented all + // documents from being returned (match, skip, limit) or they + // deselected the _id field, $pop and $set of the array are + // not safe operations. If _id was deselected, we do not know + // how to remove elements. $pop will pop off the _id from the end + // of the array in the db which is not guaranteed to be the + // same as the last element we have here. $set of the entire array + // would be similarily destructive as we never received all + // elements of the array and potentially would overwrite data. + var check = pop.options.match || + pop.options.options && hasOwnProperty(pop.options.options, 'limit') || // 0 is not permitted + pop.options.options && pop.options.options.skip || // 0 is permitted + pop.options.select && // deselected _id? + (pop.options.select._id === 0 || + /\s?-_id\s?/.test(pop.options.select)); + + if (check) { + var atomics = array._atomics; + if (Object.keys(atomics).length === 0 || atomics.$set || atomics.$pop) { + return path; + } + } +} + +/** + * Appends versioning to the where and update clauses. + * + * @api private + * @method $__version + * @memberOf Model + */ + +Model.prototype.$__version = function(where, delta) { + var key = this.schema.options.versionKey; + + if (where === true) { + // this is an insert + if (key) this.setValue(key, delta[key] = 0); + return; + } + + // updates + + // only apply versioning if our versionKey was selected. else + // there is no way to select the correct version. we could fail + // fast here and force them to include the versionKey but + // thats a bit intrusive. can we do this automatically? + if (!this.isSelected(key)) { + return; + } + + // $push $addToSet don't need the where clause set + if (VERSION_WHERE === (VERSION_WHERE & this.$__.version)) { + where[key] = this.getValue(key); + } + + if (VERSION_INC === (VERSION_INC & this.$__.version)) { + if (!delta.$set || typeof delta.$set[key] === 'undefined') { + delta.$inc || (delta.$inc = {}); + delta.$inc[key] = 1; + } + } +}; + +/** + * Signal that we desire an increment of this documents version. + * + * ####Example: + * + * Model.findById(id, function (err, doc) { + * doc.increment(); + * doc.save(function (err) { .. }) + * }) + * + * @see versionKeys http://mongoosejs.com/docs/guide.html#versionKey + * @api public + */ + +Model.prototype.increment = function increment() { + this.$__.version = VERSION_ALL; + return this; +}; + +/** + * Returns a query object which applies shardkeys if they exist. + * + * @api private + * @method $__where + * @memberOf Model + */ + +Model.prototype.$__where = function _where(where) { + where || (where = {}); + + var paths, + len; + + if (!where._id) { + where._id = this._doc._id; + } + + if (this.$__.shardval) { + paths = Object.keys(this.$__.shardval); + len = paths.length; + + for (var i = 0; i < len; ++i) { + where[paths[i]] = this.$__.shardval[paths[i]]; + } + } + + if (this._doc._id == null) { + return new Error('No _id found on document!'); + } + + return where; +}; + +/** + * Removes this document from the db. + * + * ####Example: + * product.remove(function (err, product) { + * if (err) return handleError(err); + * Product.findById(product._id, function (err, product) { + * console.log(product) // null + * }) + * }) + * + * + * As an extra measure of flow control, remove will return a Promise (bound to `fn` if passed) so it could be chained, or hooked to recive errors + * + * ####Example: + * product.remove().then(function (product) { + * ... + * }).onRejected(function (err) { + * assert.ok(err) + * }) + * + * @param {function(err,product)} [fn] optional callback + * @return {Promise} Promise + * @api public + */ + +Model.prototype.remove = function remove(options, fn) { + if (typeof options === 'function') { + fn = options; + options = undefined; + } + + if (!options) { + options = {}; + } + + if (this.$__.removing) { + if (fn) { + this.$__.removing.then( + function(res) { fn(null, res); }, + function(err) { fn(err); }); + } + return this; + } + + var _this = this; + var Promise = PromiseProvider.get(); + + if (fn) { + fn = this.constructor.$wrapCallback(fn); + } + + this.$__.removing = new Promise.ES6(function(resolve, reject) { + var where = _this.$__where(); + if (where instanceof Error) { + reject(where); + fn && fn(where); + return; + } + + if (!options.safe && _this.schema.options.safe) { + options.safe = _this.schema.options.safe; + } + + _this.collection.remove(where, options, function(err) { + if (!err) { + _this.emit('remove', _this); + resolve(_this); + fn && fn(null, _this); + return; + } + reject(err); + fn && fn(err); + }); + }); + return this.$__.removing; +}; + +/** + * Returns another Model instance. + * + * ####Example: + * + * var doc = new Tank; + * doc.model('User').findById(id, callback); + * + * @param {String} name model name + * @api public + */ + +Model.prototype.model = function model(name) { + return this.db.model(name); +}; + +/** + * Adds a discriminator type. + * + * ####Example: + * + * function BaseSchema() { + * Schema.apply(this, arguments); + * + * this.add({ + * name: String, + * createdAt: Date + * }); + * } + * util.inherits(BaseSchema, Schema); + * + * var PersonSchema = new BaseSchema(); + * var BossSchema = new BaseSchema({ department: String }); + * + * var Person = mongoose.model('Person', PersonSchema); + * var Boss = Person.discriminator('Boss', BossSchema); + * + * @param {String} name discriminator model name + * @param {Schema} schema discriminator model schema + * @api public + */ + +Model.discriminator = function discriminator(name, schema) { + var CUSTOMIZABLE_DISCRIMINATOR_OPTIONS = { + toJSON: true, + toObject: true, + _id: true, + id: true + }; + + if (!(schema && schema.instanceOfSchema)) { + throw new Error('You must pass a valid discriminator Schema'); + } + + if (this.schema.discriminatorMapping && !this.schema.discriminatorMapping.isRoot) { + throw new Error('Discriminator "' + name + + '" can only be a discriminator of the root model'); + } + + var key = this.schema.options.discriminatorKey; + if (schema.path(key)) { + throw new Error('Discriminator "' + name + + '" cannot have field with name "' + key + '"'); + } + + function merge(schema, baseSchema) { + utils.merge(schema, baseSchema); + + var obj = {}; + obj[key] = { + default: name, + set: function(newName) { + if (newName === name) { + return name; + } + throw new Error('Can\'t set discriminator key "' + key + '"'); + } + }; + obj[key][schema.options.typeKey] = String; + schema.add(obj); + schema.discriminatorMapping = {key: key, value: name, isRoot: false}; + + if (baseSchema.options.collection) { + schema.options.collection = baseSchema.options.collection; + } + + var toJSON = schema.options.toJSON; + var toObject = schema.options.toObject; + var _id = schema.options._id; + var id = schema.options.id; + + var keys = Object.keys(schema.options); + + for (var i = 0; i < keys.length; ++i) { + var _key = keys[i]; + if (!CUSTOMIZABLE_DISCRIMINATOR_OPTIONS[_key]) { + if (!utils.deepEqual(schema.options[_key], baseSchema.options[_key])) { + throw new Error('Can\'t customize discriminator option ' + _key + + ' (can only modify ' + + Object.keys(CUSTOMIZABLE_DISCRIMINATOR_OPTIONS).join(', ') + + ')'); + } + } + } + + schema.options = utils.clone(baseSchema.options); + if (toJSON) schema.options.toJSON = toJSON; + if (toObject) schema.options.toObject = toObject; + if (typeof _id !== 'undefined') { + schema.options._id = _id; + } + schema.options.id = id; + + schema.callQueue = baseSchema.callQueue.concat(schema.callQueue.slice(schema._defaultMiddleware.length)); + schema._requiredpaths = undefined; // reset just in case Schema#requiredPaths() was called on either schema + } + + // merges base schema into new discriminator schema and sets new type field. + merge(schema, this.schema); + + if (!this.discriminators) { + this.discriminators = {}; + } + + if (!this.schema.discriminatorMapping) { + this.schema.discriminatorMapping = {key: key, value: null, isRoot: true}; + } + + if (this.discriminators[name]) { + throw new Error('Discriminator with name "' + name + '" already exists'); + } + if (this.db.models[name]) { + throw new MongooseError.OverwriteModelError(name); + } + + this.discriminators[name] = this.db.model(name, schema, this.collection.name); + this.discriminators[name].prototype.__proto__ = this.prototype; + Object.defineProperty(this.discriminators[name], 'baseModelName', { + value: this.modelName, + configurable: true, + writable: false + }); + + // apply methods and statics + applyMethods(this.discriminators[name], schema); + applyStatics(this.discriminators[name], schema); + + return this.discriminators[name]; +}; + +// Model (class) features + +/*! + * Give the constructor the ability to emit events. + */ + +for (var i in EventEmitter.prototype) { + Model[i] = EventEmitter.prototype[i]; +} + +/** + * Called when the model compiles. + * + * @api private + */ + +Model.init = function init() { + if ((this.schema.options.autoIndex) || + (this.schema.options.autoIndex === null && this.db.config.autoIndex)) { + this.ensureIndexes({ __noPromise: true }); + } + + this.schema.emit('init', this); +}; + +/** + * Sends `ensureIndex` commands to mongo for each index declared in the schema. + * + * ####Example: + * + * Event.ensureIndexes(function (err) { + * if (err) return handleError(err); + * }); + * + * After completion, an `index` event is emitted on this `Model` passing an error if one occurred. + * + * ####Example: + * + * var eventSchema = new Schema({ thing: { type: 'string', unique: true }}) + * var Event = mongoose.model('Event', eventSchema); + * + * Event.on('index', function (err) { + * if (err) console.error(err); // error occurred during index creation + * }) + * + * _NOTE: It is not recommended that you run this in production. Index creation may impact database performance depending on your load. Use with caution._ + * + * The `ensureIndex` commands are not sent in parallel. This is to avoid the `MongoError: cannot add index with a background operation in progress` error. See [this ticket](https://github.com/Automattic/mongoose/issues/1365) for more information. + * + * @param {Object} [options] internal options + * @param {Function} [cb] optional callback + * @return {Promise} + * @api public + */ + +Model.ensureIndexes = function ensureIndexes(options, callback) { + if (typeof options === 'function') { + callback = options; + options = null; + } + + if (options && options.__noPromise) { + _ensureIndexes(this, callback); + return; + } + + if (callback) { + callback = this.$wrapCallback(callback); + } + + var _this = this; + var Promise = PromiseProvider.get(); + return new Promise.ES6(function(resolve, reject) { + _ensureIndexes(_this, function(error) { + if (error) { + callback && callback(error); + reject(error); + } + callback && callback(); + resolve(); + }); + }); +}; + +function _ensureIndexes(model, callback) { + var indexes = model.schema.indexes(); + if (!indexes.length) { + setImmediate(function() { + callback && callback(); + }); + return; + } + // Indexes are created one-by-one to support how MongoDB < 2.4 deals + // with background indexes. + + var done = function(err) { + if (err && model.schema.options.emitIndexErrors) { + model.emit('error', err); + } + model.emit('index', err); + callback && callback(err); + }; + + var indexSingleDone = function(err, fields, options, name) { + model.emit('index-single-done', err, fields, options, name); + }; + var indexSingleStart = function(fields, options) { + model.emit('index-single-start', fields, options); + }; + + var create = function() { + var index = indexes.shift(); + if (!index) return done(); + + var indexFields = index[0]; + var options = index[1]; + _handleSafe(options); + + indexSingleStart(indexFields, options); + + model.collection.ensureIndex(indexFields, options, tick(function(err, name) { + indexSingleDone(err, indexFields, options, name); + if (err) { + return done(err); + } + create(); + })); + }; + + setImmediate(function() { + create(); + }); +} + +function _handleSafe(options) { + if (options.safe) { + if (typeof options.safe === 'boolean') { + options.w = options.safe; + delete options.safe; + } + if (typeof options.safe === 'object') { + options.w = options.safe.w; + options.j = options.safe.j; + options.wtimeout = options.safe.wtimeout; + delete options.safe; + } + } +} + +/** + * Schema the model uses. + * + * @property schema + * @receiver Model + * @api public + */ + +Model.schema; + +/*! + * Connection instance the model uses. + * + * @property db + * @receiver Model + * @api public + */ + +Model.db; + +/*! + * Collection the model uses. + * + * @property collection + * @receiver Model + * @api public + */ + +Model.collection; + +/** + * Base Mongoose instance the model uses. + * + * @property base + * @receiver Model + * @api public + */ + +Model.base; + +/** + * Registered discriminators for this model. + * + * @property discriminators + * @receiver Model + * @api public + */ + +Model.discriminators; + +/** + * Removes documents from the collection. + * + * ####Example: + * + * Comment.remove({ title: 'baby born from alien father' }, function (err) { + * + * }); + * + * ####Note: + * + * To remove documents without waiting for a response from MongoDB, do not pass a `callback`, then call `exec` on the returned [Query](#query-js): + * + * var query = Comment.remove({ _id: id }); + * query.exec(); + * + * ####Note: + * + * This method sends a remove command directly to MongoDB, no Mongoose documents are involved. Because no Mongoose documents are involved, _no middleware (hooks) are executed_. + * + * @param {Object} conditions + * @param {Function} [callback] + * @return {Query} + * @api public + */ + +Model.remove = function remove(conditions, callback) { + if (typeof conditions === 'function') { + callback = conditions; + conditions = {}; + } + + // get the mongodb collection object + var mq = new this.Query(conditions, {}, this, this.collection); + + if (callback) { + callback = this.$wrapCallback(callback); + } + + return mq.remove(callback); +}; + +/** + * Finds documents + * + * The `conditions` are cast to their respective SchemaTypes before the command is sent. + * + * ####Examples: + * + * // named john and at least 18 + * MyModel.find({ name: 'john', age: { $gte: 18 }}); + * + * // executes immediately, passing results to callback + * MyModel.find({ name: 'john', age: { $gte: 18 }}, function (err, docs) {}); + * + * // name LIKE john and only selecting the "name" and "friends" fields, executing immediately + * MyModel.find({ name: /john/i }, 'name friends', function (err, docs) { }) + * + * // passing options + * MyModel.find({ name: /john/i }, null, { skip: 10 }) + * + * // passing options and executing immediately + * MyModel.find({ name: /john/i }, null, { skip: 10 }, function (err, docs) {}); + * + * // executing a query explicitly + * var query = MyModel.find({ name: /john/i }, null, { skip: 10 }) + * query.exec(function (err, docs) {}); + * + * // using the promise returned from executing a query + * var query = MyModel.find({ name: /john/i }, null, { skip: 10 }); + * var promise = query.exec(); + * promise.addBack(function (err, docs) {}); + * + * @param {Object} conditions + * @param {Object} [projection] optional fields to return (http://bit.ly/1HotzBo) + * @param {Object} [options] optional + * @param {Function} [callback] + * @return {Query} + * @see field selection #query_Query-select + * @see promise #promise-js + * @api public + */ + +Model.find = function find(conditions, projection, options, callback) { + if (typeof conditions === 'function') { + callback = conditions; + conditions = {}; + projection = null; + options = null; + } else if (typeof projection === 'function') { + callback = projection; + projection = null; + options = null; + } else if (typeof options === 'function') { + callback = options; + options = null; + } + + var mq = new this.Query({}, {}, this, this.collection); + mq.select(projection); + mq.setOptions(options); + if (this.schema.discriminatorMapping && mq.selectedInclusively()) { + mq.select(this.schema.options.discriminatorKey); + } + + if (callback) { + callback = this.$wrapCallback(callback); + } + + return mq.find(conditions, callback); +}; + +/** + * Finds a single document by its _id field. `findById(id)` is almost* + * equivalent to `findOne({ _id: id })`. If you want to query by a document's + * `_id`, use `findById()` instead of `findOne()`. + * + * The `id` is cast based on the Schema before sending the command. + * + * Note: `findById()` triggers `findOne` hooks. + * + * * Except for how it treats `undefined`. If you use `findOne()`, you'll see + * that `findOne(undefined)` and `findOne({ _id: undefined })` are equivalent + * to `findOne({})` and return arbitrary documents. However, mongoose + * translates `findById(undefined)` into `findOne({ _id: null })`. + * + * ####Example: + * + * // find adventure by id and execute immediately + * Adventure.findById(id, function (err, adventure) {}); + * + * // same as above + * Adventure.findById(id).exec(callback); + * + * // select only the adventures name and length + * Adventure.findById(id, 'name length', function (err, adventure) {}); + * + * // same as above + * Adventure.findById(id, 'name length').exec(callback); + * + * // include all properties except for `length` + * Adventure.findById(id, '-length').exec(function (err, adventure) {}); + * + * // passing options (in this case return the raw js objects, not mongoose documents by passing `lean` + * Adventure.findById(id, 'name', { lean: true }, function (err, doc) {}); + * + * // same as above + * Adventure.findById(id, 'name').lean().exec(function (err, doc) {}); + * + * @param {Object|String|Number} id value of `_id` to query by + * @param {Object} [projection] optional fields to return (http://bit.ly/1HotzBo) + * @param {Object} [options] optional + * @param {Function} [callback] + * @return {Query} + * @see field selection #query_Query-select + * @see lean queries #query_Query-lean + * @api public + */ + +Model.findById = function findById(id, projection, options, callback) { + if (typeof id === 'undefined') { + id = null; + } + + if (callback) { + callback = this.$wrapCallback(callback); + } + + return this.findOne({_id: id}, projection, options, callback); +}; + +/** + * Finds one document. + * + * The `conditions` are cast to their respective SchemaTypes before the command is sent. + * + * *Note:* `conditions` is optional, and if `conditions` is null or undefined, + * mongoose will send an empty `findOne` command to MongoDB, which will return + * an arbitrary document. If you're querying by `_id`, use `findById()` instead. + * + * ####Example: + * + * // find one iphone adventures - iphone adventures?? + * Adventure.findOne({ type: 'iphone' }, function (err, adventure) {}); + * + * // same as above + * Adventure.findOne({ type: 'iphone' }).exec(function (err, adventure) {}); + * + * // select only the adventures name + * Adventure.findOne({ type: 'iphone' }, 'name', function (err, adventure) {}); + * + * // same as above + * Adventure.findOne({ type: 'iphone' }, 'name').exec(function (err, adventure) {}); + * + * // specify options, in this case lean + * Adventure.findOne({ type: 'iphone' }, 'name', { lean: true }, callback); + * + * // same as above + * Adventure.findOne({ type: 'iphone' }, 'name', { lean: true }).exec(callback); + * + * // chaining findOne queries (same as above) + * Adventure.findOne({ type: 'iphone' }).select('name').lean().exec(callback); + * + * @param {Object} [conditions] + * @param {Object} [projection] optional fields to return (http://bit.ly/1HotzBo) + * @param {Object} [options] optional + * @param {Function} [callback] + * @return {Query} + * @see field selection #query_Query-select + * @see lean queries #query_Query-lean + * @api public + */ + +Model.findOne = function findOne(conditions, projection, options, callback) { + if (typeof options === 'function') { + callback = options; + options = null; + } else if (typeof projection === 'function') { + callback = projection; + projection = null; + options = null; + } else if (typeof conditions === 'function') { + callback = conditions; + conditions = {}; + projection = null; + options = null; + } + + // get the mongodb collection object + var mq = new this.Query({}, {}, this, this.collection); + mq.select(projection); + mq.setOptions(options); + if (this.schema.discriminatorMapping && mq.selectedInclusively()) { + mq.select(this.schema.options.discriminatorKey); + } + + if (callback) { + callback = this.$wrapCallback(callback); + } + + return mq.findOne(conditions, callback); +}; + +/** + * Counts number of matching documents in a database collection. + * + * ####Example: + * + * Adventure.count({ type: 'jungle' }, function (err, count) { + * if (err) .. + * console.log('there are %d jungle adventures', count); + * }); + * + * @param {Object} conditions + * @param {Function} [callback] + * @return {Query} + * @api public + */ + +Model.count = function count(conditions, callback) { + if (typeof conditions === 'function') { + callback = conditions; + conditions = {}; + } + + // get the mongodb collection object + var mq = new this.Query({}, {}, this, this.collection); + + if (callback) { + callback = this.$wrapCallback(callback); + } + + return mq.count(conditions, callback); +}; + +/** + * Creates a Query for a `distinct` operation. + * + * Passing a `callback` immediately executes the query. + * + * ####Example + * + * Link.distinct('url', { clicks: {$gt: 100}}, function (err, result) { + * if (err) return handleError(err); + * + * assert(Array.isArray(result)); + * console.log('unique urls with more than 100 clicks', result); + * }) + * + * var query = Link.distinct('url'); + * query.exec(callback); + * + * @param {String} field + * @param {Object} [conditions] optional + * @param {Function} [callback] + * @return {Query} + * @api public + */ + +Model.distinct = function distinct(field, conditions, callback) { + // get the mongodb collection object + var mq = new this.Query({}, {}, this, this.collection); + + if (typeof conditions === 'function') { + callback = conditions; + conditions = {}; + } + if (callback) { + callback = this.$wrapCallback(callback); + } + + return mq.distinct(field, conditions, callback); +}; + +/** + * Creates a Query, applies the passed conditions, and returns the Query. + * + * For example, instead of writing: + * + * User.find({age: {$gte: 21, $lte: 65}}, callback); + * + * we can instead write: + * + * User.where('age').gte(21).lte(65).exec(callback); + * + * Since the Query class also supports `where` you can continue chaining + * + * User + * .where('age').gte(21).lte(65) + * .where('name', /^b/i) + * ... etc + * + * @param {String} path + * @param {Object} [val] optional value + * @return {Query} + * @api public + */ + +Model.where = function where(path, val) { + void val; // eslint + // get the mongodb collection object + var mq = new this.Query({}, {}, this, this.collection).find({}); + return mq.where.apply(mq, arguments); +}; + +/** + * Creates a `Query` and specifies a `$where` condition. + * + * Sometimes you need to query for things in mongodb using a JavaScript expression. You can do so via `find({ $where: javascript })`, or you can use the mongoose shortcut method $where via a Query chain or from your mongoose Model. + * + * Blog.$where('this.username.indexOf("val") !== -1').exec(function (err, docs) {}); + * + * @param {String|Function} argument is a javascript string or anonymous function + * @method $where + * @memberOf Model + * @return {Query} + * @see Query.$where #query_Query-%24where + * @api public + */ + +Model.$where = function $where() { + var mq = new this.Query({}, {}, this, this.collection).find({}); + return mq.$where.apply(mq, arguments); +}; + +/** + * Issues a mongodb findAndModify update command. + * + * Finds a matching document, updates it according to the `update` arg, passing any `options`, and returns the found document (if any) to the callback. The query executes immediately if `callback` is passed else a Query object is returned. + * + * ####Options: + * + * - `new`: bool - if true, return the modified document rather than the original. defaults to false (changed in 4.0) + * - `upsert`: bool - creates the object if it doesn't exist. defaults to false. + * - `fields`: {Object|String} - Field selection. Equivalent to `.select(fields).findOneAndUpdate()` + * - `maxTimeMS`: puts a time limit on the query - requires mongodb >= 2.6.0 + * - `sort`: if multiple docs are found by the conditions, sets the sort order to choose which doc to update + * - `runValidators`: if true, runs [update validators](/docs/validation.html#update-validators) on this command. Update validators validate the update operation against the model's schema. + * - `setDefaultsOnInsert`: if this and `upsert` are true, mongoose will apply the [defaults](http://mongoosejs.com/docs/defaults.html) specified in the model's schema if a new document is created. This option only works on MongoDB >= 2.4 because it relies on [MongoDB's `$setOnInsert` operator](https://docs.mongodb.org/v2.4/reference/operator/update/setOnInsert/). + * - `passRawResult`: if true, passes the [raw result from the MongoDB driver as the third callback parameter](http://mongodb.github.io/node-mongodb-native/2.0/api/Collection.html#findAndModify) + * + * + * ####Examples: + * + * A.findOneAndUpdate(conditions, update, options, callback) // executes + * A.findOneAndUpdate(conditions, update, options) // returns Query + * A.findOneAndUpdate(conditions, update, callback) // executes + * A.findOneAndUpdate(conditions, update) // returns Query + * A.findOneAndUpdate() // returns Query + * + * ####Note: + * + * All top level update keys which are not `atomic` operation names are treated as set operations: + * + * ####Example: + * + * var query = { name: 'borne' }; + * Model.findOneAndUpdate(query, { name: 'jason borne' }, options, callback) + * + * // is sent as + * Model.findOneAndUpdate(query, { $set: { name: 'jason borne' }}, options, callback) + * + * This helps prevent accidentally overwriting your document with `{ name: 'jason borne' }`. + * + * ####Note: + * + * Values are cast to their appropriate types when using the findAndModify helpers. + * However, the below are never executed. + * + * - defaults + * - setters + * + * `findAndModify` helpers support limited defaults and validation. You can + * enable these by setting the `setDefaultsOnInsert` and `runValidators` options, + * respectively. + * + * If you need full-fledged validation, use the traditional approach of first + * retrieving the document. + * + * Model.findById(id, function (err, doc) { + * if (err) .. + * doc.name = 'jason borne'; + * doc.save(callback); + * }); + * + * @param {Object} [conditions] + * @param {Object} [update] + * @param {Object} [options] + * @param {Function} [callback] + * @return {Query} + * @see mongodb http://www.mongodb.org/display/DOCS/findAndModify+Command + * @api public + */ + +Model.findOneAndUpdate = function(conditions, update, options, callback) { + if (typeof options === 'function') { + callback = options; + options = null; + } else if (arguments.length === 1) { + if (typeof conditions === 'function') { + var msg = 'Model.findOneAndUpdate(): First argument must not be a function.\n\n' + + ' ' + this.modelName + '.findOneAndUpdate(conditions, update, options, callback)\n' + + ' ' + this.modelName + '.findOneAndUpdate(conditions, update, options)\n' + + ' ' + this.modelName + '.findOneAndUpdate(conditions, update)\n' + + ' ' + this.modelName + '.findOneAndUpdate(update)\n' + + ' ' + this.modelName + '.findOneAndUpdate()\n'; + throw new TypeError(msg); + } + update = conditions; + conditions = undefined; + } + if (callback) { + callback = this.$wrapCallback(callback); + } + + var fields; + if (options && options.fields) { + fields = options.fields; + } + + update = utils.clone(update, {depopulate: 1}); + if (this.schema.options.versionKey && options && options.upsert) { + if (!update.$setOnInsert) { + update.$setOnInsert = {}; + } + update.$setOnInsert[this.schema.options.versionKey] = 0; + } + + var mq = new this.Query({}, {}, this, this.collection); + mq.select(fields); + + return mq.findOneAndUpdate(conditions, update, options, callback); +}; + +/** + * Issues a mongodb findAndModify update command by a document's _id field. + * `findByIdAndUpdate(id, ...)` is equivalent to `findOneAndUpdate({ _id: id }, ...)`. + * + * Finds a matching document, updates it according to the `update` arg, + * passing any `options`, and returns the found document (if any) to the + * callback. The query executes immediately if `callback` is passed else a + * Query object is returned. + * + * This function triggers `findOneAndUpdate` middleware. + * + * ####Options: + * + * - `new`: bool - true to return the modified document rather than the original. defaults to false + * - `upsert`: bool - creates the object if it doesn't exist. defaults to false. + * - `runValidators`: if true, runs [update validators](/docs/validation.html#update-validators) on this command. Update validators validate the update operation against the model's schema. + * - `setDefaultsOnInsert`: if this and `upsert` are true, mongoose will apply the [defaults](http://mongoosejs.com/docs/defaults.html) specified in the model's schema if a new document is created. This option only works on MongoDB >= 2.4 because it relies on [MongoDB's `$setOnInsert` operator](https://docs.mongodb.org/v2.4/reference/operator/update/setOnInsert/). + * - `sort`: if multiple docs are found by the conditions, sets the sort order to choose which doc to update + * - `select`: sets the document fields to return + * + * ####Examples: + * + * A.findByIdAndUpdate(id, update, options, callback) // executes + * A.findByIdAndUpdate(id, update, options) // returns Query + * A.findByIdAndUpdate(id, update, callback) // executes + * A.findByIdAndUpdate(id, update) // returns Query + * A.findByIdAndUpdate() // returns Query + * + * ####Note: + * + * All top level update keys which are not `atomic` operation names are treated as set operations: + * + * ####Example: + * + * Model.findByIdAndUpdate(id, { name: 'jason borne' }, options, callback) + * + * // is sent as + * Model.findByIdAndUpdate(id, { $set: { name: 'jason borne' }}, options, callback) + * + * This helps prevent accidentally overwriting your document with `{ name: 'jason borne' }`. + * + * ####Note: + * + * Values are cast to their appropriate types when using the findAndModify helpers. + * However, the below are never executed. + * + * - defaults + * - setters + * + * `findAndModify` helpers support limited defaults and validation. You can + * enable these by setting the `setDefaultsOnInsert` and `runValidators` options, + * respectively. + * + * If you need full-fledged validation, use the traditional approach of first + * retrieving the document. + * + * Model.findById(id, function (err, doc) { + * if (err) .. + * doc.name = 'jason borne'; + * doc.save(callback); + * }); + * + * @param {Object|Number|String} id value of `_id` to query by + * @param {Object} [update] + * @param {Object} [options] + * @param {Function} [callback] + * @return {Query} + * @see Model.findOneAndUpdate #model_Model.findOneAndUpdate + * @see mongodb http://www.mongodb.org/display/DOCS/findAndModify+Command + * @api public + */ + +Model.findByIdAndUpdate = function(id, update, options, callback) { + if (callback) { + callback = this.$wrapCallback(callback); + } + if (arguments.length === 1) { + if (typeof id === 'function') { + var msg = 'Model.findByIdAndUpdate(): First argument must not be a function.\n\n' + + ' ' + this.modelName + '.findByIdAndUpdate(id, callback)\n' + + ' ' + this.modelName + '.findByIdAndUpdate(id)\n' + + ' ' + this.modelName + '.findByIdAndUpdate()\n'; + throw new TypeError(msg); + } + return this.findOneAndUpdate({_id: id}, undefined); + } + + // if a model is passed in instead of an id + if (id instanceof Document) { + id = id._id; + } + + return this.findOneAndUpdate.call(this, {_id: id}, update, options, callback); +}; + +/** + * Issue a mongodb findAndModify remove command. + * + * Finds a matching document, removes it, passing the found document (if any) to the callback. + * + * Executes immediately if `callback` is passed else a Query object is returned. + * + * ####Options: + * + * - `sort`: if multiple docs are found by the conditions, sets the sort order to choose which doc to update + * - `maxTimeMS`: puts a time limit on the query - requires mongodb >= 2.6.0 + * - `select`: sets the document fields to return + * + * ####Examples: + * + * A.findOneAndRemove(conditions, options, callback) // executes + * A.findOneAndRemove(conditions, options) // return Query + * A.findOneAndRemove(conditions, callback) // executes + * A.findOneAndRemove(conditions) // returns Query + * A.findOneAndRemove() // returns Query + * + * Values are cast to their appropriate types when using the findAndModify helpers. + * However, the below are never executed. + * + * - defaults + * - setters + * + * `findAndModify` helpers support limited defaults and validation. You can + * enable these by setting the `setDefaultsOnInsert` and `runValidators` options, + * respectively. + * + * If you need full-fledged validation, use the traditional approach of first + * retrieving the document. + * + * Model.findById(id, function (err, doc) { + * if (err) .. + * doc.name = 'jason borne'; + * doc.save(callback); + * }); + * + * @param {Object} conditions + * @param {Object} [options] + * @param {Function} [callback] + * @return {Query} + * @see mongodb http://www.mongodb.org/display/DOCS/findAndModify+Command + * @api public + */ + +Model.findOneAndRemove = function(conditions, options, callback) { + if (arguments.length === 1 && typeof conditions === 'function') { + var msg = 'Model.findOneAndRemove(): First argument must not be a function.\n\n' + + ' ' + this.modelName + '.findOneAndRemove(conditions, callback)\n' + + ' ' + this.modelName + '.findOneAndRemove(conditions)\n' + + ' ' + this.modelName + '.findOneAndRemove()\n'; + throw new TypeError(msg); + } + + if (typeof options === 'function') { + callback = options; + options = undefined; + } + if (callback) { + callback = this.$wrapCallback(callback); + } + + var fields; + if (options) { + fields = options.select; + options.select = undefined; + } + + var mq = new this.Query({}, {}, this, this.collection); + mq.select(fields); + + return mq.findOneAndRemove(conditions, options, callback); +}; + +/** + * Issue a mongodb findAndModify remove command by a document's _id field. `findByIdAndRemove(id, ...)` is equivalent to `findOneAndRemove({ _id: id }, ...)`. + * + * Finds a matching document, removes it, passing the found document (if any) to the callback. + * + * Executes immediately if `callback` is passed, else a `Query` object is returned. + * + * ####Options: + * + * - `sort`: if multiple docs are found by the conditions, sets the sort order to choose which doc to update + * - `select`: sets the document fields to return + * + * ####Examples: + * + * A.findByIdAndRemove(id, options, callback) // executes + * A.findByIdAndRemove(id, options) // return Query + * A.findByIdAndRemove(id, callback) // executes + * A.findByIdAndRemove(id) // returns Query + * A.findByIdAndRemove() // returns Query + * + * @param {Object|Number|String} id value of `_id` to query by + * @param {Object} [options] + * @param {Function} [callback] + * @return {Query} + * @see Model.findOneAndRemove #model_Model.findOneAndRemove + * @see mongodb http://www.mongodb.org/display/DOCS/findAndModify+Command + */ + +Model.findByIdAndRemove = function(id, options, callback) { + if (arguments.length === 1 && typeof id === 'function') { + var msg = 'Model.findByIdAndRemove(): First argument must not be a function.\n\n' + + ' ' + this.modelName + '.findByIdAndRemove(id, callback)\n' + + ' ' + this.modelName + '.findByIdAndRemove(id)\n' + + ' ' + this.modelName + '.findByIdAndRemove()\n'; + throw new TypeError(msg); + } + if (callback) { + callback = this.$wrapCallback(callback); + } + + return this.findOneAndRemove({_id: id}, options, callback); +}; + +/** + * Shortcut for saving one or more documents to the database. + * `MyModel.create(docs)` does `new MyModel(doc).save()` for every doc in + * docs. + * + * Hooks Triggered: + * - `save()` + * + * ####Example: + * + * // pass individual docs + * Candy.create({ type: 'jelly bean' }, { type: 'snickers' }, function (err, jellybean, snickers) { + * if (err) // ... + * }); + * + * // pass an array + * var array = [{ type: 'jelly bean' }, { type: 'snickers' }]; + * Candy.create(array, function (err, candies) { + * if (err) // ... + * + * var jellybean = candies[0]; + * var snickers = candies[1]; + * // ... + * }); + * + * // callback is optional; use the returned promise if you like: + * var promise = Candy.create({ type: 'jawbreaker' }); + * promise.then(function (jawbreaker) { + * // ... + * }) + * + * @param {Array|Object|*} doc(s) + * @param {Function} [callback] callback + * @return {Promise} + * @api public + */ + +Model.create = function create(doc, callback) { + var args; + var cb; + + if (Array.isArray(doc)) { + args = doc; + cb = callback; + } else { + var last = arguments[arguments.length - 1]; + if (typeof last === 'function') { + cb = last; + args = utils.args(arguments, 0, arguments.length - 1); + } else { + args = utils.args(arguments); + } + } + + var Promise = PromiseProvider.get(); + var _this = this; + if (cb) { + cb = this.$wrapCallback(cb); + } + + var promise = new Promise.ES6(function(resolve, reject) { + if (args.length === 0) { + setImmediate(function() { + cb && cb(null); + resolve(null); + }); + return; + } + + var toExecute = []; + args.forEach(function(doc) { + toExecute.push(function(callback) { + var toSave = doc instanceof _this ? doc : new _this(doc); + var callbackWrapper = function(error, doc) { + if (error) { + return callback(error); + } + callback(null, doc); + }; + + // Hack to avoid getting a promise because of + // $__registerHooksFromSchema + if (toSave.$__original_save) { + toSave.$__original_save({ __noPromise: true }, callbackWrapper); + } else { + toSave.save({ __noPromise: true }, callbackWrapper); + } + }); + }); + + parallel(toExecute, function(error, savedDocs) { + if (error) { + if (cb) { + cb(error); + } else { + reject(error); + } + return; + } + + if (doc instanceof Array) { + resolve(savedDocs); + cb && cb.call(_this, null, savedDocs); + } else { + resolve.apply(promise, savedDocs); + if (cb) { + savedDocs.unshift(null); + cb.apply(_this, savedDocs); + } + } + }); + }); + + return promise; +}; + +/** + * Shortcut for validating an array of documents and inserting them into + * MongoDB if they're all valid. This function is faster than `.create()` + * because it only sends one operation to the server, rather than one for each + * document. + * + * This function does **not** trigger save middleware. + * + * ####Example: + * + * var arr = [{ name: 'Star Wars' }, { name: 'The Empire Strikes Back' }]; + * Movies.insertMany(arr, function(error, docs) {}); + * + * @param {Array|Object|*} doc(s) + * @param {Function} [callback] callback + * @return {Promise} + * @api public + */ + +Model.insertMany = function(arr, callback) { + var _this = this; + if (callback) { + callback = this.$wrapCallback(callback); + } + + var toExecute = []; + arr.forEach(function(doc) { + toExecute.push(function(callback) { + doc = new _this(doc); + doc.validate({ __noPromise: true }, function(error) { + if (error) { + return callback(error); + } + callback(null, doc); + }); + }); + }); + + parallel(toExecute, function(error, docs) { + if (error) { + callback && callback(error); + return; + } + var docObjects = docs.map(function(doc) { + if (doc.schema.options.versionKey) { + doc[doc.schema.options.versionKey] = 0; + } + if (doc.initializeTimestamps) { + return doc.initializeTimestamps().toObject({ transform: false }); + } + return doc.toObject({ transform: false }); + }); + _this.collection.insertMany(docObjects, function(error) { + if (error) { + callback && callback(error); + return; + } + for (var i = 0; i < docs.length; ++i) { + docs[i].isNew = false; + docs[i].emit('isNew', false); + } + callback && callback(null, docs); + }); + }); +}; + +/** + * Shortcut for creating a new Document from existing raw data, pre-saved in the DB. + * The document returned has no paths marked as modified initially. + * + * ####Example: + * + * // hydrate previous data into a Mongoose document + * var mongooseCandy = Candy.hydrate({ _id: '54108337212ffb6d459f854c', type: 'jelly bean' }); + * + * @param {Object} obj + * @return {Document} + * @api public + */ + +Model.hydrate = function(obj) { + var model = require('./queryhelpers').createModel(this, obj); + model.init(obj); + return model; +}; + +/** + * Updates documents in the database without returning them. + * + * ####Examples: + * + * MyModel.update({ age: { $gt: 18 } }, { oldEnough: true }, fn); + * MyModel.update({ name: 'Tobi' }, { ferret: true }, { multi: true }, function (err, raw) { + * if (err) return handleError(err); + * console.log('The raw response from Mongo was ', raw); + * }); + * + * ####Valid options: + * + * - `safe` (boolean) safe mode (defaults to value set in schema (true)) + * - `upsert` (boolean) whether to create the doc if it doesn't match (false) + * - `multi` (boolean) whether multiple documents should be updated (false) + * - `runValidators`: if true, runs [update validators](/docs/validation.html#update-validators) on this command. Update validators validate the update operation against the model's schema. + * - `setDefaultsOnInsert`: if this and `upsert` are true, mongoose will apply the [defaults](http://mongoosejs.com/docs/defaults.html) specified in the model's schema if a new document is created. This option only works on MongoDB >= 2.4 because it relies on [MongoDB's `$setOnInsert` operator](https://docs.mongodb.org/v2.4/reference/operator/update/setOnInsert/). + * - `strict` (boolean) overrides the `strict` option for this update + * - `overwrite` (boolean) disables update-only mode, allowing you to overwrite the doc (false) + * + * All `update` values are cast to their appropriate SchemaTypes before being sent. + * + * The `callback` function receives `(err, rawResponse)`. + * + * - `err` is the error if any occurred + * - `rawResponse` is the full response from Mongo + * + * ####Note: + * + * All top level keys which are not `atomic` operation names are treated as set operations: + * + * ####Example: + * + * var query = { name: 'borne' }; + * Model.update(query, { name: 'jason borne' }, options, callback) + * + * // is sent as + * Model.update(query, { $set: { name: 'jason borne' }}, options, callback) + * // if overwrite option is false. If overwrite is true, sent without the $set wrapper. + * + * This helps prevent accidentally overwriting all documents in your collection with `{ name: 'jason borne' }`. + * + * ####Note: + * + * Be careful to not use an existing model instance for the update clause (this won't work and can cause weird behavior like infinite loops). Also, ensure that the update clause does not have an _id property, which causes Mongo to return a "Mod on _id not allowed" error. + * + * ####Note: + * + * To update documents without waiting for a response from MongoDB, do not pass a `callback`, then call `exec` on the returned [Query](#query-js): + * + * Comment.update({ _id: id }, { $set: { text: 'changed' }}).exec(); + * + * ####Note: + * + * Although values are casted to their appropriate types when using update, the following are *not* applied: + * + * - defaults + * - setters + * - validators + * - middleware + * + * If you need those features, use the traditional approach of first retrieving the document. + * + * Model.findOne({ name: 'borne' }, function (err, doc) { + * if (err) .. + * doc.name = 'jason borne'; + * doc.save(callback); + * }) + * + * @see strict http://mongoosejs.com/docs/guide.html#strict + * @see response http://docs.mongodb.org/v2.6/reference/command/update/#output + * @param {Object} conditions + * @param {Object} doc + * @param {Object} [options] + * @param {Function} [callback] + * @return {Query} + * @api public + */ + +Model.update = function update(conditions, doc, options, callback) { + var mq = new this.Query({}, {}, this, this.collection); + if (callback) { + callback = this.$wrapCallback(callback); + } + // gh-2406 + // make local deep copy of conditions + if (conditions instanceof Document) { + conditions = conditions.toObject(); + } else { + conditions = utils.clone(conditions, {retainKeyOrder: true}); + } + options = typeof options === 'function' ? options : utils.clone(options); + + return mq.update(conditions, doc, options, callback); +}; + +/** + * Executes a mapReduce command. + * + * `o` is an object specifying all mapReduce options as well as the map and reduce functions. All options are delegated to the driver implementation. See [node-mongodb-native mapReduce() documentation](http://mongodb.github.io/node-mongodb-native/api-generated/collection.html#mapreduce) for more detail about options. + * + * ####Example: + * + * var o = {}; + * o.map = function () { emit(this.name, 1) } + * o.reduce = function (k, vals) { return vals.length } + * User.mapReduce(o, function (err, results) { + * console.log(results) + * }) + * + * ####Other options: + * + * - `query` {Object} query filter object. + * - `sort` {Object} sort input objects using this key + * - `limit` {Number} max number of documents + * - `keeptemp` {Boolean, default:false} keep temporary data + * - `finalize` {Function} finalize function + * - `scope` {Object} scope variables exposed to map/reduce/finalize during execution + * - `jsMode` {Boolean, default:false} it is possible to make the execution stay in JS. Provided in MongoDB > 2.0.X + * - `verbose` {Boolean, default:false} provide statistics on job execution time. + * - `readPreference` {String} + * - `out*` {Object, default: {inline:1}} sets the output target for the map reduce job. + * + * ####* out options: + * + * - `{inline:1}` the results are returned in an array + * - `{replace: 'collectionName'}` add the results to collectionName: the results replace the collection + * - `{reduce: 'collectionName'}` add the results to collectionName: if dups are detected, uses the reducer / finalize functions + * - `{merge: 'collectionName'}` add the results to collectionName: if dups exist the new docs overwrite the old + * + * If `options.out` is set to `replace`, `merge`, or `reduce`, a Model instance is returned that can be used for further querying. Queries run against this model are all executed with the `lean` option; meaning only the js object is returned and no Mongoose magic is applied (getters, setters, etc). + * + * ####Example: + * + * var o = {}; + * o.map = function () { emit(this.name, 1) } + * o.reduce = function (k, vals) { return vals.length } + * o.out = { replace: 'createdCollectionNameForResults' } + * o.verbose = true; + * + * User.mapReduce(o, function (err, model, stats) { + * console.log('map reduce took %d ms', stats.processtime) + * model.find().where('value').gt(10).exec(function (err, docs) { + * console.log(docs); + * }); + * }) + * + * // a promise is returned so you may instead write + * var promise = User.mapReduce(o); + * promise.then(function (model, stats) { + * console.log('map reduce took %d ms', stats.processtime) + * return model.find().where('value').gt(10).exec(); + * }).then(function (docs) { + * console.log(docs); + * }).then(null, handleError).end() + * + * @param {Object} o an object specifying map-reduce options + * @param {Function} [callback] optional callback + * @see http://www.mongodb.org/display/DOCS/MapReduce + * @return {Promise} + * @api public + */ + +Model.mapReduce = function mapReduce(o, callback) { + var _this = this; + if (callback) { + callback = this.$wrapCallback(callback); + } + var Promise = PromiseProvider.get(); + return new Promise.ES6(function(resolve, reject) { + if (!Model.mapReduce.schema) { + var opts = {noId: true, noVirtualId: true, strict: false}; + Model.mapReduce.schema = new Schema({}, opts); + } + + if (!o.out) o.out = {inline: 1}; + if (o.verbose !== false) o.verbose = true; + + o.map = String(o.map); + o.reduce = String(o.reduce); + + if (o.query) { + var q = new _this.Query(o.query); + q.cast(_this); + o.query = q._conditions; + q = undefined; + } + + _this.collection.mapReduce(null, null, o, function(err, ret, stats) { + if (err) { + callback && callback(err); + reject(err); + return; + } + + if (ret.findOne && ret.mapReduce) { + // returned a collection, convert to Model + var model = Model.compile( + '_mapreduce_' + ret.collectionName + , Model.mapReduce.schema + , ret.collectionName + , _this.db + , _this.base); + + model._mapreduce = true; + + callback && callback(null, model, stats); + return resolve(model, stats); + } + + callback && callback(null, ret, stats); + resolve(ret, stats); + }); + }); +}; + +/** + * geoNear support for Mongoose + * + * ####Options: + * - `lean` {Boolean} return the raw object + * - All options supported by the driver are also supported + * + * ####Example: + * + * // Legacy point + * Model.geoNear([1,3], { maxDistance : 5, spherical : true }, function(err, results, stats) { + * console.log(results); + * }); + * + * // geoJson + * var point = { type : "Point", coordinates : [9,9] }; + * Model.geoNear(point, { maxDistance : 5, spherical : true }, function(err, results, stats) { + * console.log(results); + * }); + * + * @param {Object|Array} GeoJSON point or legacy coordinate pair [x,y] to search near + * @param {Object} options for the qurery + * @param {Function} [callback] optional callback for the query + * @return {Promise} + * @see http://docs.mongodb.org/manual/core/2dsphere/ + * @see http://mongodb.github.io/node-mongodb-native/api-generated/collection.html?highlight=geonear#geoNear + * @api public + */ + +Model.geoNear = function(near, options, callback) { + if (typeof options === 'function') { + callback = options; + options = {}; + } + + if (callback) { + callback = this.$wrapCallback(callback); + } + + var _this = this; + var Promise = PromiseProvider.get(); + if (!near) { + return new Promise.ES6(function(resolve, reject) { + var error = new Error('Must pass a near option to geoNear'); + reject(error); + callback && callback(error); + }); + } + + var x, y; + + return new Promise.ES6(function(resolve, reject) { + var handler = function(err, res) { + if (err) { + reject(err); + callback && callback(err); + return; + } + if (options.lean) { + resolve(res.results, res.stats); + callback && callback(null, res.results, res.stats); + return; + } + + var count = res.results.length; + // if there are no results, fulfill the promise now + if (count === 0) { + resolve(res.results, res.stats); + callback && callback(null, res.results, res.stats); + return; + } + + var errSeen = false; + + function init(err) { + if (err && !errSeen) { + errSeen = true; + reject(err); + callback && callback(err); + return; + } + if (--count <= 0) { + resolve(res.results, res.stats); + callback && callback(null, res.results, res.stats); + } + } + + for (var i = 0; i < res.results.length; i++) { + var temp = res.results[i].obj; + res.results[i].obj = new _this(); + res.results[i].obj.init(temp, init); + } + }; + + if (Array.isArray(near)) { + if (near.length !== 2) { + var error = new Error('If using legacy coordinates, must be an array ' + + 'of size 2 for geoNear'); + reject(error); + callback && callback(error); + return; + } + x = near[0]; + y = near[1]; + _this.collection.geoNear(x, y, options, handler); + } else { + if (near.type !== 'Point' || !Array.isArray(near.coordinates)) { + error = new Error('Must pass either a legacy coordinate array or ' + + 'GeoJSON Point to geoNear'); + reject(error); + callback && callback(error); + return; + } + + _this.collection.geoNear(near, options, handler); + } + }); +}; + +/** + * Performs [aggregations](http://docs.mongodb.org/manual/applications/aggregation/) on the models collection. + * + * If a `callback` is passed, the `aggregate` is executed and a `Promise` is returned. If a callback is not passed, the `aggregate` itself is returned. + * + * ####Example: + * + * // Find the max balance of all accounts + * Users.aggregate( + * { $group: { _id: null, maxBalance: { $max: '$balance' }}} + * , { $project: { _id: 0, maxBalance: 1 }} + * , function (err, res) { + * if (err) return handleError(err); + * console.log(res); // [ { maxBalance: 98000 } ] + * }); + * + * // Or use the aggregation pipeline builder. + * Users.aggregate() + * .group({ _id: null, maxBalance: { $max: '$balance' } }) + * .select('-id maxBalance') + * .exec(function (err, res) { + * if (err) return handleError(err); + * console.log(res); // [ { maxBalance: 98 } ] + * }); + * + * ####NOTE: + * + * - Arguments are not cast to the model's schema because `$project` operators allow redefining the "shape" of the documents at any stage of the pipeline, which may leave documents in an incompatible format. + * - The documents returned are plain javascript objects, not mongoose documents (since any shape of document can be returned). + * - Requires MongoDB >= 2.1 + * + * @see Aggregate #aggregate_Aggregate + * @see MongoDB http://docs.mongodb.org/manual/applications/aggregation/ + * @param {Object|Array} [...] aggregation pipeline operator(s) or operator array + * @param {Function} [callback] + * @return {Aggregate|Promise} + * @api public + */ + +Model.aggregate = function aggregate() { + var args = [].slice.call(arguments), + aggregate, + callback; + + if (typeof args[args.length - 1] === 'function') { + callback = args.pop(); + } + + if (args.length === 1 && util.isArray(args[0])) { + aggregate = new Aggregate(args[0]); + } else { + aggregate = new Aggregate(args); + } + + aggregate.model(this); + + if (typeof callback === 'undefined') { + return aggregate; + } + + if (callback) { + callback = this.$wrapCallback(callback); + } + + aggregate.exec(callback); +}; + +/** + * Implements `$geoSearch` functionality for Mongoose + * + * ####Example: + * + * var options = { near: [10, 10], maxDistance: 5 }; + * Locations.geoSearch({ type : "house" }, options, function(err, res) { + * console.log(res); + * }); + * + * ####Options: + * - `near` {Array} x,y point to search for + * - `maxDistance` {Number} the maximum distance from the point near that a result can be + * - `limit` {Number} The maximum number of results to return + * - `lean` {Boolean} return the raw object instead of the Mongoose Model + * + * @param {Object} conditions an object that specifies the match condition (required) + * @param {Object} options for the geoSearch, some (near, maxDistance) are required + * @param {Function} [callback] optional callback + * @return {Promise} + * @see http://docs.mongodb.org/manual/reference/command/geoSearch/ + * @see http://docs.mongodb.org/manual/core/geohaystack/ + * @api public + */ + +Model.geoSearch = function(conditions, options, callback) { + if (typeof options === 'function') { + callback = options; + options = {}; + } + if (callback) { + callback = this.$wrapCallback(callback); + } + + var _this = this; + var Promise = PromiseProvider.get(); + return new Promise.ES6(function(resolve, reject) { + var error; + if (conditions === undefined || !utils.isObject(conditions)) { + error = new Error('Must pass conditions to geoSearch'); + } else if (!options.near) { + error = new Error('Must specify the near option in geoSearch'); + } else if (!Array.isArray(options.near)) { + error = new Error('near option must be an array [x, y]'); + } + + if (error) { + callback && callback(error); + reject(error); + return; + } + + // send the conditions in the options object + options.search = conditions; + + _this.collection.geoHaystackSearch(options.near[0], options.near[1], options, function(err, res) { + // have to deal with driver problem. Should be fixed in a soon-ish release + // (7/8/2013) + if (err) { + callback && callback(err); + reject(err); + return; + } + + var count = res.results.length; + if (options.lean || count === 0) { + callback && callback(null, res.results, res.stats); + resolve(res.results, res.stats); + return; + } + + var errSeen = false; + + function init(err) { + if (err && !errSeen) { + callback && callback(err); + reject(err); + return; + } + + if (!--count && !errSeen) { + callback && callback(null, res.results, res.stats); + resolve(res.results, res.stats); + } + } + + for (var i = 0; i < res.results.length; i++) { + var temp = res.results[i]; + res.results[i] = new _this(); + res.results[i].init(temp, {}, init); + } + }); + }); +}; + +/** + * Populates document references. + * + * ####Available options: + * + * - path: space delimited path(s) to populate + * - select: optional fields to select + * - match: optional query conditions to match + * - model: optional name of the model to use for population + * - options: optional query options like sort, limit, etc + * + * ####Examples: + * + * // populates a single object + * User.findById(id, function (err, user) { + * var opts = [ + * { path: 'company', match: { x: 1 }, select: 'name' } + * , { path: 'notes', options: { limit: 10 }, model: 'override' } + * ] + * + * User.populate(user, opts, function (err, user) { + * console.log(user); + * }) + * }) + * + * // populates an array of objects + * User.find(match, function (err, users) { + * var opts = [{ path: 'company', match: { x: 1 }, select: 'name' }] + * + * var promise = User.populate(users, opts); + * promise.then(console.log).end(); + * }) + * + * // imagine a Weapon model exists with two saved documents: + * // { _id: 389, name: 'whip' } + * // { _id: 8921, name: 'boomerang' } + * + * var user = { name: 'Indiana Jones', weapon: 389 } + * Weapon.populate(user, { path: 'weapon', model: 'Weapon' }, function (err, user) { + * console.log(user.weapon.name) // whip + * }) + * + * // populate many plain objects + * var users = [{ name: 'Indiana Jones', weapon: 389 }] + * users.push({ name: 'Batman', weapon: 8921 }) + * Weapon.populate(users, { path: 'weapon' }, function (err, users) { + * users.forEach(function (user) { + * console.log('%s uses a %s', users.name, user.weapon.name) + * // Indiana Jones uses a whip + * // Batman uses a boomerang + * }) + * }) + * // Note that we didn't need to specify the Weapon model because + * // we were already using it's populate() method. + * + * @param {Document|Array} docs Either a single document or array of documents to populate. + * @param {Object} options A hash of key/val (path, options) used for population. + * @param {Function} [callback(err,doc)] Optional callback, executed upon completion. Receives `err` and the `doc(s)`. + * @return {Promise} + * @api public + */ + +Model.populate = function(docs, paths, callback) { + var _this = this; + if (callback) { + callback = this.$wrapCallback(callback); + } + + // normalized paths + var noPromise = paths && !!paths.__noPromise; + paths = utils.populate(paths); + + // data that should persist across subPopulate calls + var cache = {}; + + if (noPromise) { + _populate(this, docs, paths, cache, callback); + } else { + var Promise = PromiseProvider.get(); + return new Promise.ES6(function(resolve, reject) { + _populate(_this, docs, paths, cache, function(error, docs) { + if (error) { + callback && callback(error); + reject(error); + } else { + callback && callback(null, docs); + resolve(docs); + } + }); + }); + } +}; + +/*! + * Populate helper + * + * @param {Model} model the model to use + * @param {Document|Array} docs Either a single document or array of documents to populate. + * @param {Object} paths + * @param {Function} [cb(err,doc)] Optional callback, executed upon completion. Receives `err` and the `doc(s)`. + * @return {Function} + * @api private + */ + +function _populate(model, docs, paths, cache, callback) { + var pending = paths.length; + + if (pending === 0) { + return callback(null, docs); + } + + // each path has its own query options and must be executed separately + var i = pending; + var path; + while (i--) { + path = paths[i]; + populate(model, docs, path, next); + } + + function next(err) { + if (err) { + return callback(err); + } + if (--pending) { + return; + } + callback(null, docs); + } +} + +/*! + * Populates `docs` + */ +var excludeIdReg = /\s?-_id\s?/, + excludeIdRegGlobal = /\s?-_id\s?/g; + +function populate(model, docs, options, callback) { + var modelsMap; + + // normalize single / multiple docs passed + if (!Array.isArray(docs)) { + docs = [docs]; + } + + if (docs.length === 0 || docs.every(utils.isNullOrUndefined)) { + return callback(); + } + + modelsMap = getModelsMapForPopulate(model, docs, options); + + var i, len = modelsMap.length, + mod, match, select, vals = []; + + function flatten(item) { + // no need to include undefined values in our query + return undefined !== item; + } + + var _remaining = len; + var hasOne = false; + for (i = 0; i < len; i++) { + mod = modelsMap[i]; + select = mod.options.select; + + if (mod.options.match) { + match = utils.object.shallowCopy(mod.options.match); + } else { + match = {}; + } + + var ids = utils.array.flatten(mod.ids, flatten); + ids = utils.array.unique(ids); + + if (ids.length === 0 || ids.every(utils.isNullOrUndefined)) { + --_remaining; + continue; + } + + hasOne = true; + if (mod.foreignField !== '_id' || !match['_id']) { + match[mod.foreignField] = { $in: ids }; + } + + var assignmentOpts = {}; + assignmentOpts.sort = mod.options.options && mod.options.options.sort || undefined; + assignmentOpts.excludeId = excludeIdReg.test(select) || (select && select._id === 0); + + if (assignmentOpts.excludeId) { + // override the exclusion from the query so we can use the _id + // for document matching during assignment. we'll delete the + // _id back off before returning the result. + if (typeof select === 'string') { + select = select.replace(excludeIdRegGlobal, ' '); + } else { + // preserve original select conditions by copying + select = utils.object.shallowCopy(select); + delete select._id; + } + } + + if (mod.options.options && mod.options.options.limit) { + assignmentOpts.originalLimit = mod.options.options.limit; + mod.options.options.limit = mod.options.options.limit * ids.length; + } + + var subPopulate = mod.options.populate; + var query = mod.Model.find(match, select, mod.options.options); + if (subPopulate) { + query.populate(subPopulate); + } + query.exec(next.bind(this, mod, assignmentOpts)); + } + + if (!hasOne) { + return callback(); + } + + function next(options, assignmentOpts, err, valsFromDb) { + if (err) return callback(err); + vals = vals.concat(valsFromDb); + _assign(null, vals, options, assignmentOpts); + if (--_remaining === 0) { + callback(); + } + } + + function _assign(err, vals, mod, assignmentOpts) { + if (err) return callback(err); + + var options = mod.options; + var _val; + var lean = options.options && options.options.lean, + len = vals.length, + rawOrder = {}, rawDocs = {}, key, val; + + // optimization: + // record the document positions as returned by + // the query result. + for (var i = 0; i < len; i++) { + val = vals[i]; + if (val) { + _val = utils.getValue(mod.foreignField, val); + if (Array.isArray(_val)) { + var _valLength = _val.length; + for (var j = 0; j < _valLength; ++j) { + key = String(_val[j]); + if (rawDocs[key]) { + if (Array.isArray(rawDocs[key])) { + rawDocs[key].push(val); + rawOrder[key].push(i); + } else { + rawDocs[key] = [rawDocs[key], val]; + rawOrder[key] = [rawOrder[key], i]; + } + } else { + rawDocs[key] = val; + rawOrder[key] = i; + } + } + } else { + key = String(utils.getValue(mod.foreignField, val)); + if (rawDocs[key]) { + if (Array.isArray(rawDocs[key])) { + rawDocs[key].push(val); + rawOrder[key].push(i); + } else { + rawDocs[key] = [rawDocs[key], val]; + rawOrder[key] = [rawOrder[key], i]; + } + } else { + rawDocs[key] = val; + rawOrder[key] = i; + } + } + // flag each as result of population + if (!lean) { + val.$__.wasPopulated = true; + } + } + } + + assignVals({ + originalModel: model, + rawIds: mod.ids, + localField: mod.localField, + foreignField: mod.foreignField, + rawDocs: rawDocs, + rawOrder: rawOrder, + docs: mod.docs, + path: options.path, + options: assignmentOpts, + justOne: mod.justOne, + isVirtual: mod.isVirtual + }); + } +} + +/*! + * Assigns documents returned from a population query back + * to the original document path. + */ + +function assignVals(o) { + // replace the original ids in our intermediate _ids structure + // with the documents found by query + assignRawDocsToIdStructure(o.rawIds, o.rawDocs, o.rawOrder, o.options, + o.localField, o.foreignField); + + // now update the original documents being populated using the + // result structure that contains real documents. + + var docs = o.docs; + var rawIds = o.rawIds; + var options = o.options; + + function setValue(val) { + return valueFilter(val, options); + } + + for (var i = 0; i < docs.length; ++i) { + if (utils.getValue(o.path, docs[i]) == null && + !o.originalModel.schema.virtuals[o.path]) { + continue; + } + + if (o.isVirtual && !o.justOne && !Array.isArray(rawIds[i])) { + rawIds[i] = [rawIds[i]]; + } + utils.setValue(o.path, rawIds[i], docs[i], setValue); + } +} + +/*! + * Assign `vals` returned by mongo query to the `rawIds` + * structure returned from utils.getVals() honoring + * query sort order if specified by user. + * + * This can be optimized. + * + * Rules: + * + * if the value of the path is not an array, use findOne rules, else find. + * for findOne the results are assigned directly to doc path (including null results). + * for find, if user specified sort order, results are assigned directly + * else documents are put back in original order of array if found in results + * + * @param {Array} rawIds + * @param {Array} vals + * @param {Boolean} sort + * @api private + */ + +function assignRawDocsToIdStructure(rawIds, resultDocs, resultOrder, options, localFields, foreignFields, recursed) { + // honor user specified sort order + var newOrder = []; + var sorting = options.sort && rawIds.length > 1; + var doc; + var sid; + var id; + + for (var i = 0; i < rawIds.length; ++i) { + id = rawIds[i]; + + if (Array.isArray(id)) { + // handle [ [id0, id2], [id3] ] + assignRawDocsToIdStructure(id, resultDocs, resultOrder, options, localFields, foreignFields, true); + newOrder.push(id); + continue; + } + + if (id === null && !sorting) { + // keep nulls for findOne unless sorting, which always + // removes them (backward compat) + newOrder.push(id); + continue; + } + + sid = String(id); + + if (recursed) { + // apply find behavior + + // assign matching documents in original order unless sorting + doc = resultDocs[sid]; + if (doc) { + if (sorting) { + newOrder[resultOrder[sid]] = doc; + } else { + newOrder.push(doc); + } + } else { + newOrder.push(id); + } + } else { + // apply findOne behavior - if document in results, assign, else assign null + newOrder[i] = doc = resultDocs[sid] || null; + } + } + + rawIds.length = 0; + if (newOrder.length) { + // reassign the documents based on corrected order + + // forEach skips over sparse entries in arrays so we + // can safely use this to our advantage dealing with sorted + // result sets too. + newOrder.forEach(function(doc, i) { + if (!doc) { + return; + } + rawIds[i] = doc; + }); + } +} + +function getModelsMapForPopulate(model, docs, options) { + var i, doc, len = docs.length, + available = {}, + map = [], + modelNameFromQuery = options.model && options.model.modelName || options.model, + schema, refPath, Model, currentOptions, modelNames, modelName, discriminatorKey, modelForFindSchema; + + var originalOptions = utils.clone(options); + var isVirtual = false; + + schema = model._getSchema(options.path); + + if (schema && schema.caster) { + schema = schema.caster; + } + + if (!schema && model.discriminators) { + discriminatorKey = model.schema.discriminatorMapping.key; + } + + refPath = schema && schema.options && schema.options.refPath; + + for (i = 0; i < len; i++) { + doc = docs[i]; + + if (refPath) { + modelNames = utils.getValue(refPath, doc); + } else { + if (!modelNameFromQuery) { + var modelForCurrentDoc = model; + var schemaForCurrentDoc; + + if (!schema && discriminatorKey) { + modelForFindSchema = utils.getValue(discriminatorKey, doc); + + if (modelForFindSchema) { + modelForCurrentDoc = model.db.model(modelForFindSchema); + schemaForCurrentDoc = modelForCurrentDoc._getSchema(options.path); + + if (schemaForCurrentDoc && schemaForCurrentDoc.caster) { + schemaForCurrentDoc = schemaForCurrentDoc.caster; + } + } + } else { + schemaForCurrentDoc = schema; + } + var virtual = modelForCurrentDoc.schema.virtuals[options.path]; + + if (schemaForCurrentDoc && schemaForCurrentDoc.options && schemaForCurrentDoc.options.ref) { + modelNames = [schemaForCurrentDoc.options.ref]; + } else if (virtual && virtual.options && virtual.options.ref) { + modelNames = [virtual && virtual.options && virtual.options.ref]; + isVirtual = true; + } else { + modelNames = [model.modelName]; + } + } else { + modelNames = [modelNameFromQuery]; // query options + } + } + + if (!modelNames) { + continue; + } + + if (!Array.isArray(modelNames)) { + modelNames = [modelNames]; + } + + virtual = model.schema.virtuals[options.path]; + var localField = virtual && virtual.options ? + virtual.options.localField : + options.path; + var foreignField = virtual && virtual.options ? + virtual.options.foreignField : + '_id'; + var justOne = virtual && virtual.options && virtual.options.justOne; + if (virtual && virtual.options && virtual.options.ref) { + isVirtual = true; + } + + var ret = convertTo_id(utils.getValue(localField, doc)); + var id = String(utils.getValue(foreignField, doc)); + options._docs[id] = Array.isArray(ret) ? ret.slice() : ret; + if (doc.$__) { + doc.populated(options.path, options._docs[id], options); + } + + var k = modelNames.length; + while (k--) { + modelName = modelNames[k]; + Model = originalOptions.model && originalOptions.model.modelName ? + originalOptions.model : + model.db.model(modelName); + + if (!available[modelName]) { + currentOptions = { + model: Model + }; + + utils.merge(currentOptions, options); + if (schema && !discriminatorKey) { + currentOptions.model = Model; + } + options.model = Model; + + available[modelName] = { + Model: Model, + options: currentOptions, + docs: [doc], + ids: [ret], + // Assume only 1 localField + foreignField + localField: localField, + foreignField: foreignField, + justOne: justOne, + isVirtual: isVirtual + }; + map.push(available[modelName]); + } else { + available[modelName].docs.push(doc); + available[modelName].ids.push(ret); + } + } + } + + return map; +} + +/*! + * Retrieve the _id of `val` if a Document or Array of Documents. + * + * @param {Array|Document|Any} val + * @return {Array|Document|Any} + */ + +function convertTo_id(val) { + if (val instanceof Model) return val._id; + + if (Array.isArray(val)) { + for (var i = 0; i < val.length; ++i) { + if (val[i] instanceof Model) { + val[i] = val[i]._id; + } + } + return val; + } + + return val; +} + +/*! + * 1) Apply backwards compatible find/findOne behavior to sub documents + * + * find logic: + * a) filter out non-documents + * b) remove _id from sub docs when user specified + * + * findOne + * a) if no doc found, set to null + * b) remove _id from sub docs when user specified + * + * 2) Remove _ids when specified by users query. + * + * background: + * _ids are left in the query even when user excludes them so + * that population mapping can occur. + */ + +function valueFilter(val, assignmentOpts) { + if (Array.isArray(val)) { + // find logic + var ret = []; + var numValues = val.length; + for (var i = 0; i < numValues; ++i) { + var subdoc = val[i]; + if (!isDoc(subdoc)) continue; + maybeRemoveId(subdoc, assignmentOpts); + ret.push(subdoc); + if (assignmentOpts.originalLimit && + ret.length >= assignmentOpts.originalLimit) { + break; + } + } + + // Since we don't want to have to create a new mongoosearray, make sure to + // modify the array in place + while (val.length > ret.length) { + Array.prototype.pop.apply(val, []); + } + for (i = 0; i < ret.length; ++i) { + val[i] = ret[i]; + } + return val; + } + + // findOne + if (isDoc(val)) { + maybeRemoveId(val, assignmentOpts); + return val; + } + + return null; +} + +/*! + * Remove _id from `subdoc` if user specified "lean" query option + */ + +function maybeRemoveId(subdoc, assignmentOpts) { + if (assignmentOpts.excludeId) { + if (typeof subdoc.setValue === 'function') { + delete subdoc._doc._id; + } else { + delete subdoc._id; + } + } +} + +/*! + * Determine if `doc` is a document returned + * by a populate query. + */ + +function isDoc(doc) { + if (doc == null) { + return false; + } + + var type = typeof doc; + if (type === 'string') { + return false; + } + + if (type === 'number') { + return false; + } + + if (Buffer.isBuffer(doc)) { + return false; + } + + if (doc.constructor.name === 'ObjectID') { + return false; + } + + // only docs + return true; +} + +/** + * Finds the schema for `path`. This is different than + * calling `schema.path` as it also resolves paths with + * positional selectors (something.$.another.$.path). + * + * @param {String} path + * @return {Schema} + * @api private + */ + +Model._getSchema = function _getSchema(path) { + return this.schema._getSchema(path); +}; + +/*! + * Compiler utility. + * + * @param {String} name model name + * @param {Schema} schema + * @param {String} collectionName + * @param {Connection} connection + * @param {Mongoose} base mongoose instance + */ + +Model.compile = function compile(name, schema, collectionName, connection, base) { + var versioningEnabled = schema.options.versionKey !== false; + + if (versioningEnabled && !schema.paths[schema.options.versionKey]) { + // add versioning to top level documents only + var o = {}; + o[schema.options.versionKey] = Number; + schema.add(o); + } + + // generate new class + function model(doc, fields, skipId) { + if (!(this instanceof model)) { + return new model(doc, fields, skipId); + } + Model.call(this, doc, fields, skipId); + } + + model.hooks = schema.s.hooks.clone(); + model.base = base; + model.modelName = name; + model.__proto__ = Model; + model.prototype.__proto__ = Model.prototype; + model.model = Model.prototype.model; + model.db = model.prototype.db = connection; + model.discriminators = model.prototype.discriminators = undefined; + + model.prototype.$__setSchema(schema); + + var collectionOptions = { + bufferCommands: schema.options.bufferCommands, + capped: schema.options.capped + }; + + model.prototype.collection = connection.collection( + collectionName + , collectionOptions + ); + + // apply methods and statics + applyMethods(model, schema); + applyStatics(model, schema); + + model.schema = model.prototype.schema; + model.collection = model.prototype.collection; + + // Create custom query constructor + model.Query = function() { + Query.apply(this, arguments); + }; + model.Query.prototype = Object.create(Query.prototype); + model.Query.base = Query.base; + applyQueryMethods(model, schema.query); + + var kareemOptions = { useErrorHandlers: true }; + model.$__insertMany = model.hooks.createWrapper('insertMany', + model.insertMany, model, kareemOptions); + model.insertMany = function(arr, callback) { + var Promise = PromiseProvider.get(); + return new Promise.ES6(function(resolve, reject) { + model.$__insertMany(arr, function(error, result) { + if (error) { + callback && callback(error); + return reject(error); + } + callback && callback(null, result); + resolve(result); + }); + }); + }; + + return model; +}; + +/*! + * Register methods for this model + * + * @param {Model} model + * @param {Schema} schema + */ +var applyMethods = function(model, schema) { + function apply(method, schema) { + Object.defineProperty(model.prototype, method, { + get: function() { + var h = {}; + for (var k in schema.methods[method]) { + h[k] = schema.methods[method][k].bind(this); + } + return h; + }, + configurable: true + }); + } + for (var method in schema.methods) { + if (schema.tree.hasOwnProperty(method)) { + throw new Error('You have a method and a property in your schema both ' + + 'named "' + method + '"'); + } + if (typeof schema.methods[method] === 'function') { + model.prototype[method] = schema.methods[method]; + } else { + apply(method, schema); + } + } +}; + +/*! + * Register statics for this model + * @param {Model} model + * @param {Schema} schema + */ +var applyStatics = function(model, schema) { + for (var i in schema.statics) { + model[i] = schema.statics[i]; + } +}; + +/*! + * Register custom query methods for this model + * + * @param {Model} model + * @param {Schema} schema + */ + +function applyQueryMethods(model, methods) { + for (var i in methods) { + model.Query.prototype[i] = methods[i]; + } +} + +/*! + * Subclass this model with `conn`, `schema`, and `collection` settings. + * + * @param {Connection} conn + * @param {Schema} [schema] + * @param {String} [collection] + * @return {Model} + */ + +Model.__subclass = function subclass(conn, schema, collection) { + // subclass model using this connection and collection name + var _this = this; + + var Model = function Model(doc, fields, skipId) { + if (!(this instanceof Model)) { + return new Model(doc, fields, skipId); + } + _this.call(this, doc, fields, skipId); + }; + + Model.__proto__ = _this; + Model.prototype.__proto__ = _this.prototype; + Model.db = Model.prototype.db = conn; + + var s = schema && typeof schema !== 'string' + ? schema + : _this.prototype.schema; + + var options = s.options || {}; + + if (!collection) { + collection = _this.prototype.schema.get('collection') + || utils.toCollectionName(_this.modelName, options); + } + + var collectionOptions = { + bufferCommands: s ? options.bufferCommands : true, + capped: s && options.capped + }; + + Model.prototype.collection = conn.collection(collection, collectionOptions); + Model.collection = Model.prototype.collection; + Model.init(); + return Model; +}; + +Model.$wrapCallback = function(callback) { + var _this = this; + return function() { + try { + callback.apply(null, arguments); + } catch (error) { + _this.emit('error', error); + } + }; +}; + +/*! + * Module exports. + */ + +module.exports = exports = Model; diff --git a/node_modules/mongoose/lib/promise.js b/node_modules/mongoose/lib/promise.js new file mode 100644 index 0000000..72163ea --- /dev/null +++ b/node_modules/mongoose/lib/promise.js @@ -0,0 +1,314 @@ +/*! + * Module dependencies + */ + +var MPromise = require('mpromise'); +var util = require('util'); + +/** + * Promise constructor. + * + * Promises are returned from executed queries. Example: + * + * var query = Candy.find({ bar: true }); + * var promise = query.exec(); + * + * DEPRECATED. Mongoose 5.0 will use native promises by default (or bluebird, + * if native promises are not present) but still + * support plugging in your own ES6-compatible promises library. Mongoose 5.0 + * will **not** support mpromise. + * + * @param {Function} fn a function which will be called when the promise is resolved that accepts `fn(err, ...){}` as signature + * @inherits mpromise https://github.com/aheckmann/mpromise + * @inherits NodeJS EventEmitter http://nodejs.org/api/events.html#events_class_events_eventemitter + * @event `err`: Emits when the promise is rejected + * @event `complete`: Emits when the promise is fulfilled + * @api public + * @deprecated + */ + +function Promise(fn) { + MPromise.call(this, fn); +} + +/** + * ES6-style promise constructor wrapper around mpromise. + * + * @param {Function} resolver + * @return {Promise} new promise + * @api public + */ +Promise.ES6 = function(resolver) { + var promise = new Promise(); + + // No try/catch for backwards compatibility + resolver( + function() { + promise.complete.apply(promise, arguments); + }, + function(e) { + promise.error(e); + }); + + return promise; +}; + +/*! + * Inherit from mpromise + */ + +Promise.prototype = Object.create(MPromise.prototype, { + constructor: { + value: Promise, + enumerable: false, + writable: true, + configurable: true + } +}); + +/*! + * ignore + */ + +Promise.prototype.then = util.deprecate(Promise.prototype.then, + 'Mongoose: mpromise (mongoose\'s default promise library) is deprecated, ' + + 'plug in your own promise library instead: ' + + 'http://mongoosejs.com/docs/promises.html'); + +/** + * ES6-style `.catch()` shorthand + * + * @method catch + * @memberOf Promise + * @param {Function} onReject + * @return {Promise} + * @api public + */ + +Promise.prototype.catch = function(onReject) { + return this.then(null, onReject); +}; + +/*! + * Override event names for backward compatibility. + */ + +Promise.SUCCESS = 'complete'; +Promise.FAILURE = 'err'; + +/** + * Adds `listener` to the `event`. + * + * If `event` is either the success or failure event and the event has already been emitted, the`listener` is called immediately and passed the results of the original emitted event. + * + * @see mpromise#on https://github.com/aheckmann/mpromise#on + * @method on + * @memberOf Promise + * @param {String} event + * @param {Function} listener + * @return {Promise} this + * @api public + */ + +/** + * Rejects this promise with `reason`. + * + * If the promise has already been fulfilled or rejected, not action is taken. + * + * @see mpromise#reject https://github.com/aheckmann/mpromise#reject + * @method reject + * @memberOf Promise + * @param {Object|String|Error} reason + * @return {Promise} this + * @api public + */ + +/** + * Rejects this promise with `err`. + * + * If the promise has already been fulfilled or rejected, not action is taken. + * + * Differs from [#reject](#promise_Promise-reject) by first casting `err` to an `Error` if it is not `instanceof Error`. + * + * @api public + * @param {Error|String} err + * @return {Promise} this + */ + +Promise.prototype.error = function(err) { + if (!(err instanceof Error)) { + if (err instanceof Object) { + err = util.inspect(err); + } + err = new Error(err); + } + return this.reject(err); +}; + +/** + * Resolves this promise to a rejected state if `err` is passed or a fulfilled state if no `err` is passed. + * + * If the promise has already been fulfilled or rejected, not action is taken. + * + * `err` will be cast to an Error if not already instanceof Error. + * + * _NOTE: overrides [mpromise#resolve](https://github.com/aheckmann/mpromise#resolve) to provide error casting._ + * + * @param {Error} [err] error or null + * @param {Object} [val] value to fulfill the promise with + * @api public + * @deprecated + */ + +Promise.prototype.resolve = function(err) { + if (err) return this.error(err); + return this.fulfill.apply(this, Array.prototype.slice.call(arguments, 1)); +}; + +/** + * Adds a single function as a listener to both err and complete. + * + * It will be executed with traditional node.js argument position when the promise is resolved. + * + * promise.addBack(function (err, args...) { + * if (err) return handleError(err); + * console.log('success'); + * }) + * + * Alias of [mpromise#onResolve](https://github.com/aheckmann/mpromise#onresolve). + * + * _Deprecated. Use `onResolve` instead._ + * + * @method addBack + * @param {Function} listener + * @return {Promise} this + * @deprecated + */ + +Promise.prototype.addBack = Promise.prototype.onResolve; + +/** + * Fulfills this promise with passed arguments. + * + * @method fulfill + * @receiver Promise + * @see https://github.com/aheckmann/mpromise#fulfill + * @param {any} args + * @api public + * @deprecated + */ + +/** + * Fulfills this promise with passed arguments. + * + * Alias of [mpromise#fulfill](https://github.com/aheckmann/mpromise#fulfill). + * + * _Deprecated. Use `fulfill` instead._ + * + * @method complete + * @receiver Promise + * @param {any} args + * @api public + * @deprecated + */ + +Promise.prototype.complete = MPromise.prototype.fulfill; + +/** + * Adds a listener to the `complete` (success) event. + * + * Alias of [mpromise#onFulfill](https://github.com/aheckmann/mpromise#onfulfill). + * + * _Deprecated. Use `onFulfill` instead._ + * + * @method addCallback + * @param {Function} listener + * @return {Promise} this + * @api public + * @deprecated + */ + +Promise.prototype.addCallback = Promise.prototype.onFulfill; + +/** + * Adds a listener to the `err` (rejected) event. + * + * Alias of [mpromise#onReject](https://github.com/aheckmann/mpromise#onreject). + * + * _Deprecated. Use `onReject` instead._ + * + * @method addErrback + * @param {Function} listener + * @return {Promise} this + * @api public + * @deprecated + */ + +Promise.prototype.addErrback = Promise.prototype.onReject; + +/** + * Creates a new promise and returns it. If `onFulfill` or `onReject` are passed, they are added as SUCCESS/ERROR callbacks to this promise after the nextTick. + * + * Conforms to [promises/A+](https://github.com/promises-aplus/promises-spec) specification. + * + * ####Example: + * + * var promise = Meetups.find({ tags: 'javascript' }).select('_id').exec(); + * promise.then(function (meetups) { + * var ids = meetups.map(function (m) { + * return m._id; + * }); + * return People.find({ meetups: { $in: ids }).exec(); + * }).then(function (people) { + * if (people.length < 10000) { + * throw new Error('Too few people!!!'); + * } else { + * throw new Error('Still need more people!!!'); + * } + * }).then(null, function (err) { + * assert.ok(err instanceof Error); + * }); + * + * @see promises-A+ https://github.com/promises-aplus/promises-spec + * @see mpromise#then https://github.com/aheckmann/mpromise#then + * @method then + * @memberOf Promise + * @param {Function} onFulFill + * @param {Function} onReject + * @return {Promise} newPromise + * @deprecated + */ + +/** + * Signifies that this promise was the last in a chain of `then()s`: if a handler passed to the call to `then` which produced this promise throws, the exception will go uncaught. + * + * ####Example: + * + * var p = new Promise; + * p.then(function(){ throw new Error('shucks') }); + * setTimeout(function () { + * p.fulfill(); + * // error was caught and swallowed by the promise returned from + * // p.then(). we either have to always register handlers on + * // the returned promises or we can do the following... + * }, 10); + * + * // this time we use .end() which prevents catching thrown errors + * var p = new Promise; + * var p2 = p.then(function(){ throw new Error('shucks') }).end(); // <-- + * setTimeout(function () { + * p.fulfill(); // throws "shucks" + * }, 10); + * + * @api public + * @see mpromise#end https://github.com/aheckmann/mpromise#end + * @method end + * @memberOf Promise + * @deprecated + */ + +/*! + * expose + */ + +module.exports = Promise; diff --git a/node_modules/mongoose/lib/promise_provider.js b/node_modules/mongoose/lib/promise_provider.js new file mode 100644 index 0000000..368cf85 --- /dev/null +++ b/node_modules/mongoose/lib/promise_provider.js @@ -0,0 +1,51 @@ +/*! + * Module dependencies. + */ + +var MPromise = require('./promise'); + +/** + * Helper for multiplexing promise implementations + * + * @api private + */ + +var Promise = { + _promise: MPromise +}; + +/** + * Get the current promise constructor + * + * @api private + */ +Promise.get = function() { + return Promise._promise; +}; + +/** + * Set the current promise constructor + * + * @api private + */ + +Promise.set = function(lib) { + if (lib === MPromise) { + return Promise.reset(); + } + Promise._promise = require('./ES6Promise'); + Promise._promise.use(lib); + require('mquery').Promise = Promise._promise.ES6; +}; + +/** + * Resets to using mpromise + * + * @api private + */ + +Promise.reset = function() { + Promise._promise = MPromise; +}; + +module.exports = Promise; diff --git a/node_modules/mongoose/lib/query.js b/node_modules/mongoose/lib/query.js new file mode 100644 index 0000000..03e6261 --- /dev/null +++ b/node_modules/mongoose/lib/query.js @@ -0,0 +1,3346 @@ +/*! + * Module dependencies. + */ + +var PromiseProvider = require('./promise_provider'); +var QueryCursor = require('./querycursor'); +var QueryStream = require('./querystream'); +var StrictModeError = require('./error/strict'); +var cast = require('./cast'); +var helpers = require('./queryhelpers'); +var mquery = require('mquery'); +var readPref = require('./drivers').ReadPreference; +var setDefaultsOnInsert = require('./services/setDefaultsOnInsert'); +var updateValidators = require('./services/updateValidators'); +var util = require('util'); +var utils = require('./utils'); + +/** + * Query constructor used for building queries. + * + * ####Example: + * + * var query = new Query(); + * query.setOptions({ lean : true }); + * query.collection(model.collection); + * query.where('age').gte(21).exec(callback); + * + * @param {Object} [options] + * @param {Object} [model] + * @param {Object} [conditions] + * @param {Object} [collection] Mongoose collection + * @api private + */ + +function Query(conditions, options, model, collection) { + // this stuff is for dealing with custom queries created by #toConstructor + if (!this._mongooseOptions) { + this._mongooseOptions = {}; + } + + // this is the case where we have a CustomQuery, we need to check if we got + // options passed in, and if we did, merge them in + if (options) { + var keys = Object.keys(options); + for (var i = 0; i < keys.length; ++i) { + var k = keys[i]; + this._mongooseOptions[k] = options[k]; + } + } + + if (collection) { + this.mongooseCollection = collection; + } + + if (model) { + this.model = model; + this.schema = model.schema; + } + + // this is needed because map reduce returns a model that can be queried, but + // all of the queries on said model should be lean + if (this.model && this.model._mapreduce) { + this.lean(); + } + + // inherit mquery + mquery.call(this, this.mongooseCollection, options); + + if (conditions) { + this.find(conditions); + } + + if (this.schema) { + var kareemOptions = { useErrorHandlers: true }; + this._count = this.model.hooks.createWrapper('count', + Query.prototype._count, this, kareemOptions); + this._execUpdate = this.model.hooks.createWrapper('update', + Query.prototype._execUpdate, this, kareemOptions); + this._find = this.model.hooks.createWrapper('find', + Query.prototype._find, this, kareemOptions); + this._findOne = this.model.hooks.createWrapper('findOne', + Query.prototype._findOne, this, kareemOptions); + this._findOneAndRemove = this.model.hooks.createWrapper('findOneAndRemove', + Query.prototype._findOneAndRemove, this, kareemOptions); + this._findOneAndUpdate = this.model.hooks.createWrapper('findOneAndUpdate', + Query.prototype._findOneAndUpdate, this, kareemOptions); + } +} + +/*! + * inherit mquery + */ + +Query.prototype = new mquery; +Query.prototype.constructor = Query; +Query.base = mquery.prototype; + +/** + * Flag to opt out of using `$geoWithin`. + * + * mongoose.Query.use$geoWithin = false; + * + * MongoDB 2.4 deprecated the use of `$within`, replacing it with `$geoWithin`. Mongoose uses `$geoWithin` by default (which is 100% backward compatible with $within). If you are running an older version of MongoDB, set this flag to `false` so your `within()` queries continue to work. + * + * @see http://docs.mongodb.org/manual/reference/operator/geoWithin/ + * @default true + * @property use$geoWithin + * @memberOf Query + * @receiver Query + * @api public + */ + +Query.use$geoWithin = mquery.use$geoWithin; + +/** + * Converts this query to a customized, reusable query constructor with all arguments and options retained. + * + * ####Example + * + * // Create a query for adventure movies and read from the primary + * // node in the replica-set unless it is down, in which case we'll + * // read from a secondary node. + * var query = Movie.find({ tags: 'adventure' }).read('primaryPreferred'); + * + * // create a custom Query constructor based off these settings + * var Adventure = query.toConstructor(); + * + * // Adventure is now a subclass of mongoose.Query and works the same way but with the + * // default query parameters and options set. + * Adventure().exec(callback) + * + * // further narrow down our query results while still using the previous settings + * Adventure().where({ name: /^Life/ }).exec(callback); + * + * // since Adventure is a stand-alone constructor we can also add our own + * // helper methods and getters without impacting global queries + * Adventure.prototype.startsWith = function (prefix) { + * this.where({ name: new RegExp('^' + prefix) }) + * return this; + * } + * Object.defineProperty(Adventure.prototype, 'highlyRated', { + * get: function () { + * this.where({ rating: { $gt: 4.5 }}); + * return this; + * } + * }) + * Adventure().highlyRated.startsWith('Life').exec(callback) + * + * New in 3.7.3 + * + * @return {Query} subclass-of-Query + * @api public + */ + +Query.prototype.toConstructor = function toConstructor() { + var model = this.model; + var coll = this.mongooseCollection; + + var CustomQuery = function(criteria, options) { + if (!(this instanceof CustomQuery)) { + return new CustomQuery(criteria, options); + } + this._mongooseOptions = utils.clone(p._mongooseOptions); + Query.call(this, criteria, options || null, model, coll); + }; + + util.inherits(CustomQuery, Query); + + // set inherited defaults + var p = CustomQuery.prototype; + + p.options = {}; + + p.setOptions(this.options); + + p.op = this.op; + p._conditions = utils.clone(this._conditions); + p._fields = utils.clone(this._fields); + p._update = utils.clone(this._update); + p._path = this._path; + p._distinct = this._distinct; + p._collection = this._collection; + p._mongooseOptions = this._mongooseOptions; + + return CustomQuery; +}; + +/** + * Specifies a javascript function or expression to pass to MongoDBs query system. + * + * ####Example + * + * query.$where('this.comments.length === 10 || this.name.length === 5') + * + * // or + * + * query.$where(function () { + * return this.comments.length === 10 || this.name.length === 5; + * }) + * + * ####NOTE: + * + * Only use `$where` when you have a condition that cannot be met using other MongoDB operators like `$lt`. + * **Be sure to read about all of [its caveats](http://docs.mongodb.org/manual/reference/operator/where/) before using.** + * + * @see $where http://docs.mongodb.org/manual/reference/operator/where/ + * @method $where + * @param {String|Function} js javascript string or function + * @return {Query} this + * @memberOf Query + * @method $where + * @api public + */ + +/** + * Specifies a `path` for use with chaining. + * + * ####Example + * + * // instead of writing: + * User.find({age: {$gte: 21, $lte: 65}}, callback); + * + * // we can instead write: + * User.where('age').gte(21).lte(65); + * + * // passing query conditions is permitted + * User.find().where({ name: 'vonderful' }) + * + * // chaining + * User + * .where('age').gte(21).lte(65) + * .where('name', /^vonderful/i) + * .where('friends').slice(10) + * .exec(callback) + * + * @method where + * @memberOf Query + * @param {String|Object} [path] + * @param {any} [val] + * @return {Query} this + * @api public + */ + +/** + * Specifies the complementary comparison value for paths specified with `where()` + * + * ####Example + * + * User.where('age').equals(49); + * + * // is the same as + * + * User.where('age', 49); + * + * @method equals + * @memberOf Query + * @param {Object} val + * @return {Query} this + * @api public + */ + +/** + * Specifies arguments for an `$or` condition. + * + * ####Example + * + * query.or([{ color: 'red' }, { status: 'emergency' }]) + * + * @see $or http://docs.mongodb.org/manual/reference/operator/or/ + * @method or + * @memberOf Query + * @param {Array} array array of conditions + * @return {Query} this + * @api public + */ + +/** + * Specifies arguments for a `$nor` condition. + * + * ####Example + * + * query.nor([{ color: 'green' }, { status: 'ok' }]) + * + * @see $nor http://docs.mongodb.org/manual/reference/operator/nor/ + * @method nor + * @memberOf Query + * @param {Array} array array of conditions + * @return {Query} this + * @api public + */ + +/** + * Specifies arguments for a `$and` condition. + * + * ####Example + * + * query.and([{ color: 'green' }, { status: 'ok' }]) + * + * @method and + * @memberOf Query + * @see $and http://docs.mongodb.org/manual/reference/operator/and/ + * @param {Array} array array of conditions + * @return {Query} this + * @api public + */ + +/** + * Specifies a $gt query condition. + * + * When called with one argument, the most recent path passed to `where()` is used. + * + * ####Example + * + * Thing.find().where('age').gt(21) + * + * // or + * Thing.find().gt('age', 21) + * + * @method gt + * @memberOf Query + * @param {String} [path] + * @param {Number} val + * @see $gt http://docs.mongodb.org/manual/reference/operator/gt/ + * @api public + */ + +/** + * Specifies a $gte query condition. + * + * When called with one argument, the most recent path passed to `where()` is used. + * + * @method gte + * @memberOf Query + * @param {String} [path] + * @param {Number} val + * @see $gte http://docs.mongodb.org/manual/reference/operator/gte/ + * @api public + */ + +/** + * Specifies a $lt query condition. + * + * When called with one argument, the most recent path passed to `where()` is used. + * + * @method lt + * @memberOf Query + * @param {String} [path] + * @param {Number} val + * @see $lt http://docs.mongodb.org/manual/reference/operator/lt/ + * @api public + */ + +/** + * Specifies a $lte query condition. + * + * When called with one argument, the most recent path passed to `where()` is used. + * + * @method lte + * @see $lte http://docs.mongodb.org/manual/reference/operator/lte/ + * @memberOf Query + * @param {String} [path] + * @param {Number} val + * @api public + */ + +/** + * Specifies a $ne query condition. + * + * When called with one argument, the most recent path passed to `where()` is used. + * + * @see $ne http://docs.mongodb.org/manual/reference/operator/ne/ + * @method ne + * @memberOf Query + * @param {String} [path] + * @param {Number} val + * @api public + */ + +/** + * Specifies an $in query condition. + * + * When called with one argument, the most recent path passed to `where()` is used. + * + * @see $in http://docs.mongodb.org/manual/reference/operator/in/ + * @method in + * @memberOf Query + * @param {String} [path] + * @param {Number} val + * @api public + */ + +/** + * Specifies an $nin query condition. + * + * When called with one argument, the most recent path passed to `where()` is used. + * + * @see $nin http://docs.mongodb.org/manual/reference/operator/nin/ + * @method nin + * @memberOf Query + * @param {String} [path] + * @param {Number} val + * @api public + */ + +/** + * Specifies an $all query condition. + * + * When called with one argument, the most recent path passed to `where()` is used. + * + * @see $all http://docs.mongodb.org/manual/reference/operator/all/ + * @method all + * @memberOf Query + * @param {String} [path] + * @param {Number} val + * @api public + */ + +/** + * Specifies a $size query condition. + * + * When called with one argument, the most recent path passed to `where()` is used. + * + * ####Example + * + * MyModel.where('tags').size(0).exec(function (err, docs) { + * if (err) return handleError(err); + * + * assert(Array.isArray(docs)); + * console.log('documents with 0 tags', docs); + * }) + * + * @see $size http://docs.mongodb.org/manual/reference/operator/size/ + * @method size + * @memberOf Query + * @param {String} [path] + * @param {Number} val + * @api public + */ + +/** + * Specifies a $regex query condition. + * + * When called with one argument, the most recent path passed to `where()` is used. + * + * @see $regex http://docs.mongodb.org/manual/reference/operator/regex/ + * @method regex + * @memberOf Query + * @param {String} [path] + * @param {Number} val + * @api public + */ + +/** + * Specifies a $maxDistance query condition. + * + * When called with one argument, the most recent path passed to `where()` is used. + * + * @see $maxDistance http://docs.mongodb.org/manual/reference/operator/maxDistance/ + * @method maxDistance + * @memberOf Query + * @param {String} [path] + * @param {Number} val + * @api public + */ + +/** + * Specifies a `$mod` condition + * + * @method mod + * @memberOf Query + * @param {String} [path] + * @param {Number} val + * @return {Query} this + * @see $mod http://docs.mongodb.org/manual/reference/operator/mod/ + * @api public + */ + +/** + * Specifies an `$exists` condition + * + * ####Example + * + * // { name: { $exists: true }} + * Thing.where('name').exists() + * Thing.where('name').exists(true) + * Thing.find().exists('name') + * + * // { name: { $exists: false }} + * Thing.where('name').exists(false); + * Thing.find().exists('name', false); + * + * @method exists + * @memberOf Query + * @param {String} [path] + * @param {Number} val + * @return {Query} this + * @see $exists http://docs.mongodb.org/manual/reference/operator/exists/ + * @api public + */ + +/** + * Specifies an `$elemMatch` condition + * + * ####Example + * + * query.elemMatch('comment', { author: 'autobot', votes: {$gte: 5}}) + * + * query.where('comment').elemMatch({ author: 'autobot', votes: {$gte: 5}}) + * + * query.elemMatch('comment', function (elem) { + * elem.where('author').equals('autobot'); + * elem.where('votes').gte(5); + * }) + * + * query.where('comment').elemMatch(function (elem) { + * elem.where({ author: 'autobot' }); + * elem.where('votes').gte(5); + * }) + * + * @method elemMatch + * @memberOf Query + * @param {String|Object|Function} path + * @param {Object|Function} criteria + * @return {Query} this + * @see $elemMatch http://docs.mongodb.org/manual/reference/operator/elemMatch/ + * @api public + */ + +/** + * Defines a `$within` or `$geoWithin` argument for geo-spatial queries. + * + * ####Example + * + * query.where(path).within().box() + * query.where(path).within().circle() + * query.where(path).within().geometry() + * + * query.where('loc').within({ center: [50,50], radius: 10, unique: true, spherical: true }); + * query.where('loc').within({ box: [[40.73, -73.9], [40.7, -73.988]] }); + * query.where('loc').within({ polygon: [[],[],[],[]] }); + * + * query.where('loc').within([], [], []) // polygon + * query.where('loc').within([], []) // box + * query.where('loc').within({ type: 'LineString', coordinates: [...] }); // geometry + * + * **MUST** be used after `where()`. + * + * ####NOTE: + * + * As of Mongoose 3.7, `$geoWithin` is always used for queries. To change this behavior, see [Query.use$geoWithin](#query_Query-use%2524geoWithin). + * + * ####NOTE: + * + * In Mongoose 3.7, `within` changed from a getter to a function. If you need the old syntax, use [this](https://github.com/ebensing/mongoose-within). + * + * @method within + * @see $polygon http://docs.mongodb.org/manual/reference/operator/polygon/ + * @see $box http://docs.mongodb.org/manual/reference/operator/box/ + * @see $geometry http://docs.mongodb.org/manual/reference/operator/geometry/ + * @see $center http://docs.mongodb.org/manual/reference/operator/center/ + * @see $centerSphere http://docs.mongodb.org/manual/reference/operator/centerSphere/ + * @memberOf Query + * @return {Query} this + * @api public + */ + +/** + * Specifies a $slice projection for an array. + * + * ####Example + * + * query.slice('comments', 5) + * query.slice('comments', -5) + * query.slice('comments', [10, 5]) + * query.where('comments').slice(5) + * query.where('comments').slice([-10, 5]) + * + * @method slice + * @memberOf Query + * @param {String} [path] + * @param {Number} val number/range of elements to slice + * @return {Query} this + * @see mongodb http://www.mongodb.org/display/DOCS/Retrieving+a+Subset+of+Fields#RetrievingaSubsetofFields-RetrievingaSubrangeofArrayElements + * @see $slice http://docs.mongodb.org/manual/reference/projection/slice/#prj._S_slice + * @api public + */ + +/** + * Specifies the maximum number of documents the query will return. + * + * ####Example + * + * query.limit(20) + * + * ####Note + * + * Cannot be used with `distinct()` + * + * @method limit + * @memberOf Query + * @param {Number} val + * @api public + */ + +/** + * Specifies the number of documents to skip. + * + * ####Example + * + * query.skip(100).limit(20) + * + * ####Note + * + * Cannot be used with `distinct()` + * + * @method skip + * @memberOf Query + * @param {Number} val + * @see cursor.skip http://docs.mongodb.org/manual/reference/method/cursor.skip/ + * @api public + */ + +/** + * Specifies the maxScan option. + * + * ####Example + * + * query.maxScan(100) + * + * ####Note + * + * Cannot be used with `distinct()` + * + * @method maxScan + * @memberOf Query + * @param {Number} val + * @see maxScan http://docs.mongodb.org/manual/reference/operator/maxScan/ + * @api public + */ + +/** + * Specifies the batchSize option. + * + * ####Example + * + * query.batchSize(100) + * + * ####Note + * + * Cannot be used with `distinct()` + * + * @method batchSize + * @memberOf Query + * @param {Number} val + * @see batchSize http://docs.mongodb.org/manual/reference/method/cursor.batchSize/ + * @api public + */ + +/** + * Specifies the `comment` option. + * + * ####Example + * + * query.comment('login query') + * + * ####Note + * + * Cannot be used with `distinct()` + * + * @method comment + * @memberOf Query + * @param {Number} val + * @see comment http://docs.mongodb.org/manual/reference/operator/comment/ + * @api public + */ + +/** + * Specifies this query as a `snapshot` query. + * + * ####Example + * + * query.snapshot() // true + * query.snapshot(true) + * query.snapshot(false) + * + * ####Note + * + * Cannot be used with `distinct()` + * + * @method snapshot + * @memberOf Query + * @see snapshot http://docs.mongodb.org/manual/reference/operator/snapshot/ + * @return {Query} this + * @api public + */ + +/** + * Sets query hints. + * + * ####Example + * + * query.hint({ indexA: 1, indexB: -1}) + * + * ####Note + * + * Cannot be used with `distinct()` + * + * @method hint + * @memberOf Query + * @param {Object} val a hint object + * @return {Query} this + * @see $hint http://docs.mongodb.org/manual/reference/operator/hint/ + * @api public + */ + +/** + * Specifies which document fields to include or exclude (also known as the query "projection") + * + * When using string syntax, prefixing a path with `-` will flag that path as excluded. When a path does not have the `-` prefix, it is included. Lastly, if a path is prefixed with `+`, it forces inclusion of the path, which is useful for paths excluded at the [schema level](/docs/api.html#schematype_SchemaType-select). + * + * ####Example + * + * // include a and b, exclude other fields + * query.select('a b'); + * + * // exclude c and d, include other fields + * query.select('-c -d'); + * + * // or you may use object notation, useful when + * // you have keys already prefixed with a "-" + * query.select({ a: 1, b: 1 }); + * query.select({ c: 0, d: 0 }); + * + * // force inclusion of field excluded at schema level + * query.select('+path') + * + * ####NOTE: + * + * Cannot be used with `distinct()`. + * + * _v2 had slightly different syntax such as allowing arrays of field names. This support was removed in v3._ + * + * @method select + * @memberOf Query + * @param {Object|String} arg + * @return {Query} this + * @see SchemaType + * @api public + */ + +/** + * _DEPRECATED_ Sets the slaveOk option. + * + * **Deprecated** in MongoDB 2.2 in favor of [read preferences](#query_Query-read). + * + * ####Example: + * + * query.slaveOk() // true + * query.slaveOk(true) + * query.slaveOk(false) + * + * @method slaveOk + * @memberOf Query + * @deprecated use read() preferences instead if on mongodb >= 2.2 + * @param {Boolean} v defaults to true + * @see mongodb http://docs.mongodb.org/manual/applications/replication/#read-preference + * @see slaveOk http://docs.mongodb.org/manual/reference/method/rs.slaveOk/ + * @see read() #query_Query-read + * @return {Query} this + * @api public + */ + +/** + * Determines the MongoDB nodes from which to read. + * + * ####Preferences: + * + * primary - (default) Read from primary only. Operations will produce an error if primary is unavailable. Cannot be combined with tags. + * secondary Read from secondary if available, otherwise error. + * primaryPreferred Read from primary if available, otherwise a secondary. + * secondaryPreferred Read from a secondary if available, otherwise read from the primary. + * nearest All operations read from among the nearest candidates, but unlike other modes, this option will include both the primary and all secondaries in the random selection. + * + * Aliases + * + * p primary + * pp primaryPreferred + * s secondary + * sp secondaryPreferred + * n nearest + * + * ####Example: + * + * new Query().read('primary') + * new Query().read('p') // same as primary + * + * new Query().read('primaryPreferred') + * new Query().read('pp') // same as primaryPreferred + * + * new Query().read('secondary') + * new Query().read('s') // same as secondary + * + * new Query().read('secondaryPreferred') + * new Query().read('sp') // same as secondaryPreferred + * + * new Query().read('nearest') + * new Query().read('n') // same as nearest + * + * // read from secondaries with matching tags + * new Query().read('s', [{ dc:'sf', s: 1 },{ dc:'ma', s: 2 }]) + * + * Read more about how to use read preferrences [here](http://docs.mongodb.org/manual/applications/replication/#read-preference) and [here](http://mongodb.github.com/node-mongodb-native/driver-articles/anintroductionto1_1and2_2.html#read-preferences). + * + * @method read + * @memberOf Query + * @param {String} pref one of the listed preference options or aliases + * @param {Array} [tags] optional tags for this query + * @see mongodb http://docs.mongodb.org/manual/applications/replication/#read-preference + * @see driver http://mongodb.github.com/node-mongodb-native/driver-articles/anintroductionto1_1and2_2.html#read-preferences + * @return {Query} this + * @api public + */ + +Query.prototype.read = function read(pref, tags) { + // first cast into a ReadPreference object to support tags + var read = readPref.call(readPref, pref, tags); + return Query.base.read.call(this, read); +}; + +/** + * Merges another Query or conditions object into this one. + * + * When a Query is passed, conditions, field selection and options are merged. + * + * New in 3.7.0 + * + * @method merge + * @memberOf Query + * @param {Query|Object} source + * @return {Query} this + */ + +/** + * Sets query options. + * + * ####Options: + * + * - [tailable](http://www.mongodb.org/display/DOCS/Tailable+Cursors) * + * - [sort](http://www.mongodb.org/display/DOCS/Advanced+Queries#AdvancedQueries-%7B%7Bsort(\)%7D%7D) * + * - [limit](http://www.mongodb.org/display/DOCS/Advanced+Queries#AdvancedQueries-%7B%7Blimit%28%29%7D%7D) * + * - [skip](http://www.mongodb.org/display/DOCS/Advanced+Queries#AdvancedQueries-%7B%7Bskip%28%29%7D%7D) * + * - [maxscan](https://docs.mongodb.org/v3.2/reference/operator/meta/maxScan/#metaOp._S_maxScan) * + * - [batchSize](http://www.mongodb.org/display/DOCS/Advanced+Queries#AdvancedQueries-%7B%7BbatchSize%28%29%7D%7D) * + * - [comment](http://www.mongodb.org/display/DOCS/Advanced+Queries#AdvancedQueries-%24comment) * + * - [snapshot](http://www.mongodb.org/display/DOCS/Advanced+Queries#AdvancedQueries-%7B%7Bsnapshot%28%29%7D%7D) * + * - [hint](http://www.mongodb.org/display/DOCS/Advanced+Queries#AdvancedQueries-%24hint) * + * - [readPreference](http://docs.mongodb.org/manual/applications/replication/#read-preference) ** + * - [lean](./api.html#query_Query-lean) * + * - [safe](http://www.mongodb.org/display/DOCS/getLastError+Command) + * + * _* denotes a query helper method is also available_ + * _** query helper method to set `readPreference` is `read()`_ + * + * @param {Object} options + * @api public + */ + +Query.prototype.setOptions = function(options, overwrite) { + // overwrite is only for internal use + if (overwrite) { + // ensure that _mongooseOptions & options are two different objects + this._mongooseOptions = (options && utils.clone(options)) || {}; + this.options = options || {}; + + if ('populate' in options) { + this.populate(this._mongooseOptions); + } + return this; + } + + if (!(options && options.constructor.name === 'Object')) { + return this; + } + + if (options && Array.isArray(options.populate)) { + var populate = options.populate; + delete options.populate; + var _numPopulate = populate.length; + for (var i = 0; i < _numPopulate; ++i) { + this.populate(populate[i]); + } + } + + return Query.base.setOptions.call(this, options); +}; + +/** + * Returns the current query conditions as a JSON object. + * + * ####Example: + * + * var query = new Query(); + * query.find({ a: 1 }).where('b').gt(2); + * query.getQuery(); // { a: 1, b: { $gt: 2 } } + * + * @return {Object} current query conditions + * @api public + */ + +Query.prototype.getQuery = function() { + return this._conditions; +}; + +/** + * Returns the current update operations as a JSON object. + * + * ####Example: + * + * var query = new Query(); + * query.update({}, { $set: { a: 5 } }); + * query.getUpdate(); // { $set: { a: 5 } } + * + * @return {Object} current update operations + * @api public + */ + +Query.prototype.getUpdate = function() { + return this._update; +}; + +/** + * Returns fields selection for this query. + * + * @method _fieldsForExec + * @return {Object} + * @api private + * @receiver Query + */ + +/** + * Return an update document with corrected $set operations. + * + * @method _updateForExec + * @api private + * @receiver Query + */ + +Query.prototype._updateForExec = function() { + var update = utils.clone(this._update, { retainKeyOrder: true }); + var ops = Object.keys(update); + var i = ops.length; + var ret = {}; + + while (i--) { + var op = ops[i]; + + if (this.options.overwrite) { + ret[op] = update[op]; + continue; + } + + if ('$' !== op[0]) { + // fix up $set sugar + if (!ret.$set) { + if (update.$set) { + ret.$set = update.$set; + } else { + ret.$set = {}; + } + } + ret.$set[op] = update[op]; + ops.splice(i, 1); + if (!~ops.indexOf('$set')) ops.push('$set'); + } else if ('$set' === op) { + if (!ret.$set) { + ret[op] = update[op]; + } + } else { + ret[op] = update[op]; + } + } + + this._compiledUpdate = ret; + return ret; +}; + +/** + * Makes sure _path is set. + * + * @method _ensurePath + * @param {String} method + * @api private + * @receiver Query + */ + +/** + * Determines if `conds` can be merged using `mquery().merge()` + * + * @method canMerge + * @memberOf Query + * @param {Object} conds + * @return {Boolean} + * @api private + */ + +/** + * Returns default options for this query. + * + * @param {Model} model + * @api private + */ + +Query.prototype._optionsForExec = function(model) { + var options = Query.base._optionsForExec.call(this); + + delete options.populate; + model = model || this.model; + + if (!model) { + return options; + } + + if (!('safe' in options) && model.schema.options.safe) { + options.safe = model.schema.options.safe; + } + + if (!('readPreference' in options) && model.schema.options.read) { + options.readPreference = model.schema.options.read; + } + + return options; +}; + +/** + * Sets the lean option. + * + * Documents returned from queries with the `lean` option enabled are plain javascript objects, not [MongooseDocuments](#document-js). They have no `save` method, getters/setters or other Mongoose magic applied. + * + * ####Example: + * + * new Query().lean() // true + * new Query().lean(true) + * new Query().lean(false) + * + * Model.find().lean().exec(function (err, docs) { + * docs[0] instanceof mongoose.Document // false + * }); + * + * This is a [great](https://groups.google.com/forum/#!topic/mongoose-orm/u2_DzDydcnA/discussion) option in high-performance read-only scenarios, especially when combined with [stream](#query_Query-stream). + * + * @param {Boolean} bool defaults to true + * @return {Query} this + * @api public + */ + +Query.prototype.lean = function(v) { + this._mongooseOptions.lean = arguments.length ? !!v : true; + return this; +}; + +/** + * Thunk around find() + * + * @param {Function} [callback] + * @return {Query} this + * @api private + */ +Query.prototype._find = function(callback) { + if (this._castError) { + callback(this._castError); + return this; + } + + this._applyPaths(); + this._fields = this._castFields(this._fields); + + var fields = this._fieldsForExec(); + var options = this._mongooseOptions; + var _this = this; + + var cb = function(err, docs) { + if (err) { + return callback(err); + } + + if (docs.length === 0) { + return callback(null, docs); + } + + if (!options.populate) { + return options.lean === true + ? callback(null, docs) + : completeMany(_this.model, docs, fields, _this, null, callback); + } + + var pop = helpers.preparePopulationOptionsMQ(_this, options); + pop.__noPromise = true; + _this.model.populate(docs, pop, function(err, docs) { + if (err) return callback(err); + return options.lean === true + ? callback(null, docs) + : completeMany(_this.model, docs, fields, _this, pop, callback); + }); + }; + + return Query.base.find.call(this, {}, cb); +}; + +/** + * Finds documents. + * + * When no `callback` is passed, the query is not executed. When the query is executed, the result will be an array of documents. + * + * ####Example + * + * query.find({ name: 'Los Pollos Hermanos' }).find(callback) + * + * @param {Object} [criteria] mongodb selector + * @param {Function} [callback] + * @return {Query} this + * @api public + */ + +Query.prototype.find = function(conditions, callback) { + if (typeof conditions === 'function') { + callback = conditions; + conditions = {}; + } + + conditions = utils.toObject(conditions); + + if (mquery.canMerge(conditions)) { + this.merge(conditions); + } + + prepareDiscriminatorCriteria(this); + + try { + this.cast(this.model); + this._castError = null; + } catch (err) { + this._castError = err; + } + + // if we don't have a callback, then just return the query object + if (!callback) { + return Query.base.find.call(this); + } + + this._find(callback); + + return this; +}; + +/*! + * hydrates many documents + * + * @param {Model} model + * @param {Array} docs + * @param {Object} fields + * @param {Query} self + * @param {Array} [pop] array of paths used in population + * @param {Function} callback + */ + +function completeMany(model, docs, fields, self, pop, callback) { + var arr = []; + var count = docs.length; + var len = count; + var opts = pop ? + {populated: pop} + : undefined; + function init(err) { + if (err) return callback(err); + --count || callback(null, arr); + } + for (var i = 0; i < len; ++i) { + arr[i] = helpers.createModel(model, docs[i], fields); + arr[i].init(docs[i], opts, init); + } +} + +/** + * Thunk around findOne() + * + * @param {Function} [callback] + * @see findOne http://docs.mongodb.org/manual/reference/method/db.collection.findOne/ + * @api private + */ + +Query.prototype._findOne = function(callback) { + if (this._castError) { + return callback(this._castError); + } + + this._applyPaths(); + this._fields = this._castFields(this._fields); + + var options = this._mongooseOptions; + var projection = this._fieldsForExec(); + var _this = this; + + // don't pass in the conditions because we already merged them in + Query.base.findOne.call(_this, {}, function(err, doc) { + if (err) { + return callback(err); + } + if (!doc) { + return callback(null, null); + } + + if (!options.populate) { + return options.lean === true + ? callback(null, doc) + : completeOne(_this.model, doc, null, projection, _this, null, callback); + } + + var pop = helpers.preparePopulationOptionsMQ(_this, options); + pop.__noPromise = true; + _this.model.populate(doc, pop, function(err, doc) { + if (err) { + return callback(err); + } + return options.lean === true + ? callback(null, doc) + : completeOne(_this.model, doc, null, projection, _this, pop, callback); + }); + }); +}; + +/** + * Declares the query a findOne operation. When executed, the first found document is passed to the callback. + * + * Passing a `callback` executes the query. The result of the query is a single document. + * + * * *Note:* `conditions` is optional, and if `conditions` is null or undefined, + * mongoose will send an empty `findOne` command to MongoDB, which will return + * an arbitrary document. If you're querying by `_id`, use `Model.findById()` + * instead. + * + * ####Example + * + * var query = Kitten.where({ color: 'white' }); + * query.findOne(function (err, kitten) { + * if (err) return handleError(err); + * if (kitten) { + * // doc may be null if no document matched + * } + * }); + * + * @param {Object|Query} [criteria] mongodb selector + * @param {Object} [projection] optional fields to return + * @param {Function} [callback] + * @return {Query} this + * @see findOne http://docs.mongodb.org/manual/reference/method/db.collection.findOne/ + * @see Query.select #query_Query-select + * @api public + */ + +Query.prototype.findOne = function(conditions, projection, options, callback) { + if (typeof conditions === 'function') { + callback = conditions; + conditions = null; + projection = null; + options = null; + } else if (typeof projection === 'function') { + callback = projection; + options = null; + projection = null; + } else if (typeof options === 'function') { + callback = options; + options = null; + } + + // make sure we don't send in the whole Document to merge() + conditions = utils.toObject(conditions); + + this.op = 'findOne'; + + if (options) { + this.setOptions(options); + } + + if (projection) { + this.select(projection); + } + + if (mquery.canMerge(conditions)) { + this.merge(conditions); + } else if (conditions != null) { + throw new Error('Invalid argument to findOne(): ' + + util.inspect(conditions)); + } + + prepareDiscriminatorCriteria(this); + + try { + this.cast(this.model); + this._castError = null; + } catch (err) { + this._castError = err; + } + + if (!callback) { + // already merged in the conditions, don't need to send them in. + return Query.base.findOne.call(this); + } + + this._findOne(callback); + + return this; +}; + +/** + * Thunk around count() + * + * @param {Function} [callback] + * @see count http://docs.mongodb.org/manual/reference/method/db.collection.count/ + * @api private + */ + +Query.prototype._count = function(callback) { + try { + this.cast(this.model); + } catch (err) { + process.nextTick(function() { + callback(err); + }); + return this; + } + + var conds = this._conditions; + var options = this._optionsForExec(); + + this._collection.count(conds, options, utils.tick(callback)); +}; + +/** + * Specifying this query as a `count` query. + * + * Passing a `callback` executes the query. + * + * ####Example: + * + * var countQuery = model.where({ 'color': 'black' }).count(); + * + * query.count({ color: 'black' }).count(callback) + * + * query.count({ color: 'black' }, callback) + * + * query.where('color', 'black').count(function (err, count) { + * if (err) return handleError(err); + * console.log('there are %d kittens', count); + * }) + * + * @param {Object} [criteria] mongodb selector + * @param {Function} [callback] + * @return {Query} this + * @see count http://docs.mongodb.org/manual/reference/method/db.collection.count/ + * @api public + */ + +Query.prototype.count = function(conditions, callback) { + if (typeof conditions === 'function') { + callback = conditions; + conditions = undefined; + } + + if (mquery.canMerge(conditions)) { + this.merge(conditions); + } + + this.op = 'count'; + if (!callback) { + return this; + } + + this._count(callback); + + return this; +}; + +/** + * Declares or executes a distict() operation. + * + * Passing a `callback` executes the query. + * + * ####Example + * + * distinct(field, conditions, callback) + * distinct(field, conditions) + * distinct(field, callback) + * distinct(field) + * distinct(callback) + * distinct() + * + * @param {String} [field] + * @param {Object|Query} [criteria] + * @param {Function} [callback] + * @return {Query} this + * @see distinct http://docs.mongodb.org/manual/reference/method/db.collection.distinct/ + * @api public + */ + +Query.prototype.distinct = function(field, conditions, callback) { + if (!callback) { + if (typeof conditions === 'function') { + callback = conditions; + conditions = undefined; + } else if (typeof field === 'function') { + callback = field; + field = undefined; + conditions = undefined; + } + } + + conditions = utils.toObject(conditions); + + if (mquery.canMerge(conditions)) { + this.merge(conditions); + } + + try { + this.cast(this.model); + } catch (err) { + if (!callback) { + throw err; + } + callback(err); + return this; + } + + return Query.base.distinct.call(this, {}, field, callback); +}; + +/** + * Sets the sort order + * + * If an object is passed, values allowed are `asc`, `desc`, `ascending`, `descending`, `1`, and `-1`. + * + * If a string is passed, it must be a space delimited list of path names. The + * sort order of each path is ascending unless the path name is prefixed with `-` + * which will be treated as descending. + * + * ####Example + * + * // sort by "field" ascending and "test" descending + * query.sort({ field: 'asc', test: -1 }); + * + * // equivalent + * query.sort('field -test'); + * + * ####Note + * + * Cannot be used with `distinct()` + * + * @param {Object|String} arg + * @return {Query} this + * @see cursor.sort http://docs.mongodb.org/manual/reference/method/cursor.sort/ + * @api public + */ + +Query.prototype.sort = function(arg) { + var nArg = {}; + + if (arguments.length > 1) { + throw new Error('sort() only takes 1 Argument'); + } + + if (Array.isArray(arg)) { + // time to deal with the terrible syntax + for (var i = 0; i < arg.length; i++) { + if (!Array.isArray(arg[i])) throw new Error('Invalid sort() argument.'); + nArg[arg[i][0]] = arg[i][1]; + } + } else { + nArg = arg; + } + + return Query.base.sort.call(this, nArg); +}; + +/** + * Declare and/or execute this query as a remove() operation. + * + * ####Example + * + * Model.remove({ artist: 'Anne Murray' }, callback) + * + * ####Note + * + * The operation is only executed when a callback is passed. To force execution without a callback, you must first call `remove()` and then execute it by using the `exec()` method. + * + * // not executed + * var query = Model.find().remove({ name: 'Anne Murray' }) + * + * // executed + * query.remove({ name: 'Anne Murray' }, callback) + * query.remove({ name: 'Anne Murray' }).remove(callback) + * + * // executed without a callback + * query.exec() + * + * // summary + * query.remove(conds, fn); // executes + * query.remove(conds) + * query.remove(fn) // executes + * query.remove() + * + * @param {Object|Query} [criteria] mongodb selector + * @param {Function} [callback] + * @return {Query} this + * @see remove http://docs.mongodb.org/manual/reference/method/db.collection.remove/ + * @api public + */ + +Query.prototype.remove = function(cond, callback) { + if (typeof cond === 'function') { + callback = cond; + cond = null; + } + + var cb = typeof callback === 'function'; + + try { + this.cast(this.model); + } catch (err) { + if (cb) return process.nextTick(callback.bind(null, err)); + return this; + } + + return Query.base.remove.call(this, cond, callback); +}; + +/*! + * hydrates a document + * + * @param {Model} model + * @param {Document} doc + * @param {Object} res 3rd parameter to callback + * @param {Object} fields + * @param {Query} self + * @param {Array} [pop] array of paths used in population + * @param {Function} callback + */ + +function completeOne(model, doc, res, fields, self, pop, callback) { + var opts = pop ? + {populated: pop} + : undefined; + + var casted = helpers.createModel(model, doc, fields); + casted.init(doc, opts, function(err) { + if (err) { + return callback(err); + } + if (res) { + return callback(null, casted, res); + } + callback(null, casted); + }); +} + +/*! + * If the model is a discriminator type and not root, then add the key & value to the criteria. + */ + +function prepareDiscriminatorCriteria(query) { + if (!query || !query.model || !query.model.schema) { + return; + } + + var schema = query.model.schema; + + if (schema && schema.discriminatorMapping && !schema.discriminatorMapping.isRoot) { + query._conditions[schema.discriminatorMapping.key] = schema.discriminatorMapping.value; + } +} + +/** + * Issues a mongodb [findAndModify](http://www.mongodb.org/display/DOCS/findAndModify+Command) update command. + * + * Finds a matching document, updates it according to the `update` arg, passing any `options`, and returns the found document (if any) to the callback. The query executes immediately if `callback` is passed. + * + * ####Available options + * + * - `new`: bool - if true, return the modified document rather than the original. defaults to false (changed in 4.0) + * - `upsert`: bool - creates the object if it doesn't exist. defaults to false. + * - `fields`: {Object|String} - Field selection. Equivalent to `.select(fields).findOneAndUpdate()` + * - `sort`: if multiple docs are found by the conditions, sets the sort order to choose which doc to update + * - `maxTimeMS`: puts a time limit on the query - requires mongodb >= 2.6.0 + * - `runValidators`: if true, runs [update validators](/docs/validation.html#update-validators) on this command. Update validators validate the update operation against the model's schema. + * - `setDefaultsOnInsert`: if this and `upsert` are true, mongoose will apply the [defaults](http://mongoosejs.com/docs/defaults.html) specified in the model's schema if a new document is created. This option only works on MongoDB >= 2.4 because it relies on [MongoDB's `$setOnInsert` operator](https://docs.mongodb.org/v2.4/reference/operator/update/setOnInsert/). + * - `passRawResult`: if true, passes the [raw result from the MongoDB driver as the third callback parameter](http://mongodb.github.io/node-mongodb-native/2.0/api/Collection.html#findAndModify) + * - `context` (string) if set to 'query' and `runValidators` is on, `this` will refer to the query in custom validator functions that update validation runs. Does nothing if `runValidators` is false. + * + * ####Callback Signature + * function(error, doc) { + * // error: any errors that occurred + * // doc: the document before updates are applied if `new: false`, or after updates if `new = true` + * } + * + * ####Examples + * + * query.findOneAndUpdate(conditions, update, options, callback) // executes + * query.findOneAndUpdate(conditions, update, options) // returns Query + * query.findOneAndUpdate(conditions, update, callback) // executes + * query.findOneAndUpdate(conditions, update) // returns Query + * query.findOneAndUpdate(update, callback) // returns Query + * query.findOneAndUpdate(update) // returns Query + * query.findOneAndUpdate(callback) // executes + * query.findOneAndUpdate() // returns Query + * + * @method findOneAndUpdate + * @memberOf Query + * @param {Object|Query} [query] + * @param {Object} [doc] + * @param {Object} [options] + * @param {Function} [callback] + * @see mongodb http://www.mongodb.org/display/DOCS/findAndModify+Command + * @return {Query} this + * @api public + */ + +Query.prototype.findOneAndUpdate = function(criteria, doc, options, callback) { + this.op = 'findOneAndUpdate'; + this._validate(); + + switch (arguments.length) { + case 3: + if (typeof options === 'function') { + callback = options; + options = {}; + } + break; + case 2: + if (typeof doc === 'function') { + callback = doc; + doc = criteria; + criteria = undefined; + } + options = undefined; + break; + case 1: + if (typeof criteria === 'function') { + callback = criteria; + criteria = options = doc = undefined; + } else { + doc = criteria; + criteria = options = undefined; + } + } + + if (mquery.canMerge(criteria)) { + this.merge(criteria); + } + + // apply doc + if (doc) { + this._mergeUpdate(doc); + } + + if (options) { + options = utils.clone(options, { retainKeyOrder: true }); + if (options.projection) { + this.select(options.projection); + delete options.projection; + } + if (options.fields) { + this.select(options.fields); + delete options.fields; + } + + this.setOptions(options); + } + + if (!callback) { + return this; + } + + return this._findOneAndUpdate(callback); +}; + +/** + * Thunk around findOneAndUpdate() + * + * @param {Function} [callback] + * @api private + */ + +Query.prototype._findOneAndUpdate = function(callback) { + this._findAndModify('update', callback); + return this; +}; + +/** + * Issues a mongodb [findAndModify](http://www.mongodb.org/display/DOCS/findAndModify+Command) remove command. + * + * Finds a matching document, removes it, passing the found document (if any) to the callback. Executes immediately if `callback` is passed. + * + * ####Available options + * + * - `sort`: if multiple docs are found by the conditions, sets the sort order to choose which doc to update + * - `maxTimeMS`: puts a time limit on the query - requires mongodb >= 2.6.0 + * - `passRawResult`: if true, passes the [raw result from the MongoDB driver as the third callback parameter](http://mongodb.github.io/node-mongodb-native/2.0/api/Collection.html#findAndModify) + * + * ####Callback Signature + * function(error, doc, result) { + * // error: any errors that occurred + * // doc: the document before updates are applied if `new: false`, or after updates if `new = true` + * // result: [raw result from the MongoDB driver](http://mongodb.github.io/node-mongodb-native/2.0/api/Collection.html#findAndModify) + * } + * + * ####Examples + * + * A.where().findOneAndRemove(conditions, options, callback) // executes + * A.where().findOneAndRemove(conditions, options) // return Query + * A.where().findOneAndRemove(conditions, callback) // executes + * A.where().findOneAndRemove(conditions) // returns Query + * A.where().findOneAndRemove(callback) // executes + * A.where().findOneAndRemove() // returns Query + * + * @method findOneAndRemove + * @memberOf Query + * @param {Object} [conditions] + * @param {Object} [options] + * @param {Function} [callback] + * @return {Query} this + * @see mongodb http://www.mongodb.org/display/DOCS/findAndModify+Command + * @api public + */ + +Query.prototype.findOneAndRemove = function(conditions, options, callback) { + this.op = 'findOneAndRemove'; + this._validate(); + + switch (arguments.length) { + case 2: + if (typeof options === 'function') { + callback = options; + options = {}; + } + break; + case 1: + if (typeof conditions === 'function') { + callback = conditions; + conditions = undefined; + options = undefined; + } + break; + } + + if (mquery.canMerge(conditions)) { + this.merge(conditions); + } + + options && this.setOptions(options); + + if (!callback) { + return this; + } + + this._findOneAndRemove(callback); + + return this; +}; + +/** + * Thunk around findOneAndRemove() + * + * @param {Function} [callback] + * @return {Query} this + * @api private + */ +Query.prototype._findOneAndRemove = function(callback) { + Query.base.findOneAndRemove.call(this, callback); +}; + +/** + * Override mquery.prototype._findAndModify to provide casting etc. + * + * @param {String} type - either "remove" or "update" + * @param {Function} callback + * @api private + */ + +Query.prototype._findAndModify = function(type, callback) { + if (typeof callback !== 'function') { + throw new Error('Expected callback in _findAndModify'); + } + + var model = this.model; + var schema = model.schema; + var _this = this; + var castedQuery; + var castedDoc; + var fields; + var opts; + var doValidate; + + castedQuery = castQuery(this); + if (castedQuery instanceof Error) { + return callback(castedQuery); + } + + opts = this._optionsForExec(model); + + if ('strict' in opts) { + this._mongooseOptions.strict = opts.strict; + } + + if (type === 'remove') { + opts.remove = true; + } else { + if (!('new' in opts)) { + opts.new = false; + } + if (!('upsert' in opts)) { + opts.upsert = false; + } + if (opts.upsert || opts['new']) { + opts.remove = false; + } + + castedDoc = castDoc(this, opts.overwrite); + castedDoc = setDefaultsOnInsert(this, schema, castedDoc, opts); + if (!castedDoc) { + if (opts.upsert) { + // still need to do the upsert to empty doc + var doc = utils.clone(castedQuery); + delete doc._id; + castedDoc = {$set: doc}; + } else { + return this.findOne(callback); + } + } else if (castedDoc instanceof Error) { + return callback(castedDoc); + } else { + // In order to make MongoDB 2.6 happy (see + // https://jira.mongodb.org/browse/SERVER-12266 and related issues) + // if we have an actual update document but $set is empty, junk the $set. + if (castedDoc.$set && Object.keys(castedDoc.$set).length === 0) { + delete castedDoc.$set; + } + } + + doValidate = updateValidators(this, schema, castedDoc, opts); + } + + this._applyPaths(); + + var options = this._mongooseOptions; + + if (this._fields) { + fields = utils.clone(this._fields); + opts.fields = this._castFields(fields); + if (opts.fields instanceof Error) { + return callback(opts.fields); + } + } + + if (opts.sort) convertSortToArray(opts); + + var cb = function(err, doc, res) { + if (err) { + return callback(err); + } + + if (!doc || (utils.isObject(doc) && Object.keys(doc).length === 0)) { + if (opts.passRawResult) { + return callback(null, null, res); + } + return callback(null, null); + } + + if (!opts.passRawResult) { + res = null; + } + + if (!options.populate) { + return options.lean === true + ? callback(null, doc) + : completeOne(_this.model, doc, res, fields, _this, null, callback); + } + + var pop = helpers.preparePopulationOptionsMQ(_this, options); + pop.__noPromise = true; + _this.model.populate(doc, pop, function(err, doc) { + if (err) { + return callback(err); + } + + return options.lean === true + ? callback(null, doc) + : completeOne(_this.model, doc, res, fields, _this, pop, callback); + }); + }; + + if (opts.runValidators && doValidate) { + var _callback = function(error) { + if (error) { + return callback(error); + } + _this._collection.findAndModify(castedQuery, castedDoc, opts, utils.tick(function(error, res) { + return cb(error, res ? res.value : res, res); + })); + }; + + try { + doValidate(_callback); + } catch (error) { + callback(error); + } + } else { + this._collection.findAndModify(castedQuery, castedDoc, opts, utils.tick(function(error, res) { + return cb(error, res ? res.value : res, res); + })); + } + + return this; +}; + +/** + * Override mquery.prototype._mergeUpdate to handle mongoose objects in + * updates. + * + * @param {Object} doc + * @api private + */ + +Query.prototype._mergeUpdate = function(doc) { + if (!this._update) this._update = {}; + if (doc instanceof Query) { + if (doc._update) { + utils.mergeClone(this._update, doc._update); + } + } else { + utils.mergeClone(this._update, doc); + } +}; + +/*! + * The mongodb driver 1.3.23 only supports the nested array sort + * syntax. We must convert it or sorting findAndModify will not work. + */ + +function convertSortToArray(opts) { + if (Array.isArray(opts.sort)) { + return; + } + if (!utils.isObject(opts.sort)) { + return; + } + + var sort = []; + + for (var key in opts.sort) { + if (utils.object.hasOwnProperty(opts.sort, key)) { + sort.push([key, opts.sort[key]]); + } + } + + opts.sort = sort; +} + +/** + * Internal thunk for .update() + * + * @param {Function} callback + * @see Model.update #model_Model.update + * @api private + */ +Query.prototype._execUpdate = function(callback) { + var schema = this.model.schema; + var doValidate; + var _this; + + var castedQuery = this._conditions; + var castedDoc = this._update; + var options = this.options; + + if (this._castError) { + callback(this._castError); + return this; + } + + if (this.options.runValidators) { + _this = this; + doValidate = updateValidators(this, schema, castedDoc, options); + var _callback = function(err) { + if (err) { + return callback(err); + } + + Query.base.update.call(_this, castedQuery, castedDoc, options, callback); + }; + try { + doValidate(_callback); + } catch (err) { + process.nextTick(function() { + callback(err); + }); + } + return this; + } + + Query.base.update.call(this, castedQuery, castedDoc, options, callback); + return this; +}; + +/** + * Declare and/or execute this query as an update() operation. + * + * _All paths passed that are not $atomic operations will become $set ops._ + * + * ####Example + * + * Model.where({ _id: id }).update({ title: 'words' }) + * + * // becomes + * + * Model.where({ _id: id }).update({ $set: { title: 'words' }}) + * + * ####Valid options: + * + * - `safe` (boolean) safe mode (defaults to value set in schema (true)) + * - `upsert` (boolean) whether to create the doc if it doesn't match (false) + * - `multi` (boolean) whether multiple documents should be updated (false) + * - `runValidators`: if true, runs [update validators](/docs/validation.html#update-validators) on this command. Update validators validate the update operation against the model's schema. + * - `setDefaultsOnInsert`: if this and `upsert` are true, mongoose will apply the [defaults](http://mongoosejs.com/docs/defaults.html) specified in the model's schema if a new document is created. This option only works on MongoDB >= 2.4 because it relies on [MongoDB's `$setOnInsert` operator](https://docs.mongodb.org/v2.4/reference/operator/update/setOnInsert/). + * - `strict` (boolean) overrides the `strict` option for this update + * - `overwrite` (boolean) disables update-only mode, allowing you to overwrite the doc (false) + * - `context` (string) if set to 'query' and `runValidators` is on, `this` will refer to the query in custom validator functions that update validation runs. Does nothing if `runValidators` is false. + * + * ####Note + * + * Passing an empty object `{}` as the doc will result in a no-op unless the `overwrite` option is passed. Without the `overwrite` option set, the update operation will be ignored and the callback executed without sending the command to MongoDB so as to prevent accidently overwritting documents in the collection. + * + * ####Note + * + * The operation is only executed when a callback is passed. To force execution without a callback, we must first call update() and then execute it by using the `exec()` method. + * + * var q = Model.where({ _id: id }); + * q.update({ $set: { name: 'bob' }}).update(); // not executed + * + * q.update({ $set: { name: 'bob' }}).exec(); // executed + * + * // keys that are not $atomic ops become $set. + * // this executes the same command as the previous example. + * q.update({ name: 'bob' }).exec(); + * + * // overwriting with empty docs + * var q = Model.where({ _id: id }).setOptions({ overwrite: true }) + * q.update({ }, callback); // executes + * + * // multi update with overwrite to empty doc + * var q = Model.where({ _id: id }); + * q.setOptions({ multi: true, overwrite: true }) + * q.update({ }); + * q.update(callback); // executed + * + * // multi updates + * Model.where() + * .update({ name: /^match/ }, { $set: { arr: [] }}, { multi: true }, callback) + * + * // more multi updates + * Model.where() + * .setOptions({ multi: true }) + * .update({ $set: { arr: [] }}, callback) + * + * // single update by default + * Model.where({ email: 'address@example.com' }) + * .update({ $inc: { counter: 1 }}, callback) + * + * API summary + * + * update(criteria, doc, options, cb) // executes + * update(criteria, doc, options) + * update(criteria, doc, cb) // executes + * update(criteria, doc) + * update(doc, cb) // executes + * update(doc) + * update(cb) // executes + * update(true) // executes + * update() + * + * @param {Object} [criteria] + * @param {Object} [doc] the update command + * @param {Object} [options] + * @param {Function} [callback] + * @return {Query} this + * @see Model.update #model_Model.update + * @see update http://docs.mongodb.org/manual/reference/method/db.collection.update/ + * @api public + */ + +Query.prototype.update = function(conditions, doc, options, callback) { + if (typeof options === 'function') { + // .update(conditions, doc, callback) + callback = options; + options = null; + } else if (typeof doc === 'function') { + // .update(doc, callback); + callback = doc; + doc = conditions; + conditions = {}; + options = null; + } else if (typeof conditions === 'function') { + // .update(callback) + callback = conditions; + conditions = undefined; + doc = undefined; + options = undefined; + } else if (typeof conditions === 'object' && !doc && !options && !callback) { + // .update(doc) + doc = conditions; + conditions = undefined; + options = undefined; + callback = undefined; + } + + // make sure we don't send in the whole Document to merge() + conditions = utils.toObject(conditions); + + var oldCb = callback; + if (oldCb) { + if (typeof oldCb === 'function') { + callback = function(error, result) { + oldCb(error, result ? result.result : {ok: 0, n: 0, nModified: 0}); + }; + } else { + throw new Error('Invalid callback() argument.'); + } + } + + // strict is an option used in the update checking, make sure it gets set + if (options) { + if ('strict' in options) { + this._mongooseOptions.strict = options.strict; + } + } + + // if doc is undefined at this point, this means this function is being + // executed by exec(not always see below). Grab the update doc from here in + // order to validate + // This could also be somebody calling update() or update({}). Probably not a + // common use case, check for _update to make sure we don't do anything bad + if (!doc && this._update) { + doc = this._updateForExec(); + } + + if (mquery.canMerge(conditions)) { + this.merge(conditions); + } + + // validate the selector part of the query + var castedQuery = castQuery(this); + if (castedQuery instanceof Error) { + this._castError = castedQuery; + if (callback) { + callback(castedQuery); + return this; + } else if (!options || !options.dontThrowCastError) { + throw castedQuery; + } + } + + // validate the update part of the query + var castedDoc; + try { + var $options = {retainKeyOrder: true}; + if (options && options.minimize) { + $options.minimize = true; + } + castedDoc = this._castUpdate(utils.clone(doc, $options), + options && options.overwrite); + } catch (err) { + this._castError = castedQuery; + if (callback) { + callback(err); + return this; + } else if (!options || !options.dontThrowCastError) { + throw err; + } + } + + castedDoc = setDefaultsOnInsert(this, this.schema, castedDoc, options); + if (!castedDoc) { + // Make sure promises know that this is still an update, see gh-2796 + this.op = 'update'; + callback && callback(null); + return this; + } + + if (utils.isObject(options)) { + this.setOptions(options); + } + + if (!this._update) this._update = castedDoc; + + // Hooks + if (callback) { + return this._execUpdate(callback); + } + + return Query.base.update.call(this, castedQuery, castedDoc, options, callback); +}; + +/** + * Executes the query + * + * ####Examples: + * + * var promise = query.exec(); + * var promise = query.exec('update'); + * + * query.exec(callback); + * query.exec('find', callback); + * + * @param {String|Function} [operation] + * @param {Function} [callback] + * @return {Promise} + * @api public + */ + +Query.prototype.exec = function exec(op, callback) { + var Promise = PromiseProvider.get(); + var _this = this; + + if (typeof op === 'function') { + callback = op; + op = null; + } else if (typeof op === 'string') { + this.op = op; + } + + var _results; + var promise = new Promise.ES6(function(resolve, reject) { + if (!_this.op) { + resolve(); + return; + } + + _this[_this.op].call(_this, function(error, res) { + if (error) { + reject(error); + return; + } + _results = arguments; + resolve(res); + }); + }); + + if (callback) { + promise.then( + function() { + callback.apply(null, _results); + }, + function(error) { + callback(error); + }). + catch(function(error) { + // If we made it here, we must have an error in the callback re: + // gh-4500, so we need to emit. + setImmediate(function() { + _this.model.emit('error', error); + }); + }); + } + + return promise; +}; + +/** + * Executes the query returning a `Promise` which will be + * resolved with either the doc(s) or rejected with the error. + * + * @param {Function} [resolve] + * @param {Function} [reject] + * @return {Promise} + * @api public + */ + +Query.prototype.then = function(resolve, reject) { + return this.exec().then(resolve, reject); +}; + +/** + * Executes the query returning a `Promise` which will be + * resolved with either the doc(s) or rejected with the error. + * Like `.then()`, but only takes a rejection handler. + * + * @param {Function} [reject] + * @return {Promise} + * @api public + */ + +Query.prototype.catch = function(reject) { + return this.exec().then(null, reject); +}; + +/** + * Finds the schema for `path`. This is different than + * calling `schema.path` as it also resolves paths with + * positional selectors (something.$.another.$.path). + * + * @param {String} path + * @api private + */ + +Query.prototype._getSchema = function _getSchema(path) { + return this.model._getSchema(path); +}; + +/*! + * These operators require casting docs + * to real Documents for Update operations. + */ + +var castOps = { + $push: 1, + $pushAll: 1, + $addToSet: 1, + $set: 1 +}; + +/*! + * These operators should be cast to numbers instead + * of their path schema type. + */ + +var numberOps = { + $pop: 1, + $unset: 1, + $inc: 1 +}; + +/** + * Casts obj for an update command. + * + * @param {Object} obj + * @return {Object} obj after casting its values + * @api private + */ + +Query.prototype._castUpdate = function _castUpdate(obj, overwrite) { + if (!obj) { + return undefined; + } + + var ops = Object.keys(obj); + var i = ops.length; + var ret = {}; + var hasKeys; + var val; + var hasDollarKey = false; + + while (i--) { + var op = ops[i]; + // if overwrite is set, don't do any of the special $set stuff + if (op[0] !== '$' && !overwrite) { + // fix up $set sugar + if (!ret.$set) { + if (obj.$set) { + ret.$set = obj.$set; + } else { + ret.$set = {}; + } + } + ret.$set[op] = obj[op]; + ops.splice(i, 1); + if (!~ops.indexOf('$set')) ops.push('$set'); + } else if (op === '$set') { + if (!ret.$set) { + ret[op] = obj[op]; + } + } else { + ret[op] = obj[op]; + } + } + + // cast each value + i = ops.length; + + // if we get passed {} for the update, we still need to respect that when it + // is an overwrite scenario + if (overwrite) { + hasKeys = true; + } + + while (i--) { + op = ops[i]; + val = ret[op]; + hasDollarKey = hasDollarKey || op.charAt(0) === '$'; + if (val && + val.constructor.name === 'Object' && + (!overwrite || hasDollarKey)) { + hasKeys |= this._walkUpdatePath(val, op); + } else if (overwrite && ret.constructor.name === 'Object') { + // if we are just using overwrite, cast the query and then we will + // *always* return the value, even if it is an empty object. We need to + // set hasKeys above because we need to account for the case where the + // user passes {} and wants to clobber the whole document + // Also, _walkUpdatePath expects an operation, so give it $set since that + // is basically what we're doing + this._walkUpdatePath(ret, '$set'); + } else { + var msg = 'Invalid atomic update value for ' + op + '. ' + + 'Expected an object, received ' + typeof val; + throw new Error(msg); + } + } + + return hasKeys && ret; +}; + +/** + * Walk each path of obj and cast its values + * according to its schema. + * + * @param {Object} obj - part of a query + * @param {String} op - the atomic operator ($pull, $set, etc) + * @param {String} pref - path prefix (internal only) + * @return {Bool} true if this path has keys to update + * @api private + */ + +Query.prototype._walkUpdatePath = function _walkUpdatePath(obj, op, pref) { + var prefix = pref ? pref + '.' : '', + keys = Object.keys(obj), + i = keys.length, + hasKeys = false, + schema, + key, + val; + + var useNestedStrict = this.schema.options.useNestedStrict; + + while (i--) { + key = keys[i]; + val = obj[key]; + + if (val && val.constructor.name === 'Object') { + // watch for embedded doc schemas + schema = this._getSchema(prefix + key); + if (schema && schema.caster && op in castOps) { + // embedded doc schema + hasKeys = true; + + if ('$each' in val) { + obj[key] = { + $each: this._castUpdateVal(schema, val.$each, op) + }; + + if (val.$slice != null) { + obj[key].$slice = val.$slice | 0; + } + + if (val.$sort) { + obj[key].$sort = val.$sort; + } + + if (!!val.$position || val.$position === 0) { + obj[key].$position = val.$position; + } + } else { + obj[key] = this._castUpdateVal(schema, val, op); + } + } else if (op === '$currentDate') { + // $currentDate can take an object + obj[key] = this._castUpdateVal(schema, val, op); + hasKeys = true; + } else if (op === '$set' && schema) { + obj[key] = this._castUpdateVal(schema, val, op); + hasKeys = true; + } else { + var pathToCheck = (prefix + key); + var v = this.model.schema._getPathType(pathToCheck); + var _strict = 'strict' in this._mongooseOptions ? + this._mongooseOptions.strict : + ((useNestedStrict && v.schema) || this.schema).options.strict; + if (v.pathType === 'undefined') { + if (_strict === 'throw') { + throw new StrictModeError(pathToCheck); + } else if (_strict) { + delete obj[key]; + continue; + } + } + + // gh-2314 + // we should be able to set a schema-less field + // to an empty object literal + hasKeys |= this._walkUpdatePath(val, op, prefix + key) || + (utils.isObject(val) && Object.keys(val).length === 0); + } + } else { + var checkPath = (key === '$each' || key === '$or' || key === '$and') ? + pref : prefix + key; + schema = this._getSchema(checkPath); + + var pathDetails = this.model.schema._getPathType(checkPath); + var isStrict = 'strict' in this._mongooseOptions ? + this._mongooseOptions.strict : + ((useNestedStrict && pathDetails.schema) || this.schema).options.strict; + + var skip = isStrict && + !schema && + !/real|nested/.test(pathDetails.pathType); + + if (skip) { + if (isStrict === 'throw') { + throw new StrictModeError(prefix + key); + } else { + delete obj[key]; + } + } else { + // gh-1845 temporary fix: ignore $rename. See gh-3027 for tracking + // improving this. + if (op === '$rename') { + hasKeys = true; + continue; + } + + hasKeys = true; + obj[key] = this._castUpdateVal(schema, val, op, key); + } + } + } + return hasKeys; +}; + +/** + * Casts `val` according to `schema` and atomic `op`. + * + * @param {Schema} schema + * @param {Object} val + * @param {String} op - the atomic operator ($pull, $set, etc) + * @param {String} [$conditional] + * @api private + */ + +Query.prototype._castUpdateVal = function _castUpdateVal(schema, val, op, $conditional) { + if (!schema) { + // non-existing schema path + return op in numberOps + ? Number(val) + : val; + } + + var cond = schema.caster && op in castOps && + (utils.isObject(val) || Array.isArray(val)); + if (cond) { + // Cast values for ops that add data to MongoDB. + // Ensures embedded documents get ObjectIds etc. + var tmp = schema.cast(val); + if (Array.isArray(val)) { + val = tmp; + } else if (schema.caster.$isSingleNested) { + val = tmp; + } else { + val = tmp[0]; + } + } + + if (op in numberOps) { + if (op === '$inc') { + return schema.castForQuery(val); + } + return Number(val); + } + if (op === '$currentDate') { + if (typeof val === 'object') { + return {$type: val.$type}; + } + return Boolean(val); + } + if (/^\$/.test($conditional)) { + return schema.castForQuery($conditional, val); + } + + return schema.castForQuery(val); +}; + +/*! + * castQuery + * @api private + */ + +function castQuery(query) { + try { + return query.cast(query.model); + } catch (err) { + return err; + } +} + +/*! + * castDoc + * @api private + */ + +function castDoc(query, overwrite) { + try { + return query._castUpdate(query._update, overwrite); + } catch (err) { + return err; + } +} + +/** + * Specifies paths which should be populated with other documents. + * + * ####Example: + * + * Kitten.findOne().populate('owner').exec(function (err, kitten) { + * console.log(kitten.owner.name) // Max + * }) + * + * Kitten.find().populate({ + * path: 'owner' + * , select: 'name' + * , match: { color: 'black' } + * , options: { sort: { name: -1 }} + * }).exec(function (err, kittens) { + * console.log(kittens[0].owner.name) // Zoopa + * }) + * + * // alternatively + * Kitten.find().populate('owner', 'name', null, {sort: { name: -1 }}).exec(function (err, kittens) { + * console.log(kittens[0].owner.name) // Zoopa + * }) + * + * Paths are populated after the query executes and a response is received. A separate query is then executed for each path specified for population. After a response for each query has also been returned, the results are passed to the callback. + * + * @param {Object|String} path either the path to populate or an object specifying all parameters + * @param {Object|String} [select] Field selection for the population query + * @param {Model} [model] The model you wish to use for population. If not specified, populate will look up the model by the name in the Schema's `ref` field. + * @param {Object} [match] Conditions for the population query + * @param {Object} [options] Options for the population query (sort, etc) + * @see population ./populate.html + * @see Query#select #query_Query-select + * @see Model.populate #model_Model.populate + * @return {Query} this + * @api public + */ + +Query.prototype.populate = function() { + var res = utils.populate.apply(null, arguments); + var opts = this._mongooseOptions; + + if (!utils.isObject(opts.populate)) { + opts.populate = {}; + } + + var pop = opts.populate; + + for (var i = 0; i < res.length; ++i) { + var path = res[i].path; + if (pop[path] && pop[path].populate && res[i].populate) { + res[i].populate = pop[path].populate.concat(res[i].populate); + } + pop[res[i].path] = res[i]; + } + + return this; +}; + +/** + * Casts this query to the schema of `model` + * + * ####Note + * + * If `obj` is present, it is cast instead of this query. + * + * @param {Model} model + * @param {Object} [obj] + * @return {Object} + * @api public + */ + +Query.prototype.cast = function(model, obj) { + obj || (obj = this._conditions); + + return cast(model.schema, obj); +}; + +/** + * Casts selected field arguments for field selection with mongo 2.2 + * + * query.select({ ids: { $elemMatch: { $in: [hexString] }}) + * + * @param {Object} fields + * @see https://github.com/Automattic/mongoose/issues/1091 + * @see http://docs.mongodb.org/manual/reference/projection/elemMatch/ + * @api private + */ + +Query.prototype._castFields = function _castFields(fields) { + var selected, + elemMatchKeys, + keys, + key, + out, + i; + + if (fields) { + keys = Object.keys(fields); + elemMatchKeys = []; + i = keys.length; + + // collect $elemMatch args + while (i--) { + key = keys[i]; + if (fields[key].$elemMatch) { + selected || (selected = {}); + selected[key] = fields[key]; + elemMatchKeys.push(key); + } + } + } + + if (selected) { + // they passed $elemMatch, cast em + try { + out = this.cast(this.model, selected); + } catch (err) { + return err; + } + + // apply the casted field args + i = elemMatchKeys.length; + while (i--) { + key = elemMatchKeys[i]; + fields[key] = out[key]; + } + } + + return fields; +}; + +/** + * Applies schematype selected options to this query. + * @api private + */ + +Query.prototype._applyPaths = function applyPaths() { + // determine if query is selecting or excluding fields + + var fields = this._fields, + exclude, + keys, + ki; + + if (fields) { + keys = Object.keys(fields); + ki = keys.length; + + while (ki--) { + if (keys[ki][0] === '+') continue; + exclude = fields[keys[ki]] === 0; + break; + } + } + + // if selecting, apply default schematype select:true fields + // if excluding, apply schematype select:false fields + + var selected = [], + excluded = [], + seen = []; + + var analyzePath = function(path, type) { + if (typeof type.selected !== 'boolean') return; + + var plusPath = '+' + path; + if (fields && plusPath in fields) { + // forced inclusion + delete fields[plusPath]; + + // if there are other fields being included, add this one + // if no other included fields, leave this out (implied inclusion) + if (exclude === false && keys.length > 1 && !~keys.indexOf(path)) { + fields[path] = 1; + } + + return; + } + + // check for parent exclusions + var root = path.split('.')[0]; + if (~excluded.indexOf(root)) return; + + (type.selected ? selected : excluded).push(path); + }; + + var analyzeSchema = function(schema, prefix) { + prefix || (prefix = ''); + + // avoid recursion + if (~seen.indexOf(schema)) return; + seen.push(schema); + + schema.eachPath(function(path, type) { + if (prefix) path = prefix + '.' + path; + + analyzePath(path, type); + + // array of subdocs? + if (type.schema) { + analyzeSchema(type.schema, path); + } + }); + }; + + analyzeSchema(this.model.schema); + + switch (exclude) { + case true: + excluded.length && this.select('-' + excluded.join(' -')); + break; + case false: + if (this.model.schema && this.model.schema.paths['_id'] && + this.model.schema.paths['_id'].options && this.model.schema.paths['_id'].options.select === false) { + selected.push('-_id'); + } + selected.length && this.select(selected.join(' ')); + break; + case undefined: + // user didn't specify fields, implies returning all fields. + // only need to apply excluded fields + excluded.length && this.select('-' + excluded.join(' -')); + break; + } + seen = excluded = selected = keys = fields = null; +}; + +/** + * Returns a Node.js 0.8 style [read stream](http://nodejs.org/docs/v0.8.21/api/stream.html#stream_readable_stream) interface. + * + * ####Example + * + * // follows the nodejs 0.8 stream api + * Thing.find({ name: /^hello/ }).stream().pipe(res) + * + * // manual streaming + * var stream = Thing.find({ name: /^hello/ }).stream(); + * + * stream.on('data', function (doc) { + * // do something with the mongoose document + * }).on('error', function (err) { + * // handle the error + * }).on('close', function () { + * // the stream is closed + * }); + * + * ####Valid options + * + * - `transform`: optional function which accepts a mongoose document. The return value of the function will be emitted on `data`. + * + * ####Example + * + * // JSON.stringify all documents before emitting + * var stream = Thing.find().stream({ transform: JSON.stringify }); + * stream.pipe(writeStream); + * + * @return {QueryStream} + * @param {Object} [options] + * @see QueryStream + * @api public + */ + +Query.prototype.stream = function stream(opts) { + this._applyPaths(); + this._fields = this._castFields(this._fields); + return new QueryStream(this, opts); +}; +Query.prototype.stream = util.deprecate(Query.prototype.stream, 'Mongoose: ' + + 'Query.prototype.stream() is deprecated in mongoose >= 4.5.0, ' + + 'use Query.prototype.cursor() instead'); + +/** + * Returns a wrapper around a [mongodb driver cursor](http://mongodb.github.io/node-mongodb-native/2.1/api/Cursor.html). + * A QueryCursor exposes a [Streams3](https://strongloop.com/strongblog/whats-new-io-js-beta-streams3/)-compatible + * interface, as well as a `.next()` function. + * + * ####Example + * + * // There are 2 ways to use a cursor. First, as a stream: + * Thing. + * find({ name: /^hello/ }). + * cursor(). + * on('data', function(doc) { console.log(doc); }). + * on('end', function() { console.log('Done!'); }); + * + * // Or you can use `.next()` to manually get the next doc in the stream. + * // `.next()` returns a promise, so you can use promises or callbacks. + * var cursor = Thing.find({ name: /^hello/ }).cursor(); + * cursor.next(function(error, doc) { + * console.log(doc); + * }); + * + * // Because `.next()` returns a promise, you can use co + * // to easily iterate through all documents without loading them + * // all into memory. + * co(function*() { + * const cursor = Thing.find({ name: /^hello/ }).cursor(); + * for (let doc = yield cursor.next(); doc != null; doc = yield cursor.next()) { + * console.log(doc); + * } + * }); + * + * + * @return {QueryCursor} + * @param {Object} [options] + * @see QueryCursor + * @api public + */ + +Query.prototype.cursor = function cursor(opts) { + this._applyPaths(); + this._fields = this._castFields(this._fields); + this.setOptions({ fields: this._fieldsForExec() }); + if (opts) { + this.setOptions(opts); + } + + try { + this.cast(this.model); + } catch (err) { + return (new QueryCursor(this, this.options))._markError(err); + } + + return new QueryCursor(this, this.options); +}; + +// the rest of these are basically to support older Mongoose syntax with mquery + +/** + * _DEPRECATED_ Alias of `maxScan` + * + * @deprecated + * @see maxScan #query_Query-maxScan + * @method maxscan + * @memberOf Query + */ + +Query.prototype.maxscan = Query.base.maxScan; + +/** + * Sets the tailable option (for use with capped collections). + * + * ####Example + * + * query.tailable() // true + * query.tailable(true) + * query.tailable(false) + * + * ####Note + * + * Cannot be used with `distinct()` + * + * @param {Boolean} bool defaults to true + * @param {Object} [opts] options to set + * @param {Number} [opts.numberOfRetries] if cursor is exhausted, retry this many times before giving up + * @param {Number} [opts.tailableRetryInterval] if cursor is exhausted, wait this many milliseconds before retrying + * @see tailable http://docs.mongodb.org/manual/tutorial/create-tailable-cursor/ + * @api public + */ + +Query.prototype.tailable = function(val, opts) { + // we need to support the tailable({ awaitdata : true }) as well as the + // tailable(true, {awaitdata :true}) syntax that mquery does not support + if (val && val.constructor.name === 'Object') { + opts = val; + val = true; + } + + if (val === undefined) { + val = true; + } + + if (opts && typeof opts === 'object') { + for (var key in opts) { + if (key === 'awaitdata') { + // For backwards compatibility + this.options[key] = !!opts[key]; + } else { + this.options[key] = opts[key]; + } + } + } + + return Query.base.tailable.call(this, val); +}; + +/** + * Declares an intersects query for `geometry()`. + * + * ####Example + * + * query.where('path').intersects().geometry({ + * type: 'LineString' + * , coordinates: [[180.0, 11.0], [180, 9.0]] + * }) + * + * query.where('path').intersects({ + * type: 'LineString' + * , coordinates: [[180.0, 11.0], [180, 9.0]] + * }) + * + * ####NOTE: + * + * **MUST** be used after `where()`. + * + * ####NOTE: + * + * In Mongoose 3.7, `intersects` changed from a getter to a function. If you need the old syntax, use [this](https://github.com/ebensing/mongoose-within). + * + * @method intersects + * @memberOf Query + * @param {Object} [arg] + * @return {Query} this + * @see $geometry http://docs.mongodb.org/manual/reference/operator/geometry/ + * @see geoIntersects http://docs.mongodb.org/manual/reference/operator/geoIntersects/ + * @api public + */ + +/** + * Specifies a `$geometry` condition + * + * ####Example + * + * var polyA = [[[ 10, 20 ], [ 10, 40 ], [ 30, 40 ], [ 30, 20 ]]] + * query.where('loc').within().geometry({ type: 'Polygon', coordinates: polyA }) + * + * // or + * var polyB = [[ 0, 0 ], [ 1, 1 ]] + * query.where('loc').within().geometry({ type: 'LineString', coordinates: polyB }) + * + * // or + * var polyC = [ 0, 0 ] + * query.where('loc').within().geometry({ type: 'Point', coordinates: polyC }) + * + * // or + * query.where('loc').intersects().geometry({ type: 'Point', coordinates: polyC }) + * + * The argument is assigned to the most recent path passed to `where()`. + * + * ####NOTE: + * + * `geometry()` **must** come after either `intersects()` or `within()`. + * + * The `object` argument must contain `type` and `coordinates` properties. + * - type {String} + * - coordinates {Array} + * + * @method geometry + * @memberOf Query + * @param {Object} object Must contain a `type` property which is a String and a `coordinates` property which is an Array. See the examples. + * @return {Query} this + * @see $geometry http://docs.mongodb.org/manual/reference/operator/geometry/ + * @see http://docs.mongodb.org/manual/release-notes/2.4/#new-geospatial-indexes-with-geojson-and-improved-spherical-geometry + * @see http://www.mongodb.org/display/DOCS/Geospatial+Indexing + * @api public + */ + +/** + * Specifies a `$near` or `$nearSphere` condition + * + * These operators return documents sorted by distance. + * + * ####Example + * + * query.where('loc').near({ center: [10, 10] }); + * query.where('loc').near({ center: [10, 10], maxDistance: 5 }); + * query.where('loc').near({ center: [10, 10], maxDistance: 5, spherical: true }); + * query.near('loc', { center: [10, 10], maxDistance: 5 }); + * + * @method near + * @memberOf Query + * @param {String} [path] + * @param {Object} val + * @return {Query} this + * @see $near http://docs.mongodb.org/manual/reference/operator/near/ + * @see $nearSphere http://docs.mongodb.org/manual/reference/operator/nearSphere/ + * @see $maxDistance http://docs.mongodb.org/manual/reference/operator/maxDistance/ + * @see http://www.mongodb.org/display/DOCS/Geospatial+Indexing + * @api public + */ + +/*! + * Overwriting mquery is needed to support a couple different near() forms found in older + * versions of mongoose + * near([1,1]) + * near(1,1) + * near(field, [1,2]) + * near(field, 1, 2) + * In addition to all of the normal forms supported by mquery + */ + +Query.prototype.near = function() { + var params = []; + var sphere = this._mongooseOptions.nearSphere; + + // TODO refactor + + if (arguments.length === 1) { + if (Array.isArray(arguments[0])) { + params.push({center: arguments[0], spherical: sphere}); + } else if (typeof arguments[0] === 'string') { + // just passing a path + params.push(arguments[0]); + } else if (utils.isObject(arguments[0])) { + if (typeof arguments[0].spherical !== 'boolean') { + arguments[0].spherical = sphere; + } + params.push(arguments[0]); + } else { + throw new TypeError('invalid argument'); + } + } else if (arguments.length === 2) { + if (typeof arguments[0] === 'number' && typeof arguments[1] === 'number') { + params.push({center: [arguments[0], arguments[1]], spherical: sphere}); + } else if (typeof arguments[0] === 'string' && Array.isArray(arguments[1])) { + params.push(arguments[0]); + params.push({center: arguments[1], spherical: sphere}); + } else if (typeof arguments[0] === 'string' && utils.isObject(arguments[1])) { + params.push(arguments[0]); + if (typeof arguments[1].spherical !== 'boolean') { + arguments[1].spherical = sphere; + } + params.push(arguments[1]); + } else { + throw new TypeError('invalid argument'); + } + } else if (arguments.length === 3) { + if (typeof arguments[0] === 'string' && typeof arguments[1] === 'number' + && typeof arguments[2] === 'number') { + params.push(arguments[0]); + params.push({center: [arguments[1], arguments[2]], spherical: sphere}); + } else { + throw new TypeError('invalid argument'); + } + } else { + throw new TypeError('invalid argument'); + } + + return Query.base.near.apply(this, params); +}; + +/** + * _DEPRECATED_ Specifies a `$nearSphere` condition + * + * ####Example + * + * query.where('loc').nearSphere({ center: [10, 10], maxDistance: 5 }); + * + * **Deprecated.** Use `query.near()` instead with the `spherical` option set to `true`. + * + * ####Example + * + * query.where('loc').near({ center: [10, 10], spherical: true }); + * + * @deprecated + * @see near() #query_Query-near + * @see $near http://docs.mongodb.org/manual/reference/operator/near/ + * @see $nearSphere http://docs.mongodb.org/manual/reference/operator/nearSphere/ + * @see $maxDistance http://docs.mongodb.org/manual/reference/operator/maxDistance/ + */ + +Query.prototype.nearSphere = function() { + this._mongooseOptions.nearSphere = true; + this.near.apply(this, arguments); + return this; +}; + +/** + * Specifies a $polygon condition + * + * ####Example + * + * query.where('loc').within().polygon([10,20], [13, 25], [7,15]) + * query.polygon('loc', [10,20], [13, 25], [7,15]) + * + * @method polygon + * @memberOf Query + * @param {String|Array} [path] + * @param {Array|Object} [coordinatePairs...] + * @return {Query} this + * @see $polygon http://docs.mongodb.org/manual/reference/operator/polygon/ + * @see http://www.mongodb.org/display/DOCS/Geospatial+Indexing + * @api public + */ + +/** + * Specifies a $box condition + * + * ####Example + * + * var lowerLeft = [40.73083, -73.99756] + * var upperRight= [40.741404, -73.988135] + * + * query.where('loc').within().box(lowerLeft, upperRight) + * query.box({ ll : lowerLeft, ur : upperRight }) + * + * @method box + * @memberOf Query + * @see $box http://docs.mongodb.org/manual/reference/operator/box/ + * @see within() Query#within #query_Query-within + * @see http://www.mongodb.org/display/DOCS/Geospatial+Indexing + * @param {Object} val + * @param [Array] Upper Right Coords + * @return {Query} this + * @api public + */ + +/*! + * this is needed to support the mongoose syntax of: + * box(field, { ll : [x,y], ur : [x2,y2] }) + * box({ ll : [x,y], ur : [x2,y2] }) + */ + +Query.prototype.box = function(ll, ur) { + if (!Array.isArray(ll) && utils.isObject(ll)) { + ur = ll.ur; + ll = ll.ll; + } + return Query.base.box.call(this, ll, ur); +}; + +/** + * Specifies a $center or $centerSphere condition. + * + * ####Example + * + * var area = { center: [50, 50], radius: 10, unique: true } + * query.where('loc').within().circle(area) + * // alternatively + * query.circle('loc', area); + * + * // spherical calculations + * var area = { center: [50, 50], radius: 10, unique: true, spherical: true } + * query.where('loc').within().circle(area) + * // alternatively + * query.circle('loc', area); + * + * New in 3.7.0 + * + * @method circle + * @memberOf Query + * @param {String} [path] + * @param {Object} area + * @return {Query} this + * @see $center http://docs.mongodb.org/manual/reference/operator/center/ + * @see $centerSphere http://docs.mongodb.org/manual/reference/operator/centerSphere/ + * @see $geoWithin http://docs.mongodb.org/manual/reference/operator/geoWithin/ + * @see http://www.mongodb.org/display/DOCS/Geospatial+Indexing + * @api public + */ + +/** + * _DEPRECATED_ Alias for [circle](#query_Query-circle) + * + * **Deprecated.** Use [circle](#query_Query-circle) instead. + * + * @deprecated + * @method center + * @memberOf Query + * @api public + */ + +Query.prototype.center = Query.base.circle; + +/** + * _DEPRECATED_ Specifies a $centerSphere condition + * + * **Deprecated.** Use [circle](#query_Query-circle) instead. + * + * ####Example + * + * var area = { center: [50, 50], radius: 10 }; + * query.where('loc').within().centerSphere(area); + * + * @deprecated + * @param {String} [path] + * @param {Object} val + * @return {Query} this + * @see http://www.mongodb.org/display/DOCS/Geospatial+Indexing + * @see $centerSphere http://docs.mongodb.org/manual/reference/operator/centerSphere/ + * @api public + */ + +Query.prototype.centerSphere = function() { + if (arguments[0] && arguments[0].constructor.name === 'Object') { + arguments[0].spherical = true; + } + + if (arguments[1] && arguments[1].constructor.name === 'Object') { + arguments[1].spherical = true; + } + + Query.base.circle.apply(this, arguments); +}; + +/** + * Determines if field selection has been made. + * + * @method selected + * @memberOf Query + * @return {Boolean} + * @api public + */ + +/** + * Determines if inclusive field selection has been made. + * + * query.selectedInclusively() // false + * query.select('name') + * query.selectedInclusively() // true + * + * @method selectedInclusively + * @memberOf Query + * @return {Boolean} + * @api public + */ + +/** + * Determines if exclusive field selection has been made. + * + * query.selectedExclusively() // false + * query.select('-name') + * query.selectedExclusively() // true + * query.selectedInclusively() // false + * + * @method selectedExclusively + * @memberOf Query + * @return {Boolean} + * @api public + */ + +/*! + * Export + */ + +module.exports = Query; diff --git a/node_modules/mongoose/lib/querycursor.js b/node_modules/mongoose/lib/querycursor.js new file mode 100644 index 0000000..455b17d --- /dev/null +++ b/node_modules/mongoose/lib/querycursor.js @@ -0,0 +1,262 @@ +/*! + * Module dependencies. + */ + +var PromiseProvider = require('./promise_provider'); +var Readable = require('stream').Readable; +var helpers = require('./queryhelpers'); +var util = require('util'); + +/** + * A QueryCursor is a concurrency primitive for processing query results + * one document at a time. A QueryCursor fulfills the [Node.js streams3 API](https://strongloop.com/strongblog/whats-new-io-js-beta-streams3/), + * in addition to several other mechanisms for loading documents from MongoDB + * one at a time. + * + * Unless you're an advanced user, do **not** instantiate this class directly. + * Use [`Query#cursor()`](/docs/api.html#query_Query-cursor) instead. + * + * @param {Query} query + * @param {Object} options query options passed to `.find()` + * @inherits Readable + * @event `cursor`: Emitted when the cursor is created + * @event `error`: Emitted when an error occurred + * @event `data`: Emitted when the stream is flowing and the next doc is ready + * @event `end`: Emitted when the stream is exhausted + * @api public + */ + +function QueryCursor(query, options) { + Readable.call(this, { objectMode: true }); + + this.cursor = null; + this.query = query; + var _this = this; + var model = query.model; + model.collection.find(query._conditions, options, function(err, cursor) { + if (_this._error) { + cursor.close(function() {}); + _this.listeners('error').length > 0 && _this.emit('error', _this._error); + } + if (err) { + return _this.emit('error', err); + } + _this.cursor = cursor; + _this.emit('cursor', cursor); + }); +} + +util.inherits(QueryCursor, Readable); + +/*! + * Necessary to satisfy the Readable API + */ + +QueryCursor.prototype._read = function() { + var _this = this; + _next(this, function(error, doc) { + if (error) { + return _this.emit('error', error); + } + if (!doc) { + _this.push(null); + return _this.cursor.close(function(error) { + if (error) { + return _this.emit('error', error); + } + _this.emit('close'); + }); + } + _this.push(doc); + }); +}; + +/*! + * Marks this cursor as errored + */ + +QueryCursor.prototype._markError = function(error) { + this._error = error; + return this; +}; + +/** + * Marks this cursor as closed. Will stop streaming and subsequent calls to + * `next()` will error. + * + * @param {Function} callback + * @return {Promise} + * @api public + * @method close + * @emits close + * @see MongoDB driver cursor#close http://mongodb.github.io/node-mongodb-native/2.1/api/Cursor.html#close + */ + +QueryCursor.prototype.close = function(callback) { + var Promise = PromiseProvider.get(); + var _this = this; + return new Promise.ES6(function(resolve, reject) { + _this.cursor.close(function(error) { + if (error) { + callback && callback(error); + reject(error); + return _this.listeners('error').length > 0 && + _this.emit('error', error); + } + _this.emit('close'); + resolve(); + callback && callback(); + }); + }); +}; + +/** + * Get the next document from this cursor. Will return `null` when there are + * no documents left. + * + * @param {Function} callback + * @return {Promise} + * @api public + * @method next + */ + +QueryCursor.prototype.next = function(callback) { + var Promise = PromiseProvider.get(); + var _this = this; + return new Promise.ES6(function(resolve, reject) { + _next(_this, function(error, doc) { + if (error) { + callback && callback(error); + return reject(error); + } + callback && callback(null, doc); + resolve(doc); + }); + }); +}; + +/** + * Execute `fn` for every document in the cursor. If `fn` returns a promise, + * will wait for the promise to resolve before iterating on to the next one. + * Returns a promise that resolves when done. + * + * @param {Function} fn + * @param {Function} [callback] executed when all docs have been processed + * @return {Promise} + * @api public + * @method eachAsync + */ + +QueryCursor.prototype.eachAsync = function(fn, callback) { + var Promise = PromiseProvider.get(); + var _this = this; + + var handleNextResult = function(doc, callback) { + var promise = fn(doc); + if (promise && typeof promise.then === 'function') { + promise.then( + function() { callback(null); }, + function(error) { callback(error); }); + } else { + callback(null); + } + }; + + var iterate = function(callback) { + return _next(_this, function(error, doc) { + if (error) { + return callback(error); + } + if (!doc) { + return callback(null); + } + handleNextResult(doc, function(error) { + if (error) { + return callback(error); + } + iterate(callback); + }); + }); + }; + + return new Promise.ES6(function(resolve, reject) { + iterate(function(error) { + if (error) { + callback && callback(error); + return reject(error); + } + callback && callback(null); + return resolve(); + }); + }); +}; + +/*! + * Get the next doc from the underlying cursor and mongooseify it + * (populate, etc.) + */ + +function _next(ctx, callback) { + if (ctx._error) { + return process.nextTick(function() { + callback(ctx._error); + }); + } + + if (ctx.cursor) { + ctx.cursor.next(function(error, doc) { + if (error) { + return callback(error); + } + if (!doc) { + return callback(null, null); + } + + var opts = ctx.query._mongooseOptions; + if (!opts.populate) { + return opts.lean === true ? + callback(null, doc) : + _create(ctx, doc, null, callback); + } + + var pop = helpers.preparePopulationOptionsMQ(ctx.query, + ctx.query._mongooseOptions); + pop.forEach(function(option) { + delete option.model; + }); + pop.__noPromise = true; + ctx.query.model.populate(doc, pop, function(err, doc) { + if (err) { + return callback(err); + } + return opts.lean === true ? + callback(null, doc) : + _create(ctx, doc, pop, callback); + }); + }); + } else { + ctx.once('cursor', function() { + _next(ctx, callback); + }); + } +} + +/*! + * Convert a raw doc into a full mongoose doc. + */ + +function _create(ctx, doc, populatedIds, cb) { + var instance = helpers.createModel(ctx.query.model, doc, ctx.query._fields); + var opts = populatedIds ? + { populated: populatedIds } : + undefined; + + instance.init(doc, opts, function(err) { + if (err) { + return cb(err); + } + cb(null, instance); + }); +} + +module.exports = QueryCursor; diff --git a/node_modules/mongoose/lib/queryhelpers.js b/node_modules/mongoose/lib/queryhelpers.js new file mode 100644 index 0000000..3e0b82d --- /dev/null +++ b/node_modules/mongoose/lib/queryhelpers.js @@ -0,0 +1,78 @@ + +/*! + * Module dependencies + */ + +var utils = require('./utils'); + +/*! + * Prepare a set of path options for query population. + * + * @param {Query} query + * @param {Object} options + * @return {Array} + */ + +exports.preparePopulationOptions = function preparePopulationOptions(query, options) { + var pop = utils.object.vals(query.options.populate); + + // lean options should trickle through all queries + if (options.lean) pop.forEach(makeLean); + + return pop; +}; + +/*! + * Prepare a set of path options for query population. This is the MongooseQuery + * version + * + * @param {Query} query + * @param {Object} options + * @return {Array} + */ + +exports.preparePopulationOptionsMQ = function preparePopulationOptionsMQ(query, options) { + var pop = utils.object.vals(query._mongooseOptions.populate); + + // lean options should trickle through all queries + if (options.lean) pop.forEach(makeLean); + + return pop; +}; + +/*! + * If the document is a mapped discriminator type, it returns a model instance for that type, otherwise, + * it returns an instance of the given model. + * + * @param {Model} model + * @param {Object} doc + * @param {Object} fields + * + * @return {Model} + */ +exports.createModel = function createModel(model, doc, fields) { + var discriminatorMapping = model.schema + ? model.schema.discriminatorMapping + : null; + + var key = discriminatorMapping && discriminatorMapping.isRoot + ? discriminatorMapping.key + : null; + + if (key && doc[key] && model.discriminators && model.discriminators[doc[key]]) { + return new model.discriminators[doc[key]](undefined, fields, true); + } + + return new model(undefined, fields, true); +}; + +/*! + * Set each path query option to lean + * + * @param {Object} option + */ + +function makeLean(option) { + option.options || (option.options = {}); + option.options.lean = true; +} diff --git a/node_modules/mongoose/lib/querystream.js b/node_modules/mongoose/lib/querystream.js new file mode 100644 index 0000000..2918e25 --- /dev/null +++ b/node_modules/mongoose/lib/querystream.js @@ -0,0 +1,367 @@ +/* eslint no-empty: 1 */ + +/*! + * Module dependencies. + */ + +var Stream = require('stream').Stream; +var utils = require('./utils'); +var helpers = require('./queryhelpers'); +var K = function(k) { + return k; +}; + +/** + * Provides a Node.js 0.8 style [ReadStream](http://nodejs.org/docs/v0.8.21/api/stream.html#stream_readable_stream) interface for Queries. + * + * var stream = Model.find().stream(); + * + * stream.on('data', function (doc) { + * // do something with the mongoose document + * }).on('error', function (err) { + * // handle the error + * }).on('close', function () { + * // the stream is closed + * }); + * + * + * The stream interface allows us to simply "plug-in" to other _Node.js 0.8_ style write streams. + * + * Model.where('created').gte(twoWeeksAgo).stream().pipe(writeStream); + * + * ####Valid options + * + * - `transform`: optional function which accepts a mongoose document. The return value of the function will be emitted on `data`. + * + * ####Example + * + * // JSON.stringify all documents before emitting + * var stream = Thing.find().stream({ transform: JSON.stringify }); + * stream.pipe(writeStream); + * + * _NOTE: plugging into an HTTP response will *not* work out of the box. Those streams expect only strings or buffers to be emitted, so first formatting our documents as strings/buffers is necessary._ + * + * _NOTE: these streams are Node.js 0.8 style read streams which differ from Node.js 0.10 style. Node.js 0.10 streams are not well tested yet and are not guaranteed to work._ + * + * @param {Query} query + * @param {Object} [options] + * @inherits NodeJS Stream http://nodejs.org/docs/v0.8.21/api/stream.html#stream_readable_stream + * @event `data`: emits a single Mongoose document + * @event `error`: emits when an error occurs during streaming. This will emit _before_ the `close` event. + * @event `close`: emits when the stream reaches the end of the cursor or an error occurs, or the stream is manually `destroy`ed. After this event, no more events are emitted. + * @api public + */ + +function QueryStream(query, options) { + Stream.call(this); + + this.query = query; + this.readable = true; + this.paused = false; + this._cursor = null; + this._destroyed = null; + this._fields = null; + this._buffer = null; + this._inline = T_INIT; + this._running = false; + this._transform = options && typeof options.transform === 'function' + ? options.transform + : K; + + // give time to hook up events + var _this = this; + process.nextTick(function() { + _this._init(); + }); +} + +/*! + * Inherit from Stream + */ + +QueryStream.prototype.__proto__ = Stream.prototype; + +/** + * Flag stating whether or not this stream is readable. + * + * @property readable + * @api public + */ + +QueryStream.prototype.readable; + +/** + * Flag stating whether or not this stream is paused. + * + * @property paused + * @api public + */ + +QueryStream.prototype.paused; + +// trampoline flags +var T_INIT = 0; +var T_IDLE = 1; +var T_CONT = 2; + +/** + * Initializes the query. + * + * @api private + */ + +QueryStream.prototype._init = function() { + if (this._destroyed) { + return; + } + + var query = this.query, + model = query.model, + options = query._optionsForExec(model), + _this = this; + + try { + query.cast(model); + } catch (err) { + return _this.destroy(err); + } + + _this._fields = utils.clone(query._fields); + options.fields = query._castFields(_this._fields); + + model.collection.find(query._conditions, options, function(err, cursor) { + if (err) { + return _this.destroy(err); + } + _this._cursor = cursor; + _this._next(); + }); +}; + +/** + * Trampoline for pulling the next doc from cursor. + * + * @see QueryStream#__next #querystream_QueryStream-__next + * @api private + */ + +QueryStream.prototype._next = function _next() { + if (this.paused || this._destroyed) { + this._running = false; + return this._running; + } + + this._running = true; + + if (this._buffer && this._buffer.length) { + var arg; + while (!this.paused && !this._destroyed && (arg = this._buffer.shift())) { // eslint-disable-line no-cond-assign + this._onNextObject.apply(this, arg); + } + } + + // avoid stack overflows with large result sets. + // trampoline instead of recursion. + while (this.__next()) { + } +}; + +/** + * Pulls the next doc from the cursor. + * + * @see QueryStream#_next #querystream_QueryStream-_next + * @api private + */ + +QueryStream.prototype.__next = function() { + if (this.paused || this._destroyed) { + this._running = false; + return this._running; + } + + var _this = this; + _this._inline = T_INIT; + + _this._cursor.nextObject(function cursorcb(err, doc) { + _this._onNextObject(err, doc); + }); + + // if onNextObject() was already called in this tick + // return ourselves to the trampoline. + if (T_CONT === this._inline) { + return true; + } + // onNextObject() hasn't fired yet. tell onNextObject + // that its ok to call _next b/c we are not within + // the trampoline anymore. + this._inline = T_IDLE; +}; + +/** + * Transforms raw `doc`s returned from the cursor into a model instance. + * + * @param {Error|null} err + * @param {Object} doc + * @api private + */ + +QueryStream.prototype._onNextObject = function _onNextObject(err, doc) { + if (this._destroyed) { + return; + } + + if (this.paused) { + this._buffer || (this._buffer = []); + this._buffer.push([err, doc]); + this._running = false; + return this._running; + } + + if (err) { + return this.destroy(err); + } + + // when doc is null we hit the end of the cursor + if (!doc) { + this.emit('end'); + return this.destroy(); + } + + var opts = this.query._mongooseOptions; + + if (!opts.populate) { + return opts.lean === true ? + emit(this, doc) : + createAndEmit(this, null, doc); + } + + var _this = this; + var pop = helpers.preparePopulationOptionsMQ(_this.query, _this.query._mongooseOptions); + + // Hack to work around gh-3108 + pop.forEach(function(option) { + delete option.model; + }); + + pop.__noPromise = true; + _this.query.model.populate(doc, pop, function(err, doc) { + if (err) { + return _this.destroy(err); + } + return opts.lean === true ? + emit(_this, doc) : + createAndEmit(_this, pop, doc); + }); +}; + +function createAndEmit(self, populatedIds, doc) { + var instance = helpers.createModel(self.query.model, doc, self._fields); + var opts = populatedIds ? + {populated: populatedIds} : + undefined; + + instance.init(doc, opts, function(err) { + if (err) { + return self.destroy(err); + } + emit(self, instance); + }); +} + +/*! + * Emit a data event and manage the trampoline state + */ + +function emit(self, doc) { + self.emit('data', self._transform(doc)); + + // trampoline management + if (T_IDLE === self._inline) { + // no longer in trampoline. restart it. + self._next(); + } else { + // in a trampoline. tell __next that its + // ok to continue jumping. + self._inline = T_CONT; + } +} + +/** + * Pauses this stream. + * + * @api public + */ + +QueryStream.prototype.pause = function() { + this.paused = true; +}; + +/** + * Resumes this stream. + * + * @api public + */ + +QueryStream.prototype.resume = function() { + this.paused = false; + + if (!this._cursor) { + // cannot start if not initialized + return; + } + + // are we within the trampoline? + if (T_INIT === this._inline) { + return; + } + + if (!this._running) { + // outside QueryStream control, need manual restart + return this._next(); + } +}; + +/** + * Destroys the stream, closing the underlying cursor, which emits the close event. No more events will be emitted after the close event. + * + * @param {Error} [err] + * @api public + */ + +QueryStream.prototype.destroy = function(err) { + if (this._destroyed) { + return; + } + this._destroyed = true; + this._running = false; + this.readable = false; + + if (this._cursor) { + this._cursor.close(); + } + + if (err) { + this.emit('error', err); + } + + this.emit('close'); +}; + +/** + * Pipes this query stream into another stream. This method is inherited from NodeJS Streams. + * + * ####Example: + * + * query.stream().pipe(writeStream [, options]) + * + * @method pipe + * @memberOf QueryStream + * @see NodeJS http://nodejs.org/api/stream.html + * @api public + */ + +/*! + * Module exports + */ + +module.exports = exports = QueryStream; diff --git a/node_modules/mongoose/lib/schema.js b/node_modules/mongoose/lib/schema.js new file mode 100644 index 0000000..0d8d0f1 --- /dev/null +++ b/node_modules/mongoose/lib/schema.js @@ -0,0 +1,1664 @@ +/*! + * Module dependencies. + */ + +var readPref = require('./drivers').ReadPreference; +var EventEmitter = require('events').EventEmitter; +var VirtualType = require('./virtualtype'); +var utils = require('./utils'); +var MongooseTypes; +var Kareem = require('kareem'); +var each = require('async/each'); +var SchemaType = require('./schematype'); + +var IS_KAREEM_HOOK = { + count: true, + find: true, + findOne: true, + findOneAndUpdate: true, + findOneAndRemove: true, + insertMany: true, + update: true +}; + +/** + * Schema constructor. + * + * ####Example: + * + * var child = new Schema({ name: String }); + * var schema = new Schema({ name: String, age: Number, children: [child] }); + * var Tree = mongoose.model('Tree', schema); + * + * // setting schema options + * new Schema({ name: String }, { _id: false, autoIndex: false }) + * + * ####Options: + * + * - [autoIndex](/docs/guide.html#autoIndex): bool - defaults to null (which means use the connection's autoIndex option) + * - [bufferCommands](/docs/guide.html#bufferCommands): bool - defaults to true + * - [capped](/docs/guide.html#capped): bool - defaults to false + * - [collection](/docs/guide.html#collection): string - no default + * - [emitIndexErrors](/docs/guide.html#emitIndexErrors): bool - defaults to false. + * - [id](/docs/guide.html#id): bool - defaults to true + * - [_id](/docs/guide.html#_id): bool - defaults to true + * - `minimize`: bool - controls [document#toObject](#document_Document-toObject) behavior when called manually - defaults to true + * - [read](/docs/guide.html#read): string + * - [safe](/docs/guide.html#safe): bool - defaults to true. + * - [shardKey](/docs/guide.html#shardKey): bool - defaults to `null` + * - [strict](/docs/guide.html#strict): bool - defaults to true + * - [toJSON](/docs/guide.html#toJSON) - object - no default + * - [toObject](/docs/guide.html#toObject) - object - no default + * - [typeKey](/docs/guide.html#typeKey) - string - defaults to 'type' + * - [useNestedStrict](/docs/guide.html#useNestedStrict) - boolean - defaults to false + * - [validateBeforeSave](/docs/guide.html#validateBeforeSave) - bool - defaults to `true` + * - [versionKey](/docs/guide.html#versionKey): string - defaults to "__v" + * + * ####Note: + * + * _When nesting schemas, (`children` in the example above), always declare the child schema first before passing it into its parent._ + * + * @param {Object} definition + * @param {Object} [options] + * @inherits NodeJS EventEmitter http://nodejs.org/api/events.html#events_class_events_eventemitter + * @event `init`: Emitted after the schema is compiled into a `Model`. + * @api public + */ + +function Schema(obj, options) { + if (!(this instanceof Schema)) { + return new Schema(obj, options); + } + + this.obj = obj; + this.paths = {}; + this.subpaths = {}; + this.virtuals = {}; + this.singleNestedPaths = {}; + this.nested = {}; + this.inherits = {}; + this.callQueue = []; + this._indexes = []; + this.methods = {}; + this.statics = {}; + this.tree = {}; + this._requiredpaths = undefined; + this.discriminatorMapping = undefined; + this._indexedpaths = undefined; + this.query = {}; + this.childSchemas = []; + + this.s = { + hooks: new Kareem(), + kareemHooks: IS_KAREEM_HOOK + }; + + this.options = this.defaultOptions(options); + + // build paths + if (obj) { + this.add(obj); + } + + // check if _id's value is a subdocument (gh-2276) + var _idSubDoc = obj && obj._id && utils.isObject(obj._id); + + // ensure the documents get an auto _id unless disabled + var auto_id = !this.paths['_id'] && + (!this.options.noId && this.options._id) && !_idSubDoc; + + if (auto_id) { + obj = {_id: {auto: true}}; + obj._id[this.options.typeKey] = Schema.ObjectId; + this.add(obj); + } + + // ensure the documents receive an id getter unless disabled + var autoid = !this.paths['id'] && + (!this.options.noVirtualId && this.options.id); + if (autoid) { + this.virtual('id').get(idGetter); + } + + for (var i = 0; i < this._defaultMiddleware.length; ++i) { + var m = this._defaultMiddleware[i]; + this[m.kind](m.hook, !!m.isAsync, m.fn); + } + + if (this.options.timestamps) { + this.setupTimestamp(this.options.timestamps); + } +} + +/*! + * Returns this documents _id cast to a string. + */ + +function idGetter() { + if (this.$__._id) { + return this.$__._id; + } + + this.$__._id = this._id == null + ? null + : String(this._id); + return this.$__._id; +} + +/*! + * Inherit from EventEmitter. + */ +Schema.prototype = Object.create(EventEmitter.prototype); +Schema.prototype.constructor = Schema; +Schema.prototype.instanceOfSchema = true; + +/** + * Default middleware attached to a schema. Cannot be changed. + * + * This field is used to make sure discriminators don't get multiple copies of + * built-in middleware. Declared as a constant because changing this at runtime + * may lead to instability with Model.prototype.discriminator(). + * + * @api private + * @property _defaultMiddleware + */ +Object.defineProperty(Schema.prototype, '_defaultMiddleware', { + configurable: false, + enumerable: false, + writable: false, + value: [ + { + kind: 'pre', + hook: 'save', + fn: function(next, options) { + var _this = this; + // Nested docs have their own presave + if (this.ownerDocument) { + return next(); + } + + var hasValidateBeforeSaveOption = options && + (typeof options === 'object') && + ('validateBeforeSave' in options); + + var shouldValidate; + if (hasValidateBeforeSaveOption) { + shouldValidate = !!options.validateBeforeSave; + } else { + shouldValidate = this.schema.options.validateBeforeSave; + } + + // Validate + if (shouldValidate) { + // HACK: use $__original_validate to avoid promises so bluebird doesn't + // complain + if (this.$__original_validate) { + this.$__original_validate({__noPromise: true}, function(error) { + return _this.schema.s.hooks.execPost('save:error', _this, [_this], { error: error }, function(error) { + next(error); + }); + }); + } else { + this.validate({__noPromise: true}, function(error) { + return _this.schema.s.hooks.execPost('save:error', _this, [ _this], { error: error }, function(error) { + next(error); + }); + }); + } + } else { + next(); + } + } + }, + { + kind: 'pre', + hook: 'save', + isAsync: true, + fn: function(next, done) { + var _this = this; + var subdocs = this.$__getAllSubdocs(); + + if (!subdocs.length || this.$__preSavingFromParent) { + done(); + next(); + return; + } + + each(subdocs, function(subdoc, cb) { + subdoc.$__preSavingFromParent = true; + subdoc.save(function(err) { + cb(err); + }); + }, function(error) { + for (var i = 0; i < subdocs.length; ++i) { + delete subdocs[i].$__preSavingFromParent; + } + if (error) { + return _this.schema.s.hooks.execPost('save:error', _this, [_this], { error: error }, function(error) { + done(error); + }); + } + next(); + done(); + }); + } + }, + { + kind: 'pre', + hook: 'validate', + isAsync: true, + fn: function(next, done) { + // Hack to ensure that we always wrap validate() in a promise + next(); + done(); + } + }, + { + kind: 'pre', + hook: 'remove', + isAsync: true, + fn: function(next, done) { + if (this.ownerDocument) { + done(); + next(); + return; + } + + var subdocs = this.$__getAllSubdocs(); + + if (!subdocs.length || this.$__preSavingFromParent) { + done(); + next(); + return; + } + + each(subdocs, function(subdoc, cb) { + subdoc.remove({ noop: true }, function(err) { + cb(err); + }); + }, function(error) { + if (error) { + done(error); + return; + } + next(); + done(); + }); + } + } + ] +}); + + +/** + * The original object passed to the schema constructor + * + * ####Example: + * + * var schema = new Schema({ a: String }).add({ b: String }); + * schema.obj; // { a: String } + * + * @api public + * @property obj + */ + +Schema.prototype.obj; + +/** + * Schema as flat paths + * + * ####Example: + * { + * '_id' : SchemaType, + * , 'nested.key' : SchemaType, + * } + * + * @api private + * @property paths + */ + +Schema.prototype.paths; + +/** + * Schema as a tree + * + * ####Example: + * { + * '_id' : ObjectId + * , 'nested' : { + * 'key' : String + * } + * } + * + * @api private + * @property tree + */ + +Schema.prototype.tree; + +/** + * Returns default options for this schema, merged with `options`. + * + * @param {Object} options + * @return {Object} + * @api private + */ + +Schema.prototype.defaultOptions = function(options) { + if (options && options.safe === false) { + options.safe = {w: 0}; + } + + if (options && options.safe && options.safe.w === 0) { + // if you turn off safe writes, then versioning goes off as well + options.versionKey = false; + } + + options = utils.options({ + strict: true, + bufferCommands: true, + capped: false, // { size, max, autoIndexId } + versionKey: '__v', + discriminatorKey: '__t', + minimize: true, + autoIndex: null, + shardKey: null, + read: null, + validateBeforeSave: true, + // the following are only applied at construction time + noId: false, // deprecated, use { _id: false } + _id: true, + noVirtualId: false, // deprecated, use { id: false } + id: true, + typeKey: 'type' + }, options); + + if (options.read) { + options.read = readPref(options.read); + } + + return options; +}; + +/** + * Adds key path / schema type pairs to this schema. + * + * ####Example: + * + * var ToySchema = new Schema; + * ToySchema.add({ name: 'string', color: 'string', price: 'number' }); + * + * @param {Object} obj + * @param {String} prefix + * @api public + */ + +Schema.prototype.add = function add(obj, prefix) { + prefix = prefix || ''; + var keys = Object.keys(obj); + + for (var i = 0; i < keys.length; ++i) { + var key = keys[i]; + + if (obj[key] == null) { + throw new TypeError('Invalid value for schema path `' + prefix + key + '`'); + } + + if (Array.isArray(obj[key]) && obj[key].length === 1 && obj[key][0] == null) { + throw new TypeError('Invalid value for schema Array path `' + prefix + key + '`'); + } + + if (utils.isObject(obj[key]) && + (!obj[key].constructor || utils.getFunctionName(obj[key].constructor) === 'Object') && + (!obj[key][this.options.typeKey] || (this.options.typeKey === 'type' && obj[key].type.type))) { + if (Object.keys(obj[key]).length) { + // nested object { last: { name: String }} + this.nested[prefix + key] = true; + this.add(obj[key], prefix + key + '.'); + } else { + if (prefix) { + this.nested[prefix.substr(0, prefix.length - 1)] = true; + } + this.path(prefix + key, obj[key]); // mixed type + } + } else { + if (prefix) { + this.nested[prefix.substr(0, prefix.length - 1)] = true; + } + this.path(prefix + key, obj[key]); + } + } +}; + +/** + * Reserved document keys. + * + * Keys in this object are names that are rejected in schema declarations b/c they conflict with mongoose functionality. Using these key name will throw an error. + * + * on, emit, _events, db, get, set, init, isNew, errors, schema, options, modelName, collection, _pres, _posts, toObject + * + * _NOTE:_ Use of these terms as method names is permitted, but play at your own risk, as they may be existing mongoose document methods you are stomping on. + * + * var schema = new Schema(..); + * schema.methods.init = function () {} // potentially breaking + */ + +Schema.reserved = Object.create(null); +var reserved = Schema.reserved; +// EventEmitter +reserved.emit = +reserved.on = +reserved.once = +reserved.listeners = +reserved.removeListener = +// document properties and functions +reserved.collection = +reserved.db = +reserved.errors = +reserved.init = +reserved.isModified = +reserved.isNew = +reserved.get = +reserved.modelName = +reserved.save = +reserved.schema = +reserved.set = +reserved.toObject = +reserved.validate = +// hooks.js +reserved._pres = reserved._posts = 1; + +/*! + * Document keys to print warnings for + */ + +var warnings = {}; +warnings.increment = '`increment` should not be used as a schema path name ' + + 'unless you have disabled versioning.'; + +/** + * Gets/sets schema paths. + * + * Sets a path (if arity 2) + * Gets a path (if arity 1) + * + * ####Example + * + * schema.path('name') // returns a SchemaType + * schema.path('name', Number) // changes the schemaType of `name` to Number + * + * @param {String} path + * @param {Object} constructor + * @api public + */ + +Schema.prototype.path = function(path, obj) { + if (obj === undefined) { + if (this.paths[path]) { + return this.paths[path]; + } + if (this.subpaths[path]) { + return this.subpaths[path]; + } + if (this.singleNestedPaths[path]) { + return this.singleNestedPaths[path]; + } + + // subpaths? + return /\.\d+\.?.*$/.test(path) + ? getPositionalPath(this, path) + : undefined; + } + + // some path names conflict with document methods + if (reserved[path]) { + throw new Error('`' + path + '` may not be used as a schema pathname'); + } + + if (warnings[path]) { + console.log('WARN: ' + warnings[path]); + } + + // update the tree + var subpaths = path.split(/\./), + last = subpaths.pop(), + branch = this.tree; + + subpaths.forEach(function(sub, i) { + if (!branch[sub]) { + branch[sub] = {}; + } + if (typeof branch[sub] !== 'object') { + var msg = 'Cannot set nested path `' + path + '`. ' + + 'Parent path `' + + subpaths.slice(0, i).concat([sub]).join('.') + + '` already set to type ' + branch[sub].name + + '.'; + throw new Error(msg); + } + branch = branch[sub]; + }); + + branch[last] = utils.clone(obj); + + this.paths[path] = Schema.interpretAsType(path, obj, this.options); + + if (this.paths[path].$isSingleNested) { + for (var key in this.paths[path].schema.paths) { + this.singleNestedPaths[path + '.' + key] = + this.paths[path].schema.paths[key]; + } + for (key in this.paths[path].schema.singleNestedPaths) { + this.singleNestedPaths[path + '.' + key] = + this.paths[path].schema.singleNestedPaths[key]; + } + + this.childSchemas.push(this.paths[path].schema); + } else if (this.paths[path].$isMongooseDocumentArray) { + this.childSchemas.push(this.paths[path].schema); + } + return this; +}; + +/** + * Converts type arguments into Mongoose Types. + * + * @param {String} path + * @param {Object} obj constructor + * @api private + */ + +Schema.interpretAsType = function(path, obj, options) { + if (obj.constructor) { + var constructorName = utils.getFunctionName(obj.constructor); + if (constructorName !== 'Object') { + var oldObj = obj; + obj = {}; + obj[options.typeKey] = oldObj; + } + } + + // Get the type making sure to allow keys named "type" + // and default to mixed if not specified. + // { type: { type: String, default: 'freshcut' } } + var type = obj[options.typeKey] && (options.typeKey !== 'type' || !obj.type.type) + ? obj[options.typeKey] + : {}; + + if (utils.getFunctionName(type.constructor) === 'Object' || type === 'mixed') { + return new MongooseTypes.Mixed(path, obj); + } + + if (Array.isArray(type) || Array === type || type === 'array') { + // if it was specified through { type } look for `cast` + var cast = (Array === type || type === 'array') + ? obj.cast + : type[0]; + + if (cast && cast.instanceOfSchema) { + return new MongooseTypes.DocumentArray(path, cast, obj); + } + + if (Array.isArray(cast)) { + return new MongooseTypes.Array(path, Schema.interpretAsType(path, cast, options), obj); + } + + if (typeof cast === 'string') { + cast = MongooseTypes[cast.charAt(0).toUpperCase() + cast.substring(1)]; + } else if (cast && (!cast[options.typeKey] || (options.typeKey === 'type' && cast.type.type)) + && utils.getFunctionName(cast.constructor) === 'Object') { + if (Object.keys(cast).length) { + // The `minimize` and `typeKey` options propagate to child schemas + // declared inline, like `{ arr: [{ val: { $type: String } }] }`. + // See gh-3560 + var childSchemaOptions = {minimize: options.minimize}; + if (options.typeKey) { + childSchemaOptions.typeKey = options.typeKey; + } + var childSchema = new Schema(cast, childSchemaOptions); + childSchema.$implicitlyCreated = true; + return new MongooseTypes.DocumentArray(path, childSchema, obj); + } else { + // Special case: empty object becomes mixed + return new MongooseTypes.Array(path, MongooseTypes.Mixed, obj); + } + } + + if (cast) { + type = cast[options.typeKey] && (options.typeKey !== 'type' || !cast.type.type) + ? cast[options.typeKey] + : cast; + + name = typeof type === 'string' + ? type + : type.schemaName || utils.getFunctionName(type); + + if (!(name in MongooseTypes)) { + throw new TypeError('Undefined type `' + name + '` at array `' + path + + '`'); + } + } + + return new MongooseTypes.Array(path, cast || MongooseTypes.Mixed, obj, options); + } + + if (type && type.instanceOfSchema) { + return new MongooseTypes.Embedded(type, path, obj); + } + + var name; + if (Buffer.isBuffer(type)) { + name = 'Buffer'; + } else { + name = typeof type === 'string' + ? type + // If not string, `type` is a function. Outside of IE, function.name + // gives you the function name. In IE, you need to compute it + : type.schemaName || utils.getFunctionName(type); + } + + if (name) { + name = name.charAt(0).toUpperCase() + name.substring(1); + } + + if (undefined == MongooseTypes[name]) { + throw new TypeError('Undefined type `' + name + '` at `' + path + + '`\n Did you try nesting Schemas? ' + + 'You can only nest using refs or arrays.'); + } + + return new MongooseTypes[name](path, obj); +}; + +/** + * Iterates the schemas paths similar to Array#forEach. + * + * The callback is passed the pathname and schemaType as arguments on each iteration. + * + * @param {Function} fn callback function + * @return {Schema} this + * @api public + */ + +Schema.prototype.eachPath = function(fn) { + var keys = Object.keys(this.paths), + len = keys.length; + + for (var i = 0; i < len; ++i) { + fn(keys[i], this.paths[keys[i]]); + } + + return this; +}; + +/** + * Returns an Array of path strings that are required by this schema. + * + * @api public + * @param {Boolean} invalidate refresh the cache + * @return {Array} + */ + +Schema.prototype.requiredPaths = function requiredPaths(invalidate) { + if (this._requiredpaths && !invalidate) { + return this._requiredpaths; + } + + var paths = Object.keys(this.paths), + i = paths.length, + ret = []; + + while (i--) { + var path = paths[i]; + if (this.paths[path].isRequired) { + ret.push(path); + } + } + this._requiredpaths = ret; + return this._requiredpaths; +}; + +/** + * Returns indexes from fields and schema-level indexes (cached). + * + * @api private + * @return {Array} + */ + +Schema.prototype.indexedPaths = function indexedPaths() { + if (this._indexedpaths) { + return this._indexedpaths; + } + this._indexedpaths = this.indexes(); + return this._indexedpaths; +}; + +/** + * Returns the pathType of `path` for this schema. + * + * Given a path, returns whether it is a real, virtual, nested, or ad-hoc/undefined path. + * + * @param {String} path + * @return {String} + * @api public + */ + +Schema.prototype.pathType = function(path) { + if (path in this.paths) { + return 'real'; + } + if (path in this.virtuals) { + return 'virtual'; + } + if (path in this.nested) { + return 'nested'; + } + if (path in this.subpaths) { + return 'real'; + } + if (path in this.singleNestedPaths) { + return 'real'; + } + + if (/\.\d+\.|\.\d+$/.test(path)) { + return getPositionalPathType(this, path); + } + return 'adhocOrUndefined'; +}; + +/** + * Returns true iff this path is a child of a mixed schema. + * + * @param {String} path + * @return {Boolean} + * @api private + */ + +Schema.prototype.hasMixedParent = function(path) { + var subpaths = path.split(/\./g); + path = ''; + for (var i = 0; i < subpaths.length; ++i) { + path = i > 0 ? path + '.' + subpaths[i] : subpaths[i]; + if (path in this.paths && + this.paths[path] instanceof MongooseTypes.Mixed) { + return true; + } + } + + return false; +}; + +/** + * Setup updatedAt and createdAt timestamps to documents if enabled + * + * @param {Boolean|Object} timestamps timestamps options + * @api private + */ +Schema.prototype.setupTimestamp = function(timestamps) { + if (timestamps) { + var createdAt = timestamps.createdAt || 'createdAt'; + var updatedAt = timestamps.updatedAt || 'updatedAt'; + var schemaAdditions = {}; + + schemaAdditions[updatedAt] = Date; + + if (!this.paths[createdAt]) { + schemaAdditions[createdAt] = Date; + } + + this.add(schemaAdditions); + + this.pre('save', function(next) { + var defaultTimestamp = new Date(); + var auto_id = this._id && this._id.auto; + + if (!this[createdAt] && this.isSelected(createdAt)) { + this[createdAt] = auto_id ? this._id.getTimestamp() : defaultTimestamp; + } + + if (this.isNew || this.isModified()) { + this[updatedAt] = this.isNew ? this[createdAt] : defaultTimestamp; + } + + next(); + }); + + var genUpdates = function() { + var now = new Date(); + var updates = { $set: {}, $setOnInsert: {} }; + updates.$set[updatedAt] = now; + updates.$setOnInsert[createdAt] = now; + + return updates; + }; + + this.methods.initializeTimestamps = function() { + if (!this[createdAt]) { + this[createdAt] = new Date(); + } + if (!this[updatedAt]) { + this[updatedAt] = new Date(); + } + return this; + }; + + this.pre('findOneAndUpdate', function(next) { + this.findOneAndUpdate({}, genUpdates()); + applyTimestampsToChildren(this); + next(); + }); + + this.pre('update', function(next) { + this.update({}, genUpdates()); + applyTimestampsToChildren(this); + next(); + }); + } +}; + +/*! + * ignore + */ + +function applyTimestampsToChildren(query) { + var now = new Date(); + var update = query.getUpdate(); + var keys = Object.keys(update); + var key; + var schema = query.model.schema; + var len; + var createdAt; + var updatedAt; + var timestamps; + var path; + + var hasDollarKey = keys.length && keys[0].charAt(0) === '$'; + + if (hasDollarKey) { + if (update.$push) { + for (key in update.$push) { + if (update.$push[key] && + schema.path(key).$isMongooseDocumentArray && + schema.path(key).schema.options.timestamps) { + timestamps = schema.path(key).schema.options.timestamps; + createdAt = timestamps.createdAt || 'createdAt'; + updatedAt = timestamps.updatedAt || 'updatedAt'; + update.$push[key][updatedAt] = now; + update.$push[key][createdAt] = now; + } + } + } + if (update.$set) { + for (key in update.$set) { + path = schema.path(key); + if (!path) { + continue; + } + if (Array.isArray(update.$set[key]) && path.$isMongooseDocumentArray) { + len = update.$set[key].length; + timestamps = schema.path(key).schema.options.timestamps; + if (timestamps) { + createdAt = timestamps.createdAt || 'createdAt'; + updatedAt = timestamps.updatedAt || 'updatedAt'; + for (var i = 0; i < len; ++i) { + update.$set[key][i][updatedAt] = now; + update.$set[key][i][createdAt] = now; + } + } + } else if (update.$set[key] && path.$isSingleNested) { + timestamps = schema.path(key).schema.options.timestamps; + if (timestamps) { + createdAt = timestamps.createdAt || 'createdAt'; + updatedAt = timestamps.updatedAt || 'updatedAt'; + update.$set[key][updatedAt] = now; + update.$set[key][createdAt] = now; + } + } + } + } + } +} + +/*! + * ignore + */ + +function getPositionalPathType(self, path) { + var subpaths = path.split(/\.(\d+)\.|\.(\d+)$/).filter(Boolean); + if (subpaths.length < 2) { + return self.paths[subpaths[0]]; + } + + var val = self.path(subpaths[0]); + var isNested = false; + if (!val) { + return val; + } + + var last = subpaths.length - 1, + subpath, + i = 1; + + for (; i < subpaths.length; ++i) { + isNested = false; + subpath = subpaths[i]; + + if (i === last && val && !/\D/.test(subpath)) { + if (val.$isMongooseDocumentArray) { + var oldVal = val; + val = new SchemaType(subpath); + val.cast = function(value, doc, init) { + return oldVal.cast(value, doc, init)[0]; + }; + } else if (val instanceof MongooseTypes.Array) { + // StringSchema, NumberSchema, etc + val = val.caster; + } else { + val = undefined; + } + break; + } + + // ignore if its just a position segment: path.0.subpath + if (!/\D/.test(subpath)) { + continue; + } + + if (!(val && val.schema)) { + val = undefined; + break; + } + + var type = val.schema.pathType(subpath); + isNested = (type === 'nested'); + val = val.schema.path(subpath); + } + + self.subpaths[path] = val; + if (val) { + return 'real'; + } + if (isNested) { + return 'nested'; + } + return 'adhocOrUndefined'; +} + + +/*! + * ignore + */ + +function getPositionalPath(self, path) { + getPositionalPathType(self, path); + return self.subpaths[path]; +} + +/** + * Adds a method call to the queue. + * + * @param {String} name name of the document method to call later + * @param {Array} args arguments to pass to the method + * @api public + */ + +Schema.prototype.queue = function(name, args) { + this.callQueue.push([name, args]); + return this; +}; + +/** + * Defines a pre hook for the document. + * + * ####Example + * + * var toySchema = new Schema(..); + * + * toySchema.pre('save', function (next) { + * if (!this.created) this.created = new Date; + * next(); + * }) + * + * toySchema.pre('validate', function (next) { + * if (this.name !== 'Woody') this.name = 'Woody'; + * next(); + * }) + * + * @param {String} method + * @param {Function} callback + * @see hooks.js https://github.com/bnoguchi/hooks-js/tree/31ec571cef0332e21121ee7157e0cf9728572cc3 + * @api public + */ + +Schema.prototype.pre = function() { + var name = arguments[0]; + if (IS_KAREEM_HOOK[name]) { + this.s.hooks.pre.apply(this.s.hooks, arguments); + return this; + } + return this.queue('pre', arguments); +}; + +/** + * Defines a post hook for the document + * + * var schema = new Schema(..); + * schema.post('save', function (doc) { + * console.log('this fired after a document was saved'); + * }); + * + * shema.post('find', function(docs) { + * console.log('this fired after you run a find query'); + * }); + * + * var Model = mongoose.model('Model', schema); + * + * var m = new Model(..); + * m.save(function(err) { + * console.log('this fires after the `post` hook'); + * }); + * + * m.find(function(err, docs) { + * console.log('this fires after the post find hook'); + * }); + * + * @param {String} method name of the method to hook + * @param {Function} fn callback + * @see middleware http://mongoosejs.com/docs/middleware.html + * @see hooks.js https://www.npmjs.com/package/hooks-fixed + * @see kareem http://npmjs.org/package/kareem + * @api public + */ + +Schema.prototype.post = function(method, fn) { + if (IS_KAREEM_HOOK[method]) { + this.s.hooks.post.apply(this.s.hooks, arguments); + return this; + } + // assuming that all callbacks with arity < 2 are synchronous post hooks + if (fn.length < 2) { + return this.queue('on', [arguments[0], function(doc) { + return fn.call(doc, doc); + }]); + } + + if (fn.length === 3) { + this.s.hooks.post(method + ':error', fn); + return this; + } + + return this.queue('post', [arguments[0], function(next) { + // wrap original function so that the callback goes last, + // for compatibility with old code that is using synchronous post hooks + var _this = this; + var args = Array.prototype.slice.call(arguments, 1); + fn.call(this, this, function(err) { + return next.apply(_this, [err].concat(args)); + }); + }]); +}; + +/** + * Registers a plugin for this schema. + * + * @param {Function} plugin callback + * @param {Object} [opts] + * @see plugins + * @api public + */ + +Schema.prototype.plugin = function(fn, opts) { + fn(this, opts); + return this; +}; + +/** + * Adds an instance method to documents constructed from Models compiled from this schema. + * + * ####Example + * + * var schema = kittySchema = new Schema(..); + * + * schema.method('meow', function () { + * console.log('meeeeeoooooooooooow'); + * }) + * + * var Kitty = mongoose.model('Kitty', schema); + * + * var fizz = new Kitty; + * fizz.meow(); // meeeeeooooooooooooow + * + * If a hash of name/fn pairs is passed as the only argument, each name/fn pair will be added as methods. + * + * schema.method({ + * purr: function () {} + * , scratch: function () {} + * }); + * + * // later + * fizz.purr(); + * fizz.scratch(); + * + * @param {String|Object} method name + * @param {Function} [fn] + * @api public + */ + +Schema.prototype.method = function(name, fn) { + if (typeof name !== 'string') { + for (var i in name) { + this.methods[i] = name[i]; + } + } else { + this.methods[name] = fn; + } + return this; +}; + +/** + * Adds static "class" methods to Models compiled from this schema. + * + * ####Example + * + * var schema = new Schema(..); + * schema.static('findByName', function (name, callback) { + * return this.find({ name: name }, callback); + * }); + * + * var Drink = mongoose.model('Drink', schema); + * Drink.findByName('sanpellegrino', function (err, drinks) { + * // + * }); + * + * If a hash of name/fn pairs is passed as the only argument, each name/fn pair will be added as statics. + * + * @param {String|Object} name + * @param {Function} [fn] + * @api public + */ + +Schema.prototype.static = function(name, fn) { + if (typeof name !== 'string') { + for (var i in name) { + this.statics[i] = name[i]; + } + } else { + this.statics[name] = fn; + } + return this; +}; + +/** + * Defines an index (most likely compound) for this schema. + * + * ####Example + * + * schema.index({ first: 1, last: -1 }) + * + * @param {Object} fields + * @param {Object} [options] Options to pass to [MongoDB driver's `createIndex()` function](http://mongodb.github.io/node-mongodb-native/2.0/api/Collection.html#createIndex) + * @param {String} [options.expires=null] Mongoose-specific syntactic sugar, uses [ms](https://www.npmjs.com/package/ms) to convert `expires` option into seconds for the `expireAfterSeconds` in the above link. + * @api public + */ + +Schema.prototype.index = function(fields, options) { + options || (options = {}); + + if (options.expires) { + utils.expires(options); + } + + this._indexes.push([fields, options]); + return this; +}; + +/** + * Sets/gets a schema option. + * + * ####Example + * + * schema.set('strict'); // 'true' by default + * schema.set('strict', false); // Sets 'strict' to false + * schema.set('strict'); // 'false' + * + * @param {String} key option name + * @param {Object} [value] if not passed, the current option value is returned + * @see Schema ./ + * @api public + */ + +Schema.prototype.set = function(key, value, _tags) { + if (arguments.length === 1) { + return this.options[key]; + } + + switch (key) { + case 'read': + this.options[key] = readPref(value, _tags); + break; + case 'safe': + this.options[key] = value === false + ? {w: 0} + : value; + break; + case 'timestamps': + this.setupTimestamp(value); + this.options[key] = value; + break; + default: + this.options[key] = value; + } + + return this; +}; + +/** + * Gets a schema option. + * + * @param {String} key option name + * @api public + */ + +Schema.prototype.get = function(key) { + return this.options[key]; +}; + +/** + * The allowed index types + * + * @static indexTypes + * @receiver Schema + * @api public + */ + +var indexTypes = '2d 2dsphere hashed text'.split(' '); + +Object.defineProperty(Schema, 'indexTypes', { + get: function() { + return indexTypes; + }, + set: function() { + throw new Error('Cannot overwrite Schema.indexTypes'); + } +}); + +/** + * Compiles indexes from fields and schema-level indexes + * + * @api public + */ + +Schema.prototype.indexes = function() { + 'use strict'; + + var indexes = []; + var seenPrefix = {}; + + var collectIndexes = function(schema, prefix) { + if (seenPrefix[prefix]) { + return; + } + seenPrefix[prefix] = true; + + prefix = prefix || ''; + var key, path, index, field, isObject, options, type; + var keys = Object.keys(schema.paths); + + for (var i = 0; i < keys.length; ++i) { + key = keys[i]; + path = schema.paths[key]; + + if ((path instanceof MongooseTypes.DocumentArray) || path.$isSingleNested) { + collectIndexes(path.schema, key + '.'); + } else { + index = path._index; + + if (index !== false && index !== null && index !== undefined) { + field = {}; + isObject = utils.isObject(index); + options = isObject ? index : {}; + type = typeof index === 'string' ? index : + isObject ? index.type : + false; + + if (type && ~Schema.indexTypes.indexOf(type)) { + field[prefix + key] = type; + } else if (options.text) { + field[prefix + key] = 'text'; + delete options.text; + } else { + field[prefix + key] = 1; + } + + delete options.type; + if (!('background' in options)) { + options.background = true; + } + + indexes.push([field, options]); + } + } + } + + if (prefix) { + fixSubIndexPaths(schema, prefix); + } else { + schema._indexes.forEach(function(index) { + if (!('background' in index[1])) { + index[1].background = true; + } + }); + indexes = indexes.concat(schema._indexes); + } + }; + + collectIndexes(this); + return indexes; + + /*! + * Checks for indexes added to subdocs using Schema.index(). + * These indexes need their paths prefixed properly. + * + * schema._indexes = [ [indexObj, options], [indexObj, options] ..] + */ + + function fixSubIndexPaths(schema, prefix) { + var subindexes = schema._indexes, + len = subindexes.length, + indexObj, + newindex, + klen, + keys, + key, + i = 0, + j; + + for (i = 0; i < len; ++i) { + indexObj = subindexes[i][0]; + keys = Object.keys(indexObj); + klen = keys.length; + newindex = {}; + + // use forward iteration, order matters + for (j = 0; j < klen; ++j) { + key = keys[j]; + newindex[prefix + key] = indexObj[key]; + } + + indexes.push([newindex, subindexes[i][1]]); + } + } +}; + +/** + * Creates a virtual type with the given name. + * + * @param {String} name + * @param {Object} [options] + * @return {VirtualType} + */ + +Schema.prototype.virtual = function(name, options) { + if (options && options.ref) { + if (!options.localField) { + throw new Error('Reference virtuals require `localField` option'); + } + + if (!options.foreignField) { + throw new Error('Reference virtuals require `foreignField` option'); + } + + this.pre('init', function(next, obj) { + if (name in obj) { + if (!this.$$populatedVirtuals) { + this.$$populatedVirtuals = {}; + } + + if (options.justOne) { + this.$$populatedVirtuals[name] = Array.isArray(obj[name]) ? + obj[name][0] : + obj[name]; + } else { + this.$$populatedVirtuals[name] = Array.isArray(obj[name]) ? + obj[name] : + obj[name] == null ? [] : [obj[name]]; + } + + delete obj[name]; + } + next(); + }); + + var virtual = this.virtual(name); + virtual.options = options; + return virtual. + get(function() { + if (!this.$$populatedVirtuals) { + this.$$populatedVirtuals = {}; + } + if (name in this.$$populatedVirtuals) { + return this.$$populatedVirtuals[name]; + } + return null; + }). + set(function(v) { + if (!this.$$populatedVirtuals) { + this.$$populatedVirtuals = {}; + } + this.$$populatedVirtuals[name] = v; + }); + } + + var virtuals = this.virtuals; + var parts = name.split('.'); + virtuals[name] = parts.reduce(function(mem, part, i) { + mem[part] || (mem[part] = (i === parts.length - 1) + ? new VirtualType(options, name) + : {}); + return mem[part]; + }, this.tree); + return virtuals[name]; +}; + +/** + * Returns the virtual type with the given `name`. + * + * @param {String} name + * @return {VirtualType} + */ + +Schema.prototype.virtualpath = function(name) { + return this.virtuals[name]; +}; + +/** + * Removes the given `path` (or [`paths`]). + * + * @param {String|Array} path + * + * @api public + */ +Schema.prototype.remove = function(path) { + if (typeof path === 'string') { + path = [path]; + } + if (Array.isArray(path)) { + path.forEach(function(name) { + if (this.path(name)) { + delete this.paths[name]; + + var pieces = name.split('.'); + var last = pieces.pop(); + var branch = this.tree; + for (var i = 0; i < pieces.length; ++i) { + branch = branch[pieces[i]]; + } + delete branch[last]; + } + }, this); + } +}; + +/*! + * ignore + */ + +Schema.prototype._getSchema = function(path) { + var _this = this; + var pathschema = _this.path(path); + var resultPath = []; + + if (pathschema) { + pathschema.$fullPath = path; + return pathschema; + } + + function search(parts, schema) { + var p = parts.length + 1, + foundschema, + trypath; + + while (p--) { + trypath = parts.slice(0, p).join('.'); + foundschema = schema.path(trypath); + if (foundschema) { + resultPath.push(trypath); + + if (foundschema.caster) { + // array of Mixed? + if (foundschema.caster instanceof MongooseTypes.Mixed) { + foundschema.caster.$fullPath = resultPath.join('.'); + return foundschema.caster; + } + + // Now that we found the array, we need to check if there + // are remaining document paths to look up for casting. + // Also we need to handle array.$.path since schema.path + // doesn't work for that. + // If there is no foundschema.schema we are dealing with + // a path like array.$ + if (p !== parts.length && foundschema.schema) { + if (parts[p] === '$') { + // comments.$.comments.$.title + return search(parts.slice(p + 1), foundschema.schema); + } + // this is the last path of the selector + return search(parts.slice(p), foundschema.schema); + } + } + + foundschema.$fullPath = resultPath.join('.'); + + return foundschema; + } + } + } + + // look for arrays + return search(path.split('.'), _this); +}; + +/*! + * ignore + */ + +Schema.prototype._getPathType = function(path) { + var _this = this; + var pathschema = _this.path(path); + + if (pathschema) { + return 'real'; + } + + function search(parts, schema) { + var p = parts.length + 1, + foundschema, + trypath; + + while (p--) { + trypath = parts.slice(0, p).join('.'); + foundschema = schema.path(trypath); + if (foundschema) { + if (foundschema.caster) { + // array of Mixed? + if (foundschema.caster instanceof MongooseTypes.Mixed) { + return { schema: foundschema, pathType: 'mixed' }; + } + + // Now that we found the array, we need to check if there + // are remaining document paths to look up for casting. + // Also we need to handle array.$.path since schema.path + // doesn't work for that. + // If there is no foundschema.schema we are dealing with + // a path like array.$ + if (p !== parts.length && foundschema.schema) { + if (parts[p] === '$') { + if (p === parts.length - 1) { + return { schema: foundschema, pathType: 'nested' }; + } + // comments.$.comments.$.title + return search(parts.slice(p + 1), foundschema.schema); + } + // this is the last path of the selector + return search(parts.slice(p), foundschema.schema); + } + return { + schema: foundschema, + pathType: foundschema.$isSingleNested ? 'nested' : 'array' + }; + } + return { schema: foundschema, pathType: 'real' }; + } else if (p === parts.length && schema.nested[trypath]) { + return { schema: schema, pathType: 'nested' }; + } + } + return { schema: foundschema || schema, pathType: 'undefined' }; + } + + // look for arrays + return search(path.split('.'), _this); +}; + + +/*! + * Module exports. + */ + +module.exports = exports = Schema; + +// require down here because of reference issues + +/** + * The various built-in Mongoose Schema Types. + * + * ####Example: + * + * var mongoose = require('mongoose'); + * var ObjectId = mongoose.Schema.Types.ObjectId; + * + * ####Types: + * + * - [String](#schema-string-js) + * - [Number](#schema-number-js) + * - [Boolean](#schema-boolean-js) | Bool + * - [Array](#schema-array-js) + * - [Buffer](#schema-buffer-js) + * - [Date](#schema-date-js) + * - [ObjectId](#schema-objectid-js) | Oid + * - [Mixed](#schema-mixed-js) + * + * Using this exposed access to the `Mixed` SchemaType, we can use them in our schema. + * + * var Mixed = mongoose.Schema.Types.Mixed; + * new mongoose.Schema({ _user: Mixed }) + * + * @api public + */ + +Schema.Types = MongooseTypes = require('./schema/index'); + +/*! + * ignore + */ + +exports.ObjectId = MongooseTypes.ObjectId; diff --git a/node_modules/mongoose/lib/schema/array.js b/node_modules/mongoose/lib/schema/array.js new file mode 100644 index 0000000..329d410 --- /dev/null +++ b/node_modules/mongoose/lib/schema/array.js @@ -0,0 +1,309 @@ +/*! + * Module dependencies. + */ + +var SchemaType = require('../schematype'); +var CastError = SchemaType.CastError; +var Types = { + Boolean: require('./boolean'), + Date: require('./date'), + Number: require('./number'), + String: require('./string'), + ObjectId: require('./objectid'), + Buffer: require('./buffer') +}; +var MongooseArray = require('../types').Array; +var EmbeddedDoc = require('../types').Embedded; +var Mixed = require('./mixed'); +var cast = require('../cast'); +var util = require('util'); +var utils = require('../utils'); +var castToNumber = require('./operators/helpers').castToNumber; +var geospatial = require('./operators/geospatial'); + +/** + * Array SchemaType constructor + * + * @param {String} key + * @param {SchemaType} cast + * @param {Object} options + * @inherits SchemaType + * @api public + */ + +function SchemaArray(key, cast, options, schemaOptions) { + var typeKey = 'type'; + if (schemaOptions && schemaOptions.typeKey) { + typeKey = schemaOptions.typeKey; + } + + if (cast) { + var castOptions = {}; + + if (utils.getFunctionName(cast.constructor) === 'Object') { + if (cast[typeKey]) { + // support { type: Woot } + castOptions = utils.clone(cast); // do not alter user arguments + delete castOptions[typeKey]; + cast = cast[typeKey]; + } else { + cast = Mixed; + } + } + + // support { type: 'String' } + var name = typeof cast === 'string' + ? cast + : utils.getFunctionName(cast); + + var caster = name in Types + ? Types[name] + : cast; + + this.casterConstructor = caster; + if (typeof caster === 'function') { + this.caster = new caster(null, castOptions); + } else { + this.caster = caster; + } + + if (!(this.caster instanceof EmbeddedDoc)) { + this.caster.path = key; + } + } + + SchemaType.call(this, key, options, 'Array'); + + var defaultArr; + var fn; + + if (this.defaultValue) { + defaultArr = this.defaultValue; + fn = typeof defaultArr === 'function'; + } + + if (!('defaultValue' in this) || this.defaultValue !== void 0) { + this.default(function() { + var arr = fn ? defaultArr() : defaultArr || []; + // Leave it up to `cast()` to convert the array + return arr; + }); + } +} + +/** + * This schema type's name, to defend against minifiers that mangle + * function names. + * + * @api public + */ +SchemaArray.schemaName = 'Array'; + +/*! + * Inherits from SchemaType. + */ +SchemaArray.prototype = Object.create(SchemaType.prototype); +SchemaArray.prototype.constructor = SchemaArray; + +/** + * Check if the given value satisfies a required validator. The given value + * must be not null nor undefined, and have a non-zero length. + * + * @param {Any} value + * @return {Boolean} + * @api public + */ + +SchemaArray.prototype.checkRequired = function(value) { + return !!(value && value.length); +}; + +/** + * Overrides the getters application for the population special-case + * + * @param {Object} value + * @param {Object} scope + * @api private + */ + +SchemaArray.prototype.applyGetters = function(value, scope) { + if (this.caster.options && this.caster.options.ref) { + // means the object id was populated + return value; + } + + return SchemaType.prototype.applyGetters.call(this, value, scope); +}; + +/** + * Casts values for set(). + * + * @param {Object} value + * @param {Document} doc document that triggers the casting + * @param {Boolean} init whether this is an initialization cast + * @api private + */ + +SchemaArray.prototype.cast = function(value, doc, init) { + if (Array.isArray(value)) { + if (!value.length && doc) { + var indexes = doc.schema.indexedPaths(); + + for (var i = 0, l = indexes.length; i < l; ++i) { + var pathIndex = indexes[i][0][this.path]; + if (pathIndex === '2dsphere' || pathIndex === '2d') { + return; + } + } + } + + if (!(value && value.isMongooseArray)) { + value = new MongooseArray(value, this.path, doc); + } else if (value && value.isMongooseArray) { + // We need to create a new array, otherwise change tracking will + // update the old doc (gh-4449) + value = new MongooseArray(value, this.path, doc); + } + + if (this.caster) { + try { + for (i = 0, l = value.length; i < l; i++) { + value[i] = this.caster.cast(value[i], doc, init); + } + } catch (e) { + // rethrow + throw new CastError('[' + e.kind + ']', util.inspect(value), this.path, e); + } + } + + return value; + } + // gh-2442: if we're loading this from the db and its not an array, mark + // the whole array as modified. + if (!!doc && !!init) { + doc.markModified(this.path); + } + return this.cast([value], doc, init); +}; + +/** + * Casts values for queries. + * + * @param {String} $conditional + * @param {any} [value] + * @api private + */ + +SchemaArray.prototype.castForQuery = function($conditional, value) { + var handler, + val; + + if (arguments.length === 2) { + handler = this.$conditionalHandlers[$conditional]; + + if (!handler) { + throw new Error('Can\'t use ' + $conditional + ' with Array.'); + } + + val = handler.call(this, value); + } else { + val = $conditional; + var proto = this.casterConstructor.prototype; + var method = proto && (proto.castForQuery || proto.cast); + var caster = this.caster; + + if (Array.isArray(val)) { + val = val.map(function(v) { + if (utils.isObject(v) && v.$elemMatch) { + return v; + } + if (method) { + v = method.call(caster, v); + } + return v; + }); + } else if (method) { + val = method.call(caster, val); + } + } + + return val; +}; + +function cast$all(val) { + if (!Array.isArray(val)) { + val = [val]; + } + + val = val.map(function(v) { + if (utils.isObject(v)) { + var o = {}; + o[this.path] = v; + return cast(this.casterConstructor.schema, o)[this.path]; + } + return v; + }, this); + + return this.castForQuery(val); +} + +function cast$elemMatch(val) { + var keys = Object.keys(val); + var numKeys = keys.length; + var key; + var value; + for (var i = 0; i < numKeys; ++i) { + key = keys[i]; + value = val[key]; + if (key.indexOf('$') === 0 && value) { + val[key] = this.castForQuery(key, value); + } + } + + return cast(this.casterConstructor.schema, val); +} + +var handle = SchemaArray.prototype.$conditionalHandlers = {}; + +handle.$all = cast$all; +handle.$options = String; +handle.$elemMatch = cast$elemMatch; +handle.$geoIntersects = geospatial.cast$geoIntersects; +handle.$or = handle.$and = function(val) { + if (!Array.isArray(val)) { + throw new TypeError('conditional $or/$and require array'); + } + + var ret = []; + for (var i = 0; i < val.length; ++i) { + ret.push(cast(this.casterConstructor.schema, val[i])); + } + + return ret; +}; + +handle.$near = +handle.$nearSphere = geospatial.cast$near; + +handle.$within = +handle.$geoWithin = geospatial.cast$within; + +handle.$size = +handle.$minDistance = +handle.$maxDistance = castToNumber; + +handle.$eq = +handle.$gt = +handle.$gte = +handle.$in = +handle.$lt = +handle.$lte = +handle.$ne = +handle.$nin = +handle.$regex = SchemaArray.prototype.castForQuery; + +/*! + * Module exports. + */ + +module.exports = SchemaArray; diff --git a/node_modules/mongoose/lib/schema/boolean.js b/node_modules/mongoose/lib/schema/boolean.js new file mode 100644 index 0000000..206d9fd --- /dev/null +++ b/node_modules/mongoose/lib/schema/boolean.js @@ -0,0 +1,103 @@ +/*! + * Module dependencies. + */ + +var utils = require('../utils'); + +var SchemaType = require('../schematype'); + +/** + * Boolean SchemaType constructor. + * + * @param {String} path + * @param {Object} options + * @inherits SchemaType + * @api public + */ + +function SchemaBoolean(path, options) { + SchemaType.call(this, path, options, 'Boolean'); +} + +/** + * This schema type's name, to defend against minifiers that mangle + * function names. + * + * @api public + */ +SchemaBoolean.schemaName = 'Boolean'; + +/*! + * Inherits from SchemaType. + */ +SchemaBoolean.prototype = Object.create(SchemaType.prototype); +SchemaBoolean.prototype.constructor = SchemaBoolean; + +/** + * Check if the given value satisfies a required validator. For a boolean + * to satisfy a required validator, it must be strictly equal to true or to + * false. + * + * @param {Any} value + * @return {Boolean} + * @api public + */ + +SchemaBoolean.prototype.checkRequired = function(value) { + return value === true || value === false; +}; + +/** + * Casts to boolean + * + * @param {Object} value + * @api private + */ + +SchemaBoolean.prototype.cast = function(value) { + if (value === null) { + return value; + } + if (value === '0') { + return false; + } + if (value === 'true') { + return true; + } + if (value === 'false') { + return false; + } + return !!value; +}; + +SchemaBoolean.$conditionalHandlers = + utils.options(SchemaType.prototype.$conditionalHandlers, {}); + +/** + * Casts contents for queries. + * + * @param {String} $conditional + * @param {any} val + * @api private + */ + +SchemaBoolean.prototype.castForQuery = function($conditional, val) { + var handler; + if (arguments.length === 2) { + handler = SchemaBoolean.$conditionalHandlers[$conditional]; + + if (handler) { + return handler.call(this, val); + } + + return this.cast(val); + } + + return this.cast($conditional); +}; + +/*! + * Module exports. + */ + +module.exports = SchemaBoolean; diff --git a/node_modules/mongoose/lib/schema/buffer.js b/node_modules/mongoose/lib/schema/buffer.js new file mode 100644 index 0000000..e7fe814 --- /dev/null +++ b/node_modules/mongoose/lib/schema/buffer.js @@ -0,0 +1,188 @@ +/*! + * Module dependencies. + */ + +var handleBitwiseOperator = require('./operators/bitwise'); +var utils = require('../utils'); + +var MongooseBuffer = require('../types').Buffer; +var SchemaType = require('../schematype'); + +var Binary = MongooseBuffer.Binary; +var CastError = SchemaType.CastError; +var Document; + +/** + * Buffer SchemaType constructor + * + * @param {String} key + * @param {Object} options + * @inherits SchemaType + * @api public + */ + +function SchemaBuffer(key, options) { + SchemaType.call(this, key, options, 'Buffer'); +} + +/** + * This schema type's name, to defend against minifiers that mangle + * function names. + * + * @api public + */ +SchemaBuffer.schemaName = 'Buffer'; + +/*! + * Inherits from SchemaType. + */ +SchemaBuffer.prototype = Object.create(SchemaType.prototype); +SchemaBuffer.prototype.constructor = SchemaBuffer; + +/** + * Check if the given value satisfies a required validator. To satisfy a + * required validator, a buffer must not be null or undefined and have + * non-zero length. + * + * @param {Any} value + * @param {Document} doc + * @return {Boolean} + * @api public + */ + +SchemaBuffer.prototype.checkRequired = function(value, doc) { + if (SchemaType._isRef(this, value, doc, true)) { + return !!value; + } + return !!(value && value.length); +}; + +/** + * Casts contents + * + * @param {Object} value + * @param {Document} doc document that triggers the casting + * @param {Boolean} init + * @api private + */ + +SchemaBuffer.prototype.cast = function(value, doc, init) { + var ret; + if (SchemaType._isRef(this, value, doc, init)) { + // wait! we may need to cast this to a document + + if (value === null || value === undefined) { + return value; + } + + // lazy load + Document || (Document = require('./../document')); + + if (value instanceof Document) { + value.$__.wasPopulated = true; + return value; + } + + // setting a populated path + if (Buffer.isBuffer(value)) { + return value; + } else if (!utils.isObject(value)) { + throw new CastError('buffer', value, this.path); + } + + // Handle the case where user directly sets a populated + // path to a plain object; cast to the Model used in + // the population query. + var path = doc.$__fullPath(this.path); + var owner = doc.ownerDocument ? doc.ownerDocument() : doc; + var pop = owner.populated(path, true); + ret = new pop.options.model(value); + ret.$__.wasPopulated = true; + return ret; + } + + // documents + if (value && value._id) { + value = value._id; + } + + if (value && value.isMongooseBuffer) { + return value; + } + + if (Buffer.isBuffer(value)) { + if (!value || !value.isMongooseBuffer) { + value = new MongooseBuffer(value, [this.path, doc]); + } + + return value; + } else if (value instanceof Binary) { + ret = new MongooseBuffer(value.value(true), [this.path, doc]); + if (typeof value.sub_type !== 'number') { + throw new CastError('buffer', value, this.path); + } + ret._subtype = value.sub_type; + return ret; + } + + if (value === null) { + return value; + } + + var type = typeof value; + if (type === 'string' || type === 'number' || Array.isArray(value)) { + if (type === 'number') { + value = [value]; + } + ret = new MongooseBuffer(value, [this.path, doc]); + return ret; + } + + throw new CastError('buffer', value, this.path); +}; + +/*! + * ignore + */ +function handleSingle(val) { + return this.castForQuery(val); +} + +SchemaBuffer.prototype.$conditionalHandlers = + utils.options(SchemaType.prototype.$conditionalHandlers, { + $bitsAllClear: handleBitwiseOperator, + $bitsAnyClear: handleBitwiseOperator, + $bitsAllSet: handleBitwiseOperator, + $bitsAnySet: handleBitwiseOperator, + $gt: handleSingle, + $gte: handleSingle, + $lt: handleSingle, + $lte: handleSingle + }); + +/** + * Casts contents for queries. + * + * @param {String} $conditional + * @param {any} [value] + * @api private + */ + +SchemaBuffer.prototype.castForQuery = function($conditional, val) { + var handler; + if (arguments.length === 2) { + handler = this.$conditionalHandlers[$conditional]; + if (!handler) { + throw new Error('Can\'t use ' + $conditional + ' with Buffer.'); + } + return handler.call(this, val); + } + val = $conditional; + return this.cast(val).toObject({ transform: false }); +}; + +/*! + * Module exports. + */ + +module.exports = SchemaBuffer; diff --git a/node_modules/mongoose/lib/schema/date.js b/node_modules/mongoose/lib/schema/date.js new file mode 100644 index 0000000..b7bcf22 --- /dev/null +++ b/node_modules/mongoose/lib/schema/date.js @@ -0,0 +1,296 @@ +/*! + * Module requirements. + */ + +var MongooseError = require('../error'); +var utils = require('../utils'); + +var SchemaType = require('../schematype'); + +var CastError = SchemaType.CastError; + +/** + * Date SchemaType constructor. + * + * @param {String} key + * @param {Object} options + * @inherits SchemaType + * @api public + */ + +function SchemaDate(key, options) { + SchemaType.call(this, key, options, 'Date'); +} + +/** + * This schema type's name, to defend against minifiers that mangle + * function names. + * + * @api public + */ +SchemaDate.schemaName = 'Date'; + +/*! + * Inherits from SchemaType. + */ +SchemaDate.prototype = Object.create(SchemaType.prototype); +SchemaDate.prototype.constructor = SchemaDate; + +/** + * Declares a TTL index (rounded to the nearest second) for _Date_ types only. + * + * This sets the `expireAfterSeconds` index option available in MongoDB >= 2.1.2. + * This index type is only compatible with Date types. + * + * ####Example: + * + * // expire in 24 hours + * new Schema({ createdAt: { type: Date, expires: 60*60*24 }}); + * + * `expires` utilizes the `ms` module from [guille](https://github.com/guille/) allowing us to use a friendlier syntax: + * + * ####Example: + * + * // expire in 24 hours + * new Schema({ createdAt: { type: Date, expires: '24h' }}); + * + * // expire in 1.5 hours + * new Schema({ createdAt: { type: Date, expires: '1.5h' }}); + * + * // expire in 7 days + * var schema = new Schema({ createdAt: Date }); + * schema.path('createdAt').expires('7d'); + * + * @param {Number|String} when + * @added 3.0.0 + * @return {SchemaType} this + * @api public + */ + +SchemaDate.prototype.expires = function(when) { + if (!this._index || this._index.constructor.name !== 'Object') { + this._index = {}; + } + + this._index.expires = when; + utils.expires(this._index); + return this; +}; + +/** + * Check if the given value satisfies a required validator. To satisfy + * a required validator, the given value must be an instance of `Date`. + * + * @param {Any} value + * @param {Document} doc + * @return {Boolean} + * @api public + */ + +SchemaDate.prototype.checkRequired = function(value) { + return value instanceof Date; +}; + +/** + * Sets a minimum date validator. + * + * ####Example: + * + * var s = new Schema({ d: { type: Date, min: Date('1970-01-01') }) + * var M = db.model('M', s) + * var m = new M({ d: Date('1969-12-31') }) + * m.save(function (err) { + * console.error(err) // validator error + * m.d = Date('2014-12-08'); + * m.save() // success + * }) + * + * // custom error messages + * // We can also use the special {MIN} token which will be replaced with the invalid value + * var min = [Date('1970-01-01'), 'The value of path `{PATH}` ({VALUE}) is beneath the limit ({MIN}).']; + * var schema = new Schema({ d: { type: Date, min: min }) + * var M = mongoose.model('M', schema); + * var s= new M({ d: Date('1969-12-31') }); + * s.validate(function (err) { + * console.log(String(err)) // ValidationError: The value of path `d` (1969-12-31) is before the limit (1970-01-01). + * }) + * + * @param {Date} value minimum date + * @param {String} [message] optional custom error message + * @return {SchemaType} this + * @see Customized Error Messages #error_messages_MongooseError-messages + * @api public + */ + +SchemaDate.prototype.min = function(value, message) { + if (this.minValidator) { + this.validators = this.validators.filter(function(v) { + return v.validator !== this.minValidator; + }, this); + } + + if (value) { + var msg = message || MongooseError.messages.Date.min; + msg = msg.replace(/{MIN}/, (value === Date.now ? 'Date.now()' : this.cast(value).toString())); + var _this = this; + this.validators.push({ + validator: this.minValidator = function(val) { + var min = (value === Date.now ? value() : _this.cast(value)); + return val === null || val.valueOf() >= min.valueOf(); + }, + message: msg, + type: 'min', + min: value + }); + } + + return this; +}; + +/** + * Sets a maximum date validator. + * + * ####Example: + * + * var s = new Schema({ d: { type: Date, max: Date('2014-01-01') }) + * var M = db.model('M', s) + * var m = new M({ d: Date('2014-12-08') }) + * m.save(function (err) { + * console.error(err) // validator error + * m.d = Date('2013-12-31'); + * m.save() // success + * }) + * + * // custom error messages + * // We can also use the special {MAX} token which will be replaced with the invalid value + * var max = [Date('2014-01-01'), 'The value of path `{PATH}` ({VALUE}) exceeds the limit ({MAX}).']; + * var schema = new Schema({ d: { type: Date, max: max }) + * var M = mongoose.model('M', schema); + * var s= new M({ d: Date('2014-12-08') }); + * s.validate(function (err) { + * console.log(String(err)) // ValidationError: The value of path `d` (2014-12-08) exceeds the limit (2014-01-01). + * }) + * + * @param {Date} maximum date + * @param {String} [message] optional custom error message + * @return {SchemaType} this + * @see Customized Error Messages #error_messages_MongooseError-messages + * @api public + */ + +SchemaDate.prototype.max = function(value, message) { + if (this.maxValidator) { + this.validators = this.validators.filter(function(v) { + return v.validator !== this.maxValidator; + }, this); + } + + if (value) { + var msg = message || MongooseError.messages.Date.max; + msg = msg.replace(/{MAX}/, (value === Date.now ? 'Date.now()' : this.cast(value).toString())); + var _this = this; + this.validators.push({ + validator: this.maxValidator = function(val) { + var max = (value === Date.now ? value() : _this.cast(value)); + return val === null || val.valueOf() <= max.valueOf(); + }, + message: msg, + type: 'max', + max: value + }); + } + + return this; +}; + +/** + * Casts to date + * + * @param {Object} value to cast + * @api private + */ + +SchemaDate.prototype.cast = function(value) { + // If null or undefined + if (value === null || value === void 0 || value === '') { + return null; + } + + if (value instanceof Date) { + if (isNaN(value.valueOf())) { + throw new CastError('date', value, this.path); + } + + return value; + } + + var date; + + if (typeof value === 'boolean') { + throw new CastError('date', value, this.path); + } + + if (value instanceof Number || typeof value === 'number' + || String(value) == Number(value)) { + // support for timestamps + date = new Date(Number(value)); + } else if (value.valueOf) { + // support for moment.js + date = new Date(value.valueOf()); + } + + if (!isNaN(date.valueOf())) { + return date; + } + + throw new CastError('date', value, this.path); +}; + +/*! + * Date Query casting. + * + * @api private + */ + +function handleSingle(val) { + return this.cast(val); +} + +SchemaDate.prototype.$conditionalHandlers = + utils.options(SchemaType.prototype.$conditionalHandlers, { + $gt: handleSingle, + $gte: handleSingle, + $lt: handleSingle, + $lte: handleSingle + }); + + +/** + * Casts contents for queries. + * + * @param {String} $conditional + * @param {any} [value] + * @api private + */ + +SchemaDate.prototype.castForQuery = function($conditional, val) { + var handler; + + if (arguments.length !== 2) { + return this.cast($conditional); + } + + handler = this.$conditionalHandlers[$conditional]; + + if (!handler) { + throw new Error('Can\'t use ' + $conditional + ' with Date.'); + } + + return handler.call(this, val); +}; + +/*! + * Module exports. + */ + +module.exports = SchemaDate; diff --git a/node_modules/mongoose/lib/schema/documentarray.js b/node_modules/mongoose/lib/schema/documentarray.js new file mode 100644 index 0000000..828811e --- /dev/null +++ b/node_modules/mongoose/lib/schema/documentarray.js @@ -0,0 +1,308 @@ +/* eslint no-empty: 1 */ + +/*! + * Module dependencies. + */ + +var ArrayType = require('./array'); +var CastError = require('../error/cast'); +var MongooseDocumentArray = require('../types/documentarray'); +var SchemaType = require('../schematype'); +var Subdocument = require('../types/embedded'); +var util = require('util'); + +/** + * SubdocsArray SchemaType constructor + * + * @param {String} key + * @param {Schema} schema + * @param {Object} options + * @inherits SchemaArray + * @api public + */ + +function DocumentArray(key, schema, options) { + // compile an embedded document for this schema + function EmbeddedDocument() { + Subdocument.apply(this, arguments); + } + + EmbeddedDocument.prototype = Object.create(Subdocument.prototype); + EmbeddedDocument.prototype.$__setSchema(schema); + EmbeddedDocument.schema = schema; + + // apply methods + for (var i in schema.methods) { + EmbeddedDocument.prototype[i] = schema.methods[i]; + } + + // apply statics + for (i in schema.statics) { + EmbeddedDocument[i] = schema.statics[i]; + } + + EmbeddedDocument.options = options; + + ArrayType.call(this, key, EmbeddedDocument, options); + + this.schema = schema; + this.$isMongooseDocumentArray = true; + var fn = this.defaultValue; + + if (!('defaultValue' in this) || fn !== void 0) { + this.default(function() { + var arr = fn.call(this); + if (!Array.isArray(arr)) { + arr = [arr]; + } + // Leave it up to `cast()` to convert this to a documentarray + return arr; + }); + } +} + +/** + * This schema type's name, to defend against minifiers that mangle + * function names. + * + * @api public + */ +DocumentArray.schemaName = 'DocumentArray'; + +/*! + * Inherits from ArrayType. + */ +DocumentArray.prototype = Object.create(ArrayType.prototype); +DocumentArray.prototype.constructor = DocumentArray; + +/** + * Performs local validations first, then validations on each embedded doc + * + * @api private + */ + +DocumentArray.prototype.doValidate = function(array, fn, scope, options) { + var _this = this; + SchemaType.prototype.doValidate.call(this, array, function(err) { + if (err) { + return fn(err); + } + + var count = array && array.length; + var error; + + if (!count) { + return fn(); + } + if (options && options.updateValidator) { + return fn(); + } + + // handle sparse arrays, do not use array.forEach which does not + // iterate over sparse elements yet reports array.length including + // them :( + + function callback(err) { + if (err) { + error = err; + } + --count || fn(error); + } + + for (var i = 0, len = count; i < len; ++i) { + // sidestep sparse entries + var doc = array[i]; + if (!doc) { + --count || fn(error); + continue; + } + + // If you set the array index directly, the doc might not yet be + // a full fledged mongoose subdoc, so make it into one. + if (!(doc instanceof Subdocument)) { + doc = array[i] = new _this.casterConstructor(doc, array, undefined, + undefined, i); + } + + // HACK: use $__original_validate to avoid promises so bluebird doesn't + // complain + if (doc.$__original_validate) { + doc.$__original_validate({__noPromise: true}, callback); + } else { + doc.validate({__noPromise: true}, callback); + } + } + }, scope); +}; + +/** + * Performs local validations first, then validations on each embedded doc. + * + * ####Note: + * + * This method ignores the asynchronous validators. + * + * @return {MongooseError|undefined} + * @api private + */ + +DocumentArray.prototype.doValidateSync = function(array, scope) { + var schemaTypeError = SchemaType.prototype.doValidateSync.call(this, array, scope); + if (schemaTypeError) { + return schemaTypeError; + } + + var count = array && array.length, + resultError = null; + + if (!count) { + return; + } + + // handle sparse arrays, do not use array.forEach which does not + // iterate over sparse elements yet reports array.length including + // them :( + + for (var i = 0, len = count; i < len; ++i) { + // only first error + if (resultError) { + break; + } + // sidestep sparse entries + var doc = array[i]; + if (!doc) { + continue; + } + + var subdocValidateError = doc.validateSync(); + + if (subdocValidateError) { + resultError = subdocValidateError; + } + } + + return resultError; +}; + +/** + * Casts contents + * + * @param {Object} value + * @param {Document} document that triggers the casting + * @api private + */ + +DocumentArray.prototype.cast = function(value, doc, init, prev, options) { + var selected, + subdoc, + i; + + if (!Array.isArray(value)) { + // gh-2442 mark whole array as modified if we're initializing a doc from + // the db and the path isn't an array in the document + if (!!doc && init) { + doc.markModified(this.path); + } + return this.cast([value], doc, init, prev); + } + + if (!(value && value.isMongooseDocumentArray) && + (!options || !options.skipDocumentArrayCast)) { + value = new MongooseDocumentArray(value, this.path, doc); + if (prev && prev._handlers) { + for (var key in prev._handlers) { + doc.removeListener(key, prev._handlers[key]); + } + } + } else if (value && value.isMongooseDocumentArray) { + // We need to create a new array, otherwise change tracking will + // update the old doc (gh-4449) + value = new MongooseDocumentArray(value, this.path, doc); + } + + i = value.length; + + while (i--) { + if (!value[i]) { + continue; + } + // Check if the document has a different schema (re gh-3701) + if ((value[i] instanceof Subdocument) && + value[i].schema !== this.casterConstructor.schema) { + value[i] = value[i].toObject({transform: false}); + } + if (!(value[i] instanceof Subdocument) && value[i]) { + if (init) { + selected || (selected = scopePaths(this, doc.$__.selected, init)); + subdoc = new this.casterConstructor(null, value, true, selected, i); + value[i] = subdoc.init(value[i]); + } else { + try { + subdoc = prev.id(value[i]._id); + } catch (e) { + } + + if (prev && subdoc) { + // handle resetting doc with existing id but differing data + // doc.array = [{ doc: 'val' }] + subdoc.set(value[i]); + // if set() is hooked it will have no return value + // see gh-746 + value[i] = subdoc; + } else { + try { + subdoc = new this.casterConstructor(value[i], value, undefined, + undefined, i); + // if set() is hooked it will have no return value + // see gh-746 + value[i] = subdoc; + } catch (error) { + var valueInErrorMessage = util.inspect(value[i]); + throw new CastError('embedded', valueInErrorMessage, + value._path, error); + } + } + } + } + } + + return value; +}; + +/*! + * Scopes paths selected in a query to this array. + * Necessary for proper default application of subdocument values. + * + * @param {DocumentArray} array - the array to scope `fields` paths + * @param {Object|undefined} fields - the root fields selected in the query + * @param {Boolean|undefined} init - if we are being created part of a query result + */ + +function scopePaths(array, fields, init) { + if (!(init && fields)) { + return undefined; + } + + var path = array.path + '.', + keys = Object.keys(fields), + i = keys.length, + selected = {}, + hasKeys, + key; + + while (i--) { + key = keys[i]; + if (key.indexOf(path) === 0) { + hasKeys || (hasKeys = true); + selected[key.substring(path.length)] = fields[key]; + } + } + + return hasKeys && selected || undefined; +} + +/*! + * Module exports. + */ + +module.exports = DocumentArray; diff --git a/node_modules/mongoose/lib/schema/embedded.js b/node_modules/mongoose/lib/schema/embedded.js new file mode 100644 index 0000000..e9752e8 --- /dev/null +++ b/node_modules/mongoose/lib/schema/embedded.js @@ -0,0 +1,174 @@ +'use strict'; + +/*! + * Module dependencies. + */ + +var SchemaType = require('../schematype'); +var Subdocument = require('../types/subdocument'); +var castToNumber = require('./operators/helpers').castToNumber; +var geospatial = require('./operators/geospatial'); + +module.exports = Embedded; + +/** + * Sub-schema schematype constructor + * + * @param {Schema} schema + * @param {String} key + * @param {Object} options + * @inherits SchemaType + * @api public + */ + +function Embedded(schema, path, options) { + var _embedded = function(value, path, parent) { + var _this = this; + Subdocument.apply(this, arguments); + this.$parent = parent; + if (parent) { + parent.on('save', function() { + _this.emit('save', _this); + }); + + parent.on('isNew', function(val) { + _this.isNew = val; + _this.emit('isNew', val); + }); + } + }; + _embedded.prototype = Object.create(Subdocument.prototype); + _embedded.prototype.$__setSchema(schema); + _embedded.schema = schema; + _embedded.$isSingleNested = true; + _embedded.prototype.$basePath = path; + _embedded.prototype.toBSON = function() { + return this.toObject({ transform: false }); + }; + + // apply methods + for (var i in schema.methods) { + _embedded.prototype[i] = schema.methods[i]; + } + + // apply statics + for (i in schema.statics) { + _embedded[i] = schema.statics[i]; + } + + this.caster = _embedded; + this.schema = schema; + this.$isSingleNested = true; + SchemaType.call(this, path, options, 'Embedded'); +} + +Embedded.prototype = Object.create(SchemaType.prototype); + +/** + * Special case for when users use a common location schema to represent + * locations for use with $geoWithin. + * https://docs.mongodb.org/manual/reference/operator/query/geoWithin/ + * + * @param {Object} val + * @api private + */ + +Embedded.prototype.$conditionalHandlers.$geoWithin = function(val) { + return { $geometry: this.castForQuery(val.$geometry) }; +}; + +/*! + * ignore + */ + +Embedded.prototype.$conditionalHandlers.$near = +Embedded.prototype.$conditionalHandlers.$nearSphere = geospatial.cast$near; + +Embedded.prototype.$conditionalHandlers.$within = +Embedded.prototype.$conditionalHandlers.$geoWithin = geospatial.cast$within; + +Embedded.prototype.$conditionalHandlers.$geoIntersects = + geospatial.cast$geoIntersects; + +Embedded.prototype.$conditionalHandlers.$minDistance = castToNumber; +Embedded.prototype.$conditionalHandlers.$maxDistance = castToNumber; + +/** + * Casts contents + * + * @param {Object} value + * @api private + */ + +Embedded.prototype.cast = function(val, doc, init) { + if (val && val.$isSingleNested) { + return val; + } + var subdoc = new this.caster(void 0, doc ? doc.$__.selected : void 0, doc); + if (init) { + subdoc.init(val); + } else { + subdoc.set(val, undefined, true); + } + return subdoc; +}; + +/** + * Casts contents for query + * + * @param {string} [$conditional] optional query operator (like `$eq` or `$in`) + * @param {any} value + * @api private + */ + +Embedded.prototype.castForQuery = function($conditional, val) { + var handler; + if (arguments.length === 2) { + handler = this.$conditionalHandlers[$conditional]; + if (!handler) { + throw new Error('Can\'t use ' + $conditional); + } + return handler.call(this, val); + } + val = $conditional; + if (val == null) { + return val; + } + + return new this.caster(val); +}; + +/** + * Async validation on this single nested doc. + * + * @api private + */ + +Embedded.prototype.doValidate = function(value, fn) { + SchemaType.prototype.doValidate.call(this, value, function(error) { + if (error) { + return fn(error); + } + if (!value) { + return fn(null); + } + value.validate(fn, {__noPromise: true}); + }); +}; + +/** + * Synchronously validate this single nested doc + * + * @api private + */ + +Embedded.prototype.doValidateSync = function(value) { + var schemaTypeError = SchemaType.prototype.doValidateSync.call(this, value); + if (schemaTypeError) { + return schemaTypeError; + } + if (!value) { + return; + } + return value.validateSync(); +}; diff --git a/node_modules/mongoose/lib/schema/index.js b/node_modules/mongoose/lib/schema/index.js new file mode 100644 index 0000000..f2935c1 --- /dev/null +++ b/node_modules/mongoose/lib/schema/index.js @@ -0,0 +1,30 @@ + +/*! + * Module exports. + */ + +exports.String = require('./string'); + +exports.Number = require('./number'); + +exports.Boolean = require('./boolean'); + +exports.DocumentArray = require('./documentarray'); + +exports.Embedded = require('./embedded'); + +exports.Array = require('./array'); + +exports.Buffer = require('./buffer'); + +exports.Date = require('./date'); + +exports.ObjectId = require('./objectid'); + +exports.Mixed = require('./mixed'); + +// alias + +exports.Oid = exports.ObjectId; +exports.Object = exports.Mixed; +exports.Bool = exports.Boolean; diff --git a/node_modules/mongoose/lib/schema/mixed.js b/node_modules/mongoose/lib/schema/mixed.js new file mode 100644 index 0000000..e4c23ca --- /dev/null +++ b/node_modules/mongoose/lib/schema/mixed.js @@ -0,0 +1,80 @@ +/*! + * Module dependencies. + */ + +var SchemaType = require('../schematype'); +var utils = require('../utils'); + +/** + * Mixed SchemaType constructor. + * + * @param {String} path + * @param {Object} options + * @inherits SchemaType + * @api public + */ + +function Mixed(path, options) { + if (options && options.default) { + var def = options.default; + if (Array.isArray(def) && def.length === 0) { + // make sure empty array defaults are handled + options.default = Array; + } else if (!options.shared && utils.isObject(def) && Object.keys(def).length === 0) { + // prevent odd "shared" objects between documents + options.default = function() { + return {}; + }; + } + } + + SchemaType.call(this, path, options, 'Mixed'); +} + +/** + * This schema type's name, to defend against minifiers that mangle + * function names. + * + * @api public + */ +Mixed.schemaName = 'Mixed'; + +/*! + * Inherits from SchemaType. + */ +Mixed.prototype = Object.create(SchemaType.prototype); +Mixed.prototype.constructor = Mixed; + +/** + * Casts `val` for Mixed. + * + * _this is a no-op_ + * + * @param {Object} value to cast + * @api private + */ + +Mixed.prototype.cast = function(val) { + return val; +}; + +/** + * Casts contents for queries. + * + * @param {String} $cond + * @param {any} [val] + * @api private + */ + +Mixed.prototype.castForQuery = function($cond, val) { + if (arguments.length === 2) { + return val; + } + return $cond; +}; + +/*! + * Module exports. + */ + +module.exports = Mixed; diff --git a/node_modules/mongoose/lib/schema/number.js b/node_modules/mongoose/lib/schema/number.js new file mode 100644 index 0000000..3fec612 --- /dev/null +++ b/node_modules/mongoose/lib/schema/number.js @@ -0,0 +1,290 @@ +/*! + * Module requirements. + */ + +var SchemaType = require('../schematype'); +var CastError = SchemaType.CastError; +var handleBitwiseOperator = require('./operators/bitwise'); +var MongooseError = require('../error'); +var utils = require('../utils'); +var Document; + +/** + * Number SchemaType constructor. + * + * @param {String} key + * @param {Object} options + * @inherits SchemaType + * @api public + */ + +function SchemaNumber(key, options) { + SchemaType.call(this, key, options, 'Number'); +} + +/** + * This schema type's name, to defend against minifiers that mangle + * function names. + * + * @api public + */ +SchemaNumber.schemaName = 'Number'; + +/*! + * Inherits from SchemaType. + */ +SchemaNumber.prototype = Object.create(SchemaType.prototype); +SchemaNumber.prototype.constructor = SchemaNumber; + +/** + * Check if the given value satisfies a required validator. + * + * @param {Any} value + * @param {Document} doc + * @return {Boolean} + * @api public + */ + +SchemaNumber.prototype.checkRequired = function checkRequired(value, doc) { + if (SchemaType._isRef(this, value, doc, true)) { + return !!value; + } + return typeof value === 'number' || value instanceof Number; +}; + +/** + * Sets a minimum number validator. + * + * ####Example: + * + * var s = new Schema({ n: { type: Number, min: 10 }) + * var M = db.model('M', s) + * var m = new M({ n: 9 }) + * m.save(function (err) { + * console.error(err) // validator error + * m.n = 10; + * m.save() // success + * }) + * + * // custom error messages + * // We can also use the special {MIN} token which will be replaced with the invalid value + * var min = [10, 'The value of path `{PATH}` ({VALUE}) is beneath the limit ({MIN}).']; + * var schema = new Schema({ n: { type: Number, min: min }) + * var M = mongoose.model('Measurement', schema); + * var s= new M({ n: 4 }); + * s.validate(function (err) { + * console.log(String(err)) // ValidationError: The value of path `n` (4) is beneath the limit (10). + * }) + * + * @param {Number} value minimum number + * @param {String} [message] optional custom error message + * @return {SchemaType} this + * @see Customized Error Messages #error_messages_MongooseError-messages + * @api public + */ + +SchemaNumber.prototype.min = function(value, message) { + if (this.minValidator) { + this.validators = this.validators.filter(function(v) { + return v.validator !== this.minValidator; + }, this); + } + + if (value !== null && value !== undefined) { + var msg = message || MongooseError.messages.Number.min; + msg = msg.replace(/{MIN}/, value); + this.validators.push({ + validator: this.minValidator = function(v) { + return v == null || v >= value; + }, + message: msg, + type: 'min', + min: value + }); + } + + return this; +}; + +/** + * Sets a maximum number validator. + * + * ####Example: + * + * var s = new Schema({ n: { type: Number, max: 10 }) + * var M = db.model('M', s) + * var m = new M({ n: 11 }) + * m.save(function (err) { + * console.error(err) // validator error + * m.n = 10; + * m.save() // success + * }) + * + * // custom error messages + * // We can also use the special {MAX} token which will be replaced with the invalid value + * var max = [10, 'The value of path `{PATH}` ({VALUE}) exceeds the limit ({MAX}).']; + * var schema = new Schema({ n: { type: Number, max: max }) + * var M = mongoose.model('Measurement', schema); + * var s= new M({ n: 4 }); + * s.validate(function (err) { + * console.log(String(err)) // ValidationError: The value of path `n` (4) exceeds the limit (10). + * }) + * + * @param {Number} maximum number + * @param {String} [message] optional custom error message + * @return {SchemaType} this + * @see Customized Error Messages #error_messages_MongooseError-messages + * @api public + */ + +SchemaNumber.prototype.max = function(value, message) { + if (this.maxValidator) { + this.validators = this.validators.filter(function(v) { + return v.validator !== this.maxValidator; + }, this); + } + + if (value !== null && value !== undefined) { + var msg = message || MongooseError.messages.Number.max; + msg = msg.replace(/{MAX}/, value); + this.validators.push({ + validator: this.maxValidator = function(v) { + return v == null || v <= value; + }, + message: msg, + type: 'max', + max: value + }); + } + + return this; +}; + +/** + * Casts to number + * + * @param {Object} value value to cast + * @param {Document} doc document that triggers the casting + * @param {Boolean} init + * @api private + */ + +SchemaNumber.prototype.cast = function(value, doc, init) { + if (SchemaType._isRef(this, value, doc, init)) { + // wait! we may need to cast this to a document + + if (value === null || value === undefined) { + return value; + } + + // lazy load + Document || (Document = require('./../document')); + + if (value instanceof Document) { + value.$__.wasPopulated = true; + return value; + } + + // setting a populated path + if (typeof value === 'number') { + return value; + } else if (Buffer.isBuffer(value) || !utils.isObject(value)) { + throw new CastError('number', value, this.path); + } + + // Handle the case where user directly sets a populated + // path to a plain object; cast to the Model used in + // the population query. + var path = doc.$__fullPath(this.path); + var owner = doc.ownerDocument ? doc.ownerDocument() : doc; + var pop = owner.populated(path, true); + var ret = new pop.options.model(value); + ret.$__.wasPopulated = true; + return ret; + } + + var val = value && value._id + ? value._id // documents + : value; + + if (!isNaN(val)) { + if (val === null) { + return val; + } + if (val === '') { + return null; + } + if (typeof val === 'string' || typeof val === 'boolean') { + val = Number(val); + } + if (val instanceof Number) { + return val; + } + if (typeof val === 'number') { + return val; + } + if (val.toString && !Array.isArray(val) && val.toString() == Number(val)) { + return new Number(val); + } + } + + throw new CastError('number', value, this.path); +}; + +/*! + * ignore + */ + +function handleSingle(val) { + return this.cast(val); +} + +function handleArray(val) { + var _this = this; + if (!Array.isArray(val)) { + return [this.cast(val)]; + } + return val.map(function(m) { + return _this.cast(m); + }); +} + +SchemaNumber.prototype.$conditionalHandlers = + utils.options(SchemaType.prototype.$conditionalHandlers, { + $bitsAllClear: handleBitwiseOperator, + $bitsAnyClear: handleBitwiseOperator, + $bitsAllSet: handleBitwiseOperator, + $bitsAnySet: handleBitwiseOperator, + $gt: handleSingle, + $gte: handleSingle, + $lt: handleSingle, + $lte: handleSingle, + $mod: handleArray + }); + +/** + * Casts contents for queries. + * + * @param {String} $conditional + * @param {any} [value] + * @api private + */ + +SchemaNumber.prototype.castForQuery = function($conditional, val) { + var handler; + if (arguments.length === 2) { + handler = this.$conditionalHandlers[$conditional]; + if (!handler) { + throw new Error('Can\'t use ' + $conditional + ' with Number.'); + } + return handler.call(this, val); + } + val = this.cast($conditional); + return val; +}; + +/*! + * Module exports. + */ + +module.exports = SchemaNumber; diff --git a/node_modules/mongoose/lib/schema/objectid.js b/node_modules/mongoose/lib/schema/objectid.js new file mode 100644 index 0000000..2885823 --- /dev/null +++ b/node_modules/mongoose/lib/schema/objectid.js @@ -0,0 +1,207 @@ +/* eslint no-empty: 1 */ + +/*! + * Module dependencies. + */ + +var SchemaType = require('../schematype'), + CastError = SchemaType.CastError, + oid = require('../types/objectid'), + utils = require('../utils'), + Document; + +/** + * ObjectId SchemaType constructor. + * + * @param {String} key + * @param {Object} options + * @inherits SchemaType + * @api public + */ + +function ObjectId(key, options) { + SchemaType.call(this, key, options, 'ObjectID'); +} + +/** + * This schema type's name, to defend against minifiers that mangle + * function names. + * + * @api public + */ +ObjectId.schemaName = 'ObjectId'; + +/*! + * Inherits from SchemaType. + */ +ObjectId.prototype = Object.create(SchemaType.prototype); +ObjectId.prototype.constructor = ObjectId; + +/** + * Adds an auto-generated ObjectId default if turnOn is true. + * @param {Boolean} turnOn auto generated ObjectId defaults + * @api public + * @return {SchemaType} this + */ + +ObjectId.prototype.auto = function(turnOn) { + if (turnOn) { + this.default(defaultId); + this.set(resetId); + } + + return this; +}; + +/** + * Check if the given value satisfies a required validator. + * + * @param {Any} value + * @param {Document} doc + * @return {Boolean} + * @api public + */ + +ObjectId.prototype.checkRequired = function checkRequired(value, doc) { + if (SchemaType._isRef(this, value, doc, true)) { + return !!value; + } + return value instanceof oid; +}; + +/** + * Casts to ObjectId + * + * @param {Object} value + * @param {Object} doc + * @param {Boolean} init whether this is an initialization cast + * @api private + */ + +ObjectId.prototype.cast = function(value, doc, init) { + if (SchemaType._isRef(this, value, doc, init)) { + // wait! we may need to cast this to a document + + if (value === null || value === undefined) { + return value; + } + + // lazy load + Document || (Document = require('./../document')); + + if (value instanceof Document) { + value.$__.wasPopulated = true; + return value; + } + + // setting a populated path + if (value instanceof oid) { + return value; + } else if (Buffer.isBuffer(value) || !utils.isObject(value)) { + throw new CastError('ObjectId', value, this.path); + } + + // Handle the case where user directly sets a populated + // path to a plain object; cast to the Model used in + // the population query. + var path = doc.$__fullPath(this.path); + var owner = doc.ownerDocument ? doc.ownerDocument() : doc; + var pop = owner.populated(path, true); + var ret = value; + if (!doc.$__.populated || + !doc.$__.populated[path] || + !doc.$__.populated[path].options || + !doc.$__.populated[path].options.options || + !doc.$__.populated[path].options.options.lean) { + ret = new pop.options.model(value); + ret.$__.wasPopulated = true; + } + + return ret; + } + + if (value === null || value === undefined) { + return value; + } + + if (value instanceof oid) { + return value; + } + + if (value._id) { + if (value._id instanceof oid) { + return value._id; + } + if (value._id.toString instanceof Function) { + try { + return new oid(value._id.toString()); + } catch (e) { + } + } + } + + if (value.toString instanceof Function) { + try { + return new oid(value.toString()); + } catch (err) { + throw new CastError('ObjectId', value, this.path); + } + } + + throw new CastError('ObjectId', value, this.path); +}; + +/*! + * ignore + */ + +function handleSingle(val) { + return this.cast(val); +} + +ObjectId.prototype.$conditionalHandlers = + utils.options(SchemaType.prototype.$conditionalHandlers, { + $gt: handleSingle, + $gte: handleSingle, + $lt: handleSingle, + $lte: handleSingle + }); + +/** + * Casts contents for queries. + * + * @param {String} $conditional + * @param {any} [val] + * @api private + */ + +ObjectId.prototype.castForQuery = function($conditional, val) { + var handler; + if (arguments.length === 2) { + handler = this.$conditionalHandlers[$conditional]; + if (!handler) { + throw new Error('Can\'t use ' + $conditional + ' with ObjectId.'); + } + return handler.call(this, val); + } + return this.cast($conditional); +}; + +/*! + * ignore + */ + +function defaultId() { + return new oid(); +} + +function resetId(v) { + this.$__._id = null; + return v; +} + +/*! + * Module exports. + */ + +module.exports = ObjectId; diff --git a/node_modules/mongoose/lib/schema/operators/bitwise.js b/node_modules/mongoose/lib/schema/operators/bitwise.js new file mode 100644 index 0000000..c1fdd34 --- /dev/null +++ b/node_modules/mongoose/lib/schema/operators/bitwise.js @@ -0,0 +1,36 @@ +/*! + * Module requirements. + */ + +var CastError = require('../../error/cast'); + +/*! + * ignore + */ + +function handleBitwiseOperator(val) { + var _this = this; + if (Array.isArray(val)) { + return val.map(function(v) { + return _castNumber(_this.path, v); + }); + } else if (Buffer.isBuffer(val)) { + return val; + } + // Assume trying to cast to number + return _castNumber(_this.path, val); +} + +/*! + * ignore + */ + +function _castNumber(path, num) { + var v = Number(num); + if (isNaN(v)) { + throw new CastError('number', num, path); + } + return v; +} + +module.exports = handleBitwiseOperator; diff --git a/node_modules/mongoose/lib/schema/operators/geospatial.js b/node_modules/mongoose/lib/schema/operators/geospatial.js new file mode 100644 index 0000000..b490d2d --- /dev/null +++ b/node_modules/mongoose/lib/schema/operators/geospatial.js @@ -0,0 +1,100 @@ +/*! + * Module requirements. + */ + +var castArraysOfNumbers = require('./helpers').castArraysOfNumbers; +var castToNumber = require('./helpers').castToNumber; + +/*! + * ignore + */ + +exports.cast$geoIntersects = cast$geoIntersects; +exports.cast$near = cast$near; +exports.cast$within = cast$within; + +function cast$near(val) { + var SchemaArray = require('../array'); + + if (Array.isArray(val)) { + castArraysOfNumbers(val, this); + return val; + } + + _castMinMaxDistance(this, val); + + if (val && val.$geometry) { + return cast$geometry(val, this); + } + + return SchemaArray.prototype.castForQuery.call(this, val); +} + +function cast$geometry(val, self) { + switch (val.$geometry.type) { + case 'Polygon': + case 'LineString': + case 'Point': + castArraysOfNumbers(val.$geometry.coordinates, self); + break; + default: + // ignore unknowns + break; + } + + _castMinMaxDistance(this, val); + + return val; +} + +function cast$within(val) { + _castMinMaxDistance(this, val); + + if (val.$box || val.$polygon) { + var type = val.$box ? '$box' : '$polygon'; + val[type].forEach(function(arr) { + if (!Array.isArray(arr)) { + var msg = 'Invalid $within $box argument. ' + + 'Expected an array, received ' + arr; + throw new TypeError(msg); + } + arr.forEach(function(v, i) { + arr[i] = castToNumber.call(this, v); + }); + }); + } else if (val.$center || val.$centerSphere) { + type = val.$center ? '$center' : '$centerSphere'; + val[type].forEach(function(item, i) { + if (Array.isArray(item)) { + item.forEach(function(v, j) { + item[j] = castToNumber.call(this, v); + }); + } else { + val[type][i] = castToNumber.call(this, item); + } + }); + } else if (val.$geometry) { + cast$geometry(val, this); + } + + return val; +} + +function cast$geoIntersects(val) { + var geo = val.$geometry; + if (!geo) { + return; + } + + cast$geometry(val, this); + return val; +} + +function _castMinMaxDistance(self, val) { + if (val.$maxDistance) { + val.$maxDistance = castToNumber.call(self, val.$maxDistance); + } + if (val.$minDistance) { + val.$minDistance = castToNumber.call(self, val.$minDistance); + } +} diff --git a/node_modules/mongoose/lib/schema/operators/helpers.js b/node_modules/mongoose/lib/schema/operators/helpers.js new file mode 100644 index 0000000..850354a --- /dev/null +++ b/node_modules/mongoose/lib/schema/operators/helpers.js @@ -0,0 +1,34 @@ +'use strict'; + +/*! + * Module requirements. + */ + +var Types = { + Number: require('../number') +}; + +/*! + * @ignore + */ + +exports.castToNumber = castToNumber; +exports.castArraysOfNumbers = castArraysOfNumbers; + +/*! + * @ignore + */ + +function castToNumber(val) { + return Types.Number.prototype.cast.call(this, val); +} + +function castArraysOfNumbers(arr, self) { + arr.forEach(function(v, i) { + if (Array.isArray(v)) { + castArraysOfNumbers(v, self); + } else { + arr[i] = castToNumber.call(self, v); + } + }); +} diff --git a/node_modules/mongoose/lib/schema/string.js b/node_modules/mongoose/lib/schema/string.js new file mode 100644 index 0000000..ba25b38 --- /dev/null +++ b/node_modules/mongoose/lib/schema/string.js @@ -0,0 +1,509 @@ +/*! + * Module dependencies. + */ + +var SchemaType = require('../schematype'); +var CastError = SchemaType.CastError; +var MongooseError = require('../error'); +var utils = require('../utils'); +var Document; + +/** + * String SchemaType constructor. + * + * @param {String} key + * @param {Object} options + * @inherits SchemaType + * @api public + */ + +function SchemaString(key, options) { + this.enumValues = []; + this.regExp = null; + SchemaType.call(this, key, options, 'String'); +} + +/** + * This schema type's name, to defend against minifiers that mangle + * function names. + * + * @api public + */ +SchemaString.schemaName = 'String'; + +/*! + * Inherits from SchemaType. + */ +SchemaString.prototype = Object.create(SchemaType.prototype); +SchemaString.prototype.constructor = SchemaString; + +/** + * Adds an enum validator + * + * ####Example: + * + * var states = 'opening open closing closed'.split(' ') + * var s = new Schema({ state: { type: String, enum: states }}) + * var M = db.model('M', s) + * var m = new M({ state: 'invalid' }) + * m.save(function (err) { + * console.error(String(err)) // ValidationError: `invalid` is not a valid enum value for path `state`. + * m.state = 'open' + * m.save(callback) // success + * }) + * + * // or with custom error messages + * var enu = { + * values: 'opening open closing closed'.split(' '), + * message: 'enum validator failed for path `{PATH}` with value `{VALUE}`' + * } + * var s = new Schema({ state: { type: String, enum: enu }) + * var M = db.model('M', s) + * var m = new M({ state: 'invalid' }) + * m.save(function (err) { + * console.error(String(err)) // ValidationError: enum validator failed for path `state` with value `invalid` + * m.state = 'open' + * m.save(callback) // success + * }) + * + * @param {String|Object} [args...] enumeration values + * @return {SchemaType} this + * @see Customized Error Messages #error_messages_MongooseError-messages + * @api public + */ + +SchemaString.prototype.enum = function() { + if (this.enumValidator) { + this.validators = this.validators.filter(function(v) { + return v.validator !== this.enumValidator; + }, this); + this.enumValidator = false; + } + + if (arguments[0] === void 0 || arguments[0] === false) { + return this; + } + + var values; + var errorMessage; + + if (utils.isObject(arguments[0])) { + values = arguments[0].values; + errorMessage = arguments[0].message; + } else { + values = arguments; + errorMessage = MongooseError.messages.String.enum; + } + + for (var i = 0; i < values.length; i++) { + if (undefined !== values[i]) { + this.enumValues.push(this.cast(values[i])); + } + } + + var vals = this.enumValues; + this.enumValidator = function(v) { + return undefined === v || ~vals.indexOf(v); + }; + this.validators.push({ + validator: this.enumValidator, + message: errorMessage, + type: 'enum', + enumValues: vals + }); + + return this; +}; + +/** + * Adds a lowercase setter. + * + * ####Example: + * + * var s = new Schema({ email: { type: String, lowercase: true }}) + * var M = db.model('M', s); + * var m = new M({ email: 'SomeEmail@example.COM' }); + * console.log(m.email) // someemail@example.com + * + * @api public + * @return {SchemaType} this + */ + +SchemaString.prototype.lowercase = function() { + return this.set(function(v, self) { + if (typeof v !== 'string') { + v = self.cast(v); + } + if (v) { + return v.toLowerCase(); + } + return v; + }); +}; + +/** + * Adds an uppercase setter. + * + * ####Example: + * + * var s = new Schema({ caps: { type: String, uppercase: true }}) + * var M = db.model('M', s); + * var m = new M({ caps: 'an example' }); + * console.log(m.caps) // AN EXAMPLE + * + * @api public + * @return {SchemaType} this + */ + +SchemaString.prototype.uppercase = function() { + return this.set(function(v, self) { + if (typeof v !== 'string') { + v = self.cast(v); + } + if (v) { + return v.toUpperCase(); + } + return v; + }); +}; + +/** + * Adds a trim setter. + * + * The string value will be trimmed when set. + * + * ####Example: + * + * var s = new Schema({ name: { type: String, trim: true }}) + * var M = db.model('M', s) + * var string = ' some name ' + * console.log(string.length) // 11 + * var m = new M({ name: string }) + * console.log(m.name.length) // 9 + * + * @api public + * @return {SchemaType} this + */ + +SchemaString.prototype.trim = function(shouldTrim) { + if (arguments.length > 0 && !shouldTrim) { + return this; + } + return this.set(function(v, self) { + if (typeof v !== 'string') { + v = self.cast(v); + } + if (v) { + return v.trim(); + } + return v; + }); +}; + +/** + * Sets a minimum length validator. + * + * ####Example: + * + * var schema = new Schema({ postalCode: { type: String, minlength: 5 }) + * var Address = db.model('Address', schema) + * var address = new Address({ postalCode: '9512' }) + * address.save(function (err) { + * console.error(err) // validator error + * address.postalCode = '95125'; + * address.save() // success + * }) + * + * // custom error messages + * // We can also use the special {MINLENGTH} token which will be replaced with the minimum allowed length + * var minlength = [5, 'The value of path `{PATH}` (`{VALUE}`) is shorter than the minimum allowed length ({MINLENGTH}).']; + * var schema = new Schema({ postalCode: { type: String, minlength: minlength }) + * var Address = mongoose.model('Address', schema); + * var address = new Address({ postalCode: '9512' }); + * address.validate(function (err) { + * console.log(String(err)) // ValidationError: The value of path `postalCode` (`9512`) is shorter than the minimum length (5). + * }) + * + * @param {Number} value minimum string length + * @param {String} [message] optional custom error message + * @return {SchemaType} this + * @see Customized Error Messages #error_messages_MongooseError-messages + * @api public + */ + +SchemaString.prototype.minlength = function(value, message) { + if (this.minlengthValidator) { + this.validators = this.validators.filter(function(v) { + return v.validator !== this.minlengthValidator; + }, this); + } + + if (value !== null && value !== undefined) { + var msg = message || MongooseError.messages.String.minlength; + msg = msg.replace(/{MINLENGTH}/, value); + this.validators.push({ + validator: this.minlengthValidator = function(v) { + return v === null || v.length >= value; + }, + message: msg, + type: 'minlength', + minlength: value + }); + } + + return this; +}; + +/** + * Sets a maximum length validator. + * + * ####Example: + * + * var schema = new Schema({ postalCode: { type: String, maxlength: 9 }) + * var Address = db.model('Address', schema) + * var address = new Address({ postalCode: '9512512345' }) + * address.save(function (err) { + * console.error(err) // validator error + * address.postalCode = '95125'; + * address.save() // success + * }) + * + * // custom error messages + * // We can also use the special {MAXLENGTH} token which will be replaced with the maximum allowed length + * var maxlength = [9, 'The value of path `{PATH}` (`{VALUE}`) exceeds the maximum allowed length ({MAXLENGTH}).']; + * var schema = new Schema({ postalCode: { type: String, maxlength: maxlength }) + * var Address = mongoose.model('Address', schema); + * var address = new Address({ postalCode: '9512512345' }); + * address.validate(function (err) { + * console.log(String(err)) // ValidationError: The value of path `postalCode` (`9512512345`) exceeds the maximum allowed length (9). + * }) + * + * @param {Number} value maximum string length + * @param {String} [message] optional custom error message + * @return {SchemaType} this + * @see Customized Error Messages #error_messages_MongooseError-messages + * @api public + */ + +SchemaString.prototype.maxlength = function(value, message) { + if (this.maxlengthValidator) { + this.validators = this.validators.filter(function(v) { + return v.validator !== this.maxlengthValidator; + }, this); + } + + if (value !== null && value !== undefined) { + var msg = message || MongooseError.messages.String.maxlength; + msg = msg.replace(/{MAXLENGTH}/, value); + this.validators.push({ + validator: this.maxlengthValidator = function(v) { + return v === null || v.length <= value; + }, + message: msg, + type: 'maxlength', + maxlength: value + }); + } + + return this; +}; + +/** + * Sets a regexp validator. + * + * Any value that does not pass `regExp`.test(val) will fail validation. + * + * ####Example: + * + * var s = new Schema({ name: { type: String, match: /^a/ }}) + * var M = db.model('M', s) + * var m = new M({ name: 'I am invalid' }) + * m.validate(function (err) { + * console.error(String(err)) // "ValidationError: Path `name` is invalid (I am invalid)." + * m.name = 'apples' + * m.validate(function (err) { + * assert.ok(err) // success + * }) + * }) + * + * // using a custom error message + * var match = [ /\.html$/, "That file doesn't end in .html ({VALUE})" ]; + * var s = new Schema({ file: { type: String, match: match }}) + * var M = db.model('M', s); + * var m = new M({ file: 'invalid' }); + * m.validate(function (err) { + * console.log(String(err)) // "ValidationError: That file doesn't end in .html (invalid)" + * }) + * + * Empty strings, `undefined`, and `null` values always pass the match validator. If you require these values, enable the `required` validator also. + * + * var s = new Schema({ name: { type: String, match: /^a/, required: true }}) + * + * @param {RegExp} regExp regular expression to test against + * @param {String} [message] optional custom error message + * @return {SchemaType} this + * @see Customized Error Messages #error_messages_MongooseError-messages + * @api public + */ + +SchemaString.prototype.match = function match(regExp, message) { + // yes, we allow multiple match validators + + var msg = message || MongooseError.messages.String.match; + + var matchValidator = function(v) { + if (!regExp) { + return false; + } + + var ret = ((v != null && v !== '') + ? regExp.test(v) + : true); + return ret; + }; + + this.validators.push({ + validator: matchValidator, + message: msg, + type: 'regexp', + regexp: regExp + }); + return this; +}; + +/** + * Check if the given value satisfies a required validator. + * + * @param {Any} value + * @param {Document} doc + * @return {Boolean} + * @api public + */ + +SchemaString.prototype.checkRequired = function checkRequired(value, doc) { + if (SchemaType._isRef(this, value, doc, true)) { + return !!value; + } + return (value instanceof String || typeof value === 'string') && value.length; +}; + +/** + * Casts to String + * + * @api private + */ + +SchemaString.prototype.cast = function(value, doc, init) { + if (SchemaType._isRef(this, value, doc, init)) { + // wait! we may need to cast this to a document + + if (value === null || value === undefined) { + return value; + } + + // lazy load + Document || (Document = require('./../document')); + + if (value instanceof Document) { + value.$__.wasPopulated = true; + return value; + } + + // setting a populated path + if (typeof value === 'string') { + return value; + } else if (Buffer.isBuffer(value) || !utils.isObject(value)) { + throw new CastError('string', value, this.path); + } + + // Handle the case where user directly sets a populated + // path to a plain object; cast to the Model used in + // the population query. + var path = doc.$__fullPath(this.path); + var owner = doc.ownerDocument ? doc.ownerDocument() : doc; + var pop = owner.populated(path, true); + var ret = new pop.options.model(value); + ret.$__.wasPopulated = true; + return ret; + } + + // If null or undefined + if (value === null || value === undefined) { + return value; + } + + if (typeof value !== 'undefined') { + // handle documents being passed + if (value._id && typeof value._id === 'string') { + return value._id; + } + + // Re: gh-647 and gh-3030, we're ok with casting using `toString()` + // **unless** its the default Object.toString, because "[object Object]" + // doesn't really qualify as useful data + if (value.toString && value.toString !== Object.prototype.toString) { + return value.toString(); + } + } + + throw new CastError('string', value, this.path); +}; + +/*! + * ignore + */ + +function handleSingle(val) { + return this.castForQuery(val); +} + +function handleArray(val) { + var _this = this; + if (!Array.isArray(val)) { + return [this.castForQuery(val)]; + } + return val.map(function(m) { + return _this.castForQuery(m); + }); +} + +SchemaString.prototype.$conditionalHandlers = + utils.options(SchemaType.prototype.$conditionalHandlers, { + $all: handleArray, + $gt: handleSingle, + $gte: handleSingle, + $lt: handleSingle, + $lte: handleSingle, + $options: handleSingle, + $regex: handleSingle + }); + +/** + * Casts contents for queries. + * + * @param {String} $conditional + * @param {any} [val] + * @api private + */ + +SchemaString.prototype.castForQuery = function($conditional, val) { + var handler; + if (arguments.length === 2) { + handler = this.$conditionalHandlers[$conditional]; + if (!handler) { + throw new Error('Can\'t use ' + $conditional + ' with String.'); + } + return handler.call(this, val); + } + val = $conditional; + if (Object.prototype.toString.call(val) === '[object RegExp]') { + return val; + } + return this.cast(val); +}; + +/*! + * Module exports. + */ + +module.exports = SchemaString; diff --git a/node_modules/mongoose/lib/schematype.js b/node_modules/mongoose/lib/schematype.js new file mode 100644 index 0000000..8c796d9 --- /dev/null +++ b/node_modules/mongoose/lib/schematype.js @@ -0,0 +1,920 @@ +/*! + * Module dependencies. + */ + +var utils = require('./utils'); +var MongooseError = require('./error'); +var CastError = MongooseError.CastError; +var ValidatorError = MongooseError.ValidatorError; + +/** + * SchemaType constructor + * + * @param {String} path + * @param {Object} [options] + * @param {String} [instance] + * @api public + */ + +function SchemaType(path, options, instance) { + this.path = path; + this.instance = instance; + this.validators = []; + this.setters = []; + this.getters = []; + this.options = options; + this._index = null; + this.selected; + + for (var i in options) { + if (this[i] && typeof this[i] === 'function') { + // { unique: true, index: true } + if (i === 'index' && this._index) { + continue; + } + + var opts = Array.isArray(options[i]) + ? options[i] + : [options[i]]; + + this[i].apply(this, opts); + } + } +} + +/** + * Sets a default value for this SchemaType. + * + * ####Example: + * + * var schema = new Schema({ n: { type: Number, default: 10 }) + * var M = db.model('M', schema) + * var m = new M; + * console.log(m.n) // 10 + * + * Defaults can be either `functions` which return the value to use as the default or the literal value itself. Either way, the value will be cast based on its schema type before being set during document creation. + * + * ####Example: + * + * // values are cast: + * var schema = new Schema({ aNumber: { type: Number, default: 4.815162342 }}) + * var M = db.model('M', schema) + * var m = new M; + * console.log(m.aNumber) // 4.815162342 + * + * // default unique objects for Mixed types: + * var schema = new Schema({ mixed: Schema.Types.Mixed }); + * schema.path('mixed').default(function () { + * return {}; + * }); + * + * // if we don't use a function to return object literals for Mixed defaults, + * // each document will receive a reference to the same object literal creating + * // a "shared" object instance: + * var schema = new Schema({ mixed: Schema.Types.Mixed }); + * schema.path('mixed').default({}); + * var M = db.model('M', schema); + * var m1 = new M; + * m1.mixed.added = 1; + * console.log(m1.mixed); // { added: 1 } + * var m2 = new M; + * console.log(m2.mixed); // { added: 1 } + * + * @param {Function|any} val the default value + * @return {defaultValue} + * @api public + */ + +SchemaType.prototype.default = function(val) { + if (arguments.length === 1) { + if (val === void 0) { + this.defaultValue = void 0; + return void 0; + } + this.defaultValue = val; + return this.defaultValue; + } else if (arguments.length > 1) { + this.defaultValue = utils.args(arguments); + } + return this.defaultValue; +}; + +/** + * Declares the index options for this schematype. + * + * ####Example: + * + * var s = new Schema({ name: { type: String, index: true }) + * var s = new Schema({ loc: { type: [Number], index: 'hashed' }) + * var s = new Schema({ loc: { type: [Number], index: '2d', sparse: true }) + * var s = new Schema({ loc: { type: [Number], index: { type: '2dsphere', sparse: true }}) + * var s = new Schema({ date: { type: Date, index: { unique: true, expires: '1d' }}) + * Schema.path('my.path').index(true); + * Schema.path('my.date').index({ expires: 60 }); + * Schema.path('my.path').index({ unique: true, sparse: true }); + * + * ####NOTE: + * + * _Indexes are created in the background by default. Specify `background: false` to override._ + * + * [Direction doesn't matter for single key indexes](http://www.mongodb.org/display/DOCS/Indexes#Indexes-CompoundKeysIndexes) + * + * @param {Object|Boolean|String} options + * @return {SchemaType} this + * @api public + */ + +SchemaType.prototype.index = function(options) { + this._index = options; + utils.expires(this._index); + return this; +}; + +/** + * Declares an unique index. + * + * ####Example: + * + * var s = new Schema({ name: { type: String, unique: true }}); + * Schema.path('name').index({ unique: true }); + * + * _NOTE: violating the constraint returns an `E11000` error from MongoDB when saving, not a Mongoose validation error._ + * + * @param {Boolean} bool + * @return {SchemaType} this + * @api public + */ + +SchemaType.prototype.unique = function(bool) { + if (this._index === false) { + if (!bool) { + return; + } + throw new Error('Path "' + this.path + '" may not have `index` set to ' + + 'false and `unique` set to true'); + } + if (this._index == null || this._index === true) { + this._index = {}; + } else if (typeof this._index === 'string') { + this._index = {type: this._index}; + } + + this._index.unique = bool; + return this; +}; + +/** + * Declares a full text index. + * + * ###Example: + * + * var s = new Schema({name : {type: String, text : true }) + * Schema.path('name').index({text : true}); + * @param {Boolean} bool + * @return {SchemaType} this + * @api public + */ + +SchemaType.prototype.text = function(bool) { + if (this._index === null || this._index === undefined || + typeof this._index === 'boolean') { + this._index = {}; + } else if (typeof this._index === 'string') { + this._index = {type: this._index}; + } + + this._index.text = bool; + return this; +}; + +/** + * Declares a sparse index. + * + * ####Example: + * + * var s = new Schema({ name: { type: String, sparse: true }) + * Schema.path('name').index({ sparse: true }); + * + * @param {Boolean} bool + * @return {SchemaType} this + * @api public + */ + +SchemaType.prototype.sparse = function(bool) { + if (this._index === null || this._index === undefined || + typeof this._index === 'boolean') { + this._index = {}; + } else if (typeof this._index === 'string') { + this._index = {type: this._index}; + } + + this._index.sparse = bool; + return this; +}; + +/** + * Adds a setter to this schematype. + * + * ####Example: + * + * function capitalize (val) { + * if (typeof val !== 'string') val = ''; + * return val.charAt(0).toUpperCase() + val.substring(1); + * } + * + * // defining within the schema + * var s = new Schema({ name: { type: String, set: capitalize }}) + * + * // or by retreiving its SchemaType + * var s = new Schema({ name: String }) + * s.path('name').set(capitalize) + * + * Setters allow you to transform the data before it gets to the raw mongodb document and is set as a value on an actual key. + * + * Suppose you are implementing user registration for a website. Users provide an email and password, which gets saved to mongodb. The email is a string that you will want to normalize to lower case, in order to avoid one email having more than one account -- e.g., otherwise, avenue@q.com can be registered for 2 accounts via avenue@q.com and AvEnUe@Q.CoM. + * + * You can set up email lower case normalization easily via a Mongoose setter. + * + * function toLower (v) { + * return v.toLowerCase(); + * } + * + * var UserSchema = new Schema({ + * email: { type: String, set: toLower } + * }) + * + * var User = db.model('User', UserSchema) + * + * var user = new User({email: 'AVENUE@Q.COM'}) + * console.log(user.email); // 'avenue@q.com' + * + * // or + * var user = new User + * user.email = 'Avenue@Q.com' + * console.log(user.email) // 'avenue@q.com' + * + * As you can see above, setters allow you to transform the data before it gets to the raw mongodb document and is set as a value on an actual key. + * + * _NOTE: we could have also just used the built-in `lowercase: true` SchemaType option instead of defining our own function._ + * + * new Schema({ email: { type: String, lowercase: true }}) + * + * Setters are also passed a second argument, the schematype on which the setter was defined. This allows for tailored behavior based on options passed in the schema. + * + * function inspector (val, schematype) { + * if (schematype.options.required) { + * return schematype.path + ' is required'; + * } else { + * return val; + * } + * } + * + * var VirusSchema = new Schema({ + * name: { type: String, required: true, set: inspector }, + * taxonomy: { type: String, set: inspector } + * }) + * + * var Virus = db.model('Virus', VirusSchema); + * var v = new Virus({ name: 'Parvoviridae', taxonomy: 'Parvovirinae' }); + * + * console.log(v.name); // name is required + * console.log(v.taxonomy); // Parvovirinae + * + * @param {Function} fn + * @return {SchemaType} this + * @api public + */ + +SchemaType.prototype.set = function(fn) { + if (typeof fn !== 'function') { + throw new TypeError('A setter must be a function.'); + } + this.setters.push(fn); + return this; +}; + +/** + * Adds a getter to this schematype. + * + * ####Example: + * + * function dob (val) { + * if (!val) return val; + * return (val.getMonth() + 1) + "/" + val.getDate() + "/" + val.getFullYear(); + * } + * + * // defining within the schema + * var s = new Schema({ born: { type: Date, get: dob }) + * + * // or by retreiving its SchemaType + * var s = new Schema({ born: Date }) + * s.path('born').get(dob) + * + * Getters allow you to transform the representation of the data as it travels from the raw mongodb document to the value that you see. + * + * Suppose you are storing credit card numbers and you want to hide everything except the last 4 digits to the mongoose user. You can do so by defining a getter in the following way: + * + * function obfuscate (cc) { + * return '****-****-****-' + cc.slice(cc.length-4, cc.length); + * } + * + * var AccountSchema = new Schema({ + * creditCardNumber: { type: String, get: obfuscate } + * }); + * + * var Account = db.model('Account', AccountSchema); + * + * Account.findById(id, function (err, found) { + * console.log(found.creditCardNumber); // '****-****-****-1234' + * }); + * + * Getters are also passed a second argument, the schematype on which the getter was defined. This allows for tailored behavior based on options passed in the schema. + * + * function inspector (val, schematype) { + * if (schematype.options.required) { + * return schematype.path + ' is required'; + * } else { + * return schematype.path + ' is not'; + * } + * } + * + * var VirusSchema = new Schema({ + * name: { type: String, required: true, get: inspector }, + * taxonomy: { type: String, get: inspector } + * }) + * + * var Virus = db.model('Virus', VirusSchema); + * + * Virus.findById(id, function (err, virus) { + * console.log(virus.name); // name is required + * console.log(virus.taxonomy); // taxonomy is not + * }) + * + * @param {Function} fn + * @return {SchemaType} this + * @api public + */ + +SchemaType.prototype.get = function(fn) { + if (typeof fn !== 'function') { + throw new TypeError('A getter must be a function.'); + } + this.getters.push(fn); + return this; +}; + +/** + * Adds validator(s) for this document path. + * + * Validators always receive the value to validate as their first argument and must return `Boolean`. Returning `false` means validation failed. + * + * The error message argument is optional. If not passed, the [default generic error message template](#error_messages_MongooseError-messages) will be used. + * + * ####Examples: + * + * // make sure every value is equal to "something" + * function validator (val) { + * return val == 'something'; + * } + * new Schema({ name: { type: String, validate: validator }}); + * + * // with a custom error message + * + * var custom = [validator, 'Uh oh, {PATH} does not equal "something".'] + * new Schema({ name: { type: String, validate: custom }}); + * + * // adding many validators at a time + * + * var many = [ + * { validator: validator, msg: 'uh oh' } + * , { validator: anotherValidator, msg: 'failed' } + * ] + * new Schema({ name: { type: String, validate: many }}); + * + * // or utilizing SchemaType methods directly: + * + * var schema = new Schema({ name: 'string' }); + * schema.path('name').validate(validator, 'validation of `{PATH}` failed with value `{VALUE}`'); + * + * ####Error message templates: + * + * From the examples above, you may have noticed that error messages support basic templating. There are a few other template keywords besides `{PATH}` and `{VALUE}` too. To find out more, details are available [here](#error_messages_MongooseError.messages) + * + * ####Asynchronous validation: + * + * Passing a validator function that receives two arguments tells mongoose that the validator is an asynchronous validator. The first argument passed to the validator function is the value being validated. The second argument is a callback function that must called when you finish validating the value and passed either `true` or `false` to communicate either success or failure respectively. + * + * schema.path('name').validate(function (value, respond) { + * doStuff(value, function () { + * ... + * respond(false); // validation failed + * }) + * }, '{PATH} failed validation.'); + * + * // or with dynamic message + * + * schema.path('name').validate(function (value, respond) { + * doStuff(value, function () { + * ... + * respond(false, 'this message gets to the validation error'); + * }); + * }, 'this message does not matter'); + * + * You might use asynchronous validators to retreive other documents from the database to validate against or to meet other I/O bound validation needs. + * + * Validation occurs `pre('save')` or whenever you manually execute [document#validate](#document_Document-validate). + * + * If validation fails during `pre('save')` and no callback was passed to receive the error, an `error` event will be emitted on your Models associated db [connection](#connection_Connection), passing the validation error object along. + * + * var conn = mongoose.createConnection(..); + * conn.on('error', handleError); + * + * var Product = conn.model('Product', yourSchema); + * var dvd = new Product(..); + * dvd.save(); // emits error on the `conn` above + * + * If you desire handling these errors at the Model level, attach an `error` listener to your Model and the event will instead be emitted there. + * + * // registering an error listener on the Model lets us handle errors more locally + * Product.on('error', handleError); + * + * @param {RegExp|Function|Object} obj validator + * @param {String} [errorMsg] optional error message + * @param {String} [type] optional validator type + * @return {SchemaType} this + * @api public + */ + +SchemaType.prototype.validate = function(obj, message, type) { + if (typeof obj === 'function' || obj && utils.getFunctionName(obj.constructor) === 'RegExp') { + var properties; + if (message instanceof Object && !type) { + properties = utils.clone(message); + if (!properties.message) { + properties.message = properties.msg; + } + properties.validator = obj; + properties.type = properties.type || 'user defined'; + } else { + if (!message) { + message = MongooseError.messages.general.default; + } + if (!type) { + type = 'user defined'; + } + properties = {message: message, type: type, validator: obj}; + } + this.validators.push(properties); + return this; + } + + var i, + length, + arg; + + for (i = 0, length = arguments.length; i < length; i++) { + arg = arguments[i]; + if (!(arg && utils.getFunctionName(arg.constructor) === 'Object')) { + var msg = 'Invalid validator. Received (' + typeof arg + ') ' + + arg + + '. See http://mongoosejs.com/docs/api.html#schematype_SchemaType-validate'; + + throw new Error(msg); + } + this.validate(arg.validator, arg); + } + + return this; +}; + +/** + * Adds a required validator to this SchemaType. The validator gets added + * to the front of this SchemaType's validators array using `unshift()`. + * + * ####Example: + * + * var s = new Schema({ born: { type: Date, required: true }) + * + * // or with custom error message + * + * var s = new Schema({ born: { type: Date, required: '{PATH} is required!' }) + * + * // or through the path API + * + * Schema.path('name').required(true); + * + * // with custom error messaging + * + * Schema.path('name').required(true, 'grrr :( '); + * + * // or make a path conditionally required based on a function + * var isOver18 = function() { return this.age >= 18; }; + * Schema.path('voterRegistrationId').required(isOver18); + * + * The required validator uses the SchemaType's `checkRequired` function to + * determine whether a given value satisfies the required validator. By default, + * a value satisfies the required validator if `val != null` (that is, if + * the value is not null nor undefined). However, most built-in mongoose schema + * types override the default `checkRequired` function: + * + * @param {Boolean} required enable/disable the validator + * @param {String} [message] optional custom error message + * @return {SchemaType} this + * @see Customized Error Messages #error_messages_MongooseError-messages + * @see SchemaArray#checkRequired #schema_array_SchemaArray.checkRequired + * @see SchemaBoolean#checkRequired #schema_boolean_SchemaBoolean-checkRequired + * @see SchemaBuffer#checkRequired #schema_buffer_SchemaBuffer.schemaName + * @see SchemaNumber#checkRequired #schema_number_SchemaNumber-min + * @see SchemaObjectId#checkRequired #schema_objectid_ObjectId-auto + * @see SchemaString#checkRequired #schema_string_SchemaString-checkRequired + * @api public + */ + +SchemaType.prototype.required = function(required, message) { + if (required === false) { + this.validators = this.validators.filter(function(v) { + return v.validator !== this.requiredValidator; + }, this); + + this.isRequired = false; + return this; + } + + var _this = this; + this.isRequired = true; + + this.requiredValidator = function(v) { + // in here, `this` refers to the validating document. + // no validation when this path wasn't selected in the query. + if ('isSelected' in this && !this.isSelected(_this.path) && !this.isModified(_this.path)) { + return true; + } + + return ((typeof required === 'function') && !required.apply(this)) || + _this.checkRequired(v, this); + }; + this.originalRequiredValue = required; + + if (typeof required === 'string') { + message = required; + required = undefined; + } + + var msg = message || MongooseError.messages.general.required; + this.validators.unshift({ + validator: this.requiredValidator, + message: msg, + type: 'required' + }); + + return this; +}; + +/** + * Gets the default value + * + * @param {Object} scope the scope which callback are executed + * @param {Boolean} init + * @api private + */ + +SchemaType.prototype.getDefault = function(scope, init) { + var ret = typeof this.defaultValue === 'function' + ? this.defaultValue.call(scope) + : this.defaultValue; + + if (ret !== null && ret !== undefined) { + var casted = this.cast(ret, scope, init); + if (casted && casted.$isSingleNested) { + casted.$parent = scope; + } + return casted; + } + return ret; +}; + +/** + * Applies setters + * + * @param {Object} value + * @param {Object} scope + * @param {Boolean} init + * @api private + */ + +SchemaType.prototype.applySetters = function(value, scope, init, priorVal, options) { + var v = value, + setters = this.setters, + len = setters.length, + caster = this.caster; + + while (len--) { + v = setters[len].call(scope, v, this); + } + + if (Array.isArray(v) && caster && caster.setters) { + var newVal = []; + for (var i = 0; i < v.length; i++) { + newVal.push(caster.applySetters(v[i], scope, init, priorVal)); + } + v = newVal; + } + + if (v === null || v === undefined) { + return v; + } + + // do not cast until all setters are applied #665 + v = this.cast(v, scope, init, priorVal, options); + + return v; +}; + +/** + * Applies getters to a value + * + * @param {Object} value + * @param {Object} scope + * @api private + */ + +SchemaType.prototype.applyGetters = function(value, scope) { + var v = value, + getters = this.getters, + len = getters.length; + + if (!len) { + return v; + } + + while (len--) { + v = getters[len].call(scope, v, this); + } + + return v; +}; + +/** + * Sets default `select()` behavior for this path. + * + * Set to `true` if this path should always be included in the results, `false` if it should be excluded by default. This setting can be overridden at the query level. + * + * ####Example: + * + * T = db.model('T', new Schema({ x: { type: String, select: true }})); + * T.find(..); // field x will always be selected .. + * // .. unless overridden; + * T.find().select('-x').exec(callback); + * + * @param {Boolean} val + * @return {SchemaType} this + * @api public + */ + +SchemaType.prototype.select = function select(val) { + this.selected = !!val; + return this; +}; + +/** + * Performs a validation of `value` using the validators declared for this SchemaType. + * + * @param {any} value + * @param {Function} callback + * @param {Object} scope + * @api private + */ + +SchemaType.prototype.doValidate = function(value, fn, scope) { + var err = false, + path = this.path, + count = this.validators.length; + + if (!count) { + return fn(null); + } + + var validate = function(ok, validatorProperties) { + if (err) { + return; + } + if (ok === undefined || ok) { + --count || fn(null); + } else { + err = new ValidatorError(validatorProperties); + fn(err); + } + }; + + var _this = this; + this.validators.forEach(function(v) { + if (err) { + return; + } + + var validator = v.validator; + + var validatorProperties = utils.clone(v); + validatorProperties.path = path; + validatorProperties.value = value; + + if (validator instanceof RegExp) { + validate(validator.test(value), validatorProperties); + } else if (typeof validator === 'function') { + if (value === undefined && !_this.isRequired) { + validate(true, validatorProperties); + return; + } + if (validator.length === 2) { + var returnVal = validator.call(scope, value, function(ok, customMsg) { + if (typeof returnVal === 'boolean') { + return; + } + if (customMsg) { + validatorProperties.message = customMsg; + } + validate(ok, validatorProperties); + }); + if (typeof returnVal === 'boolean') { + validate(returnVal, validatorProperties); + } + } else { + validate(validator.call(scope, value), validatorProperties); + } + } + }); +}; + +/** + * Performs a validation of `value` using the validators declared for this SchemaType. + * + * ####Note: + * + * This method ignores the asynchronous validators. + * + * @param {any} value + * @param {Object} scope + * @return {MongooseError|undefined} + * @api private + */ + +SchemaType.prototype.doValidateSync = function(value, scope) { + var err = null, + path = this.path, + count = this.validators.length; + + if (!count) { + return null; + } + + var validate = function(ok, validatorProperties) { + if (err) { + return; + } + if (ok !== undefined && !ok) { + err = new ValidatorError(validatorProperties); + } + }; + + var _this = this; + if (value === undefined && !_this.isRequired) { + return null; + } + + this.validators.forEach(function(v) { + if (err) { + return; + } + + var validator = v.validator; + var validatorProperties = utils.clone(v); + validatorProperties.path = path; + validatorProperties.value = value; + + if (validator instanceof RegExp) { + validate(validator.test(value), validatorProperties); + } else if (typeof validator === 'function') { + // if not async validators + if (validator.length !== 2) { + validate(validator.call(scope, value), validatorProperties); + } + } + }); + + return err; +}; + +/** + * Determines if value is a valid Reference. + * + * @param {SchemaType} self + * @param {Object} value + * @param {Document} doc + * @param {Boolean} init + * @return {Boolean} + * @api private + */ + +SchemaType._isRef = function(self, value, doc, init) { + // fast path + var ref = init && self.options && self.options.ref; + + if (!ref && doc && doc.$__fullPath) { + // checks for + // - this populated with adhoc model and no ref was set in schema OR + // - setting / pushing values after population + var path = doc.$__fullPath(self.path); + var owner = doc.ownerDocument ? doc.ownerDocument() : doc; + ref = owner.populated(path); + } + + if (ref) { + if (value == null) { + return true; + } + if (!Buffer.isBuffer(value) && // buffers are objects too + value._bsontype !== 'Binary' // raw binary value from the db + && utils.isObject(value) // might have deselected _id in population query + ) { + return true; + } + } + + return false; +}; + +/*! + * ignore + */ + +function handleSingle(val) { + return this.castForQuery(val); +} + +/*! + * ignore + */ + +function handleArray(val) { + var _this = this; + if (!Array.isArray(val)) { + return [this.castForQuery(val)]; + } + return val.map(function(m) { + return _this.castForQuery(m); + }); +} + +/*! + * ignore + */ + +SchemaType.prototype.$conditionalHandlers = { + $all: handleArray, + $eq: handleSingle, + $in: handleArray, + $ne: handleSingle, + $nin: handleArray +}; + +/** + * Cast the given value with the given optional query operator. + * + * @param {String} [$conditional] query operator, like `$eq` or `$in` + * @param {any} val + * @api private + */ + +SchemaType.prototype.castForQuery = function($conditional, val) { + var handler; + if (arguments.length === 2) { + handler = this.$conditionalHandlers[$conditional]; + if (!handler) { + throw new Error('Can\'t use ' + $conditional); + } + return handler.call(this, val); + } + val = $conditional; + return this.cast(val); +}; + +/** + * Default check for if this path satisfies the `required` validator. + * + * @param {any} val + * @api private + */ + +SchemaType.prototype.checkRequired = function(val) { + return val != null; +}; + +/*! + * Module exports. + */ + +module.exports = exports = SchemaType; + +exports.CastError = CastError; + +exports.ValidatorError = ValidatorError; diff --git a/node_modules/mongoose/lib/services/common.js b/node_modules/mongoose/lib/services/common.js new file mode 100644 index 0000000..d125987 --- /dev/null +++ b/node_modules/mongoose/lib/services/common.js @@ -0,0 +1,87 @@ +'use strict'; + +/*! + * Module dependencies. + */ + +var ObjectId = require('../types/objectid'); +var utils = require('../utils'); + +exports.flatten = flatten; +exports.modifiedPaths = modifiedPaths; + +/*! + * ignore + */ + +function flatten(update, path, options) { + var keys; + if (update && utils.isMongooseObject(update) && !Buffer.isBuffer(update)) { + keys = Object.keys(update.toObject({ transform: false })); + } else { + keys = Object.keys(update || {}); + } + + var numKeys = keys.length; + var result = {}; + path = path ? path + '.' : ''; + + for (var i = 0; i < numKeys; ++i) { + var key = keys[i]; + var val = update[key]; + result[path + key] = val; + if (shouldFlatten(val)) { + if (options && options.skipArrays && Array.isArray(val)) { + continue; + } + var flat = flatten(val, path + key); + for (var k in flat) { + result[k] = flat[k]; + } + if (Array.isArray(val)) { + result[path + key] = val; + } + } + } + + return result; +} + +/*! + * ignore + */ + +function modifiedPaths(update, path, result) { + var keys = Object.keys(update || {}); + var numKeys = keys.length; + result = result || {}; + path = path ? path + '.' : ''; + + for (var i = 0; i < numKeys; ++i) { + var key = keys[i]; + var val = update[key]; + + result[path + key] = true; + if (utils.isMongooseObject(val) && !Buffer.isBuffer(val)) { + val = val.toObject({ transform: false }); + } + if (shouldFlatten(val)) { + modifiedPaths(val, path + key, result); + } + } + + return result; +} + +/*! + * ignore + */ + +function shouldFlatten(val) { + return val && + typeof val === 'object' && + !(val instanceof Date) && + !(val instanceof ObjectId) && + (!Array.isArray(val) || val.length > 0) && + !(val instanceof Buffer); +} diff --git a/node_modules/mongoose/lib/services/setDefaultsOnInsert.js b/node_modules/mongoose/lib/services/setDefaultsOnInsert.js new file mode 100644 index 0000000..f122f40 --- /dev/null +++ b/node_modules/mongoose/lib/services/setDefaultsOnInsert.js @@ -0,0 +1,112 @@ +'use strict'; + +var flatten = require('./common').flatten; +var modifiedPaths = require('./common').modifiedPaths; + +/** + * Applies defaults to update and findOneAndUpdate operations. + * + * @param {Query} query + * @param {Schema} schema + * @param {Object} castedDoc + * @param {Object} options + * @method setDefaultsOnInsert + * @api private + */ + +module.exports = function(query, schema, castedDoc, options) { + var keys = Object.keys(castedDoc || {}); + var updatedKeys = {}; + var updatedValues = {}; + var numKeys = keys.length; + var hasDollarUpdate = false; + var modified = {}; + + for (var i = 0; i < numKeys; ++i) { + if (keys[i].charAt(0) === '$') { + modifiedPaths(castedDoc[keys[i]], '', modified); + var flat = flatten(castedDoc[keys[i]]); + var paths = Object.keys(flat); + var numPaths = paths.length; + for (var j = 0; j < numPaths; ++j) { + var updatedPath = paths[j].replace('.$.', '.0.'); + updatedPath = updatedPath.replace(/\.\$$/, '.0'); + if (keys[i] === '$set' || keys[i] === '$setOnInsert') { + updatedValues[updatedPath] = flat[paths[j]]; + } else if (keys[i] === '$unset') { + updatedValues[updatedPath] = undefined; + } + updatedKeys[updatedPath] = true; + } + hasDollarUpdate = true; + } + } + + if (!hasDollarUpdate) { + modifiedPaths(castedDoc, '', modified); + updatedValues = flatten(castedDoc); + updatedKeys = Object.keys(updatedValues); + } + + if (options && options.upsert) { + paths = Object.keys(query._conditions); + numPaths = keys.length; + for (i = 0; i < numPaths; ++i) { + var path = paths[i]; + var condition = query._conditions[path]; + if (condition && typeof condition === 'object') { + var conditionKeys = Object.keys(condition); + var numConditionKeys = conditionKeys.length; + var hasDollarKey = false; + for (j = 0; j < numConditionKeys; ++j) { + if (conditionKeys[j].charAt(0) === '$') { + hasDollarKey = true; + break; + } + } + if (hasDollarKey) { + continue; + } + } + updatedKeys[path] = true; + modified[path] = true; + } + + if (options.setDefaultsOnInsert) { + schema.eachPath(function(path, schemaType) { + if (path === '_id') { + // Ignore _id for now because it causes bugs in 2.4 + return; + } + if (schemaType.$isSingleNested) { + // Only handle nested schemas 1-level deep to avoid infinite + // recursion re: https://github.com/mongodb-js/mongoose-autopopulate/issues/11 + schemaType.schema.eachPath(function(_path, _schemaType) { + if (path === '_id') { + // Ignore _id for now because it causes bugs in 2.4 + return; + } + + var def = _schemaType.getDefault(null, true); + if (!modified[path + '.' + _path] && typeof def !== 'undefined') { + castedDoc = castedDoc || {}; + castedDoc.$setOnInsert = castedDoc.$setOnInsert || {}; + castedDoc.$setOnInsert[path + '.' + _path] = def; + updatedValues[path + '.' + _path] = def; + } + }); + } else { + var def = schemaType.getDefault(null, true); + if (!modified[path] && typeof def !== 'undefined') { + castedDoc = castedDoc || {}; + castedDoc.$setOnInsert = castedDoc.$setOnInsert || {}; + castedDoc.$setOnInsert[path] = def; + updatedValues[path] = def; + } + } + }); + } + } + + return castedDoc; +}; diff --git a/node_modules/mongoose/lib/services/updateValidators.js b/node_modules/mongoose/lib/services/updateValidators.js new file mode 100644 index 0000000..162ea73 --- /dev/null +++ b/node_modules/mongoose/lib/services/updateValidators.js @@ -0,0 +1,100 @@ +/*! + * Module dependencies. + */ + +var Mixed = require('../schema/mixed'); +var ValidationError = require('../error/validation'); +var parallel = require('async/parallel'); +var flatten = require('./common').flatten; +var modifiedPaths = require('./common').modifiedPaths; + +/** + * Applies validators and defaults to update and findOneAndUpdate operations, + * specifically passing a null doc as `this` to validators and defaults + * + * @param {Query} query + * @param {Schema} schema + * @param {Object} castedDoc + * @param {Object} options + * @method runValidatorsOnUpdate + * @api private + */ + +module.exports = function(query, schema, castedDoc, options) { + var keys = Object.keys(castedDoc || {}); + var updatedKeys = {}; + var updatedValues = {}; + var numKeys = keys.length; + var hasDollarUpdate = false; + var modified = {}; + + for (var i = 0; i < numKeys; ++i) { + if (keys[i].charAt(0) === '$') { + modifiedPaths(castedDoc[keys[i]], '', modified); + var flat = flatten(castedDoc[keys[i]]); + var paths = Object.keys(flat); + var numPaths = paths.length; + for (var j = 0; j < numPaths; ++j) { + var updatedPath = paths[j].replace('.$.', '.0.'); + updatedPath = updatedPath.replace(/\.\$$/, '.0'); + if (keys[i] === '$set' || keys[i] === '$setOnInsert') { + updatedValues[updatedPath] = flat[paths[j]]; + } else if (keys[i] === '$unset') { + updatedValues[updatedPath] = undefined; + } + updatedKeys[updatedPath] = true; + } + hasDollarUpdate = true; + } + } + + if (!hasDollarUpdate) { + modifiedPaths(castedDoc, '', modified); + updatedValues = flatten(castedDoc); + updatedKeys = Object.keys(updatedValues); + } + + var updates = Object.keys(updatedValues); + var numUpdates = updates.length; + var validatorsToExecute = []; + var validationErrors = []; + function iter(i) { + var schemaPath = schema._getSchema(updates[i]); + if (schemaPath) { + // gh-4305: `_getSchema()` will report all sub-fields of a 'Mixed' path + // as 'Mixed', so avoid double validating them. + if (schemaPath instanceof Mixed && schemaPath.$fullPath !== updates[i]) { + return; + } + validatorsToExecute.push(function(callback) { + schemaPath.doValidate( + updatedValues[updates[i]], + function(err) { + if (err) { + err.path = updates[i]; + validationErrors.push(err); + } + callback(null); + }, + options && options.context === 'query' ? query : null, + {updateValidator: true}); + }); + } + } + for (i = 0; i < numUpdates; ++i) { + iter(i); + } + + return function(callback) { + parallel(validatorsToExecute, function() { + if (validationErrors.length) { + var err = new ValidationError(null); + for (var i = 0; i < validationErrors.length; ++i) { + err.errors[validationErrors[i].path] = validationErrors[i]; + } + return callback(err); + } + callback(null); + }); + }; +}; diff --git a/node_modules/mongoose/lib/statemachine.js b/node_modules/mongoose/lib/statemachine.js new file mode 100644 index 0000000..3bba519 --- /dev/null +++ b/node_modules/mongoose/lib/statemachine.js @@ -0,0 +1,178 @@ + +/*! + * Module dependencies. + */ + +var utils = require('./utils'); + +/*! + * StateMachine represents a minimal `interface` for the + * constructors it builds via StateMachine.ctor(...). + * + * @api private + */ + +var StateMachine = module.exports = exports = function StateMachine() { +}; + +/*! + * StateMachine.ctor('state1', 'state2', ...) + * A factory method for subclassing StateMachine. + * The arguments are a list of states. For each state, + * the constructor's prototype gets state transition + * methods named after each state. These transition methods + * place their path argument into the given state. + * + * @param {String} state + * @param {String} [state] + * @return {Function} subclass constructor + * @private + */ + +StateMachine.ctor = function() { + var states = utils.args(arguments); + + var ctor = function() { + StateMachine.apply(this, arguments); + this.paths = {}; + this.states = {}; + this.stateNames = states; + + var i = states.length, + state; + + while (i--) { + state = states[i]; + this.states[state] = {}; + } + }; + + ctor.prototype = new StateMachine(); + + states.forEach(function(state) { + // Changes the `path`'s state to `state`. + ctor.prototype[state] = function(path) { + this._changeState(path, state); + }; + }); + + return ctor; +}; + +/*! + * This function is wrapped by the state change functions: + * + * - `require(path)` + * - `modify(path)` + * - `init(path)` + * + * @api private + */ + +StateMachine.prototype._changeState = function _changeState(path, nextState) { + var prevBucket = this.states[this.paths[path]]; + if (prevBucket) delete prevBucket[path]; + + this.paths[path] = nextState; + this.states[nextState][path] = true; +}; + +/*! + * ignore + */ + +StateMachine.prototype.clear = function clear(state) { + var keys = Object.keys(this.states[state]), + i = keys.length, + path; + + while (i--) { + path = keys[i]; + delete this.states[state][path]; + delete this.paths[path]; + } +}; + +/*! + * Checks to see if at least one path is in the states passed in via `arguments` + * e.g., this.some('required', 'inited') + * + * @param {String} state that we want to check for. + * @private + */ + +StateMachine.prototype.some = function some() { + var _this = this; + var what = arguments.length ? arguments : this.stateNames; + return Array.prototype.some.call(what, function(state) { + return Object.keys(_this.states[state]).length; + }); +}; + +/*! + * This function builds the functions that get assigned to `forEach` and `map`, + * since both of those methods share a lot of the same logic. + * + * @param {String} iterMethod is either 'forEach' or 'map' + * @return {Function} + * @api private + */ + +StateMachine.prototype._iter = function _iter(iterMethod) { + return function() { + var numArgs = arguments.length, + states = utils.args(arguments, 0, numArgs - 1), + callback = arguments[numArgs - 1]; + + if (!states.length) states = this.stateNames; + + var _this = this; + + var paths = states.reduce(function(paths, state) { + return paths.concat(Object.keys(_this.states[state])); + }, []); + + return paths[iterMethod](function(path, i, paths) { + return callback(path, i, paths); + }); + }; +}; + +/*! + * Iterates over the paths that belong to one of the parameter states. + * + * The function profile can look like: + * this.forEach(state1, fn); // iterates over all paths in state1 + * this.forEach(state1, state2, fn); // iterates over all paths in state1 or state2 + * this.forEach(fn); // iterates over all paths in all states + * + * @param {String} [state] + * @param {String} [state] + * @param {Function} callback + * @private + */ + +StateMachine.prototype.forEach = function forEach() { + this.forEach = this._iter('forEach'); + return this.forEach.apply(this, arguments); +}; + +/*! + * Maps over the paths that belong to one of the parameter states. + * + * The function profile can look like: + * this.forEach(state1, fn); // iterates over all paths in state1 + * this.forEach(state1, state2, fn); // iterates over all paths in state1 or state2 + * this.forEach(fn); // iterates over all paths in all states + * + * @param {String} [state] + * @param {String} [state] + * @param {Function} callback + * @return {Array} + * @private + */ + +StateMachine.prototype.map = function map() { + this.map = this._iter('map'); + return this.map.apply(this, arguments); +}; diff --git a/node_modules/mongoose/lib/types/array.js b/node_modules/mongoose/lib/types/array.js new file mode 100644 index 0000000..e63c023 --- /dev/null +++ b/node_modules/mongoose/lib/types/array.js @@ -0,0 +1,777 @@ +/*! + * Module dependencies. + */ + +var EmbeddedDocument = require('./embedded'); +var Document = require('../document'); +var ObjectId = require('./objectid'); +var utils = require('../utils'); +var isMongooseObject = utils.isMongooseObject; + +/** + * Mongoose Array constructor. + * + * ####NOTE: + * + * _Values always have to be passed to the constructor to initialize, otherwise `MongooseArray#push` will mark the array as modified._ + * + * @param {Array} values + * @param {String} path + * @param {Document} doc parent document + * @api private + * @inherits Array + * @see http://bit.ly/f6CnZU + */ + +function MongooseArray(values, path, doc) { + var arr = [].concat(values); + + var keysMA = Object.keys(MongooseArray.mixin); + var numKeys = keysMA.length; + for (var i = 0; i < numKeys; ++i) { + arr[keysMA[i]] = MongooseArray.mixin[keysMA[i]]; + } + + arr._path = path; + arr.isMongooseArray = true; + arr.validators = []; + arr._atomics = {}; + arr._schema = void 0; + + // Because doc comes from the context of another function, doc === global + // can happen if there was a null somewhere up the chain (see #3020) + // RB Jun 17, 2015 updated to check for presence of expected paths instead + // to make more proof against unusual node environments + if (doc && doc instanceof Document) { + arr._parent = doc; + arr._schema = doc.schema.path(path); + } + + return arr; +} + +MongooseArray.mixin = { + /*! + * ignore + */ + toBSON: function() { + return this.toObject({ transform: false }); + }, + + /** + * Stores a queue of atomic operations to perform + * + * @property _atomics + * @api private + */ + + _atomics: undefined, + + /** + * Parent owner document + * + * @property _parent + * @api private + * @receiver MongooseArray + */ + + _parent: undefined, + + /** + * Casts a member based on this arrays schema. + * + * @param {any} value + * @return value the casted value + * @method _cast + * @api private + * @receiver MongooseArray + */ + + _cast: function(value) { + var populated = false; + var Model; + + if (this._parent) { + populated = this._parent.populated(this._path, true); + } + + if (populated && value !== null && value !== undefined) { + // cast to the populated Models schema + Model = populated.options.model; + + // only objects are permitted so we can safely assume that + // non-objects are to be interpreted as _id + if (Buffer.isBuffer(value) || + value instanceof ObjectId || !utils.isObject(value)) { + value = {_id: value}; + } + + // gh-2399 + // we should cast model only when it's not a discriminator + var isDisc = value.schema && value.schema.discriminatorMapping && + value.schema.discriminatorMapping.key !== undefined; + if (!isDisc) { + value = new Model(value); + } + return this._schema.caster.cast(value, this._parent, true); + } + + return this._schema.caster.cast(value, this._parent, false); + }, + + /** + * Marks this array as modified. + * + * If it bubbles up from an embedded document change, then it takes the following arguments (otherwise, takes 0 arguments) + * + * @param {EmbeddedDocument} embeddedDoc the embedded doc that invoked this method on the Array + * @param {String} embeddedPath the path which changed in the embeddedDoc + * @method _markModified + * @api private + * @receiver MongooseArray + */ + + _markModified: function(elem, embeddedPath) { + var parent = this._parent, + dirtyPath; + + if (parent) { + dirtyPath = this._path; + + if (arguments.length) { + if (embeddedPath != null) { + // an embedded doc bubbled up the change + dirtyPath = dirtyPath + '.' + this.indexOf(elem) + '.' + embeddedPath; + } else { + // directly set an index + dirtyPath = dirtyPath + '.' + elem; + } + } + + parent.markModified(dirtyPath); + } + + return this; + }, + + /** + * Register an atomic operation with the parent. + * + * @param {Array} op operation + * @param {any} val + * @method _registerAtomic + * @api private + * @receiver MongooseArray + */ + + _registerAtomic: function(op, val) { + if (op === '$set') { + // $set takes precedence over all other ops. + // mark entire array modified. + this._atomics = {$set: val}; + return this; + } + + var atomics = this._atomics; + + // reset pop/shift after save + if (op === '$pop' && !('$pop' in atomics)) { + var _this = this; + this._parent.once('save', function() { + _this._popped = _this._shifted = null; + }); + } + + // check for impossible $atomic combos (Mongo denies more than one + // $atomic op on a single path + if (this._atomics.$set || + Object.keys(atomics).length && !(op in atomics)) { + // a different op was previously registered. + // save the entire thing. + this._atomics = {$set: this}; + return this; + } + + var selector; + + if (op === '$pullAll' || op === '$pushAll' || op === '$addToSet') { + atomics[op] || (atomics[op] = []); + atomics[op] = atomics[op].concat(val); + } else if (op === '$pullDocs') { + var pullOp = atomics['$pull'] || (atomics['$pull'] = {}); + if (val[0] instanceof EmbeddedDocument) { + selector = pullOp['$or'] || (pullOp['$or'] = []); + Array.prototype.push.apply(selector, val.map(function(v) { + return v.toObject({transform: false}); + })); + } else { + selector = pullOp['_id'] || (pullOp['_id'] = {$in: []}); + selector['$in'] = selector['$in'].concat(val); + } + } else { + atomics[op] = val; + } + + return this; + }, + + /** + * Depopulates stored atomic operation values as necessary for direct insertion to MongoDB. + * + * If no atomics exist, we return all array values after conversion. + * + * @return {Array} + * @method $__getAtomics + * @memberOf MongooseArray + * @api private + */ + + $__getAtomics: function() { + var ret = []; + var keys = Object.keys(this._atomics); + var i = keys.length; + + if (i === 0) { + ret[0] = ['$set', this.toObject({depopulate: 1, transform: false})]; + return ret; + } + + while (i--) { + var op = keys[i]; + var val = this._atomics[op]; + + // the atomic values which are arrays are not MongooseArrays. we + // need to convert their elements as if they were MongooseArrays + // to handle populated arrays versus DocumentArrays properly. + if (isMongooseObject(val)) { + val = val.toObject({depopulate: 1, transform: false}); + } else if (Array.isArray(val)) { + val = this.toObject.call(val, {depopulate: 1, transform: false}); + } else if (val.valueOf) { + val = val.valueOf(); + } + + if (op === '$addToSet') { + val = {$each: val}; + } + + ret.push([op, val]); + } + + return ret; + }, + + /** + * Returns the number of pending atomic operations to send to the db for this array. + * + * @api private + * @return {Number} + * @method hasAtomics + * @receiver MongooseArray + */ + + hasAtomics: function hasAtomics() { + if (!(this._atomics && this._atomics.constructor.name === 'Object')) { + return 0; + } + + return Object.keys(this._atomics).length; + }, + + /** + * Internal helper for .map() + * + * @api private + * @return {Number} + * @method _mapCast + * @receiver MongooseArray + */ + _mapCast: function(val, index) { + return this._cast(val, this.length + index); + }, + + /** + * Wraps [`Array#push`](https://developer.mozilla.org/en/JavaScript/Reference/Global_Objects/Array/push) with proper change tracking. + * + * @param {Object} [args...] + * @api public + * @method push + * @receiver MongooseArray + */ + + push: function() { + var values = [].map.call(arguments, this._mapCast, this); + values = this._schema.applySetters(values, this._parent, undefined, + undefined, {skipDocumentArrayCast: true}); + var ret = [].push.apply(this, values); + + // $pushAll might be fibbed (could be $push). But it makes it easier to + // handle what could have been $push, $pushAll combos + this._registerAtomic('$pushAll', values); + this._markModified(); + return ret; + }, + + /** + * Pushes items to the array non-atomically. + * + * ####NOTE: + * + * _marks the entire array as modified, which if saved, will store it as a `$set` operation, potentially overwritting any changes that happen between when you retrieved the object and when you save it._ + * + * @param {any} [args...] + * @api public + * @method nonAtomicPush + * @receiver MongooseArray + */ + + nonAtomicPush: function() { + var values = [].map.call(arguments, this._mapCast, this); + var ret = [].push.apply(this, values); + this._registerAtomic('$set', this); + this._markModified(); + return ret; + }, + + /** + * Pops the array atomically at most one time per document `save()`. + * + * #### NOTE: + * + * _Calling this mulitple times on an array before saving sends the same command as calling it once._ + * _This update is implemented using the MongoDB [$pop](http://www.mongodb.org/display/DOCS/Updating/#Updating-%24pop) method which enforces this restriction._ + * + * doc.array = [1,2,3]; + * + * var popped = doc.array.$pop(); + * console.log(popped); // 3 + * console.log(doc.array); // [1,2] + * + * // no affect + * popped = doc.array.$pop(); + * console.log(doc.array); // [1,2] + * + * doc.save(function (err) { + * if (err) return handleError(err); + * + * // we saved, now $pop works again + * popped = doc.array.$pop(); + * console.log(popped); // 2 + * console.log(doc.array); // [1] + * }) + * + * @api public + * @method $pop + * @memberOf MongooseArray + * @see mongodb http://www.mongodb.org/display/DOCS/Updating/#Updating-%24pop + * @method $pop + * @receiver MongooseArray + */ + + $pop: function() { + this._registerAtomic('$pop', 1); + this._markModified(); + + // only allow popping once + if (this._popped) { + return; + } + this._popped = true; + + return [].pop.call(this); + }, + + /** + * Wraps [`Array#pop`](https://developer.mozilla.org/en/JavaScript/Reference/Global_Objects/Array/pop) with proper change tracking. + * + * ####Note: + * + * _marks the entire array as modified which will pass the entire thing to $set potentially overwritting any changes that happen between when you retrieved the object and when you save it._ + * + * @see MongooseArray#$pop #types_array_MongooseArray-%24pop + * @api public + * @method pop + * @receiver MongooseArray + */ + + pop: function() { + var ret = [].pop.call(this); + this._registerAtomic('$set', this); + this._markModified(); + return ret; + }, + + /** + * Atomically shifts the array at most one time per document `save()`. + * + * ####NOTE: + * + * _Calling this mulitple times on an array before saving sends the same command as calling it once._ + * _This update is implemented using the MongoDB [$pop](http://www.mongodb.org/display/DOCS/Updating/#Updating-%24pop) method which enforces this restriction._ + * + * doc.array = [1,2,3]; + * + * var shifted = doc.array.$shift(); + * console.log(shifted); // 1 + * console.log(doc.array); // [2,3] + * + * // no affect + * shifted = doc.array.$shift(); + * console.log(doc.array); // [2,3] + * + * doc.save(function (err) { + * if (err) return handleError(err); + * + * // we saved, now $shift works again + * shifted = doc.array.$shift(); + * console.log(shifted ); // 2 + * console.log(doc.array); // [3] + * }) + * + * @api public + * @memberOf MongooseArray + * @method $shift + * @see mongodb http://www.mongodb.org/display/DOCS/Updating/#Updating-%24pop + */ + + $shift: function $shift() { + this._registerAtomic('$pop', -1); + this._markModified(); + + // only allow shifting once + if (this._shifted) { + return; + } + this._shifted = true; + + return [].shift.call(this); + }, + + /** + * Wraps [`Array#shift`](https://developer.mozilla.org/en/JavaScript/Reference/Global_Objects/Array/unshift) with proper change tracking. + * + * ####Example: + * + * doc.array = [2,3]; + * var res = doc.array.shift(); + * console.log(res) // 2 + * console.log(doc.array) // [3] + * + * ####Note: + * + * _marks the entire array as modified, which if saved, will store it as a `$set` operation, potentially overwritting any changes that happen between when you retrieved the object and when you save it._ + * + * @api public + * @method shift + * @receiver MongooseArray + */ + + shift: function() { + var ret = [].shift.call(this); + this._registerAtomic('$set', this); + this._markModified(); + return ret; + }, + + /** + * Pulls items from the array atomically. Equality is determined by casting + * the provided value to an embedded document and comparing using + * [the `Document.equals()` function.](./api.html#document_Document-equals) + * + * ####Examples: + * + * doc.array.pull(ObjectId) + * doc.array.pull({ _id: 'someId' }) + * doc.array.pull(36) + * doc.array.pull('tag 1', 'tag 2') + * + * To remove a document from a subdocument array we may pass an object with a matching `_id`. + * + * doc.subdocs.push({ _id: 4815162342 }) + * doc.subdocs.pull({ _id: 4815162342 }) // removed + * + * Or we may passing the _id directly and let mongoose take care of it. + * + * doc.subdocs.push({ _id: 4815162342 }) + * doc.subdocs.pull(4815162342); // works + * + * The first pull call will result in a atomic operation on the database, if pull is called repeatedly without saving the document, a $set operation is used on the complete array instead, overwriting possible changes that happened on the database in the meantime. + * + * @param {any} [args...] + * @see mongodb http://www.mongodb.org/display/DOCS/Updating/#Updating-%24pull + * @api public + * @method pull + * @receiver MongooseArray + */ + + pull: function() { + var values = [].map.call(arguments, this._cast, this), + cur = this._parent.get(this._path), + i = cur.length, + mem; + + while (i--) { + mem = cur[i]; + if (mem instanceof Document) { + var some = values.some(function(v) { + return mem.equals(v); + }); + if (some) { + [].splice.call(cur, i, 1); + } + } else if (~cur.indexOf.call(values, mem)) { + [].splice.call(cur, i, 1); + } + } + + if (values[0] instanceof EmbeddedDocument) { + this._registerAtomic('$pullDocs', values.map(function(v) { + return v._id || v; + })); + } else { + this._registerAtomic('$pullAll', values); + } + + this._markModified(); + return this; + }, + + /** + * Wraps [`Array#splice`](https://developer.mozilla.org/en/JavaScript/Reference/Global_Objects/Array/splice) with proper change tracking and casting. + * + * ####Note: + * + * _marks the entire array as modified, which if saved, will store it as a `$set` operation, potentially overwritting any changes that happen between when you retrieved the object and when you save it._ + * + * @api public + * @method splice + * @receiver MongooseArray + */ + + splice: function splice() { + var ret, vals, i; + + if (arguments.length) { + vals = []; + for (i = 0; i < arguments.length; ++i) { + vals[i] = i < 2 + ? arguments[i] + : this._cast(arguments[i], arguments[0] + (i - 2)); + } + ret = [].splice.apply(this, vals); + this._registerAtomic('$set', this); + this._markModified(); + } + + return ret; + }, + + /** + * Wraps [`Array#unshift`](https://developer.mozilla.org/en/JavaScript/Reference/Global_Objects/Array/unshift) with proper change tracking. + * + * ####Note: + * + * _marks the entire array as modified, which if saved, will store it as a `$set` operation, potentially overwritting any changes that happen between when you retrieved the object and when you save it._ + * + * @api public + * @method unshift + * @receiver MongooseArray + */ + + unshift: function() { + var values = [].map.call(arguments, this._cast, this); + values = this._schema.applySetters(values, this._parent); + [].unshift.apply(this, values); + this._registerAtomic('$set', this); + this._markModified(); + return this.length; + }, + + /** + * Wraps [`Array#sort`](https://developer.mozilla.org/en/JavaScript/Reference/Global_Objects/Array/sort) with proper change tracking. + * + * ####NOTE: + * + * _marks the entire array as modified, which if saved, will store it as a `$set` operation, potentially overwritting any changes that happen between when you retrieved the object and when you save it._ + * + * @api public + * @method sort + * @receiver MongooseArray + */ + + sort: function() { + var ret = [].sort.apply(this, arguments); + this._registerAtomic('$set', this); + this._markModified(); + return ret; + }, + + /** + * Adds values to the array if not already present. + * + * ####Example: + * + * console.log(doc.array) // [2,3,4] + * var added = doc.array.addToSet(4,5); + * console.log(doc.array) // [2,3,4,5] + * console.log(added) // [5] + * + * @param {any} [args...] + * @return {Array} the values that were added + * @receiver MongooseArray + * @api public + * @method addToSet + */ + + addToSet: function addToSet() { + var values = [].map.call(arguments, this._mapCast, this); + values = this._schema.applySetters(values, this._parent); + var added = []; + var type = ''; + if (values[0] instanceof EmbeddedDocument) { + type = 'doc'; + } else if (values[0] instanceof Date) { + type = 'date'; + } + + values.forEach(function(v) { + var found; + switch (type) { + case 'doc': + found = this.some(function(doc) { + return doc.equals(v); + }); + break; + case 'date': + var val = +v; + found = this.some(function(d) { + return +d === val; + }); + break; + default: + found = ~this.indexOf(v); + } + + if (!found) { + [].push.call(this, v); + this._registerAtomic('$addToSet', v); + this._markModified(); + [].push.call(added, v); + } + }, this); + + return added; + }, + + /** + * Sets the casted `val` at index `i` and marks the array modified. + * + * ####Example: + * + * // given documents based on the following + * var Doc = mongoose.model('Doc', new Schema({ array: [Number] })); + * + * var doc = new Doc({ array: [2,3,4] }) + * + * console.log(doc.array) // [2,3,4] + * + * doc.array.set(1,"5"); + * console.log(doc.array); // [2,5,4] // properly cast to number + * doc.save() // the change is saved + * + * // VS not using array#set + * doc.array[1] = "5"; + * console.log(doc.array); // [2,"5",4] // no casting + * doc.save() // change is not saved + * + * @return {Array} this + * @api public + * @method set + * @receiver MongooseArray + */ + + set: function set(i, val) { + var value = this._cast(val, i); + value = this._schema.caster instanceof EmbeddedDocument ? + value : + this._schema.caster.applySetters(val, this._parent) + ; + this[i] = value; + this._markModified(i); + return this; + }, + + /** + * Returns a native js Array. + * + * @param {Object} options + * @return {Array} + * @api public + * @method toObject + * @receiver MongooseArray + */ + + toObject: function(options) { + if (options && options.depopulate) { + return this.map(function(doc) { + return doc instanceof Document + ? doc.toObject(options) + : doc; + }); + } + + return this.slice(); + }, + + /** + * Helper for console.log + * + * @api public + * @method inspect + * @receiver MongooseArray + */ + + inspect: function() { + return JSON.stringify(this); + }, + + /** + * Return the index of `obj` or `-1` if not found. + * + * @param {Object} obj the item to look for + * @return {Number} + * @api public + * @method indexOf + * @receiver MongooseArray + */ + + indexOf: function indexOf(obj) { + if (obj instanceof ObjectId) { + obj = obj.toString(); + } + for (var i = 0, len = this.length; i < len; ++i) { + if (obj == this[i]) { + return i; + } + } + return -1; + } +}; + +/** + * Alias of [pull](#types_array_MongooseArray-pull) + * + * @see MongooseArray#pull #types_array_MongooseArray-pull + * @see mongodb http://www.mongodb.org/display/DOCS/Updating/#Updating-%24pull + * @api public + * @memberOf MongooseArray + * @method remove + */ + +MongooseArray.mixin.remove = MongooseArray.mixin.pull; + +/*! + * Module exports. + */ + +module.exports = exports = MongooseArray; diff --git a/node_modules/mongoose/lib/types/buffer.js b/node_modules/mongoose/lib/types/buffer.js new file mode 100644 index 0000000..8be67c8 --- /dev/null +++ b/node_modules/mongoose/lib/types/buffer.js @@ -0,0 +1,273 @@ +/*! + * Module dependencies. + */ + +var Binary = require('../drivers').Binary, + utils = require('../utils'); + +/** + * Mongoose Buffer constructor. + * + * Values always have to be passed to the constructor to initialize. + * + * @param {Buffer} value + * @param {String} encode + * @param {Number} offset + * @api private + * @inherits Buffer + * @see http://bit.ly/f6CnZU + */ + +function MongooseBuffer(value, encode, offset) { + var length = arguments.length; + var val; + + if (length === 0 || arguments[0] === null || arguments[0] === undefined) { + val = 0; + } else { + val = value; + } + + var encoding; + var path; + var doc; + + if (Array.isArray(encode)) { + // internal casting + path = encode[0]; + doc = encode[1]; + } else { + encoding = encode; + } + + var buf = new Buffer(val, encoding, offset); + utils.decorate(buf, MongooseBuffer.mixin); + buf.isMongooseBuffer = true; + + // make sure these internal props don't show up in Object.keys() + Object.defineProperties(buf, { + validators: {value: []}, + _path: {value: path}, + _parent: {value: doc} + }); + + if (doc && typeof path === 'string') { + Object.defineProperty(buf, '_schema', { + value: doc.schema.path(path) + }); + } + + buf._subtype = 0; + return buf; +} + +/*! + * Inherit from Buffer. + */ + +// MongooseBuffer.prototype = new Buffer(0); + +MongooseBuffer.mixin = { + + /** + * Parent owner document + * + * @api private + * @property _parent + * @receiver MongooseBuffer + */ + + _parent: undefined, + + /** + * Default subtype for the Binary representing this Buffer + * + * @api private + * @property _subtype + * @receiver MongooseBuffer + */ + + _subtype: undefined, + + /** + * Marks this buffer as modified. + * + * @api private + * @method _markModified + * @receiver MongooseBuffer + */ + + _markModified: function() { + var parent = this._parent; + + if (parent) { + parent.markModified(this._path); + } + return this; + }, + + /** + * Writes the buffer. + * + * @api public + * @method write + * @receiver MongooseBuffer + */ + + write: function() { + var written = Buffer.prototype.write.apply(this, arguments); + + if (written > 0) { + this._markModified(); + } + + return written; + }, + + /** + * Copies the buffer. + * + * ####Note: + * + * `Buffer#copy` does not mark `target` as modified so you must copy from a `MongooseBuffer` for it to work as expected. This is a work around since `copy` modifies the target, not this. + * + * @return {Number} The number of bytes copied. + * @param {Buffer} target + * @method copy + * @receiver MongooseBuffer + */ + + copy: function(target) { + var ret = Buffer.prototype.copy.apply(this, arguments); + + if (target && target.isMongooseBuffer) { + target._markModified(); + } + + return ret; + } +}; + +/*! + * Compile other Buffer methods marking this buffer as modified. + */ + +( +// node < 0.5 + 'writeUInt8 writeUInt16 writeUInt32 writeInt8 writeInt16 writeInt32 ' + + 'writeFloat writeDouble fill ' + + 'utf8Write binaryWrite asciiWrite set ' + + +// node >= 0.5 + 'writeUInt16LE writeUInt16BE writeUInt32LE writeUInt32BE ' + + 'writeInt16LE writeInt16BE writeInt32LE writeInt32BE ' + + 'writeFloatLE writeFloatBE writeDoubleLE writeDoubleBE' +).split(' ').forEach(function(method) { + if (!Buffer.prototype[method]) { + return; + } + MongooseBuffer.mixin[method] = function() { + var ret = Buffer.prototype[method].apply(this, arguments); + this._markModified(); + return ret; + }; +}); + +/** + * Converts this buffer to its Binary type representation. + * + * ####SubTypes: + * + * var bson = require('bson') + * bson.BSON_BINARY_SUBTYPE_DEFAULT + * bson.BSON_BINARY_SUBTYPE_FUNCTION + * bson.BSON_BINARY_SUBTYPE_BYTE_ARRAY + * bson.BSON_BINARY_SUBTYPE_UUID + * bson.BSON_BINARY_SUBTYPE_MD5 + * bson.BSON_BINARY_SUBTYPE_USER_DEFINED + * + * doc.buffer.toObject(bson.BSON_BINARY_SUBTYPE_USER_DEFINED); + * + * @see http://bsonspec.org/#/specification + * @param {Hex} [subtype] + * @return {Binary} + * @api public + * @method toObject + * @receiver MongooseBuffer + */ + +MongooseBuffer.mixin.toObject = function(options) { + var subtype = typeof options === 'number' + ? options + : (this._subtype || 0); + return new Binary(this, subtype); +}; + +/** + * Determines if this buffer is equals to `other` buffer + * + * @param {Buffer} other + * @return {Boolean} + * @method equals + * @receiver MongooseBuffer + */ + +MongooseBuffer.mixin.equals = function(other) { + if (!Buffer.isBuffer(other)) { + return false; + } + + if (this.length !== other.length) { + return false; + } + + for (var i = 0; i < this.length; ++i) { + if (this[i] !== other[i]) { + return false; + } + } + + return true; +}; + +/** + * Sets the subtype option and marks the buffer modified. + * + * ####SubTypes: + * + * var bson = require('bson') + * bson.BSON_BINARY_SUBTYPE_DEFAULT + * bson.BSON_BINARY_SUBTYPE_FUNCTION + * bson.BSON_BINARY_SUBTYPE_BYTE_ARRAY + * bson.BSON_BINARY_SUBTYPE_UUID + * bson.BSON_BINARY_SUBTYPE_MD5 + * bson.BSON_BINARY_SUBTYPE_USER_DEFINED + * + * doc.buffer.subtype(bson.BSON_BINARY_SUBTYPE_UUID); + * + * @see http://bsonspec.org/#/specification + * @param {Hex} subtype + * @api public + * @method subtype + * @receiver MongooseBuffer + */ + +MongooseBuffer.mixin.subtype = function(subtype) { + if (typeof subtype !== 'number') { + throw new TypeError('Invalid subtype. Expected a number'); + } + + if (this._subtype !== subtype) { + this._markModified(); + } + + this._subtype = subtype; +}; + +/*! + * Module exports. + */ + +MongooseBuffer.Binary = Binary; + +module.exports = MongooseBuffer; diff --git a/node_modules/mongoose/lib/types/documentarray.js b/node_modules/mongoose/lib/types/documentarray.js new file mode 100644 index 0000000..f6fb227 --- /dev/null +++ b/node_modules/mongoose/lib/types/documentarray.js @@ -0,0 +1,256 @@ +/*! + * Module dependencies. + */ + +var MongooseArray = require('./array'), + ObjectId = require('./objectid'), + ObjectIdSchema = require('../schema/objectid'), + utils = require('../utils'), + Document = require('../document'); + +/** + * DocumentArray constructor + * + * @param {Array} values + * @param {String} path the path to this array + * @param {Document} doc parent document + * @api private + * @return {MongooseDocumentArray} + * @inherits MongooseArray + * @see http://bit.ly/f6CnZU + */ + +function MongooseDocumentArray(values, path, doc) { + var arr = [].concat(values); + arr._path = path; + + var props = { + isMongooseArray: true, + isMongooseDocumentArray: true, + validators: [], + _atomics: {}, + _schema: void 0, + _handlers: void 0 + }; + + // Values always have to be passed to the constructor to initialize, since + // otherwise MongooseArray#push will mark the array as modified to the parent. + var keysMA = Object.keys(MongooseArray.mixin); + var numKeys = keysMA.length; + for (var j = 0; j < numKeys; ++j) { + arr[keysMA[j]] = MongooseArray.mixin[keysMA[j]]; + } + + var keysMDA = Object.keys(MongooseDocumentArray.mixin); + numKeys = keysMDA.length; + for (var i = 0; i < numKeys; ++i) { + arr[keysMDA[i]] = MongooseDocumentArray.mixin[keysMDA[i]]; + } + + var keysP = Object.keys(props); + numKeys = keysP.length; + for (var k = 0; k < numKeys; ++k) { + arr[keysP[k]] = props[keysP[k]]; + } + + // Because doc comes from the context of another function, doc === global + // can happen if there was a null somewhere up the chain (see #3020 && #3034) + // RB Jun 17, 2015 updated to check for presence of expected paths instead + // to make more proof against unusual node environments + if (doc && doc instanceof Document) { + arr._parent = doc; + arr._schema = doc.schema.path(path); + arr._handlers = { + isNew: arr.notify('isNew'), + save: arr.notify('save') + }; + + doc.on('save', arr._handlers.save); + doc.on('isNew', arr._handlers.isNew); + } + + return arr; +} + +/*! + * Inherits from MongooseArray + */ +// MongooseDocumentArray.mixin = Object.create( MongooseArray.mixin ); +MongooseDocumentArray.mixin = { + /*! + * ignore + */ + toBSON: function() { + return this.toObject({ transform: false }); + }, + + /** + * Overrides MongooseArray#cast + * + * @method _cast + * @api private + * @receiver MongooseDocumentArray + */ + + _cast: function(value, index) { + if (value instanceof this._schema.casterConstructor) { + if (!(value.__parent && value.__parentArray)) { + // value may have been created using array.create() + value.__parent = this._parent; + value.__parentArray = this; + } + value.__index = index; + return value; + } + + if (value === undefined || value === null) { + return null; + } + + // handle cast('string') or cast(ObjectId) etc. + // only objects are permitted so we can safely assume that + // non-objects are to be interpreted as _id + if (Buffer.isBuffer(value) || + value instanceof ObjectId || !utils.isObject(value)) { + value = {_id: value}; + } + return new this._schema.casterConstructor(value, this, undefined, undefined, index); + }, + + /** + * Searches array items for the first document with a matching _id. + * + * ####Example: + * + * var embeddedDoc = m.array.id(some_id); + * + * @return {EmbeddedDocument|null} the subdocument or null if not found. + * @param {ObjectId|String|Number|Buffer} id + * @TODO cast to the _id based on schema for proper comparison + * @method id + * @api public + * @receiver MongooseDocumentArray + */ + + id: function(id) { + var casted, + sid, + _id; + + try { + var casted_ = ObjectIdSchema.prototype.cast.call({}, id); + if (casted_) { + casted = String(casted_); + } + } catch (e) { + casted = null; + } + + for (var i = 0, l = this.length; i < l; i++) { + _id = this[i].get('_id'); + + if (_id === null || typeof _id === 'undefined') { + continue; + } else if (_id instanceof Document) { + sid || (sid = String(id)); + if (sid == _id._id) { + return this[i]; + } + } else if (!(id instanceof ObjectId) && !(_id instanceof ObjectId)) { + if (utils.deepEqual(id, _id)) { + return this[i]; + } + } else if (casted == _id) { + return this[i]; + } + } + + return null; + }, + + /** + * Returns a native js Array of plain js objects + * + * ####NOTE: + * + * _Each sub-document is converted to a plain object by calling its `#toObject` method._ + * + * @param {Object} [options] optional options to pass to each documents `toObject` method call during conversion + * @return {Array} + * @method toObject + * @api public + * @receiver MongooseDocumentArray + */ + + toObject: function(options) { + return this.map(function(doc) { + return doc && doc.toObject(options) || null; + }); + }, + + /** + * Helper for console.log + * + * @method inspect + * @api public + * @receiver MongooseDocumentArray + */ + + inspect: function() { + return Array.prototype.slice.call(this); + }, + + /** + * Creates a subdocument casted to this schema. + * + * This is the same subdocument constructor used for casting. + * + * @param {Object} obj the value to cast to this arrays SubDocument schema + * @method create + * @api public + * @receiver MongooseDocumentArray + */ + + create: function(obj) { + return new this._schema.casterConstructor(obj); + }, + + /** + * Creates a fn that notifies all child docs of `event`. + * + * @param {String} event + * @return {Function} + * @method notify + * @api private + * @receiver MongooseDocumentArray + */ + + notify: function notify(event) { + var _this = this; + return function notify(val) { + var i = _this.length; + while (i--) { + if (!_this[i]) { + continue; + } + switch (event) { + // only swap for save event for now, we may change this to all event types later + case 'save': + val = _this[i]; + break; + default: + // NO-OP + break; + } + _this[i].emit(event, val); + } + }; + } + +}; + +/*! + * Module exports. + */ + +module.exports = MongooseDocumentArray; diff --git a/node_modules/mongoose/lib/types/embedded.js b/node_modules/mongoose/lib/types/embedded.js new file mode 100644 index 0000000..a3c4df4 --- /dev/null +++ b/node_modules/mongoose/lib/types/embedded.js @@ -0,0 +1,347 @@ +/* eslint no-func-assign: 1 */ + +/*! + * Module dependencies. + */ + +var Document = require('../document_provider')(); +var PromiseProvider = require('../promise_provider'); + +/** + * EmbeddedDocument constructor. + * + * @param {Object} obj js object returned from the db + * @param {MongooseDocumentArray} parentArr the parent array of this document + * @param {Boolean} skipId + * @inherits Document + * @api private + */ + +function EmbeddedDocument(obj, parentArr, skipId, fields, index) { + if (parentArr) { + this.__parentArray = parentArr; + this.__parent = parentArr._parent; + } else { + this.__parentArray = undefined; + this.__parent = undefined; + } + this.__index = index; + + Document.call(this, obj, fields, skipId); + + var _this = this; + this.on('isNew', function(val) { + _this.isNew = val; + }); +} + +/*! + * Inherit from Document + */ +EmbeddedDocument.prototype = Object.create(Document.prototype); +EmbeddedDocument.prototype.constructor = EmbeddedDocument; + +EmbeddedDocument.prototype.toBSON = function() { + return this.toObject({ transform: false }); +}; + +/** + * Marks the embedded doc modified. + * + * ####Example: + * + * var doc = blogpost.comments.id(hexstring); + * doc.mixed.type = 'changed'; + * doc.markModified('mixed.type'); + * + * @param {String} path the path which changed + * @api public + * @receiver EmbeddedDocument + */ + +EmbeddedDocument.prototype.markModified = function(path) { + this.$__.activePaths.modify(path); + if (!this.__parentArray) { + return; + } + + if (this.isNew) { + // Mark the WHOLE parent array as modified + // if this is a new document (i.e., we are initializing + // a document), + this.__parentArray._markModified(); + } else { + this.__parentArray._markModified(this, path); + } +}; + +/*! + * ignore + */ + +EmbeddedDocument.prototype.populate = function() { + throw new Error('Mongoose does not support calling populate() on nested ' + + 'docs. Instead of `doc.arr[0].populate("path")`, use ' + + '`doc.populate("arr.0.path")`'); +}; + +/** + * Used as a stub for [hooks.js](https://github.com/bnoguchi/hooks-js/tree/31ec571cef0332e21121ee7157e0cf9728572cc3) + * + * ####NOTE: + * + * _This is a no-op. Does not actually save the doc to the db._ + * + * @param {Function} [fn] + * @return {Promise} resolved Promise + * @api private + */ + +EmbeddedDocument.prototype.save = function(fn) { + var Promise = PromiseProvider.get(); + return new Promise.ES6(function(resolve) { + fn && fn(); + resolve(); + }); +}; + +/*! + * Registers remove event listeners for triggering + * on subdocuments. + * + * @param {EmbeddedDocument} sub + * @api private + */ + +function registerRemoveListener(sub) { + var owner = sub.ownerDocument(); + + function emitRemove() { + owner.removeListener('save', emitRemove); + owner.removeListener('remove', emitRemove); + sub.emit('remove', sub); + owner = sub = null; + } + + owner.on('save', emitRemove); + owner.on('remove', emitRemove); +} + +/** + * Removes the subdocument from its parent array. + * + * @param {Object} [options] + * @param {Function} [fn] + * @api public + */ + +EmbeddedDocument.prototype.remove = function(options, fn) { + if ( typeof options === 'function' && !fn ) { + fn = options; + options = undefined; + } + if (!this.__parentArray || (options && options.noop)) { + fn && fn(null); + return this; + } + + var _id; + if (!this.willRemove) { + _id = this._doc._id; + if (!_id) { + throw new Error('For your own good, Mongoose does not know ' + + 'how to remove an EmbeddedDocument that has no _id'); + } + this.__parentArray.pull({_id: _id}); + this.willRemove = true; + registerRemoveListener(this); + } + + if (fn) { + fn(null); + } + + return this; +}; + +/** + * Override #update method of parent documents. + * @api private + */ + +EmbeddedDocument.prototype.update = function() { + throw new Error('The #update method is not available on EmbeddedDocuments'); +}; + +/** + * Helper for console.log + * + * @api public + */ + +EmbeddedDocument.prototype.inspect = function() { + return this.toObject({ transform: false, retainKeyOrder: true }); +}; + +/** + * Marks a path as invalid, causing validation to fail. + * + * @param {String} path the field to invalidate + * @param {String|Error} err error which states the reason `path` was invalid + * @return {Boolean} + * @api public + */ + +EmbeddedDocument.prototype.invalidate = function(path, err, val, first) { + Document.prototype.invalidate.call(this, path, err, val); + if (!this.__parent) { + if (err.name === 'ValidatorError') { + return true; + } + throw err; + } + + var index = this.__index; + if (typeof index !== 'undefined') { + var parentPath = this.__parentArray._path; + var fullPath = [parentPath, index, path].join('.'); + this.__parent.invalidate(fullPath, err, val); + } + + if (first) { + this.$__.validationError = this.ownerDocument().$__.validationError; + } + + return true; +}; + +/** + * Marks a path as valid, removing existing validation errors. + * + * @param {String} path the field to mark as valid + * @api private + * @method $markValid + * @receiver EmbeddedDocument + */ + +EmbeddedDocument.prototype.$markValid = function(path) { + if (!this.__parent) { + return; + } + + var index = this.__index; + if (typeof index !== 'undefined') { + var parentPath = this.__parentArray._path; + var fullPath = [parentPath, index, path].join('.'); + this.__parent.$markValid(fullPath); + } +}; + +/** + * Checks if a path is invalid + * + * @param {String} path the field to check + * @api private + * @method $isValid + * @receiver EmbeddedDocument + */ + +EmbeddedDocument.prototype.$isValid = function(path) { + var index = this.__index; + if (typeof index !== 'undefined' && this.__parent) { + return !this.__parent.$__.validationError || + !this.__parent.$__.validationError.errors[this.$__fullPath(path)]; + } + + return true; +}; + +/** + * Returns the top level document of this sub-document. + * + * @return {Document} + */ + +EmbeddedDocument.prototype.ownerDocument = function() { + if (this.$__.ownerDocument) { + return this.$__.ownerDocument; + } + + var parent = this.__parent; + if (!parent) { + return this; + } + + while (parent.__parent || parent.$parent) { + parent = parent.__parent || parent.$parent; + } + + this.$__.ownerDocument = parent; + return this.$__.ownerDocument; +}; + +/** + * Returns the full path to this document. If optional `path` is passed, it is appended to the full path. + * + * @param {String} [path] + * @return {String} + * @api private + * @method $__fullPath + * @memberOf EmbeddedDocument + */ + +EmbeddedDocument.prototype.$__fullPath = function(path) { + if (!this.$__.fullPath) { + var parent = this; // eslint-disable-line consistent-this + if (!parent.__parent) { + return path; + } + + var paths = []; + while (parent.__parent || parent.$parent) { + if (parent.__parent) { + paths.unshift(parent.__parentArray._path); + } else { + paths.unshift(parent.$basePath); + } + parent = parent.__parent || parent.$parent; + } + + this.$__.fullPath = paths.join('.'); + + if (!this.$__.ownerDocument) { + // optimization + this.$__.ownerDocument = parent; + } + } + + return path + ? this.$__.fullPath + '.' + path + : this.$__.fullPath; +}; + +/** + * Returns this sub-documents parent document. + * + * @api public + */ + +EmbeddedDocument.prototype.parent = function() { + return this.__parent; +}; + +/** + * Returns this sub-documents parent array. + * + * @api public + */ + +EmbeddedDocument.prototype.parentArray = function() { + return this.__parentArray; +}; + +/*! + * Module exports. + */ + +module.exports = EmbeddedDocument; diff --git a/node_modules/mongoose/lib/types/index.js b/node_modules/mongoose/lib/types/index.js new file mode 100644 index 0000000..0d01923 --- /dev/null +++ b/node_modules/mongoose/lib/types/index.js @@ -0,0 +1,15 @@ + +/*! + * Module exports. + */ + +exports.Array = require('./array'); +exports.Buffer = require('./buffer'); + +exports.Document = // @deprecate +exports.Embedded = require('./embedded'); + +exports.DocumentArray = require('./documentarray'); +exports.ObjectId = require('./objectid'); + +exports.Subdocument = require('./subdocument'); diff --git a/node_modules/mongoose/lib/types/objectid.js b/node_modules/mongoose/lib/types/objectid.js new file mode 100644 index 0000000..9fe0b97 --- /dev/null +++ b/node_modules/mongoose/lib/types/objectid.js @@ -0,0 +1,13 @@ +/** + * ObjectId type constructor + * + * ####Example + * + * var id = new mongoose.Types.ObjectId; + * + * @constructor ObjectId + */ + +var ObjectId = require('../drivers').ObjectId; + +module.exports = ObjectId; diff --git a/node_modules/mongoose/lib/types/subdocument.js b/node_modules/mongoose/lib/types/subdocument.js new file mode 100644 index 0000000..606cfa7 --- /dev/null +++ b/node_modules/mongoose/lib/types/subdocument.js @@ -0,0 +1,152 @@ +var Document = require('../document'); +var PromiseProvider = require('../promise_provider'); + +module.exports = Subdocument; + +/** + * Subdocument constructor. + * + * @inherits Document + * @api private + */ + +function Subdocument(value, fields) { + this.$isSingleNested = true; + Document.call(this, value, fields); +} + +Subdocument.prototype = Object.create(Document.prototype); + +Subdocument.prototype.toBSON = function() { + return this.toObject({ transform: false }); +}, + +/** + * Used as a stub for [hooks.js](https://github.com/bnoguchi/hooks-js/tree/31ec571cef0332e21121ee7157e0cf9728572cc3) + * + * ####NOTE: + * + * _This is a no-op. Does not actually save the doc to the db._ + * + * @param {Function} [fn] + * @return {Promise} resolved Promise + * @api private + */ + +Subdocument.prototype.save = function(fn) { + var Promise = PromiseProvider.get(); + return new Promise.ES6(function(resolve) { + fn && fn(); + resolve(); + }); +}; + +Subdocument.prototype.$isValid = function(path) { + if (this.$parent) { + return this.$parent.$isValid([this.$basePath, path].join('.')); + } +}; + +Subdocument.prototype.markModified = function(path) { + Document.prototype.markModified.call(this, path); + if (this.$parent) { + if (this.$parent.isDirectModified(this.$basePath)) { + return; + } + this.$parent.markModified([this.$basePath, path].join('.')); + } +}; + +Subdocument.prototype.$markValid = function(path) { + if (this.$parent) { + this.$parent.$markValid([this.$basePath, path].join('.')); + } +}; + +Subdocument.prototype.invalidate = function(path, err, val) { + Document.prototype.invalidate.call(this, path, err, val); + if (this.$parent) { + this.$parent.invalidate([this.$basePath, path].join('.'), err, val); + } else if (err.kind === 'cast' || err.name === 'CastError') { + throw err; + } +}; + +/** + * Returns the top level document of this sub-document. + * + * @return {Document} + */ + +Subdocument.prototype.ownerDocument = function() { + if (this.$__.ownerDocument) { + return this.$__.ownerDocument; + } + + var parent = this.$parent; + if (!parent) { + return this; + } + + while (parent.$parent || parent.__parent) { + parent = parent.$parent || parent.__parent; + } + this.$__.ownerDocument = parent; + return this.$__.ownerDocument; +}; + +/** + * Null-out this subdoc + * + * @param {Object} [options] + * @param {Function} [callback] optional callback for compatibility with Document.prototype.remove + */ + +Subdocument.prototype.remove = function(options, callback) { + if (typeof options === 'function') { + callback = options; + options = null; + } + + // If removing entire doc, no need to remove subdoc + if (!options || !options.noop) { + this.$parent.set(this.$basePath, null); + registerRemoveListener(this); + } + + if (typeof callback === 'function') { + callback(null); + } +}; + +/*! + * ignore + */ + +Subdocument.prototype.populate = function() { + throw new Error('Mongoose does not support calling populate() on nested ' + + 'docs. Instead of `doc.nested.populate("path")`, use ' + + '`doc.populate("nested.path")`'); +}; + +/*! + * Registers remove event listeners for triggering + * on subdocuments. + * + * @param {EmbeddedDocument} sub + * @api private + */ + +function registerRemoveListener(sub) { + var owner = sub.ownerDocument(); + + function emitRemove() { + owner.removeListener('save', emitRemove); + owner.removeListener('remove', emitRemove); + sub.emit('remove', sub); + owner = sub = null; + } + + owner.on('save', emitRemove); + owner.on('remove', emitRemove); +} diff --git a/node_modules/mongoose/lib/utils.js b/node_modules/mongoose/lib/utils.js new file mode 100644 index 0000000..6fa6a57 --- /dev/null +++ b/node_modules/mongoose/lib/utils.js @@ -0,0 +1,847 @@ +/*! + * Module dependencies. + */ + +var ObjectId = require('./types/objectid'); +var cloneRegExp = require('regexp-clone'); +var sliced = require('sliced'); +var mpath = require('mpath'); +var ms = require('ms'); +var MongooseBuffer; +var MongooseArray; +var Document; + +/*! + * Produces a collection name from model `name`. + * + * @param {String} name a model name + * @return {String} a collection name + * @api private + */ + +exports.toCollectionName = function(name, options) { + options = options || {}; + if (name === 'system.profile') { + return name; + } + if (name === 'system.indexes') { + return name; + } + if (options.pluralization === false) { + return name; + } + return pluralize(name.toLowerCase()); +}; + +/** + * Pluralization rules. + * + * These rules are applied while processing the argument to `toCollectionName`. + * + * @deprecated remove in 4.x gh-1350 + */ + +exports.pluralization = [ + [/(m)an$/gi, '$1en'], + [/(pe)rson$/gi, '$1ople'], + [/(child)$/gi, '$1ren'], + [/^(ox)$/gi, '$1en'], + [/(ax|test)is$/gi, '$1es'], + [/(octop|vir)us$/gi, '$1i'], + [/(alias|status)$/gi, '$1es'], + [/(bu)s$/gi, '$1ses'], + [/(buffal|tomat|potat)o$/gi, '$1oes'], + [/([ti])um$/gi, '$1a'], + [/sis$/gi, 'ses'], + [/(?:([^f])fe|([lr])f)$/gi, '$1$2ves'], + [/(hive)$/gi, '$1s'], + [/([^aeiouy]|qu)y$/gi, '$1ies'], + [/(x|ch|ss|sh)$/gi, '$1es'], + [/(matr|vert|ind)ix|ex$/gi, '$1ices'], + [/([m|l])ouse$/gi, '$1ice'], + [/(kn|w|l)ife$/gi, '$1ives'], + [/(quiz)$/gi, '$1zes'], + [/s$/gi, 's'], + [/([^a-z])$/, '$1'], + [/$/gi, 's'] +]; +var rules = exports.pluralization; + +/** + * Uncountable words. + * + * These words are applied while processing the argument to `toCollectionName`. + * @api public + */ + +exports.uncountables = [ + 'advice', + 'energy', + 'excretion', + 'digestion', + 'cooperation', + 'health', + 'justice', + 'labour', + 'machinery', + 'equipment', + 'information', + 'pollution', + 'sewage', + 'paper', + 'money', + 'species', + 'series', + 'rain', + 'rice', + 'fish', + 'sheep', + 'moose', + 'deer', + 'news', + 'expertise', + 'status', + 'media' +]; +var uncountables = exports.uncountables; + +/*! + * Pluralize function. + * + * @author TJ Holowaychuk (extracted from _ext.js_) + * @param {String} string to pluralize + * @api private + */ + +function pluralize(str) { + var found; + if (!~uncountables.indexOf(str.toLowerCase())) { + found = rules.filter(function(rule) { + return str.match(rule[0]); + }); + if (found[0]) { + return str.replace(found[0][0], found[0][1]); + } + } + return str; +} + +/*! + * Determines if `a` and `b` are deep equal. + * + * Modified from node/lib/assert.js + * + * @param {any} a a value to compare to `b` + * @param {any} b a value to compare to `a` + * @return {Boolean} + * @api private + */ + +exports.deepEqual = function deepEqual(a, b) { + if (a === b) { + return true; + } + + if (a instanceof Date && b instanceof Date) { + return a.getTime() === b.getTime(); + } + + if (a instanceof ObjectId && b instanceof ObjectId) { + return a.toString() === b.toString(); + } + + if (a instanceof RegExp && b instanceof RegExp) { + return a.source === b.source && + a.ignoreCase === b.ignoreCase && + a.multiline === b.multiline && + a.global === b.global; + } + + if (typeof a !== 'object' && typeof b !== 'object') { + return a == b; + } + + if (a === null || b === null || a === undefined || b === undefined) { + return false; + } + + if (a.prototype !== b.prototype) { + return false; + } + + // Handle MongooseNumbers + if (a instanceof Number && b instanceof Number) { + return a.valueOf() === b.valueOf(); + } + + if (Buffer.isBuffer(a)) { + return exports.buffer.areEqual(a, b); + } + + if (isMongooseObject(a)) { + a = a.toObject(); + } + if (isMongooseObject(b)) { + b = b.toObject(); + } + + try { + var ka = Object.keys(a), + kb = Object.keys(b), + key, i; + } catch (e) { + // happens when one is a string literal and the other isn't + return false; + } + + // having the same number of owned properties (keys incorporates + // hasOwnProperty) + if (ka.length !== kb.length) { + return false; + } + + // the same set of keys (although not necessarily the same order), + ka.sort(); + kb.sort(); + + // ~~~cheap key test + for (i = ka.length - 1; i >= 0; i--) { + if (ka[i] !== kb[i]) { + return false; + } + } + + // equivalent values for every corresponding key, and + // ~~~possibly expensive deep test + for (i = ka.length - 1; i >= 0; i--) { + key = ka[i]; + if (!deepEqual(a[key], b[key])) { + return false; + } + } + + return true; +}; + +/*! + * Object clone with Mongoose natives support. + * + * If options.minimize is true, creates a minimal data object. Empty objects and undefined values will not be cloned. This makes the data payload sent to MongoDB as small as possible. + * + * Functions are never cloned. + * + * @param {Object} obj the object to clone + * @param {Object} options + * @return {Object} the cloned object + * @api private + */ + +exports.clone = function clone(obj, options) { + if (obj === undefined || obj === null) { + return obj; + } + + if (Array.isArray(obj)) { + return cloneArray(obj, options); + } + + if (isMongooseObject(obj)) { + if (options && options.json && typeof obj.toJSON === 'function') { + return obj.toJSON(options); + } + return obj.toObject(options); + } + + if (obj.constructor) { + switch (exports.getFunctionName(obj.constructor)) { + case 'Object': + return cloneObject(obj, options); + case 'Date': + return new obj.constructor(+obj); + case 'RegExp': + return cloneRegExp(obj); + default: + // ignore + break; + } + } + + if (obj instanceof ObjectId) { + return new ObjectId(obj.id); + } + + if (!obj.constructor && exports.isObject(obj)) { + // object created with Object.create(null) + return cloneObject(obj, options); + } + + if (obj.valueOf) { + return obj.valueOf(); + } +}; +var clone = exports.clone; + +/*! + * ignore + */ + +function cloneObject(obj, options) { + var retainKeyOrder = options && options.retainKeyOrder, + minimize = options && options.minimize, + ret = {}, + hasKeys, + keys, + val, + k, + i; + + if (retainKeyOrder) { + for (k in obj) { + val = clone(obj[k], options); + + if (!minimize || (typeof val !== 'undefined')) { + hasKeys || (hasKeys = true); + ret[k] = val; + } + } + } else { + // faster + + keys = Object.keys(obj); + i = keys.length; + + while (i--) { + k = keys[i]; + val = clone(obj[k], options); + + if (!minimize || (typeof val !== 'undefined')) { + if (!hasKeys) { + hasKeys = true; + } + ret[k] = val; + } + } + } + + return minimize + ? hasKeys && ret + : ret; +} + +function cloneArray(arr, options) { + var ret = []; + for (var i = 0, l = arr.length; i < l; i++) { + ret.push(clone(arr[i], options)); + } + return ret; +} + +/*! + * Shallow copies defaults into options. + * + * @param {Object} defaults + * @param {Object} options + * @return {Object} the merged object + * @api private + */ + +exports.options = function(defaults, options) { + var keys = Object.keys(defaults), + i = keys.length, + k; + + options = options || {}; + + while (i--) { + k = keys[i]; + if (!(k in options)) { + options[k] = defaults[k]; + } + } + + return options; +}; + +/*! + * Generates a random string + * + * @api private + */ + +exports.random = function() { + return Math.random().toString().substr(3); +}; + +/*! + * Merges `from` into `to` without overwriting existing properties. + * + * @param {Object} to + * @param {Object} from + * @api private + */ + +exports.merge = function merge(to, from) { + var keys = Object.keys(from), + i = keys.length, + key; + + while (i--) { + key = keys[i]; + if (typeof to[key] === 'undefined') { + to[key] = from[key]; + } else if (exports.isObject(from[key])) { + merge(to[key], from[key]); + } + } +}; + +/*! + * toString helper + */ + +var toString = Object.prototype.toString; + +/*! + * Applies toObject recursively. + * + * @param {Document|Array|Object} obj + * @return {Object} + * @api private + */ + +exports.toObject = function toObject(obj) { + Document || (Document = require('./document')); + var ret; + + if (exports.isNullOrUndefined(obj)) { + return obj; + } + + if (obj instanceof Document) { + return obj.toObject(); + } + + if (Array.isArray(obj)) { + ret = []; + + for (var i = 0, len = obj.length; i < len; ++i) { + ret.push(toObject(obj[i])); + } + + return ret; + } + + if ((obj.constructor && exports.getFunctionName(obj.constructor) === 'Object') || + (!obj.constructor && exports.isObject(obj))) { + ret = {}; + + for (var k in obj) { + ret[k] = toObject(obj[k]); + } + + return ret; + } + + return obj; +}; + +/*! + * Determines if `arg` is an object. + * + * @param {Object|Array|String|Function|RegExp|any} arg + * @api private + * @return {Boolean} + */ + +exports.isObject = function(arg) { + if (Buffer.isBuffer(arg)) { + return true; + } + return toString.call(arg) === '[object Object]'; +}; + +/*! + * A faster Array.prototype.slice.call(arguments) alternative + * @api private + */ + +exports.args = sliced; + +/*! + * process.nextTick helper. + * + * Wraps `callback` in a try/catch + nextTick. + * + * node-mongodb-native has a habit of state corruption when an error is immediately thrown from within a collection callback. + * + * @param {Function} callback + * @api private + */ + +exports.tick = function tick(callback) { + if (typeof callback !== 'function') { + return; + } + return function() { + try { + callback.apply(this, arguments); + } catch (err) { + // only nextTick on err to get out of + // the event loop and avoid state corruption. + process.nextTick(function() { + throw err; + }); + } + }; +}; + +/*! + * Returns if `v` is a mongoose object that has a `toObject()` method we can use. + * + * This is for compatibility with libs like Date.js which do foolish things to Natives. + * + * @param {any} v + * @api private + */ + +exports.isMongooseObject = function(v) { + Document || (Document = require('./document')); + MongooseArray || (MongooseArray = require('./types').Array); + MongooseBuffer || (MongooseBuffer = require('./types').Buffer); + + return v instanceof Document || + (v && v.isMongooseArray) || + (v && v.isMongooseBuffer); +}; +var isMongooseObject = exports.isMongooseObject; + +/*! + * Converts `expires` options of index objects to `expiresAfterSeconds` options for MongoDB. + * + * @param {Object} object + * @api private + */ + +exports.expires = function expires(object) { + if (!(object && object.constructor.name === 'Object')) { + return; + } + if (!('expires' in object)) { + return; + } + + var when; + if (typeof object.expires !== 'string') { + when = object.expires; + } else { + when = Math.round(ms(object.expires) / 1000); + } + object.expireAfterSeconds = when; + delete object.expires; +}; + +/*! + * Populate options constructor + */ + +function PopulateOptions(path, select, match, options, model, subPopulate) { + this.path = path; + this.match = match; + this.select = select; + this.options = options; + this.model = model; + if (typeof subPopulate === 'object') { + this.populate = subPopulate; + } + this._docs = {}; +} + +// make it compatible with utils.clone +PopulateOptions.prototype.constructor = Object; + +// expose +exports.PopulateOptions = PopulateOptions; + +/*! + * populate helper + */ + +exports.populate = function populate(path, select, model, match, options, subPopulate) { + // The order of select/conditions args is opposite Model.find but + // necessary to keep backward compatibility (select could be + // an array, string, or object literal). + + // might have passed an object specifying all arguments + if (arguments.length === 1) { + if (path instanceof PopulateOptions) { + return [path]; + } + + if (Array.isArray(path)) { + return path.map(function(o) { + return exports.populate(o)[0]; + }); + } + + if (exports.isObject(path)) { + match = path.match; + options = path.options; + select = path.select; + model = path.model; + subPopulate = path.populate; + path = path.path; + } + } else if (typeof model !== 'string' && typeof model !== 'function') { + options = match; + match = model; + model = undefined; + } + + if (typeof path !== 'string') { + throw new TypeError('utils.populate: invalid path. Expected string. Got typeof `' + typeof path + '`'); + } + + if (typeof subPopulate === 'object') { + subPopulate = exports.populate(subPopulate); + } + + var ret = []; + var paths = path.split(' '); + options = exports.clone(options, { retainKeyOrder: true }); + for (var i = 0; i < paths.length; ++i) { + ret.push(new PopulateOptions(paths[i], select, match, options, model, subPopulate)); + } + + return ret; +}; + +/*! + * Return the value of `obj` at the given `path`. + * + * @param {String} path + * @param {Object} obj + */ + +exports.getValue = function(path, obj, map) { + return mpath.get(path, obj, '_doc', map); +}; + +/*! + * Sets the value of `obj` at the given `path`. + * + * @param {String} path + * @param {Anything} val + * @param {Object} obj + */ + +exports.setValue = function(path, val, obj, map) { + mpath.set(path, val, obj, '_doc', map); +}; + +/*! + * Returns an array of values from object `o`. + * + * @param {Object} o + * @return {Array} + * @private + */ + +exports.object = {}; +exports.object.vals = function vals(o) { + var keys = Object.keys(o), + i = keys.length, + ret = []; + + while (i--) { + ret.push(o[keys[i]]); + } + + return ret; +}; + +/*! + * @see exports.options + */ + +exports.object.shallowCopy = exports.options; + +/*! + * Safer helper for hasOwnProperty checks + * + * @param {Object} obj + * @param {String} prop + */ + +var hop = Object.prototype.hasOwnProperty; +exports.object.hasOwnProperty = function(obj, prop) { + return hop.call(obj, prop); +}; + +/*! + * Determine if `val` is null or undefined + * + * @return {Boolean} + */ + +exports.isNullOrUndefined = function(val) { + return val === null || val === undefined; +}; + +/*! + * ignore + */ + +exports.array = {}; + +/*! + * Flattens an array. + * + * [ 1, [ 2, 3, [4] ]] -> [1,2,3,4] + * + * @param {Array} arr + * @param {Function} [filter] If passed, will be invoked with each item in the array. If `filter` returns a falsey value, the item will not be included in the results. + * @return {Array} + * @private + */ + +exports.array.flatten = function flatten(arr, filter, ret) { + ret || (ret = []); + + arr.forEach(function(item) { + if (Array.isArray(item)) { + flatten(item, filter, ret); + } else { + if (!filter || filter(item)) { + ret.push(item); + } + } + }); + + return ret; +}; + +/*! + * Removes duplicate values from an array + * + * [1, 2, 3, 3, 5] => [1, 2, 3, 5] + * [ ObjectId("550988ba0c19d57f697dc45e"), ObjectId("550988ba0c19d57f697dc45e") ] + * => [ObjectId("550988ba0c19d57f697dc45e")] + * + * @param {Array} arr + * @return {Array} + * @private + */ + +exports.array.unique = function(arr) { + var primitives = {}; + var ids = {}; + var ret = []; + var length = arr.length; + for (var i = 0; i < length; ++i) { + if (typeof arr[i] === 'number' || typeof arr[i] === 'string') { + if (primitives[arr[i]]) { + continue; + } + ret.push(arr[i]); + primitives[arr[i]] = true; + } else if (arr[i] instanceof ObjectId) { + if (ids[arr[i].toString()]) { + continue; + } + ret.push(arr[i]); + ids[arr[i].toString()] = true; + } else { + ret.push(arr[i]); + } + } + + return ret; +}; + +/*! + * Determines if two buffers are equal. + * + * @param {Buffer} a + * @param {Object} b + */ + +exports.buffer = {}; +exports.buffer.areEqual = function(a, b) { + if (!Buffer.isBuffer(a)) { + return false; + } + if (!Buffer.isBuffer(b)) { + return false; + } + if (a.length !== b.length) { + return false; + } + for (var i = 0, len = a.length; i < len; ++i) { + if (a[i] !== b[i]) { + return false; + } + } + return true; +}; + +exports.getFunctionName = function(fn) { + if (fn.name) { + return fn.name; + } + return (fn.toString().trim().match(/^function\s*([^\s(]+)/) || [])[1]; +}; + +exports.decorate = function(destination, source) { + for (var key in source) { + destination[key] = source[key]; + } +}; + +/** + * merges to with a copy of from + * + * @param {Object} to + * @param {Object} fromObj + * @api private + */ + +exports.mergeClone = function(to, fromObj) { + var keys = Object.keys(fromObj), + i = keys.length, + key; + + while (i--) { + key = keys[i]; + if (typeof to[key] === 'undefined') { + // make sure to retain key order here because of a bug handling the $each + // operator in mongodb 2.4.4 + to[key] = exports.clone(fromObj[key], {retainKeyOrder: 1}); + } else { + if (exports.isObject(fromObj[key])) { + var obj = fromObj[key]; + if (isMongooseObject(fromObj[key]) && !fromObj[key].isMongooseBuffer) { + obj = obj.toObject({ transform: false }); + } + exports.mergeClone(to[key], obj); + } else { + // make sure to retain key order here because of a bug handling the + // $each operator in mongodb 2.4.4 + to[key] = exports.clone(fromObj[key], {retainKeyOrder: 1}); + } + } + } +}; + +/** + * Executes a function on each element of an array (like _.each) + * + * @param {Array} arr + * @param {Function} fn + * @api private + */ + +exports.each = function(arr, fn) { + for (var i = 0; i < arr.length; ++i) { + fn(arr[i]); + } +}; diff --git a/node_modules/mongoose/lib/virtualtype.js b/node_modules/mongoose/lib/virtualtype.js new file mode 100644 index 0000000..f43cbe2 --- /dev/null +++ b/node_modules/mongoose/lib/virtualtype.js @@ -0,0 +1,103 @@ + +/** + * VirtualType constructor + * + * This is what mongoose uses to define virtual attributes via `Schema.prototype.virtual`. + * + * ####Example: + * + * var fullname = schema.virtual('fullname'); + * fullname instanceof mongoose.VirtualType // true + * + * @parma {Object} options + * @api public + */ + +function VirtualType(options, name) { + this.path = name; + this.getters = []; + this.setters = []; + this.options = options || {}; +} + +/** + * Defines a getter. + * + * ####Example: + * + * var virtual = schema.virtual('fullname'); + * virtual.get(function () { + * return this.name.first + ' ' + this.name.last; + * }); + * + * @param {Function} fn + * @return {VirtualType} this + * @api public + */ + +VirtualType.prototype.get = function(fn) { + this.getters.push(fn); + return this; +}; + +/** + * Defines a setter. + * + * ####Example: + * + * var virtual = schema.virtual('fullname'); + * virtual.set(function (v) { + * var parts = v.split(' '); + * this.name.first = parts[0]; + * this.name.last = parts[1]; + * }); + * + * @param {Function} fn + * @return {VirtualType} this + * @api public + */ + +VirtualType.prototype.set = function(fn) { + this.setters.push(fn); + return this; +}; + +/** + * Applies getters to `value` using optional `scope`. + * + * @param {Object} value + * @param {Object} scope + * @return {any} the value after applying all getters + * @api public + */ + +VirtualType.prototype.applyGetters = function(value, scope) { + var v = value; + for (var l = this.getters.length - 1; l >= 0; l--) { + v = this.getters[l].call(scope, v, this); + } + return v; +}; + +/** + * Applies setters to `value` using optional `scope`. + * + * @param {Object} value + * @param {Object} scope + * @return {any} the value after applying all setters + * @api public + */ + +VirtualType.prototype.applySetters = function(value, scope) { + var v = value; + for (var l = this.setters.length - 1; l >= 0; l--) { + v = this.setters[l].call(scope, v, this); + } + return v; +}; + +/*! + * exports + */ + +module.exports = VirtualType; diff --git a/node_modules/mongoose/node_modules/async/CHANGELOG.md b/node_modules/mongoose/node_modules/async/CHANGELOG.md new file mode 100644 index 0000000..94cf2ca --- /dev/null +++ b/node_modules/mongoose/node_modules/async/CHANGELOG.md @@ -0,0 +1,208 @@ +# v2.0.1 + +- Significantly optimized all iteration based collection methods such as `each`, `map`, `filter`, etc (#1245, #1246, #1247). + +# v2.0.0 + +Lots of changes here! + +First and foremost, we have a slick new [site for docs](https://caolan.github.io/async/). Special thanks to [**@hargasinski**](https://github.com/hargasinski) for his work converting our old docs to `jsdoc` format and implementing the new website. Also huge ups to [**@ivanseidel**](https://github.com/ivanseidel) for designing our new logo. It was a long process for both of these tasks, but I think these changes turned out extraordinary well. + +The biggest feature is modularization. You can now `require("async/series")` to only require the `series` function. Every Async library function is available this way. You still can `require("async")` to require the entire library, like you could do before. + +We also provide Async as a collection of ES2015 modules. You can now `import {each} from 'async-es'` or `import waterfall from 'async-es/waterfall'`. If you are using only a few Async functions, and are using a ES bundler such as Rollup, this can significantly lower your build size. + +Major thanks to [**@Kikobeats**](github.com/Kikobeats), [**@aearly**](github.com/aearly) and [**@megawac**](github.com/megawac) for doing the majority of the modularization work, as well as [**@jdalton**](github.com/jdalton) and [**@Rich-Harris**](github.com/Rich-Harris) for advisory work on the general modularization strategy. + +Another one of the general themes of the 2.0 release is standardization of what an "async" function is. We are now more strictly following the node-style continuation passing style. That is, an async function is a function that: + +1. Takes a variable number of arguments +2. The last argument is always a callback +3. The callback can accept any number of arguments +4. The first argument passed to the callback will be treated as an error result, if the argument is truthy +5. Any number of result arguments can be passed after the "error" argument +6. The callback is called once and exactly once, either on the same tick or later tick of the JavaScript event loop. + +There were several cases where Async accepted some functions that did not strictly have these properties, most notably `auto`, `every`, `some`, and `filter`. + +Another theme is performance. We have eliminated internal deferrals in all cases where they make sense. For example, in `waterfall` and `auto`, there was a `setImmediate` between each task -- these deferrals have been removed. A `setImmediate` call can add up to 1ms of delay. This might not seem like a lot, but it can add up if you are using many Async functions in the course of processing a HTTP request, for example. Nearly all asynchronous functions that do I/O already have some sort of deferral built in, so the extra deferral is unnecessary. The trade-off of this change is removing our built-in stack-overflow defense. Many synchronous callback calls in series can quickly overflow the JS call stack. If you do have a function that is sometimes synchronous (calling its callback on the same tick), and are running into stack overflows, wrap it with `async.ensureAsync()`. + +Another big performance win has been re-implementing `queue`, `cargo`, and `priorityQueue` with [doubly linked lists](https://en.wikipedia.org/wiki/Doubly_linked_list) instead of arrays. This has lead to queues being an order of [magnitude faster on large sets of tasks](https://github.com/caolan/async/pull/1205). + +## New Features + +- Async is now modularized. Individual functions can be `require()`d from the main package. (`require('async/auto')`) (#984, #996) +- Async is also available as a collection of ES2015 modules in the new `async-es` package. (`import {forEachSeries} from 'async-es'`) (#984, #996) +- Added `race`, analogous to `Promise.race()`. It will run an array of async tasks in parallel and will call its callback with the result of the first task to respond. (#568, #1038) +- Collection methods now accept ES2015 iterators. Maps, Sets, and anything that implements the iterator spec can now be passed directly to `each`, `map`, `parallel`, etc.. (#579, #839, #1074) +- Added `mapValues`, for mapping over the properties of an object and returning an object with the same keys. (#1157, #1177) +- Added `timeout`, a wrapper for an async function that will make the task time-out after the specified time. (#1007, #1027) +- Added `reflect` and `reflectAll`, analagous to [`Promise.reflect()`](http://bluebirdjs.com/docs/api/reflect.html), a wrapper for async tasks that always succeeds, by gathering results and errors into an object. (#942, #1012, #1095) +- `constant` supports dynamic arguments -- it will now always use its last argument as the callback. (#1016, #1052) +- `setImmediate` and `nextTick` now support arguments to partially apply to the deferred function, like the node-native versions do. (#940, #1053) +- `auto` now supports resolving cyclic dependencies using [Kahn's algorithm](https://en.wikipedia.org/wiki/Topological_sorting#Kahn.27s_algorithm) (#1140). +- Added `autoInject`, a relative of `auto` that automatically spreads a task's dependencies as arguments to the task function. (#608, #1055, #1099, #1100) +- You can now limit the concurrency of `auto` tasks. (#635, #637) +- Added `retryable`, a relative of `retry` that wraps an async function, making it retry when called. (#1058) +- `retry` now supports specifying a function that determines the next time interval, useful for exponential backoff, logging and other retry strategies. (#1161) +- `retry` will now pass all of the arguments the task function was resolved with to the callback (#1231). +- Added `q.unsaturated` -- callback called when a `queue`'s number of running workers falls below a threshold. (#868, #1030, #1033, #1034) +- Added `q.error` -- a callback called whenever a `queue` task calls its callback with an error. (#1170) +- `applyEach` and `applyEachSeries` now pass results to the final callback. (#1088) + +## Breaking changes + +- Calling a callback more than once is considered an error, and an error will be thrown. This had an explicit breaking change in `waterfall`. If you were relying on this behavior, you should more accurately represent your control flow as an event emitter or stream. (#814, #815, #1048, #1050) +- `auto` task functions now always take the callback as the last argument. If a task has dependencies, the `results` object will be passed as the first argument. To migrate old task functions, wrap them with [`_.flip`](https://lodash.com/docs#flip) (#1036, #1042) +- Internal `setImmediate` calls have been refactored away. This may make existing flows vulnerable to stack overflows if you use many synchronous functions in series. Use `ensureAsync` to work around this. (#696, #704, #1049, #1050) +- `map` used to return an object when iterating over an object. `map` now always returns an array, like in other libraries. The previous object behavior has been split out into `mapValues`. (#1157, #1177) +- `filter`, `reject`, `some`, `every`, and related functions now expect an error as the first callback argument, rather than just a simple boolean. Pass `null` as the first argument, or use `fs.access` instead of `fs.exists`. (#118, #774, #1028, #1041) +- `{METHOD}` and `{METHOD}Series` are now implemented in terms of `{METHOD}Limit`. This is a major internal simplification, and is not expected to cause many problems, but it does subtly affect how functions execute internally. (#778, #847) +- `retry`'s callback is now optional. Previously, omitting the callback would partially apply the function, meaning it could be passed directly as a task to `series` or `auto`. The partially applied "control-flow" behavior has been separated out into `retryable`. (#1054, #1058) +- The test function for `whilst`, `until`, and `during` used to be passed non-error args from the iteratee function's callback, but this led to weirdness where the first call of the test function would be passed no args. We have made it so the test function is never passed extra arguments, and only the `doWhilst`, `doUntil`, and `doDuring` functions pass iteratee callback arguments to the test function (#1217, #1224) +- The `q.tasks` array has been renamed `q._tasks` and is now implemented as a doubly linked list (DLL). Any code that used to interact with this array will need to be updated to either use the provided helpers or support DLLs (#1205). +- The timing of the `q.saturated()` callback in a `queue` has been modified to better reflect when tasks pushed to the queue will start queueing. (#724, #1078) +- Removed `iterator` method in favour of [ES2015 iterator protocol](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Guide/Iterators_and_Generators ) which natively supports arrays (#1237) +- Dropped support for Component, Jam, SPM, and Volo (#1175, ##176) + +## Bug Fixes + +- Improved handling of no dependency cases in `auto` & `autoInject` (#1147). +- Fixed a bug where the callback generated by `asyncify` with `Promises` could resolve twice (#1197). +- Fixed several documented optional callbacks not actually being optional (#1223). + +## Other + +- Added `someSeries` and `everySeries` for symmetry, as well as a complete set of `any`/`anyLimit`/`anySeries` and `all`/`/allLmit`/`allSeries` aliases. +- Added `find` as an alias for `detect. (as well as `findLimit` and `findSeries`). +- Various doc fixes (#1005, #1008, #1010, #1015, #1021, #1037, #1039, #1051, #1102, #1107, #1121, #1123, #1129, #1135, #1138, #1141, #1153, #1216, #1217, #1232, #1233, #1236, #1238) + +Thank you [**@aearly**](github.com/aearly) and [**@megawac**](github.com/megawac) for taking the lead on version 2 of async. + +------------------------------------------ + +# v1.5.2 +- Allow using `"constructor"` as an argument in `memoize` (#998) +- Give a better error messsage when `auto` dependency checking fails (#994) +- Various doc updates (#936, #956, #979, #1002) + +# v1.5.1 +- Fix issue with `pause` in `queue` with concurrency enabled (#946) +- `while` and `until` now pass the final result to callback (#963) +- `auto` will properly handle concurrency when there is no callback (#966) +- `auto` will no. properly stop execution when an error occurs (#988, #993) +- Various doc fixes (#971, #980) + +# v1.5.0 + +- Added `transform`, analogous to [`_.transform`](http://lodash.com/docs#transform) (#892) +- `map` now returns an object when an object is passed in, rather than array with non-numeric keys. `map` will begin always returning an array with numeric indexes in the next major release. (#873) +- `auto` now accepts an optional `concurrency` argument to limit the number o. running tasks (#637) +- Added `queue#workersList()`, to retrieve the lis. of currently running tasks. (#891) +- Various code simplifications (#896, #904) +- Various doc fixes :scroll: (#890, #894, #903, #905, #912) + +# v1.4.2 + +- Ensure coverage files don't get published on npm (#879) + +# v1.4.1 + +- Add in overlooked `detectLimit` method (#866) +- Removed unnecessary files from npm releases (#861) +- Removed usage of a reserved word to prevent :boom: in older environments (#870) + +# v1.4.0 + +- `asyncify` now supports promises (#840) +- Added `Limit` versions of `filter` and `reject` (#836) +- Add `Limit` versions of `detect`, `some` and `every` (#828, #829) +- `some`, `every` and `detect` now short circuit early (#828, #829) +- Improve detection of the global object (#804), enabling use in WebWorkers +- `whilst` now called with arguments from iterator (#823) +- `during` now gets called with arguments from iterator (#824) +- Code simplifications and optimizations aplenty ([diff](https://github.com/caolan/async/compare/v1.3.0...v1.4.0)) + + +# v1.3.0 + +New Features: +- Added `constant` +- Added `asyncify`/`wrapSync` for making sync functions work with callbacks. (#671, #806) +- Added `during` and `doDuring`, which are like `whilst` with an async truth test. (#800) +- `retry` now accepts an `interval` parameter to specify a delay between retries. (#793) +- `async` should work better in Web Workers due to better `root` detection (#804) +- Callbacks are now optional in `whilst`, `doWhilst`, `until`, and `doUntil` (#642) +- Various internal updates (#786, #801, #802, #803) +- Various doc fixes (#790, #794) + +Bug Fixes: +- `cargo` now exposes the `payload` size, and `cargo.payload` can be changed on the fly after the `cargo` is created. (#740, #744, #783) + + +# v1.2.1 + +Bug Fix: + +- Small regression with synchronous iterator behavior in `eachSeries` with a 1-element array. Before 1.1.0, `eachSeries`'s callback was called on the same tick, which this patch restores. In 2.0.0, it will be called on the next tick. (#782) + + +# v1.2.0 + +New Features: + +- Added `timesLimit` (#743) +- `concurrency` can be changed after initialization in `queue` by setting `q.concurrency`. The new concurrency will be reflected the next time a task is processed. (#747, #772) + +Bug Fixes: + +- Fixed a regression in `each` and family with empty arrays that have additional properties. (#775, #777) + + +# v1.1.1 + +Bug Fix: + +- Small regression with synchronous iterator behavior in `eachSeries` with a 1-element array. Before 1.1.0, `eachSeries`'s callback was called on the same tick, which this patch restores. In 2.0.0, it will be called on the next tick. (#782) + + +# v1.1.0 + +New Features: + +- `cargo` now supports all of the same methods and event callbacks as `queue`. +- Added `ensureAsync` - A wrapper that ensures an async function calls its callback on a later tick. (#769) +- Optimized `map`, `eachOf`, and `waterfall` families of functions +- Passing a `null` or `undefined` array to `map`, `each`, `parallel` and families will be treated as an empty array (#667). +- The callback is now optional for the composed results of `compose` and `seq`. (#618) +- Reduced file size by 4kb, (minified version by 1kb) +- Added code coverage through `nyc` and `coveralls` (#768) + +Bug Fixes: + +- `forever` will no longer stack overflow with a synchronous iterator (#622) +- `eachLimit` and other limit functions will stop iterating once an error occurs (#754) +- Always pass `null` in callbacks when there is no error (#439) +- Ensure proper conditions when calling `drain()` after pushing an empty data set to a queue (#668) +- `each` and family will properly handle an empty array (#578) +- `eachSeries` and family will finish if the underlying array is modified during execution (#557) +- `queue` will throw if a non-function is passed to `q.push()` (#593) +- Doc fixes (#629, #766) + + +# v1.0.0 + +No known breaking changes, we are simply complying with semver from here on out. + +Changes: + +- Start using a changelog! +- Add `forEachOf` for iterating over Objects (or to iterate Arrays with indexes available) (#168 #704 #321) +- Detect deadlocks in `auto` (#663) +- Better support for require.js (#527) +- Throw if queue created with concurrency `0` (#714) +- Fix unneeded iteration in `queue.resume()` (#758) +- Guard against timer mocking overriding `setImmediate` (#609 #611) +- Miscellaneous doc fixes (#542 #596 #615 #628 #631 #690 #729) +- Use single noop function internally (#546) +- Optimize internal `_each`, `_map` and `_keys` functions. diff --git a/node_modules/mongoose/node_modules/async/LICENSE b/node_modules/mongoose/node_modules/async/LICENSE new file mode 100644 index 0000000..9fe85b9 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/LICENSE @@ -0,0 +1,19 @@ +Copyright (c) 2010-2016 Caolan McMahon + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. diff --git a/node_modules/mongoose/node_modules/async/README.md b/node_modules/mongoose/node_modules/async/README.md new file mode 100644 index 0000000..aece509 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/README.md @@ -0,0 +1,12 @@ +![Async Logo](https://raw.githubusercontent.com/caolan/async/master/logo/async-logo_readme.jpg) + +[![Build Status via Travis CI](https://travis-ci.org/caolan/async.svg?branch=master)](https://travis-ci.org/caolan/async) +[![NPM version](https://img.shields.io/npm/v/async.svg)](https://www.npmjs.com/package/async) +[![Coverage Status](https://coveralls.io/repos/caolan/async/badge.svg?branch=master)](https://coveralls.io/r/caolan/async?branch=master) +[![Join the chat at https://gitter.im/caolan/async](https://badges.gitter.im/Join%20Chat.svg)](https://gitter.im/caolan/async?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge) + +Async is a utility module which provides straight-forward, powerful functions for working with asynchronous JavaScript. Although originally designed for use with [Node.js](https://nodejs.org/) and installable via `npm install --save async`, it can also be used directly in the browser. + +For Documentation, visit + +*For Async v1.5.x documentation, go [HERE](https://github.com/caolan/async/blob/v1.5.2/README.md)* diff --git a/node_modules/mongoose/node_modules/async/apply.js b/node_modules/mongoose/node_modules/async/apply.js new file mode 100644 index 0000000..578f449 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/apply.js @@ -0,0 +1,62 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _rest = require('lodash/rest'); + +var _rest2 = _interopRequireDefault(_rest); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Creates a continuation function with some arguments already applied. + * + * Useful as a shorthand when combined with other control flow functions. Any + * arguments passed to the returned function are added to the arguments + * originally passed to apply. + * + * @name apply + * @static + * @memberOf module:Utils + * @method + * @category Util + * @param {Function} function - The function you want to eventually apply all + * arguments to. Invokes with (arguments...). + * @param {...*} arguments... - Any number of arguments to automatically apply + * when the continuation is called. + * @example + * + * // using apply + * async.parallel([ + * async.apply(fs.writeFile, 'testfile1', 'test1'), + * async.apply(fs.writeFile, 'testfile2', 'test2') + * ]); + * + * + * // the same process without using apply + * async.parallel([ + * function(callback) { + * fs.writeFile('testfile1', 'test1', callback); + * }, + * function(callback) { + * fs.writeFile('testfile2', 'test2', callback); + * } + * ]); + * + * // It's possible to pass any number of additional arguments when calling the + * // continuation: + * + * node> var fn = async.apply(sys.puts, 'one'); + * node> fn('two', 'three'); + * one + * two + * three + */ +exports.default = (0, _rest2.default)(function (fn, args) { + return (0, _rest2.default)(function (callArgs) { + return fn.apply(null, args.concat(callArgs)); + }); +}); +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/applyEach.js b/node_modules/mongoose/node_modules/async/applyEach.js new file mode 100644 index 0000000..c6e71b9 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/applyEach.js @@ -0,0 +1,49 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _applyEach = require('./internal/applyEach'); + +var _applyEach2 = _interopRequireDefault(_applyEach); + +var _map = require('./map'); + +var _map2 = _interopRequireDefault(_map); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Applies the provided arguments to each function in the array, calling + * `callback` after all functions have completed. If you only provide the first + * argument, then it will return a function which lets you pass in the + * arguments as if it were a single function call. + * + * @name applyEach + * @static + * @memberOf module:ControlFlow + * @method + * @category Control Flow + * @param {Array|Iterable|Object} fns - A collection of asynchronous functions to all + * call with the same arguments + * @param {...*} [args] - any number of separate arguments to pass to the + * function. + * @param {Function} [callback] - the final argument should be the callback, + * called when all functions have completed processing. + * @returns {Function} - If only the first argument is provided, it will return + * a function which lets you pass in the arguments as if it were a single + * function call. + * @example + * + * async.applyEach([enableSearch, updateSchema], 'bucket', callback); + * + * // partial application example: + * async.each( + * buckets, + * async.applyEach([enableSearch, updateSchema]), + * callback + * ); + */ +exports.default = (0, _applyEach2.default)(_map2.default); +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/applyEachSeries.js b/node_modules/mongoose/node_modules/async/applyEachSeries.js new file mode 100644 index 0000000..989f208 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/applyEachSeries.js @@ -0,0 +1,37 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _applyEach = require('./internal/applyEach'); + +var _applyEach2 = _interopRequireDefault(_applyEach); + +var _mapSeries = require('./mapSeries'); + +var _mapSeries2 = _interopRequireDefault(_mapSeries); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`applyEach`]{@link module:ControlFlow.applyEach} but runs only a single async operation at a time. + * + * @name applyEachSeries + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.applyEach]{@link module:ControlFlow.applyEach} + * @category Control Flow + * @param {Array|Iterable|Object} fns - A collection of asynchronous functions to all + * call with the same arguments + * @param {...*} [args] - any number of separate arguments to pass to the + * function. + * @param {Function} [callback] - the final argument should be the callback, + * called when all functions have completed processing. + * @returns {Function} - If only the first argument is provided, it will return + * a function which lets you pass in the arguments as if it were a single + * function call. + */ +exports.default = (0, _applyEach2.default)(_mapSeries2.default); +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/asyncify.js b/node_modules/mongoose/node_modules/async/asyncify.js new file mode 100644 index 0000000..a31fa9f --- /dev/null +++ b/node_modules/mongoose/node_modules/async/asyncify.js @@ -0,0 +1,93 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = asyncify; + +var _isObject = require('lodash/isObject'); + +var _isObject2 = _interopRequireDefault(_isObject); + +var _initialParams = require('./internal/initialParams'); + +var _initialParams2 = _interopRequireDefault(_initialParams); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Take a sync function and make it async, passing its return value to a + * callback. This is useful for plugging sync functions into a waterfall, + * series, or other async functions. Any arguments passed to the generated + * function will be passed to the wrapped function (except for the final + * callback argument). Errors thrown will be passed to the callback. + * + * If the function passed to `asyncify` returns a Promise, that promises's + * resolved/rejected state will be used to call the callback, rather than simply + * the synchronous return value. + * + * This also means you can asyncify ES2016 `async` functions. + * + * @name asyncify + * @static + * @memberOf module:Utils + * @method + * @alias wrapSync + * @category Util + * @param {Function} func - The synchronous function to convert to an + * asynchronous function. + * @returns {Function} An asynchronous wrapper of the `func`. To be invoked with + * (callback). + * @example + * + * // passing a regular synchronous function + * async.waterfall([ + * async.apply(fs.readFile, filename, "utf8"), + * async.asyncify(JSON.parse), + * function (data, next) { + * // data is the result of parsing the text. + * // If there was a parsing error, it would have been caught. + * } + * ], callback); + * + * // passing a function returning a promise + * async.waterfall([ + * async.apply(fs.readFile, filename, "utf8"), + * async.asyncify(function (contents) { + * return db.model.create(contents); + * }), + * function (model, next) { + * // `model` is the instantiated model object. + * // If there was an error, this function would be skipped. + * } + * ], callback); + * + * // es6 example + * var q = async.queue(async.asyncify(async function(file) { + * var intermediateStep = await processFile(file); + * return await somePromise(intermediateStep) + * })); + * + * q.push(files); + */ +function asyncify(func) { + return (0, _initialParams2.default)(function (args, callback) { + var result; + try { + result = func.apply(this, args); + } catch (e) { + return callback(e); + } + // if result is Promise object + if ((0, _isObject2.default)(result) && typeof result.then === 'function') { + result.then(function (value) { + callback(null, value); + }, function (err) { + callback(err.message ? err : new Error(err)); + }); + } else { + callback(null, result); + } + }); +} +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/auto.js b/node_modules/mongoose/node_modules/async/auto.js new file mode 100644 index 0000000..7f324b4 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/auto.js @@ -0,0 +1,285 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +exports.default = function (tasks, concurrency, callback) { + if (typeof concurrency === 'function') { + // concurrency is optional, shift the args. + callback = concurrency; + concurrency = null; + } + callback = (0, _once2.default)(callback || _noop2.default); + var keys = (0, _keys2.default)(tasks); + var numTasks = keys.length; + if (!numTasks) { + return callback(null); + } + if (!concurrency) { + concurrency = numTasks; + } + + var results = {}; + var runningTasks = 0; + var hasError = false; + + var listeners = {}; + + var readyTasks = []; + + // for cycle detection: + var readyToCheck = []; // tasks that have been identified as reachable + // without the possibility of returning to an ancestor task + var uncheckedDependencies = {}; + + (0, _baseForOwn2.default)(tasks, function (task, key) { + if (!(0, _isArray2.default)(task)) { + // no dependencies + enqueueTask(key, [task]); + readyToCheck.push(key); + return; + } + + var dependencies = task.slice(0, task.length - 1); + var remainingDependencies = dependencies.length; + if (remainingDependencies === 0) { + enqueueTask(key, task); + readyToCheck.push(key); + return; + } + uncheckedDependencies[key] = remainingDependencies; + + (0, _arrayEach2.default)(dependencies, function (dependencyName) { + if (!tasks[dependencyName]) { + throw new Error('async.auto task `' + key + '` has a non-existent dependency in ' + dependencies.join(', ')); + } + addListener(dependencyName, function () { + remainingDependencies--; + if (remainingDependencies === 0) { + enqueueTask(key, task); + } + }); + }); + }); + + checkForDeadlocks(); + processQueue(); + + function enqueueTask(key, task) { + readyTasks.push(function () { + runTask(key, task); + }); + } + + function processQueue() { + if (readyTasks.length === 0 && runningTasks === 0) { + return callback(null, results); + } + while (readyTasks.length && runningTasks < concurrency) { + var run = readyTasks.shift(); + run(); + } + } + + function addListener(taskName, fn) { + var taskListeners = listeners[taskName]; + if (!taskListeners) { + taskListeners = listeners[taskName] = []; + } + + taskListeners.push(fn); + } + + function taskComplete(taskName) { + var taskListeners = listeners[taskName] || []; + (0, _arrayEach2.default)(taskListeners, function (fn) { + fn(); + }); + processQueue(); + } + + function runTask(key, task) { + if (hasError) return; + + var taskCallback = (0, _onlyOnce2.default)((0, _rest2.default)(function (err, args) { + runningTasks--; + if (args.length <= 1) { + args = args[0]; + } + if (err) { + var safeResults = {}; + (0, _baseForOwn2.default)(results, function (val, rkey) { + safeResults[rkey] = val; + }); + safeResults[key] = args; + hasError = true; + listeners = []; + + callback(err, safeResults); + } else { + results[key] = args; + taskComplete(key); + } + })); + + runningTasks++; + var taskFn = task[task.length - 1]; + if (task.length > 1) { + taskFn(results, taskCallback); + } else { + taskFn(taskCallback); + } + } + + function checkForDeadlocks() { + // Kahn's algorithm + // https://en.wikipedia.org/wiki/Topological_sorting#Kahn.27s_algorithm + // http://connalle.blogspot.com/2013/10/topological-sortingkahn-algorithm.html + var currentTask; + var counter = 0; + while (readyToCheck.length) { + currentTask = readyToCheck.pop(); + counter++; + (0, _arrayEach2.default)(getDependents(currentTask), function (dependent) { + if (--uncheckedDependencies[dependent] === 0) { + readyToCheck.push(dependent); + } + }); + } + + if (counter !== numTasks) { + throw new Error('async.auto cannot execute tasks due to a recursive dependency'); + } + } + + function getDependents(taskName) { + var result = []; + (0, _baseForOwn2.default)(tasks, function (task, key) { + if ((0, _isArray2.default)(task) && (0, _baseIndexOf2.default)(task, taskName, 0) >= 0) { + result.push(key); + } + }); + return result; + } +}; + +var _arrayEach = require('lodash/_arrayEach'); + +var _arrayEach2 = _interopRequireDefault(_arrayEach); + +var _baseForOwn = require('lodash/_baseForOwn'); + +var _baseForOwn2 = _interopRequireDefault(_baseForOwn); + +var _baseIndexOf = require('lodash/_baseIndexOf'); + +var _baseIndexOf2 = _interopRequireDefault(_baseIndexOf); + +var _isArray = require('lodash/isArray'); + +var _isArray2 = _interopRequireDefault(_isArray); + +var _keys = require('lodash/keys'); + +var _keys2 = _interopRequireDefault(_keys); + +var _noop = require('lodash/noop'); + +var _noop2 = _interopRequireDefault(_noop); + +var _rest = require('lodash/rest'); + +var _rest2 = _interopRequireDefault(_rest); + +var _once = require('./internal/once'); + +var _once2 = _interopRequireDefault(_once); + +var _onlyOnce = require('./internal/onlyOnce'); + +var _onlyOnce2 = _interopRequireDefault(_onlyOnce); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +module.exports = exports['default']; + +/** + * Determines the best order for running the functions in `tasks`, based on + * their requirements. Each function can optionally depend on other functions + * being completed first, and each function is run as soon as its requirements + * are satisfied. + * + * If any of the functions pass an error to their callback, the `auto` sequence + * will stop. Further tasks will not execute (so any other functions depending + * on it will not run), and the main `callback` is immediately called with the + * error. + * + * Functions also receive an object containing the results of functions which + * have completed so far as the first argument, if they have dependencies. If a + * task function has no dependencies, it will only be passed a callback. + * + * @name auto + * @static + * @memberOf module:ControlFlow + * @method + * @category Control Flow + * @param {Object} tasks - An object. Each of its properties is either a + * function or an array of requirements, with the function itself the last item + * in the array. The object's key of a property serves as the name of the task + * defined by that property, i.e. can be used when specifying requirements for + * other tasks. The function receives one or two arguments: + * * a `results` object, containing the results of the previously executed + * functions, only passed if the task has any dependencies, + * * a `callback(err, result)` function, which must be called when finished, + * passing an `error` (which can be `null`) and the result of the function's + * execution. + * @param {number} [concurrency=Infinity] - An optional `integer` for + * determining the maximum number of tasks that can be run in parallel. By + * default, as many as possible. + * @param {Function} [callback] - An optional callback which is called when all + * the tasks have been completed. It receives the `err` argument if any `tasks` + * pass an error to their callback. Results are always returned; however, if an + * error occurs, no further `tasks` will be performed, and the results object + * will only contain partial results. Invoked with (err, results). + * @returns undefined + * @example + * + * async.auto({ + * // this function will just be passed a callback + * readData: async.apply(fs.readFile, 'data.txt', 'utf-8'), + * showData: ['readData', function(results, cb) { + * // results.readData is the file's contents + * // ... + * }] + * }, callback); + * + * async.auto({ + * get_data: function(callback) { + * console.log('in get_data'); + * // async code to get some data + * callback(null, 'data', 'converted to array'); + * }, + * make_folder: function(callback) { + * console.log('in make_folder'); + * // async code to create a directory to store a file in + * // this is run at the same time as getting the data + * callback(null, 'folder'); + * }, + * write_file: ['get_data', 'make_folder', function(results, callback) { + * console.log('in write_file', JSON.stringify(results)); + * // once there is some data and the directory exists, + * // write the data to a file in the directory + * callback(null, 'filename'); + * }], + * email_link: ['write_file', function(results, callback) { + * console.log('in email_link', JSON.stringify(results)); + * // once the file is written let's email a link to it... + * // results.write_file contains the filename returned by write_file. + * callback(null, {'file':results.write_file, 'email':'user@example.com'}); + * }] + * }, function(err, results) { + * console.log('err = ', err); + * console.log('results = ', results); + * }); + */ \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/autoInject.js b/node_modules/mongoose/node_modules/async/autoInject.js new file mode 100644 index 0000000..b9d1eaa --- /dev/null +++ b/node_modules/mongoose/node_modules/async/autoInject.js @@ -0,0 +1,167 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = autoInject; + +var _auto = require('./auto'); + +var _auto2 = _interopRequireDefault(_auto); + +var _baseForOwn = require('lodash/_baseForOwn'); + +var _baseForOwn2 = _interopRequireDefault(_baseForOwn); + +var _arrayMap = require('lodash/_arrayMap'); + +var _arrayMap2 = _interopRequireDefault(_arrayMap); + +var _copyArray = require('lodash/_copyArray'); + +var _copyArray2 = _interopRequireDefault(_copyArray); + +var _isArray = require('lodash/isArray'); + +var _isArray2 = _interopRequireDefault(_isArray); + +var _trim = require('lodash/trim'); + +var _trim2 = _interopRequireDefault(_trim); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +var FN_ARGS = /^(function)?\s*[^\(]*\(\s*([^\)]*)\)/m; +var FN_ARG_SPLIT = /,/; +var FN_ARG = /(=.+)?(\s*)$/; +var STRIP_COMMENTS = /((\/\/.*$)|(\/\*[\s\S]*?\*\/))/mg; + +function parseParams(func) { + func = func.toString().replace(STRIP_COMMENTS, ''); + func = func.match(FN_ARGS)[2].replace(' ', ''); + func = func ? func.split(FN_ARG_SPLIT) : []; + func = func.map(function (arg) { + return (0, _trim2.default)(arg.replace(FN_ARG, '')); + }); + return func; +} + +/** + * A dependency-injected version of the [async.auto]{@link module:ControlFlow.auto} function. Dependent + * tasks are specified as parameters to the function, after the usual callback + * parameter, with the parameter names matching the names of the tasks it + * depends on. This can provide even more readable task graphs which can be + * easier to maintain. + * + * If a final callback is specified, the task results are similarly injected, + * specified as named parameters after the initial error parameter. + * + * The autoInject function is purely syntactic sugar and its semantics are + * otherwise equivalent to [async.auto]{@link module:ControlFlow.auto}. + * + * @name autoInject + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.auto]{@link module:ControlFlow.auto} + * @category Control Flow + * @param {Object} tasks - An object, each of whose properties is a function of + * the form 'func([dependencies...], callback). The object's key of a property + * serves as the name of the task defined by that property, i.e. can be used + * when specifying requirements for other tasks. + * * The `callback` parameter is a `callback(err, result)` which must be called + * when finished, passing an `error` (which can be `null`) and the result of + * the function's execution. The remaining parameters name other tasks on + * which the task is dependent, and the results from those tasks are the + * arguments of those parameters. + * @param {Function} [callback] - An optional callback which is called when all + * the tasks have been completed. It receives the `err` argument if any `tasks` + * pass an error to their callback, and a `results` object with any completed + * task results, similar to `auto`. + * @example + * + * // The example from `auto` can be rewritten as follows: + * async.autoInject({ + * get_data: function(callback) { + * // async code to get some data + * callback(null, 'data', 'converted to array'); + * }, + * make_folder: function(callback) { + * // async code to create a directory to store a file in + * // this is run at the same time as getting the data + * callback(null, 'folder'); + * }, + * write_file: function(get_data, make_folder, callback) { + * // once there is some data and the directory exists, + * // write the data to a file in the directory + * callback(null, 'filename'); + * }, + * email_link: function(write_file, callback) { + * // once the file is written let's email a link to it... + * // write_file contains the filename returned by write_file. + * callback(null, {'file':write_file, 'email':'user@example.com'}); + * } + * }, function(err, results) { + * console.log('err = ', err); + * console.log('email_link = ', results.email_link); + * }); + * + * // If you are using a JS minifier that mangles parameter names, `autoInject` + * // will not work with plain functions, since the parameter names will be + * // collapsed to a single letter identifier. To work around this, you can + * // explicitly specify the names of the parameters your task function needs + * // in an array, similar to Angular.js dependency injection. + * + * // This still has an advantage over plain `auto`, since the results a task + * // depends on are still spread into arguments. + * async.autoInject({ + * //... + * write_file: ['get_data', 'make_folder', function(get_data, make_folder, callback) { + * callback(null, 'filename'); + * }], + * email_link: ['write_file', function(write_file, callback) { + * callback(null, {'file':write_file, 'email':'user@example.com'}); + * }] + * //... + * }, function(err, results) { + * console.log('err = ', err); + * console.log('email_link = ', results.email_link); + * }); + */ +function autoInject(tasks, callback) { + var newTasks = {}; + + (0, _baseForOwn2.default)(tasks, function (taskFn, key) { + var params; + + if ((0, _isArray2.default)(taskFn)) { + params = (0, _copyArray2.default)(taskFn); + taskFn = params.pop(); + + newTasks[key] = params.concat(params.length > 0 ? newTask : taskFn); + } else if (taskFn.length === 1) { + // no dependencies, use the function as-is + newTasks[key] = taskFn; + } else { + params = parseParams(taskFn); + if (taskFn.length === 0 && params.length === 0) { + throw new Error("autoInject task functions require explicit parameters."); + } + + params.pop(); + + newTasks[key] = params.concat(newTask); + } + + function newTask(results, taskCb) { + var newArgs = (0, _arrayMap2.default)(params, function (name) { + return results[name]; + }); + newArgs.push(taskCb); + taskFn.apply(null, newArgs); + } + }); + + (0, _auto2.default)(newTasks, callback); +} +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/bower.json b/node_modules/mongoose/node_modules/async/bower.json new file mode 100644 index 0000000..7dbeb14 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/bower.json @@ -0,0 +1,17 @@ +{ + "name": "async", + "main": "dist/async.js", + "ignore": [ + "bower_components", + "lib", + "mocha_test", + "node_modules", + "perf", + "support", + "**/.*", + "*.config.js", + "*.json", + "index.js", + "Makefile" + ] +} diff --git a/node_modules/mongoose/node_modules/async/cargo.js b/node_modules/mongoose/node_modules/async/cargo.js new file mode 100644 index 0000000..70e71a2 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/cargo.js @@ -0,0 +1,95 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = cargo; + +var _queue = require('./internal/queue'); + +var _queue2 = _interopRequireDefault(_queue); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * A cargo of tasks for the worker function to complete. Cargo inherits all of + * the same methods and event callbacks as [`queue`]{@link module:ControlFlow.queue}. + * @typedef {Object} CargoObject + * @memberOf module:ControlFlow + * @property {Function} length - A function returning the number of items + * waiting to be processed. Invoke like `cargo.length()`. + * @property {number} payload - An `integer` for determining how many tasks + * should be process per round. This property can be changed after a `cargo` is + * created to alter the payload on-the-fly. + * @property {Function} push - Adds `task` to the `queue`. The callback is + * called once the `worker` has finished processing the task. Instead of a + * single task, an array of `tasks` can be submitted. The respective callback is + * used for every task in the list. Invoke like `cargo.push(task, [callback])`. + * @property {Function} saturated - A callback that is called when the + * `queue.length()` hits the concurrency and further tasks will be queued. + * @property {Function} empty - A callback that is called when the last item + * from the `queue` is given to a `worker`. + * @property {Function} drain - A callback that is called when the last item + * from the `queue` has returned from the `worker`. + * @property {Function} idle - a function returning false if there are items + * waiting or being processed, or true if not. Invoke like `cargo.idle()`. + * @property {Function} pause - a function that pauses the processing of tasks + * until `resume()` is called. Invoke like `cargo.pause()`. + * @property {Function} resume - a function that resumes the processing of + * queued tasks when the queue is paused. Invoke like `cargo.resume()`. + * @property {Function} kill - a function that removes the `drain` callback and + * empties remaining tasks from the queue forcing it to go idle. Invoke like `cargo.kill()`. + */ + +/** + * Creates a `cargo` object with the specified payload. Tasks added to the + * cargo will be processed altogether (up to the `payload` limit). If the + * `worker` is in progress, the task is queued until it becomes available. Once + * the `worker` has completed some tasks, each callback of those tasks is + * called. Check out [these](https://camo.githubusercontent.com/6bbd36f4cf5b35a0f11a96dcd2e97711ffc2fb37/68747470733a2f2f662e636c6f75642e6769746875622e636f6d2f6173736574732f313637363837312f36383130382f62626330636662302d356632392d313165322d393734662d3333393763363464633835382e676966) [animations](https://camo.githubusercontent.com/f4810e00e1c5f5f8addbe3e9f49064fd5d102699/68747470733a2f2f662e636c6f75642e6769746875622e636f6d2f6173736574732f313637363837312f36383130312f38346339323036362d356632392d313165322d383134662d3964336430323431336266642e676966) + * for how `cargo` and `queue` work. + * + * While [`queue`]{@link module:ControlFlow.queue} passes only one task to one of a group of workers + * at a time, cargo passes an array of tasks to a single worker, repeating + * when the worker is finished. + * + * @name cargo + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.queue]{@link module:ControlFlow.queue} + * @category Control Flow + * @param {Function} worker - An asynchronous function for processing an array + * of queued tasks, which must call its `callback(err)` argument when finished, + * with an optional `err` argument. Invoked with `(tasks, callback)`. + * @param {number} [payload=Infinity] - An optional `integer` for determining + * how many tasks should be processed per round; if omitted, the default is + * unlimited. + * @returns {module:ControlFlow.CargoObject} A cargo object to manage the tasks. Callbacks can + * attached as certain properties to listen for specific events during the + * lifecycle of the cargo and inner queue. + * @example + * + * // create a cargo object with payload 2 + * var cargo = async.cargo(function(tasks, callback) { + * for (var i=0; i async.dir(hello, 'world'); + * {hello: 'world'} + */ +exports.default = (0, _consoleFunc2.default)('dir'); +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/dist/async.js b/node_modules/mongoose/node_modules/async/dist/async.js new file mode 100644 index 0000000..609d9cd --- /dev/null +++ b/node_modules/mongoose/node_modules/async/dist/async.js @@ -0,0 +1,5215 @@ +(function (global, factory) { + typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports) : + typeof define === 'function' && define.amd ? define(['exports'], factory) : + (factory((global.async = global.async || {}))); +}(this, function (exports) { 'use strict'; + + /** + * A faster alternative to `Function#apply`, this function invokes `func` + * with the `this` binding of `thisArg` and the arguments of `args`. + * + * @private + * @param {Function} func The function to invoke. + * @param {*} thisArg The `this` binding of `func`. + * @param {Array} args The arguments to invoke `func` with. + * @returns {*} Returns the result of `func`. + */ + function apply(func, thisArg, args) { + var length = args.length; + switch (length) { + case 0: return func.call(thisArg); + case 1: return func.call(thisArg, args[0]); + case 2: return func.call(thisArg, args[0], args[1]); + case 3: return func.call(thisArg, args[0], args[1], args[2]); + } + return func.apply(thisArg, args); + } + + /** + * Checks if `value` is the + * [language type](http://www.ecma-international.org/ecma-262/6.0/#sec-ecmascript-language-types) + * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`) + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is an object, else `false`. + * @example + * + * _.isObject({}); + * // => true + * + * _.isObject([1, 2, 3]); + * // => true + * + * _.isObject(_.noop); + * // => true + * + * _.isObject(null); + * // => false + */ + function isObject(value) { + var type = typeof value; + return !!value && (type == 'object' || type == 'function'); + } + + var funcTag = '[object Function]'; + var genTag = '[object GeneratorFunction]'; + /** Used for built-in method references. */ + var objectProto = Object.prototype; + + /** + * Used to resolve the + * [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring) + * of values. + */ + var objectToString = objectProto.toString; + + /** + * Checks if `value` is classified as a `Function` object. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is correctly classified, + * else `false`. + * @example + * + * _.isFunction(_); + * // => true + * + * _.isFunction(/abc/); + * // => false + */ + function isFunction(value) { + // The use of `Object#toString` avoids issues with the `typeof` operator + // in Safari 8 which returns 'object' for typed array and weak map constructors, + // and PhantomJS 1.9 which returns 'function' for `NodeList` instances. + var tag = isObject(value) ? objectToString.call(value) : ''; + return tag == funcTag || tag == genTag; + } + + /** + * Checks if `value` is object-like. A value is object-like if it's not `null` + * and has a `typeof` result of "object". + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is object-like, else `false`. + * @example + * + * _.isObjectLike({}); + * // => true + * + * _.isObjectLike([1, 2, 3]); + * // => true + * + * _.isObjectLike(_.noop); + * // => false + * + * _.isObjectLike(null); + * // => false + */ + function isObjectLike(value) { + return !!value && typeof value == 'object'; + } + + /** `Object#toString` result references. */ + var symbolTag = '[object Symbol]'; + + /** Used for built-in method references. */ + var objectProto$1 = Object.prototype; + + /** + * Used to resolve the + * [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring) + * of values. + */ + var objectToString$1 = objectProto$1.toString; + + /** + * Checks if `value` is classified as a `Symbol` primitive or object. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is correctly classified, + * else `false`. + * @example + * + * _.isSymbol(Symbol.iterator); + * // => true + * + * _.isSymbol('abc'); + * // => false + */ + function isSymbol(value) { + return typeof value == 'symbol' || + (isObjectLike(value) && objectToString$1.call(value) == symbolTag); + } + + /** Used as references for various `Number` constants. */ + var NAN = 0 / 0; + + /** Used to match leading and trailing whitespace. */ + var reTrim = /^\s+|\s+$/g; + + /** Used to detect bad signed hexadecimal string values. */ + var reIsBadHex = /^[-+]0x[0-9a-f]+$/i; + + /** Used to detect binary string values. */ + var reIsBinary = /^0b[01]+$/i; + + /** Used to detect octal string values. */ + var reIsOctal = /^0o[0-7]+$/i; + + /** Built-in method references without a dependency on `root`. */ + var freeParseInt = parseInt; + + /** + * Converts `value` to a number. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to process. + * @returns {number} Returns the number. + * @example + * + * _.toNumber(3.2); + * // => 3.2 + * + * _.toNumber(Number.MIN_VALUE); + * // => 5e-324 + * + * _.toNumber(Infinity); + * // => Infinity + * + * _.toNumber('3.2'); + * // => 3.2 + */ + function toNumber(value) { + if (typeof value == 'number') { + return value; + } + if (isSymbol(value)) { + return NAN; + } + if (isObject(value)) { + var other = isFunction(value.valueOf) ? value.valueOf() : value; + value = isObject(other) ? (other + '') : other; + } + if (typeof value != 'string') { + return value === 0 ? value : +value; + } + value = value.replace(reTrim, ''); + var isBinary = reIsBinary.test(value); + return (isBinary || reIsOctal.test(value)) + ? freeParseInt(value.slice(2), isBinary ? 2 : 8) + : (reIsBadHex.test(value) ? NAN : +value); + } + + var INFINITY = 1 / 0; + var MAX_INTEGER = 1.7976931348623157e+308; + /** + * Converts `value` to a finite number. + * + * @static + * @memberOf _ + * @since 4.12.0 + * @category Lang + * @param {*} value The value to convert. + * @returns {number} Returns the converted number. + * @example + * + * _.toFinite(3.2); + * // => 3.2 + * + * _.toFinite(Number.MIN_VALUE); + * // => 5e-324 + * + * _.toFinite(Infinity); + * // => 1.7976931348623157e+308 + * + * _.toFinite('3.2'); + * // => 3.2 + */ + function toFinite(value) { + if (!value) { + return value === 0 ? value : 0; + } + value = toNumber(value); + if (value === INFINITY || value === -INFINITY) { + var sign = (value < 0 ? -1 : 1); + return sign * MAX_INTEGER; + } + return value === value ? value : 0; + } + + /** + * Converts `value` to an integer. + * + * **Note:** This method is loosely based on + * [`ToInteger`](http://www.ecma-international.org/ecma-262/6.0/#sec-tointeger). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to convert. + * @returns {number} Returns the converted integer. + * @example + * + * _.toInteger(3.2); + * // => 3 + * + * _.toInteger(Number.MIN_VALUE); + * // => 0 + * + * _.toInteger(Infinity); + * // => 1.7976931348623157e+308 + * + * _.toInteger('3.2'); + * // => 3 + */ + function toInteger(value) { + var result = toFinite(value), + remainder = result % 1; + + return result === result ? (remainder ? result - remainder : result) : 0; + } + + /** Used as the `TypeError` message for "Functions" methods. */ + var FUNC_ERROR_TEXT = 'Expected a function'; + + /* Built-in method references for those with the same name as other `lodash` methods. */ + var nativeMax = Math.max; + + /** + * Creates a function that invokes `func` with the `this` binding of the + * created function and arguments from `start` and beyond provided as + * an array. + * + * **Note:** This method is based on the + * [rest parameter](https://mdn.io/rest_parameters). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Function + * @param {Function} func The function to apply a rest parameter to. + * @param {number} [start=func.length-1] The start position of the rest parameter. + * @returns {Function} Returns the new function. + * @example + * + * var say = _.rest(function(what, names) { + * return what + ' ' + _.initial(names).join(', ') + + * (_.size(names) > 1 ? ', & ' : '') + _.last(names); + * }); + * + * say('hello', 'fred', 'barney', 'pebbles'); + * // => 'hello fred, barney, & pebbles' + */ + function rest(func, start) { + if (typeof func != 'function') { + throw new TypeError(FUNC_ERROR_TEXT); + } + start = nativeMax(start === undefined ? (func.length - 1) : toInteger(start), 0); + return function() { + var args = arguments, + index = -1, + length = nativeMax(args.length - start, 0), + array = Array(length); + + while (++index < length) { + array[index] = args[start + index]; + } + switch (start) { + case 0: return func.call(this, array); + case 1: return func.call(this, args[0], array); + case 2: return func.call(this, args[0], args[1], array); + } + var otherArgs = Array(start + 1); + index = -1; + while (++index < start) { + otherArgs[index] = args[index]; + } + otherArgs[start] = array; + return apply(func, this, otherArgs); + }; + } + + function initialParams (fn) { + return rest(function (args /*..., callback*/) { + var callback = args.pop(); + fn.call(this, args, callback); + }); + } + + function applyEach$1(eachfn) { + return rest(function (fns, args) { + var go = initialParams(function (args, callback) { + var that = this; + return eachfn(fns, function (fn, cb) { + fn.apply(that, args.concat([cb])); + }, callback); + }); + if (args.length) { + return go.apply(this, args); + } else { + return go; + } + }); + } + + /** + * The base implementation of `_.property` without support for deep paths. + * + * @private + * @param {string} key The key of the property to get. + * @returns {Function} Returns the new accessor function. + */ + function baseProperty(key) { + return function(object) { + return object == null ? undefined : object[key]; + }; + } + + /** + * Gets the "length" property value of `object`. + * + * **Note:** This function is used to avoid a + * [JIT bug](https://bugs.webkit.org/show_bug.cgi?id=142792) that affects + * Safari on at least iOS 8.1-8.3 ARM64. + * + * @private + * @param {Object} object The object to query. + * @returns {*} Returns the "length" value. + */ + var getLength = baseProperty('length'); + + /** Used as references for various `Number` constants. */ + var MAX_SAFE_INTEGER = 9007199254740991; + + /** + * Checks if `value` is a valid array-like length. + * + * **Note:** This function is loosely based on + * [`ToLength`](http://ecma-international.org/ecma-262/6.0/#sec-tolength). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a valid length, + * else `false`. + * @example + * + * _.isLength(3); + * // => true + * + * _.isLength(Number.MIN_VALUE); + * // => false + * + * _.isLength(Infinity); + * // => false + * + * _.isLength('3'); + * // => false + */ + function isLength(value) { + return typeof value == 'number' && + value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER; + } + + /** + * Checks if `value` is array-like. A value is considered array-like if it's + * not a function and has a `value.length` that's an integer greater than or + * equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is array-like, else `false`. + * @example + * + * _.isArrayLike([1, 2, 3]); + * // => true + * + * _.isArrayLike(document.body.children); + * // => true + * + * _.isArrayLike('abc'); + * // => true + * + * _.isArrayLike(_.noop); + * // => false + */ + function isArrayLike(value) { + return value != null && isLength(getLength(value)) && !isFunction(value); + } + + /** + * A method that returns `undefined`. + * + * @static + * @memberOf _ + * @since 2.3.0 + * @category Util + * @example + * + * _.times(2, _.noop); + * // => [undefined, undefined] + */ + function noop() { + // No operation performed. + } + + function once(fn) { + return function () { + if (fn === null) return; + var callFn = fn; + fn = null; + callFn.apply(this, arguments); + }; + } + + var iteratorSymbol = typeof Symbol === 'function' && Symbol.iterator; + + function getIterator (coll) { + return iteratorSymbol && coll[iteratorSymbol] && coll[iteratorSymbol](); + } + + /* Built-in method references for those with the same name as other `lodash` methods. */ + var nativeGetPrototype = Object.getPrototypeOf; + + /** + * Gets the `[[Prototype]]` of `value`. + * + * @private + * @param {*} value The value to query. + * @returns {null|Object} Returns the `[[Prototype]]`. + */ + function getPrototype(value) { + return nativeGetPrototype(Object(value)); + } + + /** Used for built-in method references. */ + var objectProto$2 = Object.prototype; + + /** Used to check objects for own properties. */ + var hasOwnProperty = objectProto$2.hasOwnProperty; + + /** + * The base implementation of `_.has` without support for deep paths. + * + * @private + * @param {Object} [object] The object to query. + * @param {Array|string} key The key to check. + * @returns {boolean} Returns `true` if `key` exists, else `false`. + */ + function baseHas(object, key) { + // Avoid a bug in IE 10-11 where objects with a [[Prototype]] of `null`, + // that are composed entirely of index properties, return `false` for + // `hasOwnProperty` checks of them. + return object != null && + (hasOwnProperty.call(object, key) || + (typeof object == 'object' && key in object && getPrototype(object) === null)); + } + + /* Built-in method references for those with the same name as other `lodash` methods. */ + var nativeKeys = Object.keys; + + /** + * The base implementation of `_.keys` which doesn't skip the constructor + * property of prototypes or treat sparse arrays as dense. + * + * @private + * @param {Object} object The object to query. + * @returns {Array} Returns the array of property names. + */ + function baseKeys(object) { + return nativeKeys(Object(object)); + } + + /** + * The base implementation of `_.times` without support for iteratee shorthands + * or max array length checks. + * + * @private + * @param {number} n The number of times to invoke `iteratee`. + * @param {Function} iteratee The function invoked per iteration. + * @returns {Array} Returns the array of results. + */ + function baseTimes(n, iteratee) { + var index = -1, + result = Array(n); + + while (++index < n) { + result[index] = iteratee(index); + } + return result; + } + + /** + * This method is like `_.isArrayLike` except that it also checks if `value` + * is an object. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is an array-like object, + * else `false`. + * @example + * + * _.isArrayLikeObject([1, 2, 3]); + * // => true + * + * _.isArrayLikeObject(document.body.children); + * // => true + * + * _.isArrayLikeObject('abc'); + * // => false + * + * _.isArrayLikeObject(_.noop); + * // => false + */ + function isArrayLikeObject(value) { + return isObjectLike(value) && isArrayLike(value); + } + + /** `Object#toString` result references. */ + var argsTag = '[object Arguments]'; + + /** Used for built-in method references. */ + var objectProto$3 = Object.prototype; + + /** Used to check objects for own properties. */ + var hasOwnProperty$1 = objectProto$3.hasOwnProperty; + + /** + * Used to resolve the + * [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring) + * of values. + */ + var objectToString$2 = objectProto$3.toString; + + /** Built-in value references. */ + var propertyIsEnumerable = objectProto$3.propertyIsEnumerable; + + /** + * Checks if `value` is likely an `arguments` object. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is correctly classified, + * else `false`. + * @example + * + * _.isArguments(function() { return arguments; }()); + * // => true + * + * _.isArguments([1, 2, 3]); + * // => false + */ + function isArguments(value) { + // Safari 8.1 incorrectly makes `arguments.callee` enumerable in strict mode. + return isArrayLikeObject(value) && hasOwnProperty$1.call(value, 'callee') && + (!propertyIsEnumerable.call(value, 'callee') || objectToString$2.call(value) == argsTag); + } + + /** + * Checks if `value` is classified as an `Array` object. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @type {Function} + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is correctly classified, + * else `false`. + * @example + * + * _.isArray([1, 2, 3]); + * // => true + * + * _.isArray(document.body.children); + * // => false + * + * _.isArray('abc'); + * // => false + * + * _.isArray(_.noop); + * // => false + */ + var isArray = Array.isArray; + + /** `Object#toString` result references. */ + var stringTag = '[object String]'; + + /** Used for built-in method references. */ + var objectProto$4 = Object.prototype; + + /** + * Used to resolve the + * [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring) + * of values. + */ + var objectToString$3 = objectProto$4.toString; + + /** + * Checks if `value` is classified as a `String` primitive or object. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is correctly classified, + * else `false`. + * @example + * + * _.isString('abc'); + * // => true + * + * _.isString(1); + * // => false + */ + function isString(value) { + return typeof value == 'string' || + (!isArray(value) && isObjectLike(value) && objectToString$3.call(value) == stringTag); + } + + /** + * Creates an array of index keys for `object` values of arrays, + * `arguments` objects, and strings, otherwise `null` is returned. + * + * @private + * @param {Object} object The object to query. + * @returns {Array|null} Returns index keys, else `null`. + */ + function indexKeys(object) { + var length = object ? object.length : undefined; + if (isLength(length) && + (isArray(object) || isString(object) || isArguments(object))) { + return baseTimes(length, String); + } + return null; + } + + /** Used as references for various `Number` constants. */ + var MAX_SAFE_INTEGER$1 = 9007199254740991; + + /** Used to detect unsigned integer values. */ + var reIsUint = /^(?:0|[1-9]\d*)$/; + + /** + * Checks if `value` is a valid array-like index. + * + * @private + * @param {*} value The value to check. + * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index. + * @returns {boolean} Returns `true` if `value` is a valid index, else `false`. + */ + function isIndex(value, length) { + length = length == null ? MAX_SAFE_INTEGER$1 : length; + return !!length && + (typeof value == 'number' || reIsUint.test(value)) && + (value > -1 && value % 1 == 0 && value < length); + } + + /** Used for built-in method references. */ + var objectProto$5 = Object.prototype; + + /** + * Checks if `value` is likely a prototype object. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a prototype, else `false`. + */ + function isPrototype(value) { + var Ctor = value && value.constructor, + proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto$5; + + return value === proto; + } + + /** + * Creates an array of the own enumerable property names of `object`. + * + * **Note:** Non-object values are coerced to objects. See the + * [ES spec](http://ecma-international.org/ecma-262/6.0/#sec-object.keys) + * for more details. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Object + * @param {Object} object The object to query. + * @returns {Array} Returns the array of property names. + * @example + * + * function Foo() { + * this.a = 1; + * this.b = 2; + * } + * + * Foo.prototype.c = 3; + * + * _.keys(new Foo); + * // => ['a', 'b'] (iteration order is not guaranteed) + * + * _.keys('hi'); + * // => ['0', '1'] + */ + function keys(object) { + var isProto = isPrototype(object); + if (!(isProto || isArrayLike(object))) { + return baseKeys(object); + } + var indexes = indexKeys(object), + skipIndexes = !!indexes, + result = indexes || [], + length = result.length; + + for (var key in object) { + if (baseHas(object, key) && + !(skipIndexes && (key == 'length' || isIndex(key, length))) && + !(isProto && key == 'constructor')) { + result.push(key); + } + } + return result; + } + + function createArrayIterator(coll) { + var i = -1; + var len = coll.length; + return function next() { + return ++i < len ? { value: coll[i], key: i } : null; + }; + } + + function createES2015Iterator(iterator) { + var i = -1; + return function next() { + var item = iterator.next(); + if (item.done) return null; + i++; + return { value: item.value, key: i }; + }; + } + + function createObjectIterator(obj) { + var okeys = keys(obj); + var i = -1; + var len = okeys.length; + return function next() { + var key = okeys[++i]; + return i < len ? { value: obj[key], key: key } : null; + }; + } + + function iterator(coll) { + if (isArrayLike(coll)) { + return createArrayIterator(coll); + } + + var iterator = getIterator(coll); + return iterator ? createES2015Iterator(iterator) : createObjectIterator(coll); + } + + function onlyOnce(fn) { + return function () { + if (fn === null) throw new Error("Callback was already called."); + var callFn = fn; + fn = null; + callFn.apply(this, arguments); + }; + } + + function _eachOfLimit(limit) { + return function (obj, iteratee, callback) { + callback = once(callback || noop); + if (limit <= 0 || !obj) { + return callback(null); + } + var nextElem = iterator(obj); + var done = false; + var running = 0; + + function iterateeCallback(err) { + running -= 1; + if (err) { + done = true; + callback(err); + } else if (done && running <= 0) { + return callback(null); + } else { + replenish(); + } + } + + function replenish() { + while (running < limit && !done) { + var elem = nextElem(); + if (elem === null) { + done = true; + if (running <= 0) { + callback(null); + } + return; + } + running += 1; + iteratee(elem.value, elem.key, onlyOnce(iterateeCallback)); + } + } + + replenish(); + }; + } + + /** + * The same as [`eachOf`]{@link module:Collections.eachOf} but runs a maximum of `limit` async operations at a + * time. + * + * @name eachOfLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.eachOf]{@link module:Collections.eachOf} + * @alias forEachOfLimit + * @category Collection + * @param {Array|Iterable|Object} coll - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {Function} iteratee - A function to apply to each + * item in `coll`. The `key` is the item's key, or index in the case of an + * array. The iteratee is passed a `callback(err)` which must be called once it + * has completed. If no error has occurred, the callback should be run without + * arguments or with an explicit `null` argument. Invoked with + * (item, key, callback). + * @param {Function} [callback] - A callback which is called when all + * `iteratee` functions have finished, or an error occurs. Invoked with (err). + */ + function eachOfLimit(coll, limit, iteratee, callback) { + _eachOfLimit(limit)(coll, iteratee, callback); + } + + function doLimit(fn, limit) { + return function (iterable, iteratee, callback) { + return fn(iterable, limit, iteratee, callback); + }; + } + + /** Used as the `TypeError` message for "Functions" methods. */ + var FUNC_ERROR_TEXT$1 = 'Expected a function'; + + /** + * Creates a function that invokes `func`, with the `this` binding and arguments + * of the created function, while it's called less than `n` times. Subsequent + * calls to the created function return the result of the last `func` invocation. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Function + * @param {number} n The number of calls at which `func` is no longer invoked. + * @param {Function} func The function to restrict. + * @returns {Function} Returns the new restricted function. + * @example + * + * jQuery(element).on('click', _.before(5, addContactToList)); + * // => allows adding up to 4 contacts to the list + */ + function before(n, func) { + var result; + if (typeof func != 'function') { + throw new TypeError(FUNC_ERROR_TEXT$1); + } + n = toInteger(n); + return function() { + if (--n > 0) { + result = func.apply(this, arguments); + } + if (n <= 1) { + func = undefined; + } + return result; + }; + } + + /** + * Creates a function that is restricted to invoking `func` once. Repeat calls + * to the function return the value of the first invocation. The `func` is + * invoked with the `this` binding and arguments of the created function. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Function + * @param {Function} func The function to restrict. + * @returns {Function} Returns the new restricted function. + * @example + * + * var initialize = _.once(createApplication); + * initialize(); + * initialize(); + * // `initialize` invokes `createApplication` once + */ + function once$1(func) { + return before(2, func); + } + + // eachOf implementation optimized for array-likes + function eachOfArrayLike(coll, iteratee, callback) { + callback = once$1(callback || noop); + var index = 0, + completed = 0, + length = coll.length; + if (length === 0) { + callback(null); + } + + function iteratorCallback(err) { + if (err) { + callback(err); + } else if (++completed === length) { + callback(null); + } + } + + for (; index < length; index++) { + iteratee(coll[index], index, onlyOnce(iteratorCallback)); + } + } + + // a generic version of eachOf which can handle array, object, and iterator cases. + var eachOfGeneric = doLimit(eachOfLimit, Infinity); + + /** + * Like [`each`]{@link module:Collections.each}, except that it passes the key (or index) as the second argument + * to the iteratee. + * + * @name eachOf + * @static + * @memberOf module:Collections + * @method + * @alias forEachOf + * @category Collection + * @see [async.each]{@link module:Collections.each} + * @param {Array|Iterable|Object} coll - A collection to iterate over. + * @param {Function} iteratee - A function to apply to each + * item in `coll`. The `key` is the item's key, or index in the case of an + * array. The iteratee is passed a `callback(err)` which must be called once it + * has completed. If no error has occurred, the callback should be run without + * arguments or with an explicit `null` argument. Invoked with + * (item, key, callback). + * @param {Function} [callback] - A callback which is called when all + * `iteratee` functions have finished, or an error occurs. Invoked with (err). + * @example + * + * var obj = {dev: "/dev.json", test: "/test.json", prod: "/prod.json"}; + * var configs = {}; + * + * async.forEachOf(obj, function (value, key, callback) { + * fs.readFile(__dirname + value, "utf8", function (err, data) { + * if (err) return callback(err); + * try { + * configs[key] = JSON.parse(data); + * } catch (e) { + * return callback(e); + * } + * callback(); + * }); + * }, function (err) { + * if (err) console.error(err.message); + * // configs is now a map of JSON data + * doSomethingWith(configs); + * }); + */ + function eachOf (coll, iteratee, callback) { + var eachOfImplementation = isArrayLike(coll) ? eachOfArrayLike : eachOfGeneric; + eachOfImplementation(coll, iteratee, callback); + } + + function doParallel(fn) { + return function (obj, iteratee, callback) { + return fn(eachOf, obj, iteratee, callback); + }; + } + + function _asyncMap(eachfn, arr, iteratee, callback) { + callback = once(callback || noop); + arr = arr || []; + var results = []; + var counter = 0; + + eachfn(arr, function (value, _, callback) { + var index = counter++; + iteratee(value, function (err, v) { + results[index] = v; + callback(err); + }); + }, function (err) { + callback(err, results); + }); + } + + /** + * Produces a new collection of values by mapping each value in `coll` through + * the `iteratee` function. The `iteratee` is called with an item from `coll` + * and a callback for when it has finished processing. Each of these callback + * takes 2 arguments: an `error`, and the transformed item from `coll`. If + * `iteratee` passes an error to its callback, the main `callback` (for the + * `map` function) is immediately called with the error. + * + * Note, that since this function applies the `iteratee` to each item in + * parallel, there is no guarantee that the `iteratee` functions will complete + * in order. However, the results array will be in the same order as the + * original `coll`. + * + * If `map` is passed an Object, the results will be an Array. The results + * will roughly be in the order of the original Objects' keys (but this can + * vary across JavaScript engines) + * + * @name map + * @static + * @memberOf module:Collections + * @method + * @category Collection + * @param {Array|Iterable|Object} coll - A collection to iterate over. + * @param {Function} iteratee - A function to apply to each item in `coll`. + * The iteratee is passed a `callback(err, transformed)` which must be called + * once it has completed with an error (which can be `null`) and a + * transformed item. Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called when all `iteratee` + * functions have finished, or an error occurs. Results is an Array of the + * transformed items from the `coll`. Invoked with (err, results). + * @example + * + * async.map(['file1','file2','file3'], fs.stat, function(err, results) { + * // results is now an array of stats for each file + * }); + */ + var map = doParallel(_asyncMap); + + /** + * Applies the provided arguments to each function in the array, calling + * `callback` after all functions have completed. If you only provide the first + * argument, then it will return a function which lets you pass in the + * arguments as if it were a single function call. + * + * @name applyEach + * @static + * @memberOf module:ControlFlow + * @method + * @category Control Flow + * @param {Array|Iterable|Object} fns - A collection of asynchronous functions to all + * call with the same arguments + * @param {...*} [args] - any number of separate arguments to pass to the + * function. + * @param {Function} [callback] - the final argument should be the callback, + * called when all functions have completed processing. + * @returns {Function} - If only the first argument is provided, it will return + * a function which lets you pass in the arguments as if it were a single + * function call. + * @example + * + * async.applyEach([enableSearch, updateSchema], 'bucket', callback); + * + * // partial application example: + * async.each( + * buckets, + * async.applyEach([enableSearch, updateSchema]), + * callback + * ); + */ + var applyEach = applyEach$1(map); + + function doParallelLimit(fn) { + return function (obj, limit, iteratee, callback) { + return fn(_eachOfLimit(limit), obj, iteratee, callback); + }; + } + + /** + * The same as [`map`]{@link module:Collections.map} but runs a maximum of `limit` async operations at a time. + * + * @name mapLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.map]{@link module:Collections.map} + * @category Collection + * @param {Array|Iterable|Object} coll - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {Function} iteratee - A function to apply to each item in `coll`. + * The iteratee is passed a `callback(err, transformed)` which must be called + * once it has completed with an error (which can be `null`) and a transformed + * item. Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called when all `iteratee` + * functions have finished, or an error occurs. Results is an array of the + * transformed items from the `coll`. Invoked with (err, results). + */ + var mapLimit = doParallelLimit(_asyncMap); + + /** + * The same as [`map`]{@link module:Collections.map} but runs only a single async operation at a time. + * + * @name mapSeries + * @static + * @memberOf module:Collections + * @method + * @see [async.map]{@link module:Collections.map} + * @category Collection + * @param {Array|Iterable|Object} coll - A collection to iterate over. + * @param {Function} iteratee - A function to apply to each item in `coll`. + * The iteratee is passed a `callback(err, transformed)` which must be called + * once it has completed with an error (which can be `null`) and a + * transformed item. Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called when all `iteratee` + * functions have finished, or an error occurs. Results is an array of the + * transformed items from the `coll`. Invoked with (err, results). + */ + var mapSeries = doLimit(mapLimit, 1); + + /** + * The same as [`applyEach`]{@link module:ControlFlow.applyEach} but runs only a single async operation at a time. + * + * @name applyEachSeries + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.applyEach]{@link module:ControlFlow.applyEach} + * @category Control Flow + * @param {Array|Iterable|Object} fns - A collection of asynchronous functions to all + * call with the same arguments + * @param {...*} [args] - any number of separate arguments to pass to the + * function. + * @param {Function} [callback] - the final argument should be the callback, + * called when all functions have completed processing. + * @returns {Function} - If only the first argument is provided, it will return + * a function which lets you pass in the arguments as if it were a single + * function call. + */ + var applyEachSeries = applyEach$1(mapSeries); + + /** + * Creates a continuation function with some arguments already applied. + * + * Useful as a shorthand when combined with other control flow functions. Any + * arguments passed to the returned function are added to the arguments + * originally passed to apply. + * + * @name apply + * @static + * @memberOf module:Utils + * @method + * @category Util + * @param {Function} function - The function you want to eventually apply all + * arguments to. Invokes with (arguments...). + * @param {...*} arguments... - Any number of arguments to automatically apply + * when the continuation is called. + * @example + * + * // using apply + * async.parallel([ + * async.apply(fs.writeFile, 'testfile1', 'test1'), + * async.apply(fs.writeFile, 'testfile2', 'test2') + * ]); + * + * + * // the same process without using apply + * async.parallel([ + * function(callback) { + * fs.writeFile('testfile1', 'test1', callback); + * }, + * function(callback) { + * fs.writeFile('testfile2', 'test2', callback); + * } + * ]); + * + * // It's possible to pass any number of additional arguments when calling the + * // continuation: + * + * node> var fn = async.apply(sys.puts, 'one'); + * node> fn('two', 'three'); + * one + * two + * three + */ + var apply$1 = rest(function (fn, args) { + return rest(function (callArgs) { + return fn.apply(null, args.concat(callArgs)); + }); + }); + + /** + * Take a sync function and make it async, passing its return value to a + * callback. This is useful for plugging sync functions into a waterfall, + * series, or other async functions. Any arguments passed to the generated + * function will be passed to the wrapped function (except for the final + * callback argument). Errors thrown will be passed to the callback. + * + * If the function passed to `asyncify` returns a Promise, that promises's + * resolved/rejected state will be used to call the callback, rather than simply + * the synchronous return value. + * + * This also means you can asyncify ES2016 `async` functions. + * + * @name asyncify + * @static + * @memberOf module:Utils + * @method + * @alias wrapSync + * @category Util + * @param {Function} func - The synchronous function to convert to an + * asynchronous function. + * @returns {Function} An asynchronous wrapper of the `func`. To be invoked with + * (callback). + * @example + * + * // passing a regular synchronous function + * async.waterfall([ + * async.apply(fs.readFile, filename, "utf8"), + * async.asyncify(JSON.parse), + * function (data, next) { + * // data is the result of parsing the text. + * // If there was a parsing error, it would have been caught. + * } + * ], callback); + * + * // passing a function returning a promise + * async.waterfall([ + * async.apply(fs.readFile, filename, "utf8"), + * async.asyncify(function (contents) { + * return db.model.create(contents); + * }), + * function (model, next) { + * // `model` is the instantiated model object. + * // If there was an error, this function would be skipped. + * } + * ], callback); + * + * // es6 example + * var q = async.queue(async.asyncify(async function(file) { + * var intermediateStep = await processFile(file); + * return await somePromise(intermediateStep) + * })); + * + * q.push(files); + */ + function asyncify(func) { + return initialParams(function (args, callback) { + var result; + try { + result = func.apply(this, args); + } catch (e) { + return callback(e); + } + // if result is Promise object + if (isObject(result) && typeof result.then === 'function') { + result.then(function (value) { + callback(null, value); + }, function (err) { + callback(err.message ? err : new Error(err)); + }); + } else { + callback(null, result); + } + }); + } + + /** + * A specialized version of `_.forEach` for arrays without support for + * iteratee shorthands. + * + * @private + * @param {Array} [array] The array to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @returns {Array} Returns `array`. + */ + function arrayEach(array, iteratee) { + var index = -1, + length = array ? array.length : 0; + + while (++index < length) { + if (iteratee(array[index], index, array) === false) { + break; + } + } + return array; + } + + /** + * Creates a base function for methods like `_.forIn` and `_.forOwn`. + * + * @private + * @param {boolean} [fromRight] Specify iterating from right to left. + * @returns {Function} Returns the new base function. + */ + function createBaseFor(fromRight) { + return function(object, iteratee, keysFunc) { + var index = -1, + iterable = Object(object), + props = keysFunc(object), + length = props.length; + + while (length--) { + var key = props[fromRight ? length : ++index]; + if (iteratee(iterable[key], key, iterable) === false) { + break; + } + } + return object; + }; + } + + /** + * The base implementation of `baseForOwn` which iterates over `object` + * properties returned by `keysFunc` and invokes `iteratee` for each property. + * Iteratee functions may exit iteration early by explicitly returning `false`. + * + * @private + * @param {Object} object The object to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @param {Function} keysFunc The function to get the keys of `object`. + * @returns {Object} Returns `object`. + */ + var baseFor = createBaseFor(); + + /** + * The base implementation of `_.forOwn` without support for iteratee shorthands. + * + * @private + * @param {Object} object The object to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @returns {Object} Returns `object`. + */ + function baseForOwn(object, iteratee) { + return object && baseFor(object, iteratee, keys); + } + + /** + * Gets the index at which the first occurrence of `NaN` is found in `array`. + * + * @private + * @param {Array} array The array to search. + * @param {number} fromIndex The index to search from. + * @param {boolean} [fromRight] Specify iterating from right to left. + * @returns {number} Returns the index of the matched `NaN`, else `-1`. + */ + function indexOfNaN(array, fromIndex, fromRight) { + var length = array.length, + index = fromIndex + (fromRight ? 1 : -1); + + while ((fromRight ? index-- : ++index < length)) { + var other = array[index]; + if (other !== other) { + return index; + } + } + return -1; + } + + /** + * The base implementation of `_.indexOf` without `fromIndex` bounds checks. + * + * @private + * @param {Array} array The array to search. + * @param {*} value The value to search for. + * @param {number} fromIndex The index to search from. + * @returns {number} Returns the index of the matched value, else `-1`. + */ + function baseIndexOf(array, value, fromIndex) { + if (value !== value) { + return indexOfNaN(array, fromIndex); + } + var index = fromIndex - 1, + length = array.length; + + while (++index < length) { + if (array[index] === value) { + return index; + } + } + return -1; + } + + /** + * Determines the best order for running the functions in `tasks`, based on + * their requirements. Each function can optionally depend on other functions + * being completed first, and each function is run as soon as its requirements + * are satisfied. + * + * If any of the functions pass an error to their callback, the `auto` sequence + * will stop. Further tasks will not execute (so any other functions depending + * on it will not run), and the main `callback` is immediately called with the + * error. + * + * Functions also receive an object containing the results of functions which + * have completed so far as the first argument, if they have dependencies. If a + * task function has no dependencies, it will only be passed a callback. + * + * @name auto + * @static + * @memberOf module:ControlFlow + * @method + * @category Control Flow + * @param {Object} tasks - An object. Each of its properties is either a + * function or an array of requirements, with the function itself the last item + * in the array. The object's key of a property serves as the name of the task + * defined by that property, i.e. can be used when specifying requirements for + * other tasks. The function receives one or two arguments: + * * a `results` object, containing the results of the previously executed + * functions, only passed if the task has any dependencies, + * * a `callback(err, result)` function, which must be called when finished, + * passing an `error` (which can be `null`) and the result of the function's + * execution. + * @param {number} [concurrency=Infinity] - An optional `integer` for + * determining the maximum number of tasks that can be run in parallel. By + * default, as many as possible. + * @param {Function} [callback] - An optional callback which is called when all + * the tasks have been completed. It receives the `err` argument if any `tasks` + * pass an error to their callback. Results are always returned; however, if an + * error occurs, no further `tasks` will be performed, and the results object + * will only contain partial results. Invoked with (err, results). + * @returns undefined + * @example + * + * async.auto({ + * // this function will just be passed a callback + * readData: async.apply(fs.readFile, 'data.txt', 'utf-8'), + * showData: ['readData', function(results, cb) { + * // results.readData is the file's contents + * // ... + * }] + * }, callback); + * + * async.auto({ + * get_data: function(callback) { + * console.log('in get_data'); + * // async code to get some data + * callback(null, 'data', 'converted to array'); + * }, + * make_folder: function(callback) { + * console.log('in make_folder'); + * // async code to create a directory to store a file in + * // this is run at the same time as getting the data + * callback(null, 'folder'); + * }, + * write_file: ['get_data', 'make_folder', function(results, callback) { + * console.log('in write_file', JSON.stringify(results)); + * // once there is some data and the directory exists, + * // write the data to a file in the directory + * callback(null, 'filename'); + * }], + * email_link: ['write_file', function(results, callback) { + * console.log('in email_link', JSON.stringify(results)); + * // once the file is written let's email a link to it... + * // results.write_file contains the filename returned by write_file. + * callback(null, {'file':results.write_file, 'email':'user@example.com'}); + * }] + * }, function(err, results) { + * console.log('err = ', err); + * console.log('results = ', results); + * }); + */ + function auto (tasks, concurrency, callback) { + if (typeof concurrency === 'function') { + // concurrency is optional, shift the args. + callback = concurrency; + concurrency = null; + } + callback = once(callback || noop); + var keys$$ = keys(tasks); + var numTasks = keys$$.length; + if (!numTasks) { + return callback(null); + } + if (!concurrency) { + concurrency = numTasks; + } + + var results = {}; + var runningTasks = 0; + var hasError = false; + + var listeners = {}; + + var readyTasks = []; + + // for cycle detection: + var readyToCheck = []; // tasks that have been identified as reachable + // without the possibility of returning to an ancestor task + var uncheckedDependencies = {}; + + baseForOwn(tasks, function (task, key) { + if (!isArray(task)) { + // no dependencies + enqueueTask(key, [task]); + readyToCheck.push(key); + return; + } + + var dependencies = task.slice(0, task.length - 1); + var remainingDependencies = dependencies.length; + if (remainingDependencies === 0) { + enqueueTask(key, task); + readyToCheck.push(key); + return; + } + uncheckedDependencies[key] = remainingDependencies; + + arrayEach(dependencies, function (dependencyName) { + if (!tasks[dependencyName]) { + throw new Error('async.auto task `' + key + '` has a non-existent dependency in ' + dependencies.join(', ')); + } + addListener(dependencyName, function () { + remainingDependencies--; + if (remainingDependencies === 0) { + enqueueTask(key, task); + } + }); + }); + }); + + checkForDeadlocks(); + processQueue(); + + function enqueueTask(key, task) { + readyTasks.push(function () { + runTask(key, task); + }); + } + + function processQueue() { + if (readyTasks.length === 0 && runningTasks === 0) { + return callback(null, results); + } + while (readyTasks.length && runningTasks < concurrency) { + var run = readyTasks.shift(); + run(); + } + } + + function addListener(taskName, fn) { + var taskListeners = listeners[taskName]; + if (!taskListeners) { + taskListeners = listeners[taskName] = []; + } + + taskListeners.push(fn); + } + + function taskComplete(taskName) { + var taskListeners = listeners[taskName] || []; + arrayEach(taskListeners, function (fn) { + fn(); + }); + processQueue(); + } + + function runTask(key, task) { + if (hasError) return; + + var taskCallback = onlyOnce(rest(function (err, args) { + runningTasks--; + if (args.length <= 1) { + args = args[0]; + } + if (err) { + var safeResults = {}; + baseForOwn(results, function (val, rkey) { + safeResults[rkey] = val; + }); + safeResults[key] = args; + hasError = true; + listeners = []; + + callback(err, safeResults); + } else { + results[key] = args; + taskComplete(key); + } + })); + + runningTasks++; + var taskFn = task[task.length - 1]; + if (task.length > 1) { + taskFn(results, taskCallback); + } else { + taskFn(taskCallback); + } + } + + function checkForDeadlocks() { + // Kahn's algorithm + // https://en.wikipedia.org/wiki/Topological_sorting#Kahn.27s_algorithm + // http://connalle.blogspot.com/2013/10/topological-sortingkahn-algorithm.html + var currentTask; + var counter = 0; + while (readyToCheck.length) { + currentTask = readyToCheck.pop(); + counter++; + arrayEach(getDependents(currentTask), function (dependent) { + if (--uncheckedDependencies[dependent] === 0) { + readyToCheck.push(dependent); + } + }); + } + + if (counter !== numTasks) { + throw new Error('async.auto cannot execute tasks due to a recursive dependency'); + } + } + + function getDependents(taskName) { + var result = []; + baseForOwn(tasks, function (task, key) { + if (isArray(task) && baseIndexOf(task, taskName, 0) >= 0) { + result.push(key); + } + }); + return result; + } + } + + /** + * A specialized version of `_.map` for arrays without support for iteratee + * shorthands. + * + * @private + * @param {Array} [array] The array to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @returns {Array} Returns the new mapped array. + */ + function arrayMap(array, iteratee) { + var index = -1, + length = array ? array.length : 0, + result = Array(length); + + while (++index < length) { + result[index] = iteratee(array[index], index, array); + } + return result; + } + + /** + * Copies the values of `source` to `array`. + * + * @private + * @param {Array} source The array to copy values from. + * @param {Array} [array=[]] The array to copy values to. + * @returns {Array} Returns `array`. + */ + function copyArray(source, array) { + var index = -1, + length = source.length; + + array || (array = Array(length)); + while (++index < length) { + array[index] = source[index]; + } + return array; + } + + /** + * Checks if `value` is a global object. + * + * @private + * @param {*} value The value to check. + * @returns {null|Object} Returns `value` if it's a global object, else `null`. + */ + function checkGlobal(value) { + return (value && value.Object === Object) ? value : null; + } + + /** Detect free variable `global` from Node.js. */ + var freeGlobal = checkGlobal(typeof global == 'object' && global); + + /** Detect free variable `self`. */ + var freeSelf = checkGlobal(typeof self == 'object' && self); + + /** Detect `this` as the global object. */ + var thisGlobal = checkGlobal(typeof this == 'object' && this); + + /** Used as a reference to the global object. */ + var root = freeGlobal || freeSelf || thisGlobal || Function('return this')(); + + /** Built-in value references. */ + var Symbol$1 = root.Symbol; + + /** Used as references for various `Number` constants. */ + var INFINITY$1 = 1 / 0; + + /** Used to convert symbols to primitives and strings. */ + var symbolProto = Symbol$1 ? Symbol$1.prototype : undefined; + var symbolToString = symbolProto ? symbolProto.toString : undefined; + /** + * The base implementation of `_.toString` which doesn't convert nullish + * values to empty strings. + * + * @private + * @param {*} value The value to process. + * @returns {string} Returns the string. + */ + function baseToString(value) { + // Exit early for strings to avoid a performance hit in some environments. + if (typeof value == 'string') { + return value; + } + if (isSymbol(value)) { + return symbolToString ? symbolToString.call(value) : ''; + } + var result = (value + ''); + return (result == '0' && (1 / value) == -INFINITY$1) ? '-0' : result; + } + + /** + * The base implementation of `_.slice` without an iteratee call guard. + * + * @private + * @param {Array} array The array to slice. + * @param {number} [start=0] The start position. + * @param {number} [end=array.length] The end position. + * @returns {Array} Returns the slice of `array`. + */ + function baseSlice(array, start, end) { + var index = -1, + length = array.length; + + if (start < 0) { + start = -start > length ? 0 : (length + start); + } + end = end > length ? length : end; + if (end < 0) { + end += length; + } + length = start > end ? 0 : ((end - start) >>> 0); + start >>>= 0; + + var result = Array(length); + while (++index < length) { + result[index] = array[index + start]; + } + return result; + } + + /** + * Casts `array` to a slice if it's needed. + * + * @private + * @param {Array} array The array to inspect. + * @param {number} start The start position. + * @param {number} [end=array.length] The end position. + * @returns {Array} Returns the cast slice. + */ + function castSlice(array, start, end) { + var length = array.length; + end = end === undefined ? length : end; + return (!start && end >= length) ? array : baseSlice(array, start, end); + } + + /** + * Used by `_.trim` and `_.trimEnd` to get the index of the last string symbol + * that is not found in the character symbols. + * + * @private + * @param {Array} strSymbols The string symbols to inspect. + * @param {Array} chrSymbols The character symbols to find. + * @returns {number} Returns the index of the last unmatched string symbol. + */ + function charsEndIndex(strSymbols, chrSymbols) { + var index = strSymbols.length; + + while (index-- && baseIndexOf(chrSymbols, strSymbols[index], 0) > -1) {} + return index; + } + + /** + * Used by `_.trim` and `_.trimStart` to get the index of the first string symbol + * that is not found in the character symbols. + * + * @private + * @param {Array} strSymbols The string symbols to inspect. + * @param {Array} chrSymbols The character symbols to find. + * @returns {number} Returns the index of the first unmatched string symbol. + */ + function charsStartIndex(strSymbols, chrSymbols) { + var index = -1, + length = strSymbols.length; + + while (++index < length && baseIndexOf(chrSymbols, strSymbols[index], 0) > -1) {} + return index; + } + + /** Used to compose unicode character classes. */ + var rsAstralRange = '\\ud800-\\udfff'; + var rsComboMarksRange = '\\u0300-\\u036f\\ufe20-\\ufe23'; + var rsComboSymbolsRange = '\\u20d0-\\u20f0'; + var rsVarRange = '\\ufe0e\\ufe0f'; + var rsAstral = '[' + rsAstralRange + ']'; + var rsCombo = '[' + rsComboMarksRange + rsComboSymbolsRange + ']'; + var rsFitz = '\\ud83c[\\udffb-\\udfff]'; + var rsModifier = '(?:' + rsCombo + '|' + rsFitz + ')'; + var rsNonAstral = '[^' + rsAstralRange + ']'; + var rsRegional = '(?:\\ud83c[\\udde6-\\uddff]){2}'; + var rsSurrPair = '[\\ud800-\\udbff][\\udc00-\\udfff]'; + var rsZWJ = '\\u200d'; + var reOptMod = rsModifier + '?'; + var rsOptVar = '[' + rsVarRange + ']?'; + var rsOptJoin = '(?:' + rsZWJ + '(?:' + [rsNonAstral, rsRegional, rsSurrPair].join('|') + ')' + rsOptVar + reOptMod + ')*'; + var rsSeq = rsOptVar + reOptMod + rsOptJoin; + var rsSymbol = '(?:' + [rsNonAstral + rsCombo + '?', rsCombo, rsRegional, rsSurrPair, rsAstral].join('|') + ')'; + /** Used to match [string symbols](https://mathiasbynens.be/notes/javascript-unicode). */ + var reComplexSymbol = RegExp(rsFitz + '(?=' + rsFitz + ')|' + rsSymbol + rsSeq, 'g'); + + /** + * Converts `string` to an array. + * + * @private + * @param {string} string The string to convert. + * @returns {Array} Returns the converted array. + */ + function stringToArray(string) { + return string.match(reComplexSymbol); + } + + /** + * Converts `value` to a string. An empty string is returned for `null` + * and `undefined` values. The sign of `-0` is preserved. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to process. + * @returns {string} Returns the string. + * @example + * + * _.toString(null); + * // => '' + * + * _.toString(-0); + * // => '-0' + * + * _.toString([1, 2, 3]); + * // => '1,2,3' + */ + function toString(value) { + return value == null ? '' : baseToString(value); + } + + /** Used to match leading and trailing whitespace. */ + var reTrim$1 = /^\s+|\s+$/g; + + /** + * Removes leading and trailing whitespace or specified characters from `string`. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category String + * @param {string} [string=''] The string to trim. + * @param {string} [chars=whitespace] The characters to trim. + * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`. + * @returns {string} Returns the trimmed string. + * @example + * + * _.trim(' abc '); + * // => 'abc' + * + * _.trim('-_-abc-_-', '_-'); + * // => 'abc' + * + * _.map([' foo ', ' bar '], _.trim); + * // => ['foo', 'bar'] + */ + function trim(string, chars, guard) { + string = toString(string); + if (string && (guard || chars === undefined)) { + return string.replace(reTrim$1, ''); + } + if (!string || !(chars = baseToString(chars))) { + return string; + } + var strSymbols = stringToArray(string), + chrSymbols = stringToArray(chars), + start = charsStartIndex(strSymbols, chrSymbols), + end = charsEndIndex(strSymbols, chrSymbols) + 1; + + return castSlice(strSymbols, start, end).join(''); + } + + var FN_ARGS = /^(function)?\s*[^\(]*\(\s*([^\)]*)\)/m; + var FN_ARG_SPLIT = /,/; + var FN_ARG = /(=.+)?(\s*)$/; + var STRIP_COMMENTS = /((\/\/.*$)|(\/\*[\s\S]*?\*\/))/mg; + + function parseParams(func) { + func = func.toString().replace(STRIP_COMMENTS, ''); + func = func.match(FN_ARGS)[2].replace(' ', ''); + func = func ? func.split(FN_ARG_SPLIT) : []; + func = func.map(function (arg) { + return trim(arg.replace(FN_ARG, '')); + }); + return func; + } + + /** + * A dependency-injected version of the [async.auto]{@link module:ControlFlow.auto} function. Dependent + * tasks are specified as parameters to the function, after the usual callback + * parameter, with the parameter names matching the names of the tasks it + * depends on. This can provide even more readable task graphs which can be + * easier to maintain. + * + * If a final callback is specified, the task results are similarly injected, + * specified as named parameters after the initial error parameter. + * + * The autoInject function is purely syntactic sugar and its semantics are + * otherwise equivalent to [async.auto]{@link module:ControlFlow.auto}. + * + * @name autoInject + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.auto]{@link module:ControlFlow.auto} + * @category Control Flow + * @param {Object} tasks - An object, each of whose properties is a function of + * the form 'func([dependencies...], callback). The object's key of a property + * serves as the name of the task defined by that property, i.e. can be used + * when specifying requirements for other tasks. + * * The `callback` parameter is a `callback(err, result)` which must be called + * when finished, passing an `error` (which can be `null`) and the result of + * the function's execution. The remaining parameters name other tasks on + * which the task is dependent, and the results from those tasks are the + * arguments of those parameters. + * @param {Function} [callback] - An optional callback which is called when all + * the tasks have been completed. It receives the `err` argument if any `tasks` + * pass an error to their callback, and a `results` object with any completed + * task results, similar to `auto`. + * @example + * + * // The example from `auto` can be rewritten as follows: + * async.autoInject({ + * get_data: function(callback) { + * // async code to get some data + * callback(null, 'data', 'converted to array'); + * }, + * make_folder: function(callback) { + * // async code to create a directory to store a file in + * // this is run at the same time as getting the data + * callback(null, 'folder'); + * }, + * write_file: function(get_data, make_folder, callback) { + * // once there is some data and the directory exists, + * // write the data to a file in the directory + * callback(null, 'filename'); + * }, + * email_link: function(write_file, callback) { + * // once the file is written let's email a link to it... + * // write_file contains the filename returned by write_file. + * callback(null, {'file':write_file, 'email':'user@example.com'}); + * } + * }, function(err, results) { + * console.log('err = ', err); + * console.log('email_link = ', results.email_link); + * }); + * + * // If you are using a JS minifier that mangles parameter names, `autoInject` + * // will not work with plain functions, since the parameter names will be + * // collapsed to a single letter identifier. To work around this, you can + * // explicitly specify the names of the parameters your task function needs + * // in an array, similar to Angular.js dependency injection. + * + * // This still has an advantage over plain `auto`, since the results a task + * // depends on are still spread into arguments. + * async.autoInject({ + * //... + * write_file: ['get_data', 'make_folder', function(get_data, make_folder, callback) { + * callback(null, 'filename'); + * }], + * email_link: ['write_file', function(write_file, callback) { + * callback(null, {'file':write_file, 'email':'user@example.com'}); + * }] + * //... + * }, function(err, results) { + * console.log('err = ', err); + * console.log('email_link = ', results.email_link); + * }); + */ + function autoInject(tasks, callback) { + var newTasks = {}; + + baseForOwn(tasks, function (taskFn, key) { + var params; + + if (isArray(taskFn)) { + params = copyArray(taskFn); + taskFn = params.pop(); + + newTasks[key] = params.concat(params.length > 0 ? newTask : taskFn); + } else if (taskFn.length === 1) { + // no dependencies, use the function as-is + newTasks[key] = taskFn; + } else { + params = parseParams(taskFn); + if (taskFn.length === 0 && params.length === 0) { + throw new Error("autoInject task functions require explicit parameters."); + } + + params.pop(); + + newTasks[key] = params.concat(newTask); + } + + function newTask(results, taskCb) { + var newArgs = arrayMap(params, function (name) { + return results[name]; + }); + newArgs.push(taskCb); + taskFn.apply(null, newArgs); + } + }); + + auto(newTasks, callback); + } + + var hasSetImmediate = typeof setImmediate === 'function' && setImmediate; + var hasNextTick = typeof process === 'object' && typeof process.nextTick === 'function'; + + function fallback(fn) { + setTimeout(fn, 0); + } + + function wrap(defer) { + return rest(function (fn, args) { + defer(function () { + fn.apply(null, args); + }); + }); + } + + var _defer; + + if (hasSetImmediate) { + _defer = setImmediate; + } else if (hasNextTick) { + _defer = process.nextTick; + } else { + _defer = fallback; + } + + var setImmediate$1 = wrap(_defer); + + // Simple doubly linked list (https://en.wikipedia.org/wiki/Doubly_linked_list) implementation + // used for queues. This implementation assumes that the node provided by the user can be modified + // to adjust the next and last properties. We implement only the minimal functionality + // for queue support. + function DLL() { + this.head = this.tail = null; + this.length = 0; + } + + function setInitial(dll, node) { + dll.length = 1; + dll.head = dll.tail = node; + } + + DLL.prototype.removeLink = function (node) { + if (node.prev) node.prev.next = node.next;else this.head = node.next; + if (node.next) node.next.prev = node.prev;else this.tail = node.prev; + + node.prev = node.next = null; + this.length -= 1; + return node; + }; + + DLL.prototype.empty = DLL; + + DLL.prototype.insertAfter = function (node, newNode) { + newNode.prev = node; + newNode.next = node.next; + if (node.next) node.next.prev = newNode;else this.tail = newNode; + node.next = newNode; + this.length += 1; + }; + + DLL.prototype.insertBefore = function (node, newNode) { + newNode.prev = node.prev; + newNode.next = node; + if (node.prev) node.prev.next = newNode;else this.head = newNode; + node.prev = newNode; + this.length += 1; + }; + + DLL.prototype.unshift = function (node) { + if (this.head) this.insertBefore(this.head, node);else setInitial(this, node); + }; + + DLL.prototype.push = function (node) { + if (this.tail) this.insertAfter(this.tail, node);else setInitial(this, node); + }; + + DLL.prototype.shift = function () { + return this.head && this.removeLink(this.head); + }; + + DLL.prototype.pop = function () { + return this.tail && this.removeLink(this.tail); + }; + + function queue(worker, concurrency, payload) { + if (concurrency == null) { + concurrency = 1; + } else if (concurrency === 0) { + throw new Error('Concurrency must not be zero'); + } + + function _insert(data, insertAtFront, callback) { + if (callback != null && typeof callback !== 'function') { + throw new Error('task callback must be a function'); + } + q.started = true; + if (!isArray(data)) { + data = [data]; + } + if (data.length === 0 && q.idle()) { + // call drain immediately if there are no tasks + return setImmediate$1(function () { + q.drain(); + }); + } + arrayEach(data, function (task) { + var item = { + data: task, + callback: callback || noop + }; + + if (insertAtFront) { + q._tasks.unshift(item); + } else { + q._tasks.push(item); + } + }); + setImmediate$1(q.process); + } + + function _next(tasks) { + return rest(function (args) { + workers -= 1; + + arrayEach(tasks, function (task) { + arrayEach(workersList, function (worker, index) { + if (worker === task) { + workersList.splice(index, 1); + return false; + } + }); + + task.callback.apply(task, args); + + if (args[0] != null) { + q.error(args[0], task.data); + } + }); + + if (workers <= q.concurrency - q.buffer) { + q.unsaturated(); + } + + if (q.idle()) { + q.drain(); + } + q.process(); + }); + } + + var workers = 0; + var workersList = []; + var q = { + _tasks: new DLL(), + concurrency: concurrency, + payload: payload, + saturated: noop, + unsaturated: noop, + buffer: concurrency / 4, + empty: noop, + drain: noop, + error: noop, + started: false, + paused: false, + push: function (data, callback) { + _insert(data, false, callback); + }, + kill: function () { + q.drain = noop; + q._tasks.empty(); + }, + unshift: function (data, callback) { + _insert(data, true, callback); + }, + process: function () { + while (!q.paused && workers < q.concurrency && q._tasks.length) { + var tasks = [], + data = []; + var l = q._tasks.length; + if (q.payload) l = Math.min(l, q.payload); + for (var i = 0; i < l; i++) { + var node = q._tasks.shift(); + tasks.push(node); + data.push(node.data); + } + + if (q._tasks.length === 0) { + q.empty(); + } + workers += 1; + workersList.push(tasks[0]); + + if (workers === q.concurrency) { + q.saturated(); + } + + var cb = onlyOnce(_next(tasks)); + worker(data, cb); + } + }, + length: function () { + return q._tasks.length; + }, + running: function () { + return workers; + }, + workersList: function () { + return workersList; + }, + idle: function () { + return q._tasks.length + workers === 0; + }, + pause: function () { + q.paused = true; + }, + resume: function () { + if (q.paused === false) { + return; + } + q.paused = false; + var resumeCount = Math.min(q.concurrency, q._tasks.length); + // Need to call q.process once per concurrent + // worker to preserve full concurrency after pause + for (var w = 1; w <= resumeCount; w++) { + setImmediate$1(q.process); + } + } + }; + return q; + } + + /** + * A cargo of tasks for the worker function to complete. Cargo inherits all of + * the same methods and event callbacks as [`queue`]{@link module:ControlFlow.queue}. + * @typedef {Object} CargoObject + * @memberOf module:ControlFlow + * @property {Function} length - A function returning the number of items + * waiting to be processed. Invoke like `cargo.length()`. + * @property {number} payload - An `integer` for determining how many tasks + * should be process per round. This property can be changed after a `cargo` is + * created to alter the payload on-the-fly. + * @property {Function} push - Adds `task` to the `queue`. The callback is + * called once the `worker` has finished processing the task. Instead of a + * single task, an array of `tasks` can be submitted. The respective callback is + * used for every task in the list. Invoke like `cargo.push(task, [callback])`. + * @property {Function} saturated - A callback that is called when the + * `queue.length()` hits the concurrency and further tasks will be queued. + * @property {Function} empty - A callback that is called when the last item + * from the `queue` is given to a `worker`. + * @property {Function} drain - A callback that is called when the last item + * from the `queue` has returned from the `worker`. + * @property {Function} idle - a function returning false if there are items + * waiting or being processed, or true if not. Invoke like `cargo.idle()`. + * @property {Function} pause - a function that pauses the processing of tasks + * until `resume()` is called. Invoke like `cargo.pause()`. + * @property {Function} resume - a function that resumes the processing of + * queued tasks when the queue is paused. Invoke like `cargo.resume()`. + * @property {Function} kill - a function that removes the `drain` callback and + * empties remaining tasks from the queue forcing it to go idle. Invoke like `cargo.kill()`. + */ + + /** + * Creates a `cargo` object with the specified payload. Tasks added to the + * cargo will be processed altogether (up to the `payload` limit). If the + * `worker` is in progress, the task is queued until it becomes available. Once + * the `worker` has completed some tasks, each callback of those tasks is + * called. Check out [these](https://camo.githubusercontent.com/6bbd36f4cf5b35a0f11a96dcd2e97711ffc2fb37/68747470733a2f2f662e636c6f75642e6769746875622e636f6d2f6173736574732f313637363837312f36383130382f62626330636662302d356632392d313165322d393734662d3333393763363464633835382e676966) [animations](https://camo.githubusercontent.com/f4810e00e1c5f5f8addbe3e9f49064fd5d102699/68747470733a2f2f662e636c6f75642e6769746875622e636f6d2f6173736574732f313637363837312f36383130312f38346339323036362d356632392d313165322d383134662d3964336430323431336266642e676966) + * for how `cargo` and `queue` work. + * + * While [`queue`]{@link module:ControlFlow.queue} passes only one task to one of a group of workers + * at a time, cargo passes an array of tasks to a single worker, repeating + * when the worker is finished. + * + * @name cargo + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.queue]{@link module:ControlFlow.queue} + * @category Control Flow + * @param {Function} worker - An asynchronous function for processing an array + * of queued tasks, which must call its `callback(err)` argument when finished, + * with an optional `err` argument. Invoked with `(tasks, callback)`. + * @param {number} [payload=Infinity] - An optional `integer` for determining + * how many tasks should be processed per round; if omitted, the default is + * unlimited. + * @returns {module:ControlFlow.CargoObject} A cargo object to manage the tasks. Callbacks can + * attached as certain properties to listen for specific events during the + * lifecycle of the cargo and inner queue. + * @example + * + * // create a cargo object with payload 2 + * var cargo = async.cargo(function(tasks, callback) { + * for (var i=0; i true + */ + function identity(value) { + return value; + } + + function _createTester(eachfn, check, getResult) { + return function (arr, limit, iteratee, cb) { + function done(err) { + if (cb) { + if (err) { + cb(err); + } else { + cb(null, getResult(false)); + } + } + } + function wrappedIteratee(x, _, callback) { + if (!cb) return callback(); + iteratee(x, function (err, v) { + if (cb) { + if (err) { + cb(err); + cb = iteratee = false; + } else if (check(v)) { + cb(null, getResult(true, x)); + cb = iteratee = false; + } + } + callback(); + }); + } + if (arguments.length > 3) { + cb = cb || noop; + eachfn(arr, limit, wrappedIteratee, done); + } else { + cb = iteratee; + cb = cb || noop; + iteratee = limit; + eachfn(arr, wrappedIteratee, done); + } + }; + } + + function _findGetResult(v, x) { + return x; + } + + /** + * Returns the first value in `coll` that passes an async truth test. The + * `iteratee` is applied in parallel, meaning the first iteratee to return + * `true` will fire the detect `callback` with that result. That means the + * result might not be the first item in the original `coll` (in terms of order) + * that passes the test. + + * If order within the original `coll` is important, then look at + * [`detectSeries`]{@link module:Collections.detectSeries}. + * + * @name detect + * @static + * @memberOf module:Collections + * @method + * @alias find + * @category Collections + * @param {Array|Iterable|Object} coll - A collection to iterate over. + * @param {Function} iteratee - A truth test to apply to each item in `coll`. + * The iteratee is passed a `callback(err, truthValue)` which must be called + * with a boolean argument once it has completed. Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called as soon as any + * iteratee returns `true`, or after all the `iteratee` functions have finished. + * Result will be the first item in the array that passes the truth test + * (iteratee) or the value `undefined` if none passed. Invoked with + * (err, result). + * @example + * + * async.detect(['file1','file2','file3'], function(filePath, callback) { + * fs.access(filePath, function(err) { + * callback(null, !err) + * }); + * }, function(err, result) { + * // result now equals the first file in the list that exists + * }); + */ + var detect = _createTester(eachOf, identity, _findGetResult); + + /** + * The same as [`detect`]{@link module:Collections.detect} but runs a maximum of `limit` async operations at a + * time. + * + * @name detectLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.detect]{@link module:Collections.detect} + * @alias findLimit + * @category Collections + * @param {Array|Iterable|Object} coll - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {Function} iteratee - A truth test to apply to each item in `coll`. + * The iteratee is passed a `callback(err, truthValue)` which must be called + * with a boolean argument once it has completed. Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called as soon as any + * iteratee returns `true`, or after all the `iteratee` functions have finished. + * Result will be the first item in the array that passes the truth test + * (iteratee) or the value `undefined` if none passed. Invoked with + * (err, result). + */ + var detectLimit = _createTester(eachOfLimit, identity, _findGetResult); + + /** + * The same as [`detect`]{@link module:Collections.detect} but runs only a single async operation at a time. + * + * @name detectSeries + * @static + * @memberOf module:Collections + * @method + * @see [async.detect]{@link module:Collections.detect} + * @alias findSeries + * @category Collections + * @param {Array|Iterable|Object} coll - A collection to iterate over. + * @param {Function} iteratee - A truth test to apply to each item in `coll`. + * The iteratee is passed a `callback(err, truthValue)` which must be called + * with a boolean argument once it has completed. Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called as soon as any + * iteratee returns `true`, or after all the `iteratee` functions have finished. + * Result will be the first item in the array that passes the truth test + * (iteratee) or the value `undefined` if none passed. Invoked with + * (err, result). + */ + var detectSeries = _createTester(eachOfSeries, identity, _findGetResult); + + function consoleFunc(name) { + return rest(function (fn, args) { + fn.apply(null, args.concat([rest(function (err, args) { + if (typeof console === 'object') { + if (err) { + if (console.error) { + console.error(err); + } + } else if (console[name]) { + arrayEach(args, function (x) { + console[name](x); + }); + } + } + })])); + }); + } + + /** + * Logs the result of an `async` function to the `console` using `console.dir` + * to display the properties of the resulting object. Only works in Node.js or + * in browsers that support `console.dir` and `console.error` (such as FF and + * Chrome). If multiple arguments are returned from the async function, + * `console.dir` is called on each argument in order. + * + * @name dir + * @static + * @memberOf module:Utils + * @method + * @category Util + * @param {Function} function - The function you want to eventually apply all + * arguments to. + * @param {...*} arguments... - Any number of arguments to apply to the function. + * @example + * + * // in a module + * var hello = function(name, callback) { + * setTimeout(function() { + * callback(null, {hello: name}); + * }, 1000); + * }; + * + * // in the node repl + * node> async.dir(hello, 'world'); + * {hello: 'world'} + */ + var dir = consoleFunc('dir'); + + /** + * The post-check version of [`during`]{@link module:ControlFlow.during}. To reflect the difference in + * the order of operations, the arguments `test` and `fn` are switched. + * + * Also a version of [`doWhilst`]{@link module:ControlFlow.doWhilst} with asynchronous `test` function. + * @name doDuring + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.during]{@link module:ControlFlow.during} + * @category Control Flow + * @param {Function} fn - A function which is called each time `test` passes. + * The function is passed a `callback(err)`, which must be called once it has + * completed with an optional `err` argument. Invoked with (callback). + * @param {Function} test - asynchronous truth test to perform before each + * execution of `fn`. Invoked with (...args, callback), where `...args` are the + * non-error args from the previous callback of `fn`. + * @param {Function} [callback] - A callback which is called after the test + * function has failed and repeated execution of `fn` has stopped. `callback` + * will be passed an error if one occured, otherwise `null`. + */ + function doDuring(fn, test, callback) { + callback = onlyOnce(callback || noop); + + var next = rest(function (err, args) { + if (err) return callback(err); + args.push(check); + test.apply(this, args); + }); + + function check(err, truth) { + if (err) return callback(err); + if (!truth) return callback(null); + fn(next); + } + + check(null, true); + } + + /** + * The post-check version of [`whilst`]{@link module:ControlFlow.whilst}. To reflect the difference in + * the order of operations, the arguments `test` and `iteratee` are switched. + * + * `doWhilst` is to `whilst` as `do while` is to `while` in plain JavaScript. + * + * @name doWhilst + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.whilst]{@link module:ControlFlow.whilst} + * @category Control Flow + * @param {Function} iteratee - A function which is called each time `test` + * passes. The function is passed a `callback(err)`, which must be called once + * it has completed with an optional `err` argument. Invoked with (callback). + * @param {Function} test - synchronous truth test to perform after each + * execution of `iteratee`. Invoked with Invoked with the non-error callback + * results of `iteratee`. + * @param {Function} [callback] - A callback which is called after the test + * function has failed and repeated execution of `iteratee` has stopped. + * `callback` will be passed an error and any arguments passed to the final + * `iteratee`'s callback. Invoked with (err, [results]); + */ + function doWhilst(iteratee, test, callback) { + callback = onlyOnce(callback || noop); + var next = rest(function (err, args) { + if (err) return callback(err); + if (test.apply(this, args)) return iteratee(next); + callback.apply(null, [null].concat(args)); + }); + iteratee(next); + } + + /** + * Like ['doWhilst']{@link module:ControlFlow.doWhilst}, except the `test` is inverted. Note the + * argument ordering differs from `until`. + * + * @name doUntil + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.doWhilst]{@link module:ControlFlow.doWhilst} + * @category Control Flow + * @param {Function} fn - A function which is called each time `test` fails. + * The function is passed a `callback(err)`, which must be called once it has + * completed with an optional `err` argument. Invoked with (callback). + * @param {Function} test - synchronous truth test to perform after each + * execution of `fn`. Invoked with the non-error callback results of `fn`. + * @param {Function} [callback] - A callback which is called after the test + * function has passed and repeated execution of `fn` has stopped. `callback` + * will be passed an error and any arguments passed to the final `fn`'s + * callback. Invoked with (err, [results]); + */ + function doUntil(fn, test, callback) { + doWhilst(fn, function () { + return !test.apply(this, arguments); + }, callback); + } + + /** + * Like [`whilst`]{@link module:ControlFlow.whilst}, except the `test` is an asynchronous function that + * is passed a callback in the form of `function (err, truth)`. If error is + * passed to `test` or `fn`, the main callback is immediately called with the + * value of the error. + * + * @name during + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.whilst]{@link module:ControlFlow.whilst} + * @category Control Flow + * @param {Function} test - asynchronous truth test to perform before each + * execution of `fn`. Invoked with (callback). + * @param {Function} fn - A function which is called each time `test` passes. + * The function is passed a `callback(err)`, which must be called once it has + * completed with an optional `err` argument. Invoked with (callback). + * @param {Function} [callback] - A callback which is called after the test + * function has failed and repeated execution of `fn` has stopped. `callback` + * will be passed an error, if one occured, otherwise `null`. + * @example + * + * var count = 0; + * + * async.during( + * function (callback) { + * return callback(null, count < 5); + * }, + * function (callback) { + * count++; + * setTimeout(callback, 1000); + * }, + * function (err) { + * // 5 seconds have passed + * } + * ); + */ + function during(test, fn, callback) { + callback = onlyOnce(callback || noop); + + function next(err) { + if (err) return callback(err); + test(check); + } + + function check(err, truth) { + if (err) return callback(err); + if (!truth) return callback(null); + fn(next); + } + + test(check); + } + + function _withoutIndex(iteratee) { + return function (value, index, callback) { + return iteratee(value, callback); + }; + } + + /** + * Applies the function `iteratee` to each item in `coll`, in parallel. + * The `iteratee` is called with an item from the list, and a callback for when + * it has finished. If the `iteratee` passes an error to its `callback`, the + * main `callback` (for the `each` function) is immediately called with the + * error. + * + * Note, that since this function applies `iteratee` to each item in parallel, + * there is no guarantee that the iteratee functions will complete in order. + * + * @name each + * @static + * @memberOf module:Collections + * @method + * @alias forEach + * @category Collection + * @param {Array|Iterable|Object} coll - A collection to iterate over. + * @param {Function} iteratee - A function to apply to each item + * in `coll`. The iteratee is passed a `callback(err)` which must be called once + * it has completed. If no error has occurred, the `callback` should be run + * without arguments or with an explicit `null` argument. The array index is not + * passed to the iteratee. Invoked with (item, callback). If you need the index, + * use `eachOf`. + * @param {Function} [callback] - A callback which is called when all + * `iteratee` functions have finished, or an error occurs. Invoked with (err). + * @example + * + * // assuming openFiles is an array of file names and saveFile is a function + * // to save the modified contents of that file: + * + * async.each(openFiles, saveFile, function(err){ + * // if any of the saves produced an error, err would equal that error + * }); + * + * // assuming openFiles is an array of file names + * async.each(openFiles, function(file, callback) { + * + * // Perform operation on file here. + * console.log('Processing file ' + file); + * + * if( file.length > 32 ) { + * console.log('This file name is too long'); + * callback('File name too long'); + * } else { + * // Do work to process file here + * console.log('File processed'); + * callback(); + * } + * }, function(err) { + * // if any of the file processing produced an error, err would equal that error + * if( err ) { + * // One of the iterations produced an error. + * // All processing will now stop. + * console.log('A file failed to process'); + * } else { + * console.log('All files have been processed successfully'); + * } + * }); + */ + function eachLimit(coll, iteratee, callback) { + eachOf(coll, _withoutIndex(iteratee), callback); + } + + /** + * The same as [`each`]{@link module:Collections.each} but runs a maximum of `limit` async operations at a time. + * + * @name eachLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.each]{@link module:Collections.each} + * @alias forEachLimit + * @category Collection + * @param {Array|Iterable|Object} coll - A colleciton to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {Function} iteratee - A function to apply to each item in `coll`. The + * iteratee is passed a `callback(err)` which must be called once it has + * completed. If no error has occurred, the `callback` should be run without + * arguments or with an explicit `null` argument. The array index is not passed + * to the iteratee. Invoked with (item, callback). If you need the index, use + * `eachOfLimit`. + * @param {Function} [callback] - A callback which is called when all + * `iteratee` functions have finished, or an error occurs. Invoked with (err). + */ + function eachLimit$1(coll, limit, iteratee, callback) { + _eachOfLimit(limit)(coll, _withoutIndex(iteratee), callback); + } + + /** + * The same as [`each`]{@link module:Collections.each} but runs only a single async operation at a time. + * + * @name eachSeries + * @static + * @memberOf module:Collections + * @method + * @see [async.each]{@link module:Collections.each} + * @alias forEachSeries + * @category Collection + * @param {Array|Iterable|Object} coll - A collection to iterate over. + * @param {Function} iteratee - A function to apply to each + * item in `coll`. The iteratee is passed a `callback(err)` which must be called + * once it has completed. If no error has occurred, the `callback` should be run + * without arguments or with an explicit `null` argument. The array index is + * not passed to the iteratee. Invoked with (item, callback). If you need the + * index, use `eachOfSeries`. + * @param {Function} [callback] - A callback which is called when all + * `iteratee` functions have finished, or an error occurs. Invoked with (err). + */ + var eachSeries = doLimit(eachLimit$1, 1); + + /** + * Wrap an async function and ensure it calls its callback on a later tick of + * the event loop. If the function already calls its callback on a next tick, + * no extra deferral is added. This is useful for preventing stack overflows + * (`RangeError: Maximum call stack size exceeded`) and generally keeping + * [Zalgo](http://blog.izs.me/post/59142742143/designing-apis-for-asynchrony) + * contained. + * + * @name ensureAsync + * @static + * @memberOf module:Utils + * @method + * @category Util + * @param {Function} fn - an async function, one that expects a node-style + * callback as its last argument. + * @returns {Function} Returns a wrapped function with the exact same call + * signature as the function passed in. + * @example + * + * function sometimesAsync(arg, callback) { + * if (cache[arg]) { + * return callback(null, cache[arg]); // this would be synchronous!! + * } else { + * doSomeIO(arg, callback); // this IO would be asynchronous + * } + * } + * + * // this has a risk of stack overflows if many results are cached in a row + * async.mapSeries(args, sometimesAsync, done); + * + * // this will defer sometimesAsync's callback if necessary, + * // preventing stack overflows + * async.mapSeries(args, async.ensureAsync(sometimesAsync), done); + */ + function ensureAsync(fn) { + return initialParams(function (args, callback) { + var sync = true; + args.push(function () { + var innerArgs = arguments; + if (sync) { + setImmediate$1(function () { + callback.apply(null, innerArgs); + }); + } else { + callback.apply(null, innerArgs); + } + }); + fn.apply(this, args); + sync = false; + }); + } + + function notId(v) { + return !v; + } + + /** + * Returns `true` if every element in `coll` satisfies an async test. If any + * iteratee call returns `false`, the main `callback` is immediately called. + * + * @name every + * @static + * @memberOf module:Collections + * @method + * @alias all + * @category Collection + * @param {Array|Iterable|Object} coll - A collection to iterate over. + * @param {Function} iteratee - A truth test to apply to each item in the + * collection in parallel. The iteratee is passed a `callback(err, truthValue)` + * which must be called with a boolean argument once it has completed. Invoked + * with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Result will be either `true` or `false` + * depending on the values of the async tests. Invoked with (err, result). + * @example + * + * async.every(['file1','file2','file3'], function(filePath, callback) { + * fs.access(filePath, function(err) { + * callback(null, !err) + * }); + * }, function(err, result) { + * // if result is true then every file exists + * }); + */ + var every = _createTester(eachOf, notId, notId); + + /** + * The same as [`every`]{@link module:Collections.every} but runs a maximum of `limit` async operations at a time. + * + * @name everyLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.every]{@link module:Collections.every} + * @alias allLimit + * @category Collection + * @param {Array|Iterable|Object} coll - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {Function} iteratee - A truth test to apply to each item in the + * collection in parallel. The iteratee is passed a `callback(err, truthValue)` + * which must be called with a boolean argument once it has completed. Invoked + * with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Result will be either `true` or `false` + * depending on the values of the async tests. Invoked with (err, result). + */ + var everyLimit = _createTester(eachOfLimit, notId, notId); + + /** + * The same as [`every`]{@link module:Collections.every} but runs only a single async operation at a time. + * + * @name everySeries + * @static + * @memberOf module:Collections + * @method + * @see [async.every]{@link module:Collections.every} + * @alias allSeries + * @category Collection + * @param {Array|Iterable|Object} coll - A collection to iterate over. + * @param {Function} iteratee - A truth test to apply to each item in the + * collection in parallel. The iteratee is passed a `callback(err, truthValue)` + * which must be called with a boolean argument once it has completed. Invoked + * with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Result will be either `true` or `false` + * depending on the values of the async tests. Invoked with (err, result). + */ + var everySeries = doLimit(everyLimit, 1); + + function _filter(eachfn, arr, iteratee, callback) { + callback = once(callback || noop); + var results = []; + eachfn(arr, function (x, index, callback) { + iteratee(x, function (err, v) { + if (err) { + callback(err); + } else { + if (v) { + results.push({ index: index, value: x }); + } + callback(); + } + }); + }, function (err) { + if (err) { + callback(err); + } else { + callback(null, arrayMap(results.sort(function (a, b) { + return a.index - b.index; + }), baseProperty('value'))); + } + }); + } + + /** + * Returns a new array of all the values in `coll` which pass an async truth + * test. This operation is performed in parallel, but the results array will be + * in the same order as the original. + * + * @name filter + * @static + * @memberOf module:Collections + * @method + * @alias select + * @category Collection + * @param {Array|Iterable|Object} coll - A collection to iterate over. + * @param {Function} iteratee - A truth test to apply to each item in `coll`. + * The `iteratee` is passed a `callback(err, truthValue)`, which must be called + * with a boolean argument once it has completed. Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Invoked with (err, results). + * @example + * + * async.filter(['file1','file2','file3'], function(filePath, callback) { + * fs.access(filePath, function(err) { + * callback(null, !err) + * }); + * }, function(err, results) { + * // results now equals an array of the existing files + * }); + */ + var filter = doParallel(_filter); + + /** + * The same as [`filter`]{@link module:Collections.filter} but runs a maximum of `limit` async operations at a + * time. + * + * @name filterLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.filter]{@link module:Collections.filter} + * @alias selectLimit + * @category Collection + * @param {Array|Iterable|Object} coll - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {Function} iteratee - A truth test to apply to each item in `coll`. + * The `iteratee` is passed a `callback(err, truthValue)`, which must be called + * with a boolean argument once it has completed. Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Invoked with (err, results). + */ + var filterLimit = doParallelLimit(_filter); + + /** + * The same as [`filter`]{@link module:Collections.filter} but runs only a single async operation at a time. + * + * @name filterSeries + * @static + * @memberOf module:Collections + * @method + * @see [async.filter]{@link module:Collections.filter} + * @alias selectSeries + * @category Collection + * @param {Array|Iterable|Object} coll - A collection to iterate over. + * @param {Function} iteratee - A truth test to apply to each item in `coll`. + * The `iteratee` is passed a `callback(err, truthValue)`, which must be called + * with a boolean argument once it has completed. Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Invoked with (err, results) + */ + var filterSeries = doLimit(filterLimit, 1); + + /** + * Calls the asynchronous function `fn` with a callback parameter that allows it + * to call itself again, in series, indefinitely. + + * If an error is passed to the + * callback then `errback` is called with the error, and execution stops, + * otherwise it will never be called. + * + * @name forever + * @static + * @memberOf module:ControlFlow + * @method + * @category Control Flow + * @param {Function} fn - a function to call repeatedly. Invoked with (next). + * @param {Function} [errback] - when `fn` passes an error to it's callback, + * this function will be called, and execution stops. Invoked with (err). + * @example + * + * async.forever( + * function(next) { + * // next is suitable for passing to things that need a callback(err [, whatever]); + * // it will result in this function being called again. + * }, + * function(err) { + * // if next is called with a value in its first parameter, it will appear + * // in here as 'err', and execution will stop. + * } + * ); + */ + function forever(fn, errback) { + var done = onlyOnce(errback || noop); + var task = ensureAsync(fn); + + function next(err) { + if (err) return done(err); + task(next); + } + next(); + } + + /** + * Logs the result of an `async` function to the `console`. Only works in + * Node.js or in browsers that support `console.log` and `console.error` (such + * as FF and Chrome). If multiple arguments are returned from the async + * function, `console.log` is called on each argument in order. + * + * @name log + * @static + * @memberOf module:Utils + * @method + * @category Util + * @param {Function} function - The function you want to eventually apply all + * arguments to. + * @param {...*} arguments... - Any number of arguments to apply to the function. + * @example + * + * // in a module + * var hello = function(name, callback) { + * setTimeout(function() { + * callback(null, 'hello ' + name); + * }, 1000); + * }; + * + * // in the node repl + * node> async.log(hello, 'world'); + * 'hello world' + */ + var log = consoleFunc('log'); + + /** + * The same as [`mapValues`]{@link module:Collections.mapValues} but runs a maximum of `limit` async operations at a + * time. + * + * @name mapValuesLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.mapValues]{@link module:Collections.mapValues} + * @category Collection + * @param {Object} obj - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {Function} iteratee - A function to apply to each value in `obj`. + * The iteratee is passed a `callback(err, transformed)` which must be called + * once it has completed with an error (which can be `null`) and a + * transformed value. Invoked with (value, key, callback). + * @param {Function} [callback] - A callback which is called when all `iteratee` + * functions have finished, or an error occurs. Result is an object of the + * transformed values from the `obj`. Invoked with (err, result). + */ + function mapValuesLimit(obj, limit, iteratee, callback) { + callback = once(callback || noop); + var newObj = {}; + eachOfLimit(obj, limit, function (val, key, next) { + iteratee(val, key, function (err, result) { + if (err) return next(err); + newObj[key] = result; + next(); + }); + }, function (err) { + callback(err, newObj); + }); + } + + /** + * A relative of [`map`]{@link module:Collections.map}, designed for use with objects. + * + * Produces a new Object by mapping each value of `obj` through the `iteratee` + * function. The `iteratee` is called each `value` and `key` from `obj` and a + * callback for when it has finished processing. Each of these callbacks takes + * two arguments: an `error`, and the transformed item from `obj`. If `iteratee` + * passes an error to its callback, the main `callback` (for the `mapValues` + * function) is immediately called with the error. + * + * Note, the order of the keys in the result is not guaranteed. The keys will + * be roughly in the order they complete, (but this is very engine-specific) + * + * @name mapValues + * @static + * @memberOf module:Collections + * @method + * @category Collection + * @param {Object} obj - A collection to iterate over. + * @param {Function} iteratee - A function to apply to each value and key in + * `coll`. The iteratee is passed a `callback(err, transformed)` which must be + * called once it has completed with an error (which can be `null`) and a + * transformed value. Invoked with (value, key, callback). + * @param {Function} [callback] - A callback which is called when all `iteratee` + * functions have finished, or an error occurs. Results is an array of the + * transformed items from the `obj`. Invoked with (err, result). + * @example + * + * async.mapValues({ + * f1: 'file1', + * f2: 'file2', + * f3: 'file3' + * }, function (file, key, callback) { + * fs.stat(file, callback); + * }, function(err, result) { + * // results is now a map of stats for each file, e.g. + * // { + * // f1: [stats for file1], + * // f2: [stats for file2], + * // f3: [stats for file3] + * // } + * }); + */ + + var mapValues = doLimit(mapValuesLimit, Infinity); + + /** + * The same as [`mapValues`]{@link module:Collections.mapValues} but runs only a single async operation at a time. + * + * @name mapValuesSeries + * @static + * @memberOf module:Collections + * @method + * @see [async.mapValues]{@link module:Collections.mapValues} + * @category Collection + * @param {Object} obj - A collection to iterate over. + * @param {Function} iteratee - A function to apply to each value in `obj`. + * The iteratee is passed a `callback(err, transformed)` which must be called + * once it has completed with an error (which can be `null`) and a + * transformed value. Invoked with (value, key, callback). + * @param {Function} [callback] - A callback which is called when all `iteratee` + * functions have finished, or an error occurs. Result is an object of the + * transformed values from the `obj`. Invoked with (err, result). + */ + var mapValuesSeries = doLimit(mapValuesLimit, 1); + + function has(obj, key) { + return key in obj; + } + + /** + * Caches the results of an `async` function. When creating a hash to store + * function results against, the callback is omitted from the hash and an + * optional hash function can be used. + * + * If no hash function is specified, the first argument is used as a hash key, + * which may work reasonably if it is a string or a data type that converts to a + * distinct string. Note that objects and arrays will not behave reasonably. + * Neither will cases where the other arguments are significant. In such cases, + * specify your own hash function. + * + * The cache of results is exposed as the `memo` property of the function + * returned by `memoize`. + * + * @name memoize + * @static + * @memberOf module:Utils + * @method + * @category Util + * @param {Function} fn - The function to proxy and cache results from. + * @param {Function} hasher - An optional function for generating a custom hash + * for storing results. It has all the arguments applied to it apart from the + * callback, and must be synchronous. + * @returns {Function} a memoized version of `fn` + * @example + * + * var slow_fn = function(name, callback) { + * // do something + * callback(null, result); + * }; + * var fn = async.memoize(slow_fn); + * + * // fn can now be used as if it were slow_fn + * fn('some name', function() { + * // callback + * }); + */ + function memoize(fn, hasher) { + var memo = Object.create(null); + var queues = Object.create(null); + hasher = hasher || identity; + var memoized = initialParams(function memoized(args, callback) { + var key = hasher.apply(null, args); + if (has(memo, key)) { + setImmediate$1(function () { + callback.apply(null, memo[key]); + }); + } else if (has(queues, key)) { + queues[key].push(callback); + } else { + queues[key] = [callback]; + fn.apply(null, args.concat([rest(function (args) { + memo[key] = args; + var q = queues[key]; + delete queues[key]; + for (var i = 0, l = q.length; i < l; i++) { + q[i].apply(null, args); + } + })])); + } + }); + memoized.memo = memo; + memoized.unmemoized = fn; + return memoized; + } + + /** + * Calls `callback` on a later loop around the event loop. In Node.js this just + * calls `setImmediate`. In the browser it will use `setImmediate` if + * available, otherwise `setTimeout(callback, 0)`, which means other higher + * priority events may precede the execution of `callback`. + * + * This is used internally for browser-compatibility purposes. + * + * @name nextTick + * @static + * @memberOf module:Utils + * @method + * @alias setImmediate + * @category Util + * @param {Function} callback - The function to call on a later loop around + * the event loop. Invoked with (args...). + * @param {...*} args... - any number of additional arguments to pass to the + * callback on the next tick. + * @example + * + * var call_order = []; + * async.nextTick(function() { + * call_order.push('two'); + * // call_order now equals ['one','two'] + * }); + * call_order.push('one'); + * + * async.setImmediate(function (a, b, c) { + * // a, b, and c equal 1, 2, and 3 + * }, 1, 2, 3); + */ + var _defer$1; + + if (hasNextTick) { + _defer$1 = process.nextTick; + } else if (hasSetImmediate) { + _defer$1 = setImmediate; + } else { + _defer$1 = fallback; + } + + var nextTick = wrap(_defer$1); + + function _parallel(eachfn, tasks, callback) { + callback = callback || noop; + var results = isArrayLike(tasks) ? [] : {}; + + eachfn(tasks, function (task, key, callback) { + task(rest(function (err, args) { + if (args.length <= 1) { + args = args[0]; + } + results[key] = args; + callback(err); + })); + }, function (err) { + callback(err, results); + }); + } + + /** + * Run the `tasks` collection of functions in parallel, without waiting until + * the previous function has completed. If any of the functions pass an error to + * its callback, the main `callback` is immediately called with the value of the + * error. Once the `tasks` have completed, the results are passed to the final + * `callback` as an array. + * + * **Note:** `parallel` is about kicking-off I/O tasks in parallel, not about + * parallel execution of code. If your tasks do not use any timers or perform + * any I/O, they will actually be executed in series. Any synchronous setup + * sections for each task will happen one after the other. JavaScript remains + * single-threaded. + * + * It is also possible to use an object instead of an array. Each property will + * be run as a function and the results will be passed to the final `callback` + * as an object instead of an array. This can be a more readable way of handling + * results from {@link async.parallel}. + * + * @name parallel + * @static + * @memberOf module:ControlFlow + * @method + * @category Control Flow + * @param {Array|Iterable|Object} tasks - A collection containing functions to run. + * Each function is passed a `callback(err, result)` which it must call on + * completion with an error `err` (which can be `null`) and an optional `result` + * value. + * @param {Function} [callback] - An optional callback to run once all the + * functions have completed successfully. This function gets a results array + * (or object) containing all the result arguments passed to the task callbacks. + * Invoked with (err, results). + * @example + * async.parallel([ + * function(callback) { + * setTimeout(function() { + * callback(null, 'one'); + * }, 200); + * }, + * function(callback) { + * setTimeout(function() { + * callback(null, 'two'); + * }, 100); + * } + * ], + * // optional callback + * function(err, results) { + * // the results array will equal ['one','two'] even though + * // the second function had a shorter timeout. + * }); + * + * // an example using an object instead of an array + * async.parallel({ + * one: function(callback) { + * setTimeout(function() { + * callback(null, 1); + * }, 200); + * }, + * two: function(callback) { + * setTimeout(function() { + * callback(null, 2); + * }, 100); + * } + * }, function(err, results) { + * // results is now equals to: {one: 1, two: 2} + * }); + */ + function parallelLimit(tasks, callback) { + _parallel(eachOf, tasks, callback); + } + + /** + * The same as [`parallel`]{@link module:ControlFlow.parallel} but runs a maximum of `limit` async operations at a + * time. + * + * @name parallelLimit + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.parallel]{@link module:ControlFlow.parallel} + * @category Control Flow + * @param {Array|Collection} tasks - A collection containing functions to run. + * Each function is passed a `callback(err, result)` which it must call on + * completion with an error `err` (which can be `null`) and an optional `result` + * value. + * @param {number} limit - The maximum number of async operations at a time. + * @param {Function} [callback] - An optional callback to run once all the + * functions have completed successfully. This function gets a results array + * (or object) containing all the result arguments passed to the task callbacks. + * Invoked with (err, results). + */ + function parallelLimit$1(tasks, limit, callback) { + _parallel(_eachOfLimit(limit), tasks, callback); + } + + /** + * A queue of tasks for the worker function to complete. + * @typedef {Object} QueueObject + * @memberOf module:ControlFlow + * @property {Function} length - a function returning the number of items + * waiting to be processed. Invoke with `queue.length()`. + * @property {boolean} started - a boolean indicating whether or not any + * items have been pushed and processed by the queue. + * @property {Function} running - a function returning the number of items + * currently being processed. Invoke with `queue.running()`. + * @property {Function} workersList - a function returning the array of items + * currently being processed. Invoke with `queue.workersList()`. + * @property {Function} idle - a function returning false if there are items + * waiting or being processed, or true if not. Invoke with `queue.idle()`. + * @property {number} concurrency - an integer for determining how many `worker` + * functions should be run in parallel. This property can be changed after a + * `queue` is created to alter the concurrency on-the-fly. + * @property {Function} push - add a new task to the `queue`. Calls `callback` + * once the `worker` has finished processing the task. Instead of a single task, + * a `tasks` array can be submitted. The respective callback is used for every + * task in the list. Invoke with `queue.push(task, [callback])`, + * @property {Function} unshift - add a new task to the front of the `queue`. + * Invoke with `queue.unshift(task, [callback])`. + * @property {Function} saturated - a callback that is called when the number of + * running workers hits the `concurrency` limit, and further tasks will be + * queued. + * @property {Function} unsaturated - a callback that is called when the number + * of running workers is less than the `concurrency` & `buffer` limits, and + * further tasks will not be queued. + * @property {number} buffer - A minimum threshold buffer in order to say that + * the `queue` is `unsaturated`. + * @property {Function} empty - a callback that is called when the last item + * from the `queue` is given to a `worker`. + * @property {Function} drain - a callback that is called when the last item + * from the `queue` has returned from the `worker`. + * @property {Function} error - a callback that is called when a task errors. + * Has the signature `function(error, task)`. + * @property {boolean} paused - a boolean for determining whether the queue is + * in a paused state. + * @property {Function} pause - a function that pauses the processing of tasks + * until `resume()` is called. Invoke with `queue.pause()`. + * @property {Function} resume - a function that resumes the processing of + * queued tasks when the queue is paused. Invoke with `queue.resume()`. + * @property {Function} kill - a function that removes the `drain` callback and + * empties remaining tasks from the queue forcing it to go idle. Invoke with `queue.kill()`. + */ + + /** + * Creates a `queue` object with the specified `concurrency`. Tasks added to the + * `queue` are processed in parallel (up to the `concurrency` limit). If all + * `worker`s are in progress, the task is queued until one becomes available. + * Once a `worker` completes a `task`, that `task`'s callback is called. + * + * @name queue + * @static + * @memberOf module:ControlFlow + * @method + * @category Control Flow + * @param {Function} worker - An asynchronous function for processing a queued + * task, which must call its `callback(err)` argument when finished, with an + * optional `error` as an argument. If you want to handle errors from an + * individual task, pass a callback to `q.push()`. Invoked with + * (task, callback). + * @param {number} [concurrency=1] - An `integer` for determining how many + * `worker` functions should be run in parallel. If omitted, the concurrency + * defaults to `1`. If the concurrency is `0`, an error is thrown. + * @returns {module:ControlFlow.QueueObject} A queue object to manage the tasks. Callbacks can + * attached as certain properties to listen for specific events during the + * lifecycle of the queue. + * @example + * + * // create a queue object with concurrency 2 + * var q = async.queue(function(task, callback) { + * console.log('hello ' + task.name); + * callback(); + * }, 2); + * + * // assign a callback + * q.drain = function() { + * console.log('all items have been processed'); + * }; + * + * // add some items to the queue + * q.push({name: 'foo'}, function(err) { + * console.log('finished processing foo'); + * }); + * q.push({name: 'bar'}, function (err) { + * console.log('finished processing bar'); + * }); + * + * // add some items to the queue (batch-wise) + * q.push([{name: 'baz'},{name: 'bay'},{name: 'bax'}], function(err) { + * console.log('finished processing item'); + * }); + * + * // add some items to the front of the queue + * q.unshift({name: 'bar'}, function (err) { + * console.log('finished processing bar'); + * }); + */ + function queue$1 (worker, concurrency) { + return queue(function (items, cb) { + worker(items[0], cb); + }, concurrency, 1); + } + + /** + * The same as [async.queue]{@link module:ControlFlow.queue} only tasks are assigned a priority and + * completed in ascending priority order. + * + * @name priorityQueue + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.queue]{@link module:ControlFlow.queue} + * @category Control Flow + * @param {Function} worker - An asynchronous function for processing a queued + * task, which must call its `callback(err)` argument when finished, with an + * optional `error` as an argument. If you want to handle errors from an + * individual task, pass a callback to `q.push()`. Invoked with + * (task, callback). + * @param {number} concurrency - An `integer` for determining how many `worker` + * functions should be run in parallel. If omitted, the concurrency defaults to + * `1`. If the concurrency is `0`, an error is thrown. + * @returns {module:ControlFlow.QueueObject} A priorityQueue object to manage the tasks. There are two + * differences between `queue` and `priorityQueue` objects: + * * `push(task, priority, [callback])` - `priority` should be a number. If an + * array of `tasks` is given, all tasks will be assigned the same priority. + * * The `unshift` method was removed. + */ + function priorityQueue (worker, concurrency) { + // Start with a normal queue + var q = queue$1(worker, concurrency); + + // Override push to accept second parameter representing priority + q.push = function (data, priority, callback) { + if (callback == null) callback = noop; + if (typeof callback !== 'function') { + throw new Error('task callback must be a function'); + } + q.started = true; + if (!isArray(data)) { + data = [data]; + } + if (data.length === 0) { + // call drain immediately if there are no tasks + return setImmediate$1(function () { + q.drain(); + }); + } + + priority = priority || 0; + var nextNode = q._tasks.head; + while (nextNode && priority >= nextNode.priority) { + nextNode = nextNode.next; + } + + arrayEach(data, function (task) { + var item = { + data: task, + priority: priority, + callback: callback + }; + + if (nextNode) { + q._tasks.insertBefore(nextNode, item); + } else { + q._tasks.push(item); + } + }); + setImmediate$1(q.process); + }; + + // Remove unshift function + delete q.unshift; + + return q; + } + + /** + * Runs the `tasks` array of functions in parallel, without waiting until the + * previous function has completed. Once any the `tasks` completed or pass an + * error to its callback, the main `callback` is immediately called. It's + * equivalent to `Promise.race()`. + * + * @name race + * @static + * @memberOf module:ControlFlow + * @method + * @category Control Flow + * @param {Array} tasks - An array containing functions to run. Each function + * is passed a `callback(err, result)` which it must call on completion with an + * error `err` (which can be `null`) and an optional `result` value. + * @param {Function} callback - A callback to run once any of the functions have + * completed. This function gets an error or result from the first function that + * completed. Invoked with (err, result). + * @returns undefined + * @example + * + * async.race([ + * function(callback) { + * setTimeout(function() { + * callback(null, 'one'); + * }, 200); + * }, + * function(callback) { + * setTimeout(function() { + * callback(null, 'two'); + * }, 100); + * } + * ], + * // main callback + * function(err, result) { + * // the result will be equal to 'two' as it finishes earlier + * }); + */ + function race(tasks, callback) { + callback = once(callback || noop); + if (!isArray(tasks)) return callback(new TypeError('First argument to race must be an array of functions')); + if (!tasks.length) return callback(); + arrayEach(tasks, function (task) { + task(callback); + }); + } + + var slice = Array.prototype.slice; + + /** + * Same as [`reduce`]{@link module:Collections.reduce}, only operates on `array` in reverse order. + * + * @name reduceRight + * @static + * @memberOf module:Collections + * @method + * @see [async.reduce]{@link module:Collections.reduce} + * @alias foldr + * @category Collection + * @param {Array} array - A collection to iterate over. + * @param {*} memo - The initial state of the reduction. + * @param {Function} iteratee - A function applied to each item in the + * array to produce the next step in the reduction. The `iteratee` is passed a + * `callback(err, reduction)` which accepts an optional error as its first + * argument, and the state of the reduction as the second. If an error is + * passed to the callback, the reduction is stopped and the main `callback` is + * immediately called with the error. Invoked with (memo, item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Result is the reduced value. Invoked with + * (err, result). + */ + function reduceRight(array, memo, iteratee, callback) { + var reversed = slice.call(array).reverse(); + reduce(reversed, memo, iteratee, callback); + } + + /** + * Wraps the function in another function that always returns data even when it + * errors. + * + * The object returned has either the property `error` or `value`. + * + * @name reflect + * @static + * @memberOf module:Utils + * @method + * @category Util + * @param {Function} fn - The function you want to wrap + * @returns {Function} - A function that always passes null to it's callback as + * the error. The second argument to the callback will be an `object` with + * either an `error` or a `value` property. + * @example + * + * async.parallel([ + * async.reflect(function(callback) { + * // do some stuff ... + * callback(null, 'one'); + * }), + * async.reflect(function(callback) { + * // do some more stuff but error ... + * callback('bad stuff happened'); + * }), + * async.reflect(function(callback) { + * // do some more stuff ... + * callback(null, 'two'); + * }) + * ], + * // optional callback + * function(err, results) { + * // values + * // results[0].value = 'one' + * // results[1].error = 'bad stuff happened' + * // results[2].value = 'two' + * }); + */ + function reflect(fn) { + return initialParams(function reflectOn(args, reflectCallback) { + args.push(rest(function callback(err, cbArgs) { + if (err) { + reflectCallback(null, { + error: err + }); + } else { + var value = null; + if (cbArgs.length === 1) { + value = cbArgs[0]; + } else if (cbArgs.length > 1) { + value = cbArgs; + } + reflectCallback(null, { + value: value + }); + } + })); + + return fn.apply(this, args); + }); + } + + function reject$1(eachfn, arr, iteratee, callback) { + _filter(eachfn, arr, function (value, cb) { + iteratee(value, function (err, v) { + if (err) { + cb(err); + } else { + cb(null, !v); + } + }); + }, callback); + } + + /** + * The opposite of [`filter`]{@link module:Collections.filter}. Removes values that pass an `async` truth test. + * + * @name reject + * @static + * @memberOf module:Collections + * @method + * @see [async.filter]{@link module:Collections.filter} + * @category Collection + * @param {Array|Iterable|Object} coll - A collection to iterate over. + * @param {Function} iteratee - A truth test to apply to each item in `coll`. + * The `iteratee` is passed a `callback(err, truthValue)`, which must be called + * with a boolean argument once it has completed. Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Invoked with (err, results). + * @example + * + * async.reject(['file1','file2','file3'], function(filePath, callback) { + * fs.access(filePath, function(err) { + * callback(null, !err) + * }); + * }, function(err, results) { + * // results now equals an array of missing files + * createFiles(results); + * }); + */ + var reject = doParallel(reject$1); + + /** + * A helper function that wraps an array or an object of functions with reflect. + * + * @name reflectAll + * @static + * @memberOf module:Utils + * @method + * @see [async.reflect]{@link module:Utils.reflect} + * @category Util + * @param {Array} tasks - The array of functions to wrap in `async.reflect`. + * @returns {Array} Returns an array of functions, each function wrapped in + * `async.reflect` + * @example + * + * let tasks = [ + * function(callback) { + * setTimeout(function() { + * callback(null, 'one'); + * }, 200); + * }, + * function(callback) { + * // do some more stuff but error ... + * callback(new Error('bad stuff happened')); + * }, + * function(callback) { + * setTimeout(function() { + * callback(null, 'two'); + * }, 100); + * } + * ]; + * + * async.parallel(async.reflectAll(tasks), + * // optional callback + * function(err, results) { + * // values + * // results[0].value = 'one' + * // results[1].error = Error('bad stuff happened') + * // results[2].value = 'two' + * }); + * + * // an example using an object instead of an array + * let tasks = { + * one: function(callback) { + * setTimeout(function() { + * callback(null, 'one'); + * }, 200); + * }, + * two: function(callback) { + * callback('two'); + * }, + * three: function(callback) { + * setTimeout(function() { + * callback(null, 'three'); + * }, 100); + * } + * }; + * + * async.parallel(async.reflectAll(tasks), + * // optional callback + * function(err, results) { + * // values + * // results.one.value = 'one' + * // results.two.error = 'two' + * // results.three.value = 'three' + * }); + */ + function reflectAll(tasks) { + var results; + if (isArray(tasks)) { + results = arrayMap(tasks, reflect); + } else { + results = {}; + baseForOwn(tasks, function (task, key) { + results[key] = reflect.call(this, task); + }); + } + return results; + } + + /** + * The same as [`reject`]{@link module:Collections.reject} but runs a maximum of `limit` async operations at a + * time. + * + * @name rejectLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.reject]{@link module:Collections.reject} + * @category Collection + * @param {Array|Iterable|Object} coll - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {Function} iteratee - A truth test to apply to each item in `coll`. + * The `iteratee` is passed a `callback(err, truthValue)`, which must be called + * with a boolean argument once it has completed. Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Invoked with (err, results). + */ + var rejectLimit = doParallelLimit(reject$1); + + /** + * The same as [`reject`]{@link module:Collections.reject} but runs only a single async operation at a time. + * + * @name rejectSeries + * @static + * @memberOf module:Collections + * @method + * @see [async.reject]{@link module:Collections.reject} + * @category Collection + * @param {Array|Iterable|Object} coll - A collection to iterate over. + * @param {Function} iteratee - A truth test to apply to each item in `coll`. + * The `iteratee` is passed a `callback(err, truthValue)`, which must be called + * with a boolean argument once it has completed. Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Invoked with (err, results). + */ + var rejectSeries = doLimit(rejectLimit, 1); + + /** + * Creates a function that returns `value`. + * + * @static + * @memberOf _ + * @since 2.4.0 + * @category Util + * @param {*} value The value to return from the new function. + * @returns {Function} Returns the new constant function. + * @example + * + * var objects = _.times(2, _.constant({ 'a': 1 })); + * + * console.log(objects); + * // => [{ 'a': 1 }, { 'a': 1 }] + * + * console.log(objects[0] === objects[1]); + * // => true + */ + function constant$1(value) { + return function() { + return value; + }; + } + + /** + * Attempts to get a successful response from `task` no more than `times` times + * before returning an error. If the task is successful, the `callback` will be + * passed the result of the successful task. If all attempts fail, the callback + * will be passed the error and result (if any) of the final attempt. + * + * @name retry + * @static + * @memberOf module:ControlFlow + * @method + * @category Control Flow + * @param {Object|number} [opts = {times: 5, interval: 0}| 5] - Can be either an + * object with `times` and `interval` or a number. + * * `times` - The number of attempts to make before giving up. The default + * is `5`. + * * `interval` - The time to wait between retries, in milliseconds. The + * default is `0`. The interval may also be specified as a function of the + * retry count (see example). + * * If `opts` is a number, the number specifies the number of times to retry, + * with the default interval of `0`. + * @param {Function} task - A function which receives two arguments: (1) a + * `callback(err, result)` which must be called when finished, passing `err` + * (which can be `null`) and the `result` of the function's execution, and (2) + * a `results` object, containing the results of the previously executed + * functions (if nested inside another control flow). Invoked with + * (callback, results). + * @param {Function} [callback] - An optional callback which is called when the + * task has succeeded, or after the final failed attempt. It receives the `err` + * and `result` arguments of the last attempt at completing the `task`. Invoked + * with (err, results). + * @example + * + * // The `retry` function can be used as a stand-alone control flow by passing + * // a callback, as shown below: + * + * // try calling apiMethod 3 times + * async.retry(3, apiMethod, function(err, result) { + * // do something with the result + * }); + * + * // try calling apiMethod 3 times, waiting 200 ms between each retry + * async.retry({times: 3, interval: 200}, apiMethod, function(err, result) { + * // do something with the result + * }); + * + * // try calling apiMethod 10 times with exponential backoff + * // (i.e. intervals of 100, 200, 400, 800, 1600, ... milliseconds) + * async.retry({ + * times: 10, + * interval: function(retryCount) { + * return 50 * Math.pow(2, retryCount); + * } + * }, apiMethod, function(err, result) { + * // do something with the result + * }); + * + * // try calling apiMethod the default 5 times no delay between each retry + * async.retry(apiMethod, function(err, result) { + * // do something with the result + * }); + * + * // It can also be embedded within other control flow functions to retry + * // individual methods that are not as reliable, like this: + * async.auto({ + * users: api.getUsers.bind(api), + * payments: async.retry(3, api.getPayments.bind(api)) + * }, function(err, results) { + * // do something with the results + * }); + */ + function retry(opts, task, callback) { + var DEFAULT_TIMES = 5; + var DEFAULT_INTERVAL = 0; + + var options = { + times: DEFAULT_TIMES, + intervalFunc: constant$1(DEFAULT_INTERVAL) + }; + + function parseTimes(acc, t) { + if (typeof t === 'object') { + acc.times = +t.times || DEFAULT_TIMES; + + acc.intervalFunc = typeof t.interval === 'function' ? t.interval : constant$1(+t.interval || DEFAULT_INTERVAL); + } else if (typeof t === 'number' || typeof t === 'string') { + acc.times = +t || DEFAULT_TIMES; + } else { + throw new Error("Invalid arguments for async.retry"); + } + } + + if (arguments.length < 3 && typeof opts === 'function') { + callback = task || noop; + task = opts; + } else { + parseTimes(options, opts); + callback = callback || noop; + } + + if (typeof task !== 'function') { + throw new Error("Invalid arguments for async.retry"); + } + + var attempt = 1; + function retryAttempt() { + task(function (err) { + if (err && attempt++ < options.times) { + setTimeout(retryAttempt, options.intervalFunc(attempt)); + } else { + callback.apply(null, arguments); + } + }); + } + + retryAttempt(); + } + + /** + * A close relative of [`retry`]{@link module:ControlFlow.retry}. This method wraps a task and makes it + * retryable, rather than immediately calling it with retries. + * + * @name retryable + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.retry]{@link module:ControlFlow.retry} + * @category Control Flow + * @param {Object|number} [opts = {times: 5, interval: 0}| 5] - optional + * options, exactly the same as from `retry` + * @param {Function} task - the asynchronous function to wrap + * @returns {Functions} The wrapped function, which when invoked, will retry on + * an error, based on the parameters specified in `opts`. + * @example + * + * async.auto({ + * dep1: async.retryable(3, getFromFlakyService), + * process: ["dep1", async.retryable(3, function (results, cb) { + * maybeProcessData(results.dep1, cb); + * })] + * }, callback); + */ + function retryable (opts, task) { + if (!task) { + task = opts; + opts = null; + } + return initialParams(function (args, callback) { + function taskFn(cb) { + task.apply(null, args.concat([cb])); + } + + if (opts) retry(opts, taskFn, callback);else retry(taskFn, callback); + }); + } + + /** + * Run the functions in the `tasks` collection in series, each one running once + * the previous function has completed. If any functions in the series pass an + * error to its callback, no more functions are run, and `callback` is + * immediately called with the value of the error. Otherwise, `callback` + * receives an array of results when `tasks` have completed. + * + * It is also possible to use an object instead of an array. Each property will + * be run as a function, and the results will be passed to the final `callback` + * as an object instead of an array. This can be a more readable way of handling + * results from {@link async.series}. + * + * **Note** that while many implementations preserve the order of object + * properties, the [ECMAScript Language Specification](http://www.ecma-international.org/ecma-262/5.1/#sec-8.6) + * explicitly states that + * + * > The mechanics and order of enumerating the properties is not specified. + * + * So if you rely on the order in which your series of functions are executed, + * and want this to work on all platforms, consider using an array. + * + * @name series + * @static + * @memberOf module:ControlFlow + * @method + * @category Control Flow + * @param {Array|Iterable|Object} tasks - A collection containing functions to run, each + * function is passed a `callback(err, result)` it must call on completion with + * an error `err` (which can be `null`) and an optional `result` value. + * @param {Function} [callback] - An optional callback to run once all the + * functions have completed. This function gets a results array (or object) + * containing all the result arguments passed to the `task` callbacks. Invoked + * with (err, result). + * @example + * async.series([ + * function(callback) { + * // do some stuff ... + * callback(null, 'one'); + * }, + * function(callback) { + * // do some more stuff ... + * callback(null, 'two'); + * } + * ], + * // optional callback + * function(err, results) { + * // results is now equal to ['one', 'two'] + * }); + * + * async.series({ + * one: function(callback) { + * setTimeout(function() { + * callback(null, 1); + * }, 200); + * }, + * two: function(callback){ + * setTimeout(function() { + * callback(null, 2); + * }, 100); + * } + * }, function(err, results) { + * // results is now equal to: {one: 1, two: 2} + * }); + */ + function series(tasks, callback) { + _parallel(eachOfSeries, tasks, callback); + } + + /** + * Returns `true` if at least one element in the `coll` satisfies an async test. + * If any iteratee call returns `true`, the main `callback` is immediately + * called. + * + * @name some + * @static + * @memberOf module:Collections + * @method + * @alias any + * @category Collection + * @param {Array|Iterable|Object} coll - A collection to iterate over. + * @param {Function} iteratee - A truth test to apply to each item in the array + * in parallel. The iteratee is passed a `callback(err, truthValue)` which must + * be called with a boolean argument once it has completed. Invoked with + * (item, callback). + * @param {Function} [callback] - A callback which is called as soon as any + * iteratee returns `true`, or after all the iteratee functions have finished. + * Result will be either `true` or `false` depending on the values of the async + * tests. Invoked with (err, result). + * @example + * + * async.some(['file1','file2','file3'], function(filePath, callback) { + * fs.access(filePath, function(err) { + * callback(null, !err) + * }); + * }, function(err, result) { + * // if result is true then at least one of the files exists + * }); + */ + var some = _createTester(eachOf, Boolean, identity); + + /** + * The same as [`some`]{@link module:Collections.some} but runs a maximum of `limit` async operations at a time. + * + * @name someLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.some]{@link module:Collections.some} + * @alias anyLimit + * @category Collection + * @param {Array|Iterable|Object} coll - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {Function} iteratee - A truth test to apply to each item in the array + * in parallel. The iteratee is passed a `callback(err, truthValue)` which must + * be called with a boolean argument once it has completed. Invoked with + * (item, callback). + * @param {Function} [callback] - A callback which is called as soon as any + * iteratee returns `true`, or after all the iteratee functions have finished. + * Result will be either `true` or `false` depending on the values of the async + * tests. Invoked with (err, result). + */ + var someLimit = _createTester(eachOfLimit, Boolean, identity); + + /** + * The same as [`some`]{@link module:Collections.some} but runs only a single async operation at a time. + * + * @name someSeries + * @static + * @memberOf module:Collections + * @method + * @see [async.some]{@link module:Collections.some} + * @alias anySeries + * @category Collection + * @param {Array|Iterable|Object} coll - A collection to iterate over. + * @param {Function} iteratee - A truth test to apply to each item in the array + * in parallel. The iteratee is passed a `callback(err, truthValue)` which must + * be called with a boolean argument once it has completed. Invoked with + * (item, callback). + * @param {Function} [callback] - A callback which is called as soon as any + * iteratee returns `true`, or after all the iteratee functions have finished. + * Result will be either `true` or `false` depending on the values of the async + * tests. Invoked with (err, result). + */ + var someSeries = doLimit(someLimit, 1); + + /** + * Sorts a list by the results of running each `coll` value through an async + * `iteratee`. + * + * @name sortBy + * @static + * @memberOf module:Collections + * @method + * @category Collection + * @param {Array|Iterable|Object} coll - A collection to iterate over. + * @param {Function} iteratee - A function to apply to each item in `coll`. + * The iteratee is passed a `callback(err, sortValue)` which must be called once + * it has completed with an error (which can be `null`) and a value to use as + * the sort criteria. Invoked with (item, callback). + * @param {Function} callback - A callback which is called after all the + * `iteratee` functions have finished, or an error occurs. Results is the items + * from the original `coll` sorted by the values returned by the `iteratee` + * calls. Invoked with (err, results). + * @example + * + * async.sortBy(['file1','file2','file3'], function(file, callback) { + * fs.stat(file, function(err, stats) { + * callback(err, stats.mtime); + * }); + * }, function(err, results) { + * // results is now the original array of files sorted by + * // modified date + * }); + * + * // By modifying the callback parameter the + * // sorting order can be influenced: + * + * // ascending order + * async.sortBy([1,9,3,5], function(x, callback) { + * callback(null, x); + * }, function(err,result) { + * // result callback + * }); + * + * // descending order + * async.sortBy([1,9,3,5], function(x, callback) { + * callback(null, x*-1); //<- x*-1 instead of x, turns the order around + * }, function(err,result) { + * // result callback + * }); + */ + function sortBy(coll, iteratee, callback) { + map(coll, function (x, callback) { + iteratee(x, function (err, criteria) { + if (err) return callback(err); + callback(null, { value: x, criteria: criteria }); + }); + }, function (err, results) { + if (err) return callback(err); + callback(null, arrayMap(results.sort(comparator), baseProperty('value'))); + }); + + function comparator(left, right) { + var a = left.criteria, + b = right.criteria; + return a < b ? -1 : a > b ? 1 : 0; + } + } + + /** + * Sets a time limit on an asynchronous function. If the function does not call + * its callback within the specified milliseconds, it will be called with a + * timeout error. The code property for the error object will be `'ETIMEDOUT'`. + * + * @name timeout + * @static + * @memberOf module:Utils + * @method + * @category Util + * @param {Function} asyncFn - The asynchronous function you want to set the + * time limit. + * @param {number} milliseconds - The specified time limit. + * @param {*} [info] - Any variable you want attached (`string`, `object`, etc) + * to timeout Error for more information.. + * @returns {Function} Returns a wrapped function that can be used with any of + * the control flow functions. + * @example + * + * async.timeout(function(callback) { + * doAsyncTask(callback); + * }, 1000); + */ + function timeout(asyncFn, milliseconds, info) { + var originalCallback, timer; + var timedOut = false; + + function injectedCallback() { + if (!timedOut) { + originalCallback.apply(null, arguments); + clearTimeout(timer); + } + } + + function timeoutCallback() { + var name = asyncFn.name || 'anonymous'; + var error = new Error('Callback function "' + name + '" timed out.'); + error.code = 'ETIMEDOUT'; + if (info) { + error.info = info; + } + timedOut = true; + originalCallback(error); + } + + return initialParams(function (args, origCallback) { + originalCallback = origCallback; + // setup timer and call original function + timer = setTimeout(timeoutCallback, milliseconds); + asyncFn.apply(null, args.concat(injectedCallback)); + }); + } + + /* Built-in method references for those with the same name as other `lodash` methods. */ + var nativeCeil = Math.ceil; + var nativeMax$1 = Math.max; + /** + * The base implementation of `_.range` and `_.rangeRight` which doesn't + * coerce arguments to numbers. + * + * @private + * @param {number} start The start of the range. + * @param {number} end The end of the range. + * @param {number} step The value to increment or decrement by. + * @param {boolean} [fromRight] Specify iterating from right to left. + * @returns {Array} Returns the range of numbers. + */ + function baseRange(start, end, step, fromRight) { + var index = -1, + length = nativeMax$1(nativeCeil((end - start) / (step || 1)), 0), + result = Array(length); + + while (length--) { + result[fromRight ? length : ++index] = start; + start += step; + } + return result; + } + + /** + * The same as [times]{@link module:ControlFlow.times} but runs a maximum of `limit` async operations at a + * time. + * + * @name timesLimit + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.times]{@link module:ControlFlow.times} + * @category Control Flow + * @param {number} count - The number of times to run the function. + * @param {number} limit - The maximum number of async operations at a time. + * @param {Function} iteratee - The function to call `n` times. Invoked with the + * iteration index and a callback (n, next). + * @param {Function} callback - see [async.map]{@link module:Collections.map}. + */ + function timeLimit(count, limit, iteratee, callback) { + mapLimit(baseRange(0, count, 1), limit, iteratee, callback); + } + + /** + * Calls the `iteratee` function `n` times, and accumulates results in the same + * manner you would use with [map]{@link module:Collections.map}. + * + * @name times + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.map]{@link module:Collections.map} + * @category Control Flow + * @param {number} n - The number of times to run the function. + * @param {Function} iteratee - The function to call `n` times. Invoked with the + * iteration index and a callback (n, next). + * @param {Function} callback - see {@link module:Collections.map}. + * @example + * + * // Pretend this is some complicated async factory + * var createUser = function(id, callback) { + * callback(null, { + * id: 'user' + id + * }); + * }; + * + * // generate 5 users + * async.times(5, function(n, next) { + * createUser(n, function(err, user) { + * next(err, user); + * }); + * }, function(err, users) { + * // we should now have 5 users + * }); + */ + var times = doLimit(timeLimit, Infinity); + + /** + * The same as [times]{@link module:ControlFlow.times} but runs only a single async operation at a time. + * + * @name timesSeries + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.times]{@link module:ControlFlow.times} + * @category Control Flow + * @param {number} n - The number of times to run the function. + * @param {Function} iteratee - The function to call `n` times. Invoked with the + * iteration index and a callback (n, next). + * @param {Function} callback - see {@link module:Collections.map}. + */ + var timesSeries = doLimit(timeLimit, 1); + + /** + * A relative of `reduce`. Takes an Object or Array, and iterates over each + * element in series, each step potentially mutating an `accumulator` value. + * The type of the accumulator defaults to the type of collection passed in. + * + * @name transform + * @static + * @memberOf module:Collections + * @method + * @category Collection + * @param {Array|Iterable|Object} coll - A collection to iterate over. + * @param {*} [accumulator] - The initial state of the transform. If omitted, + * it will default to an empty Object or Array, depending on the type of `coll` + * @param {Function} iteratee - A function applied to each item in the + * collection that potentially modifies the accumulator. The `iteratee` is + * passed a `callback(err)` which accepts an optional error as its first + * argument. If an error is passed to the callback, the transform is stopped + * and the main `callback` is immediately called with the error. + * Invoked with (accumulator, item, key, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Result is the transformed accumulator. + * Invoked with (err, result). + * @example + * + * async.transform([1,2,3], function(acc, item, index, callback) { + * // pointless async: + * process.nextTick(function() { + * acc.push(item * 2) + * callback(null) + * }); + * }, function(err, result) { + * // result is now equal to [2, 4, 6] + * }); + * + * @example + * + * async.transform({a: 1, b: 2, c: 3}, function (obj, val, key, callback) { + * setImmediate(function () { + * obj[key] = val * 2; + * callback(); + * }) + * }, function (err, result) { + * // result is equal to {a: 2, b: 4, c: 6} + * }) + */ + function transform(coll, accumulator, iteratee, callback) { + if (arguments.length === 3) { + callback = iteratee; + iteratee = accumulator; + accumulator = isArray(coll) ? [] : {}; + } + callback = once(callback || noop); + + eachOf(coll, function (v, k, cb) { + iteratee(accumulator, v, k, cb); + }, function (err) { + callback(err, accumulator); + }); + } + + /** + * Undoes a [memoize]{@link module:Utils.memoize}d function, reverting it to the original, + * unmemoized form. Handy for testing. + * + * @name unmemoize + * @static + * @memberOf module:Utils + * @method + * @see [async.memoize]{@link module:Utils.memoize} + * @category Util + * @param {Function} fn - the memoized function + * @returns {Function} a function that calls the original unmemoized function + */ + function unmemoize(fn) { + return function () { + return (fn.unmemoized || fn).apply(null, arguments); + }; + } + + /** + * Repeatedly call `fn`, while `test` returns `true`. Calls `callback` when + * stopped, or an error occurs. + * + * @name whilst + * @static + * @memberOf module:ControlFlow + * @method + * @category Control Flow + * @param {Function} test - synchronous truth test to perform before each + * execution of `fn`. Invoked with (). + * @param {Function} iteratee - A function which is called each time `test` passes. + * The function is passed a `callback(err)`, which must be called once it has + * completed with an optional `err` argument. Invoked with (callback). + * @param {Function} [callback] - A callback which is called after the test + * function has failed and repeated execution of `fn` has stopped. `callback` + * will be passed an error and any arguments passed to the final `fn`'s + * callback. Invoked with (err, [results]); + * @returns undefined + * @example + * + * var count = 0; + * async.whilst( + * function() { return count < 5; }, + * function(callback) { + * count++; + * setTimeout(function() { + * callback(null, count); + * }, 1000); + * }, + * function (err, n) { + * // 5 seconds have passed, n = 5 + * } + * ); + */ + function whilst(test, iteratee, callback) { + callback = onlyOnce(callback || noop); + if (!test()) return callback(null); + var next = rest(function (err, args) { + if (err) return callback(err); + if (test()) return iteratee(next); + callback.apply(null, [null].concat(args)); + }); + iteratee(next); + } + + /** + * Repeatedly call `fn` until `test` returns `true`. Calls `callback` when + * stopped, or an error occurs. `callback` will be passed an error and any + * arguments passed to the final `fn`'s callback. + * + * The inverse of [whilst]{@link module:ControlFlow.whilst}. + * + * @name until + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.whilst]{@link module:ControlFlow.whilst} + * @category Control Flow + * @param {Function} test - synchronous truth test to perform before each + * execution of `fn`. Invoked with (). + * @param {Function} fn - A function which is called each time `test` fails. + * The function is passed a `callback(err)`, which must be called once it has + * completed with an optional `err` argument. Invoked with (callback). + * @param {Function} [callback] - A callback which is called after the test + * function has passed and repeated execution of `fn` has stopped. `callback` + * will be passed an error and any arguments passed to the final `fn`'s + * callback. Invoked with (err, [results]); + */ + function until(test, fn, callback) { + whilst(function () { + return !test.apply(this, arguments); + }, fn, callback); + } + + /** + * Runs the `tasks` array of functions in series, each passing their results to + * the next in the array. However, if any of the `tasks` pass an error to their + * own callback, the next function is not executed, and the main `callback` is + * immediately called with the error. + * + * @name waterfall + * @static + * @memberOf module:ControlFlow + * @method + * @category Control Flow + * @param {Array} tasks - An array of functions to run, each function is passed + * a `callback(err, result1, result2, ...)` it must call on completion. The + * first argument is an error (which can be `null`) and any further arguments + * will be passed as arguments in order to the next task. + * @param {Function} [callback] - An optional callback to run once all the + * functions have completed. This will be passed the results of the last task's + * callback. Invoked with (err, [results]). + * @returns undefined + * @example + * + * async.waterfall([ + * function(callback) { + * callback(null, 'one', 'two'); + * }, + * function(arg1, arg2, callback) { + * // arg1 now equals 'one' and arg2 now equals 'two' + * callback(null, 'three'); + * }, + * function(arg1, callback) { + * // arg1 now equals 'three' + * callback(null, 'done'); + * } + * ], function (err, result) { + * // result now equals 'done' + * }); + * + * // Or, with named functions: + * async.waterfall([ + * myFirstFunction, + * mySecondFunction, + * myLastFunction, + * ], function (err, result) { + * // result now equals 'done' + * }); + * function myFirstFunction(callback) { + * callback(null, 'one', 'two'); + * } + * function mySecondFunction(arg1, arg2, callback) { + * // arg1 now equals 'one' and arg2 now equals 'two' + * callback(null, 'three'); + * } + * function myLastFunction(arg1, callback) { + * // arg1 now equals 'three' + * callback(null, 'done'); + * } + */ + function waterfall (tasks, callback) { + callback = once(callback || noop); + if (!isArray(tasks)) return callback(new Error('First argument to waterfall must be an array of functions')); + if (!tasks.length) return callback(); + var taskIndex = 0; + + function nextTask(args) { + if (taskIndex === tasks.length) { + return callback.apply(null, [null].concat(args)); + } + + var taskCallback = onlyOnce(rest(function (err, args) { + if (err) { + return callback.apply(null, [err].concat(args)); + } + nextTask(args); + })); + + args.push(taskCallback); + + var task = tasks[taskIndex++]; + task.apply(null, args); + } + + nextTask([]); + } + + var index = { + applyEach: applyEach, + applyEachSeries: applyEachSeries, + apply: apply$1, + asyncify: asyncify, + auto: auto, + autoInject: autoInject, + cargo: cargo, + compose: compose, + concat: concat, + concatSeries: concatSeries, + constant: constant, + detect: detect, + detectLimit: detectLimit, + detectSeries: detectSeries, + dir: dir, + doDuring: doDuring, + doUntil: doUntil, + doWhilst: doWhilst, + during: during, + each: eachLimit, + eachLimit: eachLimit$1, + eachOf: eachOf, + eachOfLimit: eachOfLimit, + eachOfSeries: eachOfSeries, + eachSeries: eachSeries, + ensureAsync: ensureAsync, + every: every, + everyLimit: everyLimit, + everySeries: everySeries, + filter: filter, + filterLimit: filterLimit, + filterSeries: filterSeries, + forever: forever, + log: log, + map: map, + mapLimit: mapLimit, + mapSeries: mapSeries, + mapValues: mapValues, + mapValuesLimit: mapValuesLimit, + mapValuesSeries: mapValuesSeries, + memoize: memoize, + nextTick: nextTick, + parallel: parallelLimit, + parallelLimit: parallelLimit$1, + priorityQueue: priorityQueue, + queue: queue$1, + race: race, + reduce: reduce, + reduceRight: reduceRight, + reflect: reflect, + reflectAll: reflectAll, + reject: reject, + rejectLimit: rejectLimit, + rejectSeries: rejectSeries, + retry: retry, + retryable: retryable, + seq: seq, + series: series, + setImmediate: setImmediate$1, + some: some, + someLimit: someLimit, + someSeries: someSeries, + sortBy: sortBy, + timeout: timeout, + times: times, + timesLimit: timeLimit, + timesSeries: timesSeries, + transform: transform, + unmemoize: unmemoize, + until: until, + waterfall: waterfall, + whilst: whilst, + + // aliases + all: every, + any: some, + forEach: eachLimit, + forEachSeries: eachSeries, + forEachLimit: eachLimit$1, + forEachOf: eachOf, + forEachOfSeries: eachOfSeries, + forEachOfLimit: eachOfLimit, + inject: reduce, + foldl: reduce, + foldr: reduceRight, + select: filter, + selectLimit: filterLimit, + selectSeries: filterSeries, + wrapSync: asyncify + }; + + exports['default'] = index; + exports.applyEach = applyEach; + exports.applyEachSeries = applyEachSeries; + exports.apply = apply$1; + exports.asyncify = asyncify; + exports.auto = auto; + exports.autoInject = autoInject; + exports.cargo = cargo; + exports.compose = compose; + exports.concat = concat; + exports.concatSeries = concatSeries; + exports.constant = constant; + exports.detect = detect; + exports.detectLimit = detectLimit; + exports.detectSeries = detectSeries; + exports.dir = dir; + exports.doDuring = doDuring; + exports.doUntil = doUntil; + exports.doWhilst = doWhilst; + exports.during = during; + exports.each = eachLimit; + exports.eachLimit = eachLimit$1; + exports.eachOf = eachOf; + exports.eachOfLimit = eachOfLimit; + exports.eachOfSeries = eachOfSeries; + exports.eachSeries = eachSeries; + exports.ensureAsync = ensureAsync; + exports.every = every; + exports.everyLimit = everyLimit; + exports.everySeries = everySeries; + exports.filter = filter; + exports.filterLimit = filterLimit; + exports.filterSeries = filterSeries; + exports.forever = forever; + exports.log = log; + exports.map = map; + exports.mapLimit = mapLimit; + exports.mapSeries = mapSeries; + exports.mapValues = mapValues; + exports.mapValuesLimit = mapValuesLimit; + exports.mapValuesSeries = mapValuesSeries; + exports.memoize = memoize; + exports.nextTick = nextTick; + exports.parallel = parallelLimit; + exports.parallelLimit = parallelLimit$1; + exports.priorityQueue = priorityQueue; + exports.queue = queue$1; + exports.race = race; + exports.reduce = reduce; + exports.reduceRight = reduceRight; + exports.reflect = reflect; + exports.reflectAll = reflectAll; + exports.reject = reject; + exports.rejectLimit = rejectLimit; + exports.rejectSeries = rejectSeries; + exports.retry = retry; + exports.retryable = retryable; + exports.seq = seq; + exports.series = series; + exports.setImmediate = setImmediate$1; + exports.some = some; + exports.someLimit = someLimit; + exports.someSeries = someSeries; + exports.sortBy = sortBy; + exports.timeout = timeout; + exports.times = times; + exports.timesLimit = timeLimit; + exports.timesSeries = timesSeries; + exports.transform = transform; + exports.unmemoize = unmemoize; + exports.until = until; + exports.waterfall = waterfall; + exports.whilst = whilst; + exports.all = every; + exports.allLimit = everyLimit; + exports.allSeries = everySeries; + exports.any = some; + exports.anyLimit = someLimit; + exports.anySeries = someSeries; + exports.find = detect; + exports.findLimit = detectLimit; + exports.findSeries = detectSeries; + exports.forEach = eachLimit; + exports.forEachSeries = eachSeries; + exports.forEachLimit = eachLimit$1; + exports.forEachOf = eachOf; + exports.forEachOfSeries = eachOfSeries; + exports.forEachOfLimit = eachOfLimit; + exports.inject = reduce; + exports.foldl = reduce; + exports.foldr = reduceRight; + exports.select = filter; + exports.selectLimit = filterLimit; + exports.selectSeries = filterSeries; + exports.wrapSync = asyncify; + +})); \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/dist/async.min.js b/node_modules/mongoose/node_modules/async/dist/async.min.js new file mode 100644 index 0000000..4d5d88a --- /dev/null +++ b/node_modules/mongoose/node_modules/async/dist/async.min.js @@ -0,0 +1,2 @@ +!function(n,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports):"function"==typeof define&&define.amd?define(["exports"],t):t(n.async=n.async||{})}(this,function(n){"use strict";function t(n,t,e){var r=e.length;switch(r){case 0:return n.call(t);case 1:return n.call(t,e[0]);case 2:return n.call(t,e[0],e[1]);case 3:return n.call(t,e[0],e[1],e[2])}return n.apply(t,e)}function e(n){var t=typeof n;return!!n&&("object"==t||"function"==t)}function r(n){var t=e(n)?st.call(n):"";return t==ft||t==at}function u(n){return!!n&&"object"==typeof n}function i(n){return"symbol"==typeof n||u(n)&&vt.call(n)==pt}function o(n){if("number"==typeof n)return n;if(i(n))return yt;if(e(n)){var t=r(n.valueOf)?n.valueOf():n;n=e(t)?t+"":t}if("string"!=typeof n)return 0===n?n:+n;n=n.replace(mt,"");var u=gt.test(n);return u||bt.test(n)?St(n.slice(2),u?2:8):dt.test(n)?yt:+n}function c(n){if(!n)return 0===n?n:0;if(n=o(n),n===jt||n===-jt){var t=0>n?-1:1;return t*kt}return n===n?n:0}function f(n){var t=c(n),e=t%1;return t===t?e?t-e:t:0}function a(n,e){if("function"!=typeof n)throw new TypeError(wt);return e=Et(void 0===e?n.length-1:f(e),0),function(){for(var r=arguments,u=-1,i=Et(r.length-e,0),o=Array(i);++u-1&&n%1==0&&Lt>=n}function v(n){return null!=n&&h(xt(n))&&!r(n)}function y(){}function m(n){return function(){if(null!==n){var t=n;n=null,t.apply(this,arguments)}}}function d(n){return Ot&&n[Ot]&&n[Ot]()}function g(n){return At(Object(n))}function b(n,t){return null!=n&&(Tt.call(n,t)||"object"==typeof n&&t in n&&null===g(n))}function S(n){return _t(Object(n))}function j(n,t){for(var e=-1,r=Array(n);++e-1&&n%1==0&&t>n}function O(n){var t=n&&n.constructor,e="function"==typeof t&&t.prototype||Ut;return n===e}function A(n){var t=O(n);if(!t&&!v(n))return S(n);var e=x(n),r=!!e,u=e||[],i=u.length;for(var o in n)!b(n,o)||r&&("length"==o||L(o,i))||t&&"constructor"==o||u.push(o);return u}function I(n){var t=-1,e=n.length;return function(){return++te?{value:n[u],key:u}:null}}function F(n){if(v(n))return I(n);var t=d(n);return t?T(t):_(n)}function $(n){return function(){if(null===n)throw new Error("Callback was already called.");var t=n;n=null,t.apply(this,arguments)}}function z(n){return function(t,e,r){function u(n){if(f-=1,n)c=!0,r(n);else{if(c&&0>=f)return r(null);i()}}function i(){for(;n>f&&!c;){var t=o();if(null===t)return c=!0,void(0>=f&&r(null));f+=1,e(t.value,t.key,$(u))}}if(r=m(r||y),0>=n||!t)return r(null);var o=F(t),c=!1,f=0;i()}}function B(n,t,e,r){z(t)(n,e,r)}function M(n,t){return function(e,r,u){return n(e,t,r,u)}}function V(n,t){var e;if("function"!=typeof t)throw new TypeError(Nt);return n=f(n),function(){return--n>0&&(e=t.apply(this,arguments)),1>=n&&(t=void 0),e}}function q(n){return V(2,n)}function C(n,t,e){function r(n){n?e(n):++i===o&&e(null)}e=q(e||y);var u=0,i=0,o=n.length;for(0===o&&e(null);o>u;u++)t(n[u],u,$(r))}function D(n,t,e){var r=v(n)?C:Qt;r(n,t,e)}function P(n){return function(t,e,r){return n(D,t,e,r)}}function R(n,t,e,r){r=m(r||y),t=t||[];var u=[],i=0;n(t,function(n,t,r){var o=i++;e(n,function(n,t){u[o]=t,r(n)})},function(n){r(n,u)})}function U(n){return function(t,e,r,u){return n(z(e),t,r,u)}}function N(n){return l(function(t,r){var u;try{u=n.apply(this,t)}catch(i){return r(i)}e(u)&&"function"==typeof u.then?u.then(function(n){r(null,n)},function(n){r(n.message?n:new Error(n))}):r(null,u)})}function Q(n,t){for(var e=-1,r=n?n.length:0;++ev;){var n=b.shift();n()}}function i(n,t){var e=g[n];e||(e=g[n]=[]),e.push(t)}function o(n){var t=g[n]||[];Q(t,function(n){n()}),u()}function c(n,t){if(!d){var r=$(a(function(t,r){if(v--,r.length<=1&&(r=r[0]),t){var u={};G(h,function(n,t){u[t]=n}),u[n]=r,d=!0,g=[],e(t,u)}else h[n]=r,o(n)}));v++;var u=t[t.length-1];t.length>1?u(h,r):u(r)}}function f(){for(var n,t=0;S.length;)n=S.pop(),t++,Q(l(n),function(n){0===--j[n]&&S.push(n)});if(t!==p)throw new Error("async.auto cannot execute tasks due to a recursive dependency")}function l(t){var e=[];return G(n,function(n,r){Vt(n)&&J(n,t,0)>=0&&e.push(r)}),e}"function"==typeof t&&(e=t,t=null),e=m(e||y);var s=A(n),p=s.length;if(!p)return e(null);t||(t=p);var h={},v=0,d=!1,g={},b=[],S=[],j={};G(n,function(t,e){if(!Vt(t))return r(e,[t]),void S.push(e);var u=t.slice(0,t.length-1),o=u.length;return 0===o?(r(e,t),void S.push(e)):(j[e]=o,void Q(u,function(c){if(!n[c])throw new Error("async.auto task `"+e+"` has a non-existent dependency in "+u.join(", "));i(c,function(){o--,0===o&&r(e,t)})}))}),f(),u()}function X(n,t){for(var e=-1,r=n?n.length:0,u=Array(r);++et&&(t=-t>u?0:u+t),e=e>u?u:e,0>e&&(e+=u),u=t>e?0:e-t>>>0,t>>>=0;for(var i=Array(u);++r=r?n:tn(n,t,e)}function rn(n,t){for(var e=n.length;e--&&J(t,n[e],0)>-1;);return e}function un(n,t){for(var e=-1,r=n.length;++e-1;);return e}function on(n){return n.match(Ee)}function cn(n){return null==n?"":nn(n)}function fn(n,t,e){if(n=cn(n),n&&(e||void 0===t))return n.replace(xe,"");if(!n||!(t=nn(t)))return n;var r=on(n),u=on(t),i=un(r,u),o=rn(r,u)+1;return en(r,i,o).join("")}function an(n){return n=n.toString().replace(Ie,""),n=n.match(Le)[2].replace(" ",""),n=n?n.split(Oe):[],n=n.map(function(n){return fn(n.replace(Ae,""))})}function ln(n,t){var e={};G(n,function(n,t){function r(t,e){var r=X(u,function(n){return t[n]});r.push(e),n.apply(null,r)}var u;if(Vt(n))u=Y(n),n=u.pop(),e[t]=u.concat(u.length>0?r:n);else if(1===n.length)e[t]=n;else{if(u=an(n),0===n.length&&0===u.length)throw new Error("autoInject task functions require explicit parameters.");u.pop(),e[t]=u.concat(r)}}),K(e,t)}function sn(n){setTimeout(n,0)}function pn(n){return a(function(t,e){n(function(){t.apply(null,e)})})}function hn(){this.head=this.tail=null,this.length=0}function vn(n,t){n.length=1,n.head=n.tail=t}function yn(n,t,e){function r(n,t,e){if(null!=e&&"function"!=typeof e)throw new Error("task callback must be a function");return c.started=!0,Vt(n)||(n=[n]),0===n.length&&c.idle()?Fe(function(){c.drain()}):(Q(n,function(n){var r={data:n,callback:e||y};t?c._tasks.unshift(r):c._tasks.push(r)}),void Fe(c.process))}function u(n){return a(function(t){i-=1,Q(n,function(n){Q(o,function(t,e){return t===n?(o.splice(e,1),!1):void 0}),n.callback.apply(n,t),null!=t[0]&&c.error(t[0],n.data)}),i<=c.concurrency-c.buffer&&c.unsaturated(),c.idle()&&c.drain(),c.process()})}if(null==t)t=1;else if(0===t)throw new Error("Concurrency must not be zero");var i=0,o=[],c={_tasks:new hn,concurrency:t,payload:e,saturated:y,unsaturated:y,buffer:t/4,empty:y,drain:y,error:y,started:!1,paused:!1,push:function(n,t){r(n,!1,t)},kill:function(){c.drain=y,c._tasks.empty()},unshift:function(n,t){r(n,!0,t)},process:function(){for(;!c.paused&&if;f++){var a=c._tasks.shift();t.push(a),e.push(a.data)}0===c._tasks.length&&c.empty(),i+=1,o.push(t[0]),i===c.concurrency&&c.saturated();var l=$(u(t));n(e,l)}},length:function(){return c._tasks.length},running:function(){return i},workersList:function(){return o},idle:function(){return c._tasks.length+i===0},pause:function(){c.paused=!0},resume:function(){if(c.paused!==!1){c.paused=!1;for(var n=Math.min(c.concurrency,c._tasks.length),t=1;n>=t;t++)Fe(c.process)}}};return c}function mn(n,t){return yn(n,1,t)}function dn(n,t,e,r){r=m(r||y),ze(n,function(n,r,u){e(t,n,function(n,e){t=e,u(n)})},function(n){r(n,t)})}function gn(n,t,e,r){var u=[];n(t,function(n,t,r){e(n,function(n,t){u=u.concat(t||[]),r(n)})},function(n){r(n,u)})}function bn(n){return function(t,e,r){return n(ze,t,e,r)}}function Sn(n){return n}function jn(n,t,e){return function(r,u,i,o){function c(n){o&&(n?o(n):o(null,e(!1)))}function f(n,r,u){return o?void i(n,function(r,c){o&&(r?(o(r),o=i=!1):t(c)&&(o(null,e(!0,n)),o=i=!1)),u()}):u()}arguments.length>3?(o=o||y,n(r,u,f,c)):(o=i,o=o||y,i=u,n(r,f,c))}}function kn(n,t){return t}function wn(n){return a(function(t,e){t.apply(null,e.concat([a(function(t,e){"object"==typeof console&&(t?console.error&&console.error(t):console[n]&&Q(e,function(t){console[n](t)}))})]))})}function En(n,t,e){function r(t,r){return t?e(t):r?void n(u):e(null)}e=$(e||y);var u=a(function(n,u){return n?e(n):(u.push(r),void t.apply(this,u))});r(null,!0)}function xn(n,t,e){e=$(e||y);var r=a(function(u,i){return u?e(u):t.apply(this,i)?n(r):void e.apply(null,[null].concat(i))});n(r)}function Ln(n,t,e){xn(n,function(){return!t.apply(this,arguments)},e)}function On(n,t,e){function r(t){return t?e(t):void n(u)}function u(n,u){return n?e(n):u?void t(r):e(null)}e=$(e||y),n(u)}function An(n){return function(t,e,r){return n(t,r)}}function In(n,t,e){D(n,An(t),e)}function Tn(n,t,e,r){z(t)(n,An(e),r)}function _n(n){return l(function(t,e){var r=!0;t.push(function(){var n=arguments;r?Fe(function(){e.apply(null,n)}):e.apply(null,n)}),n.apply(this,t),r=!1})}function Fn(n){return!n}function $n(n,t,e,r){r=m(r||y);var u=[];n(t,function(n,t,r){e(n,function(e,i){e?r(e):(i&&u.push({index:t,value:n}),r())})},function(n){n?r(n):r(null,X(u.sort(function(n,t){return n.index-t.index}),p("value")))})}function zn(n,t){function e(n){return n?r(n):void u(e)}var r=$(t||y),u=_n(n);e()}function Bn(n,t,e,r){r=m(r||y);var u={};B(n,t,function(n,t,r){e(n,t,function(n,e){return n?r(n):(u[t]=e,void r())})},function(n){r(n,u)})}function Mn(n,t){return t in n}function Vn(n,t){var e=Object.create(null),r=Object.create(null);t=t||Sn;var u=l(function(u,i){var o=t.apply(null,u);Mn(e,o)?Fe(function(){i.apply(null,e[o])}):Mn(r,o)?r[o].push(i):(r[o]=[i],n.apply(null,u.concat([a(function(n){e[o]=n;var t=r[o];delete r[o];for(var u=0,i=t.length;i>u;u++)t[u].apply(null,n)})])))});return u.memo=e,u.unmemoized=n,u}function qn(n,t,e){e=e||y;var r=v(t)?[]:{};n(t,function(n,t,e){n(a(function(n,u){u.length<=1&&(u=u[0]),r[t]=u,e(n)}))},function(n){e(n,r)})}function Cn(n,t){qn(D,n,t)}function Dn(n,t,e){qn(z(t),n,e)}function Pn(n,t){return yn(function(t,e){n(t[0],e)},t,1)}function Rn(n,t){var e=Pn(n,t);return e.push=function(n,t,r){if(null==r&&(r=y),"function"!=typeof r)throw new Error("task callback must be a function");if(e.started=!0,Vt(n)||(n=[n]),0===n.length)return Fe(function(){e.drain()});t=t||0;for(var u=e._tasks.head;u&&t>=u.priority;)u=u.next;Q(n,function(n){var i={data:n,priority:t,callback:r};u?e._tasks.insertBefore(u,i):e._tasks.push(i)}),Fe(e.process)},delete e.unshift,e}function Un(n,t){return t=m(t||y),Vt(n)?n.length?void Q(n,function(n){n(t)}):t():t(new TypeError("First argument to race must be an array of functions"))}function Nn(n,t,e,r){var u=tr.call(n).reverse();dn(u,t,e,r)}function Qn(n){return l(function(t,e){return t.push(a(function(n,t){if(n)e(null,{error:n});else{var r=null;1===t.length?r=t[0]:t.length>1&&(r=t),e(null,{value:r})}})),n.apply(this,t)})}function Wn(n,t,e,r){$n(n,t,function(n,t){e(n,function(n,e){n?t(n):t(null,!e)})},r)}function Gn(n){var t;return Vt(n)?t=X(n,Qn):(t={},G(n,function(n,e){t[e]=Qn.call(this,n)})),t}function Hn(n){return function(){return n}}function Jn(n,t,e){function r(n,t){if("object"==typeof t)n.times=+t.times||i,n.intervalFunc="function"==typeof t.interval?t.interval:Hn(+t.interval||o);else{if("number"!=typeof t&&"string"!=typeof t)throw new Error("Invalid arguments for async.retry");n.times=+t||i}}function u(){t(function(n){n&&f++e?-1:e>r?1:0}Wt(n,function(n,e){t(n,function(t,r){return t?e(t):void e(null,{value:n,criteria:r})})},function(n,t){return n?e(n):void e(null,X(t.sort(r),p("value")))})}function Zn(n,t,e){function r(){c||(i.apply(null,arguments),clearTimeout(o))}function u(){var t=n.name||"anonymous",r=new Error('Callback function "'+t+'" timed out.');r.code="ETIMEDOUT",e&&(r.info=e),c=!0,i(r)}var i,o,c=!1;return l(function(e,c){i=c,o=setTimeout(u,t),n.apply(null,e.concat(r))})}function nt(n,t,e,r){for(var u=-1,i=ar(fr((t-n)/(e||1)),0),o=Array(i);i--;)o[r?i:++u]=n,n+=e;return o}function tt(n,t,e,r){Ht(nt(0,n,1),t,e,r)}function et(n,t,e,r){3===arguments.length&&(r=e,e=t,t=Vt(n)?[]:{}),r=m(r||y),D(n,function(n,r,u){e(t,n,r,u)},function(n){r(n,t)})}function rt(n){return function(){return(n.unmemoized||n).apply(null,arguments)}}function ut(n,t,e){if(e=$(e||y),!n())return e(null);var r=a(function(u,i){return u?e(u):n()?t(r):void e.apply(null,[null].concat(i))});t(r)}function it(n,t,e){ut(function(){return!n.apply(this,arguments)},t,e)}function ot(n,t){function e(u){if(r===n.length)return t.apply(null,[null].concat(u));var i=$(a(function(n,r){return n?t.apply(null,[n].concat(r)):void e(r)}));u.push(i);var o=n[r++];o.apply(null,u)}if(t=m(t||y),!Vt(n))return t(new Error("First argument to waterfall must be an array of functions"));if(!n.length)return t();var r=0;e([])}var ct,ft="[object Function]",at="[object GeneratorFunction]",lt=Object.prototype,st=lt.toString,pt="[object Symbol]",ht=Object.prototype,vt=ht.toString,yt=NaN,mt=/^\s+|\s+$/g,dt=/^[-+]0x[0-9a-f]+$/i,gt=/^0b[01]+$/i,bt=/^0o[0-7]+$/i,St=parseInt,jt=1/0,kt=1.7976931348623157e308,wt="Expected a function",Et=Math.max,xt=p("length"),Lt=9007199254740991,Ot="function"==typeof Symbol&&Symbol.iterator,At=Object.getPrototypeOf,It=Object.prototype,Tt=It.hasOwnProperty,_t=Object.keys,Ft="[object Arguments]",$t=Object.prototype,zt=$t.hasOwnProperty,Bt=$t.toString,Mt=$t.propertyIsEnumerable,Vt=Array.isArray,qt="[object String]",Ct=Object.prototype,Dt=Ct.toString,Pt=9007199254740991,Rt=/^(?:0|[1-9]\d*)$/,Ut=Object.prototype,Nt="Expected a function",Qt=M(B,1/0),Wt=P(R),Gt=s(Wt),Ht=U(R),Jt=M(Ht,1),Kt=s(Jt),Xt=a(function(n,t){return a(function(e){return n.apply(null,t.concat(e))})}),Yt=W(),Zt=Z("object"==typeof global&&global),ne=Z("object"==typeof self&&self),te=Z("object"==typeof this&&this),ee=Zt||ne||te||Function("return this")(),re=ee.Symbol,ue=1/0,ie=re?re.prototype:void 0,oe=ie?ie.toString:void 0,ce="\\ud800-\\udfff",fe="\\u0300-\\u036f\\ufe20-\\ufe23",ae="\\u20d0-\\u20f0",le="\\ufe0e\\ufe0f",se="["+ce+"]",pe="["+fe+ae+"]",he="\\ud83c[\\udffb-\\udfff]",ve="(?:"+pe+"|"+he+")",ye="[^"+ce+"]",me="(?:\\ud83c[\\udde6-\\uddff]){2}",de="[\\ud800-\\udbff][\\udc00-\\udfff]",ge="\\u200d",be=ve+"?",Se="["+le+"]?",je="(?:"+ge+"(?:"+[ye,me,de].join("|")+")"+Se+be+")*",ke=Se+be+je,we="(?:"+[ye+pe+"?",pe,me,de,se].join("|")+")",Ee=RegExp(he+"(?="+he+")|"+we+ke,"g"),xe=/^\s+|\s+$/g,Le=/^(function)?\s*[^\(]*\(\s*([^\)]*)\)/m,Oe=/,/,Ae=/(=.+)?(\s*)$/,Ie=/((\/\/.*$)|(\/\*[\s\S]*?\*\/))/gm,Te="function"==typeof setImmediate&&setImmediate,_e="object"==typeof process&&"function"==typeof process.nextTick;ct=Te?setImmediate:_e?process.nextTick:sn;var Fe=pn(ct);hn.prototype.removeLink=function(n){return n.prev?n.prev.next=n.next:this.head=n.next,n.next?n.next.prev=n.prev:this.tail=n.prev,n.prev=n.next=null,this.length-=1,n},hn.prototype.empty=hn,hn.prototype.insertAfter=function(n,t){t.prev=n,t.next=n.next,n.next?n.next.prev=t:this.tail=t,n.next=t,this.length+=1},hn.prototype.insertBefore=function(n,t){t.prev=n.prev,t.next=n,n.prev?n.prev.next=t:this.head=t,n.prev=t,this.length+=1},hn.prototype.unshift=function(n){this.head?this.insertBefore(this.head,n):vn(this,n)},hn.prototype.push=function(n){this.tail?this.insertAfter(this.tail,n):vn(this,n)},hn.prototype.shift=function(){return this.head&&this.removeLink(this.head)},hn.prototype.pop=function(){return this.tail&&this.removeLink(this.tail)};var $e,ze=M(B,1),Be=a(function(n){return a(function(t){var e=this,r=t[t.length-1];"function"==typeof r?t.pop():r=y,dn(n,t,function(n,t,r){t.apply(e,n.concat([a(function(n,t){r(n,t)})]))},function(n,t){r.apply(e,[n].concat(t))})})}),Me=a(function(n){return Be.apply(null,n.reverse())}),Ve=P(gn),qe=bn(gn),Ce=a(function(n){var t=[null].concat(n);return l(function(n,e){return e.apply(this,t)})}),De=jn(D,Sn,kn),Pe=jn(B,Sn,kn),Re=jn(ze,Sn,kn),Ue=wn("dir"),Ne=M(Tn,1),Qe=jn(D,Fn,Fn),We=jn(B,Fn,Fn),Ge=M(We,1),He=P($n),Je=U($n),Ke=M(Je,1),Xe=wn("log"),Ye=M(Bn,1/0),Ze=M(Bn,1);$e=_e?process.nextTick:Te?setImmediate:sn;var nr=pn($e),tr=Array.prototype.slice,er=P(Wn),rr=U(Wn),ur=M(rr,1),ir=jn(D,Boolean,Sn),or=jn(B,Boolean,Sn),cr=M(or,1),fr=Math.ceil,ar=Math.max,lr=M(tt,1/0),sr=M(tt,1),pr={applyEach:Gt,applyEachSeries:Kt,apply:Xt,asyncify:N,auto:K,autoInject:ln,cargo:mn,compose:Me,concat:Ve,concatSeries:qe,constant:Ce,detect:De,detectLimit:Pe,detectSeries:Re,dir:Ue,doDuring:En,doUntil:Ln,doWhilst:xn,during:On,each:In,eachLimit:Tn,eachOf:D,eachOfLimit:B,eachOfSeries:ze,eachSeries:Ne,ensureAsync:_n,every:Qe,everyLimit:We,everySeries:Ge,filter:He,filterLimit:Je,filterSeries:Ke,forever:zn,log:Xe,map:Wt,mapLimit:Ht,mapSeries:Jt,mapValues:Ye,mapValuesLimit:Bn,mapValuesSeries:Ze,memoize:Vn,nextTick:nr,parallel:Cn,parallelLimit:Dn,priorityQueue:Rn,queue:Pn,race:Un,reduce:dn,reduceRight:Nn,reflect:Qn,reflectAll:Gn,reject:er,rejectLimit:rr,rejectSeries:ur,retry:Jn,retryable:Kn,seq:Be,series:Xn,setImmediate:Fe,some:ir,someLimit:or,someSeries:cr,sortBy:Yn,timeout:Zn,times:lr,timesLimit:tt,timesSeries:sr,transform:et,unmemoize:rt,until:it,waterfall:ot,whilst:ut,all:Qe,any:ir,forEach:In,forEachSeries:Ne,forEachLimit:Tn,forEachOf:D,forEachOfSeries:ze,forEachOfLimit:B,inject:dn,foldl:dn,foldr:Nn,select:He,selectLimit:Je,selectSeries:Ke,wrapSync:N};n["default"]=pr,n.applyEach=Gt,n.applyEachSeries=Kt,n.apply=Xt,n.asyncify=N,n.auto=K,n.autoInject=ln,n.cargo=mn,n.compose=Me,n.concat=Ve,n.concatSeries=qe,n.constant=Ce,n.detect=De,n.detectLimit=Pe,n.detectSeries=Re,n.dir=Ue,n.doDuring=En,n.doUntil=Ln,n.doWhilst=xn,n.during=On,n.each=In,n.eachLimit=Tn,n.eachOf=D,n.eachOfLimit=B,n.eachOfSeries=ze,n.eachSeries=Ne,n.ensureAsync=_n,n.every=Qe,n.everyLimit=We,n.everySeries=Ge,n.filter=He,n.filterLimit=Je,n.filterSeries=Ke,n.forever=zn,n.log=Xe,n.map=Wt,n.mapLimit=Ht,n.mapSeries=Jt,n.mapValues=Ye,n.mapValuesLimit=Bn,n.mapValuesSeries=Ze,n.memoize=Vn,n.nextTick=nr,n.parallel=Cn,n.parallelLimit=Dn,n.priorityQueue=Rn,n.queue=Pn,n.race=Un,n.reduce=dn,n.reduceRight=Nn,n.reflect=Qn,n.reflectAll=Gn,n.reject=er,n.rejectLimit=rr,n.rejectSeries=ur,n.retry=Jn,n.retryable=Kn,n.seq=Be,n.series=Xn,n.setImmediate=Fe,n.some=ir,n.someLimit=or,n.someSeries=cr,n.sortBy=Yn,n.timeout=Zn,n.times=lr,n.timesLimit=tt,n.timesSeries=sr,n.transform=et,n.unmemoize=rt,n.until=it,n.waterfall=ot,n.whilst=ut,n.all=Qe,n.allLimit=We,n.allSeries=Ge,n.any=ir,n.anyLimit=or,n.anySeries=cr,n.find=De,n.findLimit=Pe,n.findSeries=Re,n.forEach=In,n.forEachSeries=Ne,n.forEachLimit=Tn,n.forEachOf=D,n.forEachOfSeries=ze,n.forEachOfLimit=B,n.inject=dn,n.foldl=dn,n.foldr=Nn,n.select=He,n.selectLimit=Je,n.selectSeries=Ke,n.wrapSync=N}); +//# sourceMappingURL=async.min.map \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/doDuring.js b/node_modules/mongoose/node_modules/async/doDuring.js new file mode 100644 index 0000000..0d01995 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/doDuring.js @@ -0,0 +1,60 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = doDuring; + +var _noop = require('lodash/noop'); + +var _noop2 = _interopRequireDefault(_noop); + +var _rest = require('lodash/rest'); + +var _rest2 = _interopRequireDefault(_rest); + +var _onlyOnce = require('./internal/onlyOnce'); + +var _onlyOnce2 = _interopRequireDefault(_onlyOnce); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The post-check version of [`during`]{@link module:ControlFlow.during}. To reflect the difference in + * the order of operations, the arguments `test` and `fn` are switched. + * + * Also a version of [`doWhilst`]{@link module:ControlFlow.doWhilst} with asynchronous `test` function. + * @name doDuring + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.during]{@link module:ControlFlow.during} + * @category Control Flow + * @param {Function} fn - A function which is called each time `test` passes. + * The function is passed a `callback(err)`, which must be called once it has + * completed with an optional `err` argument. Invoked with (callback). + * @param {Function} test - asynchronous truth test to perform before each + * execution of `fn`. Invoked with (...args, callback), where `...args` are the + * non-error args from the previous callback of `fn`. + * @param {Function} [callback] - A callback which is called after the test + * function has failed and repeated execution of `fn` has stopped. `callback` + * will be passed an error if one occured, otherwise `null`. + */ +function doDuring(fn, test, callback) { + callback = (0, _onlyOnce2.default)(callback || _noop2.default); + + var next = (0, _rest2.default)(function (err, args) { + if (err) return callback(err); + args.push(check); + test.apply(this, args); + }); + + function check(err, truth) { + if (err) return callback(err); + if (!truth) return callback(null); + fn(next); + } + + check(null, true); +} +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/doUntil.js b/node_modules/mongoose/node_modules/async/doUntil.js new file mode 100644 index 0000000..e7b5ee7 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/doUntil.js @@ -0,0 +1,39 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = doUntil; + +var _doWhilst = require('./doWhilst'); + +var _doWhilst2 = _interopRequireDefault(_doWhilst); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Like ['doWhilst']{@link module:ControlFlow.doWhilst}, except the `test` is inverted. Note the + * argument ordering differs from `until`. + * + * @name doUntil + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.doWhilst]{@link module:ControlFlow.doWhilst} + * @category Control Flow + * @param {Function} fn - A function which is called each time `test` fails. + * The function is passed a `callback(err)`, which must be called once it has + * completed with an optional `err` argument. Invoked with (callback). + * @param {Function} test - synchronous truth test to perform after each + * execution of `fn`. Invoked with the non-error callback results of `fn`. + * @param {Function} [callback] - A callback which is called after the test + * function has passed and repeated execution of `fn` has stopped. `callback` + * will be passed an error and any arguments passed to the final `fn`'s + * callback. Invoked with (err, [results]); + */ +function doUntil(fn, test, callback) { + (0, _doWhilst2.default)(fn, function () { + return !test.apply(this, arguments); + }, callback); +} +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/doWhilst.js b/node_modules/mongoose/node_modules/async/doWhilst.js new file mode 100644 index 0000000..a683bb6 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/doWhilst.js @@ -0,0 +1,54 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = doWhilst; + +var _noop = require('lodash/noop'); + +var _noop2 = _interopRequireDefault(_noop); + +var _rest = require('lodash/rest'); + +var _rest2 = _interopRequireDefault(_rest); + +var _onlyOnce = require('./internal/onlyOnce'); + +var _onlyOnce2 = _interopRequireDefault(_onlyOnce); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The post-check version of [`whilst`]{@link module:ControlFlow.whilst}. To reflect the difference in + * the order of operations, the arguments `test` and `iteratee` are switched. + * + * `doWhilst` is to `whilst` as `do while` is to `while` in plain JavaScript. + * + * @name doWhilst + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.whilst]{@link module:ControlFlow.whilst} + * @category Control Flow + * @param {Function} iteratee - A function which is called each time `test` + * passes. The function is passed a `callback(err)`, which must be called once + * it has completed with an optional `err` argument. Invoked with (callback). + * @param {Function} test - synchronous truth test to perform after each + * execution of `iteratee`. Invoked with Invoked with the non-error callback + * results of `iteratee`. + * @param {Function} [callback] - A callback which is called after the test + * function has failed and repeated execution of `iteratee` has stopped. + * `callback` will be passed an error and any arguments passed to the final + * `iteratee`'s callback. Invoked with (err, [results]); + */ +function doWhilst(iteratee, test, callback) { + callback = (0, _onlyOnce2.default)(callback || _noop2.default); + var next = (0, _rest2.default)(function (err, args) { + if (err) return callback(err); + if (test.apply(this, args)) return iteratee(next); + callback.apply(null, [null].concat(args)); + }); + iteratee(next); +} +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/during.js b/node_modules/mongoose/node_modules/async/during.js new file mode 100644 index 0000000..f605ada --- /dev/null +++ b/node_modules/mongoose/node_modules/async/during.js @@ -0,0 +1,71 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = during; + +var _noop = require('lodash/noop'); + +var _noop2 = _interopRequireDefault(_noop); + +var _onlyOnce = require('./internal/onlyOnce'); + +var _onlyOnce2 = _interopRequireDefault(_onlyOnce); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Like [`whilst`]{@link module:ControlFlow.whilst}, except the `test` is an asynchronous function that + * is passed a callback in the form of `function (err, truth)`. If error is + * passed to `test` or `fn`, the main callback is immediately called with the + * value of the error. + * + * @name during + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.whilst]{@link module:ControlFlow.whilst} + * @category Control Flow + * @param {Function} test - asynchronous truth test to perform before each + * execution of `fn`. Invoked with (callback). + * @param {Function} fn - A function which is called each time `test` passes. + * The function is passed a `callback(err)`, which must be called once it has + * completed with an optional `err` argument. Invoked with (callback). + * @param {Function} [callback] - A callback which is called after the test + * function has failed and repeated execution of `fn` has stopped. `callback` + * will be passed an error, if one occured, otherwise `null`. + * @example + * + * var count = 0; + * + * async.during( + * function (callback) { + * return callback(null, count < 5); + * }, + * function (callback) { + * count++; + * setTimeout(callback, 1000); + * }, + * function (err) { + * // 5 seconds have passed + * } + * ); + */ +function during(test, fn, callback) { + callback = (0, _onlyOnce2.default)(callback || _noop2.default); + + function next(err) { + if (err) return callback(err); + test(check); + } + + function check(err, truth) { + if (err) return callback(err); + if (!truth) return callback(null); + fn(next); + } + + test(check); +} +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/each.js b/node_modules/mongoose/node_modules/async/each.js new file mode 100644 index 0000000..222a176 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/each.js @@ -0,0 +1,80 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = eachLimit; + +var _eachOf = require('./eachOf'); + +var _eachOf2 = _interopRequireDefault(_eachOf); + +var _withoutIndex = require('./internal/withoutIndex'); + +var _withoutIndex2 = _interopRequireDefault(_withoutIndex); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Applies the function `iteratee` to each item in `coll`, in parallel. + * The `iteratee` is called with an item from the list, and a callback for when + * it has finished. If the `iteratee` passes an error to its `callback`, the + * main `callback` (for the `each` function) is immediately called with the + * error. + * + * Note, that since this function applies `iteratee` to each item in parallel, + * there is no guarantee that the iteratee functions will complete in order. + * + * @name each + * @static + * @memberOf module:Collections + * @method + * @alias forEach + * @category Collection + * @param {Array|Iterable|Object} coll - A collection to iterate over. + * @param {Function} iteratee - A function to apply to each item + * in `coll`. The iteratee is passed a `callback(err)` which must be called once + * it has completed. If no error has occurred, the `callback` should be run + * without arguments or with an explicit `null` argument. The array index is not + * passed to the iteratee. Invoked with (item, callback). If you need the index, + * use `eachOf`. + * @param {Function} [callback] - A callback which is called when all + * `iteratee` functions have finished, or an error occurs. Invoked with (err). + * @example + * + * // assuming openFiles is an array of file names and saveFile is a function + * // to save the modified contents of that file: + * + * async.each(openFiles, saveFile, function(err){ + * // if any of the saves produced an error, err would equal that error + * }); + * + * // assuming openFiles is an array of file names + * async.each(openFiles, function(file, callback) { + * + * // Perform operation on file here. + * console.log('Processing file ' + file); + * + * if( file.length > 32 ) { + * console.log('This file name is too long'); + * callback('File name too long'); + * } else { + * // Do work to process file here + * console.log('File processed'); + * callback(); + * } + * }, function(err) { + * // if any of the file processing produced an error, err would equal that error + * if( err ) { + * // One of the iterations produced an error. + * // All processing will now stop. + * console.log('A file failed to process'); + * } else { + * console.log('All files have been processed successfully'); + * } + * }); + */ +function eachLimit(coll, iteratee, callback) { + (0, _eachOf2.default)(coll, (0, _withoutIndex2.default)(iteratee), callback); +} +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/eachLimit.js b/node_modules/mongoose/node_modules/async/eachLimit.js new file mode 100644 index 0000000..691a405 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/eachLimit.js @@ -0,0 +1,42 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = eachLimit; + +var _eachOfLimit = require('./internal/eachOfLimit'); + +var _eachOfLimit2 = _interopRequireDefault(_eachOfLimit); + +var _withoutIndex = require('./internal/withoutIndex'); + +var _withoutIndex2 = _interopRequireDefault(_withoutIndex); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`each`]{@link module:Collections.each} but runs a maximum of `limit` async operations at a time. + * + * @name eachLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.each]{@link module:Collections.each} + * @alias forEachLimit + * @category Collection + * @param {Array|Iterable|Object} coll - A colleciton to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {Function} iteratee - A function to apply to each item in `coll`. The + * iteratee is passed a `callback(err)` which must be called once it has + * completed. If no error has occurred, the `callback` should be run without + * arguments or with an explicit `null` argument. The array index is not passed + * to the iteratee. Invoked with (item, callback). If you need the index, use + * `eachOfLimit`. + * @param {Function} [callback] - A callback which is called when all + * `iteratee` functions have finished, or an error occurs. Invoked with (err). + */ +function eachLimit(coll, limit, iteratee, callback) { + (0, _eachOfLimit2.default)(limit)(coll, (0, _withoutIndex2.default)(iteratee), callback); +} +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/eachOf.js b/node_modules/mongoose/node_modules/async/eachOf.js new file mode 100644 index 0000000..c562f4c --- /dev/null +++ b/node_modules/mongoose/node_modules/async/eachOf.js @@ -0,0 +1,105 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +exports.default = function (coll, iteratee, callback) { + var eachOfImplementation = (0, _isArrayLike2.default)(coll) ? eachOfArrayLike : eachOfGeneric; + eachOfImplementation(coll, iteratee, callback); +}; + +var _isArrayLike = require('lodash/isArrayLike'); + +var _isArrayLike2 = _interopRequireDefault(_isArrayLike); + +var _eachOfLimit = require('./eachOfLimit'); + +var _eachOfLimit2 = _interopRequireDefault(_eachOfLimit); + +var _doLimit = require('./internal/doLimit'); + +var _doLimit2 = _interopRequireDefault(_doLimit); + +var _noop = require('lodash/noop'); + +var _noop2 = _interopRequireDefault(_noop); + +var _once = require('lodash/once'); + +var _once2 = _interopRequireDefault(_once); + +var _onlyOnce = require('./internal/onlyOnce'); + +var _onlyOnce2 = _interopRequireDefault(_onlyOnce); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +// eachOf implementation optimized for array-likes +function eachOfArrayLike(coll, iteratee, callback) { + callback = (0, _once2.default)(callback || _noop2.default); + var index = 0, + completed = 0, + length = coll.length; + if (length === 0) { + callback(null); + } + + function iteratorCallback(err) { + if (err) { + callback(err); + } else if (++completed === length) { + callback(null); + } + } + + for (; index < length; index++) { + iteratee(coll[index], index, (0, _onlyOnce2.default)(iteratorCallback)); + } +} + +// a generic version of eachOf which can handle array, object, and iterator cases. +var eachOfGeneric = (0, _doLimit2.default)(_eachOfLimit2.default, Infinity); + +/** + * Like [`each`]{@link module:Collections.each}, except that it passes the key (or index) as the second argument + * to the iteratee. + * + * @name eachOf + * @static + * @memberOf module:Collections + * @method + * @alias forEachOf + * @category Collection + * @see [async.each]{@link module:Collections.each} + * @param {Array|Iterable|Object} coll - A collection to iterate over. + * @param {Function} iteratee - A function to apply to each + * item in `coll`. The `key` is the item's key, or index in the case of an + * array. The iteratee is passed a `callback(err)` which must be called once it + * has completed. If no error has occurred, the callback should be run without + * arguments or with an explicit `null` argument. Invoked with + * (item, key, callback). + * @param {Function} [callback] - A callback which is called when all + * `iteratee` functions have finished, or an error occurs. Invoked with (err). + * @example + * + * var obj = {dev: "/dev.json", test: "/test.json", prod: "/prod.json"}; + * var configs = {}; + * + * async.forEachOf(obj, function (value, key, callback) { + * fs.readFile(__dirname + value, "utf8", function (err, data) { + * if (err) return callback(err); + * try { + * configs[key] = JSON.parse(data); + * } catch (e) { + * return callback(e); + * } + * callback(); + * }); + * }, function (err) { + * if (err) console.error(err.message); + * // configs is now a map of JSON data + * doSomethingWith(configs); + * }); + */ +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/eachOfLimit.js b/node_modules/mongoose/node_modules/async/eachOfLimit.js new file mode 100644 index 0000000..a2ece1b --- /dev/null +++ b/node_modules/mongoose/node_modules/async/eachOfLimit.js @@ -0,0 +1,39 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = eachOfLimit; + +var _eachOfLimit2 = require('./internal/eachOfLimit'); + +var _eachOfLimit3 = _interopRequireDefault(_eachOfLimit2); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`eachOf`]{@link module:Collections.eachOf} but runs a maximum of `limit` async operations at a + * time. + * + * @name eachOfLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.eachOf]{@link module:Collections.eachOf} + * @alias forEachOfLimit + * @category Collection + * @param {Array|Iterable|Object} coll - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {Function} iteratee - A function to apply to each + * item in `coll`. The `key` is the item's key, or index in the case of an + * array. The iteratee is passed a `callback(err)` which must be called once it + * has completed. If no error has occurred, the callback should be run without + * arguments or with an explicit `null` argument. Invoked with + * (item, key, callback). + * @param {Function} [callback] - A callback which is called when all + * `iteratee` functions have finished, or an error occurs. Invoked with (err). + */ +function eachOfLimit(coll, limit, iteratee, callback) { + (0, _eachOfLimit3.default)(limit)(coll, iteratee, callback); +} +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/eachOfSeries.js b/node_modules/mongoose/node_modules/async/eachOfSeries.js new file mode 100644 index 0000000..968db26 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/eachOfSeries.js @@ -0,0 +1,37 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _eachOfLimit = require('./eachOfLimit'); + +var _eachOfLimit2 = _interopRequireDefault(_eachOfLimit); + +var _doLimit = require('./internal/doLimit'); + +var _doLimit2 = _interopRequireDefault(_doLimit); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`eachOf`]{@link module:Collections.eachOf} but runs only a single async operation at a time. + * + * @name eachOfSeries + * @static + * @memberOf module:Collections + * @method + * @see [async.eachOf]{@link module:Collections.eachOf} + * @alias forEachOfSeries + * @category Collection + * @param {Array|Iterable|Object} coll - A collection to iterate over. + * @param {Function} iteratee - A function to apply to each item in `coll`. The + * `key` is the item's key, or index in the case of an array. The iteratee is + * passed a `callback(err)` which must be called once it has completed. If no + * error has occurred, the callback should be run without arguments or with an + * explicit `null` argument. Invoked with (item, key, callback). + * @param {Function} [callback] - A callback which is called when all `iteratee` + * functions have finished, or an error occurs. Invoked with (err). + */ +exports.default = (0, _doLimit2.default)(_eachOfLimit2.default, 1); +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/eachSeries.js b/node_modules/mongoose/node_modules/async/eachSeries.js new file mode 100644 index 0000000..31a7456 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/eachSeries.js @@ -0,0 +1,38 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _eachLimit = require('./eachLimit'); + +var _eachLimit2 = _interopRequireDefault(_eachLimit); + +var _doLimit = require('./internal/doLimit'); + +var _doLimit2 = _interopRequireDefault(_doLimit); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`each`]{@link module:Collections.each} but runs only a single async operation at a time. + * + * @name eachSeries + * @static + * @memberOf module:Collections + * @method + * @see [async.each]{@link module:Collections.each} + * @alias forEachSeries + * @category Collection + * @param {Array|Iterable|Object} coll - A collection to iterate over. + * @param {Function} iteratee - A function to apply to each + * item in `coll`. The iteratee is passed a `callback(err)` which must be called + * once it has completed. If no error has occurred, the `callback` should be run + * without arguments or with an explicit `null` argument. The array index is + * not passed to the iteratee. Invoked with (item, callback). If you need the + * index, use `eachOfSeries`. + * @param {Function} [callback] - A callback which is called when all + * `iteratee` functions have finished, or an error occurs. Invoked with (err). + */ +exports.default = (0, _doLimit2.default)(_eachLimit2.default, 1); +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/ensureAsync.js b/node_modules/mongoose/node_modules/async/ensureAsync.js new file mode 100644 index 0000000..08e0829 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/ensureAsync.js @@ -0,0 +1,69 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = ensureAsync; + +var _setImmediate = require('./internal/setImmediate'); + +var _setImmediate2 = _interopRequireDefault(_setImmediate); + +var _initialParams = require('./internal/initialParams'); + +var _initialParams2 = _interopRequireDefault(_initialParams); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Wrap an async function and ensure it calls its callback on a later tick of + * the event loop. If the function already calls its callback on a next tick, + * no extra deferral is added. This is useful for preventing stack overflows + * (`RangeError: Maximum call stack size exceeded`) and generally keeping + * [Zalgo](http://blog.izs.me/post/59142742143/designing-apis-for-asynchrony) + * contained. + * + * @name ensureAsync + * @static + * @memberOf module:Utils + * @method + * @category Util + * @param {Function} fn - an async function, one that expects a node-style + * callback as its last argument. + * @returns {Function} Returns a wrapped function with the exact same call + * signature as the function passed in. + * @example + * + * function sometimesAsync(arg, callback) { + * if (cache[arg]) { + * return callback(null, cache[arg]); // this would be synchronous!! + * } else { + * doSomeIO(arg, callback); // this IO would be asynchronous + * } + * } + * + * // this has a risk of stack overflows if many results are cached in a row + * async.mapSeries(args, sometimesAsync, done); + * + * // this will defer sometimesAsync's callback if necessary, + * // preventing stack overflows + * async.mapSeries(args, async.ensureAsync(sometimesAsync), done); + */ +function ensureAsync(fn) { + return (0, _initialParams2.default)(function (args, callback) { + var sync = true; + args.push(function () { + var innerArgs = arguments; + if (sync) { + (0, _setImmediate2.default)(function () { + callback.apply(null, innerArgs); + }); + } else { + callback.apply(null, innerArgs); + } + }); + fn.apply(this, args); + sync = false; + }); +} +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/every.js b/node_modules/mongoose/node_modules/async/every.js new file mode 100644 index 0000000..edaa7ed --- /dev/null +++ b/node_modules/mongoose/node_modules/async/every.js @@ -0,0 +1,50 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _createTester = require('./internal/createTester'); + +var _createTester2 = _interopRequireDefault(_createTester); + +var _eachOf = require('./eachOf'); + +var _eachOf2 = _interopRequireDefault(_eachOf); + +var _notId = require('./internal/notId'); + +var _notId2 = _interopRequireDefault(_notId); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Returns `true` if every element in `coll` satisfies an async test. If any + * iteratee call returns `false`, the main `callback` is immediately called. + * + * @name every + * @static + * @memberOf module:Collections + * @method + * @alias all + * @category Collection + * @param {Array|Iterable|Object} coll - A collection to iterate over. + * @param {Function} iteratee - A truth test to apply to each item in the + * collection in parallel. The iteratee is passed a `callback(err, truthValue)` + * which must be called with a boolean argument once it has completed. Invoked + * with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Result will be either `true` or `false` + * depending on the values of the async tests. Invoked with (err, result). + * @example + * + * async.every(['file1','file2','file3'], function(filePath, callback) { + * fs.access(filePath, function(err) { + * callback(null, !err) + * }); + * }, function(err, result) { + * // if result is true then every file exists + * }); + */ +exports.default = (0, _createTester2.default)(_eachOf2.default, _notId2.default, _notId2.default); +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/everyLimit.js b/node_modules/mongoose/node_modules/async/everyLimit.js new file mode 100644 index 0000000..ef6c35a --- /dev/null +++ b/node_modules/mongoose/node_modules/async/everyLimit.js @@ -0,0 +1,42 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _createTester = require('./internal/createTester'); + +var _createTester2 = _interopRequireDefault(_createTester); + +var _eachOfLimit = require('./eachOfLimit'); + +var _eachOfLimit2 = _interopRequireDefault(_eachOfLimit); + +var _notId = require('./internal/notId'); + +var _notId2 = _interopRequireDefault(_notId); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`every`]{@link module:Collections.every} but runs a maximum of `limit` async operations at a time. + * + * @name everyLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.every]{@link module:Collections.every} + * @alias allLimit + * @category Collection + * @param {Array|Iterable|Object} coll - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {Function} iteratee - A truth test to apply to each item in the + * collection in parallel. The iteratee is passed a `callback(err, truthValue)` + * which must be called with a boolean argument once it has completed. Invoked + * with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Result will be either `true` or `false` + * depending on the values of the async tests. Invoked with (err, result). + */ +exports.default = (0, _createTester2.default)(_eachOfLimit2.default, _notId2.default, _notId2.default); +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/everySeries.js b/node_modules/mongoose/node_modules/async/everySeries.js new file mode 100644 index 0000000..5ed1c1a --- /dev/null +++ b/node_modules/mongoose/node_modules/async/everySeries.js @@ -0,0 +1,37 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _everyLimit = require('./everyLimit'); + +var _everyLimit2 = _interopRequireDefault(_everyLimit); + +var _doLimit = require('./internal/doLimit'); + +var _doLimit2 = _interopRequireDefault(_doLimit); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`every`]{@link module:Collections.every} but runs only a single async operation at a time. + * + * @name everySeries + * @static + * @memberOf module:Collections + * @method + * @see [async.every]{@link module:Collections.every} + * @alias allSeries + * @category Collection + * @param {Array|Iterable|Object} coll - A collection to iterate over. + * @param {Function} iteratee - A truth test to apply to each item in the + * collection in parallel. The iteratee is passed a `callback(err, truthValue)` + * which must be called with a boolean argument once it has completed. Invoked + * with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Result will be either `true` or `false` + * depending on the values of the async tests. Invoked with (err, result). + */ +exports.default = (0, _doLimit2.default)(_everyLimit2.default, 1); +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/filter.js b/node_modules/mongoose/node_modules/async/filter.js new file mode 100644 index 0000000..54772d5 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/filter.js @@ -0,0 +1,45 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _filter = require('./internal/filter'); + +var _filter2 = _interopRequireDefault(_filter); + +var _doParallel = require('./internal/doParallel'); + +var _doParallel2 = _interopRequireDefault(_doParallel); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Returns a new array of all the values in `coll` which pass an async truth + * test. This operation is performed in parallel, but the results array will be + * in the same order as the original. + * + * @name filter + * @static + * @memberOf module:Collections + * @method + * @alias select + * @category Collection + * @param {Array|Iterable|Object} coll - A collection to iterate over. + * @param {Function} iteratee - A truth test to apply to each item in `coll`. + * The `iteratee` is passed a `callback(err, truthValue)`, which must be called + * with a boolean argument once it has completed. Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Invoked with (err, results). + * @example + * + * async.filter(['file1','file2','file3'], function(filePath, callback) { + * fs.access(filePath, function(err) { + * callback(null, !err) + * }); + * }, function(err, results) { + * // results now equals an array of the existing files + * }); + */ +exports.default = (0, _doParallel2.default)(_filter2.default); +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/filterLimit.js b/node_modules/mongoose/node_modules/async/filterLimit.js new file mode 100644 index 0000000..06216f7 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/filterLimit.js @@ -0,0 +1,37 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _filter = require('./internal/filter'); + +var _filter2 = _interopRequireDefault(_filter); + +var _doParallelLimit = require('./internal/doParallelLimit'); + +var _doParallelLimit2 = _interopRequireDefault(_doParallelLimit); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`filter`]{@link module:Collections.filter} but runs a maximum of `limit` async operations at a + * time. + * + * @name filterLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.filter]{@link module:Collections.filter} + * @alias selectLimit + * @category Collection + * @param {Array|Iterable|Object} coll - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {Function} iteratee - A truth test to apply to each item in `coll`. + * The `iteratee` is passed a `callback(err, truthValue)`, which must be called + * with a boolean argument once it has completed. Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Invoked with (err, results). + */ +exports.default = (0, _doParallelLimit2.default)(_filter2.default); +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/filterSeries.js b/node_modules/mongoose/node_modules/async/filterSeries.js new file mode 100644 index 0000000..e48d966 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/filterSeries.js @@ -0,0 +1,35 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _filterLimit = require('./filterLimit'); + +var _filterLimit2 = _interopRequireDefault(_filterLimit); + +var _doLimit = require('./internal/doLimit'); + +var _doLimit2 = _interopRequireDefault(_doLimit); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`filter`]{@link module:Collections.filter} but runs only a single async operation at a time. + * + * @name filterSeries + * @static + * @memberOf module:Collections + * @method + * @see [async.filter]{@link module:Collections.filter} + * @alias selectSeries + * @category Collection + * @param {Array|Iterable|Object} coll - A collection to iterate over. + * @param {Function} iteratee - A truth test to apply to each item in `coll`. + * The `iteratee` is passed a `callback(err, truthValue)`, which must be called + * with a boolean argument once it has completed. Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Invoked with (err, results) + */ +exports.default = (0, _doLimit2.default)(_filterLimit2.default, 1); +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/forever.js b/node_modules/mongoose/node_modules/async/forever.js new file mode 100644 index 0000000..87156d0 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/forever.js @@ -0,0 +1,61 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = forever; + +var _noop = require('lodash/noop'); + +var _noop2 = _interopRequireDefault(_noop); + +var _onlyOnce = require('./internal/onlyOnce'); + +var _onlyOnce2 = _interopRequireDefault(_onlyOnce); + +var _ensureAsync = require('./ensureAsync'); + +var _ensureAsync2 = _interopRequireDefault(_ensureAsync); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Calls the asynchronous function `fn` with a callback parameter that allows it + * to call itself again, in series, indefinitely. + + * If an error is passed to the + * callback then `errback` is called with the error, and execution stops, + * otherwise it will never be called. + * + * @name forever + * @static + * @memberOf module:ControlFlow + * @method + * @category Control Flow + * @param {Function} fn - a function to call repeatedly. Invoked with (next). + * @param {Function} [errback] - when `fn` passes an error to it's callback, + * this function will be called, and execution stops. Invoked with (err). + * @example + * + * async.forever( + * function(next) { + * // next is suitable for passing to things that need a callback(err [, whatever]); + * // it will result in this function being called again. + * }, + * function(err) { + * // if next is called with a value in its first parameter, it will appear + * // in here as 'err', and execution will stop. + * } + * ); + */ +function forever(fn, errback) { + var done = (0, _onlyOnce2.default)(errback || _noop2.default); + var task = (0, _ensureAsync2.default)(fn); + + function next(err) { + if (err) return done(err); + task(next); + } + next(); +} +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/index.js b/node_modules/mongoose/node_modules/async/index.js new file mode 100644 index 0000000..b3595c7 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/index.js @@ -0,0 +1,505 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.wrapSync = exports.selectSeries = exports.selectLimit = exports.select = exports.foldr = exports.foldl = exports.inject = exports.forEachOfLimit = exports.forEachOfSeries = exports.forEachOf = exports.forEachLimit = exports.forEachSeries = exports.forEach = exports.findSeries = exports.findLimit = exports.find = exports.anySeries = exports.anyLimit = exports.any = exports.allSeries = exports.allLimit = exports.all = exports.whilst = exports.waterfall = exports.until = exports.unmemoize = exports.transform = exports.timesSeries = exports.timesLimit = exports.times = exports.timeout = exports.sortBy = exports.someSeries = exports.someLimit = exports.some = exports.setImmediate = exports.series = exports.seq = exports.retryable = exports.retry = exports.rejectSeries = exports.rejectLimit = exports.reject = exports.reflectAll = exports.reflect = exports.reduceRight = exports.reduce = exports.race = exports.queue = exports.priorityQueue = exports.parallelLimit = exports.parallel = exports.nextTick = exports.memoize = exports.mapValuesSeries = exports.mapValuesLimit = exports.mapValues = exports.mapSeries = exports.mapLimit = exports.map = exports.log = exports.forever = exports.filterSeries = exports.filterLimit = exports.filter = exports.everySeries = exports.everyLimit = exports.every = exports.ensureAsync = exports.eachSeries = exports.eachOfSeries = exports.eachOfLimit = exports.eachOf = exports.eachLimit = exports.each = exports.during = exports.doWhilst = exports.doUntil = exports.doDuring = exports.dir = exports.detectSeries = exports.detectLimit = exports.detect = exports.constant = exports.concatSeries = exports.concat = exports.compose = exports.cargo = exports.autoInject = exports.auto = exports.asyncify = exports.apply = exports.applyEachSeries = exports.applyEach = undefined; + +var _applyEach = require('./applyEach'); + +var _applyEach2 = _interopRequireDefault(_applyEach); + +var _applyEachSeries = require('./applyEachSeries'); + +var _applyEachSeries2 = _interopRequireDefault(_applyEachSeries); + +var _apply = require('./apply'); + +var _apply2 = _interopRequireDefault(_apply); + +var _asyncify = require('./asyncify'); + +var _asyncify2 = _interopRequireDefault(_asyncify); + +var _auto = require('./auto'); + +var _auto2 = _interopRequireDefault(_auto); + +var _autoInject = require('./autoInject'); + +var _autoInject2 = _interopRequireDefault(_autoInject); + +var _cargo = require('./cargo'); + +var _cargo2 = _interopRequireDefault(_cargo); + +var _compose = require('./compose'); + +var _compose2 = _interopRequireDefault(_compose); + +var _concat = require('./concat'); + +var _concat2 = _interopRequireDefault(_concat); + +var _concatSeries = require('./concatSeries'); + +var _concatSeries2 = _interopRequireDefault(_concatSeries); + +var _constant = require('./constant'); + +var _constant2 = _interopRequireDefault(_constant); + +var _detect = require('./detect'); + +var _detect2 = _interopRequireDefault(_detect); + +var _detectLimit = require('./detectLimit'); + +var _detectLimit2 = _interopRequireDefault(_detectLimit); + +var _detectSeries = require('./detectSeries'); + +var _detectSeries2 = _interopRequireDefault(_detectSeries); + +var _dir = require('./dir'); + +var _dir2 = _interopRequireDefault(_dir); + +var _doDuring = require('./doDuring'); + +var _doDuring2 = _interopRequireDefault(_doDuring); + +var _doUntil = require('./doUntil'); + +var _doUntil2 = _interopRequireDefault(_doUntil); + +var _doWhilst = require('./doWhilst'); + +var _doWhilst2 = _interopRequireDefault(_doWhilst); + +var _during = require('./during'); + +var _during2 = _interopRequireDefault(_during); + +var _each = require('./each'); + +var _each2 = _interopRequireDefault(_each); + +var _eachLimit = require('./eachLimit'); + +var _eachLimit2 = _interopRequireDefault(_eachLimit); + +var _eachOf = require('./eachOf'); + +var _eachOf2 = _interopRequireDefault(_eachOf); + +var _eachOfLimit = require('./eachOfLimit'); + +var _eachOfLimit2 = _interopRequireDefault(_eachOfLimit); + +var _eachOfSeries = require('./eachOfSeries'); + +var _eachOfSeries2 = _interopRequireDefault(_eachOfSeries); + +var _eachSeries = require('./eachSeries'); + +var _eachSeries2 = _interopRequireDefault(_eachSeries); + +var _ensureAsync = require('./ensureAsync'); + +var _ensureAsync2 = _interopRequireDefault(_ensureAsync); + +var _every = require('./every'); + +var _every2 = _interopRequireDefault(_every); + +var _everyLimit = require('./everyLimit'); + +var _everyLimit2 = _interopRequireDefault(_everyLimit); + +var _everySeries = require('./everySeries'); + +var _everySeries2 = _interopRequireDefault(_everySeries); + +var _filter = require('./filter'); + +var _filter2 = _interopRequireDefault(_filter); + +var _filterLimit = require('./filterLimit'); + +var _filterLimit2 = _interopRequireDefault(_filterLimit); + +var _filterSeries = require('./filterSeries'); + +var _filterSeries2 = _interopRequireDefault(_filterSeries); + +var _forever = require('./forever'); + +var _forever2 = _interopRequireDefault(_forever); + +var _log = require('./log'); + +var _log2 = _interopRequireDefault(_log); + +var _map = require('./map'); + +var _map2 = _interopRequireDefault(_map); + +var _mapLimit = require('./mapLimit'); + +var _mapLimit2 = _interopRequireDefault(_mapLimit); + +var _mapSeries = require('./mapSeries'); + +var _mapSeries2 = _interopRequireDefault(_mapSeries); + +var _mapValues = require('./mapValues'); + +var _mapValues2 = _interopRequireDefault(_mapValues); + +var _mapValuesLimit = require('./mapValuesLimit'); + +var _mapValuesLimit2 = _interopRequireDefault(_mapValuesLimit); + +var _mapValuesSeries = require('./mapValuesSeries'); + +var _mapValuesSeries2 = _interopRequireDefault(_mapValuesSeries); + +var _memoize = require('./memoize'); + +var _memoize2 = _interopRequireDefault(_memoize); + +var _nextTick = require('./nextTick'); + +var _nextTick2 = _interopRequireDefault(_nextTick); + +var _parallel = require('./parallel'); + +var _parallel2 = _interopRequireDefault(_parallel); + +var _parallelLimit = require('./parallelLimit'); + +var _parallelLimit2 = _interopRequireDefault(_parallelLimit); + +var _priorityQueue = require('./priorityQueue'); + +var _priorityQueue2 = _interopRequireDefault(_priorityQueue); + +var _queue = require('./queue'); + +var _queue2 = _interopRequireDefault(_queue); + +var _race = require('./race'); + +var _race2 = _interopRequireDefault(_race); + +var _reduce = require('./reduce'); + +var _reduce2 = _interopRequireDefault(_reduce); + +var _reduceRight = require('./reduceRight'); + +var _reduceRight2 = _interopRequireDefault(_reduceRight); + +var _reflect = require('./reflect'); + +var _reflect2 = _interopRequireDefault(_reflect); + +var _reject = require('./reject'); + +var _reject2 = _interopRequireDefault(_reject); + +var _reflectAll = require('./reflectAll'); + +var _reflectAll2 = _interopRequireDefault(_reflectAll); + +var _rejectLimit = require('./rejectLimit'); + +var _rejectLimit2 = _interopRequireDefault(_rejectLimit); + +var _rejectSeries = require('./rejectSeries'); + +var _rejectSeries2 = _interopRequireDefault(_rejectSeries); + +var _retry = require('./retry'); + +var _retry2 = _interopRequireDefault(_retry); + +var _retryable = require('./retryable'); + +var _retryable2 = _interopRequireDefault(_retryable); + +var _seq = require('./seq'); + +var _seq2 = _interopRequireDefault(_seq); + +var _series = require('./series'); + +var _series2 = _interopRequireDefault(_series); + +var _setImmediate = require('./setImmediate'); + +var _setImmediate2 = _interopRequireDefault(_setImmediate); + +var _some = require('./some'); + +var _some2 = _interopRequireDefault(_some); + +var _someLimit = require('./someLimit'); + +var _someLimit2 = _interopRequireDefault(_someLimit); + +var _someSeries = require('./someSeries'); + +var _someSeries2 = _interopRequireDefault(_someSeries); + +var _sortBy = require('./sortBy'); + +var _sortBy2 = _interopRequireDefault(_sortBy); + +var _timeout = require('./timeout'); + +var _timeout2 = _interopRequireDefault(_timeout); + +var _times = require('./times'); + +var _times2 = _interopRequireDefault(_times); + +var _timesLimit = require('./timesLimit'); + +var _timesLimit2 = _interopRequireDefault(_timesLimit); + +var _timesSeries = require('./timesSeries'); + +var _timesSeries2 = _interopRequireDefault(_timesSeries); + +var _transform = require('./transform'); + +var _transform2 = _interopRequireDefault(_transform); + +var _unmemoize = require('./unmemoize'); + +var _unmemoize2 = _interopRequireDefault(_unmemoize); + +var _until = require('./until'); + +var _until2 = _interopRequireDefault(_until); + +var _waterfall = require('./waterfall'); + +var _waterfall2 = _interopRequireDefault(_waterfall); + +var _whilst = require('./whilst'); + +var _whilst2 = _interopRequireDefault(_whilst); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Async is a utility module which provides straight-forward, powerful functions + * for working with asynchronous JavaScript. Although originally designed for + * use with [Node.js](http://nodejs.org) and installable via + * `npm install --save async`, it can also be used directly in the browser. + * @module async + */ + +/** + * A collection of `async` functions for manipulating collections, such as + * arrays and objects. + * @module Collections + */ + +/** + * A collection of `async` functions for controlling the flow through a script. + * @module ControlFlow + */ + +/** + * A collection of `async` utility functions. + * @module Utils + */ +exports.default = { + applyEach: _applyEach2.default, + applyEachSeries: _applyEachSeries2.default, + apply: _apply2.default, + asyncify: _asyncify2.default, + auto: _auto2.default, + autoInject: _autoInject2.default, + cargo: _cargo2.default, + compose: _compose2.default, + concat: _concat2.default, + concatSeries: _concatSeries2.default, + constant: _constant2.default, + detect: _detect2.default, + detectLimit: _detectLimit2.default, + detectSeries: _detectSeries2.default, + dir: _dir2.default, + doDuring: _doDuring2.default, + doUntil: _doUntil2.default, + doWhilst: _doWhilst2.default, + during: _during2.default, + each: _each2.default, + eachLimit: _eachLimit2.default, + eachOf: _eachOf2.default, + eachOfLimit: _eachOfLimit2.default, + eachOfSeries: _eachOfSeries2.default, + eachSeries: _eachSeries2.default, + ensureAsync: _ensureAsync2.default, + every: _every2.default, + everyLimit: _everyLimit2.default, + everySeries: _everySeries2.default, + filter: _filter2.default, + filterLimit: _filterLimit2.default, + filterSeries: _filterSeries2.default, + forever: _forever2.default, + log: _log2.default, + map: _map2.default, + mapLimit: _mapLimit2.default, + mapSeries: _mapSeries2.default, + mapValues: _mapValues2.default, + mapValuesLimit: _mapValuesLimit2.default, + mapValuesSeries: _mapValuesSeries2.default, + memoize: _memoize2.default, + nextTick: _nextTick2.default, + parallel: _parallel2.default, + parallelLimit: _parallelLimit2.default, + priorityQueue: _priorityQueue2.default, + queue: _queue2.default, + race: _race2.default, + reduce: _reduce2.default, + reduceRight: _reduceRight2.default, + reflect: _reflect2.default, + reflectAll: _reflectAll2.default, + reject: _reject2.default, + rejectLimit: _rejectLimit2.default, + rejectSeries: _rejectSeries2.default, + retry: _retry2.default, + retryable: _retryable2.default, + seq: _seq2.default, + series: _series2.default, + setImmediate: _setImmediate2.default, + some: _some2.default, + someLimit: _someLimit2.default, + someSeries: _someSeries2.default, + sortBy: _sortBy2.default, + timeout: _timeout2.default, + times: _times2.default, + timesLimit: _timesLimit2.default, + timesSeries: _timesSeries2.default, + transform: _transform2.default, + unmemoize: _unmemoize2.default, + until: _until2.default, + waterfall: _waterfall2.default, + whilst: _whilst2.default, + + // aliases + all: _every2.default, + any: _some2.default, + forEach: _each2.default, + forEachSeries: _eachSeries2.default, + forEachLimit: _eachLimit2.default, + forEachOf: _eachOf2.default, + forEachOfSeries: _eachOfSeries2.default, + forEachOfLimit: _eachOfLimit2.default, + inject: _reduce2.default, + foldl: _reduce2.default, + foldr: _reduceRight2.default, + select: _filter2.default, + selectLimit: _filterLimit2.default, + selectSeries: _filterSeries2.default, + wrapSync: _asyncify2.default +}; +exports.applyEach = _applyEach2.default; +exports.applyEachSeries = _applyEachSeries2.default; +exports.apply = _apply2.default; +exports.asyncify = _asyncify2.default; +exports.auto = _auto2.default; +exports.autoInject = _autoInject2.default; +exports.cargo = _cargo2.default; +exports.compose = _compose2.default; +exports.concat = _concat2.default; +exports.concatSeries = _concatSeries2.default; +exports.constant = _constant2.default; +exports.detect = _detect2.default; +exports.detectLimit = _detectLimit2.default; +exports.detectSeries = _detectSeries2.default; +exports.dir = _dir2.default; +exports.doDuring = _doDuring2.default; +exports.doUntil = _doUntil2.default; +exports.doWhilst = _doWhilst2.default; +exports.during = _during2.default; +exports.each = _each2.default; +exports.eachLimit = _eachLimit2.default; +exports.eachOf = _eachOf2.default; +exports.eachOfLimit = _eachOfLimit2.default; +exports.eachOfSeries = _eachOfSeries2.default; +exports.eachSeries = _eachSeries2.default; +exports.ensureAsync = _ensureAsync2.default; +exports.every = _every2.default; +exports.everyLimit = _everyLimit2.default; +exports.everySeries = _everySeries2.default; +exports.filter = _filter2.default; +exports.filterLimit = _filterLimit2.default; +exports.filterSeries = _filterSeries2.default; +exports.forever = _forever2.default; +exports.log = _log2.default; +exports.map = _map2.default; +exports.mapLimit = _mapLimit2.default; +exports.mapSeries = _mapSeries2.default; +exports.mapValues = _mapValues2.default; +exports.mapValuesLimit = _mapValuesLimit2.default; +exports.mapValuesSeries = _mapValuesSeries2.default; +exports.memoize = _memoize2.default; +exports.nextTick = _nextTick2.default; +exports.parallel = _parallel2.default; +exports.parallelLimit = _parallelLimit2.default; +exports.priorityQueue = _priorityQueue2.default; +exports.queue = _queue2.default; +exports.race = _race2.default; +exports.reduce = _reduce2.default; +exports.reduceRight = _reduceRight2.default; +exports.reflect = _reflect2.default; +exports.reflectAll = _reflectAll2.default; +exports.reject = _reject2.default; +exports.rejectLimit = _rejectLimit2.default; +exports.rejectSeries = _rejectSeries2.default; +exports.retry = _retry2.default; +exports.retryable = _retryable2.default; +exports.seq = _seq2.default; +exports.series = _series2.default; +exports.setImmediate = _setImmediate2.default; +exports.some = _some2.default; +exports.someLimit = _someLimit2.default; +exports.someSeries = _someSeries2.default; +exports.sortBy = _sortBy2.default; +exports.timeout = _timeout2.default; +exports.times = _times2.default; +exports.timesLimit = _timesLimit2.default; +exports.timesSeries = _timesSeries2.default; +exports.transform = _transform2.default; +exports.unmemoize = _unmemoize2.default; +exports.until = _until2.default; +exports.waterfall = _waterfall2.default; +exports.whilst = _whilst2.default; +exports.all = _every2.default; +exports.allLimit = _everyLimit2.default; +exports.allSeries = _everySeries2.default; +exports.any = _some2.default; +exports.anyLimit = _someLimit2.default; +exports.anySeries = _someSeries2.default; +exports.find = _detect2.default; +exports.findLimit = _detectLimit2.default; +exports.findSeries = _detectSeries2.default; +exports.forEach = _each2.default; +exports.forEachSeries = _eachSeries2.default; +exports.forEachLimit = _eachLimit2.default; +exports.forEachOf = _eachOf2.default; +exports.forEachOfSeries = _eachOfSeries2.default; +exports.forEachOfLimit = _eachOfLimit2.default; +exports.inject = _reduce2.default; +exports.foldl = _reduce2.default; +exports.foldr = _reduceRight2.default; +exports.select = _filter2.default; +exports.selectLimit = _filterLimit2.default; +exports.selectSeries = _filterSeries2.default; +exports.wrapSync = _asyncify2.default; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/internal/DoublyLinkedList.js b/node_modules/mongoose/node_modules/async/internal/DoublyLinkedList.js new file mode 100644 index 0000000..7af3b5f --- /dev/null +++ b/node_modules/mongoose/node_modules/async/internal/DoublyLinkedList.js @@ -0,0 +1,63 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = DLL; +// Simple doubly linked list (https://en.wikipedia.org/wiki/Doubly_linked_list) implementation +// used for queues. This implementation assumes that the node provided by the user can be modified +// to adjust the next and last properties. We implement only the minimal functionality +// for queue support. +function DLL() { + this.head = this.tail = null; + this.length = 0; +} + +function setInitial(dll, node) { + dll.length = 1; + dll.head = dll.tail = node; +} + +DLL.prototype.removeLink = function (node) { + if (node.prev) node.prev.next = node.next;else this.head = node.next; + if (node.next) node.next.prev = node.prev;else this.tail = node.prev; + + node.prev = node.next = null; + this.length -= 1; + return node; +}; + +DLL.prototype.empty = DLL; + +DLL.prototype.insertAfter = function (node, newNode) { + newNode.prev = node; + newNode.next = node.next; + if (node.next) node.next.prev = newNode;else this.tail = newNode; + node.next = newNode; + this.length += 1; +}; + +DLL.prototype.insertBefore = function (node, newNode) { + newNode.prev = node.prev; + newNode.next = node; + if (node.prev) node.prev.next = newNode;else this.head = newNode; + node.prev = newNode; + this.length += 1; +}; + +DLL.prototype.unshift = function (node) { + if (this.head) this.insertBefore(this.head, node);else setInitial(this, node); +}; + +DLL.prototype.push = function (node) { + if (this.tail) this.insertAfter(this.tail, node);else setInitial(this, node); +}; + +DLL.prototype.shift = function () { + return this.head && this.removeLink(this.head); +}; + +DLL.prototype.pop = function () { + return this.tail && this.removeLink(this.tail); +}; +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/internal/applyEach.js b/node_modules/mongoose/node_modules/async/internal/applyEach.js new file mode 100644 index 0000000..4035bfb --- /dev/null +++ b/node_modules/mongoose/node_modules/async/internal/applyEach.js @@ -0,0 +1,33 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = applyEach; + +var _rest = require('lodash/rest'); + +var _rest2 = _interopRequireDefault(_rest); + +var _initialParams = require('./initialParams'); + +var _initialParams2 = _interopRequireDefault(_initialParams); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +function applyEach(eachfn) { + return (0, _rest2.default)(function (fns, args) { + var go = (0, _initialParams2.default)(function (args, callback) { + var that = this; + return eachfn(fns, function (fn, cb) { + fn.apply(that, args.concat([cb])); + }, callback); + }); + if (args.length) { + return go.apply(this, args); + } else { + return go; + } + }); +} +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/internal/concat.js b/node_modules/mongoose/node_modules/async/internal/concat.js new file mode 100644 index 0000000..2203087 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/internal/concat.js @@ -0,0 +1,18 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = concat; +function concat(eachfn, arr, fn, callback) { + var result = []; + eachfn(arr, function (x, index, cb) { + fn(x, function (err, y) { + result = result.concat(y || []); + cb(err); + }); + }, function (err) { + callback(err, result); + }); +} +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/internal/consoleFunc.js b/node_modules/mongoose/node_modules/async/internal/consoleFunc.js new file mode 100644 index 0000000..f7befa8 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/internal/consoleFunc.js @@ -0,0 +1,35 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = consoleFunc; + +var _arrayEach = require('lodash/_arrayEach'); + +var _arrayEach2 = _interopRequireDefault(_arrayEach); + +var _rest = require('lodash/rest'); + +var _rest2 = _interopRequireDefault(_rest); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +function consoleFunc(name) { + return (0, _rest2.default)(function (fn, args) { + fn.apply(null, args.concat([(0, _rest2.default)(function (err, args) { + if (typeof console === 'object') { + if (err) { + if (console.error) { + console.error(err); + } + } else if (console[name]) { + (0, _arrayEach2.default)(args, function (x) { + console[name](x); + }); + } + } + })])); + }); +} +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/internal/createTester.js b/node_modules/mongoose/node_modules/async/internal/createTester.js new file mode 100644 index 0000000..4ec5db3 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/internal/createTester.js @@ -0,0 +1,51 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = _createTester; + +var _noop = require('lodash/noop'); + +var _noop2 = _interopRequireDefault(_noop); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +function _createTester(eachfn, check, getResult) { + return function (arr, limit, iteratee, cb) { + function done(err) { + if (cb) { + if (err) { + cb(err); + } else { + cb(null, getResult(false)); + } + } + } + function wrappedIteratee(x, _, callback) { + if (!cb) return callback(); + iteratee(x, function (err, v) { + if (cb) { + if (err) { + cb(err); + cb = iteratee = false; + } else if (check(v)) { + cb(null, getResult(true, x)); + cb = iteratee = false; + } + } + callback(); + }); + } + if (arguments.length > 3) { + cb = cb || _noop2.default; + eachfn(arr, limit, wrappedIteratee, done); + } else { + cb = iteratee; + cb = cb || _noop2.default; + iteratee = limit; + eachfn(arr, wrappedIteratee, done); + } + }; +} +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/internal/doLimit.js b/node_modules/mongoose/node_modules/async/internal/doLimit.js new file mode 100644 index 0000000..5bd5a75 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/internal/doLimit.js @@ -0,0 +1,12 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = doLimit; +function doLimit(fn, limit) { + return function (iterable, iteratee, callback) { + return fn(iterable, limit, iteratee, callback); + }; +} +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/internal/doParallel.js b/node_modules/mongoose/node_modules/async/internal/doParallel.js new file mode 100644 index 0000000..f4a30ee --- /dev/null +++ b/node_modules/mongoose/node_modules/async/internal/doParallel.js @@ -0,0 +1,19 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = doParallel; + +var _eachOf = require('../eachOf'); + +var _eachOf2 = _interopRequireDefault(_eachOf); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +function doParallel(fn) { + return function (obj, iteratee, callback) { + return fn(_eachOf2.default, obj, iteratee, callback); + }; +} +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/internal/doParallelLimit.js b/node_modules/mongoose/node_modules/async/internal/doParallelLimit.js new file mode 100644 index 0000000..4c4d3b4 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/internal/doParallelLimit.js @@ -0,0 +1,19 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = doParallelLimit; + +var _eachOfLimit = require('./eachOfLimit'); + +var _eachOfLimit2 = _interopRequireDefault(_eachOfLimit); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +function doParallelLimit(fn) { + return function (obj, limit, iteratee, callback) { + return fn((0, _eachOfLimit2.default)(limit), obj, iteratee, callback); + }; +} +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/internal/doSeries.js b/node_modules/mongoose/node_modules/async/internal/doSeries.js new file mode 100644 index 0000000..b149d95 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/internal/doSeries.js @@ -0,0 +1,19 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = doSeries; + +var _eachOfSeries = require('../eachOfSeries'); + +var _eachOfSeries2 = _interopRequireDefault(_eachOfSeries); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +function doSeries(fn) { + return function (obj, iteratee, callback) { + return fn(_eachOfSeries2.default, obj, iteratee, callback); + }; +} +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/internal/eachOfLimit.js b/node_modules/mongoose/node_modules/async/internal/eachOfLimit.js new file mode 100644 index 0000000..27a94bf --- /dev/null +++ b/node_modules/mongoose/node_modules/async/internal/eachOfLimit.js @@ -0,0 +1,66 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = _eachOfLimit; + +var _noop = require('lodash/noop'); + +var _noop2 = _interopRequireDefault(_noop); + +var _once = require('./once'); + +var _once2 = _interopRequireDefault(_once); + +var _iterator = require('./iterator'); + +var _iterator2 = _interopRequireDefault(_iterator); + +var _onlyOnce = require('./onlyOnce'); + +var _onlyOnce2 = _interopRequireDefault(_onlyOnce); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +function _eachOfLimit(limit) { + return function (obj, iteratee, callback) { + callback = (0, _once2.default)(callback || _noop2.default); + if (limit <= 0 || !obj) { + return callback(null); + } + var nextElem = (0, _iterator2.default)(obj); + var done = false; + var running = 0; + + function iterateeCallback(err) { + running -= 1; + if (err) { + done = true; + callback(err); + } else if (done && running <= 0) { + return callback(null); + } else { + replenish(); + } + } + + function replenish() { + while (running < limit && !done) { + var elem = nextElem(); + if (elem === null) { + done = true; + if (running <= 0) { + callback(null); + } + return; + } + running += 1; + iteratee(elem.value, elem.key, (0, _onlyOnce2.default)(iterateeCallback)); + } + } + + replenish(); + }; +} +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/internal/filter.js b/node_modules/mongoose/node_modules/async/internal/filter.js new file mode 100644 index 0000000..ff163e9 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/internal/filter.js @@ -0,0 +1,50 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = _filter; + +var _arrayMap = require('lodash/_arrayMap'); + +var _arrayMap2 = _interopRequireDefault(_arrayMap); + +var _baseProperty = require('lodash/_baseProperty'); + +var _baseProperty2 = _interopRequireDefault(_baseProperty); + +var _noop = require('lodash/noop'); + +var _noop2 = _interopRequireDefault(_noop); + +var _once = require('./once'); + +var _once2 = _interopRequireDefault(_once); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +function _filter(eachfn, arr, iteratee, callback) { + callback = (0, _once2.default)(callback || _noop2.default); + var results = []; + eachfn(arr, function (x, index, callback) { + iteratee(x, function (err, v) { + if (err) { + callback(err); + } else { + if (v) { + results.push({ index: index, value: x }); + } + callback(); + } + }); + }, function (err) { + if (err) { + callback(err); + } else { + callback(null, (0, _arrayMap2.default)(results.sort(function (a, b) { + return a.index - b.index; + }), (0, _baseProperty2.default)('value'))); + } + }); +} +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/internal/findGetResult.js b/node_modules/mongoose/node_modules/async/internal/findGetResult.js new file mode 100644 index 0000000..e686a70 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/internal/findGetResult.js @@ -0,0 +1,10 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = _findGetResult; +function _findGetResult(v, x) { + return x; +} +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/internal/getIterator.js b/node_modules/mongoose/node_modules/async/internal/getIterator.js new file mode 100644 index 0000000..3eadd24 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/internal/getIterator.js @@ -0,0 +1,13 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +exports.default = function (coll) { + return iteratorSymbol && coll[iteratorSymbol] && coll[iteratorSymbol](); +}; + +var iteratorSymbol = typeof Symbol === 'function' && Symbol.iterator; + +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/internal/initialParams.js b/node_modules/mongoose/node_modules/async/internal/initialParams.js new file mode 100644 index 0000000..2449320 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/internal/initialParams.js @@ -0,0 +1,20 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +exports.default = function (fn) { + return (0, _rest2.default)(function (args /*..., callback*/) { + var callback = args.pop(); + fn.call(this, args, callback); + }); +}; + +var _rest = require('lodash/rest'); + +var _rest2 = _interopRequireDefault(_rest); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/internal/iterator.js b/node_modules/mongoose/node_modules/async/internal/iterator.js new file mode 100644 index 0000000..3d32942 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/internal/iterator.js @@ -0,0 +1,58 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = iterator; + +var _isArrayLike = require('lodash/isArrayLike'); + +var _isArrayLike2 = _interopRequireDefault(_isArrayLike); + +var _getIterator = require('./getIterator'); + +var _getIterator2 = _interopRequireDefault(_getIterator); + +var _keys = require('lodash/keys'); + +var _keys2 = _interopRequireDefault(_keys); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +function createArrayIterator(coll) { + var i = -1; + var len = coll.length; + return function next() { + return ++i < len ? { value: coll[i], key: i } : null; + }; +} + +function createES2015Iterator(iterator) { + var i = -1; + return function next() { + var item = iterator.next(); + if (item.done) return null; + i++; + return { value: item.value, key: i }; + }; +} + +function createObjectIterator(obj) { + var okeys = (0, _keys2.default)(obj); + var i = -1; + var len = okeys.length; + return function next() { + var key = okeys[++i]; + return i < len ? { value: obj[key], key: key } : null; + }; +} + +function iterator(coll) { + if ((0, _isArrayLike2.default)(coll)) { + return createArrayIterator(coll); + } + + var iterator = (0, _getIterator2.default)(coll); + return iterator ? createES2015Iterator(iterator) : createObjectIterator(coll); +} +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/internal/map.js b/node_modules/mongoose/node_modules/async/internal/map.js new file mode 100644 index 0000000..e303d83 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/internal/map.js @@ -0,0 +1,34 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = _asyncMap; + +var _noop = require('lodash/noop'); + +var _noop2 = _interopRequireDefault(_noop); + +var _once = require('./once'); + +var _once2 = _interopRequireDefault(_once); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +function _asyncMap(eachfn, arr, iteratee, callback) { + callback = (0, _once2.default)(callback || _noop2.default); + arr = arr || []; + var results = []; + var counter = 0; + + eachfn(arr, function (value, _, callback) { + var index = counter++; + iteratee(value, function (err, v) { + results[index] = v; + callback(err); + }); + }, function (err) { + callback(err, results); + }); +} +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/internal/notId.js b/node_modules/mongoose/node_modules/async/internal/notId.js new file mode 100644 index 0000000..e0b471d --- /dev/null +++ b/node_modules/mongoose/node_modules/async/internal/notId.js @@ -0,0 +1,10 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = notId; +function notId(v) { + return !v; +} +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/internal/once.js b/node_modules/mongoose/node_modules/async/internal/once.js new file mode 100644 index 0000000..a0e46cd --- /dev/null +++ b/node_modules/mongoose/node_modules/async/internal/once.js @@ -0,0 +1,15 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = once; +function once(fn) { + return function () { + if (fn === null) return; + var callFn = fn; + fn = null; + callFn.apply(this, arguments); + }; +} +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/internal/onlyOnce.js b/node_modules/mongoose/node_modules/async/internal/onlyOnce.js new file mode 100644 index 0000000..9892f96 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/internal/onlyOnce.js @@ -0,0 +1,15 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = onlyOnce; +function onlyOnce(fn) { + return function () { + if (fn === null) throw new Error("Callback was already called."); + var callFn = fn; + fn = null; + callFn.apply(this, arguments); + }; +} +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/internal/parallel.js b/node_modules/mongoose/node_modules/async/internal/parallel.js new file mode 100644 index 0000000..f04888c --- /dev/null +++ b/node_modules/mongoose/node_modules/async/internal/parallel.js @@ -0,0 +1,38 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = _parallel; + +var _noop = require('lodash/noop'); + +var _noop2 = _interopRequireDefault(_noop); + +var _isArrayLike = require('lodash/isArrayLike'); + +var _isArrayLike2 = _interopRequireDefault(_isArrayLike); + +var _rest = require('lodash/rest'); + +var _rest2 = _interopRequireDefault(_rest); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +function _parallel(eachfn, tasks, callback) { + callback = callback || _noop2.default; + var results = (0, _isArrayLike2.default)(tasks) ? [] : {}; + + eachfn(tasks, function (task, key, callback) { + task((0, _rest2.default)(function (err, args) { + if (args.length <= 1) { + args = args[0]; + } + results[key] = args; + callback(err); + })); + }, function (err) { + callback(err, results); + }); +} +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/internal/queue.js b/node_modules/mongoose/node_modules/async/internal/queue.js new file mode 100644 index 0000000..e54a6d7 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/internal/queue.js @@ -0,0 +1,184 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = queue; + +var _arrayEach = require('lodash/_arrayEach'); + +var _arrayEach2 = _interopRequireDefault(_arrayEach); + +var _isArray = require('lodash/isArray'); + +var _isArray2 = _interopRequireDefault(_isArray); + +var _noop = require('lodash/noop'); + +var _noop2 = _interopRequireDefault(_noop); + +var _rest = require('lodash/rest'); + +var _rest2 = _interopRequireDefault(_rest); + +var _onlyOnce = require('./onlyOnce'); + +var _onlyOnce2 = _interopRequireDefault(_onlyOnce); + +var _setImmediate = require('./setImmediate'); + +var _setImmediate2 = _interopRequireDefault(_setImmediate); + +var _DoublyLinkedList = require('./DoublyLinkedList'); + +var _DoublyLinkedList2 = _interopRequireDefault(_DoublyLinkedList); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +function queue(worker, concurrency, payload) { + if (concurrency == null) { + concurrency = 1; + } else if (concurrency === 0) { + throw new Error('Concurrency must not be zero'); + } + + function _insert(data, insertAtFront, callback) { + if (callback != null && typeof callback !== 'function') { + throw new Error('task callback must be a function'); + } + q.started = true; + if (!(0, _isArray2.default)(data)) { + data = [data]; + } + if (data.length === 0 && q.idle()) { + // call drain immediately if there are no tasks + return (0, _setImmediate2.default)(function () { + q.drain(); + }); + } + (0, _arrayEach2.default)(data, function (task) { + var item = { + data: task, + callback: callback || _noop2.default + }; + + if (insertAtFront) { + q._tasks.unshift(item); + } else { + q._tasks.push(item); + } + }); + (0, _setImmediate2.default)(q.process); + } + + function _next(tasks) { + return (0, _rest2.default)(function (args) { + workers -= 1; + + (0, _arrayEach2.default)(tasks, function (task) { + (0, _arrayEach2.default)(workersList, function (worker, index) { + if (worker === task) { + workersList.splice(index, 1); + return false; + } + }); + + task.callback.apply(task, args); + + if (args[0] != null) { + q.error(args[0], task.data); + } + }); + + if (workers <= q.concurrency - q.buffer) { + q.unsaturated(); + } + + if (q.idle()) { + q.drain(); + } + q.process(); + }); + } + + var workers = 0; + var workersList = []; + var q = { + _tasks: new _DoublyLinkedList2.default(), + concurrency: concurrency, + payload: payload, + saturated: _noop2.default, + unsaturated: _noop2.default, + buffer: concurrency / 4, + empty: _noop2.default, + drain: _noop2.default, + error: _noop2.default, + started: false, + paused: false, + push: function (data, callback) { + _insert(data, false, callback); + }, + kill: function () { + q.drain = _noop2.default; + q._tasks.empty(); + }, + unshift: function (data, callback) { + _insert(data, true, callback); + }, + process: function () { + while (!q.paused && workers < q.concurrency && q._tasks.length) { + var tasks = [], + data = []; + var l = q._tasks.length; + if (q.payload) l = Math.min(l, q.payload); + for (var i = 0; i < l; i++) { + var node = q._tasks.shift(); + tasks.push(node); + data.push(node.data); + } + + if (q._tasks.length === 0) { + q.empty(); + } + workers += 1; + workersList.push(tasks[0]); + + if (workers === q.concurrency) { + q.saturated(); + } + + var cb = (0, _onlyOnce2.default)(_next(tasks)); + worker(data, cb); + } + }, + length: function () { + return q._tasks.length; + }, + running: function () { + return workers; + }, + workersList: function () { + return workersList; + }, + idle: function () { + return q._tasks.length + workers === 0; + }, + pause: function () { + q.paused = true; + }, + resume: function () { + if (q.paused === false) { + return; + } + q.paused = false; + var resumeCount = Math.min(q.concurrency, q._tasks.length); + // Need to call q.process once per concurrent + // worker to preserve full concurrency after pause + for (var w = 1; w <= resumeCount; w++) { + (0, _setImmediate2.default)(q.process); + } + } + }; + return q; +} +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/internal/reject.js b/node_modules/mongoose/node_modules/async/internal/reject.js new file mode 100644 index 0000000..b20cc3b --- /dev/null +++ b/node_modules/mongoose/node_modules/async/internal/reject.js @@ -0,0 +1,25 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = reject; + +var _filter = require('./filter'); + +var _filter2 = _interopRequireDefault(_filter); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +function reject(eachfn, arr, iteratee, callback) { + (0, _filter2.default)(eachfn, arr, function (value, cb) { + iteratee(value, function (err, v) { + if (err) { + cb(err); + } else { + cb(null, !v); + } + }); + }, callback); +} +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/internal/setImmediate.js b/node_modules/mongoose/node_modules/async/internal/setImmediate.js new file mode 100644 index 0000000..6d7e7fd --- /dev/null +++ b/node_modules/mongoose/node_modules/async/internal/setImmediate.js @@ -0,0 +1,41 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.hasNextTick = exports.hasSetImmediate = undefined; +exports.fallback = fallback; +exports.wrap = wrap; + +var _rest = require('lodash/rest'); + +var _rest2 = _interopRequireDefault(_rest); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +var hasSetImmediate = exports.hasSetImmediate = typeof setImmediate === 'function' && setImmediate; +var hasNextTick = exports.hasNextTick = typeof process === 'object' && typeof process.nextTick === 'function'; + +function fallback(fn) { + setTimeout(fn, 0); +} + +function wrap(defer) { + return (0, _rest2.default)(function (fn, args) { + defer(function () { + fn.apply(null, args); + }); + }); +} + +var _defer; + +if (hasSetImmediate) { + _defer = setImmediate; +} else if (hasNextTick) { + _defer = process.nextTick; +} else { + _defer = fallback; +} + +exports.default = wrap(_defer); \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/internal/withoutIndex.js b/node_modules/mongoose/node_modules/async/internal/withoutIndex.js new file mode 100644 index 0000000..240a840 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/internal/withoutIndex.js @@ -0,0 +1,12 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = _withoutIndex; +function _withoutIndex(iteratee) { + return function (value, index, callback) { + return iteratee(value, callback); + }; +} +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/log.js b/node_modules/mongoose/node_modules/async/log.js new file mode 100644 index 0000000..ac04693 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/log.js @@ -0,0 +1,41 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _consoleFunc = require('./internal/consoleFunc'); + +var _consoleFunc2 = _interopRequireDefault(_consoleFunc); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Logs the result of an `async` function to the `console`. Only works in + * Node.js or in browsers that support `console.log` and `console.error` (such + * as FF and Chrome). If multiple arguments are returned from the async + * function, `console.log` is called on each argument in order. + * + * @name log + * @static + * @memberOf module:Utils + * @method + * @category Util + * @param {Function} function - The function you want to eventually apply all + * arguments to. + * @param {...*} arguments... - Any number of arguments to apply to the function. + * @example + * + * // in a module + * var hello = function(name, callback) { + * setTimeout(function() { + * callback(null, 'hello ' + name); + * }, 1000); + * }; + * + * // in the node repl + * node> async.log(hello, 'world'); + * 'hello world' + */ +exports.default = (0, _consoleFunc2.default)('log'); +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/map.js b/node_modules/mongoose/node_modules/async/map.js new file mode 100644 index 0000000..37e0b01 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/map.js @@ -0,0 +1,54 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _doParallel = require('./internal/doParallel'); + +var _doParallel2 = _interopRequireDefault(_doParallel); + +var _map = require('./internal/map'); + +var _map2 = _interopRequireDefault(_map); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Produces a new collection of values by mapping each value in `coll` through + * the `iteratee` function. The `iteratee` is called with an item from `coll` + * and a callback for when it has finished processing. Each of these callback + * takes 2 arguments: an `error`, and the transformed item from `coll`. If + * `iteratee` passes an error to its callback, the main `callback` (for the + * `map` function) is immediately called with the error. + * + * Note, that since this function applies the `iteratee` to each item in + * parallel, there is no guarantee that the `iteratee` functions will complete + * in order. However, the results array will be in the same order as the + * original `coll`. + * + * If `map` is passed an Object, the results will be an Array. The results + * will roughly be in the order of the original Objects' keys (but this can + * vary across JavaScript engines) + * + * @name map + * @static + * @memberOf module:Collections + * @method + * @category Collection + * @param {Array|Iterable|Object} coll - A collection to iterate over. + * @param {Function} iteratee - A function to apply to each item in `coll`. + * The iteratee is passed a `callback(err, transformed)` which must be called + * once it has completed with an error (which can be `null`) and a + * transformed item. Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called when all `iteratee` + * functions have finished, or an error occurs. Results is an Array of the + * transformed items from the `coll`. Invoked with (err, results). + * @example + * + * async.map(['file1','file2','file3'], fs.stat, function(err, results) { + * // results is now an array of stats for each file + * }); + */ +exports.default = (0, _doParallel2.default)(_map2.default); +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/mapLimit.js b/node_modules/mongoose/node_modules/async/mapLimit.js new file mode 100644 index 0000000..9165e0a --- /dev/null +++ b/node_modules/mongoose/node_modules/async/mapLimit.js @@ -0,0 +1,37 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _doParallelLimit = require('./internal/doParallelLimit'); + +var _doParallelLimit2 = _interopRequireDefault(_doParallelLimit); + +var _map = require('./internal/map'); + +var _map2 = _interopRequireDefault(_map); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`map`]{@link module:Collections.map} but runs a maximum of `limit` async operations at a time. + * + * @name mapLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.map]{@link module:Collections.map} + * @category Collection + * @param {Array|Iterable|Object} coll - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {Function} iteratee - A function to apply to each item in `coll`. + * The iteratee is passed a `callback(err, transformed)` which must be called + * once it has completed with an error (which can be `null`) and a transformed + * item. Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called when all `iteratee` + * functions have finished, or an error occurs. Results is an array of the + * transformed items from the `coll`. Invoked with (err, results). + */ +exports.default = (0, _doParallelLimit2.default)(_map2.default); +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/mapSeries.js b/node_modules/mongoose/node_modules/async/mapSeries.js new file mode 100644 index 0000000..b3894ad --- /dev/null +++ b/node_modules/mongoose/node_modules/async/mapSeries.js @@ -0,0 +1,36 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _mapLimit = require('./mapLimit'); + +var _mapLimit2 = _interopRequireDefault(_mapLimit); + +var _doLimit = require('./internal/doLimit'); + +var _doLimit2 = _interopRequireDefault(_doLimit); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`map`]{@link module:Collections.map} but runs only a single async operation at a time. + * + * @name mapSeries + * @static + * @memberOf module:Collections + * @method + * @see [async.map]{@link module:Collections.map} + * @category Collection + * @param {Array|Iterable|Object} coll - A collection to iterate over. + * @param {Function} iteratee - A function to apply to each item in `coll`. + * The iteratee is passed a `callback(err, transformed)` which must be called + * once it has completed with an error (which can be `null`) and a + * transformed item. Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called when all `iteratee` + * functions have finished, or an error occurs. Results is an array of the + * transformed items from the `coll`. Invoked with (err, results). + */ +exports.default = (0, _doLimit2.default)(_mapLimit2.default, 1); +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/mapValues.js b/node_modules/mongoose/node_modules/async/mapValues.js new file mode 100644 index 0000000..71051db --- /dev/null +++ b/node_modules/mongoose/node_modules/async/mapValues.js @@ -0,0 +1,62 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _mapValuesLimit = require('./mapValuesLimit'); + +var _mapValuesLimit2 = _interopRequireDefault(_mapValuesLimit); + +var _doLimit = require('./internal/doLimit'); + +var _doLimit2 = _interopRequireDefault(_doLimit); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * A relative of [`map`]{@link module:Collections.map}, designed for use with objects. + * + * Produces a new Object by mapping each value of `obj` through the `iteratee` + * function. The `iteratee` is called each `value` and `key` from `obj` and a + * callback for when it has finished processing. Each of these callbacks takes + * two arguments: an `error`, and the transformed item from `obj`. If `iteratee` + * passes an error to its callback, the main `callback` (for the `mapValues` + * function) is immediately called with the error. + * + * Note, the order of the keys in the result is not guaranteed. The keys will + * be roughly in the order they complete, (but this is very engine-specific) + * + * @name mapValues + * @static + * @memberOf module:Collections + * @method + * @category Collection + * @param {Object} obj - A collection to iterate over. + * @param {Function} iteratee - A function to apply to each value and key in + * `coll`. The iteratee is passed a `callback(err, transformed)` which must be + * called once it has completed with an error (which can be `null`) and a + * transformed value. Invoked with (value, key, callback). + * @param {Function} [callback] - A callback which is called when all `iteratee` + * functions have finished, or an error occurs. Results is an array of the + * transformed items from the `obj`. Invoked with (err, result). + * @example + * + * async.mapValues({ + * f1: 'file1', + * f2: 'file2', + * f3: 'file3' + * }, function (file, key, callback) { + * fs.stat(file, callback); + * }, function(err, result) { + * // results is now a map of stats for each file, e.g. + * // { + * // f1: [stats for file1], + * // f2: [stats for file2], + * // f3: [stats for file3] + * // } + * }); + */ + +exports.default = (0, _doLimit2.default)(_mapValuesLimit2.default, Infinity); +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/mapValuesLimit.js b/node_modules/mongoose/node_modules/async/mapValuesLimit.js new file mode 100644 index 0000000..e3840b0 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/mapValuesLimit.js @@ -0,0 +1,55 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = mapValuesLimit; + +var _eachOfLimit = require('./eachOfLimit'); + +var _eachOfLimit2 = _interopRequireDefault(_eachOfLimit); + +var _noop = require('lodash/noop'); + +var _noop2 = _interopRequireDefault(_noop); + +var _once = require('./internal/once'); + +var _once2 = _interopRequireDefault(_once); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`mapValues`]{@link module:Collections.mapValues} but runs a maximum of `limit` async operations at a + * time. + * + * @name mapValuesLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.mapValues]{@link module:Collections.mapValues} + * @category Collection + * @param {Object} obj - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {Function} iteratee - A function to apply to each value in `obj`. + * The iteratee is passed a `callback(err, transformed)` which must be called + * once it has completed with an error (which can be `null`) and a + * transformed value. Invoked with (value, key, callback). + * @param {Function} [callback] - A callback which is called when all `iteratee` + * functions have finished, or an error occurs. Result is an object of the + * transformed values from the `obj`. Invoked with (err, result). + */ +function mapValuesLimit(obj, limit, iteratee, callback) { + callback = (0, _once2.default)(callback || _noop2.default); + var newObj = {}; + (0, _eachOfLimit2.default)(obj, limit, function (val, key, next) { + iteratee(val, key, function (err, result) { + if (err) return next(err); + newObj[key] = result; + next(); + }); + }, function (err) { + callback(err, newObj); + }); +} +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/mapValuesSeries.js b/node_modules/mongoose/node_modules/async/mapValuesSeries.js new file mode 100644 index 0000000..d9a8240 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/mapValuesSeries.js @@ -0,0 +1,36 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _mapValuesLimit = require('./mapValuesLimit'); + +var _mapValuesLimit2 = _interopRequireDefault(_mapValuesLimit); + +var _doLimit = require('./internal/doLimit'); + +var _doLimit2 = _interopRequireDefault(_doLimit); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`mapValues`]{@link module:Collections.mapValues} but runs only a single async operation at a time. + * + * @name mapValuesSeries + * @static + * @memberOf module:Collections + * @method + * @see [async.mapValues]{@link module:Collections.mapValues} + * @category Collection + * @param {Object} obj - A collection to iterate over. + * @param {Function} iteratee - A function to apply to each value in `obj`. + * The iteratee is passed a `callback(err, transformed)` which must be called + * once it has completed with an error (which can be `null`) and a + * transformed value. Invoked with (value, key, callback). + * @param {Function} [callback] - A callback which is called when all `iteratee` + * functions have finished, or an error occurs. Result is an object of the + * transformed values from the `obj`. Invoked with (err, result). + */ +exports.default = (0, _doLimit2.default)(_mapValuesLimit2.default, 1); +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/memoize.js b/node_modules/mongoose/node_modules/async/memoize.js new file mode 100644 index 0000000..a6bc5f0 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/memoize.js @@ -0,0 +1,95 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = memoize; + +var _identity = require('lodash/identity'); + +var _identity2 = _interopRequireDefault(_identity); + +var _rest = require('lodash/rest'); + +var _rest2 = _interopRequireDefault(_rest); + +var _setImmediate = require('./internal/setImmediate'); + +var _setImmediate2 = _interopRequireDefault(_setImmediate); + +var _initialParams = require('./internal/initialParams'); + +var _initialParams2 = _interopRequireDefault(_initialParams); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +function has(obj, key) { + return key in obj; +} + +/** + * Caches the results of an `async` function. When creating a hash to store + * function results against, the callback is omitted from the hash and an + * optional hash function can be used. + * + * If no hash function is specified, the first argument is used as a hash key, + * which may work reasonably if it is a string or a data type that converts to a + * distinct string. Note that objects and arrays will not behave reasonably. + * Neither will cases where the other arguments are significant. In such cases, + * specify your own hash function. + * + * The cache of results is exposed as the `memo` property of the function + * returned by `memoize`. + * + * @name memoize + * @static + * @memberOf module:Utils + * @method + * @category Util + * @param {Function} fn - The function to proxy and cache results from. + * @param {Function} hasher - An optional function for generating a custom hash + * for storing results. It has all the arguments applied to it apart from the + * callback, and must be synchronous. + * @returns {Function} a memoized version of `fn` + * @example + * + * var slow_fn = function(name, callback) { + * // do something + * callback(null, result); + * }; + * var fn = async.memoize(slow_fn); + * + * // fn can now be used as if it were slow_fn + * fn('some name', function() { + * // callback + * }); + */ +function memoize(fn, hasher) { + var memo = Object.create(null); + var queues = Object.create(null); + hasher = hasher || _identity2.default; + var memoized = (0, _initialParams2.default)(function memoized(args, callback) { + var key = hasher.apply(null, args); + if (has(memo, key)) { + (0, _setImmediate2.default)(function () { + callback.apply(null, memo[key]); + }); + } else if (has(queues, key)) { + queues[key].push(callback); + } else { + queues[key] = [callback]; + fn.apply(null, args.concat([(0, _rest2.default)(function (args) { + memo[key] = args; + var q = queues[key]; + delete queues[key]; + for (var i = 0, l = q.length; i < l; i++) { + q[i].apply(null, args); + } + })])); + } + }); + memoized.memo = memo; + memoized.unmemoized = fn; + return memoized; +} +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/nextTick.js b/node_modules/mongoose/node_modules/async/nextTick.js new file mode 100644 index 0000000..fa48e32 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/nextTick.js @@ -0,0 +1,51 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _setImmediate = require('./internal/setImmediate'); + +/** + * Calls `callback` on a later loop around the event loop. In Node.js this just + * calls `setImmediate`. In the browser it will use `setImmediate` if + * available, otherwise `setTimeout(callback, 0)`, which means other higher + * priority events may precede the execution of `callback`. + * + * This is used internally for browser-compatibility purposes. + * + * @name nextTick + * @static + * @memberOf module:Utils + * @method + * @alias setImmediate + * @category Util + * @param {Function} callback - The function to call on a later loop around + * the event loop. Invoked with (args...). + * @param {...*} args... - any number of additional arguments to pass to the + * callback on the next tick. + * @example + * + * var call_order = []; + * async.nextTick(function() { + * call_order.push('two'); + * // call_order now equals ['one','two'] + * }); + * call_order.push('one'); + * + * async.setImmediate(function (a, b, c) { + * // a, b, and c equal 1, 2, and 3 + * }, 1, 2, 3); + */ +var _defer; + +if (_setImmediate.hasNextTick) { + _defer = process.nextTick; +} else if (_setImmediate.hasSetImmediate) { + _defer = setImmediate; +} else { + _defer = _setImmediate.fallback; +} + +exports.default = (0, _setImmediate.wrap)(_defer); +module.exports = exports['default']; \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/LICENSE b/node_modules/mongoose/node_modules/async/node_modules/lodash/LICENSE new file mode 100644 index 0000000..e0c69d5 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/LICENSE @@ -0,0 +1,47 @@ +Copyright jQuery Foundation and other contributors + +Based on Underscore.js, copyright Jeremy Ashkenas, +DocumentCloud and Investigative Reporters & Editors + +This software consists of voluntary contributions made by many +individuals. For exact contribution history, see the revision history +available at https://github.com/lodash/lodash + +The following license applies to all parts of this software except as +documented below: + +==== + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +"Software"), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND +NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE +LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION +OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION +WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + +==== + +Copyright and related rights for sample code are waived via CC0. Sample +code is defined as all source code displayed within the prose of the +documentation. + +CC0: http://creativecommons.org/publicdomain/zero/1.0/ + +==== + +Files located in the node_modules and vendor directories are externally +maintained libraries used by this software which have their own +licenses; we recommend you read them, as their terms may differ from the +terms above. diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/README.md b/node_modules/mongoose/node_modules/async/node_modules/lodash/README.md new file mode 100644 index 0000000..72b66b2 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/README.md @@ -0,0 +1,39 @@ +# lodash v4.16.4 + +The [Lodash](https://lodash.com/) library exported as [Node.js](https://nodejs.org/) modules. + +## Installation + +Using npm: +```shell +$ npm i -g npm +$ npm i --save lodash +``` + +In Node.js: +```js +// Load the full build. +var _ = require('lodash'); +// Load the core build. +var _ = require('lodash/core'); +// Load the FP build for immutable auto-curried iteratee-first data-last methods. +var fp = require('lodash/fp'); + +// Load method categories. +var array = require('lodash/array'); +var object = require('lodash/fp/object'); + +// Cherry-pick methods for smaller browserify/rollup/webpack bundles. +var at = require('lodash/at'); +var curryN = require('lodash/fp/curryN'); +``` + +See the [package source](https://github.com/lodash/lodash/tree/4.16.4-npm) for more details. + +**Note:**
+Install [n_](https://www.npmjs.com/package/n_) for Lodash use in the Node.js < 6 REPL. + +## Support + +Tested in Chrome 52-53, Firefox 48-49, IE 11, Edge 14, Safari 9-10, Node.js 4-6, & PhantomJS 2.1.1.
+Automated [browser](https://saucelabs.com/u/lodash) & [CI](https://travis-ci.org/lodash/lodash/) test runs are available. diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_DataView.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_DataView.js new file mode 100644 index 0000000..ac2d57c --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_DataView.js @@ -0,0 +1,7 @@ +var getNative = require('./_getNative'), + root = require('./_root'); + +/* Built-in method references that are verified to be native. */ +var DataView = getNative(root, 'DataView'); + +module.exports = DataView; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_Hash.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_Hash.js new file mode 100644 index 0000000..667d5ab --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_Hash.js @@ -0,0 +1,32 @@ +var hashClear = require('./_hashClear'), + hashDelete = require('./_hashDelete'), + hashGet = require('./_hashGet'), + hashHas = require('./_hashHas'), + hashSet = require('./_hashSet'); + +/** + * Creates a hash object. + * + * @private + * @constructor + * @param {Array} [entries] The key-value pairs to cache. + */ +function Hash(entries) { + var index = -1, + length = entries ? entries.length : 0; + + this.clear(); + while (++index < length) { + var entry = entries[index]; + this.set(entry[0], entry[1]); + } +} + +// Add methods to `Hash`. +Hash.prototype.clear = hashClear; +Hash.prototype['delete'] = hashDelete; +Hash.prototype.get = hashGet; +Hash.prototype.has = hashHas; +Hash.prototype.set = hashSet; + +module.exports = Hash; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_LazyWrapper.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_LazyWrapper.js new file mode 100644 index 0000000..81786c7 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_LazyWrapper.js @@ -0,0 +1,28 @@ +var baseCreate = require('./_baseCreate'), + baseLodash = require('./_baseLodash'); + +/** Used as references for the maximum length and index of an array. */ +var MAX_ARRAY_LENGTH = 4294967295; + +/** + * Creates a lazy wrapper object which wraps `value` to enable lazy evaluation. + * + * @private + * @constructor + * @param {*} value The value to wrap. + */ +function LazyWrapper(value) { + this.__wrapped__ = value; + this.__actions__ = []; + this.__dir__ = 1; + this.__filtered__ = false; + this.__iteratees__ = []; + this.__takeCount__ = MAX_ARRAY_LENGTH; + this.__views__ = []; +} + +// Ensure `LazyWrapper` is an instance of `baseLodash`. +LazyWrapper.prototype = baseCreate(baseLodash.prototype); +LazyWrapper.prototype.constructor = LazyWrapper; + +module.exports = LazyWrapper; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_ListCache.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_ListCache.js new file mode 100644 index 0000000..73f4645 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_ListCache.js @@ -0,0 +1,32 @@ +var listCacheClear = require('./_listCacheClear'), + listCacheDelete = require('./_listCacheDelete'), + listCacheGet = require('./_listCacheGet'), + listCacheHas = require('./_listCacheHas'), + listCacheSet = require('./_listCacheSet'); + +/** + * Creates an list cache object. + * + * @private + * @constructor + * @param {Array} [entries] The key-value pairs to cache. + */ +function ListCache(entries) { + var index = -1, + length = entries ? entries.length : 0; + + this.clear(); + while (++index < length) { + var entry = entries[index]; + this.set(entry[0], entry[1]); + } +} + +// Add methods to `ListCache`. +ListCache.prototype.clear = listCacheClear; +ListCache.prototype['delete'] = listCacheDelete; +ListCache.prototype.get = listCacheGet; +ListCache.prototype.has = listCacheHas; +ListCache.prototype.set = listCacheSet; + +module.exports = ListCache; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_LodashWrapper.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_LodashWrapper.js new file mode 100644 index 0000000..c1e4d9d --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_LodashWrapper.js @@ -0,0 +1,22 @@ +var baseCreate = require('./_baseCreate'), + baseLodash = require('./_baseLodash'); + +/** + * The base constructor for creating `lodash` wrapper objects. + * + * @private + * @param {*} value The value to wrap. + * @param {boolean} [chainAll] Enable explicit method chain sequences. + */ +function LodashWrapper(value, chainAll) { + this.__wrapped__ = value; + this.__actions__ = []; + this.__chain__ = !!chainAll; + this.__index__ = 0; + this.__values__ = undefined; +} + +LodashWrapper.prototype = baseCreate(baseLodash.prototype); +LodashWrapper.prototype.constructor = LodashWrapper; + +module.exports = LodashWrapper; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_Map.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_Map.js new file mode 100644 index 0000000..b73f29a --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_Map.js @@ -0,0 +1,7 @@ +var getNative = require('./_getNative'), + root = require('./_root'); + +/* Built-in method references that are verified to be native. */ +var Map = getNative(root, 'Map'); + +module.exports = Map; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_MapCache.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_MapCache.js new file mode 100644 index 0000000..69f03a4 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_MapCache.js @@ -0,0 +1,32 @@ +var mapCacheClear = require('./_mapCacheClear'), + mapCacheDelete = require('./_mapCacheDelete'), + mapCacheGet = require('./_mapCacheGet'), + mapCacheHas = require('./_mapCacheHas'), + mapCacheSet = require('./_mapCacheSet'); + +/** + * Creates a map cache object to store key-value pairs. + * + * @private + * @constructor + * @param {Array} [entries] The key-value pairs to cache. + */ +function MapCache(entries) { + var index = -1, + length = entries ? entries.length : 0; + + this.clear(); + while (++index < length) { + var entry = entries[index]; + this.set(entry[0], entry[1]); + } +} + +// Add methods to `MapCache`. +MapCache.prototype.clear = mapCacheClear; +MapCache.prototype['delete'] = mapCacheDelete; +MapCache.prototype.get = mapCacheGet; +MapCache.prototype.has = mapCacheHas; +MapCache.prototype.set = mapCacheSet; + +module.exports = MapCache; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_Promise.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_Promise.js new file mode 100644 index 0000000..247b9e1 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_Promise.js @@ -0,0 +1,7 @@ +var getNative = require('./_getNative'), + root = require('./_root'); + +/* Built-in method references that are verified to be native. */ +var Promise = getNative(root, 'Promise'); + +module.exports = Promise; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_Set.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_Set.js new file mode 100644 index 0000000..b3c8dcb --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_Set.js @@ -0,0 +1,7 @@ +var getNative = require('./_getNative'), + root = require('./_root'); + +/* Built-in method references that are verified to be native. */ +var Set = getNative(root, 'Set'); + +module.exports = Set; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_SetCache.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_SetCache.js new file mode 100644 index 0000000..a80efd5 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_SetCache.js @@ -0,0 +1,27 @@ +var MapCache = require('./_MapCache'), + setCacheAdd = require('./_setCacheAdd'), + setCacheHas = require('./_setCacheHas'); + +/** + * + * Creates an array cache object to store unique values. + * + * @private + * @constructor + * @param {Array} [values] The values to cache. + */ +function SetCache(values) { + var index = -1, + length = values ? values.length : 0; + + this.__data__ = new MapCache; + while (++index < length) { + this.add(values[index]); + } +} + +// Add methods to `SetCache`. +SetCache.prototype.add = SetCache.prototype.push = setCacheAdd; +SetCache.prototype.has = setCacheHas; + +module.exports = SetCache; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_Stack.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_Stack.js new file mode 100644 index 0000000..80b2cf1 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_Stack.js @@ -0,0 +1,27 @@ +var ListCache = require('./_ListCache'), + stackClear = require('./_stackClear'), + stackDelete = require('./_stackDelete'), + stackGet = require('./_stackGet'), + stackHas = require('./_stackHas'), + stackSet = require('./_stackSet'); + +/** + * Creates a stack cache object to store key-value pairs. + * + * @private + * @constructor + * @param {Array} [entries] The key-value pairs to cache. + */ +function Stack(entries) { + var data = this.__data__ = new ListCache(entries); + this.size = data.size; +} + +// Add methods to `Stack`. +Stack.prototype.clear = stackClear; +Stack.prototype['delete'] = stackDelete; +Stack.prototype.get = stackGet; +Stack.prototype.has = stackHas; +Stack.prototype.set = stackSet; + +module.exports = Stack; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_Symbol.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_Symbol.js new file mode 100644 index 0000000..a013f7c --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_Symbol.js @@ -0,0 +1,6 @@ +var root = require('./_root'); + +/** Built-in value references. */ +var Symbol = root.Symbol; + +module.exports = Symbol; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_Uint8Array.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_Uint8Array.js new file mode 100644 index 0000000..2fb30e1 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_Uint8Array.js @@ -0,0 +1,6 @@ +var root = require('./_root'); + +/** Built-in value references. */ +var Uint8Array = root.Uint8Array; + +module.exports = Uint8Array; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_WeakMap.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_WeakMap.js new file mode 100644 index 0000000..567f86c --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_WeakMap.js @@ -0,0 +1,7 @@ +var getNative = require('./_getNative'), + root = require('./_root'); + +/* Built-in method references that are verified to be native. */ +var WeakMap = getNative(root, 'WeakMap'); + +module.exports = WeakMap; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_addMapEntry.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_addMapEntry.js new file mode 100644 index 0000000..5a69212 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_addMapEntry.js @@ -0,0 +1,15 @@ +/** + * Adds the key-value `pair` to `map`. + * + * @private + * @param {Object} map The map to modify. + * @param {Array} pair The key-value pair to add. + * @returns {Object} Returns `map`. + */ +function addMapEntry(map, pair) { + // Don't return `map.set` because it's not chainable in IE 11. + map.set(pair[0], pair[1]); + return map; +} + +module.exports = addMapEntry; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_addSetEntry.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_addSetEntry.js new file mode 100644 index 0000000..1a07b70 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_addSetEntry.js @@ -0,0 +1,15 @@ +/** + * Adds `value` to `set`. + * + * @private + * @param {Object} set The set to modify. + * @param {*} value The value to add. + * @returns {Object} Returns `set`. + */ +function addSetEntry(set, value) { + // Don't return `set.add` because it's not chainable in IE 11. + set.add(value); + return set; +} + +module.exports = addSetEntry; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_apply.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_apply.js new file mode 100644 index 0000000..36436dd --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_apply.js @@ -0,0 +1,21 @@ +/** + * A faster alternative to `Function#apply`, this function invokes `func` + * with the `this` binding of `thisArg` and the arguments of `args`. + * + * @private + * @param {Function} func The function to invoke. + * @param {*} thisArg The `this` binding of `func`. + * @param {Array} args The arguments to invoke `func` with. + * @returns {*} Returns the result of `func`. + */ +function apply(func, thisArg, args) { + switch (args.length) { + case 0: return func.call(thisArg); + case 1: return func.call(thisArg, args[0]); + case 2: return func.call(thisArg, args[0], args[1]); + case 3: return func.call(thisArg, args[0], args[1], args[2]); + } + return func.apply(thisArg, args); +} + +module.exports = apply; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayAggregator.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayAggregator.js new file mode 100644 index 0000000..7ca498a --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayAggregator.js @@ -0,0 +1,22 @@ +/** + * A specialized version of `baseAggregator` for arrays. + * + * @private + * @param {Array} [array] The array to iterate over. + * @param {Function} setter The function to set `accumulator` values. + * @param {Function} iteratee The iteratee to transform keys. + * @param {Object} accumulator The initial aggregated object. + * @returns {Function} Returns `accumulator`. + */ +function arrayAggregator(array, setter, iteratee, accumulator) { + var index = -1, + length = array ? array.length : 0; + + while (++index < length) { + var value = array[index]; + setter(accumulator, value, iteratee(value), array); + } + return accumulator; +} + +module.exports = arrayAggregator; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayEach.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayEach.js new file mode 100644 index 0000000..5f770bc --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayEach.js @@ -0,0 +1,22 @@ +/** + * A specialized version of `_.forEach` for arrays without support for + * iteratee shorthands. + * + * @private + * @param {Array} [array] The array to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @returns {Array} Returns `array`. + */ +function arrayEach(array, iteratee) { + var index = -1, + length = array ? array.length : 0; + + while (++index < length) { + if (iteratee(array[index], index, array) === false) { + break; + } + } + return array; +} + +module.exports = arrayEach; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayEachRight.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayEachRight.js new file mode 100644 index 0000000..72e780c --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayEachRight.js @@ -0,0 +1,21 @@ +/** + * A specialized version of `_.forEachRight` for arrays without support for + * iteratee shorthands. + * + * @private + * @param {Array} [array] The array to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @returns {Array} Returns `array`. + */ +function arrayEachRight(array, iteratee) { + var length = array ? array.length : 0; + + while (length--) { + if (iteratee(array[length], length, array) === false) { + break; + } + } + return array; +} + +module.exports = arrayEachRight; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayEvery.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayEvery.js new file mode 100644 index 0000000..f4fb425 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayEvery.js @@ -0,0 +1,23 @@ +/** + * A specialized version of `_.every` for arrays without support for + * iteratee shorthands. + * + * @private + * @param {Array} [array] The array to iterate over. + * @param {Function} predicate The function invoked per iteration. + * @returns {boolean} Returns `true` if all elements pass the predicate check, + * else `false`. + */ +function arrayEvery(array, predicate) { + var index = -1, + length = array ? array.length : 0; + + while (++index < length) { + if (!predicate(array[index], index, array)) { + return false; + } + } + return true; +} + +module.exports = arrayEvery; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayFilter.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayFilter.js new file mode 100644 index 0000000..b904fda --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayFilter.js @@ -0,0 +1,25 @@ +/** + * A specialized version of `_.filter` for arrays without support for + * iteratee shorthands. + * + * @private + * @param {Array} [array] The array to iterate over. + * @param {Function} predicate The function invoked per iteration. + * @returns {Array} Returns the new filtered array. + */ +function arrayFilter(array, predicate) { + var index = -1, + length = array ? array.length : 0, + resIndex = 0, + result = []; + + while (++index < length) { + var value = array[index]; + if (predicate(value, index, array)) { + result[resIndex++] = value; + } + } + return result; +} + +module.exports = arrayFilter; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayIncludes.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayIncludes.js new file mode 100644 index 0000000..be53e60 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayIncludes.js @@ -0,0 +1,17 @@ +var baseIndexOf = require('./_baseIndexOf'); + +/** + * A specialized version of `_.includes` for arrays without support for + * specifying an index to search from. + * + * @private + * @param {Array} [array] The array to inspect. + * @param {*} target The value to search for. + * @returns {boolean} Returns `true` if `target` is found, else `false`. + */ +function arrayIncludes(array, value) { + var length = array ? array.length : 0; + return !!length && baseIndexOf(array, value, 0) > -1; +} + +module.exports = arrayIncludes; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayIncludesWith.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayIncludesWith.js new file mode 100644 index 0000000..72ff0c8 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayIncludesWith.js @@ -0,0 +1,22 @@ +/** + * This function is like `arrayIncludes` except that it accepts a comparator. + * + * @private + * @param {Array} [array] The array to inspect. + * @param {*} target The value to search for. + * @param {Function} comparator The comparator invoked per element. + * @returns {boolean} Returns `true` if `target` is found, else `false`. + */ +function arrayIncludesWith(array, value, comparator) { + var index = -1, + length = array ? array.length : 0; + + while (++index < length) { + if (comparator(value, array[index])) { + return true; + } + } + return false; +} + +module.exports = arrayIncludesWith; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayLikeKeys.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayLikeKeys.js new file mode 100644 index 0000000..b2ec9ce --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayLikeKeys.js @@ -0,0 +1,49 @@ +var baseTimes = require('./_baseTimes'), + isArguments = require('./isArguments'), + isArray = require('./isArray'), + isBuffer = require('./isBuffer'), + isIndex = require('./_isIndex'), + isTypedArray = require('./isTypedArray'); + +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** Used to check objects for own properties. */ +var hasOwnProperty = objectProto.hasOwnProperty; + +/** + * Creates an array of the enumerable property names of the array-like `value`. + * + * @private + * @param {*} value The value to query. + * @param {boolean} inherited Specify returning inherited property names. + * @returns {Array} Returns the array of property names. + */ +function arrayLikeKeys(value, inherited) { + var isArr = isArray(value), + isArg = !isArr && isArguments(value), + isBuff = !isArr && !isArg && isBuffer(value), + isType = !isArr && !isArg && !isBuff && isTypedArray(value), + skipIndexes = isArr || isArg || isBuff || isType, + result = skipIndexes ? baseTimes(value.length, String) : [], + length = result.length; + + for (var key in value) { + if ((inherited || hasOwnProperty.call(value, key)) && + !(skipIndexes && ( + // Safari 9 has enumerable `arguments.length` in strict mode. + key == 'length' || + // Node.js 0.10 has enumerable non-index properties on buffers. + (isBuff && (key == 'offset' || key == 'parent')) || + // PhantomJS 2 has enumerable non-index properties on typed arrays. + (isType && (key == 'buffer' || key == 'byteLength' || key == 'byteOffset')) || + // Skip index properties. + isIndex(key, length) + ))) { + result.push(key); + } + } + return result; +} + +module.exports = arrayLikeKeys; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayMap.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayMap.js new file mode 100644 index 0000000..748bdbe --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayMap.js @@ -0,0 +1,21 @@ +/** + * A specialized version of `_.map` for arrays without support for iteratee + * shorthands. + * + * @private + * @param {Array} [array] The array to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @returns {Array} Returns the new mapped array. + */ +function arrayMap(array, iteratee) { + var index = -1, + length = array ? array.length : 0, + result = Array(length); + + while (++index < length) { + result[index] = iteratee(array[index], index, array); + } + return result; +} + +module.exports = arrayMap; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayPush.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayPush.js new file mode 100644 index 0000000..7d742b3 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayPush.js @@ -0,0 +1,20 @@ +/** + * Appends the elements of `values` to `array`. + * + * @private + * @param {Array} array The array to modify. + * @param {Array} values The values to append. + * @returns {Array} Returns `array`. + */ +function arrayPush(array, values) { + var index = -1, + length = values.length, + offset = array.length; + + while (++index < length) { + array[offset + index] = values[index]; + } + return array; +} + +module.exports = arrayPush; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayReduce.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayReduce.js new file mode 100644 index 0000000..57c8727 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayReduce.js @@ -0,0 +1,26 @@ +/** + * A specialized version of `_.reduce` for arrays without support for + * iteratee shorthands. + * + * @private + * @param {Array} [array] The array to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @param {*} [accumulator] The initial value. + * @param {boolean} [initAccum] Specify using the first element of `array` as + * the initial value. + * @returns {*} Returns the accumulated value. + */ +function arrayReduce(array, iteratee, accumulator, initAccum) { + var index = -1, + length = array ? array.length : 0; + + if (initAccum && length) { + accumulator = array[++index]; + } + while (++index < length) { + accumulator = iteratee(accumulator, array[index], index, array); + } + return accumulator; +} + +module.exports = arrayReduce; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayReduceRight.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayReduceRight.js new file mode 100644 index 0000000..4c85ee6 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayReduceRight.js @@ -0,0 +1,24 @@ +/** + * A specialized version of `_.reduceRight` for arrays without support for + * iteratee shorthands. + * + * @private + * @param {Array} [array] The array to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @param {*} [accumulator] The initial value. + * @param {boolean} [initAccum] Specify using the last element of `array` as + * the initial value. + * @returns {*} Returns the accumulated value. + */ +function arrayReduceRight(array, iteratee, accumulator, initAccum) { + var length = array ? array.length : 0; + if (initAccum && length) { + accumulator = array[--length]; + } + while (length--) { + accumulator = iteratee(accumulator, array[length], length, array); + } + return accumulator; +} + +module.exports = arrayReduceRight; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_arraySample.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_arraySample.js new file mode 100644 index 0000000..fcab010 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_arraySample.js @@ -0,0 +1,15 @@ +var baseRandom = require('./_baseRandom'); + +/** + * A specialized version of `_.sample` for arrays. + * + * @private + * @param {Array} array The array to sample. + * @returns {*} Returns the random element. + */ +function arraySample(array) { + var length = array.length; + return length ? array[baseRandom(0, length - 1)] : undefined; +} + +module.exports = arraySample; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_arraySampleSize.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_arraySampleSize.js new file mode 100644 index 0000000..8c7e364 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_arraySampleSize.js @@ -0,0 +1,17 @@ +var baseClamp = require('./_baseClamp'), + copyArray = require('./_copyArray'), + shuffleSelf = require('./_shuffleSelf'); + +/** + * A specialized version of `_.sampleSize` for arrays. + * + * @private + * @param {Array} array The array to sample. + * @param {number} n The number of elements to sample. + * @returns {Array} Returns the random elements. + */ +function arraySampleSize(array, n) { + return shuffleSelf(copyArray(array), baseClamp(n, 0, array.length)); +} + +module.exports = arraySampleSize; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayShuffle.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayShuffle.js new file mode 100644 index 0000000..46313a3 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_arrayShuffle.js @@ -0,0 +1,15 @@ +var copyArray = require('./_copyArray'), + shuffleSelf = require('./_shuffleSelf'); + +/** + * A specialized version of `_.shuffle` for arrays. + * + * @private + * @param {Array} array The array to shuffle. + * @returns {Array} Returns the new shuffled array. + */ +function arrayShuffle(array) { + return shuffleSelf(copyArray(array)); +} + +module.exports = arrayShuffle; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_arraySome.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_arraySome.js new file mode 100644 index 0000000..9b6e5d1 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_arraySome.js @@ -0,0 +1,23 @@ +/** + * A specialized version of `_.some` for arrays without support for iteratee + * shorthands. + * + * @private + * @param {Array} [array] The array to iterate over. + * @param {Function} predicate The function invoked per iteration. + * @returns {boolean} Returns `true` if any element passes the predicate check, + * else `false`. + */ +function arraySome(array, predicate) { + var index = -1, + length = array ? array.length : 0; + + while (++index < length) { + if (predicate(array[index], index, array)) { + return true; + } + } + return false; +} + +module.exports = arraySome; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_asciiSize.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_asciiSize.js new file mode 100644 index 0000000..11d29c3 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_asciiSize.js @@ -0,0 +1,12 @@ +var baseProperty = require('./_baseProperty'); + +/** + * Gets the size of an ASCII `string`. + * + * @private + * @param {string} string The string inspect. + * @returns {number} Returns the string size. + */ +var asciiSize = baseProperty('length'); + +module.exports = asciiSize; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_asciiToArray.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_asciiToArray.js new file mode 100644 index 0000000..8e3dd5b --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_asciiToArray.js @@ -0,0 +1,12 @@ +/** + * Converts an ASCII `string` to an array. + * + * @private + * @param {string} string The string to convert. + * @returns {Array} Returns the converted array. + */ +function asciiToArray(string) { + return string.split(''); +} + +module.exports = asciiToArray; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_asciiWords.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_asciiWords.js new file mode 100644 index 0000000..d765f0f --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_asciiWords.js @@ -0,0 +1,15 @@ +/** Used to match words composed of alphanumeric characters. */ +var reAsciiWord = /[^\x00-\x2f\x3a-\x40\x5b-\x60\x7b-\x7f]+/g; + +/** + * Splits an ASCII `string` into an array of its words. + * + * @private + * @param {string} The string to inspect. + * @returns {Array} Returns the words of `string`. + */ +function asciiWords(string) { + return string.match(reAsciiWord) || []; +} + +module.exports = asciiWords; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_assignInDefaults.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_assignInDefaults.js new file mode 100644 index 0000000..ea6b0e3 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_assignInDefaults.js @@ -0,0 +1,27 @@ +var eq = require('./eq'); + +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** Used to check objects for own properties. */ +var hasOwnProperty = objectProto.hasOwnProperty; + +/** + * Used by `_.defaults` to customize its `_.assignIn` use. + * + * @private + * @param {*} objValue The destination value. + * @param {*} srcValue The source value. + * @param {string} key The key of the property to assign. + * @param {Object} object The parent object of `objValue`. + * @returns {*} Returns the value to assign. + */ +function assignInDefaults(objValue, srcValue, key, object) { + if (objValue === undefined || + (eq(objValue, objectProto[key]) && !hasOwnProperty.call(object, key))) { + return srcValue; + } + return objValue; +} + +module.exports = assignInDefaults; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_assignMergeValue.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_assignMergeValue.js new file mode 100644 index 0000000..cb1185e --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_assignMergeValue.js @@ -0,0 +1,20 @@ +var baseAssignValue = require('./_baseAssignValue'), + eq = require('./eq'); + +/** + * This function is like `assignValue` except that it doesn't assign + * `undefined` values. + * + * @private + * @param {Object} object The object to modify. + * @param {string} key The key of the property to assign. + * @param {*} value The value to assign. + */ +function assignMergeValue(object, key, value) { + if ((value !== undefined && !eq(object[key], value)) || + (value === undefined && !(key in object))) { + baseAssignValue(object, key, value); + } +} + +module.exports = assignMergeValue; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_assignValue.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_assignValue.js new file mode 100644 index 0000000..4083957 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_assignValue.js @@ -0,0 +1,28 @@ +var baseAssignValue = require('./_baseAssignValue'), + eq = require('./eq'); + +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** Used to check objects for own properties. */ +var hasOwnProperty = objectProto.hasOwnProperty; + +/** + * Assigns `value` to `key` of `object` if the existing value is not equivalent + * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero) + * for equality comparisons. + * + * @private + * @param {Object} object The object to modify. + * @param {string} key The key of the property to assign. + * @param {*} value The value to assign. + */ +function assignValue(object, key, value) { + var objValue = object[key]; + if (!(hasOwnProperty.call(object, key) && eq(objValue, value)) || + (value === undefined && !(key in object))) { + baseAssignValue(object, key, value); + } +} + +module.exports = assignValue; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_assocIndexOf.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_assocIndexOf.js new file mode 100644 index 0000000..5b77a2b --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_assocIndexOf.js @@ -0,0 +1,21 @@ +var eq = require('./eq'); + +/** + * Gets the index at which the `key` is found in `array` of key-value pairs. + * + * @private + * @param {Array} array The array to inspect. + * @param {*} key The key to search for. + * @returns {number} Returns the index of the matched value, else `-1`. + */ +function assocIndexOf(array, key) { + var length = array.length; + while (length--) { + if (eq(array[length][0], key)) { + return length; + } + } + return -1; +} + +module.exports = assocIndexOf; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseAggregator.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseAggregator.js new file mode 100644 index 0000000..4bc9e91 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseAggregator.js @@ -0,0 +1,21 @@ +var baseEach = require('./_baseEach'); + +/** + * Aggregates elements of `collection` on `accumulator` with keys transformed + * by `iteratee` and values set by `setter`. + * + * @private + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} setter The function to set `accumulator` values. + * @param {Function} iteratee The iteratee to transform keys. + * @param {Object} accumulator The initial aggregated object. + * @returns {Function} Returns `accumulator`. + */ +function baseAggregator(collection, setter, iteratee, accumulator) { + baseEach(collection, function(value, key, collection) { + setter(accumulator, value, iteratee(value), collection); + }); + return accumulator; +} + +module.exports = baseAggregator; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseAssign.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseAssign.js new file mode 100644 index 0000000..e5c4a1a --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseAssign.js @@ -0,0 +1,17 @@ +var copyObject = require('./_copyObject'), + keys = require('./keys'); + +/** + * The base implementation of `_.assign` without support for multiple sources + * or `customizer` functions. + * + * @private + * @param {Object} object The destination object. + * @param {Object} source The source object. + * @returns {Object} Returns `object`. + */ +function baseAssign(object, source) { + return object && copyObject(source, keys(source), object); +} + +module.exports = baseAssign; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseAssignValue.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseAssignValue.js new file mode 100644 index 0000000..d6f66ef --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseAssignValue.js @@ -0,0 +1,25 @@ +var defineProperty = require('./_defineProperty'); + +/** + * The base implementation of `assignValue` and `assignMergeValue` without + * value checks. + * + * @private + * @param {Object} object The object to modify. + * @param {string} key The key of the property to assign. + * @param {*} value The value to assign. + */ +function baseAssignValue(object, key, value) { + if (key == '__proto__' && defineProperty) { + defineProperty(object, key, { + 'configurable': true, + 'enumerable': true, + 'value': value, + 'writable': true + }); + } else { + object[key] = value; + } +} + +module.exports = baseAssignValue; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseAt.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseAt.js new file mode 100644 index 0000000..ed67d9b --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseAt.js @@ -0,0 +1,23 @@ +var get = require('./get'); + +/** + * The base implementation of `_.at` without support for individual paths. + * + * @private + * @param {Object} object The object to iterate over. + * @param {string[]} paths The property paths of elements to pick. + * @returns {Array} Returns the picked elements. + */ +function baseAt(object, paths) { + var index = -1, + isNil = object == null, + length = paths.length, + result = Array(length); + + while (++index < length) { + result[index] = isNil ? undefined : get(object, paths[index]); + } + return result; +} + +module.exports = baseAt; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseClamp.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseClamp.js new file mode 100644 index 0000000..a1c5692 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseClamp.js @@ -0,0 +1,22 @@ +/** + * The base implementation of `_.clamp` which doesn't coerce arguments. + * + * @private + * @param {number} number The number to clamp. + * @param {number} [lower] The lower bound. + * @param {number} upper The upper bound. + * @returns {number} Returns the clamped number. + */ +function baseClamp(number, lower, upper) { + if (number === number) { + if (upper !== undefined) { + number = number <= upper ? number : upper; + } + if (lower !== undefined) { + number = number >= lower ? number : lower; + } + } + return number; +} + +module.exports = baseClamp; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseClone.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseClone.js new file mode 100644 index 0000000..22ff841 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseClone.js @@ -0,0 +1,133 @@ +var Stack = require('./_Stack'), + arrayEach = require('./_arrayEach'), + assignValue = require('./_assignValue'), + baseAssign = require('./_baseAssign'), + cloneBuffer = require('./_cloneBuffer'), + copyArray = require('./_copyArray'), + copySymbols = require('./_copySymbols'), + getAllKeys = require('./_getAllKeys'), + getTag = require('./_getTag'), + initCloneArray = require('./_initCloneArray'), + initCloneByTag = require('./_initCloneByTag'), + initCloneObject = require('./_initCloneObject'), + isArray = require('./isArray'), + isBuffer = require('./isBuffer'), + isObject = require('./isObject'), + keys = require('./keys'); + +/** `Object#toString` result references. */ +var argsTag = '[object Arguments]', + arrayTag = '[object Array]', + boolTag = '[object Boolean]', + dateTag = '[object Date]', + errorTag = '[object Error]', + funcTag = '[object Function]', + genTag = '[object GeneratorFunction]', + mapTag = '[object Map]', + numberTag = '[object Number]', + objectTag = '[object Object]', + regexpTag = '[object RegExp]', + setTag = '[object Set]', + stringTag = '[object String]', + symbolTag = '[object Symbol]', + weakMapTag = '[object WeakMap]'; + +var arrayBufferTag = '[object ArrayBuffer]', + dataViewTag = '[object DataView]', + float32Tag = '[object Float32Array]', + float64Tag = '[object Float64Array]', + int8Tag = '[object Int8Array]', + int16Tag = '[object Int16Array]', + int32Tag = '[object Int32Array]', + uint8Tag = '[object Uint8Array]', + uint8ClampedTag = '[object Uint8ClampedArray]', + uint16Tag = '[object Uint16Array]', + uint32Tag = '[object Uint32Array]'; + +/** Used to identify `toStringTag` values supported by `_.clone`. */ +var cloneableTags = {}; +cloneableTags[argsTag] = cloneableTags[arrayTag] = +cloneableTags[arrayBufferTag] = cloneableTags[dataViewTag] = +cloneableTags[boolTag] = cloneableTags[dateTag] = +cloneableTags[float32Tag] = cloneableTags[float64Tag] = +cloneableTags[int8Tag] = cloneableTags[int16Tag] = +cloneableTags[int32Tag] = cloneableTags[mapTag] = +cloneableTags[numberTag] = cloneableTags[objectTag] = +cloneableTags[regexpTag] = cloneableTags[setTag] = +cloneableTags[stringTag] = cloneableTags[symbolTag] = +cloneableTags[uint8Tag] = cloneableTags[uint8ClampedTag] = +cloneableTags[uint16Tag] = cloneableTags[uint32Tag] = true; +cloneableTags[errorTag] = cloneableTags[funcTag] = +cloneableTags[weakMapTag] = false; + +/** + * The base implementation of `_.clone` and `_.cloneDeep` which tracks + * traversed objects. + * + * @private + * @param {*} value The value to clone. + * @param {boolean} [isDeep] Specify a deep clone. + * @param {boolean} [isFull] Specify a clone including symbols. + * @param {Function} [customizer] The function to customize cloning. + * @param {string} [key] The key of `value`. + * @param {Object} [object] The parent object of `value`. + * @param {Object} [stack] Tracks traversed objects and their clone counterparts. + * @returns {*} Returns the cloned value. + */ +function baseClone(value, isDeep, isFull, customizer, key, object, stack) { + var result; + if (customizer) { + result = object ? customizer(value, key, object, stack) : customizer(value); + } + if (result !== undefined) { + return result; + } + if (!isObject(value)) { + return value; + } + var isArr = isArray(value); + if (isArr) { + result = initCloneArray(value); + if (!isDeep) { + return copyArray(value, result); + } + } else { + var tag = getTag(value), + isFunc = tag == funcTag || tag == genTag; + + if (isBuffer(value)) { + return cloneBuffer(value, isDeep); + } + if (tag == objectTag || tag == argsTag || (isFunc && !object)) { + result = initCloneObject(isFunc ? {} : value); + if (!isDeep) { + return copySymbols(value, baseAssign(result, value)); + } + } else { + if (!cloneableTags[tag]) { + return object ? value : {}; + } + result = initCloneByTag(value, tag, baseClone, isDeep); + } + } + // Check for circular references and return its corresponding clone. + stack || (stack = new Stack); + var stacked = stack.get(value); + if (stacked) { + return stacked; + } + stack.set(value, result); + + var props = isArr ? undefined : (isFull ? getAllKeys : keys)(value); + arrayEach(props || value, function(subValue, key) { + if (props) { + key = subValue; + subValue = value[key]; + } + // Recursively populate clone (susceptible to call stack limits). + assignValue(result, key, baseClone(subValue, isDeep, isFull, customizer, key, value, stack)); + }); + return result; +} + +module.exports = baseClone; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseConforms.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseConforms.js new file mode 100644 index 0000000..947e20d --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseConforms.js @@ -0,0 +1,18 @@ +var baseConformsTo = require('./_baseConformsTo'), + keys = require('./keys'); + +/** + * The base implementation of `_.conforms` which doesn't clone `source`. + * + * @private + * @param {Object} source The object of property predicates to conform to. + * @returns {Function} Returns the new spec function. + */ +function baseConforms(source) { + var props = keys(source); + return function(object) { + return baseConformsTo(object, source, props); + }; +} + +module.exports = baseConforms; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseConformsTo.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseConformsTo.js new file mode 100644 index 0000000..e449cb8 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseConformsTo.js @@ -0,0 +1,27 @@ +/** + * The base implementation of `_.conformsTo` which accepts `props` to check. + * + * @private + * @param {Object} object The object to inspect. + * @param {Object} source The object of property predicates to conform to. + * @returns {boolean} Returns `true` if `object` conforms, else `false`. + */ +function baseConformsTo(object, source, props) { + var length = props.length; + if (object == null) { + return !length; + } + object = Object(object); + while (length--) { + var key = props[length], + predicate = source[key], + value = object[key]; + + if ((value === undefined && !(key in object)) || !predicate(value)) { + return false; + } + } + return true; +} + +module.exports = baseConformsTo; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseCreate.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseCreate.js new file mode 100644 index 0000000..ffa6a52 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseCreate.js @@ -0,0 +1,30 @@ +var isObject = require('./isObject'); + +/** Built-in value references. */ +var objectCreate = Object.create; + +/** + * The base implementation of `_.create` without support for assigning + * properties to the created object. + * + * @private + * @param {Object} proto The object to inherit from. + * @returns {Object} Returns the new object. + */ +var baseCreate = (function() { + function object() {} + return function(proto) { + if (!isObject(proto)) { + return {}; + } + if (objectCreate) { + return objectCreate(proto); + } + object.prototype = proto; + var result = new object; + object.prototype = undefined; + return result; + }; +}()); + +module.exports = baseCreate; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseDelay.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseDelay.js new file mode 100644 index 0000000..1486d69 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseDelay.js @@ -0,0 +1,21 @@ +/** Error message constants. */ +var FUNC_ERROR_TEXT = 'Expected a function'; + +/** + * The base implementation of `_.delay` and `_.defer` which accepts `args` + * to provide to `func`. + * + * @private + * @param {Function} func The function to delay. + * @param {number} wait The number of milliseconds to delay invocation. + * @param {Array} args The arguments to provide to `func`. + * @returns {number|Object} Returns the timer id or timeout object. + */ +function baseDelay(func, wait, args) { + if (typeof func != 'function') { + throw new TypeError(FUNC_ERROR_TEXT); + } + return setTimeout(function() { func.apply(undefined, args); }, wait); +} + +module.exports = baseDelay; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseDifference.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseDifference.js new file mode 100644 index 0000000..dcccad3 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseDifference.js @@ -0,0 +1,67 @@ +var SetCache = require('./_SetCache'), + arrayIncludes = require('./_arrayIncludes'), + arrayIncludesWith = require('./_arrayIncludesWith'), + arrayMap = require('./_arrayMap'), + baseUnary = require('./_baseUnary'), + cacheHas = require('./_cacheHas'); + +/** Used as the size to enable large array optimizations. */ +var LARGE_ARRAY_SIZE = 200; + +/** + * The base implementation of methods like `_.difference` without support + * for excluding multiple arrays or iteratee shorthands. + * + * @private + * @param {Array} array The array to inspect. + * @param {Array} values The values to exclude. + * @param {Function} [iteratee] The iteratee invoked per element. + * @param {Function} [comparator] The comparator invoked per element. + * @returns {Array} Returns the new array of filtered values. + */ +function baseDifference(array, values, iteratee, comparator) { + var index = -1, + includes = arrayIncludes, + isCommon = true, + length = array.length, + result = [], + valuesLength = values.length; + + if (!length) { + return result; + } + if (iteratee) { + values = arrayMap(values, baseUnary(iteratee)); + } + if (comparator) { + includes = arrayIncludesWith; + isCommon = false; + } + else if (values.length >= LARGE_ARRAY_SIZE) { + includes = cacheHas; + isCommon = false; + values = new SetCache(values); + } + outer: + while (++index < length) { + var value = array[index], + computed = iteratee ? iteratee(value) : value; + + value = (comparator || value !== 0) ? value : 0; + if (isCommon && computed === computed) { + var valuesIndex = valuesLength; + while (valuesIndex--) { + if (values[valuesIndex] === computed) { + continue outer; + } + } + result.push(value); + } + else if (!includes(values, computed, comparator)) { + result.push(value); + } + } + return result; +} + +module.exports = baseDifference; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseEach.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseEach.js new file mode 100644 index 0000000..512c067 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseEach.js @@ -0,0 +1,14 @@ +var baseForOwn = require('./_baseForOwn'), + createBaseEach = require('./_createBaseEach'); + +/** + * The base implementation of `_.forEach` without support for iteratee shorthands. + * + * @private + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @returns {Array|Object} Returns `collection`. + */ +var baseEach = createBaseEach(baseForOwn); + +module.exports = baseEach; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseEachRight.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseEachRight.js new file mode 100644 index 0000000..0a8feec --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseEachRight.js @@ -0,0 +1,14 @@ +var baseForOwnRight = require('./_baseForOwnRight'), + createBaseEach = require('./_createBaseEach'); + +/** + * The base implementation of `_.forEachRight` without support for iteratee shorthands. + * + * @private + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @returns {Array|Object} Returns `collection`. + */ +var baseEachRight = createBaseEach(baseForOwnRight, true); + +module.exports = baseEachRight; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseEvery.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseEvery.js new file mode 100644 index 0000000..fa52f7b --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseEvery.js @@ -0,0 +1,21 @@ +var baseEach = require('./_baseEach'); + +/** + * The base implementation of `_.every` without support for iteratee shorthands. + * + * @private + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} predicate The function invoked per iteration. + * @returns {boolean} Returns `true` if all elements pass the predicate check, + * else `false` + */ +function baseEvery(collection, predicate) { + var result = true; + baseEach(collection, function(value, index, collection) { + result = !!predicate(value, index, collection); + return result; + }); + return result; +} + +module.exports = baseEvery; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseExtremum.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseExtremum.js new file mode 100644 index 0000000..9d6aa77 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseExtremum.js @@ -0,0 +1,32 @@ +var isSymbol = require('./isSymbol'); + +/** + * The base implementation of methods like `_.max` and `_.min` which accepts a + * `comparator` to determine the extremum value. + * + * @private + * @param {Array} array The array to iterate over. + * @param {Function} iteratee The iteratee invoked per iteration. + * @param {Function} comparator The comparator used to compare values. + * @returns {*} Returns the extremum value. + */ +function baseExtremum(array, iteratee, comparator) { + var index = -1, + length = array.length; + + while (++index < length) { + var value = array[index], + current = iteratee(value); + + if (current != null && (computed === undefined + ? (current === current && !isSymbol(current)) + : comparator(current, computed) + )) { + var computed = current, + result = value; + } + } + return result; +} + +module.exports = baseExtremum; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseFill.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseFill.js new file mode 100644 index 0000000..46ef9c7 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseFill.js @@ -0,0 +1,32 @@ +var toInteger = require('./toInteger'), + toLength = require('./toLength'); + +/** + * The base implementation of `_.fill` without an iteratee call guard. + * + * @private + * @param {Array} array The array to fill. + * @param {*} value The value to fill `array` with. + * @param {number} [start=0] The start position. + * @param {number} [end=array.length] The end position. + * @returns {Array} Returns `array`. + */ +function baseFill(array, value, start, end) { + var length = array.length; + + start = toInteger(start); + if (start < 0) { + start = -start > length ? 0 : (length + start); + } + end = (end === undefined || end > length) ? length : toInteger(end); + if (end < 0) { + end += length; + } + end = start > end ? 0 : toLength(end); + while (start < end) { + array[start++] = value; + } + return array; +} + +module.exports = baseFill; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseFilter.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseFilter.js new file mode 100644 index 0000000..4678477 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseFilter.js @@ -0,0 +1,21 @@ +var baseEach = require('./_baseEach'); + +/** + * The base implementation of `_.filter` without support for iteratee shorthands. + * + * @private + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} predicate The function invoked per iteration. + * @returns {Array} Returns the new filtered array. + */ +function baseFilter(collection, predicate) { + var result = []; + baseEach(collection, function(value, index, collection) { + if (predicate(value, index, collection)) { + result.push(value); + } + }); + return result; +} + +module.exports = baseFilter; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseFindIndex.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseFindIndex.js new file mode 100644 index 0000000..e3f5d8a --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseFindIndex.js @@ -0,0 +1,24 @@ +/** + * The base implementation of `_.findIndex` and `_.findLastIndex` without + * support for iteratee shorthands. + * + * @private + * @param {Array} array The array to inspect. + * @param {Function} predicate The function invoked per iteration. + * @param {number} fromIndex The index to search from. + * @param {boolean} [fromRight] Specify iterating from right to left. + * @returns {number} Returns the index of the matched value, else `-1`. + */ +function baseFindIndex(array, predicate, fromIndex, fromRight) { + var length = array.length, + index = fromIndex + (fromRight ? 1 : -1); + + while ((fromRight ? index-- : ++index < length)) { + if (predicate(array[index], index, array)) { + return index; + } + } + return -1; +} + +module.exports = baseFindIndex; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseFindKey.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseFindKey.js new file mode 100644 index 0000000..2e430f3 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseFindKey.js @@ -0,0 +1,23 @@ +/** + * The base implementation of methods like `_.findKey` and `_.findLastKey`, + * without support for iteratee shorthands, which iterates over `collection` + * using `eachFunc`. + * + * @private + * @param {Array|Object} collection The collection to inspect. + * @param {Function} predicate The function invoked per iteration. + * @param {Function} eachFunc The function to iterate over `collection`. + * @returns {*} Returns the found element or its key, else `undefined`. + */ +function baseFindKey(collection, predicate, eachFunc) { + var result; + eachFunc(collection, function(value, key, collection) { + if (predicate(value, key, collection)) { + result = key; + return false; + } + }); + return result; +} + +module.exports = baseFindKey; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseFlatten.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseFlatten.js new file mode 100644 index 0000000..4b1e009 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseFlatten.js @@ -0,0 +1,38 @@ +var arrayPush = require('./_arrayPush'), + isFlattenable = require('./_isFlattenable'); + +/** + * The base implementation of `_.flatten` with support for restricting flattening. + * + * @private + * @param {Array} array The array to flatten. + * @param {number} depth The maximum recursion depth. + * @param {boolean} [predicate=isFlattenable] The function invoked per iteration. + * @param {boolean} [isStrict] Restrict to values that pass `predicate` checks. + * @param {Array} [result=[]] The initial result value. + * @returns {Array} Returns the new flattened array. + */ +function baseFlatten(array, depth, predicate, isStrict, result) { + var index = -1, + length = array.length; + + predicate || (predicate = isFlattenable); + result || (result = []); + + while (++index < length) { + var value = array[index]; + if (depth > 0 && predicate(value)) { + if (depth > 1) { + // Recursively flatten arrays (susceptible to call stack limits). + baseFlatten(value, depth - 1, predicate, isStrict, result); + } else { + arrayPush(result, value); + } + } else if (!isStrict) { + result[result.length] = value; + } + } + return result; +} + +module.exports = baseFlatten; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseFor.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseFor.js new file mode 100644 index 0000000..d946590 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseFor.js @@ -0,0 +1,16 @@ +var createBaseFor = require('./_createBaseFor'); + +/** + * The base implementation of `baseForOwn` which iterates over `object` + * properties returned by `keysFunc` and invokes `iteratee` for each property. + * Iteratee functions may exit iteration early by explicitly returning `false`. + * + * @private + * @param {Object} object The object to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @param {Function} keysFunc The function to get the keys of `object`. + * @returns {Object} Returns `object`. + */ +var baseFor = createBaseFor(); + +module.exports = baseFor; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseForOwn.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseForOwn.js new file mode 100644 index 0000000..503d523 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseForOwn.js @@ -0,0 +1,16 @@ +var baseFor = require('./_baseFor'), + keys = require('./keys'); + +/** + * The base implementation of `_.forOwn` without support for iteratee shorthands. + * + * @private + * @param {Object} object The object to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @returns {Object} Returns `object`. + */ +function baseForOwn(object, iteratee) { + return object && baseFor(object, iteratee, keys); +} + +module.exports = baseForOwn; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseForOwnRight.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseForOwnRight.js new file mode 100644 index 0000000..a4b10e6 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseForOwnRight.js @@ -0,0 +1,16 @@ +var baseForRight = require('./_baseForRight'), + keys = require('./keys'); + +/** + * The base implementation of `_.forOwnRight` without support for iteratee shorthands. + * + * @private + * @param {Object} object The object to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @returns {Object} Returns `object`. + */ +function baseForOwnRight(object, iteratee) { + return object && baseForRight(object, iteratee, keys); +} + +module.exports = baseForOwnRight; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseForRight.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseForRight.js new file mode 100644 index 0000000..32842cd --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseForRight.js @@ -0,0 +1,15 @@ +var createBaseFor = require('./_createBaseFor'); + +/** + * This function is like `baseFor` except that it iterates over properties + * in the opposite order. + * + * @private + * @param {Object} object The object to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @param {Function} keysFunc The function to get the keys of `object`. + * @returns {Object} Returns `object`. + */ +var baseForRight = createBaseFor(true); + +module.exports = baseForRight; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseFunctions.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseFunctions.js new file mode 100644 index 0000000..d23bc9b --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseFunctions.js @@ -0,0 +1,19 @@ +var arrayFilter = require('./_arrayFilter'), + isFunction = require('./isFunction'); + +/** + * The base implementation of `_.functions` which creates an array of + * `object` function property names filtered from `props`. + * + * @private + * @param {Object} object The object to inspect. + * @param {Array} props The property names to filter. + * @returns {Array} Returns the function names. + */ +function baseFunctions(object, props) { + return arrayFilter(props, function(key) { + return isFunction(object[key]); + }); +} + +module.exports = baseFunctions; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseGet.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseGet.js new file mode 100644 index 0000000..886720b --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseGet.js @@ -0,0 +1,25 @@ +var castPath = require('./_castPath'), + isKey = require('./_isKey'), + toKey = require('./_toKey'); + +/** + * The base implementation of `_.get` without support for default values. + * + * @private + * @param {Object} object The object to query. + * @param {Array|string} path The path of the property to get. + * @returns {*} Returns the resolved value. + */ +function baseGet(object, path) { + path = isKey(path, object) ? [path] : castPath(path); + + var index = 0, + length = path.length; + + while (object != null && index < length) { + object = object[toKey(path[index++])]; + } + return (index && index == length) ? object : undefined; +} + +module.exports = baseGet; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseGetAllKeys.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseGetAllKeys.js new file mode 100644 index 0000000..8ad204e --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseGetAllKeys.js @@ -0,0 +1,20 @@ +var arrayPush = require('./_arrayPush'), + isArray = require('./isArray'); + +/** + * The base implementation of `getAllKeys` and `getAllKeysIn` which uses + * `keysFunc` and `symbolsFunc` to get the enumerable property names and + * symbols of `object`. + * + * @private + * @param {Object} object The object to query. + * @param {Function} keysFunc The function to get the keys of `object`. + * @param {Function} symbolsFunc The function to get the symbols of `object`. + * @returns {Array} Returns the array of property names and symbols. + */ +function baseGetAllKeys(object, keysFunc, symbolsFunc) { + var result = keysFunc(object); + return isArray(object) ? result : arrayPush(result, symbolsFunc(object)); +} + +module.exports = baseGetAllKeys; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseGetTag.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseGetTag.js new file mode 100644 index 0000000..c8b9e39 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseGetTag.js @@ -0,0 +1,22 @@ +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** + * Used to resolve the + * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring) + * of values. + */ +var objectToString = objectProto.toString; + +/** + * The base implementation of `getTag`. + * + * @private + * @param {*} value The value to query. + * @returns {string} Returns the `toStringTag`. + */ +function baseGetTag(value) { + return objectToString.call(value); +} + +module.exports = baseGetTag; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseGt.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseGt.js new file mode 100644 index 0000000..502d273 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseGt.js @@ -0,0 +1,14 @@ +/** + * The base implementation of `_.gt` which doesn't coerce arguments. + * + * @private + * @param {*} value The value to compare. + * @param {*} other The other value to compare. + * @returns {boolean} Returns `true` if `value` is greater than `other`, + * else `false`. + */ +function baseGt(value, other) { + return value > other; +} + +module.exports = baseGt; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseHas.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseHas.js new file mode 100644 index 0000000..1b73032 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseHas.js @@ -0,0 +1,19 @@ +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** Used to check objects for own properties. */ +var hasOwnProperty = objectProto.hasOwnProperty; + +/** + * The base implementation of `_.has` without support for deep paths. + * + * @private + * @param {Object} [object] The object to query. + * @param {Array|string} key The key to check. + * @returns {boolean} Returns `true` if `key` exists, else `false`. + */ +function baseHas(object, key) { + return object != null && hasOwnProperty.call(object, key); +} + +module.exports = baseHas; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseHasIn.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseHasIn.js new file mode 100644 index 0000000..2e0d042 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseHasIn.js @@ -0,0 +1,13 @@ +/** + * The base implementation of `_.hasIn` without support for deep paths. + * + * @private + * @param {Object} [object] The object to query. + * @param {Array|string} key The key to check. + * @returns {boolean} Returns `true` if `key` exists, else `false`. + */ +function baseHasIn(object, key) { + return object != null && key in Object(object); +} + +module.exports = baseHasIn; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseInRange.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseInRange.js new file mode 100644 index 0000000..ec95666 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseInRange.js @@ -0,0 +1,18 @@ +/* Built-in method references for those with the same name as other `lodash` methods. */ +var nativeMax = Math.max, + nativeMin = Math.min; + +/** + * The base implementation of `_.inRange` which doesn't coerce arguments. + * + * @private + * @param {number} number The number to check. + * @param {number} start The start of the range. + * @param {number} end The end of the range. + * @returns {boolean} Returns `true` if `number` is in the range, else `false`. + */ +function baseInRange(number, start, end) { + return number >= nativeMin(start, end) && number < nativeMax(start, end); +} + +module.exports = baseInRange; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIndexOf.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIndexOf.js new file mode 100644 index 0000000..167e706 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIndexOf.js @@ -0,0 +1,20 @@ +var baseFindIndex = require('./_baseFindIndex'), + baseIsNaN = require('./_baseIsNaN'), + strictIndexOf = require('./_strictIndexOf'); + +/** + * The base implementation of `_.indexOf` without `fromIndex` bounds checks. + * + * @private + * @param {Array} array The array to inspect. + * @param {*} value The value to search for. + * @param {number} fromIndex The index to search from. + * @returns {number} Returns the index of the matched value, else `-1`. + */ +function baseIndexOf(array, value, fromIndex) { + return value === value + ? strictIndexOf(array, value, fromIndex) + : baseFindIndex(array, baseIsNaN, fromIndex); +} + +module.exports = baseIndexOf; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIndexOfWith.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIndexOfWith.js new file mode 100644 index 0000000..f815fe0 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIndexOfWith.js @@ -0,0 +1,23 @@ +/** + * This function is like `baseIndexOf` except that it accepts a comparator. + * + * @private + * @param {Array} array The array to inspect. + * @param {*} value The value to search for. + * @param {number} fromIndex The index to search from. + * @param {Function} comparator The comparator invoked per element. + * @returns {number} Returns the index of the matched value, else `-1`. + */ +function baseIndexOfWith(array, value, fromIndex, comparator) { + var index = fromIndex - 1, + length = array.length; + + while (++index < length) { + if (comparator(array[index], value)) { + return index; + } + } + return -1; +} + +module.exports = baseIndexOfWith; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIntersection.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIntersection.js new file mode 100644 index 0000000..c1d250c --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIntersection.js @@ -0,0 +1,74 @@ +var SetCache = require('./_SetCache'), + arrayIncludes = require('./_arrayIncludes'), + arrayIncludesWith = require('./_arrayIncludesWith'), + arrayMap = require('./_arrayMap'), + baseUnary = require('./_baseUnary'), + cacheHas = require('./_cacheHas'); + +/* Built-in method references for those with the same name as other `lodash` methods. */ +var nativeMin = Math.min; + +/** + * The base implementation of methods like `_.intersection`, without support + * for iteratee shorthands, that accepts an array of arrays to inspect. + * + * @private + * @param {Array} arrays The arrays to inspect. + * @param {Function} [iteratee] The iteratee invoked per element. + * @param {Function} [comparator] The comparator invoked per element. + * @returns {Array} Returns the new array of shared values. + */ +function baseIntersection(arrays, iteratee, comparator) { + var includes = comparator ? arrayIncludesWith : arrayIncludes, + length = arrays[0].length, + othLength = arrays.length, + othIndex = othLength, + caches = Array(othLength), + maxLength = Infinity, + result = []; + + while (othIndex--) { + var array = arrays[othIndex]; + if (othIndex && iteratee) { + array = arrayMap(array, baseUnary(iteratee)); + } + maxLength = nativeMin(array.length, maxLength); + caches[othIndex] = !comparator && (iteratee || (length >= 120 && array.length >= 120)) + ? new SetCache(othIndex && array) + : undefined; + } + array = arrays[0]; + + var index = -1, + seen = caches[0]; + + outer: + while (++index < length && result.length < maxLength) { + var value = array[index], + computed = iteratee ? iteratee(value) : value; + + value = (comparator || value !== 0) ? value : 0; + if (!(seen + ? cacheHas(seen, computed) + : includes(result, computed, comparator) + )) { + othIndex = othLength; + while (--othIndex) { + var cache = caches[othIndex]; + if (!(cache + ? cacheHas(cache, computed) + : includes(arrays[othIndex], computed, comparator)) + ) { + continue outer; + } + } + if (seen) { + seen.push(computed); + } + result.push(value); + } + } + return result; +} + +module.exports = baseIntersection; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseInverter.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseInverter.js new file mode 100644 index 0000000..fbc337f --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseInverter.js @@ -0,0 +1,21 @@ +var baseForOwn = require('./_baseForOwn'); + +/** + * The base implementation of `_.invert` and `_.invertBy` which inverts + * `object` with values transformed by `iteratee` and set by `setter`. + * + * @private + * @param {Object} object The object to iterate over. + * @param {Function} setter The function to set `accumulator` values. + * @param {Function} iteratee The iteratee to transform values. + * @param {Object} accumulator The initial inverted object. + * @returns {Function} Returns `accumulator`. + */ +function baseInverter(object, setter, iteratee, accumulator) { + baseForOwn(object, function(value, key, object) { + setter(accumulator, iteratee(value), key, object); + }); + return accumulator; +} + +module.exports = baseInverter; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseInvoke.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseInvoke.js new file mode 100644 index 0000000..3d6bca5 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseInvoke.js @@ -0,0 +1,28 @@ +var apply = require('./_apply'), + castPath = require('./_castPath'), + isKey = require('./_isKey'), + last = require('./last'), + parent = require('./_parent'), + toKey = require('./_toKey'); + +/** + * The base implementation of `_.invoke` without support for individual + * method arguments. + * + * @private + * @param {Object} object The object to query. + * @param {Array|string} path The path of the method to invoke. + * @param {Array} args The arguments to invoke the method with. + * @returns {*} Returns the result of the invoked method. + */ +function baseInvoke(object, path, args) { + if (!isKey(path, object)) { + path = castPath(path); + object = parent(object, path); + path = last(path); + } + var func = object == null ? object : object[toKey(path)]; + return func == null ? undefined : apply(func, object, args); +} + +module.exports = baseInvoke; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIsArguments.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIsArguments.js new file mode 100644 index 0000000..a176e18 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIsArguments.js @@ -0,0 +1,27 @@ +var isObjectLike = require('./isObjectLike'); + +/** `Object#toString` result references. */ +var argsTag = '[object Arguments]'; + +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** + * Used to resolve the + * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring) + * of values. + */ +var objectToString = objectProto.toString; + +/** + * The base implementation of `_.isArguments`. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is an `arguments` object, + */ +function baseIsArguments(value) { + return isObjectLike(value) && objectToString.call(value) == argsTag; +} + +module.exports = baseIsArguments; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIsArrayBuffer.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIsArrayBuffer.js new file mode 100644 index 0000000..024ec85 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIsArrayBuffer.js @@ -0,0 +1,26 @@ +var isObjectLike = require('./isObjectLike'); + +var arrayBufferTag = '[object ArrayBuffer]'; + +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** + * Used to resolve the + * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring) + * of values. + */ +var objectToString = objectProto.toString; + +/** + * The base implementation of `_.isArrayBuffer` without Node.js optimizations. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is an array buffer, else `false`. + */ +function baseIsArrayBuffer(value) { + return isObjectLike(value) && objectToString.call(value) == arrayBufferTag; +} + +module.exports = baseIsArrayBuffer; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIsDate.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIsDate.js new file mode 100644 index 0000000..9dacf9b --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIsDate.js @@ -0,0 +1,27 @@ +var isObjectLike = require('./isObjectLike'); + +/** `Object#toString` result references. */ +var dateTag = '[object Date]'; + +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** + * Used to resolve the + * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring) + * of values. + */ +var objectToString = objectProto.toString; + +/** + * The base implementation of `_.isDate` without Node.js optimizations. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a date object, else `false`. + */ +function baseIsDate(value) { + return isObjectLike(value) && objectToString.call(value) == dateTag; +} + +module.exports = baseIsDate; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIsEqual.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIsEqual.js new file mode 100644 index 0000000..3772dab --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIsEqual.js @@ -0,0 +1,30 @@ +var baseIsEqualDeep = require('./_baseIsEqualDeep'), + isObject = require('./isObject'), + isObjectLike = require('./isObjectLike'); + +/** + * The base implementation of `_.isEqual` which supports partial comparisons + * and tracks traversed objects. + * + * @private + * @param {*} value The value to compare. + * @param {*} other The other value to compare. + * @param {Function} [customizer] The function to customize comparisons. + * @param {boolean} [bitmask] The bitmask of comparison flags. + * The bitmask may be composed of the following flags: + * 1 - Unordered comparison + * 2 - Partial comparison + * @param {Object} [stack] Tracks traversed `value` and `other` objects. + * @returns {boolean} Returns `true` if the values are equivalent, else `false`. + */ +function baseIsEqual(value, other, customizer, bitmask, stack) { + if (value === other) { + return true; + } + if (value == null || other == null || (!isObject(value) && !isObjectLike(other))) { + return value !== value && other !== other; + } + return baseIsEqualDeep(value, other, baseIsEqual, customizer, bitmask, stack); +} + +module.exports = baseIsEqual; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIsEqualDeep.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIsEqualDeep.js new file mode 100644 index 0000000..42dc03d --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIsEqualDeep.js @@ -0,0 +1,89 @@ +var Stack = require('./_Stack'), + equalArrays = require('./_equalArrays'), + equalByTag = require('./_equalByTag'), + equalObjects = require('./_equalObjects'), + getTag = require('./_getTag'), + isArray = require('./isArray'), + isBuffer = require('./isBuffer'), + isTypedArray = require('./isTypedArray'); + +/** Used to compose bitmasks for comparison styles. */ +var PARTIAL_COMPARE_FLAG = 2; + +/** `Object#toString` result references. */ +var argsTag = '[object Arguments]', + arrayTag = '[object Array]', + objectTag = '[object Object]'; + +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** Used to check objects for own properties. */ +var hasOwnProperty = objectProto.hasOwnProperty; + +/** + * A specialized version of `baseIsEqual` for arrays and objects which performs + * deep comparisons and tracks traversed objects enabling objects with circular + * references to be compared. + * + * @private + * @param {Object} object The object to compare. + * @param {Object} other The other object to compare. + * @param {Function} equalFunc The function to determine equivalents of values. + * @param {Function} [customizer] The function to customize comparisons. + * @param {number} [bitmask] The bitmask of comparison flags. See `baseIsEqual` + * for more details. + * @param {Object} [stack] Tracks traversed `object` and `other` objects. + * @returns {boolean} Returns `true` if the objects are equivalent, else `false`. + */ +function baseIsEqualDeep(object, other, equalFunc, customizer, bitmask, stack) { + var objIsArr = isArray(object), + othIsArr = isArray(other), + objTag = arrayTag, + othTag = arrayTag; + + if (!objIsArr) { + objTag = getTag(object); + objTag = objTag == argsTag ? objectTag : objTag; + } + if (!othIsArr) { + othTag = getTag(other); + othTag = othTag == argsTag ? objectTag : othTag; + } + var objIsObj = objTag == objectTag, + othIsObj = othTag == objectTag, + isSameTag = objTag == othTag; + + if (isSameTag && isBuffer(object)) { + if (!isBuffer(other)) { + return false; + } + objIsArr = true; + objIsObj = false; + } + if (isSameTag && !objIsObj) { + stack || (stack = new Stack); + return (objIsArr || isTypedArray(object)) + ? equalArrays(object, other, equalFunc, customizer, bitmask, stack) + : equalByTag(object, other, objTag, equalFunc, customizer, bitmask, stack); + } + if (!(bitmask & PARTIAL_COMPARE_FLAG)) { + var objIsWrapped = objIsObj && hasOwnProperty.call(object, '__wrapped__'), + othIsWrapped = othIsObj && hasOwnProperty.call(other, '__wrapped__'); + + if (objIsWrapped || othIsWrapped) { + var objUnwrapped = objIsWrapped ? object.value() : object, + othUnwrapped = othIsWrapped ? other.value() : other; + + stack || (stack = new Stack); + return equalFunc(objUnwrapped, othUnwrapped, customizer, bitmask, stack); + } + } + if (!isSameTag) { + return false; + } + stack || (stack = new Stack); + return equalObjects(object, other, equalFunc, customizer, bitmask, stack); +} + +module.exports = baseIsEqualDeep; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIsMap.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIsMap.js new file mode 100644 index 0000000..02a4021 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIsMap.js @@ -0,0 +1,18 @@ +var getTag = require('./_getTag'), + isObjectLike = require('./isObjectLike'); + +/** `Object#toString` result references. */ +var mapTag = '[object Map]'; + +/** + * The base implementation of `_.isMap` without Node.js optimizations. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a map, else `false`. + */ +function baseIsMap(value) { + return isObjectLike(value) && getTag(value) == mapTag; +} + +module.exports = baseIsMap; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIsMatch.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIsMatch.js new file mode 100644 index 0000000..d36c878 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIsMatch.js @@ -0,0 +1,62 @@ +var Stack = require('./_Stack'), + baseIsEqual = require('./_baseIsEqual'); + +/** Used to compose bitmasks for comparison styles. */ +var UNORDERED_COMPARE_FLAG = 1, + PARTIAL_COMPARE_FLAG = 2; + +/** + * The base implementation of `_.isMatch` without support for iteratee shorthands. + * + * @private + * @param {Object} object The object to inspect. + * @param {Object} source The object of property values to match. + * @param {Array} matchData The property names, values, and compare flags to match. + * @param {Function} [customizer] The function to customize comparisons. + * @returns {boolean} Returns `true` if `object` is a match, else `false`. + */ +function baseIsMatch(object, source, matchData, customizer) { + var index = matchData.length, + length = index, + noCustomizer = !customizer; + + if (object == null) { + return !length; + } + object = Object(object); + while (index--) { + var data = matchData[index]; + if ((noCustomizer && data[2]) + ? data[1] !== object[data[0]] + : !(data[0] in object) + ) { + return false; + } + } + while (++index < length) { + data = matchData[index]; + var key = data[0], + objValue = object[key], + srcValue = data[1]; + + if (noCustomizer && data[2]) { + if (objValue === undefined && !(key in object)) { + return false; + } + } else { + var stack = new Stack; + if (customizer) { + var result = customizer(objValue, srcValue, key, object, source, stack); + } + if (!(result === undefined + ? baseIsEqual(srcValue, objValue, customizer, UNORDERED_COMPARE_FLAG | PARTIAL_COMPARE_FLAG, stack) + : result + )) { + return false; + } + } + } + return true; +} + +module.exports = baseIsMatch; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIsNaN.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIsNaN.js new file mode 100644 index 0000000..316f1eb --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIsNaN.js @@ -0,0 +1,12 @@ +/** + * The base implementation of `_.isNaN` without support for number objects. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is `NaN`, else `false`. + */ +function baseIsNaN(value) { + return value !== value; +} + +module.exports = baseIsNaN; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIsNative.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIsNative.js new file mode 100644 index 0000000..8702330 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIsNative.js @@ -0,0 +1,47 @@ +var isFunction = require('./isFunction'), + isMasked = require('./_isMasked'), + isObject = require('./isObject'), + toSource = require('./_toSource'); + +/** + * Used to match `RegExp` + * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns). + */ +var reRegExpChar = /[\\^$.*+?()[\]{}|]/g; + +/** Used to detect host constructors (Safari). */ +var reIsHostCtor = /^\[object .+?Constructor\]$/; + +/** Used for built-in method references. */ +var funcProto = Function.prototype, + objectProto = Object.prototype; + +/** Used to resolve the decompiled source of functions. */ +var funcToString = funcProto.toString; + +/** Used to check objects for own properties. */ +var hasOwnProperty = objectProto.hasOwnProperty; + +/** Used to detect if a method is native. */ +var reIsNative = RegExp('^' + + funcToString.call(hasOwnProperty).replace(reRegExpChar, '\\$&') + .replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g, '$1.*?') + '$' +); + +/** + * The base implementation of `_.isNative` without bad shim checks. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a native function, + * else `false`. + */ +function baseIsNative(value) { + if (!isObject(value) || isMasked(value)) { + return false; + } + var pattern = isFunction(value) ? reIsNative : reIsHostCtor; + return pattern.test(toSource(value)); +} + +module.exports = baseIsNative; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIsRegExp.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIsRegExp.js new file mode 100644 index 0000000..926fbb3 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIsRegExp.js @@ -0,0 +1,27 @@ +var isObject = require('./isObject'); + +/** `Object#toString` result references. */ +var regexpTag = '[object RegExp]'; + +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** + * Used to resolve the + * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring) + * of values. + */ +var objectToString = objectProto.toString; + +/** + * The base implementation of `_.isRegExp` without Node.js optimizations. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a regexp, else `false`. + */ +function baseIsRegExp(value) { + return isObject(value) && objectToString.call(value) == regexpTag; +} + +module.exports = baseIsRegExp; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIsSet.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIsSet.js new file mode 100644 index 0000000..6dee367 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIsSet.js @@ -0,0 +1,18 @@ +var getTag = require('./_getTag'), + isObjectLike = require('./isObjectLike'); + +/** `Object#toString` result references. */ +var setTag = '[object Set]'; + +/** + * The base implementation of `_.isSet` without Node.js optimizations. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a set, else `false`. + */ +function baseIsSet(value) { + return isObjectLike(value) && getTag(value) == setTag; +} + +module.exports = baseIsSet; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIsTypedArray.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIsTypedArray.js new file mode 100644 index 0000000..9e92756 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIsTypedArray.js @@ -0,0 +1,69 @@ +var isLength = require('./isLength'), + isObjectLike = require('./isObjectLike'); + +/** `Object#toString` result references. */ +var argsTag = '[object Arguments]', + arrayTag = '[object Array]', + boolTag = '[object Boolean]', + dateTag = '[object Date]', + errorTag = '[object Error]', + funcTag = '[object Function]', + mapTag = '[object Map]', + numberTag = '[object Number]', + objectTag = '[object Object]', + regexpTag = '[object RegExp]', + setTag = '[object Set]', + stringTag = '[object String]', + weakMapTag = '[object WeakMap]'; + +var arrayBufferTag = '[object ArrayBuffer]', + dataViewTag = '[object DataView]', + float32Tag = '[object Float32Array]', + float64Tag = '[object Float64Array]', + int8Tag = '[object Int8Array]', + int16Tag = '[object Int16Array]', + int32Tag = '[object Int32Array]', + uint8Tag = '[object Uint8Array]', + uint8ClampedTag = '[object Uint8ClampedArray]', + uint16Tag = '[object Uint16Array]', + uint32Tag = '[object Uint32Array]'; + +/** Used to identify `toStringTag` values of typed arrays. */ +var typedArrayTags = {}; +typedArrayTags[float32Tag] = typedArrayTags[float64Tag] = +typedArrayTags[int8Tag] = typedArrayTags[int16Tag] = +typedArrayTags[int32Tag] = typedArrayTags[uint8Tag] = +typedArrayTags[uint8ClampedTag] = typedArrayTags[uint16Tag] = +typedArrayTags[uint32Tag] = true; +typedArrayTags[argsTag] = typedArrayTags[arrayTag] = +typedArrayTags[arrayBufferTag] = typedArrayTags[boolTag] = +typedArrayTags[dataViewTag] = typedArrayTags[dateTag] = +typedArrayTags[errorTag] = typedArrayTags[funcTag] = +typedArrayTags[mapTag] = typedArrayTags[numberTag] = +typedArrayTags[objectTag] = typedArrayTags[regexpTag] = +typedArrayTags[setTag] = typedArrayTags[stringTag] = +typedArrayTags[weakMapTag] = false; + +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** + * Used to resolve the + * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring) + * of values. + */ +var objectToString = objectProto.toString; + +/** + * The base implementation of `_.isTypedArray` without Node.js optimizations. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a typed array, else `false`. + */ +function baseIsTypedArray(value) { + return isObjectLike(value) && + isLength(value.length) && !!typedArrayTags[objectToString.call(value)]; +} + +module.exports = baseIsTypedArray; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIteratee.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIteratee.js new file mode 100644 index 0000000..995c257 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseIteratee.js @@ -0,0 +1,31 @@ +var baseMatches = require('./_baseMatches'), + baseMatchesProperty = require('./_baseMatchesProperty'), + identity = require('./identity'), + isArray = require('./isArray'), + property = require('./property'); + +/** + * The base implementation of `_.iteratee`. + * + * @private + * @param {*} [value=_.identity] The value to convert to an iteratee. + * @returns {Function} Returns the iteratee. + */ +function baseIteratee(value) { + // Don't store the `typeof` result in a variable to avoid a JIT bug in Safari 9. + // See https://bugs.webkit.org/show_bug.cgi?id=156034 for more details. + if (typeof value == 'function') { + return value; + } + if (value == null) { + return identity; + } + if (typeof value == 'object') { + return isArray(value) + ? baseMatchesProperty(value[0], value[1]) + : baseMatches(value); + } + return property(value); +} + +module.exports = baseIteratee; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseKeys.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseKeys.js new file mode 100644 index 0000000..45e9e6f --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseKeys.js @@ -0,0 +1,30 @@ +var isPrototype = require('./_isPrototype'), + nativeKeys = require('./_nativeKeys'); + +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** Used to check objects for own properties. */ +var hasOwnProperty = objectProto.hasOwnProperty; + +/** + * The base implementation of `_.keys` which doesn't treat sparse arrays as dense. + * + * @private + * @param {Object} object The object to query. + * @returns {Array} Returns the array of property names. + */ +function baseKeys(object) { + if (!isPrototype(object)) { + return nativeKeys(object); + } + var result = []; + for (var key in Object(object)) { + if (hasOwnProperty.call(object, key) && key != 'constructor') { + result.push(key); + } + } + return result; +} + +module.exports = baseKeys; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseKeysIn.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseKeysIn.js new file mode 100644 index 0000000..ea8a0a1 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseKeysIn.js @@ -0,0 +1,33 @@ +var isObject = require('./isObject'), + isPrototype = require('./_isPrototype'), + nativeKeysIn = require('./_nativeKeysIn'); + +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** Used to check objects for own properties. */ +var hasOwnProperty = objectProto.hasOwnProperty; + +/** + * The base implementation of `_.keysIn` which doesn't treat sparse arrays as dense. + * + * @private + * @param {Object} object The object to query. + * @returns {Array} Returns the array of property names. + */ +function baseKeysIn(object) { + if (!isObject(object)) { + return nativeKeysIn(object); + } + var isProto = isPrototype(object), + result = []; + + for (var key in object) { + if (!(key == 'constructor' && (isProto || !hasOwnProperty.call(object, key)))) { + result.push(key); + } + } + return result; +} + +module.exports = baseKeysIn; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseLodash.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseLodash.js new file mode 100644 index 0000000..f76c790 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseLodash.js @@ -0,0 +1,10 @@ +/** + * The function whose prototype chain sequence wrappers inherit from. + * + * @private + */ +function baseLodash() { + // No operation performed. +} + +module.exports = baseLodash; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseLt.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseLt.js new file mode 100644 index 0000000..8674d29 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseLt.js @@ -0,0 +1,14 @@ +/** + * The base implementation of `_.lt` which doesn't coerce arguments. + * + * @private + * @param {*} value The value to compare. + * @param {*} other The other value to compare. + * @returns {boolean} Returns `true` if `value` is less than `other`, + * else `false`. + */ +function baseLt(value, other) { + return value < other; +} + +module.exports = baseLt; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseMap.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseMap.js new file mode 100644 index 0000000..0bf5cea --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseMap.js @@ -0,0 +1,22 @@ +var baseEach = require('./_baseEach'), + isArrayLike = require('./isArrayLike'); + +/** + * The base implementation of `_.map` without support for iteratee shorthands. + * + * @private + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @returns {Array} Returns the new mapped array. + */ +function baseMap(collection, iteratee) { + var index = -1, + result = isArrayLike(collection) ? Array(collection.length) : []; + + baseEach(collection, function(value, key, collection) { + result[++index] = iteratee(value, key, collection); + }); + return result; +} + +module.exports = baseMap; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseMatches.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseMatches.js new file mode 100644 index 0000000..e56582a --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseMatches.js @@ -0,0 +1,22 @@ +var baseIsMatch = require('./_baseIsMatch'), + getMatchData = require('./_getMatchData'), + matchesStrictComparable = require('./_matchesStrictComparable'); + +/** + * The base implementation of `_.matches` which doesn't clone `source`. + * + * @private + * @param {Object} source The object of property values to match. + * @returns {Function} Returns the new spec function. + */ +function baseMatches(source) { + var matchData = getMatchData(source); + if (matchData.length == 1 && matchData[0][2]) { + return matchesStrictComparable(matchData[0][0], matchData[0][1]); + } + return function(object) { + return object === source || baseIsMatch(object, source, matchData); + }; +} + +module.exports = baseMatches; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseMatchesProperty.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseMatchesProperty.js new file mode 100644 index 0000000..3968081 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseMatchesProperty.js @@ -0,0 +1,33 @@ +var baseIsEqual = require('./_baseIsEqual'), + get = require('./get'), + hasIn = require('./hasIn'), + isKey = require('./_isKey'), + isStrictComparable = require('./_isStrictComparable'), + matchesStrictComparable = require('./_matchesStrictComparable'), + toKey = require('./_toKey'); + +/** Used to compose bitmasks for comparison styles. */ +var UNORDERED_COMPARE_FLAG = 1, + PARTIAL_COMPARE_FLAG = 2; + +/** + * The base implementation of `_.matchesProperty` which doesn't clone `srcValue`. + * + * @private + * @param {string} path The path of the property to get. + * @param {*} srcValue The value to match. + * @returns {Function} Returns the new spec function. + */ +function baseMatchesProperty(path, srcValue) { + if (isKey(path) && isStrictComparable(srcValue)) { + return matchesStrictComparable(toKey(path), srcValue); + } + return function(object) { + var objValue = get(object, path); + return (objValue === undefined && objValue === srcValue) + ? hasIn(object, path) + : baseIsEqual(srcValue, objValue, undefined, UNORDERED_COMPARE_FLAG | PARTIAL_COMPARE_FLAG); + }; +} + +module.exports = baseMatchesProperty; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseMean.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseMean.js new file mode 100644 index 0000000..ac99a42 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseMean.js @@ -0,0 +1,20 @@ +var baseSum = require('./_baseSum'); + +/** Used as references for various `Number` constants. */ +var NAN = 0 / 0; + +/** + * The base implementation of `_.mean` and `_.meanBy` without support for + * iteratee shorthands. + * + * @private + * @param {Array} array The array to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @returns {number} Returns the mean. + */ +function baseMean(array, iteratee) { + var length = array ? array.length : 0; + return length ? (baseSum(array, iteratee) / length) : NAN; +} + +module.exports = baseMean; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseMerge.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseMerge.js new file mode 100644 index 0000000..f4cb8c6 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseMerge.js @@ -0,0 +1,41 @@ +var Stack = require('./_Stack'), + assignMergeValue = require('./_assignMergeValue'), + baseFor = require('./_baseFor'), + baseMergeDeep = require('./_baseMergeDeep'), + isObject = require('./isObject'), + keysIn = require('./keysIn'); + +/** + * The base implementation of `_.merge` without support for multiple sources. + * + * @private + * @param {Object} object The destination object. + * @param {Object} source The source object. + * @param {number} srcIndex The index of `source`. + * @param {Function} [customizer] The function to customize merged values. + * @param {Object} [stack] Tracks traversed source values and their merged + * counterparts. + */ +function baseMerge(object, source, srcIndex, customizer, stack) { + if (object === source) { + return; + } + baseFor(source, function(srcValue, key) { + if (isObject(srcValue)) { + stack || (stack = new Stack); + baseMergeDeep(object, source, key, srcIndex, baseMerge, customizer, stack); + } + else { + var newValue = customizer + ? customizer(object[key], srcValue, (key + ''), object, source, stack) + : undefined; + + if (newValue === undefined) { + newValue = srcValue; + } + assignMergeValue(object, key, newValue); + } + }, keysIn); +} + +module.exports = baseMerge; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseMergeDeep.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseMergeDeep.js new file mode 100644 index 0000000..42b405a --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseMergeDeep.js @@ -0,0 +1,93 @@ +var assignMergeValue = require('./_assignMergeValue'), + cloneBuffer = require('./_cloneBuffer'), + cloneTypedArray = require('./_cloneTypedArray'), + copyArray = require('./_copyArray'), + initCloneObject = require('./_initCloneObject'), + isArguments = require('./isArguments'), + isArray = require('./isArray'), + isArrayLikeObject = require('./isArrayLikeObject'), + isBuffer = require('./isBuffer'), + isFunction = require('./isFunction'), + isObject = require('./isObject'), + isPlainObject = require('./isPlainObject'), + isTypedArray = require('./isTypedArray'), + toPlainObject = require('./toPlainObject'); + +/** + * A specialized version of `baseMerge` for arrays and objects which performs + * deep merges and tracks traversed objects enabling objects with circular + * references to be merged. + * + * @private + * @param {Object} object The destination object. + * @param {Object} source The source object. + * @param {string} key The key of the value to merge. + * @param {number} srcIndex The index of `source`. + * @param {Function} mergeFunc The function to merge values. + * @param {Function} [customizer] The function to customize assigned values. + * @param {Object} [stack] Tracks traversed source values and their merged + * counterparts. + */ +function baseMergeDeep(object, source, key, srcIndex, mergeFunc, customizer, stack) { + var objValue = object[key], + srcValue = source[key], + stacked = stack.get(srcValue); + + if (stacked) { + assignMergeValue(object, key, stacked); + return; + } + var newValue = customizer + ? customizer(objValue, srcValue, (key + ''), object, source, stack) + : undefined; + + var isCommon = newValue === undefined; + + if (isCommon) { + var isArr = isArray(srcValue), + isBuff = !isArr && isBuffer(srcValue), + isTyped = !isArr && !isBuff && isTypedArray(srcValue); + + newValue = srcValue; + if (isArr || isBuff || isTyped) { + if (isArray(objValue)) { + newValue = objValue; + } + else if (isArrayLikeObject(objValue)) { + newValue = copyArray(objValue); + } + else if (isBuff) { + isCommon = false; + newValue = cloneBuffer(srcValue, true); + } + else if (isTyped) { + isCommon = false; + newValue = cloneTypedArray(srcValue, true); + } + else { + newValue = []; + } + } + else if (isPlainObject(srcValue) || isArguments(srcValue)) { + newValue = objValue; + if (isArguments(objValue)) { + newValue = toPlainObject(objValue); + } + else if (!isObject(objValue) || (srcIndex && isFunction(objValue))) { + newValue = initCloneObject(srcValue); + } + } + else { + isCommon = false; + } + } + if (isCommon) { + // Recursively merge objects and arrays (susceptible to call stack limits). + stack.set(srcValue, newValue); + mergeFunc(newValue, srcValue, srcIndex, customizer, stack); + stack['delete'](srcValue); + } + assignMergeValue(object, key, newValue); +} + +module.exports = baseMergeDeep; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseNth.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseNth.js new file mode 100644 index 0000000..0403c2a --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseNth.js @@ -0,0 +1,20 @@ +var isIndex = require('./_isIndex'); + +/** + * The base implementation of `_.nth` which doesn't coerce arguments. + * + * @private + * @param {Array} array The array to query. + * @param {number} n The index of the element to return. + * @returns {*} Returns the nth element of `array`. + */ +function baseNth(array, n) { + var length = array.length; + if (!length) { + return; + } + n += n < 0 ? length : 0; + return isIndex(n, length) ? array[n] : undefined; +} + +module.exports = baseNth; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseOrderBy.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseOrderBy.js new file mode 100644 index 0000000..d8a46ab --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseOrderBy.js @@ -0,0 +1,34 @@ +var arrayMap = require('./_arrayMap'), + baseIteratee = require('./_baseIteratee'), + baseMap = require('./_baseMap'), + baseSortBy = require('./_baseSortBy'), + baseUnary = require('./_baseUnary'), + compareMultiple = require('./_compareMultiple'), + identity = require('./identity'); + +/** + * The base implementation of `_.orderBy` without param guards. + * + * @private + * @param {Array|Object} collection The collection to iterate over. + * @param {Function[]|Object[]|string[]} iteratees The iteratees to sort by. + * @param {string[]} orders The sort orders of `iteratees`. + * @returns {Array} Returns the new sorted array. + */ +function baseOrderBy(collection, iteratees, orders) { + var index = -1; + iteratees = arrayMap(iteratees.length ? iteratees : [identity], baseUnary(baseIteratee)); + + var result = baseMap(collection, function(value, key, collection) { + var criteria = arrayMap(iteratees, function(iteratee) { + return iteratee(value); + }); + return { 'criteria': criteria, 'index': ++index, 'value': value }; + }); + + return baseSortBy(result, function(object, other) { + return compareMultiple(object, other, orders); + }); +} + +module.exports = baseOrderBy; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_basePick.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_basePick.js new file mode 100644 index 0000000..add3600 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_basePick.js @@ -0,0 +1,19 @@ +var basePickBy = require('./_basePickBy'); + +/** + * The base implementation of `_.pick` without support for individual + * property identifiers. + * + * @private + * @param {Object} object The source object. + * @param {string[]} props The property identifiers to pick. + * @returns {Object} Returns the new object. + */ +function basePick(object, props) { + object = Object(object); + return basePickBy(object, props, function(value, key) { + return key in object; + }); +} + +module.exports = basePick; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_basePickBy.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_basePickBy.js new file mode 100644 index 0000000..dc9b342 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_basePickBy.js @@ -0,0 +1,28 @@ +var baseAssignValue = require('./_baseAssignValue'); + +/** + * The base implementation of `_.pickBy` without support for iteratee shorthands. + * + * @private + * @param {Object} object The source object. + * @param {string[]} props The property identifiers to pick from. + * @param {Function} predicate The function invoked per property. + * @returns {Object} Returns the new object. + */ +function basePickBy(object, props, predicate) { + var index = -1, + length = props.length, + result = {}; + + while (++index < length) { + var key = props[index], + value = object[key]; + + if (predicate(value, key)) { + baseAssignValue(result, key, value); + } + } + return result; +} + +module.exports = basePickBy; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseProperty.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseProperty.js new file mode 100644 index 0000000..496281e --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseProperty.js @@ -0,0 +1,14 @@ +/** + * The base implementation of `_.property` without support for deep paths. + * + * @private + * @param {string} key The key of the property to get. + * @returns {Function} Returns the new accessor function. + */ +function baseProperty(key) { + return function(object) { + return object == null ? undefined : object[key]; + }; +} + +module.exports = baseProperty; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_basePropertyDeep.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_basePropertyDeep.js new file mode 100644 index 0000000..1e5aae5 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_basePropertyDeep.js @@ -0,0 +1,16 @@ +var baseGet = require('./_baseGet'); + +/** + * A specialized version of `baseProperty` which supports deep paths. + * + * @private + * @param {Array|string} path The path of the property to get. + * @returns {Function} Returns the new accessor function. + */ +function basePropertyDeep(path) { + return function(object) { + return baseGet(object, path); + }; +} + +module.exports = basePropertyDeep; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_basePropertyOf.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_basePropertyOf.js new file mode 100644 index 0000000..4617399 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_basePropertyOf.js @@ -0,0 +1,14 @@ +/** + * The base implementation of `_.propertyOf` without support for deep paths. + * + * @private + * @param {Object} object The object to query. + * @returns {Function} Returns the new accessor function. + */ +function basePropertyOf(object) { + return function(key) { + return object == null ? undefined : object[key]; + }; +} + +module.exports = basePropertyOf; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_basePullAll.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_basePullAll.js new file mode 100644 index 0000000..305720e --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_basePullAll.js @@ -0,0 +1,51 @@ +var arrayMap = require('./_arrayMap'), + baseIndexOf = require('./_baseIndexOf'), + baseIndexOfWith = require('./_baseIndexOfWith'), + baseUnary = require('./_baseUnary'), + copyArray = require('./_copyArray'); + +/** Used for built-in method references. */ +var arrayProto = Array.prototype; + +/** Built-in value references. */ +var splice = arrayProto.splice; + +/** + * The base implementation of `_.pullAllBy` without support for iteratee + * shorthands. + * + * @private + * @param {Array} array The array to modify. + * @param {Array} values The values to remove. + * @param {Function} [iteratee] The iteratee invoked per element. + * @param {Function} [comparator] The comparator invoked per element. + * @returns {Array} Returns `array`. + */ +function basePullAll(array, values, iteratee, comparator) { + var indexOf = comparator ? baseIndexOfWith : baseIndexOf, + index = -1, + length = values.length, + seen = array; + + if (array === values) { + values = copyArray(values); + } + if (iteratee) { + seen = arrayMap(array, baseUnary(iteratee)); + } + while (++index < length) { + var fromIndex = 0, + value = values[index], + computed = iteratee ? iteratee(value) : value; + + while ((fromIndex = indexOf(seen, computed, fromIndex, comparator)) > -1) { + if (seen !== array) { + splice.call(seen, fromIndex, 1); + } + splice.call(array, fromIndex, 1); + } + } + return array; +} + +module.exports = basePullAll; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_basePullAt.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_basePullAt.js new file mode 100644 index 0000000..0dd1478 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_basePullAt.js @@ -0,0 +1,50 @@ +var castPath = require('./_castPath'), + isIndex = require('./_isIndex'), + isKey = require('./_isKey'), + last = require('./last'), + parent = require('./_parent'), + toKey = require('./_toKey'); + +/** Used for built-in method references. */ +var arrayProto = Array.prototype; + +/** Built-in value references. */ +var splice = arrayProto.splice; + +/** + * The base implementation of `_.pullAt` without support for individual + * indexes or capturing the removed elements. + * + * @private + * @param {Array} array The array to modify. + * @param {number[]} indexes The indexes of elements to remove. + * @returns {Array} Returns `array`. + */ +function basePullAt(array, indexes) { + var length = array ? indexes.length : 0, + lastIndex = length - 1; + + while (length--) { + var index = indexes[length]; + if (length == lastIndex || index !== previous) { + var previous = index; + if (isIndex(index)) { + splice.call(array, index, 1); + } + else if (!isKey(index, array)) { + var path = castPath(index), + object = parent(array, path); + + if (object != null) { + delete object[toKey(last(path))]; + } + } + else { + delete array[toKey(index)]; + } + } + } + return array; +} + +module.exports = basePullAt; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseRandom.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseRandom.js new file mode 100644 index 0000000..94f76a7 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseRandom.js @@ -0,0 +1,18 @@ +/* Built-in method references for those with the same name as other `lodash` methods. */ +var nativeFloor = Math.floor, + nativeRandom = Math.random; + +/** + * The base implementation of `_.random` without support for returning + * floating-point numbers. + * + * @private + * @param {number} lower The lower bound. + * @param {number} upper The upper bound. + * @returns {number} Returns the random number. + */ +function baseRandom(lower, upper) { + return lower + nativeFloor(nativeRandom() * (upper - lower + 1)); +} + +module.exports = baseRandom; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseRange.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseRange.js new file mode 100644 index 0000000..0fb8e41 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseRange.js @@ -0,0 +1,28 @@ +/* Built-in method references for those with the same name as other `lodash` methods. */ +var nativeCeil = Math.ceil, + nativeMax = Math.max; + +/** + * The base implementation of `_.range` and `_.rangeRight` which doesn't + * coerce arguments. + * + * @private + * @param {number} start The start of the range. + * @param {number} end The end of the range. + * @param {number} step The value to increment or decrement by. + * @param {boolean} [fromRight] Specify iterating from right to left. + * @returns {Array} Returns the range of numbers. + */ +function baseRange(start, end, step, fromRight) { + var index = -1, + length = nativeMax(nativeCeil((end - start) / (step || 1)), 0), + result = Array(length); + + while (length--) { + result[fromRight ? length : ++index] = start; + start += step; + } + return result; +} + +module.exports = baseRange; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseReduce.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseReduce.js new file mode 100644 index 0000000..5a1f8b5 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseReduce.js @@ -0,0 +1,23 @@ +/** + * The base implementation of `_.reduce` and `_.reduceRight`, without support + * for iteratee shorthands, which iterates over `collection` using `eachFunc`. + * + * @private + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @param {*} accumulator The initial value. + * @param {boolean} initAccum Specify using the first or last element of + * `collection` as the initial value. + * @param {Function} eachFunc The function to iterate over `collection`. + * @returns {*} Returns the accumulated value. + */ +function baseReduce(collection, iteratee, accumulator, initAccum, eachFunc) { + eachFunc(collection, function(value, index, collection) { + accumulator = initAccum + ? (initAccum = false, value) + : iteratee(accumulator, value, index, collection); + }); + return accumulator; +} + +module.exports = baseReduce; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseRepeat.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseRepeat.js new file mode 100644 index 0000000..ee44c31 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseRepeat.js @@ -0,0 +1,35 @@ +/** Used as references for various `Number` constants. */ +var MAX_SAFE_INTEGER = 9007199254740991; + +/* Built-in method references for those with the same name as other `lodash` methods. */ +var nativeFloor = Math.floor; + +/** + * The base implementation of `_.repeat` which doesn't coerce arguments. + * + * @private + * @param {string} string The string to repeat. + * @param {number} n The number of times to repeat the string. + * @returns {string} Returns the repeated string. + */ +function baseRepeat(string, n) { + var result = ''; + if (!string || n < 1 || n > MAX_SAFE_INTEGER) { + return result; + } + // Leverage the exponentiation by squaring algorithm for a faster repeat. + // See https://en.wikipedia.org/wiki/Exponentiation_by_squaring for more details. + do { + if (n % 2) { + result += string; + } + n = nativeFloor(n / 2); + if (n) { + string += string; + } + } while (n); + + return result; +} + +module.exports = baseRepeat; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseRest.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseRest.js new file mode 100644 index 0000000..d0dc4bd --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseRest.js @@ -0,0 +1,17 @@ +var identity = require('./identity'), + overRest = require('./_overRest'), + setToString = require('./_setToString'); + +/** + * The base implementation of `_.rest` which doesn't validate or coerce arguments. + * + * @private + * @param {Function} func The function to apply a rest parameter to. + * @param {number} [start=func.length-1] The start position of the rest parameter. + * @returns {Function} Returns the new function. + */ +function baseRest(func, start) { + return setToString(overRest(func, start, identity), func + ''); +} + +module.exports = baseRest; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseSample.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseSample.js new file mode 100644 index 0000000..58582b9 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseSample.js @@ -0,0 +1,15 @@ +var arraySample = require('./_arraySample'), + values = require('./values'); + +/** + * The base implementation of `_.sample`. + * + * @private + * @param {Array|Object} collection The collection to sample. + * @returns {*} Returns the random element. + */ +function baseSample(collection) { + return arraySample(values(collection)); +} + +module.exports = baseSample; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseSampleSize.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseSampleSize.js new file mode 100644 index 0000000..5c90ec5 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseSampleSize.js @@ -0,0 +1,18 @@ +var baseClamp = require('./_baseClamp'), + shuffleSelf = require('./_shuffleSelf'), + values = require('./values'); + +/** + * The base implementation of `_.sampleSize` without param guards. + * + * @private + * @param {Array|Object} collection The collection to sample. + * @param {number} n The number of elements to sample. + * @returns {Array} Returns the random elements. + */ +function baseSampleSize(collection, n) { + var array = values(collection); + return shuffleSelf(array, baseClamp(n, 0, array.length)); +} + +module.exports = baseSampleSize; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseSet.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseSet.js new file mode 100644 index 0000000..2be04d5 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseSet.js @@ -0,0 +1,48 @@ +var assignValue = require('./_assignValue'), + castPath = require('./_castPath'), + isIndex = require('./_isIndex'), + isKey = require('./_isKey'), + isObject = require('./isObject'), + toKey = require('./_toKey'); + +/** + * The base implementation of `_.set`. + * + * @private + * @param {Object} object The object to modify. + * @param {Array|string} path The path of the property to set. + * @param {*} value The value to set. + * @param {Function} [customizer] The function to customize path creation. + * @returns {Object} Returns `object`. + */ +function baseSet(object, path, value, customizer) { + if (!isObject(object)) { + return object; + } + path = isKey(path, object) ? [path] : castPath(path); + + var index = -1, + length = path.length, + lastIndex = length - 1, + nested = object; + + while (nested != null && ++index < length) { + var key = toKey(path[index]), + newValue = value; + + if (index != lastIndex) { + var objValue = nested[key]; + newValue = customizer ? customizer(objValue, key, nested) : undefined; + if (newValue === undefined) { + newValue = isObject(objValue) + ? objValue + : (isIndex(path[index + 1]) ? [] : {}); + } + } + assignValue(nested, key, newValue); + nested = nested[key]; + } + return object; +} + +module.exports = baseSet; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseSetData.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseSetData.js new file mode 100644 index 0000000..c409947 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseSetData.js @@ -0,0 +1,17 @@ +var identity = require('./identity'), + metaMap = require('./_metaMap'); + +/** + * The base implementation of `setData` without support for hot loop shorting. + * + * @private + * @param {Function} func The function to associate metadata with. + * @param {*} data The metadata. + * @returns {Function} Returns `func`. + */ +var baseSetData = !metaMap ? identity : function(func, data) { + metaMap.set(func, data); + return func; +}; + +module.exports = baseSetData; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseSetToString.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseSetToString.js new file mode 100644 index 0000000..89eaca3 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseSetToString.js @@ -0,0 +1,22 @@ +var constant = require('./constant'), + defineProperty = require('./_defineProperty'), + identity = require('./identity'); + +/** + * The base implementation of `setToString` without support for hot loop shorting. + * + * @private + * @param {Function} func The function to modify. + * @param {Function} string The `toString` result. + * @returns {Function} Returns `func`. + */ +var baseSetToString = !defineProperty ? identity : function(func, string) { + return defineProperty(func, 'toString', { + 'configurable': true, + 'enumerable': false, + 'value': constant(string), + 'writable': true + }); +}; + +module.exports = baseSetToString; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseShuffle.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseShuffle.js new file mode 100644 index 0000000..023077a --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseShuffle.js @@ -0,0 +1,15 @@ +var shuffleSelf = require('./_shuffleSelf'), + values = require('./values'); + +/** + * The base implementation of `_.shuffle`. + * + * @private + * @param {Array|Object} collection The collection to shuffle. + * @returns {Array} Returns the new shuffled array. + */ +function baseShuffle(collection) { + return shuffleSelf(values(collection)); +} + +module.exports = baseShuffle; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseSlice.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseSlice.js new file mode 100644 index 0000000..786f6c9 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseSlice.js @@ -0,0 +1,31 @@ +/** + * The base implementation of `_.slice` without an iteratee call guard. + * + * @private + * @param {Array} array The array to slice. + * @param {number} [start=0] The start position. + * @param {number} [end=array.length] The end position. + * @returns {Array} Returns the slice of `array`. + */ +function baseSlice(array, start, end) { + var index = -1, + length = array.length; + + if (start < 0) { + start = -start > length ? 0 : (length + start); + } + end = end > length ? length : end; + if (end < 0) { + end += length; + } + length = start > end ? 0 : ((end - start) >>> 0); + start >>>= 0; + + var result = Array(length); + while (++index < length) { + result[index] = array[index + start]; + } + return result; +} + +module.exports = baseSlice; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseSome.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseSome.js new file mode 100644 index 0000000..58f3f44 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseSome.js @@ -0,0 +1,22 @@ +var baseEach = require('./_baseEach'); + +/** + * The base implementation of `_.some` without support for iteratee shorthands. + * + * @private + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} predicate The function invoked per iteration. + * @returns {boolean} Returns `true` if any element passes the predicate check, + * else `false`. + */ +function baseSome(collection, predicate) { + var result; + + baseEach(collection, function(value, index, collection) { + result = predicate(value, index, collection); + return !result; + }); + return !!result; +} + +module.exports = baseSome; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseSortBy.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseSortBy.js new file mode 100644 index 0000000..a25c92e --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseSortBy.js @@ -0,0 +1,21 @@ +/** + * The base implementation of `_.sortBy` which uses `comparer` to define the + * sort order of `array` and replaces criteria objects with their corresponding + * values. + * + * @private + * @param {Array} array The array to sort. + * @param {Function} comparer The function to define sort order. + * @returns {Array} Returns `array`. + */ +function baseSortBy(array, comparer) { + var length = array.length; + + array.sort(comparer); + while (length--) { + array[length] = array[length].value; + } + return array; +} + +module.exports = baseSortBy; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseSortedIndex.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseSortedIndex.js new file mode 100644 index 0000000..0e82dc7 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseSortedIndex.js @@ -0,0 +1,42 @@ +var baseSortedIndexBy = require('./_baseSortedIndexBy'), + identity = require('./identity'), + isSymbol = require('./isSymbol'); + +/** Used as references for the maximum length and index of an array. */ +var MAX_ARRAY_LENGTH = 4294967295, + HALF_MAX_ARRAY_LENGTH = MAX_ARRAY_LENGTH >>> 1; + +/** + * The base implementation of `_.sortedIndex` and `_.sortedLastIndex` which + * performs a binary search of `array` to determine the index at which `value` + * should be inserted into `array` in order to maintain its sort order. + * + * @private + * @param {Array} array The sorted array to inspect. + * @param {*} value The value to evaluate. + * @param {boolean} [retHighest] Specify returning the highest qualified index. + * @returns {number} Returns the index at which `value` should be inserted + * into `array`. + */ +function baseSortedIndex(array, value, retHighest) { + var low = 0, + high = array ? array.length : low; + + if (typeof value == 'number' && value === value && high <= HALF_MAX_ARRAY_LENGTH) { + while (low < high) { + var mid = (low + high) >>> 1, + computed = array[mid]; + + if (computed !== null && !isSymbol(computed) && + (retHighest ? (computed <= value) : (computed < value))) { + low = mid + 1; + } else { + high = mid; + } + } + return high; + } + return baseSortedIndexBy(array, value, identity, retHighest); +} + +module.exports = baseSortedIndex; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseSortedIndexBy.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseSortedIndexBy.js new file mode 100644 index 0000000..fde7928 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseSortedIndexBy.js @@ -0,0 +1,64 @@ +var isSymbol = require('./isSymbol'); + +/** Used as references for the maximum length and index of an array. */ +var MAX_ARRAY_LENGTH = 4294967295, + MAX_ARRAY_INDEX = MAX_ARRAY_LENGTH - 1; + +/* Built-in method references for those with the same name as other `lodash` methods. */ +var nativeFloor = Math.floor, + nativeMin = Math.min; + +/** + * The base implementation of `_.sortedIndexBy` and `_.sortedLastIndexBy` + * which invokes `iteratee` for `value` and each element of `array` to compute + * their sort ranking. The iteratee is invoked with one argument; (value). + * + * @private + * @param {Array} array The sorted array to inspect. + * @param {*} value The value to evaluate. + * @param {Function} iteratee The iteratee invoked per element. + * @param {boolean} [retHighest] Specify returning the highest qualified index. + * @returns {number} Returns the index at which `value` should be inserted + * into `array`. + */ +function baseSortedIndexBy(array, value, iteratee, retHighest) { + value = iteratee(value); + + var low = 0, + high = array ? array.length : 0, + valIsNaN = value !== value, + valIsNull = value === null, + valIsSymbol = isSymbol(value), + valIsUndefined = value === undefined; + + while (low < high) { + var mid = nativeFloor((low + high) / 2), + computed = iteratee(array[mid]), + othIsDefined = computed !== undefined, + othIsNull = computed === null, + othIsReflexive = computed === computed, + othIsSymbol = isSymbol(computed); + + if (valIsNaN) { + var setLow = retHighest || othIsReflexive; + } else if (valIsUndefined) { + setLow = othIsReflexive && (retHighest || othIsDefined); + } else if (valIsNull) { + setLow = othIsReflexive && othIsDefined && (retHighest || !othIsNull); + } else if (valIsSymbol) { + setLow = othIsReflexive && othIsDefined && !othIsNull && (retHighest || !othIsSymbol); + } else if (othIsNull || othIsSymbol) { + setLow = false; + } else { + setLow = retHighest ? (computed <= value) : (computed < value); + } + if (setLow) { + low = mid + 1; + } else { + high = mid; + } + } + return nativeMin(high, MAX_ARRAY_INDEX); +} + +module.exports = baseSortedIndexBy; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseSortedUniq.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseSortedUniq.js new file mode 100644 index 0000000..802159a --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseSortedUniq.js @@ -0,0 +1,30 @@ +var eq = require('./eq'); + +/** + * The base implementation of `_.sortedUniq` and `_.sortedUniqBy` without + * support for iteratee shorthands. + * + * @private + * @param {Array} array The array to inspect. + * @param {Function} [iteratee] The iteratee invoked per element. + * @returns {Array} Returns the new duplicate free array. + */ +function baseSortedUniq(array, iteratee) { + var index = -1, + length = array.length, + resIndex = 0, + result = []; + + while (++index < length) { + var value = array[index], + computed = iteratee ? iteratee(value) : value; + + if (!index || !eq(computed, seen)) { + var seen = computed; + result[resIndex++] = value === 0 ? 0 : value; + } + } + return result; +} + +module.exports = baseSortedUniq; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseSum.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseSum.js new file mode 100644 index 0000000..a9e84c1 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseSum.js @@ -0,0 +1,24 @@ +/** + * The base implementation of `_.sum` and `_.sumBy` without support for + * iteratee shorthands. + * + * @private + * @param {Array} array The array to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @returns {number} Returns the sum. + */ +function baseSum(array, iteratee) { + var result, + index = -1, + length = array.length; + + while (++index < length) { + var current = iteratee(array[index]); + if (current !== undefined) { + result = result === undefined ? current : (result + current); + } + } + return result; +} + +module.exports = baseSum; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseTimes.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseTimes.js new file mode 100644 index 0000000..0603fc3 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseTimes.js @@ -0,0 +1,20 @@ +/** + * The base implementation of `_.times` without support for iteratee shorthands + * or max array length checks. + * + * @private + * @param {number} n The number of times to invoke `iteratee`. + * @param {Function} iteratee The function invoked per iteration. + * @returns {Array} Returns the array of results. + */ +function baseTimes(n, iteratee) { + var index = -1, + result = Array(n); + + while (++index < n) { + result[index] = iteratee(index); + } + return result; +} + +module.exports = baseTimes; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseToNumber.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseToNumber.js new file mode 100644 index 0000000..04859f3 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseToNumber.js @@ -0,0 +1,24 @@ +var isSymbol = require('./isSymbol'); + +/** Used as references for various `Number` constants. */ +var NAN = 0 / 0; + +/** + * The base implementation of `_.toNumber` which doesn't ensure correct + * conversions of binary, hexadecimal, or octal string values. + * + * @private + * @param {*} value The value to process. + * @returns {number} Returns the number. + */ +function baseToNumber(value) { + if (typeof value == 'number') { + return value; + } + if (isSymbol(value)) { + return NAN; + } + return +value; +} + +module.exports = baseToNumber; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseToPairs.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseToPairs.js new file mode 100644 index 0000000..bff1991 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseToPairs.js @@ -0,0 +1,18 @@ +var arrayMap = require('./_arrayMap'); + +/** + * The base implementation of `_.toPairs` and `_.toPairsIn` which creates an array + * of key-value pairs for `object` corresponding to the property names of `props`. + * + * @private + * @param {Object} object The object to query. + * @param {Array} props The property names to get values for. + * @returns {Object} Returns the key-value pairs. + */ +function baseToPairs(object, props) { + return arrayMap(props, function(key) { + return [key, object[key]]; + }); +} + +module.exports = baseToPairs; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseToString.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseToString.js new file mode 100644 index 0000000..ada6ad2 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseToString.js @@ -0,0 +1,37 @@ +var Symbol = require('./_Symbol'), + arrayMap = require('./_arrayMap'), + isArray = require('./isArray'), + isSymbol = require('./isSymbol'); + +/** Used as references for various `Number` constants. */ +var INFINITY = 1 / 0; + +/** Used to convert symbols to primitives and strings. */ +var symbolProto = Symbol ? Symbol.prototype : undefined, + symbolToString = symbolProto ? symbolProto.toString : undefined; + +/** + * The base implementation of `_.toString` which doesn't convert nullish + * values to empty strings. + * + * @private + * @param {*} value The value to process. + * @returns {string} Returns the string. + */ +function baseToString(value) { + // Exit early for strings to avoid a performance hit in some environments. + if (typeof value == 'string') { + return value; + } + if (isArray(value)) { + // Recursively convert values (susceptible to call stack limits). + return arrayMap(value, baseToString) + ''; + } + if (isSymbol(value)) { + return symbolToString ? symbolToString.call(value) : ''; + } + var result = (value + ''); + return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result; +} + +module.exports = baseToString; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseUnary.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseUnary.js new file mode 100644 index 0000000..98639e9 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseUnary.js @@ -0,0 +1,14 @@ +/** + * The base implementation of `_.unary` without support for storing metadata. + * + * @private + * @param {Function} func The function to cap arguments for. + * @returns {Function} Returns the new capped function. + */ +function baseUnary(func) { + return function(value) { + return func(value); + }; +} + +module.exports = baseUnary; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseUniq.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseUniq.js new file mode 100644 index 0000000..aea459d --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseUniq.js @@ -0,0 +1,72 @@ +var SetCache = require('./_SetCache'), + arrayIncludes = require('./_arrayIncludes'), + arrayIncludesWith = require('./_arrayIncludesWith'), + cacheHas = require('./_cacheHas'), + createSet = require('./_createSet'), + setToArray = require('./_setToArray'); + +/** Used as the size to enable large array optimizations. */ +var LARGE_ARRAY_SIZE = 200; + +/** + * The base implementation of `_.uniqBy` without support for iteratee shorthands. + * + * @private + * @param {Array} array The array to inspect. + * @param {Function} [iteratee] The iteratee invoked per element. + * @param {Function} [comparator] The comparator invoked per element. + * @returns {Array} Returns the new duplicate free array. + */ +function baseUniq(array, iteratee, comparator) { + var index = -1, + includes = arrayIncludes, + length = array.length, + isCommon = true, + result = [], + seen = result; + + if (comparator) { + isCommon = false; + includes = arrayIncludesWith; + } + else if (length >= LARGE_ARRAY_SIZE) { + var set = iteratee ? null : createSet(array); + if (set) { + return setToArray(set); + } + isCommon = false; + includes = cacheHas; + seen = new SetCache; + } + else { + seen = iteratee ? [] : result; + } + outer: + while (++index < length) { + var value = array[index], + computed = iteratee ? iteratee(value) : value; + + value = (comparator || value !== 0) ? value : 0; + if (isCommon && computed === computed) { + var seenIndex = seen.length; + while (seenIndex--) { + if (seen[seenIndex] === computed) { + continue outer; + } + } + if (iteratee) { + seen.push(computed); + } + result.push(value); + } + else if (!includes(seen, computed, comparator)) { + if (seen !== result) { + seen.push(computed); + } + result.push(value); + } + } + return result; +} + +module.exports = baseUniq; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseUnset.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseUnset.js new file mode 100644 index 0000000..dda80fc --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseUnset.js @@ -0,0 +1,29 @@ +var castPath = require('./_castPath'), + isKey = require('./_isKey'), + last = require('./last'), + parent = require('./_parent'), + toKey = require('./_toKey'); + +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** Used to check objects for own properties. */ +var hasOwnProperty = objectProto.hasOwnProperty; + +/** + * The base implementation of `_.unset`. + * + * @private + * @param {Object} object The object to modify. + * @param {Array|string} path The path of the property to unset. + * @returns {boolean} Returns `true` if the property is deleted, else `false`. + */ +function baseUnset(object, path) { + path = isKey(path, object) ? [path] : castPath(path); + object = parent(object, path); + + var key = toKey(last(path)); + return !(object != null && hasOwnProperty.call(object, key)) || delete object[key]; +} + +module.exports = baseUnset; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseUpdate.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseUpdate.js new file mode 100644 index 0000000..92a6237 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseUpdate.js @@ -0,0 +1,18 @@ +var baseGet = require('./_baseGet'), + baseSet = require('./_baseSet'); + +/** + * The base implementation of `_.update`. + * + * @private + * @param {Object} object The object to modify. + * @param {Array|string} path The path of the property to update. + * @param {Function} updater The function to produce the updated value. + * @param {Function} [customizer] The function to customize path creation. + * @returns {Object} Returns `object`. + */ +function baseUpdate(object, path, updater, customizer) { + return baseSet(object, path, updater(baseGet(object, path)), customizer); +} + +module.exports = baseUpdate; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseValues.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseValues.js new file mode 100644 index 0000000..b95faad --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseValues.js @@ -0,0 +1,19 @@ +var arrayMap = require('./_arrayMap'); + +/** + * The base implementation of `_.values` and `_.valuesIn` which creates an + * array of `object` property values corresponding to the property names + * of `props`. + * + * @private + * @param {Object} object The object to query. + * @param {Array} props The property names to get values for. + * @returns {Object} Returns the array of property values. + */ +function baseValues(object, props) { + return arrayMap(props, function(key) { + return object[key]; + }); +} + +module.exports = baseValues; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseWhile.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseWhile.js new file mode 100644 index 0000000..07eac61 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseWhile.js @@ -0,0 +1,26 @@ +var baseSlice = require('./_baseSlice'); + +/** + * The base implementation of methods like `_.dropWhile` and `_.takeWhile` + * without support for iteratee shorthands. + * + * @private + * @param {Array} array The array to query. + * @param {Function} predicate The function invoked per iteration. + * @param {boolean} [isDrop] Specify dropping elements instead of taking them. + * @param {boolean} [fromRight] Specify iterating from right to left. + * @returns {Array} Returns the slice of `array`. + */ +function baseWhile(array, predicate, isDrop, fromRight) { + var length = array.length, + index = fromRight ? length : -1; + + while ((fromRight ? index-- : ++index < length) && + predicate(array[index], index, array)) {} + + return isDrop + ? baseSlice(array, (fromRight ? 0 : index), (fromRight ? index + 1 : length)) + : baseSlice(array, (fromRight ? index + 1 : 0), (fromRight ? length : index)); +} + +module.exports = baseWhile; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseWrapperValue.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseWrapperValue.js new file mode 100644 index 0000000..443e0df --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseWrapperValue.js @@ -0,0 +1,25 @@ +var LazyWrapper = require('./_LazyWrapper'), + arrayPush = require('./_arrayPush'), + arrayReduce = require('./_arrayReduce'); + +/** + * The base implementation of `wrapperValue` which returns the result of + * performing a sequence of actions on the unwrapped `value`, where each + * successive action is supplied the return value of the previous. + * + * @private + * @param {*} value The unwrapped value. + * @param {Array} actions Actions to perform to resolve the unwrapped value. + * @returns {*} Returns the resolved value. + */ +function baseWrapperValue(value, actions) { + var result = value; + if (result instanceof LazyWrapper) { + result = result.value(); + } + return arrayReduce(actions, function(result, action) { + return action.func.apply(action.thisArg, arrayPush([result], action.args)); + }, result); +} + +module.exports = baseWrapperValue; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseXor.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseXor.js new file mode 100644 index 0000000..7e62d1b --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseXor.js @@ -0,0 +1,30 @@ +var arrayPush = require('./_arrayPush'), + baseDifference = require('./_baseDifference'), + baseUniq = require('./_baseUniq'); + +/** + * The base implementation of methods like `_.xor`, without support for + * iteratee shorthands, that accepts an array of arrays to inspect. + * + * @private + * @param {Array} arrays The arrays to inspect. + * @param {Function} [iteratee] The iteratee invoked per element. + * @param {Function} [comparator] The comparator invoked per element. + * @returns {Array} Returns the new array of values. + */ +function baseXor(arrays, iteratee, comparator) { + var index = -1, + length = arrays.length; + + while (++index < length) { + var result = result + ? arrayPush( + baseDifference(result, arrays[index], iteratee, comparator), + baseDifference(arrays[index], result, iteratee, comparator) + ) + : arrays[index]; + } + return (result && result.length) ? baseUniq(result, iteratee, comparator) : []; +} + +module.exports = baseXor; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseZipObject.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseZipObject.js new file mode 100644 index 0000000..401f85b --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_baseZipObject.js @@ -0,0 +1,23 @@ +/** + * This base implementation of `_.zipObject` which assigns values using `assignFunc`. + * + * @private + * @param {Array} props The property identifiers. + * @param {Array} values The property values. + * @param {Function} assignFunc The function to assign values. + * @returns {Object} Returns the new object. + */ +function baseZipObject(props, values, assignFunc) { + var index = -1, + length = props.length, + valsLength = values.length, + result = {}; + + while (++index < length) { + var value = index < valsLength ? values[index] : undefined; + assignFunc(result, props[index], value); + } + return result; +} + +module.exports = baseZipObject; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_cacheHas.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_cacheHas.js new file mode 100644 index 0000000..2dec892 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_cacheHas.js @@ -0,0 +1,13 @@ +/** + * Checks if a `cache` value for `key` exists. + * + * @private + * @param {Object} cache The cache to query. + * @param {string} key The key of the entry to check. + * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`. + */ +function cacheHas(cache, key) { + return cache.has(key); +} + +module.exports = cacheHas; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_castArrayLikeObject.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_castArrayLikeObject.js new file mode 100644 index 0000000..92c75fa --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_castArrayLikeObject.js @@ -0,0 +1,14 @@ +var isArrayLikeObject = require('./isArrayLikeObject'); + +/** + * Casts `value` to an empty array if it's not an array like object. + * + * @private + * @param {*} value The value to inspect. + * @returns {Array|Object} Returns the cast array-like object. + */ +function castArrayLikeObject(value) { + return isArrayLikeObject(value) ? value : []; +} + +module.exports = castArrayLikeObject; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_castFunction.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_castFunction.js new file mode 100644 index 0000000..98c91ae --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_castFunction.js @@ -0,0 +1,14 @@ +var identity = require('./identity'); + +/** + * Casts `value` to `identity` if it's not a function. + * + * @private + * @param {*} value The value to inspect. + * @returns {Function} Returns cast function. + */ +function castFunction(value) { + return typeof value == 'function' ? value : identity; +} + +module.exports = castFunction; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_castPath.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_castPath.js new file mode 100644 index 0000000..4f38f95 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_castPath.js @@ -0,0 +1,15 @@ +var isArray = require('./isArray'), + stringToPath = require('./_stringToPath'); + +/** + * Casts `value` to a path array if it's not one. + * + * @private + * @param {*} value The value to inspect. + * @returns {Array} Returns the cast property path array. + */ +function castPath(value) { + return isArray(value) ? value : stringToPath(value); +} + +module.exports = castPath; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_castRest.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_castRest.js new file mode 100644 index 0000000..213c66f --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_castRest.js @@ -0,0 +1,14 @@ +var baseRest = require('./_baseRest'); + +/** + * A `baseRest` alias which can be replaced with `identity` by module + * replacement plugins. + * + * @private + * @type {Function} + * @param {Function} func The function to apply a rest parameter to. + * @returns {Function} Returns the new function. + */ +var castRest = baseRest; + +module.exports = castRest; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_castSlice.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_castSlice.js new file mode 100644 index 0000000..071faeb --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_castSlice.js @@ -0,0 +1,18 @@ +var baseSlice = require('./_baseSlice'); + +/** + * Casts `array` to a slice if it's needed. + * + * @private + * @param {Array} array The array to inspect. + * @param {number} start The start position. + * @param {number} [end=array.length] The end position. + * @returns {Array} Returns the cast slice. + */ +function castSlice(array, start, end) { + var length = array.length; + end = end === undefined ? length : end; + return (!start && end >= length) ? array : baseSlice(array, start, end); +} + +module.exports = castSlice; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_charsEndIndex.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_charsEndIndex.js new file mode 100644 index 0000000..07908ff --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_charsEndIndex.js @@ -0,0 +1,19 @@ +var baseIndexOf = require('./_baseIndexOf'); + +/** + * Used by `_.trim` and `_.trimEnd` to get the index of the last string symbol + * that is not found in the character symbols. + * + * @private + * @param {Array} strSymbols The string symbols to inspect. + * @param {Array} chrSymbols The character symbols to find. + * @returns {number} Returns the index of the last unmatched string symbol. + */ +function charsEndIndex(strSymbols, chrSymbols) { + var index = strSymbols.length; + + while (index-- && baseIndexOf(chrSymbols, strSymbols[index], 0) > -1) {} + return index; +} + +module.exports = charsEndIndex; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_charsStartIndex.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_charsStartIndex.js new file mode 100644 index 0000000..b17afd2 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_charsStartIndex.js @@ -0,0 +1,20 @@ +var baseIndexOf = require('./_baseIndexOf'); + +/** + * Used by `_.trim` and `_.trimStart` to get the index of the first string symbol + * that is not found in the character symbols. + * + * @private + * @param {Array} strSymbols The string symbols to inspect. + * @param {Array} chrSymbols The character symbols to find. + * @returns {number} Returns the index of the first unmatched string symbol. + */ +function charsStartIndex(strSymbols, chrSymbols) { + var index = -1, + length = strSymbols.length; + + while (++index < length && baseIndexOf(chrSymbols, strSymbols[index], 0) > -1) {} + return index; +} + +module.exports = charsStartIndex; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_cloneArrayBuffer.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_cloneArrayBuffer.js new file mode 100644 index 0000000..c3d8f6e --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_cloneArrayBuffer.js @@ -0,0 +1,16 @@ +var Uint8Array = require('./_Uint8Array'); + +/** + * Creates a clone of `arrayBuffer`. + * + * @private + * @param {ArrayBuffer} arrayBuffer The array buffer to clone. + * @returns {ArrayBuffer} Returns the cloned array buffer. + */ +function cloneArrayBuffer(arrayBuffer) { + var result = new arrayBuffer.constructor(arrayBuffer.byteLength); + new Uint8Array(result).set(new Uint8Array(arrayBuffer)); + return result; +} + +module.exports = cloneArrayBuffer; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_cloneBuffer.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_cloneBuffer.js new file mode 100644 index 0000000..27c4810 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_cloneBuffer.js @@ -0,0 +1,35 @@ +var root = require('./_root'); + +/** Detect free variable `exports`. */ +var freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports; + +/** Detect free variable `module`. */ +var freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module; + +/** Detect the popular CommonJS extension `module.exports`. */ +var moduleExports = freeModule && freeModule.exports === freeExports; + +/** Built-in value references. */ +var Buffer = moduleExports ? root.Buffer : undefined, + allocUnsafe = Buffer ? Buffer.allocUnsafe : undefined; + +/** + * Creates a clone of `buffer`. + * + * @private + * @param {Buffer} buffer The buffer to clone. + * @param {boolean} [isDeep] Specify a deep clone. + * @returns {Buffer} Returns the cloned buffer. + */ +function cloneBuffer(buffer, isDeep) { + if (isDeep) { + return buffer.slice(); + } + var length = buffer.length, + result = allocUnsafe ? allocUnsafe(length) : new buffer.constructor(length); + + buffer.copy(result); + return result; +} + +module.exports = cloneBuffer; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_cloneDataView.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_cloneDataView.js new file mode 100644 index 0000000..9c9b7b0 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_cloneDataView.js @@ -0,0 +1,16 @@ +var cloneArrayBuffer = require('./_cloneArrayBuffer'); + +/** + * Creates a clone of `dataView`. + * + * @private + * @param {Object} dataView The data view to clone. + * @param {boolean} [isDeep] Specify a deep clone. + * @returns {Object} Returns the cloned data view. + */ +function cloneDataView(dataView, isDeep) { + var buffer = isDeep ? cloneArrayBuffer(dataView.buffer) : dataView.buffer; + return new dataView.constructor(buffer, dataView.byteOffset, dataView.byteLength); +} + +module.exports = cloneDataView; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_cloneMap.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_cloneMap.js new file mode 100644 index 0000000..b51983d --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_cloneMap.js @@ -0,0 +1,19 @@ +var addMapEntry = require('./_addMapEntry'), + arrayReduce = require('./_arrayReduce'), + mapToArray = require('./_mapToArray'); + +/** + * Creates a clone of `map`. + * + * @private + * @param {Object} map The map to clone. + * @param {Function} cloneFunc The function to clone values. + * @param {boolean} [isDeep] Specify a deep clone. + * @returns {Object} Returns the cloned map. + */ +function cloneMap(map, isDeep, cloneFunc) { + var array = isDeep ? cloneFunc(mapToArray(map), true) : mapToArray(map); + return arrayReduce(array, addMapEntry, new map.constructor); +} + +module.exports = cloneMap; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_cloneRegExp.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_cloneRegExp.js new file mode 100644 index 0000000..64a30df --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_cloneRegExp.js @@ -0,0 +1,17 @@ +/** Used to match `RegExp` flags from their coerced string values. */ +var reFlags = /\w*$/; + +/** + * Creates a clone of `regexp`. + * + * @private + * @param {Object} regexp The regexp to clone. + * @returns {Object} Returns the cloned regexp. + */ +function cloneRegExp(regexp) { + var result = new regexp.constructor(regexp.source, reFlags.exec(regexp)); + result.lastIndex = regexp.lastIndex; + return result; +} + +module.exports = cloneRegExp; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_cloneSet.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_cloneSet.js new file mode 100644 index 0000000..dc1db95 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_cloneSet.js @@ -0,0 +1,19 @@ +var addSetEntry = require('./_addSetEntry'), + arrayReduce = require('./_arrayReduce'), + setToArray = require('./_setToArray'); + +/** + * Creates a clone of `set`. + * + * @private + * @param {Object} set The set to clone. + * @param {Function} cloneFunc The function to clone values. + * @param {boolean} [isDeep] Specify a deep clone. + * @returns {Object} Returns the cloned set. + */ +function cloneSet(set, isDeep, cloneFunc) { + var array = isDeep ? cloneFunc(setToArray(set), true) : setToArray(set); + return arrayReduce(array, addSetEntry, new set.constructor); +} + +module.exports = cloneSet; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_cloneSymbol.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_cloneSymbol.js new file mode 100644 index 0000000..bede39f --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_cloneSymbol.js @@ -0,0 +1,18 @@ +var Symbol = require('./_Symbol'); + +/** Used to convert symbols to primitives and strings. */ +var symbolProto = Symbol ? Symbol.prototype : undefined, + symbolValueOf = symbolProto ? symbolProto.valueOf : undefined; + +/** + * Creates a clone of the `symbol` object. + * + * @private + * @param {Object} symbol The symbol object to clone. + * @returns {Object} Returns the cloned symbol object. + */ +function cloneSymbol(symbol) { + return symbolValueOf ? Object(symbolValueOf.call(symbol)) : {}; +} + +module.exports = cloneSymbol; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_cloneTypedArray.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_cloneTypedArray.js new file mode 100644 index 0000000..7aad84d --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_cloneTypedArray.js @@ -0,0 +1,16 @@ +var cloneArrayBuffer = require('./_cloneArrayBuffer'); + +/** + * Creates a clone of `typedArray`. + * + * @private + * @param {Object} typedArray The typed array to clone. + * @param {boolean} [isDeep] Specify a deep clone. + * @returns {Object} Returns the cloned typed array. + */ +function cloneTypedArray(typedArray, isDeep) { + var buffer = isDeep ? cloneArrayBuffer(typedArray.buffer) : typedArray.buffer; + return new typedArray.constructor(buffer, typedArray.byteOffset, typedArray.length); +} + +module.exports = cloneTypedArray; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_compareAscending.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_compareAscending.js new file mode 100644 index 0000000..8dc2791 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_compareAscending.js @@ -0,0 +1,41 @@ +var isSymbol = require('./isSymbol'); + +/** + * Compares values to sort them in ascending order. + * + * @private + * @param {*} value The value to compare. + * @param {*} other The other value to compare. + * @returns {number} Returns the sort order indicator for `value`. + */ +function compareAscending(value, other) { + if (value !== other) { + var valIsDefined = value !== undefined, + valIsNull = value === null, + valIsReflexive = value === value, + valIsSymbol = isSymbol(value); + + var othIsDefined = other !== undefined, + othIsNull = other === null, + othIsReflexive = other === other, + othIsSymbol = isSymbol(other); + + if ((!othIsNull && !othIsSymbol && !valIsSymbol && value > other) || + (valIsSymbol && othIsDefined && othIsReflexive && !othIsNull && !othIsSymbol) || + (valIsNull && othIsDefined && othIsReflexive) || + (!valIsDefined && othIsReflexive) || + !valIsReflexive) { + return 1; + } + if ((!valIsNull && !valIsSymbol && !othIsSymbol && value < other) || + (othIsSymbol && valIsDefined && valIsReflexive && !valIsNull && !valIsSymbol) || + (othIsNull && valIsDefined && valIsReflexive) || + (!othIsDefined && valIsReflexive) || + !othIsReflexive) { + return -1; + } + } + return 0; +} + +module.exports = compareAscending; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_compareMultiple.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_compareMultiple.js new file mode 100644 index 0000000..ad61f0f --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_compareMultiple.js @@ -0,0 +1,44 @@ +var compareAscending = require('./_compareAscending'); + +/** + * Used by `_.orderBy` to compare multiple properties of a value to another + * and stable sort them. + * + * If `orders` is unspecified, all values are sorted in ascending order. Otherwise, + * specify an order of "desc" for descending or "asc" for ascending sort order + * of corresponding values. + * + * @private + * @param {Object} object The object to compare. + * @param {Object} other The other object to compare. + * @param {boolean[]|string[]} orders The order to sort by for each property. + * @returns {number} Returns the sort order indicator for `object`. + */ +function compareMultiple(object, other, orders) { + var index = -1, + objCriteria = object.criteria, + othCriteria = other.criteria, + length = objCriteria.length, + ordersLength = orders.length; + + while (++index < length) { + var result = compareAscending(objCriteria[index], othCriteria[index]); + if (result) { + if (index >= ordersLength) { + return result; + } + var order = orders[index]; + return result * (order == 'desc' ? -1 : 1); + } + } + // Fixes an `Array#sort` bug in the JS engine embedded in Adobe applications + // that causes it, under certain circumstances, to provide the same value for + // `object` and `other`. See https://github.com/jashkenas/underscore/pull/1247 + // for more details. + // + // This also ensures a stable sort in V8 and other engines. + // See https://bugs.chromium.org/p/v8/issues/detail?id=90 for more details. + return object.index - other.index; +} + +module.exports = compareMultiple; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_composeArgs.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_composeArgs.js new file mode 100644 index 0000000..1ce40f4 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_composeArgs.js @@ -0,0 +1,39 @@ +/* Built-in method references for those with the same name as other `lodash` methods. */ +var nativeMax = Math.max; + +/** + * Creates an array that is the composition of partially applied arguments, + * placeholders, and provided arguments into a single array of arguments. + * + * @private + * @param {Array} args The provided arguments. + * @param {Array} partials The arguments to prepend to those provided. + * @param {Array} holders The `partials` placeholder indexes. + * @params {boolean} [isCurried] Specify composing for a curried function. + * @returns {Array} Returns the new array of composed arguments. + */ +function composeArgs(args, partials, holders, isCurried) { + var argsIndex = -1, + argsLength = args.length, + holdersLength = holders.length, + leftIndex = -1, + leftLength = partials.length, + rangeLength = nativeMax(argsLength - holdersLength, 0), + result = Array(leftLength + rangeLength), + isUncurried = !isCurried; + + while (++leftIndex < leftLength) { + result[leftIndex] = partials[leftIndex]; + } + while (++argsIndex < holdersLength) { + if (isUncurried || argsIndex < argsLength) { + result[holders[argsIndex]] = args[argsIndex]; + } + } + while (rangeLength--) { + result[leftIndex++] = args[argsIndex++]; + } + return result; +} + +module.exports = composeArgs; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_composeArgsRight.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_composeArgsRight.js new file mode 100644 index 0000000..8dc588d --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_composeArgsRight.js @@ -0,0 +1,41 @@ +/* Built-in method references for those with the same name as other `lodash` methods. */ +var nativeMax = Math.max; + +/** + * This function is like `composeArgs` except that the arguments composition + * is tailored for `_.partialRight`. + * + * @private + * @param {Array} args The provided arguments. + * @param {Array} partials The arguments to append to those provided. + * @param {Array} holders The `partials` placeholder indexes. + * @params {boolean} [isCurried] Specify composing for a curried function. + * @returns {Array} Returns the new array of composed arguments. + */ +function composeArgsRight(args, partials, holders, isCurried) { + var argsIndex = -1, + argsLength = args.length, + holdersIndex = -1, + holdersLength = holders.length, + rightIndex = -1, + rightLength = partials.length, + rangeLength = nativeMax(argsLength - holdersLength, 0), + result = Array(rangeLength + rightLength), + isUncurried = !isCurried; + + while (++argsIndex < rangeLength) { + result[argsIndex] = args[argsIndex]; + } + var offset = argsIndex; + while (++rightIndex < rightLength) { + result[offset + rightIndex] = partials[rightIndex]; + } + while (++holdersIndex < holdersLength) { + if (isUncurried || argsIndex < argsLength) { + result[offset + holders[holdersIndex]] = args[argsIndex++]; + } + } + return result; +} + +module.exports = composeArgsRight; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_copyArray.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_copyArray.js new file mode 100644 index 0000000..cd94d5d --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_copyArray.js @@ -0,0 +1,20 @@ +/** + * Copies the values of `source` to `array`. + * + * @private + * @param {Array} source The array to copy values from. + * @param {Array} [array=[]] The array to copy values to. + * @returns {Array} Returns `array`. + */ +function copyArray(source, array) { + var index = -1, + length = source.length; + + array || (array = Array(length)); + while (++index < length) { + array[index] = source[index]; + } + return array; +} + +module.exports = copyArray; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_copyObject.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_copyObject.js new file mode 100644 index 0000000..2f2a5c2 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_copyObject.js @@ -0,0 +1,40 @@ +var assignValue = require('./_assignValue'), + baseAssignValue = require('./_baseAssignValue'); + +/** + * Copies properties of `source` to `object`. + * + * @private + * @param {Object} source The object to copy properties from. + * @param {Array} props The property identifiers to copy. + * @param {Object} [object={}] The object to copy properties to. + * @param {Function} [customizer] The function to customize copied values. + * @returns {Object} Returns `object`. + */ +function copyObject(source, props, object, customizer) { + var isNew = !object; + object || (object = {}); + + var index = -1, + length = props.length; + + while (++index < length) { + var key = props[index]; + + var newValue = customizer + ? customizer(object[key], source[key], key, object, source) + : undefined; + + if (newValue === undefined) { + newValue = source[key]; + } + if (isNew) { + baseAssignValue(object, key, newValue); + } else { + assignValue(object, key, newValue); + } + } + return object; +} + +module.exports = copyObject; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_copySymbols.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_copySymbols.js new file mode 100644 index 0000000..1fac3c8 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_copySymbols.js @@ -0,0 +1,16 @@ +var copyObject = require('./_copyObject'), + getSymbols = require('./_getSymbols'); + +/** + * Copies own symbol properties of `source` to `object`. + * + * @private + * @param {Object} source The object to copy symbols from. + * @param {Object} [object={}] The object to copy symbols to. + * @returns {Object} Returns `object`. + */ +function copySymbols(source, object) { + return copyObject(source, getSymbols(source), object); +} + +module.exports = copySymbols; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_coreJsData.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_coreJsData.js new file mode 100644 index 0000000..f8e5b4e --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_coreJsData.js @@ -0,0 +1,6 @@ +var root = require('./_root'); + +/** Used to detect overreaching core-js shims. */ +var coreJsData = root['__core-js_shared__']; + +module.exports = coreJsData; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_countHolders.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_countHolders.js new file mode 100644 index 0000000..718fcda --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_countHolders.js @@ -0,0 +1,21 @@ +/** + * Gets the number of `placeholder` occurrences in `array`. + * + * @private + * @param {Array} array The array to inspect. + * @param {*} placeholder The placeholder to search for. + * @returns {number} Returns the placeholder count. + */ +function countHolders(array, placeholder) { + var length = array.length, + result = 0; + + while (length--) { + if (array[length] === placeholder) { + ++result; + } + } + return result; +} + +module.exports = countHolders; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_createAggregator.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_createAggregator.js new file mode 100644 index 0000000..0be42c4 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_createAggregator.js @@ -0,0 +1,23 @@ +var arrayAggregator = require('./_arrayAggregator'), + baseAggregator = require('./_baseAggregator'), + baseIteratee = require('./_baseIteratee'), + isArray = require('./isArray'); + +/** + * Creates a function like `_.groupBy`. + * + * @private + * @param {Function} setter The function to set accumulator values. + * @param {Function} [initializer] The accumulator object initializer. + * @returns {Function} Returns the new aggregator function. + */ +function createAggregator(setter, initializer) { + return function(collection, iteratee) { + var func = isArray(collection) ? arrayAggregator : baseAggregator, + accumulator = initializer ? initializer() : {}; + + return func(collection, setter, baseIteratee(iteratee, 2), accumulator); + }; +} + +module.exports = createAggregator; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_createAssigner.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_createAssigner.js new file mode 100644 index 0000000..1f904c5 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_createAssigner.js @@ -0,0 +1,37 @@ +var baseRest = require('./_baseRest'), + isIterateeCall = require('./_isIterateeCall'); + +/** + * Creates a function like `_.assign`. + * + * @private + * @param {Function} assigner The function to assign values. + * @returns {Function} Returns the new assigner function. + */ +function createAssigner(assigner) { + return baseRest(function(object, sources) { + var index = -1, + length = sources.length, + customizer = length > 1 ? sources[length - 1] : undefined, + guard = length > 2 ? sources[2] : undefined; + + customizer = (assigner.length > 3 && typeof customizer == 'function') + ? (length--, customizer) + : undefined; + + if (guard && isIterateeCall(sources[0], sources[1], guard)) { + customizer = length < 3 ? undefined : customizer; + length = 1; + } + object = Object(object); + while (++index < length) { + var source = sources[index]; + if (source) { + assigner(object, source, index, customizer); + } + } + return object; + }); +} + +module.exports = createAssigner; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_createBaseEach.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_createBaseEach.js new file mode 100644 index 0000000..d24fdd1 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_createBaseEach.js @@ -0,0 +1,32 @@ +var isArrayLike = require('./isArrayLike'); + +/** + * Creates a `baseEach` or `baseEachRight` function. + * + * @private + * @param {Function} eachFunc The function to iterate over a collection. + * @param {boolean} [fromRight] Specify iterating from right to left. + * @returns {Function} Returns the new base function. + */ +function createBaseEach(eachFunc, fromRight) { + return function(collection, iteratee) { + if (collection == null) { + return collection; + } + if (!isArrayLike(collection)) { + return eachFunc(collection, iteratee); + } + var length = collection.length, + index = fromRight ? length : -1, + iterable = Object(collection); + + while ((fromRight ? index-- : ++index < length)) { + if (iteratee(iterable[index], index, iterable) === false) { + break; + } + } + return collection; + }; +} + +module.exports = createBaseEach; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_createBaseFor.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_createBaseFor.js new file mode 100644 index 0000000..94cbf29 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_createBaseFor.js @@ -0,0 +1,25 @@ +/** + * Creates a base function for methods like `_.forIn` and `_.forOwn`. + * + * @private + * @param {boolean} [fromRight] Specify iterating from right to left. + * @returns {Function} Returns the new base function. + */ +function createBaseFor(fromRight) { + return function(object, iteratee, keysFunc) { + var index = -1, + iterable = Object(object), + props = keysFunc(object), + length = props.length; + + while (length--) { + var key = props[fromRight ? length : ++index]; + if (iteratee(iterable[key], key, iterable) === false) { + break; + } + } + return object; + }; +} + +module.exports = createBaseFor; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_createBind.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_createBind.js new file mode 100644 index 0000000..aadc943 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_createBind.js @@ -0,0 +1,28 @@ +var createCtor = require('./_createCtor'), + root = require('./_root'); + +/** Used to compose bitmasks for function metadata. */ +var BIND_FLAG = 1; + +/** + * Creates a function that wraps `func` to invoke it with the optional `this` + * binding of `thisArg`. + * + * @private + * @param {Function} func The function to wrap. + * @param {number} bitmask The bitmask flags. See `createWrap` for more details. + * @param {*} [thisArg] The `this` binding of `func`. + * @returns {Function} Returns the new wrapped function. + */ +function createBind(func, bitmask, thisArg) { + var isBind = bitmask & BIND_FLAG, + Ctor = createCtor(func); + + function wrapper() { + var fn = (this && this !== root && this instanceof wrapper) ? Ctor : func; + return fn.apply(isBind ? thisArg : this, arguments); + } + return wrapper; +} + +module.exports = createBind; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_createCaseFirst.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_createCaseFirst.js new file mode 100644 index 0000000..fe8ea48 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_createCaseFirst.js @@ -0,0 +1,33 @@ +var castSlice = require('./_castSlice'), + hasUnicode = require('./_hasUnicode'), + stringToArray = require('./_stringToArray'), + toString = require('./toString'); + +/** + * Creates a function like `_.lowerFirst`. + * + * @private + * @param {string} methodName The name of the `String` case method to use. + * @returns {Function} Returns the new case function. + */ +function createCaseFirst(methodName) { + return function(string) { + string = toString(string); + + var strSymbols = hasUnicode(string) + ? stringToArray(string) + : undefined; + + var chr = strSymbols + ? strSymbols[0] + : string.charAt(0); + + var trailing = strSymbols + ? castSlice(strSymbols, 1).join('') + : string.slice(1); + + return chr[methodName]() + trailing; + }; +} + +module.exports = createCaseFirst; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_createCompounder.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_createCompounder.js new file mode 100644 index 0000000..8d4cee2 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_createCompounder.js @@ -0,0 +1,24 @@ +var arrayReduce = require('./_arrayReduce'), + deburr = require('./deburr'), + words = require('./words'); + +/** Used to compose unicode capture groups. */ +var rsApos = "['\u2019]"; + +/** Used to match apostrophes. */ +var reApos = RegExp(rsApos, 'g'); + +/** + * Creates a function like `_.camelCase`. + * + * @private + * @param {Function} callback The function to combine each word. + * @returns {Function} Returns the new compounder function. + */ +function createCompounder(callback) { + return function(string) { + return arrayReduce(words(deburr(string).replace(reApos, '')), callback, ''); + }; +} + +module.exports = createCompounder; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_createCtor.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_createCtor.js new file mode 100644 index 0000000..9047aa5 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_createCtor.js @@ -0,0 +1,37 @@ +var baseCreate = require('./_baseCreate'), + isObject = require('./isObject'); + +/** + * Creates a function that produces an instance of `Ctor` regardless of + * whether it was invoked as part of a `new` expression or by `call` or `apply`. + * + * @private + * @param {Function} Ctor The constructor to wrap. + * @returns {Function} Returns the new wrapped function. + */ +function createCtor(Ctor) { + return function() { + // Use a `switch` statement to work with class constructors. See + // http://ecma-international.org/ecma-262/7.0/#sec-ecmascript-function-objects-call-thisargument-argumentslist + // for more details. + var args = arguments; + switch (args.length) { + case 0: return new Ctor; + case 1: return new Ctor(args[0]); + case 2: return new Ctor(args[0], args[1]); + case 3: return new Ctor(args[0], args[1], args[2]); + case 4: return new Ctor(args[0], args[1], args[2], args[3]); + case 5: return new Ctor(args[0], args[1], args[2], args[3], args[4]); + case 6: return new Ctor(args[0], args[1], args[2], args[3], args[4], args[5]); + case 7: return new Ctor(args[0], args[1], args[2], args[3], args[4], args[5], args[6]); + } + var thisBinding = baseCreate(Ctor.prototype), + result = Ctor.apply(thisBinding, args); + + // Mimic the constructor's `return` behavior. + // See https://es5.github.io/#x13.2.2 for more details. + return isObject(result) ? result : thisBinding; + }; +} + +module.exports = createCtor; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_createCurry.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_createCurry.js new file mode 100644 index 0000000..f06c2cd --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_createCurry.js @@ -0,0 +1,46 @@ +var apply = require('./_apply'), + createCtor = require('./_createCtor'), + createHybrid = require('./_createHybrid'), + createRecurry = require('./_createRecurry'), + getHolder = require('./_getHolder'), + replaceHolders = require('./_replaceHolders'), + root = require('./_root'); + +/** + * Creates a function that wraps `func` to enable currying. + * + * @private + * @param {Function} func The function to wrap. + * @param {number} bitmask The bitmask flags. See `createWrap` for more details. + * @param {number} arity The arity of `func`. + * @returns {Function} Returns the new wrapped function. + */ +function createCurry(func, bitmask, arity) { + var Ctor = createCtor(func); + + function wrapper() { + var length = arguments.length, + args = Array(length), + index = length, + placeholder = getHolder(wrapper); + + while (index--) { + args[index] = arguments[index]; + } + var holders = (length < 3 && args[0] !== placeholder && args[length - 1] !== placeholder) + ? [] + : replaceHolders(args, placeholder); + + length -= holders.length; + if (length < arity) { + return createRecurry( + func, bitmask, createHybrid, wrapper.placeholder, undefined, + args, holders, undefined, undefined, arity - length); + } + var fn = (this && this !== root && this instanceof wrapper) ? Ctor : func; + return apply(fn, this, args); + } + return wrapper; +} + +module.exports = createCurry; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_createFind.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_createFind.js new file mode 100644 index 0000000..8859ff8 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_createFind.js @@ -0,0 +1,25 @@ +var baseIteratee = require('./_baseIteratee'), + isArrayLike = require('./isArrayLike'), + keys = require('./keys'); + +/** + * Creates a `_.find` or `_.findLast` function. + * + * @private + * @param {Function} findIndexFunc The function to find the collection index. + * @returns {Function} Returns the new find function. + */ +function createFind(findIndexFunc) { + return function(collection, predicate, fromIndex) { + var iterable = Object(collection); + if (!isArrayLike(collection)) { + var iteratee = baseIteratee(predicate, 3); + collection = keys(collection); + predicate = function(key) { return iteratee(iterable[key], key, iterable); }; + } + var index = findIndexFunc(collection, predicate, fromIndex); + return index > -1 ? iterable[iteratee ? collection[index] : index] : undefined; + }; +} + +module.exports = createFind; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_createFlow.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_createFlow.js new file mode 100644 index 0000000..b70d1df --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_createFlow.js @@ -0,0 +1,82 @@ +var LodashWrapper = require('./_LodashWrapper'), + flatRest = require('./_flatRest'), + getData = require('./_getData'), + getFuncName = require('./_getFuncName'), + isArray = require('./isArray'), + isLaziable = require('./_isLaziable'); + +/** Used as the size to enable large array optimizations. */ +var LARGE_ARRAY_SIZE = 200; + +/** Error message constants. */ +var FUNC_ERROR_TEXT = 'Expected a function'; + +/** Used to compose bitmasks for function metadata. */ +var CURRY_FLAG = 8, + PARTIAL_FLAG = 32, + ARY_FLAG = 128, + REARG_FLAG = 256; + +/** + * Creates a `_.flow` or `_.flowRight` function. + * + * @private + * @param {boolean} [fromRight] Specify iterating from right to left. + * @returns {Function} Returns the new flow function. + */ +function createFlow(fromRight) { + return flatRest(function(funcs) { + var length = funcs.length, + index = length, + prereq = LodashWrapper.prototype.thru; + + if (fromRight) { + funcs.reverse(); + } + while (index--) { + var func = funcs[index]; + if (typeof func != 'function') { + throw new TypeError(FUNC_ERROR_TEXT); + } + if (prereq && !wrapper && getFuncName(func) == 'wrapper') { + var wrapper = new LodashWrapper([], true); + } + } + index = wrapper ? index : length; + while (++index < length) { + func = funcs[index]; + + var funcName = getFuncName(func), + data = funcName == 'wrapper' ? getData(func) : undefined; + + if (data && isLaziable(data[0]) && + data[1] == (ARY_FLAG | CURRY_FLAG | PARTIAL_FLAG | REARG_FLAG) && + !data[4].length && data[9] == 1 + ) { + wrapper = wrapper[getFuncName(data[0])].apply(wrapper, data[3]); + } else { + wrapper = (func.length == 1 && isLaziable(func)) + ? wrapper[funcName]() + : wrapper.thru(func); + } + } + return function() { + var args = arguments, + value = args[0]; + + if (wrapper && args.length == 1 && + isArray(value) && value.length >= LARGE_ARRAY_SIZE) { + return wrapper.plant(value).value(); + } + var index = 0, + result = length ? funcs[index].apply(this, args) : value; + + while (++index < length) { + result = funcs[index].call(this, result); + } + return result; + }; + }); +} + +module.exports = createFlow; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_createHybrid.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_createHybrid.js new file mode 100644 index 0000000..1594b88 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_createHybrid.js @@ -0,0 +1,92 @@ +var composeArgs = require('./_composeArgs'), + composeArgsRight = require('./_composeArgsRight'), + countHolders = require('./_countHolders'), + createCtor = require('./_createCtor'), + createRecurry = require('./_createRecurry'), + getHolder = require('./_getHolder'), + reorder = require('./_reorder'), + replaceHolders = require('./_replaceHolders'), + root = require('./_root'); + +/** Used to compose bitmasks for function metadata. */ +var BIND_FLAG = 1, + BIND_KEY_FLAG = 2, + CURRY_FLAG = 8, + CURRY_RIGHT_FLAG = 16, + ARY_FLAG = 128, + FLIP_FLAG = 512; + +/** + * Creates a function that wraps `func` to invoke it with optional `this` + * binding of `thisArg`, partial application, and currying. + * + * @private + * @param {Function|string} func The function or method name to wrap. + * @param {number} bitmask The bitmask flags. See `createWrap` for more details. + * @param {*} [thisArg] The `this` binding of `func`. + * @param {Array} [partials] The arguments to prepend to those provided to + * the new function. + * @param {Array} [holders] The `partials` placeholder indexes. + * @param {Array} [partialsRight] The arguments to append to those provided + * to the new function. + * @param {Array} [holdersRight] The `partialsRight` placeholder indexes. + * @param {Array} [argPos] The argument positions of the new function. + * @param {number} [ary] The arity cap of `func`. + * @param {number} [arity] The arity of `func`. + * @returns {Function} Returns the new wrapped function. + */ +function createHybrid(func, bitmask, thisArg, partials, holders, partialsRight, holdersRight, argPos, ary, arity) { + var isAry = bitmask & ARY_FLAG, + isBind = bitmask & BIND_FLAG, + isBindKey = bitmask & BIND_KEY_FLAG, + isCurried = bitmask & (CURRY_FLAG | CURRY_RIGHT_FLAG), + isFlip = bitmask & FLIP_FLAG, + Ctor = isBindKey ? undefined : createCtor(func); + + function wrapper() { + var length = arguments.length, + args = Array(length), + index = length; + + while (index--) { + args[index] = arguments[index]; + } + if (isCurried) { + var placeholder = getHolder(wrapper), + holdersCount = countHolders(args, placeholder); + } + if (partials) { + args = composeArgs(args, partials, holders, isCurried); + } + if (partialsRight) { + args = composeArgsRight(args, partialsRight, holdersRight, isCurried); + } + length -= holdersCount; + if (isCurried && length < arity) { + var newHolders = replaceHolders(args, placeholder); + return createRecurry( + func, bitmask, createHybrid, wrapper.placeholder, thisArg, + args, newHolders, argPos, ary, arity - length + ); + } + var thisBinding = isBind ? thisArg : this, + fn = isBindKey ? thisBinding[func] : func; + + length = args.length; + if (argPos) { + args = reorder(args, argPos); + } else if (isFlip && length > 1) { + args.reverse(); + } + if (isAry && ary < length) { + args.length = ary; + } + if (this && this !== root && this instanceof wrapper) { + fn = Ctor || createCtor(fn); + } + return fn.apply(thisBinding, args); + } + return wrapper; +} + +module.exports = createHybrid; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_createInverter.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_createInverter.js new file mode 100644 index 0000000..6c0c562 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_createInverter.js @@ -0,0 +1,17 @@ +var baseInverter = require('./_baseInverter'); + +/** + * Creates a function like `_.invertBy`. + * + * @private + * @param {Function} setter The function to set accumulator values. + * @param {Function} toIteratee The function to resolve iteratees. + * @returns {Function} Returns the new inverter function. + */ +function createInverter(setter, toIteratee) { + return function(object, iteratee) { + return baseInverter(object, setter, toIteratee(iteratee), {}); + }; +} + +module.exports = createInverter; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_createMathOperation.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_createMathOperation.js new file mode 100644 index 0000000..f1e238a --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_createMathOperation.js @@ -0,0 +1,38 @@ +var baseToNumber = require('./_baseToNumber'), + baseToString = require('./_baseToString'); + +/** + * Creates a function that performs a mathematical operation on two values. + * + * @private + * @param {Function} operator The function to perform the operation. + * @param {number} [defaultValue] The value used for `undefined` arguments. + * @returns {Function} Returns the new mathematical operation function. + */ +function createMathOperation(operator, defaultValue) { + return function(value, other) { + var result; + if (value === undefined && other === undefined) { + return defaultValue; + } + if (value !== undefined) { + result = value; + } + if (other !== undefined) { + if (result === undefined) { + return other; + } + if (typeof value == 'string' || typeof other == 'string') { + value = baseToString(value); + other = baseToString(other); + } else { + value = baseToNumber(value); + other = baseToNumber(other); + } + result = operator(value, other); + } + return result; + }; +} + +module.exports = createMathOperation; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_createOver.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_createOver.js new file mode 100644 index 0000000..3b94551 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_createOver.js @@ -0,0 +1,27 @@ +var apply = require('./_apply'), + arrayMap = require('./_arrayMap'), + baseIteratee = require('./_baseIteratee'), + baseRest = require('./_baseRest'), + baseUnary = require('./_baseUnary'), + flatRest = require('./_flatRest'); + +/** + * Creates a function like `_.over`. + * + * @private + * @param {Function} arrayFunc The function to iterate over iteratees. + * @returns {Function} Returns the new over function. + */ +function createOver(arrayFunc) { + return flatRest(function(iteratees) { + iteratees = arrayMap(iteratees, baseUnary(baseIteratee)); + return baseRest(function(args) { + var thisArg = this; + return arrayFunc(iteratees, function(iteratee) { + return apply(iteratee, thisArg, args); + }); + }); + }); +} + +module.exports = createOver; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_createPadding.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_createPadding.js new file mode 100644 index 0000000..2124612 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_createPadding.js @@ -0,0 +1,33 @@ +var baseRepeat = require('./_baseRepeat'), + baseToString = require('./_baseToString'), + castSlice = require('./_castSlice'), + hasUnicode = require('./_hasUnicode'), + stringSize = require('./_stringSize'), + stringToArray = require('./_stringToArray'); + +/* Built-in method references for those with the same name as other `lodash` methods. */ +var nativeCeil = Math.ceil; + +/** + * Creates the padding for `string` based on `length`. The `chars` string + * is truncated if the number of characters exceeds `length`. + * + * @private + * @param {number} length The padding length. + * @param {string} [chars=' '] The string used as padding. + * @returns {string} Returns the padding for `string`. + */ +function createPadding(length, chars) { + chars = chars === undefined ? ' ' : baseToString(chars); + + var charsLength = chars.length; + if (charsLength < 2) { + return charsLength ? baseRepeat(chars, length) : chars; + } + var result = baseRepeat(chars, nativeCeil(length / stringSize(chars))); + return hasUnicode(chars) + ? castSlice(stringToArray(result), 0, length).join('') + : result.slice(0, length); +} + +module.exports = createPadding; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_createPartial.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_createPartial.js new file mode 100644 index 0000000..fc2bf8b --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_createPartial.js @@ -0,0 +1,43 @@ +var apply = require('./_apply'), + createCtor = require('./_createCtor'), + root = require('./_root'); + +/** Used to compose bitmasks for function metadata. */ +var BIND_FLAG = 1; + +/** + * Creates a function that wraps `func` to invoke it with the `this` binding + * of `thisArg` and `partials` prepended to the arguments it receives. + * + * @private + * @param {Function} func The function to wrap. + * @param {number} bitmask The bitmask flags. See `createWrap` for more details. + * @param {*} thisArg The `this` binding of `func`. + * @param {Array} partials The arguments to prepend to those provided to + * the new function. + * @returns {Function} Returns the new wrapped function. + */ +function createPartial(func, bitmask, thisArg, partials) { + var isBind = bitmask & BIND_FLAG, + Ctor = createCtor(func); + + function wrapper() { + var argsIndex = -1, + argsLength = arguments.length, + leftIndex = -1, + leftLength = partials.length, + args = Array(leftLength + argsLength), + fn = (this && this !== root && this instanceof wrapper) ? Ctor : func; + + while (++leftIndex < leftLength) { + args[leftIndex] = partials[leftIndex]; + } + while (argsLength--) { + args[leftIndex++] = arguments[++argsIndex]; + } + return apply(fn, isBind ? thisArg : this, args); + } + return wrapper; +} + +module.exports = createPartial; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_createRange.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_createRange.js new file mode 100644 index 0000000..9f52c77 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_createRange.js @@ -0,0 +1,30 @@ +var baseRange = require('./_baseRange'), + isIterateeCall = require('./_isIterateeCall'), + toFinite = require('./toFinite'); + +/** + * Creates a `_.range` or `_.rangeRight` function. + * + * @private + * @param {boolean} [fromRight] Specify iterating from right to left. + * @returns {Function} Returns the new range function. + */ +function createRange(fromRight) { + return function(start, end, step) { + if (step && typeof step != 'number' && isIterateeCall(start, end, step)) { + end = step = undefined; + } + // Ensure the sign of `-0` is preserved. + start = toFinite(start); + if (end === undefined) { + end = start; + start = 0; + } else { + end = toFinite(end); + } + step = step === undefined ? (start < end ? 1 : -1) : toFinite(step); + return baseRange(start, end, step, fromRight); + }; +} + +module.exports = createRange; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_createRecurry.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_createRecurry.js new file mode 100644 index 0000000..35a22e5 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_createRecurry.js @@ -0,0 +1,56 @@ +var isLaziable = require('./_isLaziable'), + setData = require('./_setData'), + setWrapToString = require('./_setWrapToString'); + +/** Used to compose bitmasks for function metadata. */ +var BIND_FLAG = 1, + BIND_KEY_FLAG = 2, + CURRY_BOUND_FLAG = 4, + CURRY_FLAG = 8, + PARTIAL_FLAG = 32, + PARTIAL_RIGHT_FLAG = 64; + +/** + * Creates a function that wraps `func` to continue currying. + * + * @private + * @param {Function} func The function to wrap. + * @param {number} bitmask The bitmask flags. See `createWrap` for more details. + * @param {Function} wrapFunc The function to create the `func` wrapper. + * @param {*} placeholder The placeholder value. + * @param {*} [thisArg] The `this` binding of `func`. + * @param {Array} [partials] The arguments to prepend to those provided to + * the new function. + * @param {Array} [holders] The `partials` placeholder indexes. + * @param {Array} [argPos] The argument positions of the new function. + * @param {number} [ary] The arity cap of `func`. + * @param {number} [arity] The arity of `func`. + * @returns {Function} Returns the new wrapped function. + */ +function createRecurry(func, bitmask, wrapFunc, placeholder, thisArg, partials, holders, argPos, ary, arity) { + var isCurry = bitmask & CURRY_FLAG, + newHolders = isCurry ? holders : undefined, + newHoldersRight = isCurry ? undefined : holders, + newPartials = isCurry ? partials : undefined, + newPartialsRight = isCurry ? undefined : partials; + + bitmask |= (isCurry ? PARTIAL_FLAG : PARTIAL_RIGHT_FLAG); + bitmask &= ~(isCurry ? PARTIAL_RIGHT_FLAG : PARTIAL_FLAG); + + if (!(bitmask & CURRY_BOUND_FLAG)) { + bitmask &= ~(BIND_FLAG | BIND_KEY_FLAG); + } + var newData = [ + func, bitmask, thisArg, newPartials, newHolders, newPartialsRight, + newHoldersRight, argPos, ary, arity + ]; + + var result = wrapFunc.apply(undefined, newData); + if (isLaziable(func)) { + setData(result, newData); + } + result.placeholder = placeholder; + return setWrapToString(result, func, bitmask); +} + +module.exports = createRecurry; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_createRelationalOperation.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_createRelationalOperation.js new file mode 100644 index 0000000..a17c6b5 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_createRelationalOperation.js @@ -0,0 +1,20 @@ +var toNumber = require('./toNumber'); + +/** + * Creates a function that performs a relational operation on two values. + * + * @private + * @param {Function} operator The function to perform the operation. + * @returns {Function} Returns the new relational operation function. + */ +function createRelationalOperation(operator) { + return function(value, other) { + if (!(typeof value == 'string' && typeof other == 'string')) { + value = toNumber(value); + other = toNumber(other); + } + return operator(value, other); + }; +} + +module.exports = createRelationalOperation; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_createRound.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_createRound.js new file mode 100644 index 0000000..74b20d4 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_createRound.js @@ -0,0 +1,33 @@ +var toInteger = require('./toInteger'), + toNumber = require('./toNumber'), + toString = require('./toString'); + +/* Built-in method references for those with the same name as other `lodash` methods. */ +var nativeMin = Math.min; + +/** + * Creates a function like `_.round`. + * + * @private + * @param {string} methodName The name of the `Math` method to use when rounding. + * @returns {Function} Returns the new round function. + */ +function createRound(methodName) { + var func = Math[methodName]; + return function(number, precision) { + number = toNumber(number); + precision = nativeMin(toInteger(precision), 292); + if (precision) { + // Shift with exponential notation to avoid floating-point issues. + // See [MDN](https://mdn.io/round#Examples) for more details. + var pair = (toString(number) + 'e').split('e'), + value = func(pair[0] + 'e' + (+pair[1] + precision)); + + pair = (toString(value) + 'e').split('e'); + return +(pair[0] + 'e' + (+pair[1] - precision)); + } + return func(number); + }; +} + +module.exports = createRound; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_createSet.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_createSet.js new file mode 100644 index 0000000..0f644ee --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_createSet.js @@ -0,0 +1,19 @@ +var Set = require('./_Set'), + noop = require('./noop'), + setToArray = require('./_setToArray'); + +/** Used as references for various `Number` constants. */ +var INFINITY = 1 / 0; + +/** + * Creates a set object of `values`. + * + * @private + * @param {Array} values The values to add to the set. + * @returns {Object} Returns the new set. + */ +var createSet = !(Set && (1 / setToArray(new Set([,-0]))[1]) == INFINITY) ? noop : function(values) { + return new Set(values); +}; + +module.exports = createSet; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_createToPairs.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_createToPairs.js new file mode 100644 index 0000000..568417a --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_createToPairs.js @@ -0,0 +1,30 @@ +var baseToPairs = require('./_baseToPairs'), + getTag = require('./_getTag'), + mapToArray = require('./_mapToArray'), + setToPairs = require('./_setToPairs'); + +/** `Object#toString` result references. */ +var mapTag = '[object Map]', + setTag = '[object Set]'; + +/** + * Creates a `_.toPairs` or `_.toPairsIn` function. + * + * @private + * @param {Function} keysFunc The function to get the keys of a given object. + * @returns {Function} Returns the new pairs function. + */ +function createToPairs(keysFunc) { + return function(object) { + var tag = getTag(object); + if (tag == mapTag) { + return mapToArray(object); + } + if (tag == setTag) { + return setToPairs(object); + } + return baseToPairs(object, keysFunc(object)); + }; +} + +module.exports = createToPairs; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_createWrap.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_createWrap.js new file mode 100644 index 0000000..09dac30 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_createWrap.js @@ -0,0 +1,107 @@ +var baseSetData = require('./_baseSetData'), + createBind = require('./_createBind'), + createCurry = require('./_createCurry'), + createHybrid = require('./_createHybrid'), + createPartial = require('./_createPartial'), + getData = require('./_getData'), + mergeData = require('./_mergeData'), + setData = require('./_setData'), + setWrapToString = require('./_setWrapToString'), + toInteger = require('./toInteger'); + +/** Error message constants. */ +var FUNC_ERROR_TEXT = 'Expected a function'; + +/** Used to compose bitmasks for function metadata. */ +var BIND_FLAG = 1, + BIND_KEY_FLAG = 2, + CURRY_FLAG = 8, + CURRY_RIGHT_FLAG = 16, + PARTIAL_FLAG = 32, + PARTIAL_RIGHT_FLAG = 64; + +/* Built-in method references for those with the same name as other `lodash` methods. */ +var nativeMax = Math.max; + +/** + * Creates a function that either curries or invokes `func` with optional + * `this` binding and partially applied arguments. + * + * @private + * @param {Function|string} func The function or method name to wrap. + * @param {number} bitmask The bitmask flags. + * The bitmask may be composed of the following flags: + * 1 - `_.bind` + * 2 - `_.bindKey` + * 4 - `_.curry` or `_.curryRight` of a bound function + * 8 - `_.curry` + * 16 - `_.curryRight` + * 32 - `_.partial` + * 64 - `_.partialRight` + * 128 - `_.rearg` + * 256 - `_.ary` + * 512 - `_.flip` + * @param {*} [thisArg] The `this` binding of `func`. + * @param {Array} [partials] The arguments to be partially applied. + * @param {Array} [holders] The `partials` placeholder indexes. + * @param {Array} [argPos] The argument positions of the new function. + * @param {number} [ary] The arity cap of `func`. + * @param {number} [arity] The arity of `func`. + * @returns {Function} Returns the new wrapped function. + */ +function createWrap(func, bitmask, thisArg, partials, holders, argPos, ary, arity) { + var isBindKey = bitmask & BIND_KEY_FLAG; + if (!isBindKey && typeof func != 'function') { + throw new TypeError(FUNC_ERROR_TEXT); + } + var length = partials ? partials.length : 0; + if (!length) { + bitmask &= ~(PARTIAL_FLAG | PARTIAL_RIGHT_FLAG); + partials = holders = undefined; + } + ary = ary === undefined ? ary : nativeMax(toInteger(ary), 0); + arity = arity === undefined ? arity : toInteger(arity); + length -= holders ? holders.length : 0; + + if (bitmask & PARTIAL_RIGHT_FLAG) { + var partialsRight = partials, + holdersRight = holders; + + partials = holders = undefined; + } + var data = isBindKey ? undefined : getData(func); + + var newData = [ + func, bitmask, thisArg, partials, holders, partialsRight, holdersRight, + argPos, ary, arity + ]; + + if (data) { + mergeData(newData, data); + } + func = newData[0]; + bitmask = newData[1]; + thisArg = newData[2]; + partials = newData[3]; + holders = newData[4]; + arity = newData[9] = newData[9] == null + ? (isBindKey ? 0 : func.length) + : nativeMax(newData[9] - length, 0); + + if (!arity && bitmask & (CURRY_FLAG | CURRY_RIGHT_FLAG)) { + bitmask &= ~(CURRY_FLAG | CURRY_RIGHT_FLAG); + } + if (!bitmask || bitmask == BIND_FLAG) { + var result = createBind(func, bitmask, thisArg); + } else if (bitmask == CURRY_FLAG || bitmask == CURRY_RIGHT_FLAG) { + result = createCurry(func, bitmask, arity); + } else if ((bitmask == PARTIAL_FLAG || bitmask == (BIND_FLAG | PARTIAL_FLAG)) && !holders.length) { + result = createPartial(func, bitmask, thisArg, partials); + } else { + result = createHybrid.apply(undefined, newData); + } + var setter = data ? baseSetData : setData; + return setWrapToString(setter(result, newData), func, bitmask); +} + +module.exports = createWrap; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_deburrLetter.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_deburrLetter.js new file mode 100644 index 0000000..3e531ed --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_deburrLetter.js @@ -0,0 +1,71 @@ +var basePropertyOf = require('./_basePropertyOf'); + +/** Used to map Latin Unicode letters to basic Latin letters. */ +var deburredLetters = { + // Latin-1 Supplement block. + '\xc0': 'A', '\xc1': 'A', '\xc2': 'A', '\xc3': 'A', '\xc4': 'A', '\xc5': 'A', + '\xe0': 'a', '\xe1': 'a', '\xe2': 'a', '\xe3': 'a', '\xe4': 'a', '\xe5': 'a', + '\xc7': 'C', '\xe7': 'c', + '\xd0': 'D', '\xf0': 'd', + '\xc8': 'E', '\xc9': 'E', '\xca': 'E', '\xcb': 'E', + '\xe8': 'e', '\xe9': 'e', '\xea': 'e', '\xeb': 'e', + '\xcc': 'I', '\xcd': 'I', '\xce': 'I', '\xcf': 'I', + '\xec': 'i', '\xed': 'i', '\xee': 'i', '\xef': 'i', + '\xd1': 'N', '\xf1': 'n', + '\xd2': 'O', '\xd3': 'O', '\xd4': 'O', '\xd5': 'O', '\xd6': 'O', '\xd8': 'O', + '\xf2': 'o', '\xf3': 'o', '\xf4': 'o', '\xf5': 'o', '\xf6': 'o', '\xf8': 'o', + '\xd9': 'U', '\xda': 'U', '\xdb': 'U', '\xdc': 'U', + '\xf9': 'u', '\xfa': 'u', '\xfb': 'u', '\xfc': 'u', + '\xdd': 'Y', '\xfd': 'y', '\xff': 'y', + '\xc6': 'Ae', '\xe6': 'ae', + '\xde': 'Th', '\xfe': 'th', + '\xdf': 'ss', + // Latin Extended-A block. + '\u0100': 'A', '\u0102': 'A', '\u0104': 'A', + '\u0101': 'a', '\u0103': 'a', '\u0105': 'a', + '\u0106': 'C', '\u0108': 'C', '\u010a': 'C', '\u010c': 'C', + '\u0107': 'c', '\u0109': 'c', '\u010b': 'c', '\u010d': 'c', + '\u010e': 'D', '\u0110': 'D', '\u010f': 'd', '\u0111': 'd', + '\u0112': 'E', '\u0114': 'E', '\u0116': 'E', '\u0118': 'E', '\u011a': 'E', + '\u0113': 'e', '\u0115': 'e', '\u0117': 'e', '\u0119': 'e', '\u011b': 'e', + '\u011c': 'G', '\u011e': 'G', '\u0120': 'G', '\u0122': 'G', + '\u011d': 'g', '\u011f': 'g', '\u0121': 'g', '\u0123': 'g', + '\u0124': 'H', '\u0126': 'H', '\u0125': 'h', '\u0127': 'h', + '\u0128': 'I', '\u012a': 'I', '\u012c': 'I', '\u012e': 'I', '\u0130': 'I', + '\u0129': 'i', '\u012b': 'i', '\u012d': 'i', '\u012f': 'i', '\u0131': 'i', + '\u0134': 'J', '\u0135': 'j', + '\u0136': 'K', '\u0137': 'k', '\u0138': 'k', + '\u0139': 'L', '\u013b': 'L', '\u013d': 'L', '\u013f': 'L', '\u0141': 'L', + '\u013a': 'l', '\u013c': 'l', '\u013e': 'l', '\u0140': 'l', '\u0142': 'l', + '\u0143': 'N', '\u0145': 'N', '\u0147': 'N', '\u014a': 'N', + '\u0144': 'n', '\u0146': 'n', '\u0148': 'n', '\u014b': 'n', + '\u014c': 'O', '\u014e': 'O', '\u0150': 'O', + '\u014d': 'o', '\u014f': 'o', '\u0151': 'o', + '\u0154': 'R', '\u0156': 'R', '\u0158': 'R', + '\u0155': 'r', '\u0157': 'r', '\u0159': 'r', + '\u015a': 'S', '\u015c': 'S', '\u015e': 'S', '\u0160': 'S', + '\u015b': 's', '\u015d': 's', '\u015f': 's', '\u0161': 's', + '\u0162': 'T', '\u0164': 'T', '\u0166': 'T', + '\u0163': 't', '\u0165': 't', '\u0167': 't', + '\u0168': 'U', '\u016a': 'U', '\u016c': 'U', '\u016e': 'U', '\u0170': 'U', '\u0172': 'U', + '\u0169': 'u', '\u016b': 'u', '\u016d': 'u', '\u016f': 'u', '\u0171': 'u', '\u0173': 'u', + '\u0174': 'W', '\u0175': 'w', + '\u0176': 'Y', '\u0177': 'y', '\u0178': 'Y', + '\u0179': 'Z', '\u017b': 'Z', '\u017d': 'Z', + '\u017a': 'z', '\u017c': 'z', '\u017e': 'z', + '\u0132': 'IJ', '\u0133': 'ij', + '\u0152': 'Oe', '\u0153': 'oe', + '\u0149': "'n", '\u017f': 's' +}; + +/** + * Used by `_.deburr` to convert Latin-1 Supplement and Latin Extended-A + * letters to basic Latin letters. + * + * @private + * @param {string} letter The matched letter to deburr. + * @returns {string} Returns the deburred letter. + */ +var deburrLetter = basePropertyOf(deburredLetters); + +module.exports = deburrLetter; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_defineProperty.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_defineProperty.js new file mode 100644 index 0000000..b6116d9 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_defineProperty.js @@ -0,0 +1,11 @@ +var getNative = require('./_getNative'); + +var defineProperty = (function() { + try { + var func = getNative(Object, 'defineProperty'); + func({}, '', {}); + return func; + } catch (e) {} +}()); + +module.exports = defineProperty; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_equalArrays.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_equalArrays.js new file mode 100644 index 0000000..178dced --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_equalArrays.js @@ -0,0 +1,84 @@ +var SetCache = require('./_SetCache'), + arraySome = require('./_arraySome'), + cacheHas = require('./_cacheHas'); + +/** Used to compose bitmasks for comparison styles. */ +var UNORDERED_COMPARE_FLAG = 1, + PARTIAL_COMPARE_FLAG = 2; + +/** + * A specialized version of `baseIsEqualDeep` for arrays with support for + * partial deep comparisons. + * + * @private + * @param {Array} array The array to compare. + * @param {Array} other The other array to compare. + * @param {Function} equalFunc The function to determine equivalents of values. + * @param {Function} customizer The function to customize comparisons. + * @param {number} bitmask The bitmask of comparison flags. See `baseIsEqual` + * for more details. + * @param {Object} stack Tracks traversed `array` and `other` objects. + * @returns {boolean} Returns `true` if the arrays are equivalent, else `false`. + */ +function equalArrays(array, other, equalFunc, customizer, bitmask, stack) { + var isPartial = bitmask & PARTIAL_COMPARE_FLAG, + arrLength = array.length, + othLength = other.length; + + if (arrLength != othLength && !(isPartial && othLength > arrLength)) { + return false; + } + // Assume cyclic values are equal. + var stacked = stack.get(array); + if (stacked && stack.get(other)) { + return stacked == other; + } + var index = -1, + result = true, + seen = (bitmask & UNORDERED_COMPARE_FLAG) ? new SetCache : undefined; + + stack.set(array, other); + stack.set(other, array); + + // Ignore non-index properties. + while (++index < arrLength) { + var arrValue = array[index], + othValue = other[index]; + + if (customizer) { + var compared = isPartial + ? customizer(othValue, arrValue, index, other, array, stack) + : customizer(arrValue, othValue, index, array, other, stack); + } + if (compared !== undefined) { + if (compared) { + continue; + } + result = false; + break; + } + // Recursively compare arrays (susceptible to call stack limits). + if (seen) { + if (!arraySome(other, function(othValue, othIndex) { + if (!cacheHas(seen, othIndex) && + (arrValue === othValue || equalFunc(arrValue, othValue, customizer, bitmask, stack))) { + return seen.push(othIndex); + } + })) { + result = false; + break; + } + } else if (!( + arrValue === othValue || + equalFunc(arrValue, othValue, customizer, bitmask, stack) + )) { + result = false; + break; + } + } + stack['delete'](array); + stack['delete'](other); + return result; +} + +module.exports = equalArrays; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_equalByTag.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_equalByTag.js new file mode 100644 index 0000000..07d8c8c --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_equalByTag.js @@ -0,0 +1,113 @@ +var Symbol = require('./_Symbol'), + Uint8Array = require('./_Uint8Array'), + eq = require('./eq'), + equalArrays = require('./_equalArrays'), + mapToArray = require('./_mapToArray'), + setToArray = require('./_setToArray'); + +/** Used to compose bitmasks for comparison styles. */ +var UNORDERED_COMPARE_FLAG = 1, + PARTIAL_COMPARE_FLAG = 2; + +/** `Object#toString` result references. */ +var boolTag = '[object Boolean]', + dateTag = '[object Date]', + errorTag = '[object Error]', + mapTag = '[object Map]', + numberTag = '[object Number]', + regexpTag = '[object RegExp]', + setTag = '[object Set]', + stringTag = '[object String]', + symbolTag = '[object Symbol]'; + +var arrayBufferTag = '[object ArrayBuffer]', + dataViewTag = '[object DataView]'; + +/** Used to convert symbols to primitives and strings. */ +var symbolProto = Symbol ? Symbol.prototype : undefined, + symbolValueOf = symbolProto ? symbolProto.valueOf : undefined; + +/** + * A specialized version of `baseIsEqualDeep` for comparing objects of + * the same `toStringTag`. + * + * **Note:** This function only supports comparing values with tags of + * `Boolean`, `Date`, `Error`, `Number`, `RegExp`, or `String`. + * + * @private + * @param {Object} object The object to compare. + * @param {Object} other The other object to compare. + * @param {string} tag The `toStringTag` of the objects to compare. + * @param {Function} equalFunc The function to determine equivalents of values. + * @param {Function} customizer The function to customize comparisons. + * @param {number} bitmask The bitmask of comparison flags. See `baseIsEqual` + * for more details. + * @param {Object} stack Tracks traversed `object` and `other` objects. + * @returns {boolean} Returns `true` if the objects are equivalent, else `false`. + */ +function equalByTag(object, other, tag, equalFunc, customizer, bitmask, stack) { + switch (tag) { + case dataViewTag: + if ((object.byteLength != other.byteLength) || + (object.byteOffset != other.byteOffset)) { + return false; + } + object = object.buffer; + other = other.buffer; + + case arrayBufferTag: + if ((object.byteLength != other.byteLength) || + !equalFunc(new Uint8Array(object), new Uint8Array(other))) { + return false; + } + return true; + + case boolTag: + case dateTag: + case numberTag: + // Coerce booleans to `1` or `0` and dates to milliseconds. + // Invalid dates are coerced to `NaN`. + return eq(+object, +other); + + case errorTag: + return object.name == other.name && object.message == other.message; + + case regexpTag: + case stringTag: + // Coerce regexes to strings and treat strings, primitives and objects, + // as equal. See http://www.ecma-international.org/ecma-262/7.0/#sec-regexp.prototype.tostring + // for more details. + return object == (other + ''); + + case mapTag: + var convert = mapToArray; + + case setTag: + var isPartial = bitmask & PARTIAL_COMPARE_FLAG; + convert || (convert = setToArray); + + if (object.size != other.size && !isPartial) { + return false; + } + // Assume cyclic values are equal. + var stacked = stack.get(object); + if (stacked) { + return stacked == other; + } + bitmask |= UNORDERED_COMPARE_FLAG; + + // Recursively compare objects (susceptible to call stack limits). + stack.set(object, other); + var result = equalArrays(convert(object), convert(other), equalFunc, customizer, bitmask, stack); + stack['delete'](object); + return result; + + case symbolTag: + if (symbolValueOf) { + return symbolValueOf.call(object) == symbolValueOf.call(other); + } + } + return false; +} + +module.exports = equalByTag; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_equalObjects.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_equalObjects.js new file mode 100644 index 0000000..092cb3f --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_equalObjects.js @@ -0,0 +1,90 @@ +var keys = require('./keys'); + +/** Used to compose bitmasks for comparison styles. */ +var PARTIAL_COMPARE_FLAG = 2; + +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** Used to check objects for own properties. */ +var hasOwnProperty = objectProto.hasOwnProperty; + +/** + * A specialized version of `baseIsEqualDeep` for objects with support for + * partial deep comparisons. + * + * @private + * @param {Object} object The object to compare. + * @param {Object} other The other object to compare. + * @param {Function} equalFunc The function to determine equivalents of values. + * @param {Function} customizer The function to customize comparisons. + * @param {number} bitmask The bitmask of comparison flags. See `baseIsEqual` + * for more details. + * @param {Object} stack Tracks traversed `object` and `other` objects. + * @returns {boolean} Returns `true` if the objects are equivalent, else `false`. + */ +function equalObjects(object, other, equalFunc, customizer, bitmask, stack) { + var isPartial = bitmask & PARTIAL_COMPARE_FLAG, + objProps = keys(object), + objLength = objProps.length, + othProps = keys(other), + othLength = othProps.length; + + if (objLength != othLength && !isPartial) { + return false; + } + var index = objLength; + while (index--) { + var key = objProps[index]; + if (!(isPartial ? key in other : hasOwnProperty.call(other, key))) { + return false; + } + } + // Assume cyclic values are equal. + var stacked = stack.get(object); + if (stacked && stack.get(other)) { + return stacked == other; + } + var result = true; + stack.set(object, other); + stack.set(other, object); + + var skipCtor = isPartial; + while (++index < objLength) { + key = objProps[index]; + var objValue = object[key], + othValue = other[key]; + + if (customizer) { + var compared = isPartial + ? customizer(othValue, objValue, key, other, object, stack) + : customizer(objValue, othValue, key, object, other, stack); + } + // Recursively compare objects (susceptible to call stack limits). + if (!(compared === undefined + ? (objValue === othValue || equalFunc(objValue, othValue, customizer, bitmask, stack)) + : compared + )) { + result = false; + break; + } + skipCtor || (skipCtor = key == 'constructor'); + } + if (result && !skipCtor) { + var objCtor = object.constructor, + othCtor = other.constructor; + + // Non `Object` object instances with different constructors are not equal. + if (objCtor != othCtor && + ('constructor' in object && 'constructor' in other) && + !(typeof objCtor == 'function' && objCtor instanceof objCtor && + typeof othCtor == 'function' && othCtor instanceof othCtor)) { + result = false; + } + } + stack['delete'](object); + stack['delete'](other); + return result; +} + +module.exports = equalObjects; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_escapeHtmlChar.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_escapeHtmlChar.js new file mode 100644 index 0000000..7ca68ee --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_escapeHtmlChar.js @@ -0,0 +1,21 @@ +var basePropertyOf = require('./_basePropertyOf'); + +/** Used to map characters to HTML entities. */ +var htmlEscapes = { + '&': '&', + '<': '<', + '>': '>', + '"': '"', + "'": ''' +}; + +/** + * Used by `_.escape` to convert characters to HTML entities. + * + * @private + * @param {string} chr The matched character to escape. + * @returns {string} Returns the escaped character. + */ +var escapeHtmlChar = basePropertyOf(htmlEscapes); + +module.exports = escapeHtmlChar; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_escapeStringChar.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_escapeStringChar.js new file mode 100644 index 0000000..44eca96 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_escapeStringChar.js @@ -0,0 +1,22 @@ +/** Used to escape characters for inclusion in compiled string literals. */ +var stringEscapes = { + '\\': '\\', + "'": "'", + '\n': 'n', + '\r': 'r', + '\u2028': 'u2028', + '\u2029': 'u2029' +}; + +/** + * Used by `_.template` to escape characters for inclusion in compiled string literals. + * + * @private + * @param {string} chr The matched character to escape. + * @returns {string} Returns the escaped character. + */ +function escapeStringChar(chr) { + return '\\' + stringEscapes[chr]; +} + +module.exports = escapeStringChar; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_flatRest.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_flatRest.js new file mode 100644 index 0000000..94ab6cc --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_flatRest.js @@ -0,0 +1,16 @@ +var flatten = require('./flatten'), + overRest = require('./_overRest'), + setToString = require('./_setToString'); + +/** + * A specialized version of `baseRest` which flattens the rest array. + * + * @private + * @param {Function} func The function to apply a rest parameter to. + * @returns {Function} Returns the new function. + */ +function flatRest(func) { + return setToString(overRest(func, undefined, flatten), func + ''); +} + +module.exports = flatRest; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_freeGlobal.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_freeGlobal.js new file mode 100644 index 0000000..bbec998 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_freeGlobal.js @@ -0,0 +1,4 @@ +/** Detect free variable `global` from Node.js. */ +var freeGlobal = typeof global == 'object' && global && global.Object === Object && global; + +module.exports = freeGlobal; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_getAllKeys.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_getAllKeys.js new file mode 100644 index 0000000..a9ce699 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_getAllKeys.js @@ -0,0 +1,16 @@ +var baseGetAllKeys = require('./_baseGetAllKeys'), + getSymbols = require('./_getSymbols'), + keys = require('./keys'); + +/** + * Creates an array of own enumerable property names and symbols of `object`. + * + * @private + * @param {Object} object The object to query. + * @returns {Array} Returns the array of property names and symbols. + */ +function getAllKeys(object) { + return baseGetAllKeys(object, keys, getSymbols); +} + +module.exports = getAllKeys; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_getAllKeysIn.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_getAllKeysIn.js new file mode 100644 index 0000000..1b46678 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_getAllKeysIn.js @@ -0,0 +1,17 @@ +var baseGetAllKeys = require('./_baseGetAllKeys'), + getSymbolsIn = require('./_getSymbolsIn'), + keysIn = require('./keysIn'); + +/** + * Creates an array of own and inherited enumerable property names and + * symbols of `object`. + * + * @private + * @param {Object} object The object to query. + * @returns {Array} Returns the array of property names and symbols. + */ +function getAllKeysIn(object) { + return baseGetAllKeys(object, keysIn, getSymbolsIn); +} + +module.exports = getAllKeysIn; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_getData.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_getData.js new file mode 100644 index 0000000..a1fe7b7 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_getData.js @@ -0,0 +1,15 @@ +var metaMap = require('./_metaMap'), + noop = require('./noop'); + +/** + * Gets metadata for `func`. + * + * @private + * @param {Function} func The function to query. + * @returns {*} Returns the metadata for `func`. + */ +var getData = !metaMap ? noop : function(func) { + return metaMap.get(func); +}; + +module.exports = getData; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_getFuncName.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_getFuncName.js new file mode 100644 index 0000000..21e15b3 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_getFuncName.js @@ -0,0 +1,31 @@ +var realNames = require('./_realNames'); + +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** Used to check objects for own properties. */ +var hasOwnProperty = objectProto.hasOwnProperty; + +/** + * Gets the name of `func`. + * + * @private + * @param {Function} func The function to query. + * @returns {string} Returns the function name. + */ +function getFuncName(func) { + var result = (func.name + ''), + array = realNames[result], + length = hasOwnProperty.call(realNames, result) ? array.length : 0; + + while (length--) { + var data = array[length], + otherFunc = data.func; + if (otherFunc == null || otherFunc == func) { + return data.name; + } + } + return result; +} + +module.exports = getFuncName; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_getHolder.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_getHolder.js new file mode 100644 index 0000000..65e94b5 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_getHolder.js @@ -0,0 +1,13 @@ +/** + * Gets the argument placeholder value for `func`. + * + * @private + * @param {Function} func The function to inspect. + * @returns {*} Returns the placeholder value. + */ +function getHolder(func) { + var object = func; + return object.placeholder; +} + +module.exports = getHolder; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_getMapData.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_getMapData.js new file mode 100644 index 0000000..17f6303 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_getMapData.js @@ -0,0 +1,18 @@ +var isKeyable = require('./_isKeyable'); + +/** + * Gets the data for `map`. + * + * @private + * @param {Object} map The map to query. + * @param {string} key The reference key. + * @returns {*} Returns the map data. + */ +function getMapData(map, key) { + var data = map.__data__; + return isKeyable(key) + ? data[typeof key == 'string' ? 'string' : 'hash'] + : data.map; +} + +module.exports = getMapData; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_getMatchData.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_getMatchData.js new file mode 100644 index 0000000..2cc70f9 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_getMatchData.js @@ -0,0 +1,24 @@ +var isStrictComparable = require('./_isStrictComparable'), + keys = require('./keys'); + +/** + * Gets the property names, values, and compare flags of `object`. + * + * @private + * @param {Object} object The object to query. + * @returns {Array} Returns the match data of `object`. + */ +function getMatchData(object) { + var result = keys(object), + length = result.length; + + while (length--) { + var key = result[length], + value = object[key]; + + result[length] = [key, value, isStrictComparable(value)]; + } + return result; +} + +module.exports = getMatchData; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_getNative.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_getNative.js new file mode 100644 index 0000000..97a622b --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_getNative.js @@ -0,0 +1,17 @@ +var baseIsNative = require('./_baseIsNative'), + getValue = require('./_getValue'); + +/** + * Gets the native function at `key` of `object`. + * + * @private + * @param {Object} object The object to query. + * @param {string} key The key of the method to get. + * @returns {*} Returns the function if it's native, else `undefined`. + */ +function getNative(object, key) { + var value = getValue(object, key); + return baseIsNative(value) ? value : undefined; +} + +module.exports = getNative; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_getPrototype.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_getPrototype.js new file mode 100644 index 0000000..e808612 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_getPrototype.js @@ -0,0 +1,6 @@ +var overArg = require('./_overArg'); + +/** Built-in value references. */ +var getPrototype = overArg(Object.getPrototypeOf, Object); + +module.exports = getPrototype; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_getSymbols.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_getSymbols.js new file mode 100644 index 0000000..e41dad1 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_getSymbols.js @@ -0,0 +1,16 @@ +var overArg = require('./_overArg'), + stubArray = require('./stubArray'); + +/* Built-in method references for those with the same name as other `lodash` methods. */ +var nativeGetSymbols = Object.getOwnPropertySymbols; + +/** + * Creates an array of the own enumerable symbol properties of `object`. + * + * @private + * @param {Object} object The object to query. + * @returns {Array} Returns the array of symbols. + */ +var getSymbols = nativeGetSymbols ? overArg(nativeGetSymbols, Object) : stubArray; + +module.exports = getSymbols; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_getSymbolsIn.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_getSymbolsIn.js new file mode 100644 index 0000000..221277e --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_getSymbolsIn.js @@ -0,0 +1,26 @@ +var arrayPush = require('./_arrayPush'), + getPrototype = require('./_getPrototype'), + getSymbols = require('./_getSymbols'), + stubArray = require('./stubArray'); + +/* Built-in method references for those with the same name as other `lodash` methods. */ +var nativeGetSymbols = Object.getOwnPropertySymbols; + +/** + * Creates an array of the own and inherited enumerable symbol properties + * of `object`. + * + * @private + * @param {Object} object The object to query. + * @returns {Array} Returns the array of symbols. + */ +var getSymbolsIn = !nativeGetSymbols ? stubArray : function(object) { + var result = []; + while (object) { + arrayPush(result, getSymbols(object)); + object = getPrototype(object); + } + return result; +}; + +module.exports = getSymbolsIn; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_getTag.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_getTag.js new file mode 100644 index 0000000..6954db1 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_getTag.js @@ -0,0 +1,68 @@ +var DataView = require('./_DataView'), + Map = require('./_Map'), + Promise = require('./_Promise'), + Set = require('./_Set'), + WeakMap = require('./_WeakMap'), + baseGetTag = require('./_baseGetTag'), + toSource = require('./_toSource'); + +/** `Object#toString` result references. */ +var mapTag = '[object Map]', + objectTag = '[object Object]', + promiseTag = '[object Promise]', + setTag = '[object Set]', + weakMapTag = '[object WeakMap]'; + +var dataViewTag = '[object DataView]'; + +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** + * Used to resolve the + * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring) + * of values. + */ +var objectToString = objectProto.toString; + +/** Used to detect maps, sets, and weakmaps. */ +var dataViewCtorString = toSource(DataView), + mapCtorString = toSource(Map), + promiseCtorString = toSource(Promise), + setCtorString = toSource(Set), + weakMapCtorString = toSource(WeakMap); + +/** + * Gets the `toStringTag` of `value`. + * + * @private + * @param {*} value The value to query. + * @returns {string} Returns the `toStringTag`. + */ +var getTag = baseGetTag; + +// Fallback for data views, maps, sets, and weak maps in IE 11 and promises in Node.js < 6. +if ((DataView && getTag(new DataView(new ArrayBuffer(1))) != dataViewTag) || + (Map && getTag(new Map) != mapTag) || + (Promise && getTag(Promise.resolve()) != promiseTag) || + (Set && getTag(new Set) != setTag) || + (WeakMap && getTag(new WeakMap) != weakMapTag)) { + getTag = function(value) { + var result = objectToString.call(value), + Ctor = result == objectTag ? value.constructor : undefined, + ctorString = Ctor ? toSource(Ctor) : undefined; + + if (ctorString) { + switch (ctorString) { + case dataViewCtorString: return dataViewTag; + case mapCtorString: return mapTag; + case promiseCtorString: return promiseTag; + case setCtorString: return setTag; + case weakMapCtorString: return weakMapTag; + } + } + return result; + }; +} + +module.exports = getTag; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_getValue.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_getValue.js new file mode 100644 index 0000000..5f7d773 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_getValue.js @@ -0,0 +1,13 @@ +/** + * Gets the value at `key` of `object`. + * + * @private + * @param {Object} [object] The object to query. + * @param {string} key The key of the property to get. + * @returns {*} Returns the property value. + */ +function getValue(object, key) { + return object == null ? undefined : object[key]; +} + +module.exports = getValue; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_getView.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_getView.js new file mode 100644 index 0000000..df1e5d4 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_getView.js @@ -0,0 +1,33 @@ +/* Built-in method references for those with the same name as other `lodash` methods. */ +var nativeMax = Math.max, + nativeMin = Math.min; + +/** + * Gets the view, applying any `transforms` to the `start` and `end` positions. + * + * @private + * @param {number} start The start of the view. + * @param {number} end The end of the view. + * @param {Array} transforms The transformations to apply to the view. + * @returns {Object} Returns an object containing the `start` and `end` + * positions of the view. + */ +function getView(start, end, transforms) { + var index = -1, + length = transforms.length; + + while (++index < length) { + var data = transforms[index], + size = data.size; + + switch (data.type) { + case 'drop': start += size; break; + case 'dropRight': end -= size; break; + case 'take': end = nativeMin(end, start + size); break; + case 'takeRight': start = nativeMax(start, end - size); break; + } + } + return { 'start': start, 'end': end }; +} + +module.exports = getView; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_getWrapDetails.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_getWrapDetails.js new file mode 100644 index 0000000..3bcc6e4 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_getWrapDetails.js @@ -0,0 +1,17 @@ +/** Used to match wrap detail comments. */ +var reWrapDetails = /\{\n\/\* \[wrapped with (.+)\] \*/, + reSplitDetails = /,? & /; + +/** + * Extracts wrapper details from the `source` body comment. + * + * @private + * @param {string} source The source to inspect. + * @returns {Array} Returns the wrapper details. + */ +function getWrapDetails(source) { + var match = source.match(reWrapDetails); + return match ? match[1].split(reSplitDetails) : []; +} + +module.exports = getWrapDetails; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_hasPath.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_hasPath.js new file mode 100644 index 0000000..770be4b --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_hasPath.js @@ -0,0 +1,40 @@ +var castPath = require('./_castPath'), + isArguments = require('./isArguments'), + isArray = require('./isArray'), + isIndex = require('./_isIndex'), + isKey = require('./_isKey'), + isLength = require('./isLength'), + toKey = require('./_toKey'); + +/** + * Checks if `path` exists on `object`. + * + * @private + * @param {Object} object The object to query. + * @param {Array|string} path The path to check. + * @param {Function} hasFunc The function to check properties. + * @returns {boolean} Returns `true` if `path` exists, else `false`. + */ +function hasPath(object, path, hasFunc) { + path = isKey(path, object) ? [path] : castPath(path); + + var index = -1, + length = path.length, + result = false; + + while (++index < length) { + var key = toKey(path[index]); + if (!(result = object != null && hasFunc(object, key))) { + break; + } + object = object[key]; + } + if (result || ++index != length) { + return result; + } + length = object ? object.length : 0; + return !!length && isLength(length) && isIndex(key, length) && + (isArray(object) || isArguments(object)); +} + +module.exports = hasPath; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_hasUnicode.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_hasUnicode.js new file mode 100644 index 0000000..085161a --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_hasUnicode.js @@ -0,0 +1,24 @@ +/** Used to compose unicode character classes. */ +var rsAstralRange = '\\ud800-\\udfff', + rsComboMarksRange = '\\u0300-\\u036f\\ufe20-\\ufe23', + rsComboSymbolsRange = '\\u20d0-\\u20f0', + rsVarRange = '\\ufe0e\\ufe0f'; + +/** Used to compose unicode capture groups. */ +var rsZWJ = '\\u200d'; + +/** Used to detect strings with [zero-width joiners or code points from the astral planes](http://eev.ee/blog/2015/09/12/dark-corners-of-unicode/). */ +var reHasUnicode = RegExp('[' + rsZWJ + rsAstralRange + rsComboMarksRange + rsComboSymbolsRange + rsVarRange + ']'); + +/** + * Checks if `string` contains Unicode symbols. + * + * @private + * @param {string} string The string to inspect. + * @returns {boolean} Returns `true` if a symbol is found, else `false`. + */ +function hasUnicode(string) { + return reHasUnicode.test(string); +} + +module.exports = hasUnicode; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_hasUnicodeWord.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_hasUnicodeWord.js new file mode 100644 index 0000000..a35d6e5 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_hasUnicodeWord.js @@ -0,0 +1,15 @@ +/** Used to detect strings that need a more robust regexp to match words. */ +var reHasUnicodeWord = /[a-z][A-Z]|[A-Z]{2,}[a-z]|[0-9][a-zA-Z]|[a-zA-Z][0-9]|[^a-zA-Z0-9 ]/; + +/** + * Checks if `string` contains a word composed of Unicode symbols. + * + * @private + * @param {string} string The string to inspect. + * @returns {boolean} Returns `true` if a word is found, else `false`. + */ +function hasUnicodeWord(string) { + return reHasUnicodeWord.test(string); +} + +module.exports = hasUnicodeWord; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_hashClear.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_hashClear.js new file mode 100644 index 0000000..5d4b70c --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_hashClear.js @@ -0,0 +1,15 @@ +var nativeCreate = require('./_nativeCreate'); + +/** + * Removes all key-value entries from the hash. + * + * @private + * @name clear + * @memberOf Hash + */ +function hashClear() { + this.__data__ = nativeCreate ? nativeCreate(null) : {}; + this.size = 0; +} + +module.exports = hashClear; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_hashDelete.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_hashDelete.js new file mode 100644 index 0000000..ea9dabf --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_hashDelete.js @@ -0,0 +1,17 @@ +/** + * Removes `key` and its value from the hash. + * + * @private + * @name delete + * @memberOf Hash + * @param {Object} hash The hash to modify. + * @param {string} key The key of the value to remove. + * @returns {boolean} Returns `true` if the entry was removed, else `false`. + */ +function hashDelete(key) { + var result = this.has(key) && delete this.__data__[key]; + this.size -= result ? 1 : 0; + return result; +} + +module.exports = hashDelete; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_hashGet.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_hashGet.js new file mode 100644 index 0000000..1fc2f34 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_hashGet.js @@ -0,0 +1,30 @@ +var nativeCreate = require('./_nativeCreate'); + +/** Used to stand-in for `undefined` hash values. */ +var HASH_UNDEFINED = '__lodash_hash_undefined__'; + +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** Used to check objects for own properties. */ +var hasOwnProperty = objectProto.hasOwnProperty; + +/** + * Gets the hash value for `key`. + * + * @private + * @name get + * @memberOf Hash + * @param {string} key The key of the value to get. + * @returns {*} Returns the entry value. + */ +function hashGet(key) { + var data = this.__data__; + if (nativeCreate) { + var result = data[key]; + return result === HASH_UNDEFINED ? undefined : result; + } + return hasOwnProperty.call(data, key) ? data[key] : undefined; +} + +module.exports = hashGet; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_hashHas.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_hashHas.js new file mode 100644 index 0000000..f30aac3 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_hashHas.js @@ -0,0 +1,23 @@ +var nativeCreate = require('./_nativeCreate'); + +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** Used to check objects for own properties. */ +var hasOwnProperty = objectProto.hasOwnProperty; + +/** + * Checks if a hash value for `key` exists. + * + * @private + * @name has + * @memberOf Hash + * @param {string} key The key of the entry to check. + * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`. + */ +function hashHas(key) { + var data = this.__data__; + return nativeCreate ? data[key] !== undefined : hasOwnProperty.call(data, key); +} + +module.exports = hashHas; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_hashSet.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_hashSet.js new file mode 100644 index 0000000..e105528 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_hashSet.js @@ -0,0 +1,23 @@ +var nativeCreate = require('./_nativeCreate'); + +/** Used to stand-in for `undefined` hash values. */ +var HASH_UNDEFINED = '__lodash_hash_undefined__'; + +/** + * Sets the hash `key` to `value`. + * + * @private + * @name set + * @memberOf Hash + * @param {string} key The key of the value to set. + * @param {*} value The value to set. + * @returns {Object} Returns the hash instance. + */ +function hashSet(key, value) { + var data = this.__data__; + this.size += this.has(key) ? 0 : 1; + data[key] = (nativeCreate && value === undefined) ? HASH_UNDEFINED : value; + return this; +} + +module.exports = hashSet; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_initCloneArray.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_initCloneArray.js new file mode 100644 index 0000000..aef0212 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_initCloneArray.js @@ -0,0 +1,26 @@ +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** Used to check objects for own properties. */ +var hasOwnProperty = objectProto.hasOwnProperty; + +/** + * Initializes an array clone. + * + * @private + * @param {Array} array The array to clone. + * @returns {Array} Returns the initialized clone. + */ +function initCloneArray(array) { + var length = array.length, + result = array.constructor(length); + + // Add properties assigned by `RegExp#exec`. + if (length && typeof array[0] == 'string' && hasOwnProperty.call(array, 'index')) { + result.index = array.index; + result.input = array.input; + } + return result; +} + +module.exports = initCloneArray; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_initCloneByTag.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_initCloneByTag.js new file mode 100644 index 0000000..e7b77ed --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_initCloneByTag.js @@ -0,0 +1,80 @@ +var cloneArrayBuffer = require('./_cloneArrayBuffer'), + cloneDataView = require('./_cloneDataView'), + cloneMap = require('./_cloneMap'), + cloneRegExp = require('./_cloneRegExp'), + cloneSet = require('./_cloneSet'), + cloneSymbol = require('./_cloneSymbol'), + cloneTypedArray = require('./_cloneTypedArray'); + +/** `Object#toString` result references. */ +var boolTag = '[object Boolean]', + dateTag = '[object Date]', + mapTag = '[object Map]', + numberTag = '[object Number]', + regexpTag = '[object RegExp]', + setTag = '[object Set]', + stringTag = '[object String]', + symbolTag = '[object Symbol]'; + +var arrayBufferTag = '[object ArrayBuffer]', + dataViewTag = '[object DataView]', + float32Tag = '[object Float32Array]', + float64Tag = '[object Float64Array]', + int8Tag = '[object Int8Array]', + int16Tag = '[object Int16Array]', + int32Tag = '[object Int32Array]', + uint8Tag = '[object Uint8Array]', + uint8ClampedTag = '[object Uint8ClampedArray]', + uint16Tag = '[object Uint16Array]', + uint32Tag = '[object Uint32Array]'; + +/** + * Initializes an object clone based on its `toStringTag`. + * + * **Note:** This function only supports cloning values with tags of + * `Boolean`, `Date`, `Error`, `Number`, `RegExp`, or `String`. + * + * @private + * @param {Object} object The object to clone. + * @param {string} tag The `toStringTag` of the object to clone. + * @param {Function} cloneFunc The function to clone values. + * @param {boolean} [isDeep] Specify a deep clone. + * @returns {Object} Returns the initialized clone. + */ +function initCloneByTag(object, tag, cloneFunc, isDeep) { + var Ctor = object.constructor; + switch (tag) { + case arrayBufferTag: + return cloneArrayBuffer(object); + + case boolTag: + case dateTag: + return new Ctor(+object); + + case dataViewTag: + return cloneDataView(object, isDeep); + + case float32Tag: case float64Tag: + case int8Tag: case int16Tag: case int32Tag: + case uint8Tag: case uint8ClampedTag: case uint16Tag: case uint32Tag: + return cloneTypedArray(object, isDeep); + + case mapTag: + return cloneMap(object, isDeep, cloneFunc); + + case numberTag: + case stringTag: + return new Ctor(object); + + case regexpTag: + return cloneRegExp(object); + + case setTag: + return cloneSet(object, isDeep, cloneFunc); + + case symbolTag: + return cloneSymbol(object); + } +} + +module.exports = initCloneByTag; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_initCloneObject.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_initCloneObject.js new file mode 100644 index 0000000..5a13e64 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_initCloneObject.js @@ -0,0 +1,18 @@ +var baseCreate = require('./_baseCreate'), + getPrototype = require('./_getPrototype'), + isPrototype = require('./_isPrototype'); + +/** + * Initializes an object clone. + * + * @private + * @param {Object} object The object to clone. + * @returns {Object} Returns the initialized clone. + */ +function initCloneObject(object) { + return (typeof object.constructor == 'function' && !isPrototype(object)) + ? baseCreate(getPrototype(object)) + : {}; +} + +module.exports = initCloneObject; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_insertWrapDetails.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_insertWrapDetails.js new file mode 100644 index 0000000..e790808 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_insertWrapDetails.js @@ -0,0 +1,23 @@ +/** Used to match wrap detail comments. */ +var reWrapComment = /\{(?:\n\/\* \[wrapped with .+\] \*\/)?\n?/; + +/** + * Inserts wrapper `details` in a comment at the top of the `source` body. + * + * @private + * @param {string} source The source to modify. + * @returns {Array} details The details to insert. + * @returns {string} Returns the modified source. + */ +function insertWrapDetails(source, details) { + var length = details.length; + if (!length) { + return source; + } + var lastIndex = length - 1; + details[lastIndex] = (length > 1 ? '& ' : '') + details[lastIndex]; + details = details.join(length > 2 ? ', ' : ' '); + return source.replace(reWrapComment, '{\n/* [wrapped with ' + details + '] */\n'); +} + +module.exports = insertWrapDetails; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_isFlattenable.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_isFlattenable.js new file mode 100644 index 0000000..4cc2c24 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_isFlattenable.js @@ -0,0 +1,20 @@ +var Symbol = require('./_Symbol'), + isArguments = require('./isArguments'), + isArray = require('./isArray'); + +/** Built-in value references. */ +var spreadableSymbol = Symbol ? Symbol.isConcatSpreadable : undefined; + +/** + * Checks if `value` is a flattenable `arguments` object or array. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is flattenable, else `false`. + */ +function isFlattenable(value) { + return isArray(value) || isArguments(value) || + !!(spreadableSymbol && value && value[spreadableSymbol]); +} + +module.exports = isFlattenable; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_isIndex.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_isIndex.js new file mode 100644 index 0000000..e123dde --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_isIndex.js @@ -0,0 +1,22 @@ +/** Used as references for various `Number` constants. */ +var MAX_SAFE_INTEGER = 9007199254740991; + +/** Used to detect unsigned integer values. */ +var reIsUint = /^(?:0|[1-9]\d*)$/; + +/** + * Checks if `value` is a valid array-like index. + * + * @private + * @param {*} value The value to check. + * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index. + * @returns {boolean} Returns `true` if `value` is a valid index, else `false`. + */ +function isIndex(value, length) { + length = length == null ? MAX_SAFE_INTEGER : length; + return !!length && + (typeof value == 'number' || reIsUint.test(value)) && + (value > -1 && value % 1 == 0 && value < length); +} + +module.exports = isIndex; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_isIterateeCall.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_isIterateeCall.js new file mode 100644 index 0000000..a0bb5a9 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_isIterateeCall.js @@ -0,0 +1,30 @@ +var eq = require('./eq'), + isArrayLike = require('./isArrayLike'), + isIndex = require('./_isIndex'), + isObject = require('./isObject'); + +/** + * Checks if the given arguments are from an iteratee call. + * + * @private + * @param {*} value The potential iteratee value argument. + * @param {*} index The potential iteratee index or key argument. + * @param {*} object The potential iteratee object argument. + * @returns {boolean} Returns `true` if the arguments are from an iteratee call, + * else `false`. + */ +function isIterateeCall(value, index, object) { + if (!isObject(object)) { + return false; + } + var type = typeof index; + if (type == 'number' + ? (isArrayLike(object) && isIndex(index, object.length)) + : (type == 'string' && index in object) + ) { + return eq(object[index], value); + } + return false; +} + +module.exports = isIterateeCall; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_isKey.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_isKey.js new file mode 100644 index 0000000..ff08b06 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_isKey.js @@ -0,0 +1,29 @@ +var isArray = require('./isArray'), + isSymbol = require('./isSymbol'); + +/** Used to match property names within property paths. */ +var reIsDeepProp = /\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/, + reIsPlainProp = /^\w*$/; + +/** + * Checks if `value` is a property name and not a property path. + * + * @private + * @param {*} value The value to check. + * @param {Object} [object] The object to query keys on. + * @returns {boolean} Returns `true` if `value` is a property name, else `false`. + */ +function isKey(value, object) { + if (isArray(value)) { + return false; + } + var type = typeof value; + if (type == 'number' || type == 'symbol' || type == 'boolean' || + value == null || isSymbol(value)) { + return true; + } + return reIsPlainProp.test(value) || !reIsDeepProp.test(value) || + (object != null && value in Object(object)); +} + +module.exports = isKey; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_isKeyable.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_isKeyable.js new file mode 100644 index 0000000..39f1828 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_isKeyable.js @@ -0,0 +1,15 @@ +/** + * Checks if `value` is suitable for use as unique object key. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is suitable, else `false`. + */ +function isKeyable(value) { + var type = typeof value; + return (type == 'string' || type == 'number' || type == 'symbol' || type == 'boolean') + ? (value !== '__proto__') + : (value === null); +} + +module.exports = isKeyable; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_isLaziable.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_isLaziable.js new file mode 100644 index 0000000..a57c4f2 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_isLaziable.js @@ -0,0 +1,28 @@ +var LazyWrapper = require('./_LazyWrapper'), + getData = require('./_getData'), + getFuncName = require('./_getFuncName'), + lodash = require('./wrapperLodash'); + +/** + * Checks if `func` has a lazy counterpart. + * + * @private + * @param {Function} func The function to check. + * @returns {boolean} Returns `true` if `func` has a lazy counterpart, + * else `false`. + */ +function isLaziable(func) { + var funcName = getFuncName(func), + other = lodash[funcName]; + + if (typeof other != 'function' || !(funcName in LazyWrapper.prototype)) { + return false; + } + if (func === other) { + return true; + } + var data = getData(other); + return !!data && func === data[0]; +} + +module.exports = isLaziable; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_isMaskable.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_isMaskable.js new file mode 100644 index 0000000..eb98d09 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_isMaskable.js @@ -0,0 +1,14 @@ +var coreJsData = require('./_coreJsData'), + isFunction = require('./isFunction'), + stubFalse = require('./stubFalse'); + +/** + * Checks if `func` is capable of being masked. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `func` is maskable, else `false`. + */ +var isMaskable = coreJsData ? isFunction : stubFalse; + +module.exports = isMaskable; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_isMasked.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_isMasked.js new file mode 100644 index 0000000..4b0f21b --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_isMasked.js @@ -0,0 +1,20 @@ +var coreJsData = require('./_coreJsData'); + +/** Used to detect methods masquerading as native. */ +var maskSrcKey = (function() { + var uid = /[^.]+$/.exec(coreJsData && coreJsData.keys && coreJsData.keys.IE_PROTO || ''); + return uid ? ('Symbol(src)_1.' + uid) : ''; +}()); + +/** + * Checks if `func` has its source masked. + * + * @private + * @param {Function} func The function to check. + * @returns {boolean} Returns `true` if `func` is masked, else `false`. + */ +function isMasked(func) { + return !!maskSrcKey && (maskSrcKey in func); +} + +module.exports = isMasked; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_isPrototype.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_isPrototype.js new file mode 100644 index 0000000..0f29498 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_isPrototype.js @@ -0,0 +1,18 @@ +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** + * Checks if `value` is likely a prototype object. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a prototype, else `false`. + */ +function isPrototype(value) { + var Ctor = value && value.constructor, + proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto; + + return value === proto; +} + +module.exports = isPrototype; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_isStrictComparable.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_isStrictComparable.js new file mode 100644 index 0000000..b59f40b --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_isStrictComparable.js @@ -0,0 +1,15 @@ +var isObject = require('./isObject'); + +/** + * Checks if `value` is suitable for strict equality comparisons, i.e. `===`. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` if suitable for strict + * equality comparisons, else `false`. + */ +function isStrictComparable(value) { + return value === value && !isObject(value); +} + +module.exports = isStrictComparable; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_iteratorToArray.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_iteratorToArray.js new file mode 100644 index 0000000..4768566 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_iteratorToArray.js @@ -0,0 +1,18 @@ +/** + * Converts `iterator` to an array. + * + * @private + * @param {Object} iterator The iterator to convert. + * @returns {Array} Returns the converted array. + */ +function iteratorToArray(iterator) { + var data, + result = []; + + while (!(data = iterator.next()).done) { + result.push(data.value); + } + return result; +} + +module.exports = iteratorToArray; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_lazyClone.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_lazyClone.js new file mode 100644 index 0000000..d8a51f8 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_lazyClone.js @@ -0,0 +1,23 @@ +var LazyWrapper = require('./_LazyWrapper'), + copyArray = require('./_copyArray'); + +/** + * Creates a clone of the lazy wrapper object. + * + * @private + * @name clone + * @memberOf LazyWrapper + * @returns {Object} Returns the cloned `LazyWrapper` object. + */ +function lazyClone() { + var result = new LazyWrapper(this.__wrapped__); + result.__actions__ = copyArray(this.__actions__); + result.__dir__ = this.__dir__; + result.__filtered__ = this.__filtered__; + result.__iteratees__ = copyArray(this.__iteratees__); + result.__takeCount__ = this.__takeCount__; + result.__views__ = copyArray(this.__views__); + return result; +} + +module.exports = lazyClone; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_lazyReverse.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_lazyReverse.js new file mode 100644 index 0000000..c5b5219 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_lazyReverse.js @@ -0,0 +1,23 @@ +var LazyWrapper = require('./_LazyWrapper'); + +/** + * Reverses the direction of lazy iteration. + * + * @private + * @name reverse + * @memberOf LazyWrapper + * @returns {Object} Returns the new reversed `LazyWrapper` object. + */ +function lazyReverse() { + if (this.__filtered__) { + var result = new LazyWrapper(this); + result.__dir__ = -1; + result.__filtered__ = true; + } else { + result = this.clone(); + result.__dir__ *= -1; + } + return result; +} + +module.exports = lazyReverse; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_lazyValue.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_lazyValue.js new file mode 100644 index 0000000..09bf14b --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_lazyValue.js @@ -0,0 +1,73 @@ +var baseWrapperValue = require('./_baseWrapperValue'), + getView = require('./_getView'), + isArray = require('./isArray'); + +/** Used as the size to enable large array optimizations. */ +var LARGE_ARRAY_SIZE = 200; + +/** Used to indicate the type of lazy iteratees. */ +var LAZY_FILTER_FLAG = 1, + LAZY_MAP_FLAG = 2; + +/* Built-in method references for those with the same name as other `lodash` methods. */ +var nativeMin = Math.min; + +/** + * Extracts the unwrapped value from its lazy wrapper. + * + * @private + * @name value + * @memberOf LazyWrapper + * @returns {*} Returns the unwrapped value. + */ +function lazyValue() { + var array = this.__wrapped__.value(), + dir = this.__dir__, + isArr = isArray(array), + isRight = dir < 0, + arrLength = isArr ? array.length : 0, + view = getView(0, arrLength, this.__views__), + start = view.start, + end = view.end, + length = end - start, + index = isRight ? end : (start - 1), + iteratees = this.__iteratees__, + iterLength = iteratees.length, + resIndex = 0, + takeCount = nativeMin(length, this.__takeCount__); + + if (!isArr || arrLength < LARGE_ARRAY_SIZE || + (arrLength == length && takeCount == length)) { + return baseWrapperValue(array, this.__actions__); + } + var result = []; + + outer: + while (length-- && resIndex < takeCount) { + index += dir; + + var iterIndex = -1, + value = array[index]; + + while (++iterIndex < iterLength) { + var data = iteratees[iterIndex], + iteratee = data.iteratee, + type = data.type, + computed = iteratee(value); + + if (type == LAZY_MAP_FLAG) { + value = computed; + } else if (!computed) { + if (type == LAZY_FILTER_FLAG) { + continue outer; + } else { + break outer; + } + } + } + result[resIndex++] = value; + } + return result; +} + +module.exports = lazyValue; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_listCacheClear.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_listCacheClear.js new file mode 100644 index 0000000..acbe39a --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_listCacheClear.js @@ -0,0 +1,13 @@ +/** + * Removes all key-value entries from the list cache. + * + * @private + * @name clear + * @memberOf ListCache + */ +function listCacheClear() { + this.__data__ = []; + this.size = 0; +} + +module.exports = listCacheClear; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_listCacheDelete.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_listCacheDelete.js new file mode 100644 index 0000000..b1384ad --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_listCacheDelete.js @@ -0,0 +1,35 @@ +var assocIndexOf = require('./_assocIndexOf'); + +/** Used for built-in method references. */ +var arrayProto = Array.prototype; + +/** Built-in value references. */ +var splice = arrayProto.splice; + +/** + * Removes `key` and its value from the list cache. + * + * @private + * @name delete + * @memberOf ListCache + * @param {string} key The key of the value to remove. + * @returns {boolean} Returns `true` if the entry was removed, else `false`. + */ +function listCacheDelete(key) { + var data = this.__data__, + index = assocIndexOf(data, key); + + if (index < 0) { + return false; + } + var lastIndex = data.length - 1; + if (index == lastIndex) { + data.pop(); + } else { + splice.call(data, index, 1); + } + --this.size; + return true; +} + +module.exports = listCacheDelete; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_listCacheGet.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_listCacheGet.js new file mode 100644 index 0000000..f8192fc --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_listCacheGet.js @@ -0,0 +1,19 @@ +var assocIndexOf = require('./_assocIndexOf'); + +/** + * Gets the list cache value for `key`. + * + * @private + * @name get + * @memberOf ListCache + * @param {string} key The key of the value to get. + * @returns {*} Returns the entry value. + */ +function listCacheGet(key) { + var data = this.__data__, + index = assocIndexOf(data, key); + + return index < 0 ? undefined : data[index][1]; +} + +module.exports = listCacheGet; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_listCacheHas.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_listCacheHas.js new file mode 100644 index 0000000..2adf671 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_listCacheHas.js @@ -0,0 +1,16 @@ +var assocIndexOf = require('./_assocIndexOf'); + +/** + * Checks if a list cache value for `key` exists. + * + * @private + * @name has + * @memberOf ListCache + * @param {string} key The key of the entry to check. + * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`. + */ +function listCacheHas(key) { + return assocIndexOf(this.__data__, key) > -1; +} + +module.exports = listCacheHas; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_listCacheSet.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_listCacheSet.js new file mode 100644 index 0000000..5855c95 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_listCacheSet.js @@ -0,0 +1,26 @@ +var assocIndexOf = require('./_assocIndexOf'); + +/** + * Sets the list cache `key` to `value`. + * + * @private + * @name set + * @memberOf ListCache + * @param {string} key The key of the value to set. + * @param {*} value The value to set. + * @returns {Object} Returns the list cache instance. + */ +function listCacheSet(key, value) { + var data = this.__data__, + index = assocIndexOf(data, key); + + if (index < 0) { + ++this.size; + data.push([key, value]); + } else { + data[index][1] = value; + } + return this; +} + +module.exports = listCacheSet; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_mapCacheClear.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_mapCacheClear.js new file mode 100644 index 0000000..bc9ca20 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_mapCacheClear.js @@ -0,0 +1,21 @@ +var Hash = require('./_Hash'), + ListCache = require('./_ListCache'), + Map = require('./_Map'); + +/** + * Removes all key-value entries from the map. + * + * @private + * @name clear + * @memberOf MapCache + */ +function mapCacheClear() { + this.size = 0; + this.__data__ = { + 'hash': new Hash, + 'map': new (Map || ListCache), + 'string': new Hash + }; +} + +module.exports = mapCacheClear; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_mapCacheDelete.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_mapCacheDelete.js new file mode 100644 index 0000000..946ca3c --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_mapCacheDelete.js @@ -0,0 +1,18 @@ +var getMapData = require('./_getMapData'); + +/** + * Removes `key` and its value from the map. + * + * @private + * @name delete + * @memberOf MapCache + * @param {string} key The key of the value to remove. + * @returns {boolean} Returns `true` if the entry was removed, else `false`. + */ +function mapCacheDelete(key) { + var result = getMapData(this, key)['delete'](key); + this.size -= result ? 1 : 0; + return result; +} + +module.exports = mapCacheDelete; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_mapCacheGet.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_mapCacheGet.js new file mode 100644 index 0000000..f29f55c --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_mapCacheGet.js @@ -0,0 +1,16 @@ +var getMapData = require('./_getMapData'); + +/** + * Gets the map value for `key`. + * + * @private + * @name get + * @memberOf MapCache + * @param {string} key The key of the value to get. + * @returns {*} Returns the entry value. + */ +function mapCacheGet(key) { + return getMapData(this, key).get(key); +} + +module.exports = mapCacheGet; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_mapCacheHas.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_mapCacheHas.js new file mode 100644 index 0000000..a1214c0 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_mapCacheHas.js @@ -0,0 +1,16 @@ +var getMapData = require('./_getMapData'); + +/** + * Checks if a map value for `key` exists. + * + * @private + * @name has + * @memberOf MapCache + * @param {string} key The key of the entry to check. + * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`. + */ +function mapCacheHas(key) { + return getMapData(this, key).has(key); +} + +module.exports = mapCacheHas; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_mapCacheSet.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_mapCacheSet.js new file mode 100644 index 0000000..7346849 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_mapCacheSet.js @@ -0,0 +1,22 @@ +var getMapData = require('./_getMapData'); + +/** + * Sets the map `key` to `value`. + * + * @private + * @name set + * @memberOf MapCache + * @param {string} key The key of the value to set. + * @param {*} value The value to set. + * @returns {Object} Returns the map cache instance. + */ +function mapCacheSet(key, value) { + var data = getMapData(this, key), + size = data.size; + + data.set(key, value); + this.size += data.size == size ? 0 : 1; + return this; +} + +module.exports = mapCacheSet; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_mapToArray.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_mapToArray.js new file mode 100644 index 0000000..fe3dd53 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_mapToArray.js @@ -0,0 +1,18 @@ +/** + * Converts `map` to its key-value pairs. + * + * @private + * @param {Object} map The map to convert. + * @returns {Array} Returns the key-value pairs. + */ +function mapToArray(map) { + var index = -1, + result = Array(map.size); + + map.forEach(function(value, key) { + result[++index] = [key, value]; + }); + return result; +} + +module.exports = mapToArray; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_matchesStrictComparable.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_matchesStrictComparable.js new file mode 100644 index 0000000..f608af9 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_matchesStrictComparable.js @@ -0,0 +1,20 @@ +/** + * A specialized version of `matchesProperty` for source values suitable + * for strict equality comparisons, i.e. `===`. + * + * @private + * @param {string} key The key of the property to get. + * @param {*} srcValue The value to match. + * @returns {Function} Returns the new spec function. + */ +function matchesStrictComparable(key, srcValue) { + return function(object) { + if (object == null) { + return false; + } + return object[key] === srcValue && + (srcValue !== undefined || (key in Object(object))); + }; +} + +module.exports = matchesStrictComparable; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_memoizeCapped.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_memoizeCapped.js new file mode 100644 index 0000000..7f71c8f --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_memoizeCapped.js @@ -0,0 +1,26 @@ +var memoize = require('./memoize'); + +/** Used as the maximum memoize cache size. */ +var MAX_MEMOIZE_SIZE = 500; + +/** + * A specialized version of `_.memoize` which clears the memoized function's + * cache when it exceeds `MAX_MEMOIZE_SIZE`. + * + * @private + * @param {Function} func The function to have its output memoized. + * @returns {Function} Returns the new memoized function. + */ +function memoizeCapped(func) { + var result = memoize(func, function(key) { + if (cache.size === MAX_MEMOIZE_SIZE) { + cache.clear(); + } + return key; + }); + + var cache = result.cache; + return result; +} + +module.exports = memoizeCapped; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_mergeData.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_mergeData.js new file mode 100644 index 0000000..5aa1f1f --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_mergeData.js @@ -0,0 +1,90 @@ +var composeArgs = require('./_composeArgs'), + composeArgsRight = require('./_composeArgsRight'), + replaceHolders = require('./_replaceHolders'); + +/** Used as the internal argument placeholder. */ +var PLACEHOLDER = '__lodash_placeholder__'; + +/** Used to compose bitmasks for function metadata. */ +var BIND_FLAG = 1, + BIND_KEY_FLAG = 2, + CURRY_BOUND_FLAG = 4, + CURRY_FLAG = 8, + ARY_FLAG = 128, + REARG_FLAG = 256; + +/* Built-in method references for those with the same name as other `lodash` methods. */ +var nativeMin = Math.min; + +/** + * Merges the function metadata of `source` into `data`. + * + * Merging metadata reduces the number of wrappers used to invoke a function. + * This is possible because methods like `_.bind`, `_.curry`, and `_.partial` + * may be applied regardless of execution order. Methods like `_.ary` and + * `_.rearg` modify function arguments, making the order in which they are + * executed important, preventing the merging of metadata. However, we make + * an exception for a safe combined case where curried functions have `_.ary` + * and or `_.rearg` applied. + * + * @private + * @param {Array} data The destination metadata. + * @param {Array} source The source metadata. + * @returns {Array} Returns `data`. + */ +function mergeData(data, source) { + var bitmask = data[1], + srcBitmask = source[1], + newBitmask = bitmask | srcBitmask, + isCommon = newBitmask < (BIND_FLAG | BIND_KEY_FLAG | ARY_FLAG); + + var isCombo = + ((srcBitmask == ARY_FLAG) && (bitmask == CURRY_FLAG)) || + ((srcBitmask == ARY_FLAG) && (bitmask == REARG_FLAG) && (data[7].length <= source[8])) || + ((srcBitmask == (ARY_FLAG | REARG_FLAG)) && (source[7].length <= source[8]) && (bitmask == CURRY_FLAG)); + + // Exit early if metadata can't be merged. + if (!(isCommon || isCombo)) { + return data; + } + // Use source `thisArg` if available. + if (srcBitmask & BIND_FLAG) { + data[2] = source[2]; + // Set when currying a bound function. + newBitmask |= bitmask & BIND_FLAG ? 0 : CURRY_BOUND_FLAG; + } + // Compose partial arguments. + var value = source[3]; + if (value) { + var partials = data[3]; + data[3] = partials ? composeArgs(partials, value, source[4]) : value; + data[4] = partials ? replaceHolders(data[3], PLACEHOLDER) : source[4]; + } + // Compose partial right arguments. + value = source[5]; + if (value) { + partials = data[5]; + data[5] = partials ? composeArgsRight(partials, value, source[6]) : value; + data[6] = partials ? replaceHolders(data[5], PLACEHOLDER) : source[6]; + } + // Use source `argPos` if available. + value = source[7]; + if (value) { + data[7] = value; + } + // Use source `ary` if it's smaller. + if (srcBitmask & ARY_FLAG) { + data[8] = data[8] == null ? source[8] : nativeMin(data[8], source[8]); + } + // Use source `arity` if one is not provided. + if (data[9] == null) { + data[9] = source[9]; + } + // Use source `func` and merge bitmasks. + data[0] = source[0]; + data[1] = newBitmask; + + return data; +} + +module.exports = mergeData; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_mergeDefaults.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_mergeDefaults.js new file mode 100644 index 0000000..9888f0e --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_mergeDefaults.js @@ -0,0 +1,27 @@ +var baseMerge = require('./_baseMerge'), + isObject = require('./isObject'); + +/** + * Used by `_.defaultsDeep` to customize its `_.merge` use. + * + * @private + * @param {*} objValue The destination value. + * @param {*} srcValue The source value. + * @param {string} key The key of the property to merge. + * @param {Object} object The parent object of `objValue`. + * @param {Object} source The parent object of `srcValue`. + * @param {Object} [stack] Tracks traversed source values and their merged + * counterparts. + * @returns {*} Returns the value to assign. + */ +function mergeDefaults(objValue, srcValue, key, object, source, stack) { + if (isObject(objValue) && isObject(srcValue)) { + // Recursively merge objects and arrays (susceptible to call stack limits). + stack.set(srcValue, objValue); + baseMerge(objValue, srcValue, undefined, mergeDefaults, stack); + stack['delete'](srcValue); + } + return objValue; +} + +module.exports = mergeDefaults; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_metaMap.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_metaMap.js new file mode 100644 index 0000000..0157a0b --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_metaMap.js @@ -0,0 +1,6 @@ +var WeakMap = require('./_WeakMap'); + +/** Used to store function metadata. */ +var metaMap = WeakMap && new WeakMap; + +module.exports = metaMap; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_nativeCreate.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_nativeCreate.js new file mode 100644 index 0000000..c7aede8 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_nativeCreate.js @@ -0,0 +1,6 @@ +var getNative = require('./_getNative'); + +/* Built-in method references that are verified to be native. */ +var nativeCreate = getNative(Object, 'create'); + +module.exports = nativeCreate; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_nativeKeys.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_nativeKeys.js new file mode 100644 index 0000000..479a104 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_nativeKeys.js @@ -0,0 +1,6 @@ +var overArg = require('./_overArg'); + +/* Built-in method references for those with the same name as other `lodash` methods. */ +var nativeKeys = overArg(Object.keys, Object); + +module.exports = nativeKeys; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_nativeKeysIn.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_nativeKeysIn.js new file mode 100644 index 0000000..00ee505 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_nativeKeysIn.js @@ -0,0 +1,20 @@ +/** + * This function is like + * [`Object.keys`](http://ecma-international.org/ecma-262/7.0/#sec-object.keys) + * except that it includes inherited enumerable properties. + * + * @private + * @param {Object} object The object to query. + * @returns {Array} Returns the array of property names. + */ +function nativeKeysIn(object) { + var result = []; + if (object != null) { + for (var key in Object(object)) { + result.push(key); + } + } + return result; +} + +module.exports = nativeKeysIn; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_nodeUtil.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_nodeUtil.js new file mode 100644 index 0000000..b8e48e3 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_nodeUtil.js @@ -0,0 +1,22 @@ +var freeGlobal = require('./_freeGlobal'); + +/** Detect free variable `exports`. */ +var freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports; + +/** Detect free variable `module`. */ +var freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module; + +/** Detect the popular CommonJS extension `module.exports`. */ +var moduleExports = freeModule && freeModule.exports === freeExports; + +/** Detect free variable `process` from Node.js. */ +var freeProcess = moduleExports && freeGlobal.process; + +/** Used to access faster Node.js helpers. */ +var nodeUtil = (function() { + try { + return freeProcess && freeProcess.binding('util'); + } catch (e) {} +}()); + +module.exports = nodeUtil; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_overArg.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_overArg.js new file mode 100644 index 0000000..651c5c5 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_overArg.js @@ -0,0 +1,15 @@ +/** + * Creates a unary function that invokes `func` with its argument transformed. + * + * @private + * @param {Function} func The function to wrap. + * @param {Function} transform The argument transform. + * @returns {Function} Returns the new function. + */ +function overArg(func, transform) { + return function(arg) { + return func(transform(arg)); + }; +} + +module.exports = overArg; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_overRest.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_overRest.js new file mode 100644 index 0000000..c7cdef3 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_overRest.js @@ -0,0 +1,36 @@ +var apply = require('./_apply'); + +/* Built-in method references for those with the same name as other `lodash` methods. */ +var nativeMax = Math.max; + +/** + * A specialized version of `baseRest` which transforms the rest array. + * + * @private + * @param {Function} func The function to apply a rest parameter to. + * @param {number} [start=func.length-1] The start position of the rest parameter. + * @param {Function} transform The rest array transform. + * @returns {Function} Returns the new function. + */ +function overRest(func, start, transform) { + start = nativeMax(start === undefined ? (func.length - 1) : start, 0); + return function() { + var args = arguments, + index = -1, + length = nativeMax(args.length - start, 0), + array = Array(length); + + while (++index < length) { + array[index] = args[start + index]; + } + index = -1; + var otherArgs = Array(start + 1); + while (++index < start) { + otherArgs[index] = args[index]; + } + otherArgs[start] = transform(array); + return apply(func, this, otherArgs); + }; +} + +module.exports = overRest; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_parent.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_parent.js new file mode 100644 index 0000000..81d94d0 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_parent.js @@ -0,0 +1,16 @@ +var baseGet = require('./_baseGet'), + baseSlice = require('./_baseSlice'); + +/** + * Gets the parent value at `path` of `object`. + * + * @private + * @param {Object} object The object to query. + * @param {Array} path The path to get the parent value of. + * @returns {*} Returns the parent value. + */ +function parent(object, path) { + return path.length == 1 ? object : baseGet(object, baseSlice(path, 0, -1)); +} + +module.exports = parent; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_reEscape.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_reEscape.js new file mode 100644 index 0000000..7f47eda --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_reEscape.js @@ -0,0 +1,4 @@ +/** Used to match template delimiters. */ +var reEscape = /<%-([\s\S]+?)%>/g; + +module.exports = reEscape; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_reEvaluate.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_reEvaluate.js new file mode 100644 index 0000000..6adfc31 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_reEvaluate.js @@ -0,0 +1,4 @@ +/** Used to match template delimiters. */ +var reEvaluate = /<%([\s\S]+?)%>/g; + +module.exports = reEvaluate; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_reInterpolate.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_reInterpolate.js new file mode 100644 index 0000000..d02ff0b --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_reInterpolate.js @@ -0,0 +1,4 @@ +/** Used to match template delimiters. */ +var reInterpolate = /<%=([\s\S]+?)%>/g; + +module.exports = reInterpolate; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_realNames.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_realNames.js new file mode 100644 index 0000000..aa0d529 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_realNames.js @@ -0,0 +1,4 @@ +/** Used to lookup unminified function names. */ +var realNames = {}; + +module.exports = realNames; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_reorder.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_reorder.js new file mode 100644 index 0000000..a3502b0 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_reorder.js @@ -0,0 +1,29 @@ +var copyArray = require('./_copyArray'), + isIndex = require('./_isIndex'); + +/* Built-in method references for those with the same name as other `lodash` methods. */ +var nativeMin = Math.min; + +/** + * Reorder `array` according to the specified indexes where the element at + * the first index is assigned as the first element, the element at + * the second index is assigned as the second element, and so on. + * + * @private + * @param {Array} array The array to reorder. + * @param {Array} indexes The arranged array indexes. + * @returns {Array} Returns `array`. + */ +function reorder(array, indexes) { + var arrLength = array.length, + length = nativeMin(indexes.length, arrLength), + oldArray = copyArray(array); + + while (length--) { + var index = indexes[length]; + array[length] = isIndex(index, arrLength) ? oldArray[index] : undefined; + } + return array; +} + +module.exports = reorder; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_replaceHolders.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_replaceHolders.js new file mode 100644 index 0000000..74360ec --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_replaceHolders.js @@ -0,0 +1,29 @@ +/** Used as the internal argument placeholder. */ +var PLACEHOLDER = '__lodash_placeholder__'; + +/** + * Replaces all `placeholder` elements in `array` with an internal placeholder + * and returns an array of their indexes. + * + * @private + * @param {Array} array The array to modify. + * @param {*} placeholder The placeholder to replace. + * @returns {Array} Returns the new array of placeholder indexes. + */ +function replaceHolders(array, placeholder) { + var index = -1, + length = array.length, + resIndex = 0, + result = []; + + while (++index < length) { + var value = array[index]; + if (value === placeholder || value === PLACEHOLDER) { + array[index] = PLACEHOLDER; + result[resIndex++] = index; + } + } + return result; +} + +module.exports = replaceHolders; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_root.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_root.js new file mode 100644 index 0000000..d2852be --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_root.js @@ -0,0 +1,9 @@ +var freeGlobal = require('./_freeGlobal'); + +/** Detect free variable `self`. */ +var freeSelf = typeof self == 'object' && self && self.Object === Object && self; + +/** Used as a reference to the global object. */ +var root = freeGlobal || freeSelf || Function('return this')(); + +module.exports = root; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_setCacheAdd.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_setCacheAdd.js new file mode 100644 index 0000000..1081a74 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_setCacheAdd.js @@ -0,0 +1,19 @@ +/** Used to stand-in for `undefined` hash values. */ +var HASH_UNDEFINED = '__lodash_hash_undefined__'; + +/** + * Adds `value` to the array cache. + * + * @private + * @name add + * @memberOf SetCache + * @alias push + * @param {*} value The value to cache. + * @returns {Object} Returns the cache instance. + */ +function setCacheAdd(value) { + this.__data__.set(value, HASH_UNDEFINED); + return this; +} + +module.exports = setCacheAdd; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_setCacheHas.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_setCacheHas.js new file mode 100644 index 0000000..9a49255 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_setCacheHas.js @@ -0,0 +1,14 @@ +/** + * Checks if `value` is in the array cache. + * + * @private + * @name has + * @memberOf SetCache + * @param {*} value The value to search for. + * @returns {number} Returns `true` if `value` is found, else `false`. + */ +function setCacheHas(value) { + return this.__data__.has(value); +} + +module.exports = setCacheHas; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_setData.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_setData.js new file mode 100644 index 0000000..e5cf3eb --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_setData.js @@ -0,0 +1,20 @@ +var baseSetData = require('./_baseSetData'), + shortOut = require('./_shortOut'); + +/** + * Sets metadata for `func`. + * + * **Note:** If this function becomes hot, i.e. is invoked a lot in a short + * period of time, it will trip its breaker and transition to an identity + * function to avoid garbage collection pauses in V8. See + * [V8 issue 2070](https://bugs.chromium.org/p/v8/issues/detail?id=2070) + * for more details. + * + * @private + * @param {Function} func The function to associate metadata with. + * @param {*} data The metadata. + * @returns {Function} Returns `func`. + */ +var setData = shortOut(baseSetData); + +module.exports = setData; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_setToArray.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_setToArray.js new file mode 100644 index 0000000..b87f074 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_setToArray.js @@ -0,0 +1,18 @@ +/** + * Converts `set` to an array of its values. + * + * @private + * @param {Object} set The set to convert. + * @returns {Array} Returns the values. + */ +function setToArray(set) { + var index = -1, + result = Array(set.size); + + set.forEach(function(value) { + result[++index] = value; + }); + return result; +} + +module.exports = setToArray; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_setToPairs.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_setToPairs.js new file mode 100644 index 0000000..36ad37a --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_setToPairs.js @@ -0,0 +1,18 @@ +/** + * Converts `set` to its value-value pairs. + * + * @private + * @param {Object} set The set to convert. + * @returns {Array} Returns the value-value pairs. + */ +function setToPairs(set) { + var index = -1, + result = Array(set.size); + + set.forEach(function(value) { + result[++index] = [value, value]; + }); + return result; +} + +module.exports = setToPairs; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_setToString.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_setToString.js new file mode 100644 index 0000000..6ca8419 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_setToString.js @@ -0,0 +1,14 @@ +var baseSetToString = require('./_baseSetToString'), + shortOut = require('./_shortOut'); + +/** + * Sets the `toString` method of `func` to return `string`. + * + * @private + * @param {Function} func The function to modify. + * @param {Function} string The `toString` result. + * @returns {Function} Returns `func`. + */ +var setToString = shortOut(baseSetToString); + +module.exports = setToString; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_setWrapToString.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_setWrapToString.js new file mode 100644 index 0000000..decdc44 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_setWrapToString.js @@ -0,0 +1,21 @@ +var getWrapDetails = require('./_getWrapDetails'), + insertWrapDetails = require('./_insertWrapDetails'), + setToString = require('./_setToString'), + updateWrapDetails = require('./_updateWrapDetails'); + +/** + * Sets the `toString` method of `wrapper` to mimic the source of `reference` + * with wrapper details in a comment at the top of the source body. + * + * @private + * @param {Function} wrapper The function to modify. + * @param {Function} reference The reference function. + * @param {number} bitmask The bitmask flags. See `createWrap` for more details. + * @returns {Function} Returns `wrapper`. + */ +function setWrapToString(wrapper, reference, bitmask) { + var source = (reference + ''); + return setToString(wrapper, insertWrapDetails(source, updateWrapDetails(getWrapDetails(source), bitmask))); +} + +module.exports = setWrapToString; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_shortOut.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_shortOut.js new file mode 100644 index 0000000..a4e6507 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_shortOut.js @@ -0,0 +1,37 @@ +/** Used to detect hot functions by number of calls within a span of milliseconds. */ +var HOT_COUNT = 500, + HOT_SPAN = 16; + +/* Built-in method references for those with the same name as other `lodash` methods. */ +var nativeNow = Date.now; + +/** + * Creates a function that'll short out and invoke `identity` instead + * of `func` when it's called `HOT_COUNT` or more times in `HOT_SPAN` + * milliseconds. + * + * @private + * @param {Function} func The function to restrict. + * @returns {Function} Returns the new shortable function. + */ +function shortOut(func) { + var count = 0, + lastCalled = 0; + + return function() { + var stamp = nativeNow(), + remaining = HOT_SPAN - (stamp - lastCalled); + + lastCalled = stamp; + if (remaining > 0) { + if (++count >= HOT_COUNT) { + return arguments[0]; + } + } else { + count = 0; + } + return func.apply(undefined, arguments); + }; +} + +module.exports = shortOut; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_shuffleSelf.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_shuffleSelf.js new file mode 100644 index 0000000..8bcc4f5 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_shuffleSelf.js @@ -0,0 +1,28 @@ +var baseRandom = require('./_baseRandom'); + +/** + * A specialized version of `_.shuffle` which mutates and sets the size of `array`. + * + * @private + * @param {Array} array The array to shuffle. + * @param {number} [size=array.length] The size of `array`. + * @returns {Array} Returns `array`. + */ +function shuffleSelf(array, size) { + var index = -1, + length = array.length, + lastIndex = length - 1; + + size = size === undefined ? length : size; + while (++index < size) { + var rand = baseRandom(index, lastIndex), + value = array[rand]; + + array[rand] = array[index]; + array[index] = value; + } + array.length = size; + return array; +} + +module.exports = shuffleSelf; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_stackClear.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_stackClear.js new file mode 100644 index 0000000..ce8e5a9 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_stackClear.js @@ -0,0 +1,15 @@ +var ListCache = require('./_ListCache'); + +/** + * Removes all key-value entries from the stack. + * + * @private + * @name clear + * @memberOf Stack + */ +function stackClear() { + this.__data__ = new ListCache; + this.size = 0; +} + +module.exports = stackClear; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_stackDelete.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_stackDelete.js new file mode 100644 index 0000000..ff9887a --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_stackDelete.js @@ -0,0 +1,18 @@ +/** + * Removes `key` and its value from the stack. + * + * @private + * @name delete + * @memberOf Stack + * @param {string} key The key of the value to remove. + * @returns {boolean} Returns `true` if the entry was removed, else `false`. + */ +function stackDelete(key) { + var data = this.__data__, + result = data['delete'](key); + + this.size = data.size; + return result; +} + +module.exports = stackDelete; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_stackGet.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_stackGet.js new file mode 100644 index 0000000..1cdf004 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_stackGet.js @@ -0,0 +1,14 @@ +/** + * Gets the stack value for `key`. + * + * @private + * @name get + * @memberOf Stack + * @param {string} key The key of the value to get. + * @returns {*} Returns the entry value. + */ +function stackGet(key) { + return this.__data__.get(key); +} + +module.exports = stackGet; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_stackHas.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_stackHas.js new file mode 100644 index 0000000..16a3ad1 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_stackHas.js @@ -0,0 +1,14 @@ +/** + * Checks if a stack value for `key` exists. + * + * @private + * @name has + * @memberOf Stack + * @param {string} key The key of the entry to check. + * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`. + */ +function stackHas(key) { + return this.__data__.has(key); +} + +module.exports = stackHas; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_stackSet.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_stackSet.js new file mode 100644 index 0000000..b790ac5 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_stackSet.js @@ -0,0 +1,34 @@ +var ListCache = require('./_ListCache'), + Map = require('./_Map'), + MapCache = require('./_MapCache'); + +/** Used as the size to enable large array optimizations. */ +var LARGE_ARRAY_SIZE = 200; + +/** + * Sets the stack `key` to `value`. + * + * @private + * @name set + * @memberOf Stack + * @param {string} key The key of the value to set. + * @param {*} value The value to set. + * @returns {Object} Returns the stack cache instance. + */ +function stackSet(key, value) { + var data = this.__data__; + if (data instanceof ListCache) { + var pairs = data.__data__; + if (!Map || (pairs.length < LARGE_ARRAY_SIZE - 1)) { + pairs.push([key, value]); + this.size = ++data.size; + return this; + } + data = this.__data__ = new MapCache(pairs); + } + data.set(key, value); + this.size = data.size; + return this; +} + +module.exports = stackSet; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_strictIndexOf.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_strictIndexOf.js new file mode 100644 index 0000000..0486a49 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_strictIndexOf.js @@ -0,0 +1,23 @@ +/** + * A specialized version of `_.indexOf` which performs strict equality + * comparisons of values, i.e. `===`. + * + * @private + * @param {Array} array The array to inspect. + * @param {*} value The value to search for. + * @param {number} fromIndex The index to search from. + * @returns {number} Returns the index of the matched value, else `-1`. + */ +function strictIndexOf(array, value, fromIndex) { + var index = fromIndex - 1, + length = array.length; + + while (++index < length) { + if (array[index] === value) { + return index; + } + } + return -1; +} + +module.exports = strictIndexOf; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_strictLastIndexOf.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_strictLastIndexOf.js new file mode 100644 index 0000000..d7310dc --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_strictLastIndexOf.js @@ -0,0 +1,21 @@ +/** + * A specialized version of `_.lastIndexOf` which performs strict equality + * comparisons of values, i.e. `===`. + * + * @private + * @param {Array} array The array to inspect. + * @param {*} value The value to search for. + * @param {number} fromIndex The index to search from. + * @returns {number} Returns the index of the matched value, else `-1`. + */ +function strictLastIndexOf(array, value, fromIndex) { + var index = fromIndex + 1; + while (index--) { + if (array[index] === value) { + return index; + } + } + return index; +} + +module.exports = strictLastIndexOf; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_stringSize.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_stringSize.js new file mode 100644 index 0000000..17ef462 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_stringSize.js @@ -0,0 +1,18 @@ +var asciiSize = require('./_asciiSize'), + hasUnicode = require('./_hasUnicode'), + unicodeSize = require('./_unicodeSize'); + +/** + * Gets the number of symbols in `string`. + * + * @private + * @param {string} string The string to inspect. + * @returns {number} Returns the string size. + */ +function stringSize(string) { + return hasUnicode(string) + ? unicodeSize(string) + : asciiSize(string); +} + +module.exports = stringSize; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_stringToArray.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_stringToArray.js new file mode 100644 index 0000000..d161158 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_stringToArray.js @@ -0,0 +1,18 @@ +var asciiToArray = require('./_asciiToArray'), + hasUnicode = require('./_hasUnicode'), + unicodeToArray = require('./_unicodeToArray'); + +/** + * Converts `string` to an array. + * + * @private + * @param {string} string The string to convert. + * @returns {Array} Returns the converted array. + */ +function stringToArray(string) { + return hasUnicode(string) + ? unicodeToArray(string) + : asciiToArray(string); +} + +module.exports = stringToArray; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_stringToPath.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_stringToPath.js new file mode 100644 index 0000000..8bb78e5 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_stringToPath.js @@ -0,0 +1,31 @@ +var memoizeCapped = require('./_memoizeCapped'), + toString = require('./toString'); + +/** Used to match property names within property paths. */ +var reLeadingDot = /^\./, + rePropName = /[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g; + +/** Used to match backslashes in property paths. */ +var reEscapeChar = /\\(\\)?/g; + +/** + * Converts `string` to a property path array. + * + * @private + * @param {string} string The string to convert. + * @returns {Array} Returns the property path array. + */ +var stringToPath = memoizeCapped(function(string) { + string = toString(string); + + var result = []; + if (reLeadingDot.test(string)) { + result.push(''); + } + string.replace(rePropName, function(match, number, quote, string) { + result.push(quote ? string.replace(reEscapeChar, '$1') : (number || match)); + }); + return result; +}); + +module.exports = stringToPath; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_toKey.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_toKey.js new file mode 100644 index 0000000..c6d645c --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_toKey.js @@ -0,0 +1,21 @@ +var isSymbol = require('./isSymbol'); + +/** Used as references for various `Number` constants. */ +var INFINITY = 1 / 0; + +/** + * Converts `value` to a string key if it's not a string or symbol. + * + * @private + * @param {*} value The value to inspect. + * @returns {string|symbol} Returns the key. + */ +function toKey(value) { + if (typeof value == 'string' || isSymbol(value)) { + return value; + } + var result = (value + ''); + return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result; +} + +module.exports = toKey; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_toSource.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_toSource.js new file mode 100644 index 0000000..00ac454 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_toSource.js @@ -0,0 +1,26 @@ +/** Used for built-in method references. */ +var funcProto = Function.prototype; + +/** Used to resolve the decompiled source of functions. */ +var funcToString = funcProto.toString; + +/** + * Converts `func` to its source code. + * + * @private + * @param {Function} func The function to process. + * @returns {string} Returns the source code. + */ +function toSource(func) { + if (func != null) { + try { + return funcToString.call(func); + } catch (e) {} + try { + return (func + ''); + } catch (e) {} + } + return ''; +} + +module.exports = toSource; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_unescapeHtmlChar.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_unescapeHtmlChar.js new file mode 100644 index 0000000..a71fecb --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_unescapeHtmlChar.js @@ -0,0 +1,21 @@ +var basePropertyOf = require('./_basePropertyOf'); + +/** Used to map HTML entities to characters. */ +var htmlUnescapes = { + '&': '&', + '<': '<', + '>': '>', + '"': '"', + ''': "'" +}; + +/** + * Used by `_.unescape` to convert HTML entities to characters. + * + * @private + * @param {string} chr The matched character to unescape. + * @returns {string} Returns the unescaped character. + */ +var unescapeHtmlChar = basePropertyOf(htmlUnescapes); + +module.exports = unescapeHtmlChar; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_unicodeSize.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_unicodeSize.js new file mode 100644 index 0000000..26cd257 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_unicodeSize.js @@ -0,0 +1,42 @@ +/** Used to compose unicode character classes. */ +var rsAstralRange = '\\ud800-\\udfff', + rsComboMarksRange = '\\u0300-\\u036f\\ufe20-\\ufe23', + rsComboSymbolsRange = '\\u20d0-\\u20f0', + rsVarRange = '\\ufe0e\\ufe0f'; + +/** Used to compose unicode capture groups. */ +var rsAstral = '[' + rsAstralRange + ']', + rsCombo = '[' + rsComboMarksRange + rsComboSymbolsRange + ']', + rsFitz = '\\ud83c[\\udffb-\\udfff]', + rsModifier = '(?:' + rsCombo + '|' + rsFitz + ')', + rsNonAstral = '[^' + rsAstralRange + ']', + rsRegional = '(?:\\ud83c[\\udde6-\\uddff]){2}', + rsSurrPair = '[\\ud800-\\udbff][\\udc00-\\udfff]', + rsZWJ = '\\u200d'; + +/** Used to compose unicode regexes. */ +var reOptMod = rsModifier + '?', + rsOptVar = '[' + rsVarRange + ']?', + rsOptJoin = '(?:' + rsZWJ + '(?:' + [rsNonAstral, rsRegional, rsSurrPair].join('|') + ')' + rsOptVar + reOptMod + ')*', + rsSeq = rsOptVar + reOptMod + rsOptJoin, + rsSymbol = '(?:' + [rsNonAstral + rsCombo + '?', rsCombo, rsRegional, rsSurrPair, rsAstral].join('|') + ')'; + +/** Used to match [string symbols](https://mathiasbynens.be/notes/javascript-unicode). */ +var reUnicode = RegExp(rsFitz + '(?=' + rsFitz + ')|' + rsSymbol + rsSeq, 'g'); + +/** + * Gets the size of a Unicode `string`. + * + * @private + * @param {string} string The string inspect. + * @returns {number} Returns the string size. + */ +function unicodeSize(string) { + var result = reUnicode.lastIndex = 0; + while (reUnicode.test(string)) { + ++result; + } + return result; +} + +module.exports = unicodeSize; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_unicodeToArray.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_unicodeToArray.js new file mode 100644 index 0000000..11ac763 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_unicodeToArray.js @@ -0,0 +1,38 @@ +/** Used to compose unicode character classes. */ +var rsAstralRange = '\\ud800-\\udfff', + rsComboMarksRange = '\\u0300-\\u036f\\ufe20-\\ufe23', + rsComboSymbolsRange = '\\u20d0-\\u20f0', + rsVarRange = '\\ufe0e\\ufe0f'; + +/** Used to compose unicode capture groups. */ +var rsAstral = '[' + rsAstralRange + ']', + rsCombo = '[' + rsComboMarksRange + rsComboSymbolsRange + ']', + rsFitz = '\\ud83c[\\udffb-\\udfff]', + rsModifier = '(?:' + rsCombo + '|' + rsFitz + ')', + rsNonAstral = '[^' + rsAstralRange + ']', + rsRegional = '(?:\\ud83c[\\udde6-\\uddff]){2}', + rsSurrPair = '[\\ud800-\\udbff][\\udc00-\\udfff]', + rsZWJ = '\\u200d'; + +/** Used to compose unicode regexes. */ +var reOptMod = rsModifier + '?', + rsOptVar = '[' + rsVarRange + ']?', + rsOptJoin = '(?:' + rsZWJ + '(?:' + [rsNonAstral, rsRegional, rsSurrPair].join('|') + ')' + rsOptVar + reOptMod + ')*', + rsSeq = rsOptVar + reOptMod + rsOptJoin, + rsSymbol = '(?:' + [rsNonAstral + rsCombo + '?', rsCombo, rsRegional, rsSurrPair, rsAstral].join('|') + ')'; + +/** Used to match [string symbols](https://mathiasbynens.be/notes/javascript-unicode). */ +var reUnicode = RegExp(rsFitz + '(?=' + rsFitz + ')|' + rsSymbol + rsSeq, 'g'); + +/** + * Converts a Unicode `string` to an array. + * + * @private + * @param {string} string The string to convert. + * @returns {Array} Returns the converted array. + */ +function unicodeToArray(string) { + return string.match(reUnicode) || []; +} + +module.exports = unicodeToArray; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_unicodeWords.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_unicodeWords.js new file mode 100644 index 0000000..a02e930 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_unicodeWords.js @@ -0,0 +1,63 @@ +/** Used to compose unicode character classes. */ +var rsAstralRange = '\\ud800-\\udfff', + rsComboMarksRange = '\\u0300-\\u036f\\ufe20-\\ufe23', + rsComboSymbolsRange = '\\u20d0-\\u20f0', + rsDingbatRange = '\\u2700-\\u27bf', + rsLowerRange = 'a-z\\xdf-\\xf6\\xf8-\\xff', + rsMathOpRange = '\\xac\\xb1\\xd7\\xf7', + rsNonCharRange = '\\x00-\\x2f\\x3a-\\x40\\x5b-\\x60\\x7b-\\xbf', + rsPunctuationRange = '\\u2000-\\u206f', + rsSpaceRange = ' \\t\\x0b\\f\\xa0\\ufeff\\n\\r\\u2028\\u2029\\u1680\\u180e\\u2000\\u2001\\u2002\\u2003\\u2004\\u2005\\u2006\\u2007\\u2008\\u2009\\u200a\\u202f\\u205f\\u3000', + rsUpperRange = 'A-Z\\xc0-\\xd6\\xd8-\\xde', + rsVarRange = '\\ufe0e\\ufe0f', + rsBreakRange = rsMathOpRange + rsNonCharRange + rsPunctuationRange + rsSpaceRange; + +/** Used to compose unicode capture groups. */ +var rsApos = "['\u2019]", + rsBreak = '[' + rsBreakRange + ']', + rsCombo = '[' + rsComboMarksRange + rsComboSymbolsRange + ']', + rsDigits = '\\d+', + rsDingbat = '[' + rsDingbatRange + ']', + rsLower = '[' + rsLowerRange + ']', + rsMisc = '[^' + rsAstralRange + rsBreakRange + rsDigits + rsDingbatRange + rsLowerRange + rsUpperRange + ']', + rsFitz = '\\ud83c[\\udffb-\\udfff]', + rsModifier = '(?:' + rsCombo + '|' + rsFitz + ')', + rsNonAstral = '[^' + rsAstralRange + ']', + rsRegional = '(?:\\ud83c[\\udde6-\\uddff]){2}', + rsSurrPair = '[\\ud800-\\udbff][\\udc00-\\udfff]', + rsUpper = '[' + rsUpperRange + ']', + rsZWJ = '\\u200d'; + +/** Used to compose unicode regexes. */ +var rsLowerMisc = '(?:' + rsLower + '|' + rsMisc + ')', + rsUpperMisc = '(?:' + rsUpper + '|' + rsMisc + ')', + rsOptLowerContr = '(?:' + rsApos + '(?:d|ll|m|re|s|t|ve))?', + rsOptUpperContr = '(?:' + rsApos + '(?:D|LL|M|RE|S|T|VE))?', + reOptMod = rsModifier + '?', + rsOptVar = '[' + rsVarRange + ']?', + rsOptJoin = '(?:' + rsZWJ + '(?:' + [rsNonAstral, rsRegional, rsSurrPair].join('|') + ')' + rsOptVar + reOptMod + ')*', + rsSeq = rsOptVar + reOptMod + rsOptJoin, + rsEmoji = '(?:' + [rsDingbat, rsRegional, rsSurrPair].join('|') + ')' + rsSeq; + +/** Used to match complex or compound words. */ +var reUnicodeWord = RegExp([ + rsUpper + '?' + rsLower + '+' + rsOptLowerContr + '(?=' + [rsBreak, rsUpper, '$'].join('|') + ')', + rsUpperMisc + '+' + rsOptUpperContr + '(?=' + [rsBreak, rsUpper + rsLowerMisc, '$'].join('|') + ')', + rsUpper + '?' + rsLowerMisc + '+' + rsOptLowerContr, + rsUpper + '+' + rsOptUpperContr, + rsDigits, + rsEmoji +].join('|'), 'g'); + +/** + * Splits a Unicode `string` into an array of its words. + * + * @private + * @param {string} The string to inspect. + * @returns {Array} Returns the words of `string`. + */ +function unicodeWords(string) { + return string.match(reUnicodeWord) || []; +} + +module.exports = unicodeWords; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_updateWrapDetails.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_updateWrapDetails.js new file mode 100644 index 0000000..128b1b4 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_updateWrapDetails.js @@ -0,0 +1,46 @@ +var arrayEach = require('./_arrayEach'), + arrayIncludes = require('./_arrayIncludes'); + +/** Used to compose bitmasks for function metadata. */ +var BIND_FLAG = 1, + BIND_KEY_FLAG = 2, + CURRY_FLAG = 8, + CURRY_RIGHT_FLAG = 16, + PARTIAL_FLAG = 32, + PARTIAL_RIGHT_FLAG = 64, + ARY_FLAG = 128, + REARG_FLAG = 256, + FLIP_FLAG = 512; + +/** Used to associate wrap methods with their bit flags. */ +var wrapFlags = [ + ['ary', ARY_FLAG], + ['bind', BIND_FLAG], + ['bindKey', BIND_KEY_FLAG], + ['curry', CURRY_FLAG], + ['curryRight', CURRY_RIGHT_FLAG], + ['flip', FLIP_FLAG], + ['partial', PARTIAL_FLAG], + ['partialRight', PARTIAL_RIGHT_FLAG], + ['rearg', REARG_FLAG] +]; + +/** + * Updates wrapper `details` based on `bitmask` flags. + * + * @private + * @returns {Array} details The details to modify. + * @param {number} bitmask The bitmask flags. See `createWrap` for more details. + * @returns {Array} Returns `details`. + */ +function updateWrapDetails(details, bitmask) { + arrayEach(wrapFlags, function(pair) { + var value = '_.' + pair[0]; + if ((bitmask & pair[1]) && !arrayIncludes(details, value)) { + details.push(value); + } + }); + return details.sort(); +} + +module.exports = updateWrapDetails; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/_wrapperClone.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/_wrapperClone.js new file mode 100644 index 0000000..7bb58a2 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/_wrapperClone.js @@ -0,0 +1,23 @@ +var LazyWrapper = require('./_LazyWrapper'), + LodashWrapper = require('./_LodashWrapper'), + copyArray = require('./_copyArray'); + +/** + * Creates a clone of `wrapper`. + * + * @private + * @param {Object} wrapper The wrapper to clone. + * @returns {Object} Returns the cloned wrapper. + */ +function wrapperClone(wrapper) { + if (wrapper instanceof LazyWrapper) { + return wrapper.clone(); + } + var result = new LodashWrapper(wrapper.__wrapped__, wrapper.__chain__); + result.__actions__ = copyArray(wrapper.__actions__); + result.__index__ = wrapper.__index__; + result.__values__ = wrapper.__values__; + return result; +} + +module.exports = wrapperClone; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/add.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/add.js new file mode 100644 index 0000000..f069515 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/add.js @@ -0,0 +1,22 @@ +var createMathOperation = require('./_createMathOperation'); + +/** + * Adds two numbers. + * + * @static + * @memberOf _ + * @since 3.4.0 + * @category Math + * @param {number} augend The first number in an addition. + * @param {number} addend The second number in an addition. + * @returns {number} Returns the total. + * @example + * + * _.add(6, 4); + * // => 10 + */ +var add = createMathOperation(function(augend, addend) { + return augend + addend; +}, 0); + +module.exports = add; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/after.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/after.js new file mode 100644 index 0000000..3900c97 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/after.js @@ -0,0 +1,42 @@ +var toInteger = require('./toInteger'); + +/** Error message constants. */ +var FUNC_ERROR_TEXT = 'Expected a function'; + +/** + * The opposite of `_.before`; this method creates a function that invokes + * `func` once it's called `n` or more times. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Function + * @param {number} n The number of calls before `func` is invoked. + * @param {Function} func The function to restrict. + * @returns {Function} Returns the new restricted function. + * @example + * + * var saves = ['profile', 'settings']; + * + * var done = _.after(saves.length, function() { + * console.log('done saving!'); + * }); + * + * _.forEach(saves, function(type) { + * asyncSave({ 'type': type, 'complete': done }); + * }); + * // => Logs 'done saving!' after the two async saves have completed. + */ +function after(n, func) { + if (typeof func != 'function') { + throw new TypeError(FUNC_ERROR_TEXT); + } + n = toInteger(n); + return function() { + if (--n < 1) { + return func.apply(this, arguments); + } + }; +} + +module.exports = after; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/array.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/array.js new file mode 100644 index 0000000..af688d3 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/array.js @@ -0,0 +1,67 @@ +module.exports = { + 'chunk': require('./chunk'), + 'compact': require('./compact'), + 'concat': require('./concat'), + 'difference': require('./difference'), + 'differenceBy': require('./differenceBy'), + 'differenceWith': require('./differenceWith'), + 'drop': require('./drop'), + 'dropRight': require('./dropRight'), + 'dropRightWhile': require('./dropRightWhile'), + 'dropWhile': require('./dropWhile'), + 'fill': require('./fill'), + 'findIndex': require('./findIndex'), + 'findLastIndex': require('./findLastIndex'), + 'first': require('./first'), + 'flatten': require('./flatten'), + 'flattenDeep': require('./flattenDeep'), + 'flattenDepth': require('./flattenDepth'), + 'fromPairs': require('./fromPairs'), + 'head': require('./head'), + 'indexOf': require('./indexOf'), + 'initial': require('./initial'), + 'intersection': require('./intersection'), + 'intersectionBy': require('./intersectionBy'), + 'intersectionWith': require('./intersectionWith'), + 'join': require('./join'), + 'last': require('./last'), + 'lastIndexOf': require('./lastIndexOf'), + 'nth': require('./nth'), + 'pull': require('./pull'), + 'pullAll': require('./pullAll'), + 'pullAllBy': require('./pullAllBy'), + 'pullAllWith': require('./pullAllWith'), + 'pullAt': require('./pullAt'), + 'remove': require('./remove'), + 'reverse': require('./reverse'), + 'slice': require('./slice'), + 'sortedIndex': require('./sortedIndex'), + 'sortedIndexBy': require('./sortedIndexBy'), + 'sortedIndexOf': require('./sortedIndexOf'), + 'sortedLastIndex': require('./sortedLastIndex'), + 'sortedLastIndexBy': require('./sortedLastIndexBy'), + 'sortedLastIndexOf': require('./sortedLastIndexOf'), + 'sortedUniq': require('./sortedUniq'), + 'sortedUniqBy': require('./sortedUniqBy'), + 'tail': require('./tail'), + 'take': require('./take'), + 'takeRight': require('./takeRight'), + 'takeRightWhile': require('./takeRightWhile'), + 'takeWhile': require('./takeWhile'), + 'union': require('./union'), + 'unionBy': require('./unionBy'), + 'unionWith': require('./unionWith'), + 'uniq': require('./uniq'), + 'uniqBy': require('./uniqBy'), + 'uniqWith': require('./uniqWith'), + 'unzip': require('./unzip'), + 'unzipWith': require('./unzipWith'), + 'without': require('./without'), + 'xor': require('./xor'), + 'xorBy': require('./xorBy'), + 'xorWith': require('./xorWith'), + 'zip': require('./zip'), + 'zipObject': require('./zipObject'), + 'zipObjectDeep': require('./zipObjectDeep'), + 'zipWith': require('./zipWith') +}; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/ary.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/ary.js new file mode 100644 index 0000000..c743b06 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/ary.js @@ -0,0 +1,29 @@ +var createWrap = require('./_createWrap'); + +/** Used to compose bitmasks for function metadata. */ +var ARY_FLAG = 128; + +/** + * Creates a function that invokes `func`, with up to `n` arguments, + * ignoring any additional arguments. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Function + * @param {Function} func The function to cap arguments for. + * @param {number} [n=func.length] The arity cap. + * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`. + * @returns {Function} Returns the new capped function. + * @example + * + * _.map(['6', '8', '10'], _.ary(parseInt, 1)); + * // => [6, 8, 10] + */ +function ary(func, n, guard) { + n = guard ? undefined : n; + n = (func && n == null) ? func.length : n; + return createWrap(func, ARY_FLAG, undefined, undefined, undefined, undefined, n); +} + +module.exports = ary; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/assign.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/assign.js new file mode 100644 index 0000000..909db26 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/assign.js @@ -0,0 +1,58 @@ +var assignValue = require('./_assignValue'), + copyObject = require('./_copyObject'), + createAssigner = require('./_createAssigner'), + isArrayLike = require('./isArrayLike'), + isPrototype = require('./_isPrototype'), + keys = require('./keys'); + +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** Used to check objects for own properties. */ +var hasOwnProperty = objectProto.hasOwnProperty; + +/** + * Assigns own enumerable string keyed properties of source objects to the + * destination object. Source objects are applied from left to right. + * Subsequent sources overwrite property assignments of previous sources. + * + * **Note:** This method mutates `object` and is loosely based on + * [`Object.assign`](https://mdn.io/Object/assign). + * + * @static + * @memberOf _ + * @since 0.10.0 + * @category Object + * @param {Object} object The destination object. + * @param {...Object} [sources] The source objects. + * @returns {Object} Returns `object`. + * @see _.assignIn + * @example + * + * function Foo() { + * this.a = 1; + * } + * + * function Bar() { + * this.c = 3; + * } + * + * Foo.prototype.b = 2; + * Bar.prototype.d = 4; + * + * _.assign({ 'a': 0 }, new Foo, new Bar); + * // => { 'a': 1, 'c': 3 } + */ +var assign = createAssigner(function(object, source) { + if (isPrototype(source) || isArrayLike(source)) { + copyObject(source, keys(source), object); + return; + } + for (var key in source) { + if (hasOwnProperty.call(source, key)) { + assignValue(object, key, source[key]); + } + } +}); + +module.exports = assign; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/assignIn.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/assignIn.js new file mode 100644 index 0000000..e663473 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/assignIn.js @@ -0,0 +1,40 @@ +var copyObject = require('./_copyObject'), + createAssigner = require('./_createAssigner'), + keysIn = require('./keysIn'); + +/** + * This method is like `_.assign` except that it iterates over own and + * inherited source properties. + * + * **Note:** This method mutates `object`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @alias extend + * @category Object + * @param {Object} object The destination object. + * @param {...Object} [sources] The source objects. + * @returns {Object} Returns `object`. + * @see _.assign + * @example + * + * function Foo() { + * this.a = 1; + * } + * + * function Bar() { + * this.c = 3; + * } + * + * Foo.prototype.b = 2; + * Bar.prototype.d = 4; + * + * _.assignIn({ 'a': 0 }, new Foo, new Bar); + * // => { 'a': 1, 'b': 2, 'c': 3, 'd': 4 } + */ +var assignIn = createAssigner(function(object, source) { + copyObject(source, keysIn(source), object); +}); + +module.exports = assignIn; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/assignInWith.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/assignInWith.js new file mode 100644 index 0000000..68fcc0b --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/assignInWith.js @@ -0,0 +1,38 @@ +var copyObject = require('./_copyObject'), + createAssigner = require('./_createAssigner'), + keysIn = require('./keysIn'); + +/** + * This method is like `_.assignIn` except that it accepts `customizer` + * which is invoked to produce the assigned values. If `customizer` returns + * `undefined`, assignment is handled by the method instead. The `customizer` + * is invoked with five arguments: (objValue, srcValue, key, object, source). + * + * **Note:** This method mutates `object`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @alias extendWith + * @category Object + * @param {Object} object The destination object. + * @param {...Object} sources The source objects. + * @param {Function} [customizer] The function to customize assigned values. + * @returns {Object} Returns `object`. + * @see _.assignWith + * @example + * + * function customizer(objValue, srcValue) { + * return _.isUndefined(objValue) ? srcValue : objValue; + * } + * + * var defaults = _.partialRight(_.assignInWith, customizer); + * + * defaults({ 'a': 1 }, { 'b': 2 }, { 'a': 3 }); + * // => { 'a': 1, 'b': 2 } + */ +var assignInWith = createAssigner(function(object, source, srcIndex, customizer) { + copyObject(source, keysIn(source), object, customizer); +}); + +module.exports = assignInWith; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/assignWith.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/assignWith.js new file mode 100644 index 0000000..7dc6c76 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/assignWith.js @@ -0,0 +1,37 @@ +var copyObject = require('./_copyObject'), + createAssigner = require('./_createAssigner'), + keys = require('./keys'); + +/** + * This method is like `_.assign` except that it accepts `customizer` + * which is invoked to produce the assigned values. If `customizer` returns + * `undefined`, assignment is handled by the method instead. The `customizer` + * is invoked with five arguments: (objValue, srcValue, key, object, source). + * + * **Note:** This method mutates `object`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Object + * @param {Object} object The destination object. + * @param {...Object} sources The source objects. + * @param {Function} [customizer] The function to customize assigned values. + * @returns {Object} Returns `object`. + * @see _.assignInWith + * @example + * + * function customizer(objValue, srcValue) { + * return _.isUndefined(objValue) ? srcValue : objValue; + * } + * + * var defaults = _.partialRight(_.assignWith, customizer); + * + * defaults({ 'a': 1 }, { 'b': 2 }, { 'a': 3 }); + * // => { 'a': 1, 'b': 2 } + */ +var assignWith = createAssigner(function(object, source, srcIndex, customizer) { + copyObject(source, keys(source), object, customizer); +}); + +module.exports = assignWith; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/at.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/at.js new file mode 100644 index 0000000..05e9482 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/at.js @@ -0,0 +1,23 @@ +var baseAt = require('./_baseAt'), + flatRest = require('./_flatRest'); + +/** + * Creates an array of values corresponding to `paths` of `object`. + * + * @static + * @memberOf _ + * @since 1.0.0 + * @category Object + * @param {Object} object The object to iterate over. + * @param {...(string|string[])} [paths] The property paths of elements to pick. + * @returns {Array} Returns the picked values. + * @example + * + * var object = { 'a': [{ 'b': { 'c': 3 } }, 4] }; + * + * _.at(object, ['a[0].b.c', 'a[1]']); + * // => [3, 4] + */ +var at = flatRest(baseAt); + +module.exports = at; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/attempt.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/attempt.js new file mode 100644 index 0000000..624d015 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/attempt.js @@ -0,0 +1,35 @@ +var apply = require('./_apply'), + baseRest = require('./_baseRest'), + isError = require('./isError'); + +/** + * Attempts to invoke `func`, returning either the result or the caught error + * object. Any additional arguments are provided to `func` when it's invoked. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Util + * @param {Function} func The function to attempt. + * @param {...*} [args] The arguments to invoke `func` with. + * @returns {*} Returns the `func` result or error object. + * @example + * + * // Avoid throwing errors for invalid selectors. + * var elements = _.attempt(function(selector) { + * return document.querySelectorAll(selector); + * }, '>_>'); + * + * if (_.isError(elements)) { + * elements = []; + * } + */ +var attempt = baseRest(function(func, args) { + try { + return apply(func, undefined, args); + } catch (e) { + return isError(e) ? e : new Error(e); + } +}); + +module.exports = attempt; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/before.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/before.js new file mode 100644 index 0000000..a3e0a16 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/before.js @@ -0,0 +1,40 @@ +var toInteger = require('./toInteger'); + +/** Error message constants. */ +var FUNC_ERROR_TEXT = 'Expected a function'; + +/** + * Creates a function that invokes `func`, with the `this` binding and arguments + * of the created function, while it's called less than `n` times. Subsequent + * calls to the created function return the result of the last `func` invocation. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Function + * @param {number} n The number of calls at which `func` is no longer invoked. + * @param {Function} func The function to restrict. + * @returns {Function} Returns the new restricted function. + * @example + * + * jQuery(element).on('click', _.before(5, addContactToList)); + * // => Allows adding up to 4 contacts to the list. + */ +function before(n, func) { + var result; + if (typeof func != 'function') { + throw new TypeError(FUNC_ERROR_TEXT); + } + n = toInteger(n); + return function() { + if (--n > 0) { + result = func.apply(this, arguments); + } + if (n <= 1) { + func = undefined; + } + return result; + }; +} + +module.exports = before; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/bind.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/bind.js new file mode 100644 index 0000000..eac913b --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/bind.js @@ -0,0 +1,57 @@ +var baseRest = require('./_baseRest'), + createWrap = require('./_createWrap'), + getHolder = require('./_getHolder'), + replaceHolders = require('./_replaceHolders'); + +/** Used to compose bitmasks for function metadata. */ +var BIND_FLAG = 1, + PARTIAL_FLAG = 32; + +/** + * Creates a function that invokes `func` with the `this` binding of `thisArg` + * and `partials` prepended to the arguments it receives. + * + * The `_.bind.placeholder` value, which defaults to `_` in monolithic builds, + * may be used as a placeholder for partially applied arguments. + * + * **Note:** Unlike native `Function#bind`, this method doesn't set the "length" + * property of bound functions. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Function + * @param {Function} func The function to bind. + * @param {*} thisArg The `this` binding of `func`. + * @param {...*} [partials] The arguments to be partially applied. + * @returns {Function} Returns the new bound function. + * @example + * + * function greet(greeting, punctuation) { + * return greeting + ' ' + this.user + punctuation; + * } + * + * var object = { 'user': 'fred' }; + * + * var bound = _.bind(greet, object, 'hi'); + * bound('!'); + * // => 'hi fred!' + * + * // Bound with placeholders. + * var bound = _.bind(greet, object, _, '!'); + * bound('hi'); + * // => 'hi fred!' + */ +var bind = baseRest(function(func, thisArg, partials) { + var bitmask = BIND_FLAG; + if (partials.length) { + var holders = replaceHolders(partials, getHolder(bind)); + bitmask |= PARTIAL_FLAG; + } + return createWrap(func, bitmask, thisArg, partials, holders); +}); + +// Assign default placeholders. +bind.placeholder = {}; + +module.exports = bind; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/bindAll.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/bindAll.js new file mode 100644 index 0000000..a35706d --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/bindAll.js @@ -0,0 +1,41 @@ +var arrayEach = require('./_arrayEach'), + baseAssignValue = require('./_baseAssignValue'), + bind = require('./bind'), + flatRest = require('./_flatRest'), + toKey = require('./_toKey'); + +/** + * Binds methods of an object to the object itself, overwriting the existing + * method. + * + * **Note:** This method doesn't set the "length" property of bound functions. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Util + * @param {Object} object The object to bind and assign the bound methods to. + * @param {...(string|string[])} methodNames The object method names to bind. + * @returns {Object} Returns `object`. + * @example + * + * var view = { + * 'label': 'docs', + * 'click': function() { + * console.log('clicked ' + this.label); + * } + * }; + * + * _.bindAll(view, ['click']); + * jQuery(element).on('click', view.click); + * // => Logs 'clicked docs' when clicked. + */ +var bindAll = flatRest(function(object, methodNames) { + arrayEach(methodNames, function(key) { + key = toKey(key); + baseAssignValue(object, key, bind(object[key], object)); + }); + return object; +}); + +module.exports = bindAll; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/bindKey.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/bindKey.js new file mode 100644 index 0000000..8824440 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/bindKey.js @@ -0,0 +1,68 @@ +var baseRest = require('./_baseRest'), + createWrap = require('./_createWrap'), + getHolder = require('./_getHolder'), + replaceHolders = require('./_replaceHolders'); + +/** Used to compose bitmasks for function metadata. */ +var BIND_FLAG = 1, + BIND_KEY_FLAG = 2, + PARTIAL_FLAG = 32; + +/** + * Creates a function that invokes the method at `object[key]` with `partials` + * prepended to the arguments it receives. + * + * This method differs from `_.bind` by allowing bound functions to reference + * methods that may be redefined or don't yet exist. See + * [Peter Michaux's article](http://peter.michaux.ca/articles/lazy-function-definition-pattern) + * for more details. + * + * The `_.bindKey.placeholder` value, which defaults to `_` in monolithic + * builds, may be used as a placeholder for partially applied arguments. + * + * @static + * @memberOf _ + * @since 0.10.0 + * @category Function + * @param {Object} object The object to invoke the method on. + * @param {string} key The key of the method. + * @param {...*} [partials] The arguments to be partially applied. + * @returns {Function} Returns the new bound function. + * @example + * + * var object = { + * 'user': 'fred', + * 'greet': function(greeting, punctuation) { + * return greeting + ' ' + this.user + punctuation; + * } + * }; + * + * var bound = _.bindKey(object, 'greet', 'hi'); + * bound('!'); + * // => 'hi fred!' + * + * object.greet = function(greeting, punctuation) { + * return greeting + 'ya ' + this.user + punctuation; + * }; + * + * bound('!'); + * // => 'hiya fred!' + * + * // Bound with placeholders. + * var bound = _.bindKey(object, 'greet', _, '!'); + * bound('hi'); + * // => 'hiya fred!' + */ +var bindKey = baseRest(function(object, key, partials) { + var bitmask = BIND_FLAG | BIND_KEY_FLAG; + if (partials.length) { + var holders = replaceHolders(partials, getHolder(bindKey)); + bitmask |= PARTIAL_FLAG; + } + return createWrap(key, bitmask, object, partials, holders); +}); + +// Assign default placeholders. +bindKey.placeholder = {}; + +module.exports = bindKey; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/camelCase.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/camelCase.js new file mode 100644 index 0000000..d7390de --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/camelCase.js @@ -0,0 +1,29 @@ +var capitalize = require('./capitalize'), + createCompounder = require('./_createCompounder'); + +/** + * Converts `string` to [camel case](https://en.wikipedia.org/wiki/CamelCase). + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category String + * @param {string} [string=''] The string to convert. + * @returns {string} Returns the camel cased string. + * @example + * + * _.camelCase('Foo Bar'); + * // => 'fooBar' + * + * _.camelCase('--foo-bar--'); + * // => 'fooBar' + * + * _.camelCase('__FOO_BAR__'); + * // => 'fooBar' + */ +var camelCase = createCompounder(function(result, word, index) { + word = word.toLowerCase(); + return result + (index ? capitalize(word) : word); +}); + +module.exports = camelCase; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/capitalize.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/capitalize.js new file mode 100644 index 0000000..3e1600e --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/capitalize.js @@ -0,0 +1,23 @@ +var toString = require('./toString'), + upperFirst = require('./upperFirst'); + +/** + * Converts the first character of `string` to upper case and the remaining + * to lower case. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category String + * @param {string} [string=''] The string to capitalize. + * @returns {string} Returns the capitalized string. + * @example + * + * _.capitalize('FRED'); + * // => 'Fred' + */ +function capitalize(string) { + return upperFirst(toString(string).toLowerCase()); +} + +module.exports = capitalize; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/castArray.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/castArray.js new file mode 100644 index 0000000..e470bdb --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/castArray.js @@ -0,0 +1,44 @@ +var isArray = require('./isArray'); + +/** + * Casts `value` as an array if it's not one. + * + * @static + * @memberOf _ + * @since 4.4.0 + * @category Lang + * @param {*} value The value to inspect. + * @returns {Array} Returns the cast array. + * @example + * + * _.castArray(1); + * // => [1] + * + * _.castArray({ 'a': 1 }); + * // => [{ 'a': 1 }] + * + * _.castArray('abc'); + * // => ['abc'] + * + * _.castArray(null); + * // => [null] + * + * _.castArray(undefined); + * // => [undefined] + * + * _.castArray(); + * // => [] + * + * var array = [1, 2, 3]; + * console.log(_.castArray(array) === array); + * // => true + */ +function castArray() { + if (!arguments.length) { + return []; + } + var value = arguments[0]; + return isArray(value) ? value : [value]; +} + +module.exports = castArray; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/ceil.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/ceil.js new file mode 100644 index 0000000..56c8722 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/ceil.js @@ -0,0 +1,26 @@ +var createRound = require('./_createRound'); + +/** + * Computes `number` rounded up to `precision`. + * + * @static + * @memberOf _ + * @since 3.10.0 + * @category Math + * @param {number} number The number to round up. + * @param {number} [precision=0] The precision to round up to. + * @returns {number} Returns the rounded up number. + * @example + * + * _.ceil(4.006); + * // => 5 + * + * _.ceil(6.004, 2); + * // => 6.01 + * + * _.ceil(6040, -2); + * // => 6100 + */ +var ceil = createRound('ceil'); + +module.exports = ceil; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/chain.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/chain.js new file mode 100644 index 0000000..f6cd647 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/chain.js @@ -0,0 +1,38 @@ +var lodash = require('./wrapperLodash'); + +/** + * Creates a `lodash` wrapper instance that wraps `value` with explicit method + * chain sequences enabled. The result of such sequences must be unwrapped + * with `_#value`. + * + * @static + * @memberOf _ + * @since 1.3.0 + * @category Seq + * @param {*} value The value to wrap. + * @returns {Object} Returns the new `lodash` wrapper instance. + * @example + * + * var users = [ + * { 'user': 'barney', 'age': 36 }, + * { 'user': 'fred', 'age': 40 }, + * { 'user': 'pebbles', 'age': 1 } + * ]; + * + * var youngest = _ + * .chain(users) + * .sortBy('age') + * .map(function(o) { + * return o.user + ' is ' + o.age; + * }) + * .head() + * .value(); + * // => 'pebbles is 1' + */ +function chain(value) { + var result = lodash(value); + result.__chain__ = true; + return result; +} + +module.exports = chain; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/chunk.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/chunk.js new file mode 100644 index 0000000..356510f --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/chunk.js @@ -0,0 +1,50 @@ +var baseSlice = require('./_baseSlice'), + isIterateeCall = require('./_isIterateeCall'), + toInteger = require('./toInteger'); + +/* Built-in method references for those with the same name as other `lodash` methods. */ +var nativeCeil = Math.ceil, + nativeMax = Math.max; + +/** + * Creates an array of elements split into groups the length of `size`. + * If `array` can't be split evenly, the final chunk will be the remaining + * elements. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Array + * @param {Array} array The array to process. + * @param {number} [size=1] The length of each chunk + * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`. + * @returns {Array} Returns the new array of chunks. + * @example + * + * _.chunk(['a', 'b', 'c', 'd'], 2); + * // => [['a', 'b'], ['c', 'd']] + * + * _.chunk(['a', 'b', 'c', 'd'], 3); + * // => [['a', 'b', 'c'], ['d']] + */ +function chunk(array, size, guard) { + if ((guard ? isIterateeCall(array, size, guard) : size === undefined)) { + size = 1; + } else { + size = nativeMax(toInteger(size), 0); + } + var length = array ? array.length : 0; + if (!length || size < 1) { + return []; + } + var index = 0, + resIndex = 0, + result = Array(nativeCeil(length / size)); + + while (index < length) { + result[resIndex++] = baseSlice(array, index, (index += size)); + } + return result; +} + +module.exports = chunk; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/clamp.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/clamp.js new file mode 100644 index 0000000..91a72c9 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/clamp.js @@ -0,0 +1,39 @@ +var baseClamp = require('./_baseClamp'), + toNumber = require('./toNumber'); + +/** + * Clamps `number` within the inclusive `lower` and `upper` bounds. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Number + * @param {number} number The number to clamp. + * @param {number} [lower] The lower bound. + * @param {number} upper The upper bound. + * @returns {number} Returns the clamped number. + * @example + * + * _.clamp(-10, -5, 5); + * // => -5 + * + * _.clamp(10, -5, 5); + * // => 5 + */ +function clamp(number, lower, upper) { + if (upper === undefined) { + upper = lower; + lower = undefined; + } + if (upper !== undefined) { + upper = toNumber(upper); + upper = upper === upper ? upper : 0; + } + if (lower !== undefined) { + lower = toNumber(lower); + lower = lower === lower ? lower : 0; + } + return baseClamp(toNumber(number), lower, upper); +} + +module.exports = clamp; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/clone.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/clone.js new file mode 100644 index 0000000..d02395e --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/clone.js @@ -0,0 +1,33 @@ +var baseClone = require('./_baseClone'); + +/** + * Creates a shallow clone of `value`. + * + * **Note:** This method is loosely based on the + * [structured clone algorithm](https://mdn.io/Structured_clone_algorithm) + * and supports cloning arrays, array buffers, booleans, date objects, maps, + * numbers, `Object` objects, regexes, sets, strings, symbols, and typed + * arrays. The own enumerable properties of `arguments` objects are cloned + * as plain objects. An empty object is returned for uncloneable values such + * as error objects, functions, DOM nodes, and WeakMaps. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to clone. + * @returns {*} Returns the cloned value. + * @see _.cloneDeep + * @example + * + * var objects = [{ 'a': 1 }, { 'b': 2 }]; + * + * var shallow = _.clone(objects); + * console.log(shallow[0] === objects[0]); + * // => true + */ +function clone(value) { + return baseClone(value, false, true); +} + +module.exports = clone; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/cloneDeep.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/cloneDeep.js new file mode 100644 index 0000000..94efce1 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/cloneDeep.js @@ -0,0 +1,25 @@ +var baseClone = require('./_baseClone'); + +/** + * This method is like `_.clone` except that it recursively clones `value`. + * + * @static + * @memberOf _ + * @since 1.0.0 + * @category Lang + * @param {*} value The value to recursively clone. + * @returns {*} Returns the deep cloned value. + * @see _.clone + * @example + * + * var objects = [{ 'a': 1 }, { 'b': 2 }]; + * + * var deep = _.cloneDeep(objects); + * console.log(deep[0] === objects[0]); + * // => false + */ +function cloneDeep(value) { + return baseClone(value, true, true); +} + +module.exports = cloneDeep; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/cloneDeepWith.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/cloneDeepWith.js new file mode 100644 index 0000000..4a345fb --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/cloneDeepWith.js @@ -0,0 +1,35 @@ +var baseClone = require('./_baseClone'); + +/** + * This method is like `_.cloneWith` except that it recursively clones `value`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to recursively clone. + * @param {Function} [customizer] The function to customize cloning. + * @returns {*} Returns the deep cloned value. + * @see _.cloneWith + * @example + * + * function customizer(value) { + * if (_.isElement(value)) { + * return value.cloneNode(true); + * } + * } + * + * var el = _.cloneDeepWith(document.body, customizer); + * + * console.log(el === document.body); + * // => false + * console.log(el.nodeName); + * // => 'BODY' + * console.log(el.childNodes.length); + * // => 20 + */ +function cloneDeepWith(value, customizer) { + return baseClone(value, true, true, customizer); +} + +module.exports = cloneDeepWith; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/cloneWith.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/cloneWith.js new file mode 100644 index 0000000..c85f573 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/cloneWith.js @@ -0,0 +1,38 @@ +var baseClone = require('./_baseClone'); + +/** + * This method is like `_.clone` except that it accepts `customizer` which + * is invoked to produce the cloned value. If `customizer` returns `undefined`, + * cloning is handled by the method instead. The `customizer` is invoked with + * up to four arguments; (value [, index|key, object, stack]). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to clone. + * @param {Function} [customizer] The function to customize cloning. + * @returns {*} Returns the cloned value. + * @see _.cloneDeepWith + * @example + * + * function customizer(value) { + * if (_.isElement(value)) { + * return value.cloneNode(false); + * } + * } + * + * var el = _.cloneWith(document.body, customizer); + * + * console.log(el === document.body); + * // => false + * console.log(el.nodeName); + * // => 'BODY' + * console.log(el.childNodes.length); + * // => 0 + */ +function cloneWith(value, customizer) { + return baseClone(value, false, true, customizer); +} + +module.exports = cloneWith; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/collection.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/collection.js new file mode 100644 index 0000000..77fe837 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/collection.js @@ -0,0 +1,30 @@ +module.exports = { + 'countBy': require('./countBy'), + 'each': require('./each'), + 'eachRight': require('./eachRight'), + 'every': require('./every'), + 'filter': require('./filter'), + 'find': require('./find'), + 'findLast': require('./findLast'), + 'flatMap': require('./flatMap'), + 'flatMapDeep': require('./flatMapDeep'), + 'flatMapDepth': require('./flatMapDepth'), + 'forEach': require('./forEach'), + 'forEachRight': require('./forEachRight'), + 'groupBy': require('./groupBy'), + 'includes': require('./includes'), + 'invokeMap': require('./invokeMap'), + 'keyBy': require('./keyBy'), + 'map': require('./map'), + 'orderBy': require('./orderBy'), + 'partition': require('./partition'), + 'reduce': require('./reduce'), + 'reduceRight': require('./reduceRight'), + 'reject': require('./reject'), + 'sample': require('./sample'), + 'sampleSize': require('./sampleSize'), + 'shuffle': require('./shuffle'), + 'size': require('./size'), + 'some': require('./some'), + 'sortBy': require('./sortBy') +}; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/commit.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/commit.js new file mode 100644 index 0000000..fe4db71 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/commit.js @@ -0,0 +1,33 @@ +var LodashWrapper = require('./_LodashWrapper'); + +/** + * Executes the chain sequence and returns the wrapped result. + * + * @name commit + * @memberOf _ + * @since 3.2.0 + * @category Seq + * @returns {Object} Returns the new `lodash` wrapper instance. + * @example + * + * var array = [1, 2]; + * var wrapped = _(array).push(3); + * + * console.log(array); + * // => [1, 2] + * + * wrapped = wrapped.commit(); + * console.log(array); + * // => [1, 2, 3] + * + * wrapped.last(); + * // => 3 + * + * console.log(array); + * // => [1, 2, 3] + */ +function wrapperCommit() { + return new LodashWrapper(this.value(), this.__chain__); +} + +module.exports = wrapperCommit; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/compact.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/compact.js new file mode 100644 index 0000000..790f311 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/compact.js @@ -0,0 +1,31 @@ +/** + * Creates an array with all falsey values removed. The values `false`, `null`, + * `0`, `""`, `undefined`, and `NaN` are falsey. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Array + * @param {Array} array The array to compact. + * @returns {Array} Returns the new array of filtered values. + * @example + * + * _.compact([0, 1, false, 2, '', 3]); + * // => [1, 2, 3] + */ +function compact(array) { + var index = -1, + length = array ? array.length : 0, + resIndex = 0, + result = []; + + while (++index < length) { + var value = array[index]; + if (value) { + result[resIndex++] = value; + } + } + return result; +} + +module.exports = compact; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/concat.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/concat.js new file mode 100644 index 0000000..1da48a4 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/concat.js @@ -0,0 +1,43 @@ +var arrayPush = require('./_arrayPush'), + baseFlatten = require('./_baseFlatten'), + copyArray = require('./_copyArray'), + isArray = require('./isArray'); + +/** + * Creates a new array concatenating `array` with any additional arrays + * and/or values. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {Array} array The array to concatenate. + * @param {...*} [values] The values to concatenate. + * @returns {Array} Returns the new concatenated array. + * @example + * + * var array = [1]; + * var other = _.concat(array, 2, [3], [[4]]); + * + * console.log(other); + * // => [1, 2, 3, [4]] + * + * console.log(array); + * // => [1] + */ +function concat() { + var length = arguments.length; + if (!length) { + return []; + } + var args = Array(length - 1), + array = arguments[0], + index = length; + + while (index--) { + args[index - 1] = arguments[index]; + } + return arrayPush(isArray(array) ? copyArray(array) : [array], baseFlatten(args, 1)); +} + +module.exports = concat; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/cond.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/cond.js new file mode 100644 index 0000000..91515c1 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/cond.js @@ -0,0 +1,60 @@ +var apply = require('./_apply'), + arrayMap = require('./_arrayMap'), + baseIteratee = require('./_baseIteratee'), + baseRest = require('./_baseRest'); + +/** Error message constants. */ +var FUNC_ERROR_TEXT = 'Expected a function'; + +/** + * Creates a function that iterates over `pairs` and invokes the corresponding + * function of the first predicate to return truthy. The predicate-function + * pairs are invoked with the `this` binding and arguments of the created + * function. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Util + * @param {Array} pairs The predicate-function pairs. + * @returns {Function} Returns the new composite function. + * @example + * + * var func = _.cond([ + * [_.matches({ 'a': 1 }), _.constant('matches A')], + * [_.conforms({ 'b': _.isNumber }), _.constant('matches B')], + * [_.stubTrue, _.constant('no match')] + * ]); + * + * func({ 'a': 1, 'b': 2 }); + * // => 'matches A' + * + * func({ 'a': 0, 'b': 1 }); + * // => 'matches B' + * + * func({ 'a': '1', 'b': '2' }); + * // => 'no match' + */ +function cond(pairs) { + var length = pairs ? pairs.length : 0, + toIteratee = baseIteratee; + + pairs = !length ? [] : arrayMap(pairs, function(pair) { + if (typeof pair[1] != 'function') { + throw new TypeError(FUNC_ERROR_TEXT); + } + return [toIteratee(pair[0]), pair[1]]; + }); + + return baseRest(function(args) { + var index = -1; + while (++index < length) { + var pair = pairs[index]; + if (apply(pair[0], this, args)) { + return apply(pair[1], this, args); + } + } + }); +} + +module.exports = cond; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/conforms.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/conforms.js new file mode 100644 index 0000000..e4c537e --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/conforms.js @@ -0,0 +1,32 @@ +var baseClone = require('./_baseClone'), + baseConforms = require('./_baseConforms'); + +/** + * Creates a function that invokes the predicate properties of `source` with + * the corresponding property values of a given object, returning `true` if + * all predicates return truthy, else `false`. + * + * **Note:** The created function is equivalent to `_.conformsTo` with + * `source` partially applied. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Util + * @param {Object} source The object of property predicates to conform to. + * @returns {Function} Returns the new spec function. + * @example + * + * var objects = [ + * { 'a': 2, 'b': 1 }, + * { 'a': 1, 'b': 2 } + * ]; + * + * _.filter(objects, _.conforms({ 'b': function(n) { return n > 1; } })); + * // => [{ 'a': 1, 'b': 2 }] + */ +function conforms(source) { + return baseConforms(baseClone(source, true)); +} + +module.exports = conforms; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/conformsTo.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/conformsTo.js new file mode 100644 index 0000000..b8a93eb --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/conformsTo.js @@ -0,0 +1,32 @@ +var baseConformsTo = require('./_baseConformsTo'), + keys = require('./keys'); + +/** + * Checks if `object` conforms to `source` by invoking the predicate + * properties of `source` with the corresponding property values of `object`. + * + * **Note:** This method is equivalent to `_.conforms` when `source` is + * partially applied. + * + * @static + * @memberOf _ + * @since 4.14.0 + * @category Lang + * @param {Object} object The object to inspect. + * @param {Object} source The object of property predicates to conform to. + * @returns {boolean} Returns `true` if `object` conforms, else `false`. + * @example + * + * var object = { 'a': 1, 'b': 2 }; + * + * _.conformsTo(object, { 'b': function(n) { return n > 1; } }); + * // => true + * + * _.conformsTo(object, { 'b': function(n) { return n > 2; } }); + * // => false + */ +function conformsTo(object, source) { + return source == null || baseConformsTo(object, source, keys(source)); +} + +module.exports = conformsTo; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/constant.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/constant.js new file mode 100644 index 0000000..655ece3 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/constant.js @@ -0,0 +1,26 @@ +/** + * Creates a function that returns `value`. + * + * @static + * @memberOf _ + * @since 2.4.0 + * @category Util + * @param {*} value The value to return from the new function. + * @returns {Function} Returns the new constant function. + * @example + * + * var objects = _.times(2, _.constant({ 'a': 1 })); + * + * console.log(objects); + * // => [{ 'a': 1 }, { 'a': 1 }] + * + * console.log(objects[0] === objects[1]); + * // => true + */ +function constant(value) { + return function() { + return value; + }; +} + +module.exports = constant; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/core.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/core.js new file mode 100644 index 0000000..c891e78 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/core.js @@ -0,0 +1,3831 @@ +/** + * @license + * lodash (Custom Build) + * Build: `lodash core -o ./dist/lodash.core.js` + * Copyright jQuery Foundation and other contributors + * Released under MIT license + * Based on Underscore.js 1.8.3 + * Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors + */ +;(function() { + + /** Used as a safe reference for `undefined` in pre-ES5 environments. */ + var undefined; + + /** Used as the semantic version number. */ + var VERSION = '4.16.4'; + + /** Error message constants. */ + var FUNC_ERROR_TEXT = 'Expected a function'; + + /** Used to compose bitmasks for function metadata. */ + var BIND_FLAG = 1, + PARTIAL_FLAG = 32; + + /** Used to compose bitmasks for comparison styles. */ + var UNORDERED_COMPARE_FLAG = 1, + PARTIAL_COMPARE_FLAG = 2; + + /** Used as references for various `Number` constants. */ + var INFINITY = 1 / 0, + MAX_SAFE_INTEGER = 9007199254740991; + + /** `Object#toString` result references. */ + var argsTag = '[object Arguments]', + arrayTag = '[object Array]', + boolTag = '[object Boolean]', + dateTag = '[object Date]', + errorTag = '[object Error]', + funcTag = '[object Function]', + genTag = '[object GeneratorFunction]', + numberTag = '[object Number]', + objectTag = '[object Object]', + proxyTag = '[object Proxy]', + regexpTag = '[object RegExp]', + stringTag = '[object String]'; + + /** Used to match HTML entities and HTML characters. */ + var reUnescapedHtml = /[&<>"']/g, + reHasUnescapedHtml = RegExp(reUnescapedHtml.source); + + /** Used to map characters to HTML entities. */ + var htmlEscapes = { + '&': '&', + '<': '<', + '>': '>', + '"': '"', + "'": ''' + }; + + /** Detect free variable `global` from Node.js. */ + var freeGlobal = typeof global == 'object' && global && global.Object === Object && global; + + /** Detect free variable `self`. */ + var freeSelf = typeof self == 'object' && self && self.Object === Object && self; + + /** Used as a reference to the global object. */ + var root = freeGlobal || freeSelf || Function('return this')(); + + /** Detect free variable `exports`. */ + var freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports; + + /** Detect free variable `module`. */ + var freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module; + + /*--------------------------------------------------------------------------*/ + + /** + * Appends the elements of `values` to `array`. + * + * @private + * @param {Array} array The array to modify. + * @param {Array} values The values to append. + * @returns {Array} Returns `array`. + */ + function arrayPush(array, values) { + array.push.apply(array, values); + return array; + } + + /** + * The base implementation of `_.findIndex` and `_.findLastIndex` without + * support for iteratee shorthands. + * + * @private + * @param {Array} array The array to inspect. + * @param {Function} predicate The function invoked per iteration. + * @param {number} fromIndex The index to search from. + * @param {boolean} [fromRight] Specify iterating from right to left. + * @returns {number} Returns the index of the matched value, else `-1`. + */ + function baseFindIndex(array, predicate, fromIndex, fromRight) { + var length = array.length, + index = fromIndex + (fromRight ? 1 : -1); + + while ((fromRight ? index-- : ++index < length)) { + if (predicate(array[index], index, array)) { + return index; + } + } + return -1; + } + + /** + * The base implementation of `_.property` without support for deep paths. + * + * @private + * @param {string} key The key of the property to get. + * @returns {Function} Returns the new accessor function. + */ + function baseProperty(key) { + return function(object) { + return object == null ? undefined : object[key]; + }; + } + + /** + * The base implementation of `_.propertyOf` without support for deep paths. + * + * @private + * @param {Object} object The object to query. + * @returns {Function} Returns the new accessor function. + */ + function basePropertyOf(object) { + return function(key) { + return object == null ? undefined : object[key]; + }; + } + + /** + * The base implementation of `_.reduce` and `_.reduceRight`, without support + * for iteratee shorthands, which iterates over `collection` using `eachFunc`. + * + * @private + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @param {*} accumulator The initial value. + * @param {boolean} initAccum Specify using the first or last element of + * `collection` as the initial value. + * @param {Function} eachFunc The function to iterate over `collection`. + * @returns {*} Returns the accumulated value. + */ + function baseReduce(collection, iteratee, accumulator, initAccum, eachFunc) { + eachFunc(collection, function(value, index, collection) { + accumulator = initAccum + ? (initAccum = false, value) + : iteratee(accumulator, value, index, collection); + }); + return accumulator; + } + + /** + * The base implementation of `_.values` and `_.valuesIn` which creates an + * array of `object` property values corresponding to the property names + * of `props`. + * + * @private + * @param {Object} object The object to query. + * @param {Array} props The property names to get values for. + * @returns {Object} Returns the array of property values. + */ + function baseValues(object, props) { + return baseMap(props, function(key) { + return object[key]; + }); + } + + /** + * Used by `_.escape` to convert characters to HTML entities. + * + * @private + * @param {string} chr The matched character to escape. + * @returns {string} Returns the escaped character. + */ + var escapeHtmlChar = basePropertyOf(htmlEscapes); + + /** + * Creates a unary function that invokes `func` with its argument transformed. + * + * @private + * @param {Function} func The function to wrap. + * @param {Function} transform The argument transform. + * @returns {Function} Returns the new function. + */ + function overArg(func, transform) { + return function(arg) { + return func(transform(arg)); + }; + } + + /*--------------------------------------------------------------------------*/ + + /** Used for built-in method references. */ + var arrayProto = Array.prototype, + objectProto = Object.prototype; + + /** Used to check objects for own properties. */ + var hasOwnProperty = objectProto.hasOwnProperty; + + /** Used to generate unique IDs. */ + var idCounter = 0; + + /** + * Used to resolve the + * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring) + * of values. + */ + var objectToString = objectProto.toString; + + /** Used to restore the original `_` reference in `_.noConflict`. */ + var oldDash = root._; + + /** Built-in value references. */ + var objectCreate = Object.create, + propertyIsEnumerable = objectProto.propertyIsEnumerable; + + /* Built-in method references for those with the same name as other `lodash` methods. */ + var nativeIsFinite = root.isFinite, + nativeKeys = overArg(Object.keys, Object), + nativeMax = Math.max; + + /*------------------------------------------------------------------------*/ + + /** + * Creates a `lodash` object which wraps `value` to enable implicit method + * chain sequences. Methods that operate on and return arrays, collections, + * and functions can be chained together. Methods that retrieve a single value + * or may return a primitive value will automatically end the chain sequence + * and return the unwrapped value. Otherwise, the value must be unwrapped + * with `_#value`. + * + * Explicit chain sequences, which must be unwrapped with `_#value`, may be + * enabled using `_.chain`. + * + * The execution of chained methods is lazy, that is, it's deferred until + * `_#value` is implicitly or explicitly called. + * + * Lazy evaluation allows several methods to support shortcut fusion. + * Shortcut fusion is an optimization to merge iteratee calls; this avoids + * the creation of intermediate arrays and can greatly reduce the number of + * iteratee executions. Sections of a chain sequence qualify for shortcut + * fusion if the section is applied to an array of at least `200` elements + * and any iteratees accept only one argument. The heuristic for whether a + * section qualifies for shortcut fusion is subject to change. + * + * Chaining is supported in custom builds as long as the `_#value` method is + * directly or indirectly included in the build. + * + * In addition to lodash methods, wrappers have `Array` and `String` methods. + * + * The wrapper `Array` methods are: + * `concat`, `join`, `pop`, `push`, `shift`, `sort`, `splice`, and `unshift` + * + * The wrapper `String` methods are: + * `replace` and `split` + * + * The wrapper methods that support shortcut fusion are: + * `at`, `compact`, `drop`, `dropRight`, `dropWhile`, `filter`, `find`, + * `findLast`, `head`, `initial`, `last`, `map`, `reject`, `reverse`, `slice`, + * `tail`, `take`, `takeRight`, `takeRightWhile`, `takeWhile`, and `toArray` + * + * The chainable wrapper methods are: + * `after`, `ary`, `assign`, `assignIn`, `assignInWith`, `assignWith`, `at`, + * `before`, `bind`, `bindAll`, `bindKey`, `castArray`, `chain`, `chunk`, + * `commit`, `compact`, `concat`, `conforms`, `constant`, `countBy`, `create`, + * `curry`, `debounce`, `defaults`, `defaultsDeep`, `defer`, `delay`, + * `difference`, `differenceBy`, `differenceWith`, `drop`, `dropRight`, + * `dropRightWhile`, `dropWhile`, `extend`, `extendWith`, `fill`, `filter`, + * `flatMap`, `flatMapDeep`, `flatMapDepth`, `flatten`, `flattenDeep`, + * `flattenDepth`, `flip`, `flow`, `flowRight`, `fromPairs`, `functions`, + * `functionsIn`, `groupBy`, `initial`, `intersection`, `intersectionBy`, + * `intersectionWith`, `invert`, `invertBy`, `invokeMap`, `iteratee`, `keyBy`, + * `keys`, `keysIn`, `map`, `mapKeys`, `mapValues`, `matches`, `matchesProperty`, + * `memoize`, `merge`, `mergeWith`, `method`, `methodOf`, `mixin`, `negate`, + * `nthArg`, `omit`, `omitBy`, `once`, `orderBy`, `over`, `overArgs`, + * `overEvery`, `overSome`, `partial`, `partialRight`, `partition`, `pick`, + * `pickBy`, `plant`, `property`, `propertyOf`, `pull`, `pullAll`, `pullAllBy`, + * `pullAllWith`, `pullAt`, `push`, `range`, `rangeRight`, `rearg`, `reject`, + * `remove`, `rest`, `reverse`, `sampleSize`, `set`, `setWith`, `shuffle`, + * `slice`, `sort`, `sortBy`, `splice`, `spread`, `tail`, `take`, `takeRight`, + * `takeRightWhile`, `takeWhile`, `tap`, `throttle`, `thru`, `toArray`, + * `toPairs`, `toPairsIn`, `toPath`, `toPlainObject`, `transform`, `unary`, + * `union`, `unionBy`, `unionWith`, `uniq`, `uniqBy`, `uniqWith`, `unset`, + * `unshift`, `unzip`, `unzipWith`, `update`, `updateWith`, `values`, + * `valuesIn`, `without`, `wrap`, `xor`, `xorBy`, `xorWith`, `zip`, + * `zipObject`, `zipObjectDeep`, and `zipWith` + * + * The wrapper methods that are **not** chainable by default are: + * `add`, `attempt`, `camelCase`, `capitalize`, `ceil`, `clamp`, `clone`, + * `cloneDeep`, `cloneDeepWith`, `cloneWith`, `conformsTo`, `deburr`, + * `defaultTo`, `divide`, `each`, `eachRight`, `endsWith`, `eq`, `escape`, + * `escapeRegExp`, `every`, `find`, `findIndex`, `findKey`, `findLast`, + * `findLastIndex`, `findLastKey`, `first`, `floor`, `forEach`, `forEachRight`, + * `forIn`, `forInRight`, `forOwn`, `forOwnRight`, `get`, `gt`, `gte`, `has`, + * `hasIn`, `head`, `identity`, `includes`, `indexOf`, `inRange`, `invoke`, + * `isArguments`, `isArray`, `isArrayBuffer`, `isArrayLike`, `isArrayLikeObject`, + * `isBoolean`, `isBuffer`, `isDate`, `isElement`, `isEmpty`, `isEqual`, + * `isEqualWith`, `isError`, `isFinite`, `isFunction`, `isInteger`, `isLength`, + * `isMap`, `isMatch`, `isMatchWith`, `isNaN`, `isNative`, `isNil`, `isNull`, + * `isNumber`, `isObject`, `isObjectLike`, `isPlainObject`, `isRegExp`, + * `isSafeInteger`, `isSet`, `isString`, `isUndefined`, `isTypedArray`, + * `isWeakMap`, `isWeakSet`, `join`, `kebabCase`, `last`, `lastIndexOf`, + * `lowerCase`, `lowerFirst`, `lt`, `lte`, `max`, `maxBy`, `mean`, `meanBy`, + * `min`, `minBy`, `multiply`, `noConflict`, `noop`, `now`, `nth`, `pad`, + * `padEnd`, `padStart`, `parseInt`, `pop`, `random`, `reduce`, `reduceRight`, + * `repeat`, `result`, `round`, `runInContext`, `sample`, `shift`, `size`, + * `snakeCase`, `some`, `sortedIndex`, `sortedIndexBy`, `sortedLastIndex`, + * `sortedLastIndexBy`, `startCase`, `startsWith`, `stubArray`, `stubFalse`, + * `stubObject`, `stubString`, `stubTrue`, `subtract`, `sum`, `sumBy`, + * `template`, `times`, `toFinite`, `toInteger`, `toJSON`, `toLength`, + * `toLower`, `toNumber`, `toSafeInteger`, `toString`, `toUpper`, `trim`, + * `trimEnd`, `trimStart`, `truncate`, `unescape`, `uniqueId`, `upperCase`, + * `upperFirst`, `value`, and `words` + * + * @name _ + * @constructor + * @category Seq + * @param {*} value The value to wrap in a `lodash` instance. + * @returns {Object} Returns the new `lodash` wrapper instance. + * @example + * + * function square(n) { + * return n * n; + * } + * + * var wrapped = _([1, 2, 3]); + * + * // Returns an unwrapped value. + * wrapped.reduce(_.add); + * // => 6 + * + * // Returns a wrapped value. + * var squares = wrapped.map(square); + * + * _.isArray(squares); + * // => false + * + * _.isArray(squares.value()); + * // => true + */ + function lodash(value) { + return value instanceof LodashWrapper + ? value + : new LodashWrapper(value); + } + + /** + * The base implementation of `_.create` without support for assigning + * properties to the created object. + * + * @private + * @param {Object} proto The object to inherit from. + * @returns {Object} Returns the new object. + */ + var baseCreate = (function() { + function object() {} + return function(proto) { + if (!isObject(proto)) { + return {}; + } + if (objectCreate) { + return objectCreate(proto); + } + object.prototype = proto; + var result = new object; + object.prototype = undefined; + return result; + }; + }()); + + /** + * The base constructor for creating `lodash` wrapper objects. + * + * @private + * @param {*} value The value to wrap. + * @param {boolean} [chainAll] Enable explicit method chain sequences. + */ + function LodashWrapper(value, chainAll) { + this.__wrapped__ = value; + this.__actions__ = []; + this.__chain__ = !!chainAll; + } + + LodashWrapper.prototype = baseCreate(lodash.prototype); + LodashWrapper.prototype.constructor = LodashWrapper; + + /*------------------------------------------------------------------------*/ + + /** + * Used by `_.defaults` to customize its `_.assignIn` use. + * + * @private + * @param {*} objValue The destination value. + * @param {*} srcValue The source value. + * @param {string} key The key of the property to assign. + * @param {Object} object The parent object of `objValue`. + * @returns {*} Returns the value to assign. + */ + function assignInDefaults(objValue, srcValue, key, object) { + if (objValue === undefined || + (eq(objValue, objectProto[key]) && !hasOwnProperty.call(object, key))) { + return srcValue; + } + return objValue; + } + + /** + * Assigns `value` to `key` of `object` if the existing value is not equivalent + * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero) + * for equality comparisons. + * + * @private + * @param {Object} object The object to modify. + * @param {string} key The key of the property to assign. + * @param {*} value The value to assign. + */ + function assignValue(object, key, value) { + var objValue = object[key]; + if (!(hasOwnProperty.call(object, key) && eq(objValue, value)) || + (value === undefined && !(key in object))) { + baseAssignValue(object, key, value); + } + } + + /** + * The base implementation of `assignValue` and `assignMergeValue` without + * value checks. + * + * @private + * @param {Object} object The object to modify. + * @param {string} key The key of the property to assign. + * @param {*} value The value to assign. + */ + function baseAssignValue(object, key, value) { + object[key] = value; + } + + /** + * The base implementation of `_.delay` and `_.defer` which accepts `args` + * to provide to `func`. + * + * @private + * @param {Function} func The function to delay. + * @param {number} wait The number of milliseconds to delay invocation. + * @param {Array} args The arguments to provide to `func`. + * @returns {number|Object} Returns the timer id or timeout object. + */ + function baseDelay(func, wait, args) { + if (typeof func != 'function') { + throw new TypeError(FUNC_ERROR_TEXT); + } + return setTimeout(function() { func.apply(undefined, args); }, wait); + } + + /** + * The base implementation of `_.forEach` without support for iteratee shorthands. + * + * @private + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @returns {Array|Object} Returns `collection`. + */ + var baseEach = createBaseEach(baseForOwn); + + /** + * The base implementation of `_.every` without support for iteratee shorthands. + * + * @private + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} predicate The function invoked per iteration. + * @returns {boolean} Returns `true` if all elements pass the predicate check, + * else `false` + */ + function baseEvery(collection, predicate) { + var result = true; + baseEach(collection, function(value, index, collection) { + result = !!predicate(value, index, collection); + return result; + }); + return result; + } + + /** + * The base implementation of methods like `_.max` and `_.min` which accepts a + * `comparator` to determine the extremum value. + * + * @private + * @param {Array} array The array to iterate over. + * @param {Function} iteratee The iteratee invoked per iteration. + * @param {Function} comparator The comparator used to compare values. + * @returns {*} Returns the extremum value. + */ + function baseExtremum(array, iteratee, comparator) { + var index = -1, + length = array.length; + + while (++index < length) { + var value = array[index], + current = iteratee(value); + + if (current != null && (computed === undefined + ? (current === current && !false) + : comparator(current, computed) + )) { + var computed = current, + result = value; + } + } + return result; + } + + /** + * The base implementation of `_.filter` without support for iteratee shorthands. + * + * @private + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} predicate The function invoked per iteration. + * @returns {Array} Returns the new filtered array. + */ + function baseFilter(collection, predicate) { + var result = []; + baseEach(collection, function(value, index, collection) { + if (predicate(value, index, collection)) { + result.push(value); + } + }); + return result; + } + + /** + * The base implementation of `_.flatten` with support for restricting flattening. + * + * @private + * @param {Array} array The array to flatten. + * @param {number} depth The maximum recursion depth. + * @param {boolean} [predicate=isFlattenable] The function invoked per iteration. + * @param {boolean} [isStrict] Restrict to values that pass `predicate` checks. + * @param {Array} [result=[]] The initial result value. + * @returns {Array} Returns the new flattened array. + */ + function baseFlatten(array, depth, predicate, isStrict, result) { + var index = -1, + length = array.length; + + predicate || (predicate = isFlattenable); + result || (result = []); + + while (++index < length) { + var value = array[index]; + if (depth > 0 && predicate(value)) { + if (depth > 1) { + // Recursively flatten arrays (susceptible to call stack limits). + baseFlatten(value, depth - 1, predicate, isStrict, result); + } else { + arrayPush(result, value); + } + } else if (!isStrict) { + result[result.length] = value; + } + } + return result; + } + + /** + * The base implementation of `baseForOwn` which iterates over `object` + * properties returned by `keysFunc` and invokes `iteratee` for each property. + * Iteratee functions may exit iteration early by explicitly returning `false`. + * + * @private + * @param {Object} object The object to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @param {Function} keysFunc The function to get the keys of `object`. + * @returns {Object} Returns `object`. + */ + var baseFor = createBaseFor(); + + /** + * The base implementation of `_.forOwn` without support for iteratee shorthands. + * + * @private + * @param {Object} object The object to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @returns {Object} Returns `object`. + */ + function baseForOwn(object, iteratee) { + return object && baseFor(object, iteratee, keys); + } + + /** + * The base implementation of `_.functions` which creates an array of + * `object` function property names filtered from `props`. + * + * @private + * @param {Object} object The object to inspect. + * @param {Array} props The property names to filter. + * @returns {Array} Returns the function names. + */ + function baseFunctions(object, props) { + return baseFilter(props, function(key) { + return isFunction(object[key]); + }); + } + + /** + * The base implementation of `_.gt` which doesn't coerce arguments. + * + * @private + * @param {*} value The value to compare. + * @param {*} other The other value to compare. + * @returns {boolean} Returns `true` if `value` is greater than `other`, + * else `false`. + */ + function baseGt(value, other) { + return value > other; + } + + /** + * The base implementation of `_.isArguments`. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is an `arguments` object, + */ + var baseIsArguments = noop; + + /** + * The base implementation of `_.isDate` without Node.js optimizations. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a date object, else `false`. + */ + function baseIsDate(value) { + return isObjectLike(value) && objectToString.call(value) == dateTag; + } + + /** + * The base implementation of `_.isEqual` which supports partial comparisons + * and tracks traversed objects. + * + * @private + * @param {*} value The value to compare. + * @param {*} other The other value to compare. + * @param {Function} [customizer] The function to customize comparisons. + * @param {boolean} [bitmask] The bitmask of comparison flags. + * The bitmask may be composed of the following flags: + * 1 - Unordered comparison + * 2 - Partial comparison + * @param {Object} [stack] Tracks traversed `value` and `other` objects. + * @returns {boolean} Returns `true` if the values are equivalent, else `false`. + */ + function baseIsEqual(value, other, customizer, bitmask, stack) { + if (value === other) { + return true; + } + if (value == null || other == null || (!isObject(value) && !isObjectLike(other))) { + return value !== value && other !== other; + } + return baseIsEqualDeep(value, other, baseIsEqual, customizer, bitmask, stack); + } + + /** + * A specialized version of `baseIsEqual` for arrays and objects which performs + * deep comparisons and tracks traversed objects enabling objects with circular + * references to be compared. + * + * @private + * @param {Object} object The object to compare. + * @param {Object} other The other object to compare. + * @param {Function} equalFunc The function to determine equivalents of values. + * @param {Function} [customizer] The function to customize comparisons. + * @param {number} [bitmask] The bitmask of comparison flags. See `baseIsEqual` + * for more details. + * @param {Object} [stack] Tracks traversed `object` and `other` objects. + * @returns {boolean} Returns `true` if the objects are equivalent, else `false`. + */ + function baseIsEqualDeep(object, other, equalFunc, customizer, bitmask, stack) { + var objIsArr = isArray(object), + othIsArr = isArray(other), + objTag = arrayTag, + othTag = arrayTag; + + if (!objIsArr) { + objTag = objectToString.call(object); + objTag = objTag == argsTag ? objectTag : objTag; + } + if (!othIsArr) { + othTag = objectToString.call(other); + othTag = othTag == argsTag ? objectTag : othTag; + } + var objIsObj = objTag == objectTag, + othIsObj = othTag == objectTag, + isSameTag = objTag == othTag; + + stack || (stack = []); + var objStack = find(stack, function(entry) { + return entry[0] == object; + }); + var othStack = find(stack, function(entry) { + return entry[0] == other; + }); + if (objStack && othStack) { + return objStack[1] == other; + } + stack.push([object, other]); + stack.push([other, object]); + if (isSameTag && !objIsObj) { + var result = (objIsArr) + ? equalArrays(object, other, equalFunc, customizer, bitmask, stack) + : equalByTag(object, other, objTag, equalFunc, customizer, bitmask, stack); + stack.pop(); + return result; + } + if (!(bitmask & PARTIAL_COMPARE_FLAG)) { + var objIsWrapped = objIsObj && hasOwnProperty.call(object, '__wrapped__'), + othIsWrapped = othIsObj && hasOwnProperty.call(other, '__wrapped__'); + + if (objIsWrapped || othIsWrapped) { + var objUnwrapped = objIsWrapped ? object.value() : object, + othUnwrapped = othIsWrapped ? other.value() : other; + + var result = equalFunc(objUnwrapped, othUnwrapped, customizer, bitmask, stack); + stack.pop(); + return result; + } + } + if (!isSameTag) { + return false; + } + var result = equalObjects(object, other, equalFunc, customizer, bitmask, stack); + stack.pop(); + return result; + } + + /** + * The base implementation of `_.isRegExp` without Node.js optimizations. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a regexp, else `false`. + */ + function baseIsRegExp(value) { + return isObject(value) && objectToString.call(value) == regexpTag; + } + + /** + * The base implementation of `_.iteratee`. + * + * @private + * @param {*} [value=_.identity] The value to convert to an iteratee. + * @returns {Function} Returns the iteratee. + */ + function baseIteratee(func) { + if (typeof func == 'function') { + return func; + } + if (func == null) { + return identity; + } + return (typeof func == 'object' ? baseMatches : baseProperty)(func); + } + + /** + * The base implementation of `_.lt` which doesn't coerce arguments. + * + * @private + * @param {*} value The value to compare. + * @param {*} other The other value to compare. + * @returns {boolean} Returns `true` if `value` is less than `other`, + * else `false`. + */ + function baseLt(value, other) { + return value < other; + } + + /** + * The base implementation of `_.map` without support for iteratee shorthands. + * + * @private + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @returns {Array} Returns the new mapped array. + */ + function baseMap(collection, iteratee) { + var index = -1, + result = isArrayLike(collection) ? Array(collection.length) : []; + + baseEach(collection, function(value, key, collection) { + result[++index] = iteratee(value, key, collection); + }); + return result; + } + + /** + * The base implementation of `_.matches` which doesn't clone `source`. + * + * @private + * @param {Object} source The object of property values to match. + * @returns {Function} Returns the new spec function. + */ + function baseMatches(source) { + var props = nativeKeys(source); + return function(object) { + var length = props.length; + if (object == null) { + return !length; + } + object = Object(object); + while (length--) { + var key = props[length]; + if (!(key in object && + baseIsEqual(source[key], object[key], undefined, UNORDERED_COMPARE_FLAG | PARTIAL_COMPARE_FLAG) + )) { + return false; + } + } + return true; + }; + } + + /** + * The base implementation of `_.pick` without support for individual + * property identifiers. + * + * @private + * @param {Object} object The source object. + * @param {string[]} props The property identifiers to pick. + * @returns {Object} Returns the new object. + */ + function basePick(object, props) { + object = Object(object); + return reduce(props, function(result, key) { + if (key in object) { + result[key] = object[key]; + } + return result; + }, {}); + } + + /** + * The base implementation of `_.rest` which doesn't validate or coerce arguments. + * + * @private + * @param {Function} func The function to apply a rest parameter to. + * @param {number} [start=func.length-1] The start position of the rest parameter. + * @returns {Function} Returns the new function. + */ + function baseRest(func, start) { + return setToString(overRest(func, start, identity), func + ''); + } + + /** + * The base implementation of `_.slice` without an iteratee call guard. + * + * @private + * @param {Array} array The array to slice. + * @param {number} [start=0] The start position. + * @param {number} [end=array.length] The end position. + * @returns {Array} Returns the slice of `array`. + */ + function baseSlice(array, start, end) { + var index = -1, + length = array.length; + + if (start < 0) { + start = -start > length ? 0 : (length + start); + } + end = end > length ? length : end; + if (end < 0) { + end += length; + } + length = start > end ? 0 : ((end - start) >>> 0); + start >>>= 0; + + var result = Array(length); + while (++index < length) { + result[index] = array[index + start]; + } + return result; + } + + /** + * Copies the values of `source` to `array`. + * + * @private + * @param {Array} source The array to copy values from. + * @param {Array} [array=[]] The array to copy values to. + * @returns {Array} Returns `array`. + */ + function copyArray(source) { + return baseSlice(source, 0, source.length); + } + + /** + * The base implementation of `_.some` without support for iteratee shorthands. + * + * @private + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} predicate The function invoked per iteration. + * @returns {boolean} Returns `true` if any element passes the predicate check, + * else `false`. + */ + function baseSome(collection, predicate) { + var result; + + baseEach(collection, function(value, index, collection) { + result = predicate(value, index, collection); + return !result; + }); + return !!result; + } + + /** + * The base implementation of `wrapperValue` which returns the result of + * performing a sequence of actions on the unwrapped `value`, where each + * successive action is supplied the return value of the previous. + * + * @private + * @param {*} value The unwrapped value. + * @param {Array} actions Actions to perform to resolve the unwrapped value. + * @returns {*} Returns the resolved value. + */ + function baseWrapperValue(value, actions) { + var result = value; + return reduce(actions, function(result, action) { + return action.func.apply(action.thisArg, arrayPush([result], action.args)); + }, result); + } + + /** + * Compares values to sort them in ascending order. + * + * @private + * @param {*} value The value to compare. + * @param {*} other The other value to compare. + * @returns {number} Returns the sort order indicator for `value`. + */ + function compareAscending(value, other) { + if (value !== other) { + var valIsDefined = value !== undefined, + valIsNull = value === null, + valIsReflexive = value === value, + valIsSymbol = false; + + var othIsDefined = other !== undefined, + othIsNull = other === null, + othIsReflexive = other === other, + othIsSymbol = false; + + if ((!othIsNull && !othIsSymbol && !valIsSymbol && value > other) || + (valIsSymbol && othIsDefined && othIsReflexive && !othIsNull && !othIsSymbol) || + (valIsNull && othIsDefined && othIsReflexive) || + (!valIsDefined && othIsReflexive) || + !valIsReflexive) { + return 1; + } + if ((!valIsNull && !valIsSymbol && !othIsSymbol && value < other) || + (othIsSymbol && valIsDefined && valIsReflexive && !valIsNull && !valIsSymbol) || + (othIsNull && valIsDefined && valIsReflexive) || + (!othIsDefined && valIsReflexive) || + !othIsReflexive) { + return -1; + } + } + return 0; + } + + /** + * Copies properties of `source` to `object`. + * + * @private + * @param {Object} source The object to copy properties from. + * @param {Array} props The property identifiers to copy. + * @param {Object} [object={}] The object to copy properties to. + * @param {Function} [customizer] The function to customize copied values. + * @returns {Object} Returns `object`. + */ + function copyObject(source, props, object, customizer) { + var isNew = !object; + object || (object = {}); + + var index = -1, + length = props.length; + + while (++index < length) { + var key = props[index]; + + var newValue = customizer + ? customizer(object[key], source[key], key, object, source) + : undefined; + + if (newValue === undefined) { + newValue = source[key]; + } + if (isNew) { + baseAssignValue(object, key, newValue); + } else { + assignValue(object, key, newValue); + } + } + return object; + } + + /** + * Creates a function like `_.assign`. + * + * @private + * @param {Function} assigner The function to assign values. + * @returns {Function} Returns the new assigner function. + */ + function createAssigner(assigner) { + return baseRest(function(object, sources) { + var index = -1, + length = sources.length, + customizer = length > 1 ? sources[length - 1] : undefined; + + customizer = (assigner.length > 3 && typeof customizer == 'function') + ? (length--, customizer) + : undefined; + + object = Object(object); + while (++index < length) { + var source = sources[index]; + if (source) { + assigner(object, source, index, customizer); + } + } + return object; + }); + } + + /** + * Creates a `baseEach` or `baseEachRight` function. + * + * @private + * @param {Function} eachFunc The function to iterate over a collection. + * @param {boolean} [fromRight] Specify iterating from right to left. + * @returns {Function} Returns the new base function. + */ + function createBaseEach(eachFunc, fromRight) { + return function(collection, iteratee) { + if (collection == null) { + return collection; + } + if (!isArrayLike(collection)) { + return eachFunc(collection, iteratee); + } + var length = collection.length, + index = fromRight ? length : -1, + iterable = Object(collection); + + while ((fromRight ? index-- : ++index < length)) { + if (iteratee(iterable[index], index, iterable) === false) { + break; + } + } + return collection; + }; + } + + /** + * Creates a base function for methods like `_.forIn` and `_.forOwn`. + * + * @private + * @param {boolean} [fromRight] Specify iterating from right to left. + * @returns {Function} Returns the new base function. + */ + function createBaseFor(fromRight) { + return function(object, iteratee, keysFunc) { + var index = -1, + iterable = Object(object), + props = keysFunc(object), + length = props.length; + + while (length--) { + var key = props[fromRight ? length : ++index]; + if (iteratee(iterable[key], key, iterable) === false) { + break; + } + } + return object; + }; + } + + /** + * Creates a function that produces an instance of `Ctor` regardless of + * whether it was invoked as part of a `new` expression or by `call` or `apply`. + * + * @private + * @param {Function} Ctor The constructor to wrap. + * @returns {Function} Returns the new wrapped function. + */ + function createCtor(Ctor) { + return function() { + // Use a `switch` statement to work with class constructors. See + // http://ecma-international.org/ecma-262/7.0/#sec-ecmascript-function-objects-call-thisargument-argumentslist + // for more details. + var args = arguments; + var thisBinding = baseCreate(Ctor.prototype), + result = Ctor.apply(thisBinding, args); + + // Mimic the constructor's `return` behavior. + // See https://es5.github.io/#x13.2.2 for more details. + return isObject(result) ? result : thisBinding; + }; + } + + /** + * Creates a `_.find` or `_.findLast` function. + * + * @private + * @param {Function} findIndexFunc The function to find the collection index. + * @returns {Function} Returns the new find function. + */ + function createFind(findIndexFunc) { + return function(collection, predicate, fromIndex) { + var iterable = Object(collection); + if (!isArrayLike(collection)) { + var iteratee = baseIteratee(predicate, 3); + collection = keys(collection); + predicate = function(key) { return iteratee(iterable[key], key, iterable); }; + } + var index = findIndexFunc(collection, predicate, fromIndex); + return index > -1 ? iterable[iteratee ? collection[index] : index] : undefined; + }; + } + + /** + * Creates a function that wraps `func` to invoke it with the `this` binding + * of `thisArg` and `partials` prepended to the arguments it receives. + * + * @private + * @param {Function} func The function to wrap. + * @param {number} bitmask The bitmask flags. See `createWrap` for more details. + * @param {*} thisArg The `this` binding of `func`. + * @param {Array} partials The arguments to prepend to those provided to + * the new function. + * @returns {Function} Returns the new wrapped function. + */ + function createPartial(func, bitmask, thisArg, partials) { + if (typeof func != 'function') { + throw new TypeError(FUNC_ERROR_TEXT); + } + var isBind = bitmask & BIND_FLAG, + Ctor = createCtor(func); + + function wrapper() { + var argsIndex = -1, + argsLength = arguments.length, + leftIndex = -1, + leftLength = partials.length, + args = Array(leftLength + argsLength), + fn = (this && this !== root && this instanceof wrapper) ? Ctor : func; + + while (++leftIndex < leftLength) { + args[leftIndex] = partials[leftIndex]; + } + while (argsLength--) { + args[leftIndex++] = arguments[++argsIndex]; + } + return fn.apply(isBind ? thisArg : this, args); + } + return wrapper; + } + + /** + * A specialized version of `baseIsEqualDeep` for arrays with support for + * partial deep comparisons. + * + * @private + * @param {Array} array The array to compare. + * @param {Array} other The other array to compare. + * @param {Function} equalFunc The function to determine equivalents of values. + * @param {Function} customizer The function to customize comparisons. + * @param {number} bitmask The bitmask of comparison flags. See `baseIsEqual` + * for more details. + * @param {Object} stack Tracks traversed `array` and `other` objects. + * @returns {boolean} Returns `true` if the arrays are equivalent, else `false`. + */ + function equalArrays(array, other, equalFunc, customizer, bitmask, stack) { + var isPartial = bitmask & PARTIAL_COMPARE_FLAG, + arrLength = array.length, + othLength = other.length; + + if (arrLength != othLength && !(isPartial && othLength > arrLength)) { + return false; + } + var index = -1, + result = true, + seen = (bitmask & UNORDERED_COMPARE_FLAG) ? [] : undefined; + + // Ignore non-index properties. + while (++index < arrLength) { + var arrValue = array[index], + othValue = other[index]; + + var compared; + if (compared !== undefined) { + if (compared) { + continue; + } + result = false; + break; + } + // Recursively compare arrays (susceptible to call stack limits). + if (seen) { + if (!baseSome(other, function(othValue, othIndex) { + if (!indexOf(seen, othIndex) && + (arrValue === othValue || equalFunc(arrValue, othValue, customizer, bitmask, stack))) { + return seen.push(othIndex); + } + })) { + result = false; + break; + } + } else if (!( + arrValue === othValue || + equalFunc(arrValue, othValue, customizer, bitmask, stack) + )) { + result = false; + break; + } + } + return result; + } + + /** + * A specialized version of `baseIsEqualDeep` for comparing objects of + * the same `toStringTag`. + * + * **Note:** This function only supports comparing values with tags of + * `Boolean`, `Date`, `Error`, `Number`, `RegExp`, or `String`. + * + * @private + * @param {Object} object The object to compare. + * @param {Object} other The other object to compare. + * @param {string} tag The `toStringTag` of the objects to compare. + * @param {Function} equalFunc The function to determine equivalents of values. + * @param {Function} customizer The function to customize comparisons. + * @param {number} bitmask The bitmask of comparison flags. See `baseIsEqual` + * for more details. + * @param {Object} stack Tracks traversed `object` and `other` objects. + * @returns {boolean} Returns `true` if the objects are equivalent, else `false`. + */ + function equalByTag(object, other, tag, equalFunc, customizer, bitmask, stack) { + switch (tag) { + + case boolTag: + case dateTag: + case numberTag: + // Coerce booleans to `1` or `0` and dates to milliseconds. + // Invalid dates are coerced to `NaN`. + return eq(+object, +other); + + case errorTag: + return object.name == other.name && object.message == other.message; + + case regexpTag: + case stringTag: + // Coerce regexes to strings and treat strings, primitives and objects, + // as equal. See http://www.ecma-international.org/ecma-262/7.0/#sec-regexp.prototype.tostring + // for more details. + return object == (other + ''); + + } + return false; + } + + /** + * A specialized version of `baseIsEqualDeep` for objects with support for + * partial deep comparisons. + * + * @private + * @param {Object} object The object to compare. + * @param {Object} other The other object to compare. + * @param {Function} equalFunc The function to determine equivalents of values. + * @param {Function} customizer The function to customize comparisons. + * @param {number} bitmask The bitmask of comparison flags. See `baseIsEqual` + * for more details. + * @param {Object} stack Tracks traversed `object` and `other` objects. + * @returns {boolean} Returns `true` if the objects are equivalent, else `false`. + */ + function equalObjects(object, other, equalFunc, customizer, bitmask, stack) { + var isPartial = bitmask & PARTIAL_COMPARE_FLAG, + objProps = keys(object), + objLength = objProps.length, + othProps = keys(other), + othLength = othProps.length; + + if (objLength != othLength && !isPartial) { + return false; + } + var index = objLength; + while (index--) { + var key = objProps[index]; + if (!(isPartial ? key in other : hasOwnProperty.call(other, key))) { + return false; + } + } + var result = true; + + var skipCtor = isPartial; + while (++index < objLength) { + key = objProps[index]; + var objValue = object[key], + othValue = other[key]; + + var compared; + // Recursively compare objects (susceptible to call stack limits). + if (!(compared === undefined + ? (objValue === othValue || equalFunc(objValue, othValue, customizer, bitmask, stack)) + : compared + )) { + result = false; + break; + } + skipCtor || (skipCtor = key == 'constructor'); + } + if (result && !skipCtor) { + var objCtor = object.constructor, + othCtor = other.constructor; + + // Non `Object` object instances with different constructors are not equal. + if (objCtor != othCtor && + ('constructor' in object && 'constructor' in other) && + !(typeof objCtor == 'function' && objCtor instanceof objCtor && + typeof othCtor == 'function' && othCtor instanceof othCtor)) { + result = false; + } + } + return result; + } + + /** + * A specialized version of `baseRest` which flattens the rest array. + * + * @private + * @param {Function} func The function to apply a rest parameter to. + * @returns {Function} Returns the new function. + */ + function flatRest(func) { + return setToString(overRest(func, undefined, flatten), func + ''); + } + + /** + * Checks if `value` is a flattenable `arguments` object or array. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is flattenable, else `false`. + */ + function isFlattenable(value) { + return isArray(value) || isArguments(value); + } + + /** + * This function is like + * [`Object.keys`](http://ecma-international.org/ecma-262/7.0/#sec-object.keys) + * except that it includes inherited enumerable properties. + * + * @private + * @param {Object} object The object to query. + * @returns {Array} Returns the array of property names. + */ + function nativeKeysIn(object) { + var result = []; + if (object != null) { + for (var key in Object(object)) { + result.push(key); + } + } + return result; + } + + /** + * A specialized version of `baseRest` which transforms the rest array. + * + * @private + * @param {Function} func The function to apply a rest parameter to. + * @param {number} [start=func.length-1] The start position of the rest parameter. + * @param {Function} transform The rest array transform. + * @returns {Function} Returns the new function. + */ + function overRest(func, start, transform) { + start = nativeMax(start === undefined ? (func.length - 1) : start, 0); + return function() { + var args = arguments, + index = -1, + length = nativeMax(args.length - start, 0), + array = Array(length); + + while (++index < length) { + array[index] = args[start + index]; + } + index = -1; + var otherArgs = Array(start + 1); + while (++index < start) { + otherArgs[index] = args[index]; + } + otherArgs[start] = transform(array); + return func.apply(this, otherArgs); + }; + } + + /** + * Sets the `toString` method of `func` to return `string`. + * + * @private + * @param {Function} func The function to modify. + * @param {Function} string The `toString` result. + * @returns {Function} Returns `func`. + */ + var setToString = identity; + + /** + * Converts `value` to a string key if it's not a string or symbol. + * + * @private + * @param {*} value The value to inspect. + * @returns {string|symbol} Returns the key. + */ + var toKey = String; + + /*------------------------------------------------------------------------*/ + + /** + * Creates an array with all falsey values removed. The values `false`, `null`, + * `0`, `""`, `undefined`, and `NaN` are falsey. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Array + * @param {Array} array The array to compact. + * @returns {Array} Returns the new array of filtered values. + * @example + * + * _.compact([0, 1, false, 2, '', 3]); + * // => [1, 2, 3] + */ + function compact(array) { + return baseFilter(array, Boolean); + } + + /** + * Creates a new array concatenating `array` with any additional arrays + * and/or values. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {Array} array The array to concatenate. + * @param {...*} [values] The values to concatenate. + * @returns {Array} Returns the new concatenated array. + * @example + * + * var array = [1]; + * var other = _.concat(array, 2, [3], [[4]]); + * + * console.log(other); + * // => [1, 2, 3, [4]] + * + * console.log(array); + * // => [1] + */ + function concat() { + var length = arguments.length; + if (!length) { + return []; + } + var args = Array(length - 1), + array = arguments[0], + index = length; + + while (index--) { + args[index - 1] = arguments[index]; + } + return arrayPush(isArray(array) ? copyArray(array) : [array], baseFlatten(args, 1)); + } + + /** + * This method is like `_.find` except that it returns the index of the first + * element `predicate` returns truthy for instead of the element itself. + * + * @static + * @memberOf _ + * @since 1.1.0 + * @category Array + * @param {Array} array The array to inspect. + * @param {Function} [predicate=_.identity] + * The function invoked per iteration. + * @param {number} [fromIndex=0] The index to search from. + * @returns {number} Returns the index of the found element, else `-1`. + * @example + * + * var users = [ + * { 'user': 'barney', 'active': false }, + * { 'user': 'fred', 'active': false }, + * { 'user': 'pebbles', 'active': true } + * ]; + * + * _.findIndex(users, function(o) { return o.user == 'barney'; }); + * // => 0 + * + * // The `_.matches` iteratee shorthand. + * _.findIndex(users, { 'user': 'fred', 'active': false }); + * // => 1 + * + * // The `_.matchesProperty` iteratee shorthand. + * _.findIndex(users, ['active', false]); + * // => 0 + * + * // The `_.property` iteratee shorthand. + * _.findIndex(users, 'active'); + * // => 2 + */ + function findIndex(array, predicate, fromIndex) { + var length = array ? array.length : 0; + if (!length) { + return -1; + } + var index = fromIndex == null ? 0 : toInteger(fromIndex); + if (index < 0) { + index = nativeMax(length + index, 0); + } + return baseFindIndex(array, baseIteratee(predicate, 3), index); + } + + /** + * Flattens `array` a single level deep. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Array + * @param {Array} array The array to flatten. + * @returns {Array} Returns the new flattened array. + * @example + * + * _.flatten([1, [2, [3, [4]], 5]]); + * // => [1, 2, [3, [4]], 5] + */ + function flatten(array) { + var length = array ? array.length : 0; + return length ? baseFlatten(array, 1) : []; + } + + /** + * Recursively flattens `array`. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Array + * @param {Array} array The array to flatten. + * @returns {Array} Returns the new flattened array. + * @example + * + * _.flattenDeep([1, [2, [3, [4]], 5]]); + * // => [1, 2, 3, 4, 5] + */ + function flattenDeep(array) { + var length = array ? array.length : 0; + return length ? baseFlatten(array, INFINITY) : []; + } + + /** + * Gets the first element of `array`. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @alias first + * @category Array + * @param {Array} array The array to query. + * @returns {*} Returns the first element of `array`. + * @example + * + * _.head([1, 2, 3]); + * // => 1 + * + * _.head([]); + * // => undefined + */ + function head(array) { + return (array && array.length) ? array[0] : undefined; + } + + /** + * Gets the index at which the first occurrence of `value` is found in `array` + * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero) + * for equality comparisons. If `fromIndex` is negative, it's used as the + * offset from the end of `array`. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Array + * @param {Array} array The array to inspect. + * @param {*} value The value to search for. + * @param {number} [fromIndex=0] The index to search from. + * @returns {number} Returns the index of the matched value, else `-1`. + * @example + * + * _.indexOf([1, 2, 1, 2], 2); + * // => 1 + * + * // Search from the `fromIndex`. + * _.indexOf([1, 2, 1, 2], 2, 2); + * // => 3 + */ + function indexOf(array, value, fromIndex) { + var length = array ? array.length : 0; + if (typeof fromIndex == 'number') { + fromIndex = fromIndex < 0 ? nativeMax(length + fromIndex, 0) : fromIndex; + } else { + fromIndex = 0; + } + var index = (fromIndex || 0) - 1, + isReflexive = value === value; + + while (++index < length) { + var other = array[index]; + if ((isReflexive ? other === value : other !== other)) { + return index; + } + } + return -1; + } + + /** + * Gets the last element of `array`. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Array + * @param {Array} array The array to query. + * @returns {*} Returns the last element of `array`. + * @example + * + * _.last([1, 2, 3]); + * // => 3 + */ + function last(array) { + var length = array ? array.length : 0; + return length ? array[length - 1] : undefined; + } + + /** + * Creates a slice of `array` from `start` up to, but not including, `end`. + * + * **Note:** This method is used instead of + * [`Array#slice`](https://mdn.io/Array/slice) to ensure dense arrays are + * returned. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Array + * @param {Array} array The array to slice. + * @param {number} [start=0] The start position. + * @param {number} [end=array.length] The end position. + * @returns {Array} Returns the slice of `array`. + */ + function slice(array, start, end) { + var length = array ? array.length : 0; + start = start == null ? 0 : +start; + end = end === undefined ? length : +end; + return length ? baseSlice(array, start, end) : []; + } + + /*------------------------------------------------------------------------*/ + + /** + * Creates a `lodash` wrapper instance that wraps `value` with explicit method + * chain sequences enabled. The result of such sequences must be unwrapped + * with `_#value`. + * + * @static + * @memberOf _ + * @since 1.3.0 + * @category Seq + * @param {*} value The value to wrap. + * @returns {Object} Returns the new `lodash` wrapper instance. + * @example + * + * var users = [ + * { 'user': 'barney', 'age': 36 }, + * { 'user': 'fred', 'age': 40 }, + * { 'user': 'pebbles', 'age': 1 } + * ]; + * + * var youngest = _ + * .chain(users) + * .sortBy('age') + * .map(function(o) { + * return o.user + ' is ' + o.age; + * }) + * .head() + * .value(); + * // => 'pebbles is 1' + */ + function chain(value) { + var result = lodash(value); + result.__chain__ = true; + return result; + } + + /** + * This method invokes `interceptor` and returns `value`. The interceptor + * is invoked with one argument; (value). The purpose of this method is to + * "tap into" a method chain sequence in order to modify intermediate results. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Seq + * @param {*} value The value to provide to `interceptor`. + * @param {Function} interceptor The function to invoke. + * @returns {*} Returns `value`. + * @example + * + * _([1, 2, 3]) + * .tap(function(array) { + * // Mutate input array. + * array.pop(); + * }) + * .reverse() + * .value(); + * // => [2, 1] + */ + function tap(value, interceptor) { + interceptor(value); + return value; + } + + /** + * This method is like `_.tap` except that it returns the result of `interceptor`. + * The purpose of this method is to "pass thru" values replacing intermediate + * results in a method chain sequence. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Seq + * @param {*} value The value to provide to `interceptor`. + * @param {Function} interceptor The function to invoke. + * @returns {*} Returns the result of `interceptor`. + * @example + * + * _(' abc ') + * .chain() + * .trim() + * .thru(function(value) { + * return [value]; + * }) + * .value(); + * // => ['abc'] + */ + function thru(value, interceptor) { + return interceptor(value); + } + + /** + * Creates a `lodash` wrapper instance with explicit method chain sequences enabled. + * + * @name chain + * @memberOf _ + * @since 0.1.0 + * @category Seq + * @returns {Object} Returns the new `lodash` wrapper instance. + * @example + * + * var users = [ + * { 'user': 'barney', 'age': 36 }, + * { 'user': 'fred', 'age': 40 } + * ]; + * + * // A sequence without explicit chaining. + * _(users).head(); + * // => { 'user': 'barney', 'age': 36 } + * + * // A sequence with explicit chaining. + * _(users) + * .chain() + * .head() + * .pick('user') + * .value(); + * // => { 'user': 'barney' } + */ + function wrapperChain() { + return chain(this); + } + + /** + * Executes the chain sequence to resolve the unwrapped value. + * + * @name value + * @memberOf _ + * @since 0.1.0 + * @alias toJSON, valueOf + * @category Seq + * @returns {*} Returns the resolved unwrapped value. + * @example + * + * _([1, 2, 3]).value(); + * // => [1, 2, 3] + */ + function wrapperValue() { + return baseWrapperValue(this.__wrapped__, this.__actions__); + } + + /*------------------------------------------------------------------------*/ + + /** + * Checks if `predicate` returns truthy for **all** elements of `collection`. + * Iteration is stopped once `predicate` returns falsey. The predicate is + * invoked with three arguments: (value, index|key, collection). + * + * **Note:** This method returns `true` for + * [empty collections](https://en.wikipedia.org/wiki/Empty_set) because + * [everything is true](https://en.wikipedia.org/wiki/Vacuous_truth) of + * elements of empty collections. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [predicate=_.identity] + * The function invoked per iteration. + * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`. + * @returns {boolean} Returns `true` if all elements pass the predicate check, + * else `false`. + * @example + * + * _.every([true, 1, null, 'yes'], Boolean); + * // => false + * + * var users = [ + * { 'user': 'barney', 'age': 36, 'active': false }, + * { 'user': 'fred', 'age': 40, 'active': false } + * ]; + * + * // The `_.matches` iteratee shorthand. + * _.every(users, { 'user': 'barney', 'active': false }); + * // => false + * + * // The `_.matchesProperty` iteratee shorthand. + * _.every(users, ['active', false]); + * // => true + * + * // The `_.property` iteratee shorthand. + * _.every(users, 'active'); + * // => false + */ + function every(collection, predicate, guard) { + predicate = guard ? undefined : predicate; + return baseEvery(collection, baseIteratee(predicate)); + } + + /** + * Iterates over elements of `collection`, returning an array of all elements + * `predicate` returns truthy for. The predicate is invoked with three + * arguments: (value, index|key, collection). + * + * **Note:** Unlike `_.remove`, this method returns a new array. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [predicate=_.identity] + * The function invoked per iteration. + * @returns {Array} Returns the new filtered array. + * @see _.reject + * @example + * + * var users = [ + * { 'user': 'barney', 'age': 36, 'active': true }, + * { 'user': 'fred', 'age': 40, 'active': false } + * ]; + * + * _.filter(users, function(o) { return !o.active; }); + * // => objects for ['fred'] + * + * // The `_.matches` iteratee shorthand. + * _.filter(users, { 'age': 36, 'active': true }); + * // => objects for ['barney'] + * + * // The `_.matchesProperty` iteratee shorthand. + * _.filter(users, ['active', false]); + * // => objects for ['fred'] + * + * // The `_.property` iteratee shorthand. + * _.filter(users, 'active'); + * // => objects for ['barney'] + */ + function filter(collection, predicate) { + return baseFilter(collection, baseIteratee(predicate)); + } + + /** + * Iterates over elements of `collection`, returning the first element + * `predicate` returns truthy for. The predicate is invoked with three + * arguments: (value, index|key, collection). + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Collection + * @param {Array|Object} collection The collection to inspect. + * @param {Function} [predicate=_.identity] + * The function invoked per iteration. + * @param {number} [fromIndex=0] The index to search from. + * @returns {*} Returns the matched element, else `undefined`. + * @example + * + * var users = [ + * { 'user': 'barney', 'age': 36, 'active': true }, + * { 'user': 'fred', 'age': 40, 'active': false }, + * { 'user': 'pebbles', 'age': 1, 'active': true } + * ]; + * + * _.find(users, function(o) { return o.age < 40; }); + * // => object for 'barney' + * + * // The `_.matches` iteratee shorthand. + * _.find(users, { 'age': 1, 'active': true }); + * // => object for 'pebbles' + * + * // The `_.matchesProperty` iteratee shorthand. + * _.find(users, ['active', false]); + * // => object for 'fred' + * + * // The `_.property` iteratee shorthand. + * _.find(users, 'active'); + * // => object for 'barney' + */ + var find = createFind(findIndex); + + /** + * Iterates over elements of `collection` and invokes `iteratee` for each element. + * The iteratee is invoked with three arguments: (value, index|key, collection). + * Iteratee functions may exit iteration early by explicitly returning `false`. + * + * **Note:** As with other "Collections" methods, objects with a "length" + * property are iterated like arrays. To avoid this behavior use `_.forIn` + * or `_.forOwn` for object iteration. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @alias each + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [iteratee=_.identity] The function invoked per iteration. + * @returns {Array|Object} Returns `collection`. + * @see _.forEachRight + * @example + * + * _.forEach([1, 2], function(value) { + * console.log(value); + * }); + * // => Logs `1` then `2`. + * + * _.forEach({ 'a': 1, 'b': 2 }, function(value, key) { + * console.log(key); + * }); + * // => Logs 'a' then 'b' (iteration order is not guaranteed). + */ + function forEach(collection, iteratee) { + return baseEach(collection, baseIteratee(iteratee)); + } + + /** + * Creates an array of values by running each element in `collection` thru + * `iteratee`. The iteratee is invoked with three arguments: + * (value, index|key, collection). + * + * Many lodash methods are guarded to work as iteratees for methods like + * `_.every`, `_.filter`, `_.map`, `_.mapValues`, `_.reject`, and `_.some`. + * + * The guarded methods are: + * `ary`, `chunk`, `curry`, `curryRight`, `drop`, `dropRight`, `every`, + * `fill`, `invert`, `parseInt`, `random`, `range`, `rangeRight`, `repeat`, + * `sampleSize`, `slice`, `some`, `sortBy`, `split`, `take`, `takeRight`, + * `template`, `trim`, `trimEnd`, `trimStart`, and `words` + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [iteratee=_.identity] The function invoked per iteration. + * @returns {Array} Returns the new mapped array. + * @example + * + * function square(n) { + * return n * n; + * } + * + * _.map([4, 8], square); + * // => [16, 64] + * + * _.map({ 'a': 4, 'b': 8 }, square); + * // => [16, 64] (iteration order is not guaranteed) + * + * var users = [ + * { 'user': 'barney' }, + * { 'user': 'fred' } + * ]; + * + * // The `_.property` iteratee shorthand. + * _.map(users, 'user'); + * // => ['barney', 'fred'] + */ + function map(collection, iteratee) { + return baseMap(collection, baseIteratee(iteratee)); + } + + /** + * Reduces `collection` to a value which is the accumulated result of running + * each element in `collection` thru `iteratee`, where each successive + * invocation is supplied the return value of the previous. If `accumulator` + * is not given, the first element of `collection` is used as the initial + * value. The iteratee is invoked with four arguments: + * (accumulator, value, index|key, collection). + * + * Many lodash methods are guarded to work as iteratees for methods like + * `_.reduce`, `_.reduceRight`, and `_.transform`. + * + * The guarded methods are: + * `assign`, `defaults`, `defaultsDeep`, `includes`, `merge`, `orderBy`, + * and `sortBy` + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [iteratee=_.identity] The function invoked per iteration. + * @param {*} [accumulator] The initial value. + * @returns {*} Returns the accumulated value. + * @see _.reduceRight + * @example + * + * _.reduce([1, 2], function(sum, n) { + * return sum + n; + * }, 0); + * // => 3 + * + * _.reduce({ 'a': 1, 'b': 2, 'c': 1 }, function(result, value, key) { + * (result[value] || (result[value] = [])).push(key); + * return result; + * }, {}); + * // => { '1': ['a', 'c'], '2': ['b'] } (iteration order is not guaranteed) + */ + function reduce(collection, iteratee, accumulator) { + return baseReduce(collection, baseIteratee(iteratee), accumulator, arguments.length < 3, baseEach); + } + + /** + * Gets the size of `collection` by returning its length for array-like + * values or the number of own enumerable string keyed properties for objects. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Collection + * @param {Array|Object|string} collection The collection to inspect. + * @returns {number} Returns the collection size. + * @example + * + * _.size([1, 2, 3]); + * // => 3 + * + * _.size({ 'a': 1, 'b': 2 }); + * // => 2 + * + * _.size('pebbles'); + * // => 7 + */ + function size(collection) { + if (collection == null) { + return 0; + } + collection = isArrayLike(collection) ? collection : nativeKeys(collection); + return collection.length; + } + + /** + * Checks if `predicate` returns truthy for **any** element of `collection`. + * Iteration is stopped once `predicate` returns truthy. The predicate is + * invoked with three arguments: (value, index|key, collection). + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [predicate=_.identity] The function invoked per iteration. + * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`. + * @returns {boolean} Returns `true` if any element passes the predicate check, + * else `false`. + * @example + * + * _.some([null, 0, 'yes', false], Boolean); + * // => true + * + * var users = [ + * { 'user': 'barney', 'active': true }, + * { 'user': 'fred', 'active': false } + * ]; + * + * // The `_.matches` iteratee shorthand. + * _.some(users, { 'user': 'barney', 'active': false }); + * // => false + * + * // The `_.matchesProperty` iteratee shorthand. + * _.some(users, ['active', false]); + * // => true + * + * // The `_.property` iteratee shorthand. + * _.some(users, 'active'); + * // => true + */ + function some(collection, predicate, guard) { + predicate = guard ? undefined : predicate; + return baseSome(collection, baseIteratee(predicate)); + } + + /** + * Creates an array of elements, sorted in ascending order by the results of + * running each element in a collection thru each iteratee. This method + * performs a stable sort, that is, it preserves the original sort order of + * equal elements. The iteratees are invoked with one argument: (value). + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {...(Function|Function[])} [iteratees=[_.identity]] + * The iteratees to sort by. + * @returns {Array} Returns the new sorted array. + * @example + * + * var users = [ + * { 'user': 'fred', 'age': 48 }, + * { 'user': 'barney', 'age': 36 }, + * { 'user': 'fred', 'age': 40 }, + * { 'user': 'barney', 'age': 34 } + * ]; + * + * _.sortBy(users, [function(o) { return o.user; }]); + * // => objects for [['barney', 36], ['barney', 34], ['fred', 48], ['fred', 40]] + * + * _.sortBy(users, ['user', 'age']); + * // => objects for [['barney', 34], ['barney', 36], ['fred', 40], ['fred', 48]] + */ + function sortBy(collection, iteratee) { + var index = 0; + iteratee = baseIteratee(iteratee); + + return baseMap(baseMap(collection, function(value, key, collection) { + return { 'value': value, 'index': index++, 'criteria': iteratee(value, key, collection) }; + }).sort(function(object, other) { + return compareAscending(object.criteria, other.criteria) || (object.index - other.index); + }), baseProperty('value')); + } + + /*------------------------------------------------------------------------*/ + + /** + * Creates a function that invokes `func`, with the `this` binding and arguments + * of the created function, while it's called less than `n` times. Subsequent + * calls to the created function return the result of the last `func` invocation. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Function + * @param {number} n The number of calls at which `func` is no longer invoked. + * @param {Function} func The function to restrict. + * @returns {Function} Returns the new restricted function. + * @example + * + * jQuery(element).on('click', _.before(5, addContactToList)); + * // => Allows adding up to 4 contacts to the list. + */ + function before(n, func) { + var result; + if (typeof func != 'function') { + throw new TypeError(FUNC_ERROR_TEXT); + } + n = toInteger(n); + return function() { + if (--n > 0) { + result = func.apply(this, arguments); + } + if (n <= 1) { + func = undefined; + } + return result; + }; + } + + /** + * Creates a function that invokes `func` with the `this` binding of `thisArg` + * and `partials` prepended to the arguments it receives. + * + * The `_.bind.placeholder` value, which defaults to `_` in monolithic builds, + * may be used as a placeholder for partially applied arguments. + * + * **Note:** Unlike native `Function#bind`, this method doesn't set the "length" + * property of bound functions. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Function + * @param {Function} func The function to bind. + * @param {*} thisArg The `this` binding of `func`. + * @param {...*} [partials] The arguments to be partially applied. + * @returns {Function} Returns the new bound function. + * @example + * + * function greet(greeting, punctuation) { + * return greeting + ' ' + this.user + punctuation; + * } + * + * var object = { 'user': 'fred' }; + * + * var bound = _.bind(greet, object, 'hi'); + * bound('!'); + * // => 'hi fred!' + * + * // Bound with placeholders. + * var bound = _.bind(greet, object, _, '!'); + * bound('hi'); + * // => 'hi fred!' + */ + var bind = baseRest(function(func, thisArg, partials) { + return createPartial(func, BIND_FLAG | PARTIAL_FLAG, thisArg, partials); + }); + + /** + * Defers invoking the `func` until the current call stack has cleared. Any + * additional arguments are provided to `func` when it's invoked. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Function + * @param {Function} func The function to defer. + * @param {...*} [args] The arguments to invoke `func` with. + * @returns {number} Returns the timer id. + * @example + * + * _.defer(function(text) { + * console.log(text); + * }, 'deferred'); + * // => Logs 'deferred' after one millisecond. + */ + var defer = baseRest(function(func, args) { + return baseDelay(func, 1, args); + }); + + /** + * Invokes `func` after `wait` milliseconds. Any additional arguments are + * provided to `func` when it's invoked. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Function + * @param {Function} func The function to delay. + * @param {number} wait The number of milliseconds to delay invocation. + * @param {...*} [args] The arguments to invoke `func` with. + * @returns {number} Returns the timer id. + * @example + * + * _.delay(function(text) { + * console.log(text); + * }, 1000, 'later'); + * // => Logs 'later' after one second. + */ + var delay = baseRest(function(func, wait, args) { + return baseDelay(func, toNumber(wait) || 0, args); + }); + + /** + * Creates a function that negates the result of the predicate `func`. The + * `func` predicate is invoked with the `this` binding and arguments of the + * created function. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Function + * @param {Function} predicate The predicate to negate. + * @returns {Function} Returns the new negated function. + * @example + * + * function isEven(n) { + * return n % 2 == 0; + * } + * + * _.filter([1, 2, 3, 4, 5, 6], _.negate(isEven)); + * // => [1, 3, 5] + */ + function negate(predicate) { + if (typeof predicate != 'function') { + throw new TypeError(FUNC_ERROR_TEXT); + } + return function() { + var args = arguments; + return !predicate.apply(this, args); + }; + } + + /** + * Creates a function that is restricted to invoking `func` once. Repeat calls + * to the function return the value of the first invocation. The `func` is + * invoked with the `this` binding and arguments of the created function. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Function + * @param {Function} func The function to restrict. + * @returns {Function} Returns the new restricted function. + * @example + * + * var initialize = _.once(createApplication); + * initialize(); + * initialize(); + * // => `createApplication` is invoked once + */ + function once(func) { + return before(2, func); + } + + /*------------------------------------------------------------------------*/ + + /** + * Creates a shallow clone of `value`. + * + * **Note:** This method is loosely based on the + * [structured clone algorithm](https://mdn.io/Structured_clone_algorithm) + * and supports cloning arrays, array buffers, booleans, date objects, maps, + * numbers, `Object` objects, regexes, sets, strings, symbols, and typed + * arrays. The own enumerable properties of `arguments` objects are cloned + * as plain objects. An empty object is returned for uncloneable values such + * as error objects, functions, DOM nodes, and WeakMaps. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to clone. + * @returns {*} Returns the cloned value. + * @see _.cloneDeep + * @example + * + * var objects = [{ 'a': 1 }, { 'b': 2 }]; + * + * var shallow = _.clone(objects); + * console.log(shallow[0] === objects[0]); + * // => true + */ + function clone(value) { + if (!isObject(value)) { + return value; + } + return isArray(value) ? copyArray(value) : copyObject(value, nativeKeys(value)); + } + + /** + * Performs a + * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero) + * comparison between two values to determine if they are equivalent. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to compare. + * @param {*} other The other value to compare. + * @returns {boolean} Returns `true` if the values are equivalent, else `false`. + * @example + * + * var object = { 'a': 1 }; + * var other = { 'a': 1 }; + * + * _.eq(object, object); + * // => true + * + * _.eq(object, other); + * // => false + * + * _.eq('a', 'a'); + * // => true + * + * _.eq('a', Object('a')); + * // => false + * + * _.eq(NaN, NaN); + * // => true + */ + function eq(value, other) { + return value === other || (value !== value && other !== other); + } + + /** + * Checks if `value` is likely an `arguments` object. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is an `arguments` object, + * else `false`. + * @example + * + * _.isArguments(function() { return arguments; }()); + * // => true + * + * _.isArguments([1, 2, 3]); + * // => false + */ + var isArguments = baseIsArguments(function() { return arguments; }()) ? baseIsArguments : function(value) { + return isObjectLike(value) && hasOwnProperty.call(value, 'callee') && + !propertyIsEnumerable.call(value, 'callee'); + }; + + /** + * Checks if `value` is classified as an `Array` object. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is an array, else `false`. + * @example + * + * _.isArray([1, 2, 3]); + * // => true + * + * _.isArray(document.body.children); + * // => false + * + * _.isArray('abc'); + * // => false + * + * _.isArray(_.noop); + * // => false + */ + var isArray = Array.isArray; + + /** + * Checks if `value` is array-like. A value is considered array-like if it's + * not a function and has a `value.length` that's an integer greater than or + * equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is array-like, else `false`. + * @example + * + * _.isArrayLike([1, 2, 3]); + * // => true + * + * _.isArrayLike(document.body.children); + * // => true + * + * _.isArrayLike('abc'); + * // => true + * + * _.isArrayLike(_.noop); + * // => false + */ + function isArrayLike(value) { + return value != null && isLength(value.length) && !isFunction(value); + } + + /** + * Checks if `value` is classified as a boolean primitive or object. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a boolean, else `false`. + * @example + * + * _.isBoolean(false); + * // => true + * + * _.isBoolean(null); + * // => false + */ + function isBoolean(value) { + return value === true || value === false || + (isObjectLike(value) && objectToString.call(value) == boolTag); + } + + /** + * Checks if `value` is classified as a `Date` object. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a date object, else `false`. + * @example + * + * _.isDate(new Date); + * // => true + * + * _.isDate('Mon April 23 2012'); + * // => false + */ + var isDate = baseIsDate; + + /** + * Checks if `value` is an empty object, collection, map, or set. + * + * Objects are considered empty if they have no own enumerable string keyed + * properties. + * + * Array-like values such as `arguments` objects, arrays, buffers, strings, or + * jQuery-like collections are considered empty if they have a `length` of `0`. + * Similarly, maps and sets are considered empty if they have a `size` of `0`. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is empty, else `false`. + * @example + * + * _.isEmpty(null); + * // => true + * + * _.isEmpty(true); + * // => true + * + * _.isEmpty(1); + * // => true + * + * _.isEmpty([1, 2, 3]); + * // => false + * + * _.isEmpty({ 'a': 1 }); + * // => false + */ + function isEmpty(value) { + if (isArrayLike(value) && + (isArray(value) || isString(value) || + isFunction(value.splice) || isArguments(value))) { + return !value.length; + } + return !nativeKeys(value).length; + } + + /** + * Performs a deep comparison between two values to determine if they are + * equivalent. + * + * **Note:** This method supports comparing arrays, array buffers, booleans, + * date objects, error objects, maps, numbers, `Object` objects, regexes, + * sets, strings, symbols, and typed arrays. `Object` objects are compared + * by their own, not inherited, enumerable properties. Functions and DOM + * nodes are **not** supported. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to compare. + * @param {*} other The other value to compare. + * @returns {boolean} Returns `true` if the values are equivalent, else `false`. + * @example + * + * var object = { 'a': 1 }; + * var other = { 'a': 1 }; + * + * _.isEqual(object, other); + * // => true + * + * object === other; + * // => false + */ + function isEqual(value, other) { + return baseIsEqual(value, other); + } + + /** + * Checks if `value` is a finite primitive number. + * + * **Note:** This method is based on + * [`Number.isFinite`](https://mdn.io/Number/isFinite). + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a finite number, else `false`. + * @example + * + * _.isFinite(3); + * // => true + * + * _.isFinite(Number.MIN_VALUE); + * // => true + * + * _.isFinite(Infinity); + * // => false + * + * _.isFinite('3'); + * // => false + */ + function isFinite(value) { + return typeof value == 'number' && nativeIsFinite(value); + } + + /** + * Checks if `value` is classified as a `Function` object. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a function, else `false`. + * @example + * + * _.isFunction(_); + * // => true + * + * _.isFunction(/abc/); + * // => false + */ + function isFunction(value) { + // The use of `Object#toString` avoids issues with the `typeof` operator + // in Safari 9 which returns 'object' for typed array and other constructors. + var tag = isObject(value) ? objectToString.call(value) : ''; + return tag == funcTag || tag == genTag || tag == proxyTag; + } + + /** + * Checks if `value` is a valid array-like length. + * + * **Note:** This method is loosely based on + * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a valid length, else `false`. + * @example + * + * _.isLength(3); + * // => true + * + * _.isLength(Number.MIN_VALUE); + * // => false + * + * _.isLength(Infinity); + * // => false + * + * _.isLength('3'); + * // => false + */ + function isLength(value) { + return typeof value == 'number' && + value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER; + } + + /** + * Checks if `value` is the + * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types) + * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`) + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is an object, else `false`. + * @example + * + * _.isObject({}); + * // => true + * + * _.isObject([1, 2, 3]); + * // => true + * + * _.isObject(_.noop); + * // => true + * + * _.isObject(null); + * // => false + */ + function isObject(value) { + var type = typeof value; + return value != null && (type == 'object' || type == 'function'); + } + + /** + * Checks if `value` is object-like. A value is object-like if it's not `null` + * and has a `typeof` result of "object". + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is object-like, else `false`. + * @example + * + * _.isObjectLike({}); + * // => true + * + * _.isObjectLike([1, 2, 3]); + * // => true + * + * _.isObjectLike(_.noop); + * // => false + * + * _.isObjectLike(null); + * // => false + */ + function isObjectLike(value) { + return value != null && typeof value == 'object'; + } + + /** + * Checks if `value` is `NaN`. + * + * **Note:** This method is based on + * [`Number.isNaN`](https://mdn.io/Number/isNaN) and is not the same as + * global [`isNaN`](https://mdn.io/isNaN) which returns `true` for + * `undefined` and other non-number values. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is `NaN`, else `false`. + * @example + * + * _.isNaN(NaN); + * // => true + * + * _.isNaN(new Number(NaN)); + * // => true + * + * isNaN(undefined); + * // => true + * + * _.isNaN(undefined); + * // => false + */ + function isNaN(value) { + // An `NaN` primitive is the only value that is not equal to itself. + // Perform the `toStringTag` check first to avoid errors with some + // ActiveX objects in IE. + return isNumber(value) && value != +value; + } + + /** + * Checks if `value` is `null`. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is `null`, else `false`. + * @example + * + * _.isNull(null); + * // => true + * + * _.isNull(void 0); + * // => false + */ + function isNull(value) { + return value === null; + } + + /** + * Checks if `value` is classified as a `Number` primitive or object. + * + * **Note:** To exclude `Infinity`, `-Infinity`, and `NaN`, which are + * classified as numbers, use the `_.isFinite` method. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a number, else `false`. + * @example + * + * _.isNumber(3); + * // => true + * + * _.isNumber(Number.MIN_VALUE); + * // => true + * + * _.isNumber(Infinity); + * // => true + * + * _.isNumber('3'); + * // => false + */ + function isNumber(value) { + return typeof value == 'number' || + (isObjectLike(value) && objectToString.call(value) == numberTag); + } + + /** + * Checks if `value` is classified as a `RegExp` object. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a regexp, else `false`. + * @example + * + * _.isRegExp(/abc/); + * // => true + * + * _.isRegExp('/abc/'); + * // => false + */ + var isRegExp = baseIsRegExp; + + /** + * Checks if `value` is classified as a `String` primitive or object. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a string, else `false`. + * @example + * + * _.isString('abc'); + * // => true + * + * _.isString(1); + * // => false + */ + function isString(value) { + return typeof value == 'string' || + (!isArray(value) && isObjectLike(value) && objectToString.call(value) == stringTag); + } + + /** + * Checks if `value` is `undefined`. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is `undefined`, else `false`. + * @example + * + * _.isUndefined(void 0); + * // => true + * + * _.isUndefined(null); + * // => false + */ + function isUndefined(value) { + return value === undefined; + } + + /** + * Converts `value` to an array. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Lang + * @param {*} value The value to convert. + * @returns {Array} Returns the converted array. + * @example + * + * _.toArray({ 'a': 1, 'b': 2 }); + * // => [1, 2] + * + * _.toArray('abc'); + * // => ['a', 'b', 'c'] + * + * _.toArray(1); + * // => [] + * + * _.toArray(null); + * // => [] + */ + function toArray(value) { + if (!isArrayLike(value)) { + return values(value); + } + return value.length ? copyArray(value) : []; + } + + /** + * Converts `value` to an integer. + * + * **Note:** This method is loosely based on + * [`ToInteger`](http://www.ecma-international.org/ecma-262/7.0/#sec-tointeger). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to convert. + * @returns {number} Returns the converted integer. + * @example + * + * _.toInteger(3.2); + * // => 3 + * + * _.toInteger(Number.MIN_VALUE); + * // => 0 + * + * _.toInteger(Infinity); + * // => 1.7976931348623157e+308 + * + * _.toInteger('3.2'); + * // => 3 + */ + var toInteger = Number; + + /** + * Converts `value` to a number. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to process. + * @returns {number} Returns the number. + * @example + * + * _.toNumber(3.2); + * // => 3.2 + * + * _.toNumber(Number.MIN_VALUE); + * // => 5e-324 + * + * _.toNumber(Infinity); + * // => Infinity + * + * _.toNumber('3.2'); + * // => 3.2 + */ + var toNumber = Number; + + /** + * Converts `value` to a string. An empty string is returned for `null` + * and `undefined` values. The sign of `-0` is preserved. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to convert. + * @returns {string} Returns the converted string. + * @example + * + * _.toString(null); + * // => '' + * + * _.toString(-0); + * // => '-0' + * + * _.toString([1, 2, 3]); + * // => '1,2,3' + */ + function toString(value) { + if (typeof value == 'string') { + return value; + } + return value == null ? '' : (value + ''); + } + + /*------------------------------------------------------------------------*/ + + /** + * Assigns own enumerable string keyed properties of source objects to the + * destination object. Source objects are applied from left to right. + * Subsequent sources overwrite property assignments of previous sources. + * + * **Note:** This method mutates `object` and is loosely based on + * [`Object.assign`](https://mdn.io/Object/assign). + * + * @static + * @memberOf _ + * @since 0.10.0 + * @category Object + * @param {Object} object The destination object. + * @param {...Object} [sources] The source objects. + * @returns {Object} Returns `object`. + * @see _.assignIn + * @example + * + * function Foo() { + * this.a = 1; + * } + * + * function Bar() { + * this.c = 3; + * } + * + * Foo.prototype.b = 2; + * Bar.prototype.d = 4; + * + * _.assign({ 'a': 0 }, new Foo, new Bar); + * // => { 'a': 1, 'c': 3 } + */ + var assign = createAssigner(function(object, source) { + copyObject(source, nativeKeys(source), object); + }); + + /** + * This method is like `_.assign` except that it iterates over own and + * inherited source properties. + * + * **Note:** This method mutates `object`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @alias extend + * @category Object + * @param {Object} object The destination object. + * @param {...Object} [sources] The source objects. + * @returns {Object} Returns `object`. + * @see _.assign + * @example + * + * function Foo() { + * this.a = 1; + * } + * + * function Bar() { + * this.c = 3; + * } + * + * Foo.prototype.b = 2; + * Bar.prototype.d = 4; + * + * _.assignIn({ 'a': 0 }, new Foo, new Bar); + * // => { 'a': 1, 'b': 2, 'c': 3, 'd': 4 } + */ + var assignIn = createAssigner(function(object, source) { + copyObject(source, nativeKeysIn(source), object); + }); + + /** + * This method is like `_.assignIn` except that it accepts `customizer` + * which is invoked to produce the assigned values. If `customizer` returns + * `undefined`, assignment is handled by the method instead. The `customizer` + * is invoked with five arguments: (objValue, srcValue, key, object, source). + * + * **Note:** This method mutates `object`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @alias extendWith + * @category Object + * @param {Object} object The destination object. + * @param {...Object} sources The source objects. + * @param {Function} [customizer] The function to customize assigned values. + * @returns {Object} Returns `object`. + * @see _.assignWith + * @example + * + * function customizer(objValue, srcValue) { + * return _.isUndefined(objValue) ? srcValue : objValue; + * } + * + * var defaults = _.partialRight(_.assignInWith, customizer); + * + * defaults({ 'a': 1 }, { 'b': 2 }, { 'a': 3 }); + * // => { 'a': 1, 'b': 2 } + */ + var assignInWith = createAssigner(function(object, source, srcIndex, customizer) { + copyObject(source, keysIn(source), object, customizer); + }); + + /** + * Creates an object that inherits from the `prototype` object. If a + * `properties` object is given, its own enumerable string keyed properties + * are assigned to the created object. + * + * @static + * @memberOf _ + * @since 2.3.0 + * @category Object + * @param {Object} prototype The object to inherit from. + * @param {Object} [properties] The properties to assign to the object. + * @returns {Object} Returns the new object. + * @example + * + * function Shape() { + * this.x = 0; + * this.y = 0; + * } + * + * function Circle() { + * Shape.call(this); + * } + * + * Circle.prototype = _.create(Shape.prototype, { + * 'constructor': Circle + * }); + * + * var circle = new Circle; + * circle instanceof Circle; + * // => true + * + * circle instanceof Shape; + * // => true + */ + function create(prototype, properties) { + var result = baseCreate(prototype); + return properties ? assign(result, properties) : result; + } + + /** + * Assigns own and inherited enumerable string keyed properties of source + * objects to the destination object for all destination properties that + * resolve to `undefined`. Source objects are applied from left to right. + * Once a property is set, additional values of the same property are ignored. + * + * **Note:** This method mutates `object`. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Object + * @param {Object} object The destination object. + * @param {...Object} [sources] The source objects. + * @returns {Object} Returns `object`. + * @see _.defaultsDeep + * @example + * + * _.defaults({ 'a': 1 }, { 'b': 2 }, { 'a': 3 }); + * // => { 'a': 1, 'b': 2 } + */ + var defaults = baseRest(function(args) { + args.push(undefined, assignInDefaults); + return assignInWith.apply(undefined, args); + }); + + /** + * Checks if `path` is a direct property of `object`. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Object + * @param {Object} object The object to query. + * @param {Array|string} path The path to check. + * @returns {boolean} Returns `true` if `path` exists, else `false`. + * @example + * + * var object = { 'a': { 'b': 2 } }; + * var other = _.create({ 'a': _.create({ 'b': 2 }) }); + * + * _.has(object, 'a'); + * // => true + * + * _.has(object, 'a.b'); + * // => true + * + * _.has(object, ['a', 'b']); + * // => true + * + * _.has(other, 'a'); + * // => false + */ + function has(object, path) { + return object != null && hasOwnProperty.call(object, path); + } + + /** + * Creates an array of the own enumerable property names of `object`. + * + * **Note:** Non-object values are coerced to objects. See the + * [ES spec](http://ecma-international.org/ecma-262/7.0/#sec-object.keys) + * for more details. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Object + * @param {Object} object The object to query. + * @returns {Array} Returns the array of property names. + * @example + * + * function Foo() { + * this.a = 1; + * this.b = 2; + * } + * + * Foo.prototype.c = 3; + * + * _.keys(new Foo); + * // => ['a', 'b'] (iteration order is not guaranteed) + * + * _.keys('hi'); + * // => ['0', '1'] + */ + var keys = nativeKeys; + + /** + * Creates an array of the own and inherited enumerable property names of `object`. + * + * **Note:** Non-object values are coerced to objects. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Object + * @param {Object} object The object to query. + * @returns {Array} Returns the array of property names. + * @example + * + * function Foo() { + * this.a = 1; + * this.b = 2; + * } + * + * Foo.prototype.c = 3; + * + * _.keysIn(new Foo); + * // => ['a', 'b', 'c'] (iteration order is not guaranteed) + */ + var keysIn = nativeKeysIn; + + /** + * Creates an object composed of the picked `object` properties. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Object + * @param {Object} object The source object. + * @param {...(string|string[])} [props] The property identifiers to pick. + * @returns {Object} Returns the new object. + * @example + * + * var object = { 'a': 1, 'b': '2', 'c': 3 }; + * + * _.pick(object, ['a', 'c']); + * // => { 'a': 1, 'c': 3 } + */ + var pick = flatRest(function(object, props) { + return object == null ? {} : basePick(object, baseMap(props, toKey)); + }); + + /** + * This method is like `_.get` except that if the resolved value is a + * function it's invoked with the `this` binding of its parent object and + * its result is returned. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Object + * @param {Object} object The object to query. + * @param {Array|string} path The path of the property to resolve. + * @param {*} [defaultValue] The value returned for `undefined` resolved values. + * @returns {*} Returns the resolved value. + * @example + * + * var object = { 'a': [{ 'b': { 'c1': 3, 'c2': _.constant(4) } }] }; + * + * _.result(object, 'a[0].b.c1'); + * // => 3 + * + * _.result(object, 'a[0].b.c2'); + * // => 4 + * + * _.result(object, 'a[0].b.c3', 'default'); + * // => 'default' + * + * _.result(object, 'a[0].b.c3', _.constant('default')); + * // => 'default' + */ + function result(object, path, defaultValue) { + var value = object == null ? undefined : object[path]; + if (value === undefined) { + value = defaultValue; + } + return isFunction(value) ? value.call(object) : value; + } + + /** + * Creates an array of the own enumerable string keyed property values of `object`. + * + * **Note:** Non-object values are coerced to objects. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Object + * @param {Object} object The object to query. + * @returns {Array} Returns the array of property values. + * @example + * + * function Foo() { + * this.a = 1; + * this.b = 2; + * } + * + * Foo.prototype.c = 3; + * + * _.values(new Foo); + * // => [1, 2] (iteration order is not guaranteed) + * + * _.values('hi'); + * // => ['h', 'i'] + */ + function values(object) { + return object ? baseValues(object, keys(object)) : []; + } + + /*------------------------------------------------------------------------*/ + + /** + * Converts the characters "&", "<", ">", '"', and "'" in `string` to their + * corresponding HTML entities. + * + * **Note:** No other characters are escaped. To escape additional + * characters use a third-party library like [_he_](https://mths.be/he). + * + * Though the ">" character is escaped for symmetry, characters like + * ">" and "/" don't need escaping in HTML and have no special meaning + * unless they're part of a tag or unquoted attribute value. See + * [Mathias Bynens's article](https://mathiasbynens.be/notes/ambiguous-ampersands) + * (under "semi-related fun fact") for more details. + * + * When working with HTML you should always + * [quote attribute values](http://wonko.com/post/html-escaping) to reduce + * XSS vectors. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category String + * @param {string} [string=''] The string to escape. + * @returns {string} Returns the escaped string. + * @example + * + * _.escape('fred, barney, & pebbles'); + * // => 'fred, barney, & pebbles' + */ + function escape(string) { + string = toString(string); + return (string && reHasUnescapedHtml.test(string)) + ? string.replace(reUnescapedHtml, escapeHtmlChar) + : string; + } + + /*------------------------------------------------------------------------*/ + + /** + * This method returns the first argument it receives. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Util + * @param {*} value Any value. + * @returns {*} Returns `value`. + * @example + * + * var object = { 'a': 1 }; + * + * console.log(_.identity(object) === object); + * // => true + */ + function identity(value) { + return value; + } + + /** + * Creates a function that invokes `func` with the arguments of the created + * function. If `func` is a property name, the created function returns the + * property value for a given element. If `func` is an array or object, the + * created function returns `true` for elements that contain the equivalent + * source properties, otherwise it returns `false`. + * + * @static + * @since 4.0.0 + * @memberOf _ + * @category Util + * @param {*} [func=_.identity] The value to convert to a callback. + * @returns {Function} Returns the callback. + * @example + * + * var users = [ + * { 'user': 'barney', 'age': 36, 'active': true }, + * { 'user': 'fred', 'age': 40, 'active': false } + * ]; + * + * // The `_.matches` iteratee shorthand. + * _.filter(users, _.iteratee({ 'user': 'barney', 'active': true })); + * // => [{ 'user': 'barney', 'age': 36, 'active': true }] + * + * // The `_.matchesProperty` iteratee shorthand. + * _.filter(users, _.iteratee(['user', 'fred'])); + * // => [{ 'user': 'fred', 'age': 40 }] + * + * // The `_.property` iteratee shorthand. + * _.map(users, _.iteratee('user')); + * // => ['barney', 'fred'] + * + * // Create custom iteratee shorthands. + * _.iteratee = _.wrap(_.iteratee, function(iteratee, func) { + * return !_.isRegExp(func) ? iteratee(func) : function(string) { + * return func.test(string); + * }; + * }); + * + * _.filter(['abc', 'def'], /ef/); + * // => ['def'] + */ + var iteratee = baseIteratee; + + /** + * Creates a function that performs a partial deep comparison between a given + * object and `source`, returning `true` if the given object has equivalent + * property values, else `false`. + * + * **Note:** The created function is equivalent to `_.isMatch` with `source` + * partially applied. + * + * Partial comparisons will match empty array and empty object `source` + * values against any array or object value, respectively. See `_.isEqual` + * for a list of supported value comparisons. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Util + * @param {Object} source The object of property values to match. + * @returns {Function} Returns the new spec function. + * @example + * + * var objects = [ + * { 'a': 1, 'b': 2, 'c': 3 }, + * { 'a': 4, 'b': 5, 'c': 6 } + * ]; + * + * _.filter(objects, _.matches({ 'a': 4, 'c': 6 })); + * // => [{ 'a': 4, 'b': 5, 'c': 6 }] + */ + function matches(source) { + return baseMatches(assign({}, source)); + } + + /** + * Adds all own enumerable string keyed function properties of a source + * object to the destination object. If `object` is a function, then methods + * are added to its prototype as well. + * + * **Note:** Use `_.runInContext` to create a pristine `lodash` function to + * avoid conflicts caused by modifying the original. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Util + * @param {Function|Object} [object=lodash] The destination object. + * @param {Object} source The object of functions to add. + * @param {Object} [options={}] The options object. + * @param {boolean} [options.chain=true] Specify whether mixins are chainable. + * @returns {Function|Object} Returns `object`. + * @example + * + * function vowels(string) { + * return _.filter(string, function(v) { + * return /[aeiou]/i.test(v); + * }); + * } + * + * _.mixin({ 'vowels': vowels }); + * _.vowels('fred'); + * // => ['e'] + * + * _('fred').vowels().value(); + * // => ['e'] + * + * _.mixin({ 'vowels': vowels }, { 'chain': false }); + * _('fred').vowels(); + * // => ['e'] + */ + function mixin(object, source, options) { + var props = keys(source), + methodNames = baseFunctions(source, props); + + if (options == null && + !(isObject(source) && (methodNames.length || !props.length))) { + options = source; + source = object; + object = this; + methodNames = baseFunctions(source, keys(source)); + } + var chain = !(isObject(options) && 'chain' in options) || !!options.chain, + isFunc = isFunction(object); + + baseEach(methodNames, function(methodName) { + var func = source[methodName]; + object[methodName] = func; + if (isFunc) { + object.prototype[methodName] = function() { + var chainAll = this.__chain__; + if (chain || chainAll) { + var result = object(this.__wrapped__), + actions = result.__actions__ = copyArray(this.__actions__); + + actions.push({ 'func': func, 'args': arguments, 'thisArg': object }); + result.__chain__ = chainAll; + return result; + } + return func.apply(object, arrayPush([this.value()], arguments)); + }; + } + }); + + return object; + } + + /** + * Reverts the `_` variable to its previous value and returns a reference to + * the `lodash` function. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Util + * @returns {Function} Returns the `lodash` function. + * @example + * + * var lodash = _.noConflict(); + */ + function noConflict() { + if (root._ === this) { + root._ = oldDash; + } + return this; + } + + /** + * This method returns `undefined`. + * + * @static + * @memberOf _ + * @since 2.3.0 + * @category Util + * @example + * + * _.times(2, _.noop); + * // => [undefined, undefined] + */ + function noop() { + // No operation performed. + } + + /** + * Generates a unique ID. If `prefix` is given, the ID is appended to it. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Util + * @param {string} [prefix=''] The value to prefix the ID with. + * @returns {string} Returns the unique ID. + * @example + * + * _.uniqueId('contact_'); + * // => 'contact_104' + * + * _.uniqueId(); + * // => '105' + */ + function uniqueId(prefix) { + var id = ++idCounter; + return toString(prefix) + id; + } + + /*------------------------------------------------------------------------*/ + + /** + * Computes the maximum value of `array`. If `array` is empty or falsey, + * `undefined` is returned. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Math + * @param {Array} array The array to iterate over. + * @returns {*} Returns the maximum value. + * @example + * + * _.max([4, 2, 8, 6]); + * // => 8 + * + * _.max([]); + * // => undefined + */ + function max(array) { + return (array && array.length) + ? baseExtremum(array, identity, baseGt) + : undefined; + } + + /** + * Computes the minimum value of `array`. If `array` is empty or falsey, + * `undefined` is returned. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Math + * @param {Array} array The array to iterate over. + * @returns {*} Returns the minimum value. + * @example + * + * _.min([4, 2, 8, 6]); + * // => 2 + * + * _.min([]); + * // => undefined + */ + function min(array) { + return (array && array.length) + ? baseExtremum(array, identity, baseLt) + : undefined; + } + + /*------------------------------------------------------------------------*/ + + // Add methods that return wrapped values in chain sequences. + lodash.assignIn = assignIn; + lodash.before = before; + lodash.bind = bind; + lodash.chain = chain; + lodash.compact = compact; + lodash.concat = concat; + lodash.create = create; + lodash.defaults = defaults; + lodash.defer = defer; + lodash.delay = delay; + lodash.filter = filter; + lodash.flatten = flatten; + lodash.flattenDeep = flattenDeep; + lodash.iteratee = iteratee; + lodash.keys = keys; + lodash.map = map; + lodash.matches = matches; + lodash.mixin = mixin; + lodash.negate = negate; + lodash.once = once; + lodash.pick = pick; + lodash.slice = slice; + lodash.sortBy = sortBy; + lodash.tap = tap; + lodash.thru = thru; + lodash.toArray = toArray; + lodash.values = values; + + // Add aliases. + lodash.extend = assignIn; + + // Add methods to `lodash.prototype`. + mixin(lodash, lodash); + + /*------------------------------------------------------------------------*/ + + // Add methods that return unwrapped values in chain sequences. + lodash.clone = clone; + lodash.escape = escape; + lodash.every = every; + lodash.find = find; + lodash.forEach = forEach; + lodash.has = has; + lodash.head = head; + lodash.identity = identity; + lodash.indexOf = indexOf; + lodash.isArguments = isArguments; + lodash.isArray = isArray; + lodash.isBoolean = isBoolean; + lodash.isDate = isDate; + lodash.isEmpty = isEmpty; + lodash.isEqual = isEqual; + lodash.isFinite = isFinite; + lodash.isFunction = isFunction; + lodash.isNaN = isNaN; + lodash.isNull = isNull; + lodash.isNumber = isNumber; + lodash.isObject = isObject; + lodash.isRegExp = isRegExp; + lodash.isString = isString; + lodash.isUndefined = isUndefined; + lodash.last = last; + lodash.max = max; + lodash.min = min; + lodash.noConflict = noConflict; + lodash.noop = noop; + lodash.reduce = reduce; + lodash.result = result; + lodash.size = size; + lodash.some = some; + lodash.uniqueId = uniqueId; + + // Add aliases. + lodash.each = forEach; + lodash.first = head; + + mixin(lodash, (function() { + var source = {}; + baseForOwn(lodash, function(func, methodName) { + if (!hasOwnProperty.call(lodash.prototype, methodName)) { + source[methodName] = func; + } + }); + return source; + }()), { 'chain': false }); + + /*------------------------------------------------------------------------*/ + + /** + * The semantic version number. + * + * @static + * @memberOf _ + * @type {string} + */ + lodash.VERSION = VERSION; + + // Add `Array` methods to `lodash.prototype`. + baseEach(['pop', 'join', 'replace', 'reverse', 'split', 'push', 'shift', 'sort', 'splice', 'unshift'], function(methodName) { + var func = (/^(?:replace|split)$/.test(methodName) ? String.prototype : arrayProto)[methodName], + chainName = /^(?:push|sort|unshift)$/.test(methodName) ? 'tap' : 'thru', + retUnwrapped = /^(?:pop|join|replace|shift)$/.test(methodName); + + lodash.prototype[methodName] = function() { + var args = arguments; + if (retUnwrapped && !this.__chain__) { + var value = this.value(); + return func.apply(isArray(value) ? value : [], args); + } + return this[chainName](function(value) { + return func.apply(isArray(value) ? value : [], args); + }); + }; + }); + + // Add chain sequence methods to the `lodash` wrapper. + lodash.prototype.toJSON = lodash.prototype.valueOf = lodash.prototype.value = wrapperValue; + + /*--------------------------------------------------------------------------*/ + + // Some AMD build optimizers, like r.js, check for condition patterns like: + if (typeof define == 'function' && typeof define.amd == 'object' && define.amd) { + // Expose Lodash on the global object to prevent errors when Lodash is + // loaded by a script tag in the presence of an AMD loader. + // See http://requirejs.org/docs/errors.html#mismatch for more details. + // Use `_.noConflict` to remove Lodash from the global object. + root._ = lodash; + + // Define as an anonymous module so, through path mapping, it can be + // referenced as the "underscore" module. + define(function() { + return lodash; + }); + } + // Check for `exports` after `define` in case a build optimizer adds it. + else if (freeModule) { + // Export for Node.js. + (freeModule.exports = lodash)._ = lodash; + // Export for CommonJS support. + freeExports._ = lodash; + } + else { + // Export to the global object. + root._ = lodash; + } +}.call(this)); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/core.min.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/core.min.js new file mode 100644 index 0000000..c1fb1cd --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/core.min.js @@ -0,0 +1,29 @@ +/** + * @license + * lodash (Custom Build) /license | Underscore.js 1.8.3 underscorejs.org/LICENSE + * Build: `lodash core -o ./dist/lodash.core.js` + */ +;(function(){function n(n){return K(n)&&pn.call(n,"callee")&&!bn.call(n,"callee")}function t(n,t){return n.push.apply(n,t),n}function r(n){return function(t){return null==t?nn:t[n]}}function e(n,t,r,e,u){return u(n,function(n,u,o){r=e?(e=false,n):t(r,n,u,o)}),r}function u(n,t){return d(t,function(t){return n[t]})}function o(n){return n instanceof i?n:new i(n)}function i(n,t){this.__wrapped__=n,this.__actions__=[],this.__chain__=!!t}function c(n,t,r,e){return n===nn||M(n,ln[r])&&!pn.call(e,r)?t:n}function f(n,t,r){ +if(typeof n!="function")throw new TypeError("Expected a function");return setTimeout(function(){n.apply(nn,r)},t)}function a(n,t){var r=true;return mn(n,function(n,e,u){return r=!!t(n,e,u)}),r}function l(n,t,r){for(var e=-1,u=n.length;++et}function b(n,t,r,e,u){return n===t||(null==n||null==t||!H(n)&&!K(t)?n!==n&&t!==t:g(n,t,b,r,e,u))}function g(n,t,r,e,u,o){var i=Sn(n),c=Sn(t),f="[object Array]",a="[object Array]";i||(f=hn.call(n),f="[object Arguments]"==f?"[object Object]":f),c||(a=hn.call(t),a="[object Arguments]"==a?"[object Object]":a);var l="[object Object]"==f,c="[object Object]"==a,a=f==a;o||(o=[]); +var p=En(o,function(t){return t[0]==n}),s=En(o,function(n){return n[0]==t});if(p&&s)return p[1]==t;if(o.push([n,t]),o.push([t,n]),a&&!l){if(i)r=B(n,t,r,e,u,o);else n:{switch(f){case"[object Boolean]":case"[object Date]":case"[object Number]":r=M(+n,+t);break n;case"[object Error]":r=n.name==t.name&&n.message==t.message;break n;case"[object RegExp]":case"[object String]":r=n==t+"";break n}r=false}return o.pop(),r}return 2&u||(i=l&&pn.call(n,"__wrapped__"),f=c&&pn.call(t,"__wrapped__"),!i&&!f)?!!a&&(r=R(n,t,r,e,u,o), +o.pop(),r):(i=i?n.value():n,f=f?t.value():t,r=r(i,f,e,u,o),o.pop(),r)}function _(n){return typeof n=="function"?n:null==n?Y:(typeof n=="object"?m:r)(n)}function j(n,t){return nt&&(t=-t>u?0:u+t),r=r>u?u:r,0>r&&(r+=u),u=t>r?0:r-t>>>0,t>>>=0,r=Array(u);++ei))return false;for(var c=-1,f=true,a=1&u?[]:nn;++cr?jn(e+r,0):r:0,r=(r||0)-1;for(var u=t===t;++rarguments.length,mn); +}function J(n,t){var r;if(typeof t!="function")throw new TypeError("Expected a function");return n=Tn(n),function(){return 0<--n&&(r=t.apply(this,arguments)),1>=n&&(t=nn),r}}function M(n,t){return n===t||n!==n&&t!==t}function U(n){var t;return(t=null!=n)&&(t=n.length,t=typeof t=="number"&&-1=t),t&&!V(n)}function V(n){return n=H(n)?hn.call(n):"","[object Function]"==n||"[object GeneratorFunction]"==n||"[object Proxy]"==n}function H(n){var t=typeof n;return null!=n&&("object"==t||"function"==t); +}function K(n){return null!=n&&typeof n=="object"}function L(n){return typeof n=="number"||K(n)&&"[object Number]"==hn.call(n)}function Q(n){return typeof n=="string"||!Sn(n)&&K(n)&&"[object String]"==hn.call(n)}function W(n){return typeof n=="string"?n:null==n?"":n+""}function X(n){return n?u(n,qn(n)):[]}function Y(n){return n}function Z(n,r,e){var u=qn(r),o=v(r,u);null!=e||H(r)&&(o.length||!u.length)||(e=r,r=n,n=this,o=v(r,qn(r)));var i=!(H(e)&&"chain"in e&&!e.chain),c=V(n);return mn(o,function(e){ +var u=r[e];n[e]=u,c&&(n.prototype[e]=function(){var r=this.__chain__;if(i||r){var e=n(this.__wrapped__);return(e.__actions__=E(this.__actions__)).push({func:u,args:arguments,thisArg:n}),e.__chain__=r,e}return u.apply(n,t([this.value()],arguments))})}),n}var nn,tn=1/0,rn=/[&<>"']/g,en=RegExp(rn.source),un=typeof self=="object"&&self&&self.Object===Object&&self,on=typeof global=="object"&&global&&global.Object===Object&&global||un||Function("return this")(),cn=(un=typeof exports=="object"&&exports&&!exports.nodeType&&exports)&&typeof module=="object"&&module&&!module.nodeType&&module,fn=function(n){ +return function(t){return null==n?nn:n[t]}}({"&":"&","<":"<",">":">",'"':""","'":"'"}),an=Array.prototype,ln=Object.prototype,pn=ln.hasOwnProperty,sn=0,hn=ln.toString,vn=on._,yn=Object.create,bn=ln.propertyIsEnumerable,gn=on.isFinite,_n=function(n,t){return function(r){return n(t(r))}}(Object.keys,Object),jn=Math.max,dn=function(){function n(){}return function(t){return H(t)?yn?yn(t):(n.prototype=t,t=new n,n.prototype=nn,t):{}}}();i.prototype=dn(o.prototype),i.prototype.constructor=i; +var mn=function(n,t){return function(r,e){if(null==r)return r;if(!U(r))return n(r,e);for(var u=r.length,o=t?u:-1,i=Object(r);(t?o--:++or&&(r=jn(e+r,0));n:{for(t=_(t),e=n.length,r+=-1;++re||o&&c&&a||!u&&a||!i){r=1;break n}if(!o&&r { '4': 1, '6': 2 } + * + * // The `_.property` iteratee shorthand. + * _.countBy(['one', 'two', 'three'], 'length'); + * // => { '3': 2, '5': 1 } + */ +var countBy = createAggregator(function(result, value, key) { + if (hasOwnProperty.call(result, key)) { + ++result[key]; + } else { + baseAssignValue(result, key, 1); + } +}); + +module.exports = countBy; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/create.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/create.js new file mode 100644 index 0000000..a99067f --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/create.js @@ -0,0 +1,43 @@ +var baseAssign = require('./_baseAssign'), + baseCreate = require('./_baseCreate'); + +/** + * Creates an object that inherits from the `prototype` object. If a + * `properties` object is given, its own enumerable string keyed properties + * are assigned to the created object. + * + * @static + * @memberOf _ + * @since 2.3.0 + * @category Object + * @param {Object} prototype The object to inherit from. + * @param {Object} [properties] The properties to assign to the object. + * @returns {Object} Returns the new object. + * @example + * + * function Shape() { + * this.x = 0; + * this.y = 0; + * } + * + * function Circle() { + * Shape.call(this); + * } + * + * Circle.prototype = _.create(Shape.prototype, { + * 'constructor': Circle + * }); + * + * var circle = new Circle; + * circle instanceof Circle; + * // => true + * + * circle instanceof Shape; + * // => true + */ +function create(prototype, properties) { + var result = baseCreate(prototype); + return properties ? baseAssign(result, properties) : result; +} + +module.exports = create; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/curry.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/curry.js new file mode 100644 index 0000000..ce3910b --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/curry.js @@ -0,0 +1,57 @@ +var createWrap = require('./_createWrap'); + +/** Used to compose bitmasks for function metadata. */ +var CURRY_FLAG = 8; + +/** + * Creates a function that accepts arguments of `func` and either invokes + * `func` returning its result, if at least `arity` number of arguments have + * been provided, or returns a function that accepts the remaining `func` + * arguments, and so on. The arity of `func` may be specified if `func.length` + * is not sufficient. + * + * The `_.curry.placeholder` value, which defaults to `_` in monolithic builds, + * may be used as a placeholder for provided arguments. + * + * **Note:** This method doesn't set the "length" property of curried functions. + * + * @static + * @memberOf _ + * @since 2.0.0 + * @category Function + * @param {Function} func The function to curry. + * @param {number} [arity=func.length] The arity of `func`. + * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`. + * @returns {Function} Returns the new curried function. + * @example + * + * var abc = function(a, b, c) { + * return [a, b, c]; + * }; + * + * var curried = _.curry(abc); + * + * curried(1)(2)(3); + * // => [1, 2, 3] + * + * curried(1, 2)(3); + * // => [1, 2, 3] + * + * curried(1, 2, 3); + * // => [1, 2, 3] + * + * // Curried with placeholders. + * curried(1)(_, 3)(2); + * // => [1, 2, 3] + */ +function curry(func, arity, guard) { + arity = guard ? undefined : arity; + var result = createWrap(func, CURRY_FLAG, undefined, undefined, undefined, undefined, undefined, arity); + result.placeholder = curry.placeholder; + return result; +} + +// Assign default placeholders. +curry.placeholder = {}; + +module.exports = curry; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/curryRight.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/curryRight.js new file mode 100644 index 0000000..2b7691f --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/curryRight.js @@ -0,0 +1,54 @@ +var createWrap = require('./_createWrap'); + +/** Used to compose bitmasks for function metadata. */ +var CURRY_RIGHT_FLAG = 16; + +/** + * This method is like `_.curry` except that arguments are applied to `func` + * in the manner of `_.partialRight` instead of `_.partial`. + * + * The `_.curryRight.placeholder` value, which defaults to `_` in monolithic + * builds, may be used as a placeholder for provided arguments. + * + * **Note:** This method doesn't set the "length" property of curried functions. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Function + * @param {Function} func The function to curry. + * @param {number} [arity=func.length] The arity of `func`. + * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`. + * @returns {Function} Returns the new curried function. + * @example + * + * var abc = function(a, b, c) { + * return [a, b, c]; + * }; + * + * var curried = _.curryRight(abc); + * + * curried(3)(2)(1); + * // => [1, 2, 3] + * + * curried(2, 3)(1); + * // => [1, 2, 3] + * + * curried(1, 2, 3); + * // => [1, 2, 3] + * + * // Curried with placeholders. + * curried(3)(1, _)(2); + * // => [1, 2, 3] + */ +function curryRight(func, arity, guard) { + arity = guard ? undefined : arity; + var result = createWrap(func, CURRY_RIGHT_FLAG, undefined, undefined, undefined, undefined, undefined, arity); + result.placeholder = curryRight.placeholder; + return result; +} + +// Assign default placeholders. +curryRight.placeholder = {}; + +module.exports = curryRight; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/date.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/date.js new file mode 100644 index 0000000..cbf5b41 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/date.js @@ -0,0 +1,3 @@ +module.exports = { + 'now': require('./now') +}; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/debounce.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/debounce.js new file mode 100644 index 0000000..04d7dfd --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/debounce.js @@ -0,0 +1,188 @@ +var isObject = require('./isObject'), + now = require('./now'), + toNumber = require('./toNumber'); + +/** Error message constants. */ +var FUNC_ERROR_TEXT = 'Expected a function'; + +/* Built-in method references for those with the same name as other `lodash` methods. */ +var nativeMax = Math.max, + nativeMin = Math.min; + +/** + * Creates a debounced function that delays invoking `func` until after `wait` + * milliseconds have elapsed since the last time the debounced function was + * invoked. The debounced function comes with a `cancel` method to cancel + * delayed `func` invocations and a `flush` method to immediately invoke them. + * Provide `options` to indicate whether `func` should be invoked on the + * leading and/or trailing edge of the `wait` timeout. The `func` is invoked + * with the last arguments provided to the debounced function. Subsequent + * calls to the debounced function return the result of the last `func` + * invocation. + * + * **Note:** If `leading` and `trailing` options are `true`, `func` is + * invoked on the trailing edge of the timeout only if the debounced function + * is invoked more than once during the `wait` timeout. + * + * If `wait` is `0` and `leading` is `false`, `func` invocation is deferred + * until to the next tick, similar to `setTimeout` with a timeout of `0`. + * + * See [David Corbacho's article](https://css-tricks.com/debouncing-throttling-explained-examples/) + * for details over the differences between `_.debounce` and `_.throttle`. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Function + * @param {Function} func The function to debounce. + * @param {number} [wait=0] The number of milliseconds to delay. + * @param {Object} [options={}] The options object. + * @param {boolean} [options.leading=false] + * Specify invoking on the leading edge of the timeout. + * @param {number} [options.maxWait] + * The maximum time `func` is allowed to be delayed before it's invoked. + * @param {boolean} [options.trailing=true] + * Specify invoking on the trailing edge of the timeout. + * @returns {Function} Returns the new debounced function. + * @example + * + * // Avoid costly calculations while the window size is in flux. + * jQuery(window).on('resize', _.debounce(calculateLayout, 150)); + * + * // Invoke `sendMail` when clicked, debouncing subsequent calls. + * jQuery(element).on('click', _.debounce(sendMail, 300, { + * 'leading': true, + * 'trailing': false + * })); + * + * // Ensure `batchLog` is invoked once after 1 second of debounced calls. + * var debounced = _.debounce(batchLog, 250, { 'maxWait': 1000 }); + * var source = new EventSource('/stream'); + * jQuery(source).on('message', debounced); + * + * // Cancel the trailing debounced invocation. + * jQuery(window).on('popstate', debounced.cancel); + */ +function debounce(func, wait, options) { + var lastArgs, + lastThis, + maxWait, + result, + timerId, + lastCallTime, + lastInvokeTime = 0, + leading = false, + maxing = false, + trailing = true; + + if (typeof func != 'function') { + throw new TypeError(FUNC_ERROR_TEXT); + } + wait = toNumber(wait) || 0; + if (isObject(options)) { + leading = !!options.leading; + maxing = 'maxWait' in options; + maxWait = maxing ? nativeMax(toNumber(options.maxWait) || 0, wait) : maxWait; + trailing = 'trailing' in options ? !!options.trailing : trailing; + } + + function invokeFunc(time) { + var args = lastArgs, + thisArg = lastThis; + + lastArgs = lastThis = undefined; + lastInvokeTime = time; + result = func.apply(thisArg, args); + return result; + } + + function leadingEdge(time) { + // Reset any `maxWait` timer. + lastInvokeTime = time; + // Start the timer for the trailing edge. + timerId = setTimeout(timerExpired, wait); + // Invoke the leading edge. + return leading ? invokeFunc(time) : result; + } + + function remainingWait(time) { + var timeSinceLastCall = time - lastCallTime, + timeSinceLastInvoke = time - lastInvokeTime, + result = wait - timeSinceLastCall; + + return maxing ? nativeMin(result, maxWait - timeSinceLastInvoke) : result; + } + + function shouldInvoke(time) { + var timeSinceLastCall = time - lastCallTime, + timeSinceLastInvoke = time - lastInvokeTime; + + // Either this is the first call, activity has stopped and we're at the + // trailing edge, the system time has gone backwards and we're treating + // it as the trailing edge, or we've hit the `maxWait` limit. + return (lastCallTime === undefined || (timeSinceLastCall >= wait) || + (timeSinceLastCall < 0) || (maxing && timeSinceLastInvoke >= maxWait)); + } + + function timerExpired() { + var time = now(); + if (shouldInvoke(time)) { + return trailingEdge(time); + } + // Restart the timer. + timerId = setTimeout(timerExpired, remainingWait(time)); + } + + function trailingEdge(time) { + timerId = undefined; + + // Only invoke if we have `lastArgs` which means `func` has been + // debounced at least once. + if (trailing && lastArgs) { + return invokeFunc(time); + } + lastArgs = lastThis = undefined; + return result; + } + + function cancel() { + if (timerId !== undefined) { + clearTimeout(timerId); + } + lastInvokeTime = 0; + lastArgs = lastCallTime = lastThis = timerId = undefined; + } + + function flush() { + return timerId === undefined ? result : trailingEdge(now()); + } + + function debounced() { + var time = now(), + isInvoking = shouldInvoke(time); + + lastArgs = arguments; + lastThis = this; + lastCallTime = time; + + if (isInvoking) { + if (timerId === undefined) { + return leadingEdge(lastCallTime); + } + if (maxing) { + // Handle invocations in a tight loop. + timerId = setTimeout(timerExpired, wait); + return invokeFunc(lastCallTime); + } + } + if (timerId === undefined) { + timerId = setTimeout(timerExpired, wait); + } + return result; + } + debounced.cancel = cancel; + debounced.flush = flush; + return debounced; +} + +module.exports = debounce; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/deburr.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/deburr.js new file mode 100644 index 0000000..bc08b05 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/deburr.js @@ -0,0 +1,43 @@ +var deburrLetter = require('./_deburrLetter'), + toString = require('./toString'); + +/** Used to match Latin Unicode letters (excluding mathematical operators). */ +var reLatin = /[\xc0-\xd6\xd8-\xf6\xf8-\xff\u0100-\u017f]/g; + +/** Used to compose unicode character classes. */ +var rsComboMarksRange = '\\u0300-\\u036f\\ufe20-\\ufe23', + rsComboSymbolsRange = '\\u20d0-\\u20f0'; + +/** Used to compose unicode capture groups. */ +var rsCombo = '[' + rsComboMarksRange + rsComboSymbolsRange + ']'; + +/** + * Used to match [combining diacritical marks](https://en.wikipedia.org/wiki/Combining_Diacritical_Marks) and + * [combining diacritical marks for symbols](https://en.wikipedia.org/wiki/Combining_Diacritical_Marks_for_Symbols). + */ +var reComboMark = RegExp(rsCombo, 'g'); + +/** + * Deburrs `string` by converting + * [Latin-1 Supplement](https://en.wikipedia.org/wiki/Latin-1_Supplement_(Unicode_block)#Character_table) + * and [Latin Extended-A](https://en.wikipedia.org/wiki/Latin_Extended-A) + * letters to basic Latin letters and removing + * [combining diacritical marks](https://en.wikipedia.org/wiki/Combining_Diacritical_Marks). + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category String + * @param {string} [string=''] The string to deburr. + * @returns {string} Returns the deburred string. + * @example + * + * _.deburr('déjà vu'); + * // => 'deja vu' + */ +function deburr(string) { + string = toString(string); + return string && string.replace(reLatin, deburrLetter).replace(reComboMark, ''); +} + +module.exports = deburr; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/defaultTo.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/defaultTo.js new file mode 100644 index 0000000..5b33359 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/defaultTo.js @@ -0,0 +1,25 @@ +/** + * Checks `value` to determine whether a default value should be returned in + * its place. The `defaultValue` is returned if `value` is `NaN`, `null`, + * or `undefined`. + * + * @static + * @memberOf _ + * @since 4.14.0 + * @category Util + * @param {*} value The value to check. + * @param {*} defaultValue The default value. + * @returns {*} Returns the resolved value. + * @example + * + * _.defaultTo(1, 10); + * // => 1 + * + * _.defaultTo(undefined, 10); + * // => 10 + */ +function defaultTo(value, defaultValue) { + return (value == null || value !== value) ? defaultValue : value; +} + +module.exports = defaultTo; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/defaults.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/defaults.js new file mode 100644 index 0000000..5333b42 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/defaults.js @@ -0,0 +1,32 @@ +var apply = require('./_apply'), + assignInDefaults = require('./_assignInDefaults'), + assignInWith = require('./assignInWith'), + baseRest = require('./_baseRest'); + +/** + * Assigns own and inherited enumerable string keyed properties of source + * objects to the destination object for all destination properties that + * resolve to `undefined`. Source objects are applied from left to right. + * Once a property is set, additional values of the same property are ignored. + * + * **Note:** This method mutates `object`. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Object + * @param {Object} object The destination object. + * @param {...Object} [sources] The source objects. + * @returns {Object} Returns `object`. + * @see _.defaultsDeep + * @example + * + * _.defaults({ 'a': 1 }, { 'b': 2 }, { 'a': 3 }); + * // => { 'a': 1, 'b': 2 } + */ +var defaults = baseRest(function(args) { + args.push(undefined, assignInDefaults); + return apply(assignInWith, undefined, args); +}); + +module.exports = defaults; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/defaultsDeep.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/defaultsDeep.js new file mode 100644 index 0000000..41680ed --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/defaultsDeep.js @@ -0,0 +1,30 @@ +var apply = require('./_apply'), + baseRest = require('./_baseRest'), + mergeDefaults = require('./_mergeDefaults'), + mergeWith = require('./mergeWith'); + +/** + * This method is like `_.defaults` except that it recursively assigns + * default properties. + * + * **Note:** This method mutates `object`. + * + * @static + * @memberOf _ + * @since 3.10.0 + * @category Object + * @param {Object} object The destination object. + * @param {...Object} [sources] The source objects. + * @returns {Object} Returns `object`. + * @see _.defaults + * @example + * + * _.defaultsDeep({ 'a': { 'b': 2 } }, { 'a': { 'b': 1, 'c': 3 } }); + * // => { 'a': { 'b': 2, 'c': 3 } } + */ +var defaultsDeep = baseRest(function(args) { + args.push(undefined, mergeDefaults); + return apply(mergeWith, undefined, args); +}); + +module.exports = defaultsDeep; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/defer.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/defer.js new file mode 100644 index 0000000..f6d6c6f --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/defer.js @@ -0,0 +1,26 @@ +var baseDelay = require('./_baseDelay'), + baseRest = require('./_baseRest'); + +/** + * Defers invoking the `func` until the current call stack has cleared. Any + * additional arguments are provided to `func` when it's invoked. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Function + * @param {Function} func The function to defer. + * @param {...*} [args] The arguments to invoke `func` with. + * @returns {number} Returns the timer id. + * @example + * + * _.defer(function(text) { + * console.log(text); + * }, 'deferred'); + * // => Logs 'deferred' after one millisecond. + */ +var defer = baseRest(function(func, args) { + return baseDelay(func, 1, args); +}); + +module.exports = defer; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/delay.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/delay.js new file mode 100644 index 0000000..bd55479 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/delay.js @@ -0,0 +1,28 @@ +var baseDelay = require('./_baseDelay'), + baseRest = require('./_baseRest'), + toNumber = require('./toNumber'); + +/** + * Invokes `func` after `wait` milliseconds. Any additional arguments are + * provided to `func` when it's invoked. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Function + * @param {Function} func The function to delay. + * @param {number} wait The number of milliseconds to delay invocation. + * @param {...*} [args] The arguments to invoke `func` with. + * @returns {number} Returns the timer id. + * @example + * + * _.delay(function(text) { + * console.log(text); + * }, 1000, 'later'); + * // => Logs 'later' after one second. + */ +var delay = baseRest(function(func, wait, args) { + return baseDelay(func, toNumber(wait) || 0, args); +}); + +module.exports = delay; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/difference.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/difference.js new file mode 100644 index 0000000..fa28bb3 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/difference.js @@ -0,0 +1,33 @@ +var baseDifference = require('./_baseDifference'), + baseFlatten = require('./_baseFlatten'), + baseRest = require('./_baseRest'), + isArrayLikeObject = require('./isArrayLikeObject'); + +/** + * Creates an array of `array` values not included in the other given arrays + * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero) + * for equality comparisons. The order and references of result values are + * determined by the first array. + * + * **Note:** Unlike `_.pullAll`, this method returns a new array. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Array + * @param {Array} array The array to inspect. + * @param {...Array} [values] The values to exclude. + * @returns {Array} Returns the new array of filtered values. + * @see _.without, _.xor + * @example + * + * _.difference([2, 1], [2, 3]); + * // => [1] + */ +var difference = baseRest(function(array, values) { + return isArrayLikeObject(array) + ? baseDifference(array, baseFlatten(values, 1, isArrayLikeObject, true)) + : []; +}); + +module.exports = difference; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/differenceBy.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/differenceBy.js new file mode 100644 index 0000000..2cd63e7 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/differenceBy.js @@ -0,0 +1,44 @@ +var baseDifference = require('./_baseDifference'), + baseFlatten = require('./_baseFlatten'), + baseIteratee = require('./_baseIteratee'), + baseRest = require('./_baseRest'), + isArrayLikeObject = require('./isArrayLikeObject'), + last = require('./last'); + +/** + * This method is like `_.difference` except that it accepts `iteratee` which + * is invoked for each element of `array` and `values` to generate the criterion + * by which they're compared. The order and references of result values are + * determined by the first array. The iteratee is invoked with one argument: + * (value). + * + * **Note:** Unlike `_.pullAllBy`, this method returns a new array. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {Array} array The array to inspect. + * @param {...Array} [values] The values to exclude. + * @param {Function} [iteratee=_.identity] The iteratee invoked per element. + * @returns {Array} Returns the new array of filtered values. + * @example + * + * _.differenceBy([2.1, 1.2], [2.3, 3.4], Math.floor); + * // => [1.2] + * + * // The `_.property` iteratee shorthand. + * _.differenceBy([{ 'x': 2 }, { 'x': 1 }], [{ 'x': 1 }], 'x'); + * // => [{ 'x': 2 }] + */ +var differenceBy = baseRest(function(array, values) { + var iteratee = last(values); + if (isArrayLikeObject(iteratee)) { + iteratee = undefined; + } + return isArrayLikeObject(array) + ? baseDifference(array, baseFlatten(values, 1, isArrayLikeObject, true), baseIteratee(iteratee, 2)) + : []; +}); + +module.exports = differenceBy; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/differenceWith.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/differenceWith.js new file mode 100644 index 0000000..c0233f4 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/differenceWith.js @@ -0,0 +1,40 @@ +var baseDifference = require('./_baseDifference'), + baseFlatten = require('./_baseFlatten'), + baseRest = require('./_baseRest'), + isArrayLikeObject = require('./isArrayLikeObject'), + last = require('./last'); + +/** + * This method is like `_.difference` except that it accepts `comparator` + * which is invoked to compare elements of `array` to `values`. The order and + * references of result values are determined by the first array. The comparator + * is invoked with two arguments: (arrVal, othVal). + * + * **Note:** Unlike `_.pullAllWith`, this method returns a new array. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {Array} array The array to inspect. + * @param {...Array} [values] The values to exclude. + * @param {Function} [comparator] The comparator invoked per element. + * @returns {Array} Returns the new array of filtered values. + * @example + * + * var objects = [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }]; + * + * _.differenceWith(objects, [{ 'x': 1, 'y': 2 }], _.isEqual); + * // => [{ 'x': 2, 'y': 1 }] + */ +var differenceWith = baseRest(function(array, values) { + var comparator = last(values); + if (isArrayLikeObject(comparator)) { + comparator = undefined; + } + return isArrayLikeObject(array) + ? baseDifference(array, baseFlatten(values, 1, isArrayLikeObject, true), undefined, comparator) + : []; +}); + +module.exports = differenceWith; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/divide.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/divide.js new file mode 100644 index 0000000..8cae0cd --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/divide.js @@ -0,0 +1,22 @@ +var createMathOperation = require('./_createMathOperation'); + +/** + * Divide two numbers. + * + * @static + * @memberOf _ + * @since 4.7.0 + * @category Math + * @param {number} dividend The first number in a division. + * @param {number} divisor The second number in a division. + * @returns {number} Returns the quotient. + * @example + * + * _.divide(6, 4); + * // => 1.5 + */ +var divide = createMathOperation(function(dividend, divisor) { + return dividend / divisor; +}, 1); + +module.exports = divide; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/drop.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/drop.js new file mode 100644 index 0000000..6124ef7 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/drop.js @@ -0,0 +1,38 @@ +var baseSlice = require('./_baseSlice'), + toInteger = require('./toInteger'); + +/** + * Creates a slice of `array` with `n` elements dropped from the beginning. + * + * @static + * @memberOf _ + * @since 0.5.0 + * @category Array + * @param {Array} array The array to query. + * @param {number} [n=1] The number of elements to drop. + * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`. + * @returns {Array} Returns the slice of `array`. + * @example + * + * _.drop([1, 2, 3]); + * // => [2, 3] + * + * _.drop([1, 2, 3], 2); + * // => [3] + * + * _.drop([1, 2, 3], 5); + * // => [] + * + * _.drop([1, 2, 3], 0); + * // => [1, 2, 3] + */ +function drop(array, n, guard) { + var length = array ? array.length : 0; + if (!length) { + return []; + } + n = (guard || n === undefined) ? 1 : toInteger(n); + return baseSlice(array, n < 0 ? 0 : n, length); +} + +module.exports = drop; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/dropRight.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/dropRight.js new file mode 100644 index 0000000..8aa3576 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/dropRight.js @@ -0,0 +1,39 @@ +var baseSlice = require('./_baseSlice'), + toInteger = require('./toInteger'); + +/** + * Creates a slice of `array` with `n` elements dropped from the end. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Array + * @param {Array} array The array to query. + * @param {number} [n=1] The number of elements to drop. + * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`. + * @returns {Array} Returns the slice of `array`. + * @example + * + * _.dropRight([1, 2, 3]); + * // => [1, 2] + * + * _.dropRight([1, 2, 3], 2); + * // => [1] + * + * _.dropRight([1, 2, 3], 5); + * // => [] + * + * _.dropRight([1, 2, 3], 0); + * // => [1, 2, 3] + */ +function dropRight(array, n, guard) { + var length = array ? array.length : 0; + if (!length) { + return []; + } + n = (guard || n === undefined) ? 1 : toInteger(n); + n = length - n; + return baseSlice(array, 0, n < 0 ? 0 : n); +} + +module.exports = dropRight; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/dropRightWhile.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/dropRightWhile.js new file mode 100644 index 0000000..9ad36a0 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/dropRightWhile.js @@ -0,0 +1,45 @@ +var baseIteratee = require('./_baseIteratee'), + baseWhile = require('./_baseWhile'); + +/** + * Creates a slice of `array` excluding elements dropped from the end. + * Elements are dropped until `predicate` returns falsey. The predicate is + * invoked with three arguments: (value, index, array). + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Array + * @param {Array} array The array to query. + * @param {Function} [predicate=_.identity] The function invoked per iteration. + * @returns {Array} Returns the slice of `array`. + * @example + * + * var users = [ + * { 'user': 'barney', 'active': true }, + * { 'user': 'fred', 'active': false }, + * { 'user': 'pebbles', 'active': false } + * ]; + * + * _.dropRightWhile(users, function(o) { return !o.active; }); + * // => objects for ['barney'] + * + * // The `_.matches` iteratee shorthand. + * _.dropRightWhile(users, { 'user': 'pebbles', 'active': false }); + * // => objects for ['barney', 'fred'] + * + * // The `_.matchesProperty` iteratee shorthand. + * _.dropRightWhile(users, ['active', false]); + * // => objects for ['barney'] + * + * // The `_.property` iteratee shorthand. + * _.dropRightWhile(users, 'active'); + * // => objects for ['barney', 'fred', 'pebbles'] + */ +function dropRightWhile(array, predicate) { + return (array && array.length) + ? baseWhile(array, baseIteratee(predicate, 3), true, true) + : []; +} + +module.exports = dropRightWhile; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/dropWhile.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/dropWhile.js new file mode 100644 index 0000000..f89444e --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/dropWhile.js @@ -0,0 +1,46 @@ +var baseIteratee = require('./_baseIteratee'), + baseWhile = require('./_baseWhile'); + +/** + * Creates a slice of `array` excluding elements dropped from the beginning. + * Elements are dropped until `predicate` returns falsey. The predicate is + * invoked with three arguments: (value, index, array). + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Array + * @param {Array} array The array to query. + * @param {Function} [predicate=_.identity] + * The function invoked per iteration. + * @returns {Array} Returns the slice of `array`. + * @example + * + * var users = [ + * { 'user': 'barney', 'active': false }, + * { 'user': 'fred', 'active': false }, + * { 'user': 'pebbles', 'active': true } + * ]; + * + * _.dropWhile(users, function(o) { return !o.active; }); + * // => objects for ['pebbles'] + * + * // The `_.matches` iteratee shorthand. + * _.dropWhile(users, { 'user': 'barney', 'active': false }); + * // => objects for ['fred', 'pebbles'] + * + * // The `_.matchesProperty` iteratee shorthand. + * _.dropWhile(users, ['active', false]); + * // => objects for ['pebbles'] + * + * // The `_.property` iteratee shorthand. + * _.dropWhile(users, 'active'); + * // => objects for ['barney', 'fred', 'pebbles'] + */ +function dropWhile(array, predicate) { + return (array && array.length) + ? baseWhile(array, baseIteratee(predicate, 3), true) + : []; +} + +module.exports = dropWhile; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/each.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/each.js new file mode 100644 index 0000000..8800f42 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/each.js @@ -0,0 +1 @@ +module.exports = require('./forEach'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/eachRight.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/eachRight.js new file mode 100644 index 0000000..3252b2a --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/eachRight.js @@ -0,0 +1 @@ +module.exports = require('./forEachRight'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/endsWith.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/endsWith.js new file mode 100644 index 0000000..76fc866 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/endsWith.js @@ -0,0 +1,43 @@ +var baseClamp = require('./_baseClamp'), + baseToString = require('./_baseToString'), + toInteger = require('./toInteger'), + toString = require('./toString'); + +/** + * Checks if `string` ends with the given target string. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category String + * @param {string} [string=''] The string to inspect. + * @param {string} [target] The string to search for. + * @param {number} [position=string.length] The position to search up to. + * @returns {boolean} Returns `true` if `string` ends with `target`, + * else `false`. + * @example + * + * _.endsWith('abc', 'c'); + * // => true + * + * _.endsWith('abc', 'b'); + * // => false + * + * _.endsWith('abc', 'b', 2); + * // => true + */ +function endsWith(string, target, position) { + string = toString(string); + target = baseToString(target); + + var length = string.length; + position = position === undefined + ? length + : baseClamp(toInteger(position), 0, length); + + var end = position; + position -= target.length; + return position >= 0 && string.slice(position, end) == target; +} + +module.exports = endsWith; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/entries.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/entries.js new file mode 100644 index 0000000..7a88df2 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/entries.js @@ -0,0 +1 @@ +module.exports = require('./toPairs'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/entriesIn.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/entriesIn.js new file mode 100644 index 0000000..f6c6331 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/entriesIn.js @@ -0,0 +1 @@ +module.exports = require('./toPairsIn'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/eq.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/eq.js new file mode 100644 index 0000000..a940688 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/eq.js @@ -0,0 +1,37 @@ +/** + * Performs a + * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero) + * comparison between two values to determine if they are equivalent. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to compare. + * @param {*} other The other value to compare. + * @returns {boolean} Returns `true` if the values are equivalent, else `false`. + * @example + * + * var object = { 'a': 1 }; + * var other = { 'a': 1 }; + * + * _.eq(object, object); + * // => true + * + * _.eq(object, other); + * // => false + * + * _.eq('a', 'a'); + * // => true + * + * _.eq('a', Object('a')); + * // => false + * + * _.eq(NaN, NaN); + * // => true + */ +function eq(value, other) { + return value === other || (value !== value && other !== other); +} + +module.exports = eq; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/escape.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/escape.js new file mode 100644 index 0000000..9247e00 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/escape.js @@ -0,0 +1,43 @@ +var escapeHtmlChar = require('./_escapeHtmlChar'), + toString = require('./toString'); + +/** Used to match HTML entities and HTML characters. */ +var reUnescapedHtml = /[&<>"']/g, + reHasUnescapedHtml = RegExp(reUnescapedHtml.source); + +/** + * Converts the characters "&", "<", ">", '"', and "'" in `string` to their + * corresponding HTML entities. + * + * **Note:** No other characters are escaped. To escape additional + * characters use a third-party library like [_he_](https://mths.be/he). + * + * Though the ">" character is escaped for symmetry, characters like + * ">" and "/" don't need escaping in HTML and have no special meaning + * unless they're part of a tag or unquoted attribute value. See + * [Mathias Bynens's article](https://mathiasbynens.be/notes/ambiguous-ampersands) + * (under "semi-related fun fact") for more details. + * + * When working with HTML you should always + * [quote attribute values](http://wonko.com/post/html-escaping) to reduce + * XSS vectors. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category String + * @param {string} [string=''] The string to escape. + * @returns {string} Returns the escaped string. + * @example + * + * _.escape('fred, barney, & pebbles'); + * // => 'fred, barney, & pebbles' + */ +function escape(string) { + string = toString(string); + return (string && reHasUnescapedHtml.test(string)) + ? string.replace(reUnescapedHtml, escapeHtmlChar) + : string; +} + +module.exports = escape; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/escapeRegExp.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/escapeRegExp.js new file mode 100644 index 0000000..0a58c69 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/escapeRegExp.js @@ -0,0 +1,32 @@ +var toString = require('./toString'); + +/** + * Used to match `RegExp` + * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns). + */ +var reRegExpChar = /[\\^$.*+?()[\]{}|]/g, + reHasRegExpChar = RegExp(reRegExpChar.source); + +/** + * Escapes the `RegExp` special characters "^", "$", "\", ".", "*", "+", + * "?", "(", ")", "[", "]", "{", "}", and "|" in `string`. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category String + * @param {string} [string=''] The string to escape. + * @returns {string} Returns the escaped string. + * @example + * + * _.escapeRegExp('[lodash](https://lodash.com/)'); + * // => '\[lodash\]\(https://lodash\.com/\)' + */ +function escapeRegExp(string) { + string = toString(string); + return (string && reHasRegExpChar.test(string)) + ? string.replace(reRegExpChar, '\\$&') + : string; +} + +module.exports = escapeRegExp; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/every.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/every.js new file mode 100644 index 0000000..114f40f --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/every.js @@ -0,0 +1,57 @@ +var arrayEvery = require('./_arrayEvery'), + baseEvery = require('./_baseEvery'), + baseIteratee = require('./_baseIteratee'), + isArray = require('./isArray'), + isIterateeCall = require('./_isIterateeCall'); + +/** + * Checks if `predicate` returns truthy for **all** elements of `collection`. + * Iteration is stopped once `predicate` returns falsey. The predicate is + * invoked with three arguments: (value, index|key, collection). + * + * **Note:** This method returns `true` for + * [empty collections](https://en.wikipedia.org/wiki/Empty_set) because + * [everything is true](https://en.wikipedia.org/wiki/Vacuous_truth) of + * elements of empty collections. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [predicate=_.identity] + * The function invoked per iteration. + * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`. + * @returns {boolean} Returns `true` if all elements pass the predicate check, + * else `false`. + * @example + * + * _.every([true, 1, null, 'yes'], Boolean); + * // => false + * + * var users = [ + * { 'user': 'barney', 'age': 36, 'active': false }, + * { 'user': 'fred', 'age': 40, 'active': false } + * ]; + * + * // The `_.matches` iteratee shorthand. + * _.every(users, { 'user': 'barney', 'active': false }); + * // => false + * + * // The `_.matchesProperty` iteratee shorthand. + * _.every(users, ['active', false]); + * // => true + * + * // The `_.property` iteratee shorthand. + * _.every(users, 'active'); + * // => false + */ +function every(collection, predicate, guard) { + var func = isArray(collection) ? arrayEvery : baseEvery; + if (guard && isIterateeCall(collection, predicate, guard)) { + predicate = undefined; + } + return func(collection, baseIteratee(predicate, 3)); +} + +module.exports = every; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/extend.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/extend.js new file mode 100644 index 0000000..e00166c --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/extend.js @@ -0,0 +1 @@ +module.exports = require('./assignIn'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/extendWith.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/extendWith.js new file mode 100644 index 0000000..dbdcb3b --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/extendWith.js @@ -0,0 +1 @@ +module.exports = require('./assignInWith'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fill.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fill.js new file mode 100644 index 0000000..5730b7d --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fill.js @@ -0,0 +1,45 @@ +var baseFill = require('./_baseFill'), + isIterateeCall = require('./_isIterateeCall'); + +/** + * Fills elements of `array` with `value` from `start` up to, but not + * including, `end`. + * + * **Note:** This method mutates `array`. + * + * @static + * @memberOf _ + * @since 3.2.0 + * @category Array + * @param {Array} array The array to fill. + * @param {*} value The value to fill `array` with. + * @param {number} [start=0] The start position. + * @param {number} [end=array.length] The end position. + * @returns {Array} Returns `array`. + * @example + * + * var array = [1, 2, 3]; + * + * _.fill(array, 'a'); + * console.log(array); + * // => ['a', 'a', 'a'] + * + * _.fill(Array(3), 2); + * // => [2, 2, 2] + * + * _.fill([4, 6, 8, 10], '*', 1, 3); + * // => [4, '*', '*', 10] + */ +function fill(array, value, start, end) { + var length = array ? array.length : 0; + if (!length) { + return []; + } + if (start && typeof start != 'number' && isIterateeCall(array, value, start)) { + start = 0; + end = length; + } + return baseFill(array, value, start, end); +} + +module.exports = fill; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/filter.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/filter.js new file mode 100644 index 0000000..3df977b --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/filter.js @@ -0,0 +1,49 @@ +var arrayFilter = require('./_arrayFilter'), + baseFilter = require('./_baseFilter'), + baseIteratee = require('./_baseIteratee'), + isArray = require('./isArray'); + +/** + * Iterates over elements of `collection`, returning an array of all elements + * `predicate` returns truthy for. The predicate is invoked with three + * arguments: (value, index|key, collection). + * + * **Note:** Unlike `_.remove`, this method returns a new array. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [predicate=_.identity] + * The function invoked per iteration. + * @returns {Array} Returns the new filtered array. + * @see _.reject + * @example + * + * var users = [ + * { 'user': 'barney', 'age': 36, 'active': true }, + * { 'user': 'fred', 'age': 40, 'active': false } + * ]; + * + * _.filter(users, function(o) { return !o.active; }); + * // => objects for ['fred'] + * + * // The `_.matches` iteratee shorthand. + * _.filter(users, { 'age': 36, 'active': true }); + * // => objects for ['barney'] + * + * // The `_.matchesProperty` iteratee shorthand. + * _.filter(users, ['active', false]); + * // => objects for ['fred'] + * + * // The `_.property` iteratee shorthand. + * _.filter(users, 'active'); + * // => objects for ['barney'] + */ +function filter(collection, predicate) { + var func = isArray(collection) ? arrayFilter : baseFilter; + return func(collection, baseIteratee(predicate, 3)); +} + +module.exports = filter; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/find.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/find.js new file mode 100644 index 0000000..b6d0950 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/find.js @@ -0,0 +1,43 @@ +var createFind = require('./_createFind'), + findIndex = require('./findIndex'); + +/** + * Iterates over elements of `collection`, returning the first element + * `predicate` returns truthy for. The predicate is invoked with three + * arguments: (value, index|key, collection). + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Collection + * @param {Array|Object} collection The collection to inspect. + * @param {Function} [predicate=_.identity] + * The function invoked per iteration. + * @param {number} [fromIndex=0] The index to search from. + * @returns {*} Returns the matched element, else `undefined`. + * @example + * + * var users = [ + * { 'user': 'barney', 'age': 36, 'active': true }, + * { 'user': 'fred', 'age': 40, 'active': false }, + * { 'user': 'pebbles', 'age': 1, 'active': true } + * ]; + * + * _.find(users, function(o) { return o.age < 40; }); + * // => object for 'barney' + * + * // The `_.matches` iteratee shorthand. + * _.find(users, { 'age': 1, 'active': true }); + * // => object for 'pebbles' + * + * // The `_.matchesProperty` iteratee shorthand. + * _.find(users, ['active', false]); + * // => object for 'fred' + * + * // The `_.property` iteratee shorthand. + * _.find(users, 'active'); + * // => object for 'barney' + */ +var find = createFind(findIndex); + +module.exports = find; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/findIndex.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/findIndex.js new file mode 100644 index 0000000..0b11d93 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/findIndex.js @@ -0,0 +1,56 @@ +var baseFindIndex = require('./_baseFindIndex'), + baseIteratee = require('./_baseIteratee'), + toInteger = require('./toInteger'); + +/* Built-in method references for those with the same name as other `lodash` methods. */ +var nativeMax = Math.max; + +/** + * This method is like `_.find` except that it returns the index of the first + * element `predicate` returns truthy for instead of the element itself. + * + * @static + * @memberOf _ + * @since 1.1.0 + * @category Array + * @param {Array} array The array to inspect. + * @param {Function} [predicate=_.identity] + * The function invoked per iteration. + * @param {number} [fromIndex=0] The index to search from. + * @returns {number} Returns the index of the found element, else `-1`. + * @example + * + * var users = [ + * { 'user': 'barney', 'active': false }, + * { 'user': 'fred', 'active': false }, + * { 'user': 'pebbles', 'active': true } + * ]; + * + * _.findIndex(users, function(o) { return o.user == 'barney'; }); + * // => 0 + * + * // The `_.matches` iteratee shorthand. + * _.findIndex(users, { 'user': 'fred', 'active': false }); + * // => 1 + * + * // The `_.matchesProperty` iteratee shorthand. + * _.findIndex(users, ['active', false]); + * // => 0 + * + * // The `_.property` iteratee shorthand. + * _.findIndex(users, 'active'); + * // => 2 + */ +function findIndex(array, predicate, fromIndex) { + var length = array ? array.length : 0; + if (!length) { + return -1; + } + var index = fromIndex == null ? 0 : toInteger(fromIndex); + if (index < 0) { + index = nativeMax(length + index, 0); + } + return baseFindIndex(array, baseIteratee(predicate, 3), index); +} + +module.exports = findIndex; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/findKey.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/findKey.js new file mode 100644 index 0000000..cac0248 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/findKey.js @@ -0,0 +1,44 @@ +var baseFindKey = require('./_baseFindKey'), + baseForOwn = require('./_baseForOwn'), + baseIteratee = require('./_baseIteratee'); + +/** + * This method is like `_.find` except that it returns the key of the first + * element `predicate` returns truthy for instead of the element itself. + * + * @static + * @memberOf _ + * @since 1.1.0 + * @category Object + * @param {Object} object The object to inspect. + * @param {Function} [predicate=_.identity] The function invoked per iteration. + * @returns {string|undefined} Returns the key of the matched element, + * else `undefined`. + * @example + * + * var users = { + * 'barney': { 'age': 36, 'active': true }, + * 'fred': { 'age': 40, 'active': false }, + * 'pebbles': { 'age': 1, 'active': true } + * }; + * + * _.findKey(users, function(o) { return o.age < 40; }); + * // => 'barney' (iteration order is not guaranteed) + * + * // The `_.matches` iteratee shorthand. + * _.findKey(users, { 'age': 1, 'active': true }); + * // => 'pebbles' + * + * // The `_.matchesProperty` iteratee shorthand. + * _.findKey(users, ['active', false]); + * // => 'fred' + * + * // The `_.property` iteratee shorthand. + * _.findKey(users, 'active'); + * // => 'barney' + */ +function findKey(object, predicate) { + return baseFindKey(object, baseIteratee(predicate, 3), baseForOwn); +} + +module.exports = findKey; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/findLast.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/findLast.js new file mode 100644 index 0000000..3ce09f4 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/findLast.js @@ -0,0 +1,26 @@ +var createFind = require('./_createFind'), + findLastIndex = require('./findLastIndex'); + +/** + * This method is like `_.find` except that it iterates over elements of + * `collection` from right to left. + * + * @static + * @memberOf _ + * @since 2.0.0 + * @category Collection + * @param {Array|Object} collection The collection to inspect. + * @param {Function} [predicate=_.identity] + * The function invoked per iteration. + * @param {number} [fromIndex=collection.length-1] The index to search from. + * @returns {*} Returns the matched element, else `undefined`. + * @example + * + * _.findLast([1, 2, 3, 4], function(n) { + * return n % 2 == 1; + * }); + * // => 3 + */ +var findLast = createFind(findLastIndex); + +module.exports = findLast; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/findLastIndex.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/findLastIndex.js new file mode 100644 index 0000000..63e8770 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/findLastIndex.js @@ -0,0 +1,60 @@ +var baseFindIndex = require('./_baseFindIndex'), + baseIteratee = require('./_baseIteratee'), + toInteger = require('./toInteger'); + +/* Built-in method references for those with the same name as other `lodash` methods. */ +var nativeMax = Math.max, + nativeMin = Math.min; + +/** + * This method is like `_.findIndex` except that it iterates over elements + * of `collection` from right to left. + * + * @static + * @memberOf _ + * @since 2.0.0 + * @category Array + * @param {Array} array The array to inspect. + * @param {Function} [predicate=_.identity] + * The function invoked per iteration. + * @param {number} [fromIndex=array.length-1] The index to search from. + * @returns {number} Returns the index of the found element, else `-1`. + * @example + * + * var users = [ + * { 'user': 'barney', 'active': true }, + * { 'user': 'fred', 'active': false }, + * { 'user': 'pebbles', 'active': false } + * ]; + * + * _.findLastIndex(users, function(o) { return o.user == 'pebbles'; }); + * // => 2 + * + * // The `_.matches` iteratee shorthand. + * _.findLastIndex(users, { 'user': 'barney', 'active': true }); + * // => 0 + * + * // The `_.matchesProperty` iteratee shorthand. + * _.findLastIndex(users, ['active', false]); + * // => 2 + * + * // The `_.property` iteratee shorthand. + * _.findLastIndex(users, 'active'); + * // => 0 + */ +function findLastIndex(array, predicate, fromIndex) { + var length = array ? array.length : 0; + if (!length) { + return -1; + } + var index = length - 1; + if (fromIndex !== undefined) { + index = toInteger(fromIndex); + index = fromIndex < 0 + ? nativeMax(length + index, 0) + : nativeMin(index, length - 1); + } + return baseFindIndex(array, baseIteratee(predicate, 3), index, true); +} + +module.exports = findLastIndex; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/findLastKey.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/findLastKey.js new file mode 100644 index 0000000..66fb9fb --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/findLastKey.js @@ -0,0 +1,44 @@ +var baseFindKey = require('./_baseFindKey'), + baseForOwnRight = require('./_baseForOwnRight'), + baseIteratee = require('./_baseIteratee'); + +/** + * This method is like `_.findKey` except that it iterates over elements of + * a collection in the opposite order. + * + * @static + * @memberOf _ + * @since 2.0.0 + * @category Object + * @param {Object} object The object to inspect. + * @param {Function} [predicate=_.identity] The function invoked per iteration. + * @returns {string|undefined} Returns the key of the matched element, + * else `undefined`. + * @example + * + * var users = { + * 'barney': { 'age': 36, 'active': true }, + * 'fred': { 'age': 40, 'active': false }, + * 'pebbles': { 'age': 1, 'active': true } + * }; + * + * _.findLastKey(users, function(o) { return o.age < 40; }); + * // => returns 'pebbles' assuming `_.findKey` returns 'barney' + * + * // The `_.matches` iteratee shorthand. + * _.findLastKey(users, { 'age': 36, 'active': true }); + * // => 'barney' + * + * // The `_.matchesProperty` iteratee shorthand. + * _.findLastKey(users, ['active', false]); + * // => 'fred' + * + * // The `_.property` iteratee shorthand. + * _.findLastKey(users, 'active'); + * // => 'pebbles' + */ +function findLastKey(object, predicate) { + return baseFindKey(object, baseIteratee(predicate, 3), baseForOwnRight); +} + +module.exports = findLastKey; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/first.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/first.js new file mode 100644 index 0000000..53f4ad1 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/first.js @@ -0,0 +1 @@ +module.exports = require('./head'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/flatMap.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/flatMap.js new file mode 100644 index 0000000..8c5d832 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/flatMap.js @@ -0,0 +1,30 @@ +var baseFlatten = require('./_baseFlatten'), + map = require('./map'); + +/** + * Creates a flattened array of values by running each element in `collection` + * thru `iteratee` and flattening the mapped results. The iteratee is invoked + * with three arguments: (value, index|key, collection). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [iteratee=_.identity] + * The function invoked per iteration. + * @returns {Array} Returns the new flattened array. + * @example + * + * function duplicate(n) { + * return [n, n]; + * } + * + * _.flatMap([1, 2], duplicate); + * // => [1, 1, 2, 2] + */ +function flatMap(collection, iteratee) { + return baseFlatten(map(collection, iteratee), 1); +} + +module.exports = flatMap; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/flatMapDeep.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/flatMapDeep.js new file mode 100644 index 0000000..9359882 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/flatMapDeep.js @@ -0,0 +1,32 @@ +var baseFlatten = require('./_baseFlatten'), + map = require('./map'); + +/** Used as references for various `Number` constants. */ +var INFINITY = 1 / 0; + +/** + * This method is like `_.flatMap` except that it recursively flattens the + * mapped results. + * + * @static + * @memberOf _ + * @since 4.7.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [iteratee=_.identity] + * The function invoked per iteration. + * @returns {Array} Returns the new flattened array. + * @example + * + * function duplicate(n) { + * return [[[n, n]]]; + * } + * + * _.flatMapDeep([1, 2], duplicate); + * // => [1, 1, 2, 2] + */ +function flatMapDeep(collection, iteratee) { + return baseFlatten(map(collection, iteratee), INFINITY); +} + +module.exports = flatMapDeep; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/flatMapDepth.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/flatMapDepth.js new file mode 100644 index 0000000..2182bed --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/flatMapDepth.js @@ -0,0 +1,32 @@ +var baseFlatten = require('./_baseFlatten'), + map = require('./map'), + toInteger = require('./toInteger'); + +/** + * This method is like `_.flatMap` except that it recursively flattens the + * mapped results up to `depth` times. + * + * @static + * @memberOf _ + * @since 4.7.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [iteratee=_.identity] + * The function invoked per iteration. + * @param {number} [depth=1] The maximum recursion depth. + * @returns {Array} Returns the new flattened array. + * @example + * + * function duplicate(n) { + * return [[[n, n]]]; + * } + * + * _.flatMapDepth([1, 2], duplicate, 2); + * // => [[1, 1], [2, 2]] + */ +function flatMapDepth(collection, iteratee, depth) { + depth = depth === undefined ? 1 : toInteger(depth); + return baseFlatten(map(collection, iteratee), depth); +} + +module.exports = flatMapDepth; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/flatten.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/flatten.js new file mode 100644 index 0000000..bd4f439 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/flatten.js @@ -0,0 +1,22 @@ +var baseFlatten = require('./_baseFlatten'); + +/** + * Flattens `array` a single level deep. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Array + * @param {Array} array The array to flatten. + * @returns {Array} Returns the new flattened array. + * @example + * + * _.flatten([1, [2, [3, [4]], 5]]); + * // => [1, 2, [3, [4]], 5] + */ +function flatten(array) { + var length = array ? array.length : 0; + return length ? baseFlatten(array, 1) : []; +} + +module.exports = flatten; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/flattenDeep.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/flattenDeep.js new file mode 100644 index 0000000..c20c781 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/flattenDeep.js @@ -0,0 +1,25 @@ +var baseFlatten = require('./_baseFlatten'); + +/** Used as references for various `Number` constants. */ +var INFINITY = 1 / 0; + +/** + * Recursively flattens `array`. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Array + * @param {Array} array The array to flatten. + * @returns {Array} Returns the new flattened array. + * @example + * + * _.flattenDeep([1, [2, [3, [4]], 5]]); + * // => [1, 2, 3, 4, 5] + */ +function flattenDeep(array) { + var length = array ? array.length : 0; + return length ? baseFlatten(array, INFINITY) : []; +} + +module.exports = flattenDeep; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/flattenDepth.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/flattenDepth.js new file mode 100644 index 0000000..a0f4b52 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/flattenDepth.js @@ -0,0 +1,33 @@ +var baseFlatten = require('./_baseFlatten'), + toInteger = require('./toInteger'); + +/** + * Recursively flatten `array` up to `depth` times. + * + * @static + * @memberOf _ + * @since 4.4.0 + * @category Array + * @param {Array} array The array to flatten. + * @param {number} [depth=1] The maximum recursion depth. + * @returns {Array} Returns the new flattened array. + * @example + * + * var array = [1, [2, [3, [4]], 5]]; + * + * _.flattenDepth(array, 1); + * // => [1, 2, [3, [4]], 5] + * + * _.flattenDepth(array, 2); + * // => [1, 2, 3, [4], 5] + */ +function flattenDepth(array, depth) { + var length = array ? array.length : 0; + if (!length) { + return []; + } + depth = depth === undefined ? 1 : toInteger(depth); + return baseFlatten(array, depth); +} + +module.exports = flattenDepth; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/flip.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/flip.js new file mode 100644 index 0000000..02e3fc2 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/flip.js @@ -0,0 +1,28 @@ +var createWrap = require('./_createWrap'); + +/** Used to compose bitmasks for function metadata. */ +var FLIP_FLAG = 512; + +/** + * Creates a function that invokes `func` with arguments reversed. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Function + * @param {Function} func The function to flip arguments for. + * @returns {Function} Returns the new flipped function. + * @example + * + * var flipped = _.flip(function() { + * return _.toArray(arguments); + * }); + * + * flipped('a', 'b', 'c', 'd'); + * // => ['d', 'c', 'b', 'a'] + */ +function flip(func) { + return createWrap(func, FLIP_FLAG); +} + +module.exports = flip; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/floor.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/floor.js new file mode 100644 index 0000000..ab6dfa2 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/floor.js @@ -0,0 +1,26 @@ +var createRound = require('./_createRound'); + +/** + * Computes `number` rounded down to `precision`. + * + * @static + * @memberOf _ + * @since 3.10.0 + * @category Math + * @param {number} number The number to round down. + * @param {number} [precision=0] The precision to round down to. + * @returns {number} Returns the rounded down number. + * @example + * + * _.floor(4.006); + * // => 4 + * + * _.floor(0.046, 2); + * // => 0.04 + * + * _.floor(4060, -2); + * // => 4000 + */ +var floor = createRound('floor'); + +module.exports = floor; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/flow.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/flow.js new file mode 100644 index 0000000..74b6b62 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/flow.js @@ -0,0 +1,27 @@ +var createFlow = require('./_createFlow'); + +/** + * Creates a function that returns the result of invoking the given functions + * with the `this` binding of the created function, where each successive + * invocation is supplied the return value of the previous. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Util + * @param {...(Function|Function[])} [funcs] The functions to invoke. + * @returns {Function} Returns the new composite function. + * @see _.flowRight + * @example + * + * function square(n) { + * return n * n; + * } + * + * var addSquare = _.flow([_.add, square]); + * addSquare(1, 2); + * // => 9 + */ +var flow = createFlow(); + +module.exports = flow; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/flowRight.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/flowRight.js new file mode 100644 index 0000000..1146141 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/flowRight.js @@ -0,0 +1,26 @@ +var createFlow = require('./_createFlow'); + +/** + * This method is like `_.flow` except that it creates a function that + * invokes the given functions from right to left. + * + * @static + * @since 3.0.0 + * @memberOf _ + * @category Util + * @param {...(Function|Function[])} [funcs] The functions to invoke. + * @returns {Function} Returns the new composite function. + * @see _.flow + * @example + * + * function square(n) { + * return n * n; + * } + * + * var addSquare = _.flowRight([square, _.add]); + * addSquare(1, 2); + * // => 9 + */ +var flowRight = createFlow(true); + +module.exports = flowRight; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/forEach.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/forEach.js new file mode 100644 index 0000000..0ce879f --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/forEach.js @@ -0,0 +1,41 @@ +var arrayEach = require('./_arrayEach'), + baseEach = require('./_baseEach'), + baseIteratee = require('./_baseIteratee'), + isArray = require('./isArray'); + +/** + * Iterates over elements of `collection` and invokes `iteratee` for each element. + * The iteratee is invoked with three arguments: (value, index|key, collection). + * Iteratee functions may exit iteration early by explicitly returning `false`. + * + * **Note:** As with other "Collections" methods, objects with a "length" + * property are iterated like arrays. To avoid this behavior use `_.forIn` + * or `_.forOwn` for object iteration. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @alias each + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [iteratee=_.identity] The function invoked per iteration. + * @returns {Array|Object} Returns `collection`. + * @see _.forEachRight + * @example + * + * _.forEach([1, 2], function(value) { + * console.log(value); + * }); + * // => Logs `1` then `2`. + * + * _.forEach({ 'a': 1, 'b': 2 }, function(value, key) { + * console.log(key); + * }); + * // => Logs 'a' then 'b' (iteration order is not guaranteed). + */ +function forEach(collection, iteratee) { + var func = isArray(collection) ? arrayEach : baseEach; + return func(collection, baseIteratee(iteratee, 3)); +} + +module.exports = forEach; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/forEachRight.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/forEachRight.js new file mode 100644 index 0000000..c5d6e06 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/forEachRight.js @@ -0,0 +1,31 @@ +var arrayEachRight = require('./_arrayEachRight'), + baseEachRight = require('./_baseEachRight'), + baseIteratee = require('./_baseIteratee'), + isArray = require('./isArray'); + +/** + * This method is like `_.forEach` except that it iterates over elements of + * `collection` from right to left. + * + * @static + * @memberOf _ + * @since 2.0.0 + * @alias eachRight + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [iteratee=_.identity] The function invoked per iteration. + * @returns {Array|Object} Returns `collection`. + * @see _.forEach + * @example + * + * _.forEachRight([1, 2], function(value) { + * console.log(value); + * }); + * // => Logs `2` then `1`. + */ +function forEachRight(collection, iteratee) { + var func = isArray(collection) ? arrayEachRight : baseEachRight; + return func(collection, baseIteratee(iteratee, 3)); +} + +module.exports = forEachRight; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/forIn.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/forIn.js new file mode 100644 index 0000000..2e757da --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/forIn.js @@ -0,0 +1,39 @@ +var baseFor = require('./_baseFor'), + baseIteratee = require('./_baseIteratee'), + keysIn = require('./keysIn'); + +/** + * Iterates over own and inherited enumerable string keyed properties of an + * object and invokes `iteratee` for each property. The iteratee is invoked + * with three arguments: (value, key, object). Iteratee functions may exit + * iteration early by explicitly returning `false`. + * + * @static + * @memberOf _ + * @since 0.3.0 + * @category Object + * @param {Object} object The object to iterate over. + * @param {Function} [iteratee=_.identity] The function invoked per iteration. + * @returns {Object} Returns `object`. + * @see _.forInRight + * @example + * + * function Foo() { + * this.a = 1; + * this.b = 2; + * } + * + * Foo.prototype.c = 3; + * + * _.forIn(new Foo, function(value, key) { + * console.log(key); + * }); + * // => Logs 'a', 'b', then 'c' (iteration order is not guaranteed). + */ +function forIn(object, iteratee) { + return object == null + ? object + : baseFor(object, baseIteratee(iteratee, 3), keysIn); +} + +module.exports = forIn; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/forInRight.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/forInRight.js new file mode 100644 index 0000000..a47d6bb --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/forInRight.js @@ -0,0 +1,37 @@ +var baseForRight = require('./_baseForRight'), + baseIteratee = require('./_baseIteratee'), + keysIn = require('./keysIn'); + +/** + * This method is like `_.forIn` except that it iterates over properties of + * `object` in the opposite order. + * + * @static + * @memberOf _ + * @since 2.0.0 + * @category Object + * @param {Object} object The object to iterate over. + * @param {Function} [iteratee=_.identity] The function invoked per iteration. + * @returns {Object} Returns `object`. + * @see _.forIn + * @example + * + * function Foo() { + * this.a = 1; + * this.b = 2; + * } + * + * Foo.prototype.c = 3; + * + * _.forInRight(new Foo, function(value, key) { + * console.log(key); + * }); + * // => Logs 'c', 'b', then 'a' assuming `_.forIn` logs 'a', 'b', then 'c'. + */ +function forInRight(object, iteratee) { + return object == null + ? object + : baseForRight(object, baseIteratee(iteratee, 3), keysIn); +} + +module.exports = forInRight; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/forOwn.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/forOwn.js new file mode 100644 index 0000000..034c30b --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/forOwn.js @@ -0,0 +1,36 @@ +var baseForOwn = require('./_baseForOwn'), + baseIteratee = require('./_baseIteratee'); + +/** + * Iterates over own enumerable string keyed properties of an object and + * invokes `iteratee` for each property. The iteratee is invoked with three + * arguments: (value, key, object). Iteratee functions may exit iteration + * early by explicitly returning `false`. + * + * @static + * @memberOf _ + * @since 0.3.0 + * @category Object + * @param {Object} object The object to iterate over. + * @param {Function} [iteratee=_.identity] The function invoked per iteration. + * @returns {Object} Returns `object`. + * @see _.forOwnRight + * @example + * + * function Foo() { + * this.a = 1; + * this.b = 2; + * } + * + * Foo.prototype.c = 3; + * + * _.forOwn(new Foo, function(value, key) { + * console.log(key); + * }); + * // => Logs 'a' then 'b' (iteration order is not guaranteed). + */ +function forOwn(object, iteratee) { + return object && baseForOwn(object, baseIteratee(iteratee, 3)); +} + +module.exports = forOwn; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/forOwnRight.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/forOwnRight.js new file mode 100644 index 0000000..0f7aab8 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/forOwnRight.js @@ -0,0 +1,34 @@ +var baseForOwnRight = require('./_baseForOwnRight'), + baseIteratee = require('./_baseIteratee'); + +/** + * This method is like `_.forOwn` except that it iterates over properties of + * `object` in the opposite order. + * + * @static + * @memberOf _ + * @since 2.0.0 + * @category Object + * @param {Object} object The object to iterate over. + * @param {Function} [iteratee=_.identity] The function invoked per iteration. + * @returns {Object} Returns `object`. + * @see _.forOwn + * @example + * + * function Foo() { + * this.a = 1; + * this.b = 2; + * } + * + * Foo.prototype.c = 3; + * + * _.forOwnRight(new Foo, function(value, key) { + * console.log(key); + * }); + * // => Logs 'b' then 'a' assuming `_.forOwn` logs 'a' then 'b'. + */ +function forOwnRight(object, iteratee) { + return object && baseForOwnRight(object, baseIteratee(iteratee, 3)); +} + +module.exports = forOwnRight; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp.js new file mode 100644 index 0000000..e372dbb --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp.js @@ -0,0 +1,2 @@ +var _ = require('./lodash.min').runInContext(); +module.exports = require('./fp/_baseConvert')(_, _); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/F.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/F.js new file mode 100644 index 0000000..a05a63a --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/F.js @@ -0,0 +1 @@ +module.exports = require('./stubFalse'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/T.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/T.js new file mode 100644 index 0000000..e2ba8ea --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/T.js @@ -0,0 +1 @@ +module.exports = require('./stubTrue'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/__.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/__.js new file mode 100644 index 0000000..4af98de --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/__.js @@ -0,0 +1 @@ +module.exports = require('./placeholder'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/_baseConvert.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/_baseConvert.js new file mode 100644 index 0000000..0def5f6 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/_baseConvert.js @@ -0,0 +1,535 @@ +var mapping = require('./_mapping'), + mutateMap = mapping.mutate, + fallbackHolder = require('./placeholder'); + +/** + * Creates a function, with an arity of `n`, that invokes `func` with the + * arguments it receives. + * + * @private + * @param {Function} func The function to wrap. + * @param {number} n The arity of the new function. + * @returns {Function} Returns the new function. + */ +function baseArity(func, n) { + return n == 2 + ? function(a, b) { return func.apply(undefined, arguments); } + : function(a) { return func.apply(undefined, arguments); }; +} + +/** + * Creates a function that invokes `func`, with up to `n` arguments, ignoring + * any additional arguments. + * + * @private + * @param {Function} func The function to cap arguments for. + * @param {number} n The arity cap. + * @returns {Function} Returns the new function. + */ +function baseAry(func, n) { + return n == 2 + ? function(a, b) { return func(a, b); } + : function(a) { return func(a); }; +} + +/** + * Creates a clone of `array`. + * + * @private + * @param {Array} array The array to clone. + * @returns {Array} Returns the cloned array. + */ +function cloneArray(array) { + var length = array ? array.length : 0, + result = Array(length); + + while (length--) { + result[length] = array[length]; + } + return result; +} + +/** + * Creates a function that clones a given object using the assignment `func`. + * + * @private + * @param {Function} func The assignment function. + * @returns {Function} Returns the new cloner function. + */ +function createCloner(func) { + return function(object) { + return func({}, object); + }; +} + +/** + * Creates a function that wraps `func` and uses `cloner` to clone the first + * argument it receives. + * + * @private + * @param {Function} func The function to wrap. + * @param {Function} cloner The function to clone arguments. + * @returns {Function} Returns the new immutable function. + */ +function wrapImmutable(func, cloner) { + return function() { + var length = arguments.length; + if (!length) { + return; + } + var args = Array(length); + while (length--) { + args[length] = arguments[length]; + } + var result = args[0] = cloner.apply(undefined, args); + func.apply(undefined, args); + return result; + }; +} + +/** + * The base implementation of `convert` which accepts a `util` object of methods + * required to perform conversions. + * + * @param {Object} util The util object. + * @param {string} name The name of the function to convert. + * @param {Function} func The function to convert. + * @param {Object} [options] The options object. + * @param {boolean} [options.cap=true] Specify capping iteratee arguments. + * @param {boolean} [options.curry=true] Specify currying. + * @param {boolean} [options.fixed=true] Specify fixed arity. + * @param {boolean} [options.immutable=true] Specify immutable operations. + * @param {boolean} [options.rearg=true] Specify rearranging arguments. + * @returns {Function|Object} Returns the converted function or object. + */ +function baseConvert(util, name, func, options) { + var setPlaceholder, + isLib = typeof name == 'function', + isObj = name === Object(name); + + if (isObj) { + options = func; + func = name; + name = undefined; + } + if (func == null) { + throw new TypeError; + } + options || (options = {}); + + var config = { + 'cap': 'cap' in options ? options.cap : true, + 'curry': 'curry' in options ? options.curry : true, + 'fixed': 'fixed' in options ? options.fixed : true, + 'immutable': 'immutable' in options ? options.immutable : true, + 'rearg': 'rearg' in options ? options.rearg : true + }; + + var forceCurry = ('curry' in options) && options.curry, + forceFixed = ('fixed' in options) && options.fixed, + forceRearg = ('rearg' in options) && options.rearg, + placeholder = isLib ? func : fallbackHolder, + pristine = isLib ? func.runInContext() : undefined; + + var helpers = isLib ? func : { + 'ary': util.ary, + 'assign': util.assign, + 'clone': util.clone, + 'curry': util.curry, + 'forEach': util.forEach, + 'isArray': util.isArray, + 'isFunction': util.isFunction, + 'iteratee': util.iteratee, + 'keys': util.keys, + 'rearg': util.rearg, + 'spread': util.spread, + 'toInteger': util.toInteger, + 'toPath': util.toPath + }; + + var ary = helpers.ary, + assign = helpers.assign, + clone = helpers.clone, + curry = helpers.curry, + each = helpers.forEach, + isArray = helpers.isArray, + isFunction = helpers.isFunction, + keys = helpers.keys, + rearg = helpers.rearg, + spread = helpers.spread, + toInteger = helpers.toInteger, + toPath = helpers.toPath; + + var aryMethodKeys = keys(mapping.aryMethod); + + var wrappers = { + 'castArray': function(castArray) { + return function() { + var value = arguments[0]; + return isArray(value) + ? castArray(cloneArray(value)) + : castArray.apply(undefined, arguments); + }; + }, + 'iteratee': function(iteratee) { + return function() { + var func = arguments[0], + arity = arguments[1], + result = iteratee(func, arity), + length = result.length; + + if (config.cap && typeof arity == 'number') { + arity = arity > 2 ? (arity - 2) : 1; + return (length && length <= arity) ? result : baseAry(result, arity); + } + return result; + }; + }, + 'mixin': function(mixin) { + return function(source) { + var func = this; + if (!isFunction(func)) { + return mixin(func, Object(source)); + } + var pairs = []; + each(keys(source), function(key) { + if (isFunction(source[key])) { + pairs.push([key, func.prototype[key]]); + } + }); + + mixin(func, Object(source)); + + each(pairs, function(pair) { + var value = pair[1]; + if (isFunction(value)) { + func.prototype[pair[0]] = value; + } else { + delete func.prototype[pair[0]]; + } + }); + return func; + }; + }, + 'nthArg': function(nthArg) { + return function(n) { + var arity = n < 0 ? 1 : (toInteger(n) + 1); + return curry(nthArg(n), arity); + }; + }, + 'rearg': function(rearg) { + return function(func, indexes) { + var arity = indexes ? indexes.length : 0; + return curry(rearg(func, indexes), arity); + }; + }, + 'runInContext': function(runInContext) { + return function(context) { + return baseConvert(util, runInContext(context), options); + }; + } + }; + + /*--------------------------------------------------------------------------*/ + + /** + * Casts `func` to a function with an arity capped iteratee if needed. + * + * @private + * @param {string} name The name of the function to inspect. + * @param {Function} func The function to inspect. + * @returns {Function} Returns the cast function. + */ + function castCap(name, func) { + if (config.cap) { + var indexes = mapping.iterateeRearg[name]; + if (indexes) { + return iterateeRearg(func, indexes); + } + var n = !isLib && mapping.iterateeAry[name]; + if (n) { + return iterateeAry(func, n); + } + } + return func; + } + + /** + * Casts `func` to a curried function if needed. + * + * @private + * @param {string} name The name of the function to inspect. + * @param {Function} func The function to inspect. + * @param {number} n The arity of `func`. + * @returns {Function} Returns the cast function. + */ + function castCurry(name, func, n) { + return (forceCurry || (config.curry && n > 1)) + ? curry(func, n) + : func; + } + + /** + * Casts `func` to a fixed arity function if needed. + * + * @private + * @param {string} name The name of the function to inspect. + * @param {Function} func The function to inspect. + * @param {number} n The arity cap. + * @returns {Function} Returns the cast function. + */ + function castFixed(name, func, n) { + if (config.fixed && (forceFixed || !mapping.skipFixed[name])) { + var data = mapping.methodSpread[name], + start = data && data.start; + + return start === undefined ? ary(func, n) : spread(func, start); + } + return func; + } + + /** + * Casts `func` to an rearged function if needed. + * + * @private + * @param {string} name The name of the function to inspect. + * @param {Function} func The function to inspect. + * @param {number} n The arity of `func`. + * @returns {Function} Returns the cast function. + */ + function castRearg(name, func, n) { + return (config.rearg && n > 1 && (forceRearg || !mapping.skipRearg[name])) + ? rearg(func, mapping.methodRearg[name] || mapping.aryRearg[n]) + : func; + } + + /** + * Creates a clone of `object` by `path`. + * + * @private + * @param {Object} object The object to clone. + * @param {Array|string} path The path to clone by. + * @returns {Object} Returns the cloned object. + */ + function cloneByPath(object, path) { + path = toPath(path); + + var index = -1, + length = path.length, + lastIndex = length - 1, + result = clone(Object(object)), + nested = result; + + while (nested != null && ++index < length) { + var key = path[index], + value = nested[key]; + + if (value != null) { + nested[path[index]] = clone(index == lastIndex ? value : Object(value)); + } + nested = nested[key]; + } + return result; + } + + /** + * Converts `lodash` to an immutable auto-curried iteratee-first data-last + * version with conversion `options` applied. + * + * @param {Object} [options] The options object. See `baseConvert` for more details. + * @returns {Function} Returns the converted `lodash`. + */ + function convertLib(options) { + return _.runInContext.convert(options)(undefined); + } + + /** + * Create a converter function for `func` of `name`. + * + * @param {string} name The name of the function to convert. + * @param {Function} func The function to convert. + * @returns {Function} Returns the new converter function. + */ + function createConverter(name, func) { + var oldOptions = options; + return function(options) { + var newUtil = isLib ? pristine : helpers, + newFunc = isLib ? pristine[name] : func, + newOptions = assign(assign({}, oldOptions), options); + + return baseConvert(newUtil, name, newFunc, newOptions); + }; + } + + /** + * Creates a function that wraps `func` to invoke its iteratee, with up to `n` + * arguments, ignoring any additional arguments. + * + * @private + * @param {Function} func The function to cap iteratee arguments for. + * @param {number} n The arity cap. + * @returns {Function} Returns the new function. + */ + function iterateeAry(func, n) { + return overArg(func, function(func) { + return typeof func == 'function' ? baseAry(func, n) : func; + }); + } + + /** + * Creates a function that wraps `func` to invoke its iteratee with arguments + * arranged according to the specified `indexes` where the argument value at + * the first index is provided as the first argument, the argument value at + * the second index is provided as the second argument, and so on. + * + * @private + * @param {Function} func The function to rearrange iteratee arguments for. + * @param {number[]} indexes The arranged argument indexes. + * @returns {Function} Returns the new function. + */ + function iterateeRearg(func, indexes) { + return overArg(func, function(func) { + var n = indexes.length; + return baseArity(rearg(baseAry(func, n), indexes), n); + }); + } + + /** + * Creates a function that invokes `func` with its first argument transformed. + * + * @private + * @param {Function} func The function to wrap. + * @param {Function} transform The argument transform. + * @returns {Function} Returns the new function. + */ + function overArg(func, transform) { + return function() { + var length = arguments.length; + if (!length) { + return func(); + } + var args = Array(length); + while (length--) { + args[length] = arguments[length]; + } + var index = config.rearg ? 0 : (length - 1); + args[index] = transform(args[index]); + return func.apply(undefined, args); + }; + } + + /** + * Creates a function that wraps `func` and applys the conversions + * rules by `name`. + * + * @private + * @param {string} name The name of the function to wrap. + * @param {Function} func The function to wrap. + * @returns {Function} Returns the converted function. + */ + function wrap(name, func) { + name = mapping.aliasToReal[name] || name; + + var result, + wrapped = func, + wrapper = wrappers[name]; + + if (wrapper) { + wrapped = wrapper(func); + } + else if (config.immutable) { + if (mutateMap.array[name]) { + wrapped = wrapImmutable(func, cloneArray); + } + else if (mutateMap.object[name]) { + wrapped = wrapImmutable(func, createCloner(func)); + } + else if (mutateMap.set[name]) { + wrapped = wrapImmutable(func, cloneByPath); + } + } + each(aryMethodKeys, function(aryKey) { + each(mapping.aryMethod[aryKey], function(otherName) { + if (name == otherName) { + var spreadData = mapping.methodSpread[name], + afterRearg = spreadData && spreadData.afterRearg; + + result = afterRearg + ? castFixed(name, castRearg(name, wrapped, aryKey), aryKey) + : castRearg(name, castFixed(name, wrapped, aryKey), aryKey); + + result = castCap(name, result); + result = castCurry(name, result, aryKey); + return false; + } + }); + return !result; + }); + + result || (result = wrapped); + if (result == func) { + result = forceCurry ? curry(result, 1) : function() { + return func.apply(this, arguments); + }; + } + result.convert = createConverter(name, func); + if (mapping.placeholder[name]) { + setPlaceholder = true; + result.placeholder = func.placeholder = placeholder; + } + return result; + } + + /*--------------------------------------------------------------------------*/ + + if (!isObj) { + return wrap(name, func); + } + var _ = func; + + // Convert methods by ary cap. + var pairs = []; + each(aryMethodKeys, function(aryKey) { + each(mapping.aryMethod[aryKey], function(key) { + var func = _[mapping.remap[key] || key]; + if (func) { + pairs.push([key, wrap(key, func)]); + } + }); + }); + + // Convert remaining methods. + each(keys(_), function(key) { + var func = _[key]; + if (typeof func == 'function') { + var length = pairs.length; + while (length--) { + if (pairs[length][0] == key) { + return; + } + } + func.convert = createConverter(key, func); + pairs.push([key, func]); + } + }); + + // Assign to `_` leaving `_.prototype` unchanged to allow chaining. + each(pairs, function(pair) { + _[pair[0]] = pair[1]; + }); + + _.convert = convertLib; + if (setPlaceholder) { + _.placeholder = placeholder; + } + // Assign aliases. + each(keys(_), function(key) { + each(mapping.realToAlias[key] || [], function(alias) { + _[alias] = _[key]; + }); + }); + + return _; +} + +module.exports = baseConvert; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/_convertBrowser.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/_convertBrowser.js new file mode 100644 index 0000000..bde030d --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/_convertBrowser.js @@ -0,0 +1,18 @@ +var baseConvert = require('./_baseConvert'); + +/** + * Converts `lodash` to an immutable auto-curried iteratee-first data-last + * version with conversion `options` applied. + * + * @param {Function} lodash The lodash function to convert. + * @param {Object} [options] The options object. See `baseConvert` for more details. + * @returns {Function} Returns the converted `lodash`. + */ +function browserConvert(lodash, options) { + return baseConvert(lodash, lodash, options); +} + +if (typeof _ == 'function' && typeof _.runInContext == 'function') { + _ = browserConvert(_.runInContext()); +} +module.exports = browserConvert; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/_falseOptions.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/_falseOptions.js new file mode 100644 index 0000000..773235e --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/_falseOptions.js @@ -0,0 +1,7 @@ +module.exports = { + 'cap': false, + 'curry': false, + 'fixed': false, + 'immutable': false, + 'rearg': false +}; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/_mapping.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/_mapping.js new file mode 100644 index 0000000..7fa8e67 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/_mapping.js @@ -0,0 +1,367 @@ +/** Used to map aliases to their real names. */ +exports.aliasToReal = { + + // Lodash aliases. + 'each': 'forEach', + 'eachRight': 'forEachRight', + 'entries': 'toPairs', + 'entriesIn': 'toPairsIn', + 'extend': 'assignIn', + 'extendAll': 'assignInAll', + 'extendAllWith': 'assignInAllWith', + 'extendWith': 'assignInWith', + 'first': 'head', + + // Methods that are curried variants of others. + 'conforms': 'conformsTo', + 'matches': 'isMatch', + 'property': 'get', + + // Ramda aliases. + '__': 'placeholder', + 'F': 'stubFalse', + 'T': 'stubTrue', + 'all': 'every', + 'allPass': 'overEvery', + 'always': 'constant', + 'any': 'some', + 'anyPass': 'overSome', + 'apply': 'spread', + 'assoc': 'set', + 'assocPath': 'set', + 'complement': 'negate', + 'compose': 'flowRight', + 'contains': 'includes', + 'dissoc': 'unset', + 'dissocPath': 'unset', + 'dropLast': 'dropRight', + 'dropLastWhile': 'dropRightWhile', + 'equals': 'isEqual', + 'identical': 'eq', + 'indexBy': 'keyBy', + 'init': 'initial', + 'invertObj': 'invert', + 'juxt': 'over', + 'omitAll': 'omit', + 'nAry': 'ary', + 'path': 'get', + 'pathEq': 'matchesProperty', + 'pathOr': 'getOr', + 'paths': 'at', + 'pickAll': 'pick', + 'pipe': 'flow', + 'pluck': 'map', + 'prop': 'get', + 'propEq': 'matchesProperty', + 'propOr': 'getOr', + 'props': 'at', + 'symmetricDifference': 'xor', + 'symmetricDifferenceBy': 'xorBy', + 'symmetricDifferenceWith': 'xorWith', + 'takeLast': 'takeRight', + 'takeLastWhile': 'takeRightWhile', + 'unapply': 'rest', + 'unnest': 'flatten', + 'useWith': 'overArgs', + 'where': 'conformsTo', + 'whereEq': 'isMatch', + 'zipObj': 'zipObject' +}; + +/** Used to map ary to method names. */ +exports.aryMethod = { + '1': [ + 'assignAll', 'assignInAll', 'attempt', 'castArray', 'ceil', 'create', + 'curry', 'curryRight', 'defaultsAll', 'defaultsDeepAll', 'floor', 'flow', + 'flowRight', 'fromPairs', 'invert', 'iteratee', 'memoize', 'method', 'mergeAll', + 'methodOf', 'mixin', 'nthArg', 'over', 'overEvery', 'overSome','rest', 'reverse', + 'round', 'runInContext', 'spread', 'template', 'trim', 'trimEnd', 'trimStart', + 'uniqueId', 'words', 'zipAll' + ], + '2': [ + 'add', 'after', 'ary', 'assign', 'assignAllWith', 'assignIn', 'assignInAllWith', + 'at', 'before', 'bind', 'bindAll', 'bindKey', 'chunk', 'cloneDeepWith', + 'cloneWith', 'concat', 'conformsTo', 'countBy', 'curryN', 'curryRightN', + 'debounce', 'defaults', 'defaultsDeep', 'defaultTo', 'delay', 'difference', + 'divide', 'drop', 'dropRight', 'dropRightWhile', 'dropWhile', 'endsWith', 'eq', + 'every', 'filter', 'find', 'findIndex', 'findKey', 'findLast', 'findLastIndex', + 'findLastKey', 'flatMap', 'flatMapDeep', 'flattenDepth', 'forEach', + 'forEachRight', 'forIn', 'forInRight', 'forOwn', 'forOwnRight', 'get', + 'groupBy', 'gt', 'gte', 'has', 'hasIn', 'includes', 'indexOf', 'intersection', + 'invertBy', 'invoke', 'invokeMap', 'isEqual', 'isMatch', 'join', 'keyBy', + 'lastIndexOf', 'lt', 'lte', 'map', 'mapKeys', 'mapValues', 'matchesProperty', + 'maxBy', 'meanBy', 'merge', 'mergeAllWith', 'minBy', 'multiply', 'nth', 'omit', + 'omitBy', 'overArgs', 'pad', 'padEnd', 'padStart', 'parseInt', 'partial', + 'partialRight', 'partition', 'pick', 'pickBy', 'propertyOf', 'pull', 'pullAll', + 'pullAt', 'random', 'range', 'rangeRight', 'rearg', 'reject', 'remove', + 'repeat', 'restFrom', 'result', 'sampleSize', 'some', 'sortBy', 'sortedIndex', + 'sortedIndexOf', 'sortedLastIndex', 'sortedLastIndexOf', 'sortedUniqBy', + 'split', 'spreadFrom', 'startsWith', 'subtract', 'sumBy', 'take', 'takeRight', + 'takeRightWhile', 'takeWhile', 'tap', 'throttle', 'thru', 'times', 'trimChars', + 'trimCharsEnd', 'trimCharsStart', 'truncate', 'union', 'uniqBy', 'uniqWith', + 'unset', 'unzipWith', 'without', 'wrap', 'xor', 'zip', 'zipObject', + 'zipObjectDeep' + ], + '3': [ + 'assignInWith', 'assignWith', 'clamp', 'differenceBy', 'differenceWith', + 'findFrom', 'findIndexFrom', 'findLastFrom', 'findLastIndexFrom', 'getOr', + 'includesFrom', 'indexOfFrom', 'inRange', 'intersectionBy', 'intersectionWith', + 'invokeArgs', 'invokeArgsMap', 'isEqualWith', 'isMatchWith', 'flatMapDepth', + 'lastIndexOfFrom', 'mergeWith', 'orderBy', 'padChars', 'padCharsEnd', + 'padCharsStart', 'pullAllBy', 'pullAllWith', 'rangeStep', 'rangeStepRight', + 'reduce', 'reduceRight', 'replace', 'set', 'slice', 'sortedIndexBy', + 'sortedLastIndexBy', 'transform', 'unionBy', 'unionWith', 'update', 'xorBy', + 'xorWith', 'zipWith' + ], + '4': [ + 'fill', 'setWith', 'updateWith' + ] +}; + +/** Used to map ary to rearg configs. */ +exports.aryRearg = { + '2': [1, 0], + '3': [2, 0, 1], + '4': [3, 2, 0, 1] +}; + +/** Used to map method names to their iteratee ary. */ +exports.iterateeAry = { + 'dropRightWhile': 1, + 'dropWhile': 1, + 'every': 1, + 'filter': 1, + 'find': 1, + 'findFrom': 1, + 'findIndex': 1, + 'findIndexFrom': 1, + 'findKey': 1, + 'findLast': 1, + 'findLastFrom': 1, + 'findLastIndex': 1, + 'findLastIndexFrom': 1, + 'findLastKey': 1, + 'flatMap': 1, + 'flatMapDeep': 1, + 'flatMapDepth': 1, + 'forEach': 1, + 'forEachRight': 1, + 'forIn': 1, + 'forInRight': 1, + 'forOwn': 1, + 'forOwnRight': 1, + 'map': 1, + 'mapKeys': 1, + 'mapValues': 1, + 'partition': 1, + 'reduce': 2, + 'reduceRight': 2, + 'reject': 1, + 'remove': 1, + 'some': 1, + 'takeRightWhile': 1, + 'takeWhile': 1, + 'times': 1, + 'transform': 2 +}; + +/** Used to map method names to iteratee rearg configs. */ +exports.iterateeRearg = { + 'mapKeys': [1] +}; + +/** Used to map method names to rearg configs. */ +exports.methodRearg = { + 'assignInAllWith': [1, 2, 0], + 'assignInWith': [1, 2, 0], + 'assignAllWith': [1, 2, 0], + 'assignWith': [1, 2, 0], + 'differenceBy': [1, 2, 0], + 'differenceWith': [1, 2, 0], + 'getOr': [2, 1, 0], + 'intersectionBy': [1, 2, 0], + 'intersectionWith': [1, 2, 0], + 'isEqualWith': [1, 2, 0], + 'isMatchWith': [2, 1, 0], + 'mergeAllWith': [1, 2, 0], + 'mergeWith': [1, 2, 0], + 'padChars': [2, 1, 0], + 'padCharsEnd': [2, 1, 0], + 'padCharsStart': [2, 1, 0], + 'pullAllBy': [2, 1, 0], + 'pullAllWith': [2, 1, 0], + 'rangeStep': [1, 2, 0], + 'rangeStepRight': [1, 2, 0], + 'setWith': [3, 1, 2, 0], + 'sortedIndexBy': [2, 1, 0], + 'sortedLastIndexBy': [2, 1, 0], + 'unionBy': [1, 2, 0], + 'unionWith': [1, 2, 0], + 'updateWith': [3, 1, 2, 0], + 'xorBy': [1, 2, 0], + 'xorWith': [1, 2, 0], + 'zipWith': [1, 2, 0] +}; + +/** Used to map method names to spread configs. */ +exports.methodSpread = { + 'assignAll': { 'start': 0 }, + 'assignAllWith': { 'afterRearg': true, 'start': 1 }, + 'assignInAll': { 'start': 0 }, + 'assignInAllWith': { 'afterRearg': true, 'start': 1 }, + 'defaultsAll': { 'start': 0 }, + 'defaultsDeepAll': { 'start': 0 }, + 'invokeArgs': { 'start': 2 }, + 'invokeArgsMap': { 'start': 2 }, + 'mergeAll': { 'start': 0 }, + 'mergeAllWith': { 'afterRearg': true, 'start': 1 }, + 'partial': { 'start': 1 }, + 'partialRight': { 'start': 1 }, + 'without': { 'start': 1 }, + 'zipAll': { 'start': 0 } +}; + +/** Used to identify methods which mutate arrays or objects. */ +exports.mutate = { + 'array': { + 'fill': true, + 'pull': true, + 'pullAll': true, + 'pullAllBy': true, + 'pullAllWith': true, + 'pullAt': true, + 'remove': true, + 'reverse': true + }, + 'object': { + 'assign': true, + 'assignAll': true, + 'assignAllWith': true, + 'assignIn': true, + 'assignInAll': true, + 'assignInAllWith': true, + 'assignInWith': true, + 'assignWith': true, + 'defaults': true, + 'defaultsAll': true, + 'defaultsDeep': true, + 'defaultsDeepAll': true, + 'merge': true, + 'mergeAll': true, + 'mergeAllWith': true, + 'mergeWith': true, + }, + 'set': { + 'set': true, + 'setWith': true, + 'unset': true, + 'update': true, + 'updateWith': true + } +}; + +/** Used to track methods with placeholder support */ +exports.placeholder = { + 'bind': true, + 'bindKey': true, + 'curry': true, + 'curryRight': true, + 'partial': true, + 'partialRight': true +}; + +/** Used to map real names to their aliases. */ +exports.realToAlias = (function() { + var hasOwnProperty = Object.prototype.hasOwnProperty, + object = exports.aliasToReal, + result = {}; + + for (var key in object) { + var value = object[key]; + if (hasOwnProperty.call(result, value)) { + result[value].push(key); + } else { + result[value] = [key]; + } + } + return result; +}()); + +/** Used to map method names to other names. */ +exports.remap = { + 'assignAll': 'assign', + 'assignAllWith': 'assignWith', + 'assignInAll': 'assignIn', + 'assignInAllWith': 'assignInWith', + 'curryN': 'curry', + 'curryRightN': 'curryRight', + 'defaultsAll': 'defaults', + 'defaultsDeepAll': 'defaultsDeep', + 'findFrom': 'find', + 'findIndexFrom': 'findIndex', + 'findLastFrom': 'findLast', + 'findLastIndexFrom': 'findLastIndex', + 'getOr': 'get', + 'includesFrom': 'includes', + 'indexOfFrom': 'indexOf', + 'invokeArgs': 'invoke', + 'invokeArgsMap': 'invokeMap', + 'lastIndexOfFrom': 'lastIndexOf', + 'mergeAll': 'merge', + 'mergeAllWith': 'mergeWith', + 'padChars': 'pad', + 'padCharsEnd': 'padEnd', + 'padCharsStart': 'padStart', + 'propertyOf': 'get', + 'rangeStep': 'range', + 'rangeStepRight': 'rangeRight', + 'restFrom': 'rest', + 'spreadFrom': 'spread', + 'trimChars': 'trim', + 'trimCharsEnd': 'trimEnd', + 'trimCharsStart': 'trimStart', + 'zipAll': 'zip' +}; + +/** Used to track methods that skip fixing their arity. */ +exports.skipFixed = { + 'castArray': true, + 'flow': true, + 'flowRight': true, + 'iteratee': true, + 'mixin': true, + 'rearg': true, + 'runInContext': true +}; + +/** Used to track methods that skip rearranging arguments. */ +exports.skipRearg = { + 'add': true, + 'assign': true, + 'assignIn': true, + 'bind': true, + 'bindKey': true, + 'concat': true, + 'difference': true, + 'divide': true, + 'eq': true, + 'gt': true, + 'gte': true, + 'isEqual': true, + 'lt': true, + 'lte': true, + 'matchesProperty': true, + 'merge': true, + 'multiply': true, + 'overArgs': true, + 'partial': true, + 'partialRight': true, + 'propertyOf': true, + 'random': true, + 'range': true, + 'rangeRight': true, + 'subtract': true, + 'zip': true, + 'zipObject': true, + 'zipObjectDeep': true +}; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/_util.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/_util.js new file mode 100644 index 0000000..f814812 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/_util.js @@ -0,0 +1,15 @@ +module.exports = { + 'ary': require('../ary'), + 'assign': require('../_baseAssign'), + 'clone': require('../clone'), + 'curry': require('../curry'), + 'forEach': require('../_arrayEach'), + 'isArray': require('../isArray'), + 'isFunction': require('../isFunction'), + 'iteratee': require('../iteratee'), + 'keys': require('../_baseKeys'), + 'rearg': require('../rearg'), + 'spread': require('../spread'), + 'toInteger': require('../toInteger'), + 'toPath': require('../toPath') +}; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/add.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/add.js new file mode 100644 index 0000000..816eeec --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/add.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('add', require('../add')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/after.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/after.js new file mode 100644 index 0000000..21a0167 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/after.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('after', require('../after')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/all.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/all.js new file mode 100644 index 0000000..d0839f7 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/all.js @@ -0,0 +1 @@ +module.exports = require('./every'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/allPass.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/allPass.js new file mode 100644 index 0000000..79b73ef --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/allPass.js @@ -0,0 +1 @@ +module.exports = require('./overEvery'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/always.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/always.js new file mode 100644 index 0000000..9887703 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/always.js @@ -0,0 +1 @@ +module.exports = require('./constant'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/any.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/any.js new file mode 100644 index 0000000..900ac25 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/any.js @@ -0,0 +1 @@ +module.exports = require('./some'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/anyPass.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/anyPass.js new file mode 100644 index 0000000..2774ab3 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/anyPass.js @@ -0,0 +1 @@ +module.exports = require('./overSome'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/apply.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/apply.js new file mode 100644 index 0000000..2b75712 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/apply.js @@ -0,0 +1 @@ +module.exports = require('./spread'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/array.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/array.js new file mode 100644 index 0000000..fe939c2 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/array.js @@ -0,0 +1,2 @@ +var convert = require('./convert'); +module.exports = convert(require('../array')); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/ary.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/ary.js new file mode 100644 index 0000000..8edf187 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/ary.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('ary', require('../ary')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/assign.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/assign.js new file mode 100644 index 0000000..23f47af --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/assign.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('assign', require('../assign')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/assignAll.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/assignAll.js new file mode 100644 index 0000000..b1d36c7 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/assignAll.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('assignAll', require('../assign')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/assignAllWith.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/assignAllWith.js new file mode 100644 index 0000000..21e836e --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/assignAllWith.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('assignAllWith', require('../assignWith')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/assignIn.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/assignIn.js new file mode 100644 index 0000000..6e7c65f --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/assignIn.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('assignIn', require('../assignIn')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/assignInAll.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/assignInAll.js new file mode 100644 index 0000000..7ba75db --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/assignInAll.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('assignInAll', require('../assignIn')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/assignInAllWith.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/assignInAllWith.js new file mode 100644 index 0000000..e766903 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/assignInAllWith.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('assignInAllWith', require('../assignInWith')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/assignInWith.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/assignInWith.js new file mode 100644 index 0000000..acb5923 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/assignInWith.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('assignInWith', require('../assignInWith')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/assignWith.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/assignWith.js new file mode 100644 index 0000000..eb92521 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/assignWith.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('assignWith', require('../assignWith')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/assoc.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/assoc.js new file mode 100644 index 0000000..7648820 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/assoc.js @@ -0,0 +1 @@ +module.exports = require('./set'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/assocPath.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/assocPath.js new file mode 100644 index 0000000..7648820 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/assocPath.js @@ -0,0 +1 @@ +module.exports = require('./set'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/at.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/at.js new file mode 100644 index 0000000..cc39d25 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/at.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('at', require('../at')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/attempt.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/attempt.js new file mode 100644 index 0000000..26ca42e --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/attempt.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('attempt', require('../attempt')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/before.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/before.js new file mode 100644 index 0000000..7a2de65 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/before.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('before', require('../before')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/bind.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/bind.js new file mode 100644 index 0000000..5cbe4f3 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/bind.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('bind', require('../bind')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/bindAll.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/bindAll.js new file mode 100644 index 0000000..6b4a4a0 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/bindAll.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('bindAll', require('../bindAll')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/bindKey.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/bindKey.js new file mode 100644 index 0000000..6a46c6b --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/bindKey.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('bindKey', require('../bindKey')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/camelCase.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/camelCase.js new file mode 100644 index 0000000..87b77b4 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/camelCase.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('camelCase', require('../camelCase'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/capitalize.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/capitalize.js new file mode 100644 index 0000000..cac74e1 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/capitalize.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('capitalize', require('../capitalize'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/castArray.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/castArray.js new file mode 100644 index 0000000..8681c09 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/castArray.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('castArray', require('../castArray')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/ceil.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/ceil.js new file mode 100644 index 0000000..f416b72 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/ceil.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('ceil', require('../ceil')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/chain.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/chain.js new file mode 100644 index 0000000..604fe39 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/chain.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('chain', require('../chain'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/chunk.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/chunk.js new file mode 100644 index 0000000..871ab08 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/chunk.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('chunk', require('../chunk')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/clamp.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/clamp.js new file mode 100644 index 0000000..3b06c01 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/clamp.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('clamp', require('../clamp')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/clone.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/clone.js new file mode 100644 index 0000000..cadb59c --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/clone.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('clone', require('../clone'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/cloneDeep.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/cloneDeep.js new file mode 100644 index 0000000..a6107aa --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/cloneDeep.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('cloneDeep', require('../cloneDeep'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/cloneDeepWith.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/cloneDeepWith.js new file mode 100644 index 0000000..6f01e44 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/cloneDeepWith.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('cloneDeepWith', require('../cloneDeepWith')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/cloneWith.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/cloneWith.js new file mode 100644 index 0000000..aa88578 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/cloneWith.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('cloneWith', require('../cloneWith')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/collection.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/collection.js new file mode 100644 index 0000000..fc8b328 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/collection.js @@ -0,0 +1,2 @@ +var convert = require('./convert'); +module.exports = convert(require('../collection')); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/commit.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/commit.js new file mode 100644 index 0000000..130a894 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/commit.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('commit', require('../commit'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/compact.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/compact.js new file mode 100644 index 0000000..ce8f7a1 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/compact.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('compact', require('../compact'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/complement.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/complement.js new file mode 100644 index 0000000..93eb462 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/complement.js @@ -0,0 +1 @@ +module.exports = require('./negate'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/compose.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/compose.js new file mode 100644 index 0000000..1954e94 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/compose.js @@ -0,0 +1 @@ +module.exports = require('./flowRight'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/concat.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/concat.js new file mode 100644 index 0000000..e59346a --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/concat.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('concat', require('../concat')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/cond.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/cond.js new file mode 100644 index 0000000..6a0120e --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/cond.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('cond', require('../cond'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/conforms.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/conforms.js new file mode 100644 index 0000000..3247f64 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/conforms.js @@ -0,0 +1 @@ +module.exports = require('./conformsTo'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/conformsTo.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/conformsTo.js new file mode 100644 index 0000000..aa7f41e --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/conformsTo.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('conformsTo', require('../conformsTo')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/constant.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/constant.js new file mode 100644 index 0000000..9e406fc --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/constant.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('constant', require('../constant'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/contains.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/contains.js new file mode 100644 index 0000000..594722a --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/contains.js @@ -0,0 +1 @@ +module.exports = require('./includes'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/convert.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/convert.js new file mode 100644 index 0000000..4795dc4 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/convert.js @@ -0,0 +1,18 @@ +var baseConvert = require('./_baseConvert'), + util = require('./_util'); + +/** + * Converts `func` of `name` to an immutable auto-curried iteratee-first data-last + * version with conversion `options` applied. If `name` is an object its methods + * will be converted. + * + * @param {string} name The name of the function to wrap. + * @param {Function} [func] The function to wrap. + * @param {Object} [options] The options object. See `baseConvert` for more details. + * @returns {Function|Object} Returns the converted function or object. + */ +function convert(name, func, options) { + return baseConvert(util, name, func, options); +} + +module.exports = convert; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/countBy.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/countBy.js new file mode 100644 index 0000000..dfa4643 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/countBy.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('countBy', require('../countBy')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/create.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/create.js new file mode 100644 index 0000000..752025f --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/create.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('create', require('../create')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/curry.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/curry.js new file mode 100644 index 0000000..b0b4168 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/curry.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('curry', require('../curry')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/curryN.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/curryN.js new file mode 100644 index 0000000..2ae7d00 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/curryN.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('curryN', require('../curry')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/curryRight.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/curryRight.js new file mode 100644 index 0000000..cb619eb --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/curryRight.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('curryRight', require('../curryRight')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/curryRightN.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/curryRightN.js new file mode 100644 index 0000000..2495afc --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/curryRightN.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('curryRightN', require('../curryRight')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/date.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/date.js new file mode 100644 index 0000000..82cb952 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/date.js @@ -0,0 +1,2 @@ +var convert = require('./convert'); +module.exports = convert(require('../date')); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/debounce.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/debounce.js new file mode 100644 index 0000000..2612229 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/debounce.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('debounce', require('../debounce')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/deburr.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/deburr.js new file mode 100644 index 0000000..96463ab --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/deburr.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('deburr', require('../deburr'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/defaultTo.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/defaultTo.js new file mode 100644 index 0000000..d6b52a4 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/defaultTo.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('defaultTo', require('../defaultTo')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/defaults.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/defaults.js new file mode 100644 index 0000000..e1a8e6e --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/defaults.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('defaults', require('../defaults')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/defaultsAll.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/defaultsAll.js new file mode 100644 index 0000000..238fcc3 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/defaultsAll.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('defaultsAll', require('../defaults')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/defaultsDeep.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/defaultsDeep.js new file mode 100644 index 0000000..1f172ff --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/defaultsDeep.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('defaultsDeep', require('../defaultsDeep')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/defaultsDeepAll.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/defaultsDeepAll.js new file mode 100644 index 0000000..6835f2f --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/defaultsDeepAll.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('defaultsDeepAll', require('../defaultsDeep')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/defer.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/defer.js new file mode 100644 index 0000000..ec7990f --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/defer.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('defer', require('../defer'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/delay.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/delay.js new file mode 100644 index 0000000..556dbd5 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/delay.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('delay', require('../delay')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/difference.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/difference.js new file mode 100644 index 0000000..2d03765 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/difference.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('difference', require('../difference')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/differenceBy.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/differenceBy.js new file mode 100644 index 0000000..2f91491 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/differenceBy.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('differenceBy', require('../differenceBy')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/differenceWith.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/differenceWith.js new file mode 100644 index 0000000..bcf5ad2 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/differenceWith.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('differenceWith', require('../differenceWith')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/dissoc.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/dissoc.js new file mode 100644 index 0000000..7ec7be1 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/dissoc.js @@ -0,0 +1 @@ +module.exports = require('./unset'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/dissocPath.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/dissocPath.js new file mode 100644 index 0000000..7ec7be1 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/dissocPath.js @@ -0,0 +1 @@ +module.exports = require('./unset'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/divide.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/divide.js new file mode 100644 index 0000000..82048c5 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/divide.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('divide', require('../divide')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/drop.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/drop.js new file mode 100644 index 0000000..2fa9b4f --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/drop.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('drop', require('../drop')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/dropLast.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/dropLast.js new file mode 100644 index 0000000..174e525 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/dropLast.js @@ -0,0 +1 @@ +module.exports = require('./dropRight'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/dropLastWhile.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/dropLastWhile.js new file mode 100644 index 0000000..be2a9d2 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/dropLastWhile.js @@ -0,0 +1 @@ +module.exports = require('./dropRightWhile'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/dropRight.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/dropRight.js new file mode 100644 index 0000000..e98881f --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/dropRight.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('dropRight', require('../dropRight')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/dropRightWhile.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/dropRightWhile.js new file mode 100644 index 0000000..cacaa70 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/dropRightWhile.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('dropRightWhile', require('../dropRightWhile')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/dropWhile.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/dropWhile.js new file mode 100644 index 0000000..285f864 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/dropWhile.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('dropWhile', require('../dropWhile')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/each.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/each.js new file mode 100644 index 0000000..8800f42 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/each.js @@ -0,0 +1 @@ +module.exports = require('./forEach'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/eachRight.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/eachRight.js new file mode 100644 index 0000000..3252b2a --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/eachRight.js @@ -0,0 +1 @@ +module.exports = require('./forEachRight'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/endsWith.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/endsWith.js new file mode 100644 index 0000000..17dc2a4 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/endsWith.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('endsWith', require('../endsWith')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/entries.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/entries.js new file mode 100644 index 0000000..7a88df2 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/entries.js @@ -0,0 +1 @@ +module.exports = require('./toPairs'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/entriesIn.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/entriesIn.js new file mode 100644 index 0000000..f6c6331 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/entriesIn.js @@ -0,0 +1 @@ +module.exports = require('./toPairsIn'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/eq.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/eq.js new file mode 100644 index 0000000..9a3d21b --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/eq.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('eq', require('../eq')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/equals.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/equals.js new file mode 100644 index 0000000..e6a5ce0 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/equals.js @@ -0,0 +1 @@ +module.exports = require('./isEqual'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/escape.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/escape.js new file mode 100644 index 0000000..52c1fbb --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/escape.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('escape', require('../escape'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/escapeRegExp.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/escapeRegExp.js new file mode 100644 index 0000000..369b2ef --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/escapeRegExp.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('escapeRegExp', require('../escapeRegExp'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/every.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/every.js new file mode 100644 index 0000000..95c2776 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/every.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('every', require('../every')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/extend.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/extend.js new file mode 100644 index 0000000..e00166c --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/extend.js @@ -0,0 +1 @@ +module.exports = require('./assignIn'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/extendAll.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/extendAll.js new file mode 100644 index 0000000..cc55b64 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/extendAll.js @@ -0,0 +1 @@ +module.exports = require('./assignInAll'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/extendAllWith.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/extendAllWith.js new file mode 100644 index 0000000..6679d20 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/extendAllWith.js @@ -0,0 +1 @@ +module.exports = require('./assignInAllWith'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/extendWith.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/extendWith.js new file mode 100644 index 0000000..dbdcb3b --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/extendWith.js @@ -0,0 +1 @@ +module.exports = require('./assignInWith'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/fill.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/fill.js new file mode 100644 index 0000000..b2d47e8 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/fill.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('fill', require('../fill')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/filter.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/filter.js new file mode 100644 index 0000000..796d501 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/filter.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('filter', require('../filter')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/find.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/find.js new file mode 100644 index 0000000..f805d33 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/find.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('find', require('../find')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/findFrom.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/findFrom.js new file mode 100644 index 0000000..da8275e --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/findFrom.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('findFrom', require('../find')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/findIndex.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/findIndex.js new file mode 100644 index 0000000..8c15fd1 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/findIndex.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('findIndex', require('../findIndex')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/findIndexFrom.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/findIndexFrom.js new file mode 100644 index 0000000..32e98cb --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/findIndexFrom.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('findIndexFrom', require('../findIndex')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/findKey.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/findKey.js new file mode 100644 index 0000000..475bcfa --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/findKey.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('findKey', require('../findKey')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/findLast.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/findLast.js new file mode 100644 index 0000000..093fe94 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/findLast.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('findLast', require('../findLast')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/findLastFrom.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/findLastFrom.js new file mode 100644 index 0000000..76c38fb --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/findLastFrom.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('findLastFrom', require('../findLast')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/findLastIndex.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/findLastIndex.js new file mode 100644 index 0000000..36986df --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/findLastIndex.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('findLastIndex', require('../findLastIndex')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/findLastIndexFrom.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/findLastIndexFrom.js new file mode 100644 index 0000000..34c8176 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/findLastIndexFrom.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('findLastIndexFrom', require('../findLastIndex')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/findLastKey.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/findLastKey.js new file mode 100644 index 0000000..5f81b60 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/findLastKey.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('findLastKey', require('../findLastKey')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/first.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/first.js new file mode 100644 index 0000000..53f4ad1 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/first.js @@ -0,0 +1 @@ +module.exports = require('./head'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/flatMap.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/flatMap.js new file mode 100644 index 0000000..d01dc4d --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/flatMap.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('flatMap', require('../flatMap')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/flatMapDeep.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/flatMapDeep.js new file mode 100644 index 0000000..569c42e --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/flatMapDeep.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('flatMapDeep', require('../flatMapDeep')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/flatMapDepth.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/flatMapDepth.js new file mode 100644 index 0000000..6eb68fd --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/flatMapDepth.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('flatMapDepth', require('../flatMapDepth')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/flatten.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/flatten.js new file mode 100644 index 0000000..30425d8 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/flatten.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('flatten', require('../flatten'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/flattenDeep.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/flattenDeep.js new file mode 100644 index 0000000..aed5db2 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/flattenDeep.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('flattenDeep', require('../flattenDeep'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/flattenDepth.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/flattenDepth.js new file mode 100644 index 0000000..ad65e37 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/flattenDepth.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('flattenDepth', require('../flattenDepth')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/flip.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/flip.js new file mode 100644 index 0000000..0547e7b --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/flip.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('flip', require('../flip'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/floor.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/floor.js new file mode 100644 index 0000000..a6cf335 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/floor.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('floor', require('../floor')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/flow.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/flow.js new file mode 100644 index 0000000..cd83677 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/flow.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('flow', require('../flow')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/flowRight.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/flowRight.js new file mode 100644 index 0000000..972a5b9 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/flowRight.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('flowRight', require('../flowRight')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/forEach.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/forEach.js new file mode 100644 index 0000000..2f49452 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/forEach.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('forEach', require('../forEach')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/forEachRight.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/forEachRight.js new file mode 100644 index 0000000..3ff9733 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/forEachRight.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('forEachRight', require('../forEachRight')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/forIn.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/forIn.js new file mode 100644 index 0000000..9341749 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/forIn.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('forIn', require('../forIn')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/forInRight.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/forInRight.js new file mode 100644 index 0000000..cecf8bb --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/forInRight.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('forInRight', require('../forInRight')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/forOwn.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/forOwn.js new file mode 100644 index 0000000..246449e --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/forOwn.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('forOwn', require('../forOwn')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/forOwnRight.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/forOwnRight.js new file mode 100644 index 0000000..c5e826e --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/forOwnRight.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('forOwnRight', require('../forOwnRight')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/fromPairs.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/fromPairs.js new file mode 100644 index 0000000..f8cc596 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/fromPairs.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('fromPairs', require('../fromPairs')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/function.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/function.js new file mode 100644 index 0000000..dfe69b1 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/function.js @@ -0,0 +1,2 @@ +var convert = require('./convert'); +module.exports = convert(require('../function')); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/functions.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/functions.js new file mode 100644 index 0000000..09d1bb1 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/functions.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('functions', require('../functions'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/functionsIn.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/functionsIn.js new file mode 100644 index 0000000..2cfeb83 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/functionsIn.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('functionsIn', require('../functionsIn'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/get.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/get.js new file mode 100644 index 0000000..6d3a328 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/get.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('get', require('../get')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/getOr.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/getOr.js new file mode 100644 index 0000000..7dbf771 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/getOr.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('getOr', require('../get')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/groupBy.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/groupBy.js new file mode 100644 index 0000000..fc0bc78 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/groupBy.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('groupBy', require('../groupBy')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/gt.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/gt.js new file mode 100644 index 0000000..9e57c80 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/gt.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('gt', require('../gt')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/gte.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/gte.js new file mode 100644 index 0000000..4584786 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/gte.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('gte', require('../gte')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/has.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/has.js new file mode 100644 index 0000000..b901298 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/has.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('has', require('../has')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/hasIn.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/hasIn.js new file mode 100644 index 0000000..b3c3d1a --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/hasIn.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('hasIn', require('../hasIn')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/head.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/head.js new file mode 100644 index 0000000..2694f0a --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/head.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('head', require('../head'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/identical.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/identical.js new file mode 100644 index 0000000..85563f4 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/identical.js @@ -0,0 +1 @@ +module.exports = require('./eq'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/identity.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/identity.js new file mode 100644 index 0000000..096415a --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/identity.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('identity', require('../identity'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/inRange.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/inRange.js new file mode 100644 index 0000000..202d940 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/inRange.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('inRange', require('../inRange')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/includes.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/includes.js new file mode 100644 index 0000000..1146780 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/includes.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('includes', require('../includes')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/includesFrom.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/includesFrom.js new file mode 100644 index 0000000..683afdb --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/includesFrom.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('includesFrom', require('../includes')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/indexBy.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/indexBy.js new file mode 100644 index 0000000..7e64bc0 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/indexBy.js @@ -0,0 +1 @@ +module.exports = require('./keyBy'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/indexOf.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/indexOf.js new file mode 100644 index 0000000..524658e --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/indexOf.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('indexOf', require('../indexOf')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/indexOfFrom.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/indexOfFrom.js new file mode 100644 index 0000000..d99c822 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/indexOfFrom.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('indexOfFrom', require('../indexOf')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/init.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/init.js new file mode 100644 index 0000000..2f88d8b --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/init.js @@ -0,0 +1 @@ +module.exports = require('./initial'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/initial.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/initial.js new file mode 100644 index 0000000..b732ba0 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/initial.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('initial', require('../initial'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/intersection.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/intersection.js new file mode 100644 index 0000000..52936d5 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/intersection.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('intersection', require('../intersection')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/intersectionBy.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/intersectionBy.js new file mode 100644 index 0000000..72629f2 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/intersectionBy.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('intersectionBy', require('../intersectionBy')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/intersectionWith.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/intersectionWith.js new file mode 100644 index 0000000..e064f40 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/intersectionWith.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('intersectionWith', require('../intersectionWith')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/invert.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/invert.js new file mode 100644 index 0000000..2d5d1f0 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/invert.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('invert', require('../invert')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/invertBy.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/invertBy.js new file mode 100644 index 0000000..63ca97e --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/invertBy.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('invertBy', require('../invertBy')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/invertObj.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/invertObj.js new file mode 100644 index 0000000..f1d842e --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/invertObj.js @@ -0,0 +1 @@ +module.exports = require('./invert'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/invoke.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/invoke.js new file mode 100644 index 0000000..fcf17f0 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/invoke.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('invoke', require('../invoke')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/invokeArgs.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/invokeArgs.js new file mode 100644 index 0000000..d3f2953 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/invokeArgs.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('invokeArgs', require('../invoke')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/invokeArgsMap.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/invokeArgsMap.js new file mode 100644 index 0000000..eaa9f84 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/invokeArgsMap.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('invokeArgsMap', require('../invokeMap')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/invokeMap.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/invokeMap.js new file mode 100644 index 0000000..6515fd7 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/invokeMap.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('invokeMap', require('../invokeMap')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isArguments.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isArguments.js new file mode 100644 index 0000000..1d93c9e --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isArguments.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('isArguments', require('../isArguments'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isArray.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isArray.js new file mode 100644 index 0000000..ba7ade8 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isArray.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('isArray', require('../isArray'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isArrayBuffer.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isArrayBuffer.js new file mode 100644 index 0000000..5088513 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isArrayBuffer.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('isArrayBuffer', require('../isArrayBuffer'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isArrayLike.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isArrayLike.js new file mode 100644 index 0000000..8f1856b --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isArrayLike.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('isArrayLike', require('../isArrayLike'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isArrayLikeObject.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isArrayLikeObject.js new file mode 100644 index 0000000..2108498 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isArrayLikeObject.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('isArrayLikeObject', require('../isArrayLikeObject'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isBoolean.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isBoolean.js new file mode 100644 index 0000000..9339f75 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isBoolean.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('isBoolean', require('../isBoolean'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isBuffer.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isBuffer.js new file mode 100644 index 0000000..e60b123 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isBuffer.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('isBuffer', require('../isBuffer'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isDate.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isDate.js new file mode 100644 index 0000000..dc41d08 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isDate.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('isDate', require('../isDate'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isElement.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isElement.js new file mode 100644 index 0000000..18ee039 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isElement.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('isElement', require('../isElement'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isEmpty.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isEmpty.js new file mode 100644 index 0000000..0f4ae84 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isEmpty.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('isEmpty', require('../isEmpty'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isEqual.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isEqual.js new file mode 100644 index 0000000..4138386 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isEqual.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('isEqual', require('../isEqual')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isEqualWith.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isEqualWith.js new file mode 100644 index 0000000..029ff5c --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isEqualWith.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('isEqualWith', require('../isEqualWith')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isError.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isError.js new file mode 100644 index 0000000..3dfd81c --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isError.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('isError', require('../isError'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isFinite.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isFinite.js new file mode 100644 index 0000000..0b647b8 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isFinite.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('isFinite', require('../isFinite'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isFunction.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isFunction.js new file mode 100644 index 0000000..ff8e5c4 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isFunction.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('isFunction', require('../isFunction'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isInteger.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isInteger.js new file mode 100644 index 0000000..67af4ff --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isInteger.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('isInteger', require('../isInteger'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isLength.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isLength.js new file mode 100644 index 0000000..fc101c5 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isLength.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('isLength', require('../isLength'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isMap.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isMap.js new file mode 100644 index 0000000..a209aa6 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isMap.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('isMap', require('../isMap'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isMatch.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isMatch.js new file mode 100644 index 0000000..6264ca1 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isMatch.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('isMatch', require('../isMatch')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isMatchWith.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isMatchWith.js new file mode 100644 index 0000000..d95f319 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isMatchWith.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('isMatchWith', require('../isMatchWith')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isNaN.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isNaN.js new file mode 100644 index 0000000..66a978f --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isNaN.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('isNaN', require('../isNaN'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isNative.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isNative.js new file mode 100644 index 0000000..3d775ba --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isNative.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('isNative', require('../isNative'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isNil.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isNil.js new file mode 100644 index 0000000..5952c02 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isNil.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('isNil', require('../isNil'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isNull.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isNull.js new file mode 100644 index 0000000..f201a35 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isNull.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('isNull', require('../isNull'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isNumber.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isNumber.js new file mode 100644 index 0000000..a2b5fa0 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isNumber.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('isNumber', require('../isNumber'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isObject.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isObject.js new file mode 100644 index 0000000..231ace0 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isObject.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('isObject', require('../isObject'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isObjectLike.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isObjectLike.js new file mode 100644 index 0000000..f16082e --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isObjectLike.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('isObjectLike', require('../isObjectLike'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isPlainObject.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isPlainObject.js new file mode 100644 index 0000000..b5bea90 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isPlainObject.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('isPlainObject', require('../isPlainObject'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isRegExp.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isRegExp.js new file mode 100644 index 0000000..12a1a3d --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isRegExp.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('isRegExp', require('../isRegExp'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isSafeInteger.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isSafeInteger.js new file mode 100644 index 0000000..7230f55 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isSafeInteger.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('isSafeInteger', require('../isSafeInteger'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isSet.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isSet.js new file mode 100644 index 0000000..35c01f6 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isSet.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('isSet', require('../isSet'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isString.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isString.js new file mode 100644 index 0000000..1fd0679 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isString.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('isString', require('../isString'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isSymbol.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isSymbol.js new file mode 100644 index 0000000..3867695 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isSymbol.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('isSymbol', require('../isSymbol'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isTypedArray.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isTypedArray.js new file mode 100644 index 0000000..8567953 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isTypedArray.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('isTypedArray', require('../isTypedArray'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isUndefined.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isUndefined.js new file mode 100644 index 0000000..ddbca31 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isUndefined.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('isUndefined', require('../isUndefined'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isWeakMap.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isWeakMap.js new file mode 100644 index 0000000..ef60c61 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isWeakMap.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('isWeakMap', require('../isWeakMap'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isWeakSet.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isWeakSet.js new file mode 100644 index 0000000..c99bfaa --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/isWeakSet.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('isWeakSet', require('../isWeakSet'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/iteratee.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/iteratee.js new file mode 100644 index 0000000..9f0f717 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/iteratee.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('iteratee', require('../iteratee')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/join.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/join.js new file mode 100644 index 0000000..a220e00 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/join.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('join', require('../join')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/juxt.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/juxt.js new file mode 100644 index 0000000..f71e04e --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/juxt.js @@ -0,0 +1 @@ +module.exports = require('./over'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/kebabCase.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/kebabCase.js new file mode 100644 index 0000000..60737f1 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/kebabCase.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('kebabCase', require('../kebabCase'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/keyBy.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/keyBy.js new file mode 100644 index 0000000..9a6a85d --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/keyBy.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('keyBy', require('../keyBy')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/keys.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/keys.js new file mode 100644 index 0000000..e12bb07 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/keys.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('keys', require('../keys'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/keysIn.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/keysIn.js new file mode 100644 index 0000000..f3eb36a --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/keysIn.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('keysIn', require('../keysIn'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/lang.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/lang.js new file mode 100644 index 0000000..08cc9c1 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/lang.js @@ -0,0 +1,2 @@ +var convert = require('./convert'); +module.exports = convert(require('../lang')); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/last.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/last.js new file mode 100644 index 0000000..0f71699 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/last.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('last', require('../last'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/lastIndexOf.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/lastIndexOf.js new file mode 100644 index 0000000..ddf39c3 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/lastIndexOf.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('lastIndexOf', require('../lastIndexOf')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/lastIndexOfFrom.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/lastIndexOfFrom.js new file mode 100644 index 0000000..1ff6a0b --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/lastIndexOfFrom.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('lastIndexOfFrom', require('../lastIndexOf')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/lowerCase.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/lowerCase.js new file mode 100644 index 0000000..ea64bc1 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/lowerCase.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('lowerCase', require('../lowerCase'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/lowerFirst.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/lowerFirst.js new file mode 100644 index 0000000..539720a --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/lowerFirst.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('lowerFirst', require('../lowerFirst'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/lt.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/lt.js new file mode 100644 index 0000000..a31d21e --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/lt.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('lt', require('../lt')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/lte.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/lte.js new file mode 100644 index 0000000..d795d10 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/lte.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('lte', require('../lte')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/map.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/map.js new file mode 100644 index 0000000..cf98794 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/map.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('map', require('../map')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/mapKeys.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/mapKeys.js new file mode 100644 index 0000000..1684587 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/mapKeys.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('mapKeys', require('../mapKeys')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/mapValues.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/mapValues.js new file mode 100644 index 0000000..4004972 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/mapValues.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('mapValues', require('../mapValues')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/matches.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/matches.js new file mode 100644 index 0000000..29d1e1e --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/matches.js @@ -0,0 +1 @@ +module.exports = require('./isMatch'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/matchesProperty.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/matchesProperty.js new file mode 100644 index 0000000..4575bd2 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/matchesProperty.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('matchesProperty', require('../matchesProperty')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/math.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/math.js new file mode 100644 index 0000000..e8f50f7 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/math.js @@ -0,0 +1,2 @@ +var convert = require('./convert'); +module.exports = convert(require('../math')); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/max.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/max.js new file mode 100644 index 0000000..a66acac --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/max.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('max', require('../max'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/maxBy.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/maxBy.js new file mode 100644 index 0000000..d083fd6 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/maxBy.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('maxBy', require('../maxBy')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/mean.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/mean.js new file mode 100644 index 0000000..3117246 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/mean.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('mean', require('../mean'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/meanBy.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/meanBy.js new file mode 100644 index 0000000..556f25e --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/meanBy.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('meanBy', require('../meanBy')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/memoize.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/memoize.js new file mode 100644 index 0000000..638eec6 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/memoize.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('memoize', require('../memoize')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/merge.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/merge.js new file mode 100644 index 0000000..ac66add --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/merge.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('merge', require('../merge')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/mergeAll.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/mergeAll.js new file mode 100644 index 0000000..a3674d6 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/mergeAll.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('mergeAll', require('../merge')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/mergeAllWith.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/mergeAllWith.js new file mode 100644 index 0000000..4bd4206 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/mergeAllWith.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('mergeAllWith', require('../mergeWith')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/mergeWith.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/mergeWith.js new file mode 100644 index 0000000..00d44d5 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/mergeWith.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('mergeWith', require('../mergeWith')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/method.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/method.js new file mode 100644 index 0000000..f4060c6 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/method.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('method', require('../method')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/methodOf.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/methodOf.js new file mode 100644 index 0000000..6139905 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/methodOf.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('methodOf', require('../methodOf')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/min.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/min.js new file mode 100644 index 0000000..d12c6b4 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/min.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('min', require('../min'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/minBy.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/minBy.js new file mode 100644 index 0000000..fdb9e24 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/minBy.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('minBy', require('../minBy')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/mixin.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/mixin.js new file mode 100644 index 0000000..332e6fb --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/mixin.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('mixin', require('../mixin')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/multiply.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/multiply.js new file mode 100644 index 0000000..4dcf0b0 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/multiply.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('multiply', require('../multiply')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/nAry.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/nAry.js new file mode 100644 index 0000000..f262a76 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/nAry.js @@ -0,0 +1 @@ +module.exports = require('./ary'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/negate.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/negate.js new file mode 100644 index 0000000..8b6dc7c --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/negate.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('negate', require('../negate'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/next.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/next.js new file mode 100644 index 0000000..140155e --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/next.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('next', require('../next'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/noop.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/noop.js new file mode 100644 index 0000000..b9e32cc --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/noop.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('noop', require('../noop'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/now.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/now.js new file mode 100644 index 0000000..6de2068 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/now.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('now', require('../now'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/nth.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/nth.js new file mode 100644 index 0000000..da4fda7 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/nth.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('nth', require('../nth')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/nthArg.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/nthArg.js new file mode 100644 index 0000000..fce3165 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/nthArg.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('nthArg', require('../nthArg')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/number.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/number.js new file mode 100644 index 0000000..5c10b88 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/number.js @@ -0,0 +1,2 @@ +var convert = require('./convert'); +module.exports = convert(require('../number')); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/object.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/object.js new file mode 100644 index 0000000..ae39a13 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/object.js @@ -0,0 +1,2 @@ +var convert = require('./convert'); +module.exports = convert(require('../object')); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/omit.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/omit.js new file mode 100644 index 0000000..fd68529 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/omit.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('omit', require('../omit')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/omitAll.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/omitAll.js new file mode 100644 index 0000000..144cf4b --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/omitAll.js @@ -0,0 +1 @@ +module.exports = require('./omit'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/omitBy.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/omitBy.js new file mode 100644 index 0000000..90df738 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/omitBy.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('omitBy', require('../omitBy')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/once.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/once.js new file mode 100644 index 0000000..f8f0a5c --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/once.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('once', require('../once'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/orderBy.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/orderBy.js new file mode 100644 index 0000000..848e210 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/orderBy.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('orderBy', require('../orderBy')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/over.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/over.js new file mode 100644 index 0000000..01eba7b --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/over.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('over', require('../over')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/overArgs.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/overArgs.js new file mode 100644 index 0000000..738556f --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/overArgs.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('overArgs', require('../overArgs')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/overEvery.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/overEvery.js new file mode 100644 index 0000000..9f5a032 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/overEvery.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('overEvery', require('../overEvery')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/overSome.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/overSome.js new file mode 100644 index 0000000..15939d5 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/overSome.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('overSome', require('../overSome')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pad.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pad.js new file mode 100644 index 0000000..f1dea4a --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pad.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('pad', require('../pad')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/padChars.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/padChars.js new file mode 100644 index 0000000..d6e0804 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/padChars.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('padChars', require('../pad')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/padCharsEnd.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/padCharsEnd.js new file mode 100644 index 0000000..d4ab79a --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/padCharsEnd.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('padCharsEnd', require('../padEnd')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/padCharsStart.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/padCharsStart.js new file mode 100644 index 0000000..a08a300 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/padCharsStart.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('padCharsStart', require('../padStart')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/padEnd.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/padEnd.js new file mode 100644 index 0000000..a8522ec --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/padEnd.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('padEnd', require('../padEnd')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/padStart.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/padStart.js new file mode 100644 index 0000000..f4ca79d --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/padStart.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('padStart', require('../padStart')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/parseInt.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/parseInt.js new file mode 100644 index 0000000..27314cc --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/parseInt.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('parseInt', require('../parseInt')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/partial.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/partial.js new file mode 100644 index 0000000..5d46015 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/partial.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('partial', require('../partial')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/partialRight.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/partialRight.js new file mode 100644 index 0000000..7f05fed --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/partialRight.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('partialRight', require('../partialRight')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/partition.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/partition.js new file mode 100644 index 0000000..2ebcacc --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/partition.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('partition', require('../partition')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/path.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/path.js new file mode 100644 index 0000000..b29cfb2 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/path.js @@ -0,0 +1 @@ +module.exports = require('./get'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pathEq.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pathEq.js new file mode 100644 index 0000000..36c027a --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pathEq.js @@ -0,0 +1 @@ +module.exports = require('./matchesProperty'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pathOr.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pathOr.js new file mode 100644 index 0000000..4ab5820 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pathOr.js @@ -0,0 +1 @@ +module.exports = require('./getOr'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/paths.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/paths.js new file mode 100644 index 0000000..1eb7950 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/paths.js @@ -0,0 +1 @@ +module.exports = require('./at'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pick.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pick.js new file mode 100644 index 0000000..197393d --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pick.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('pick', require('../pick')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pickAll.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pickAll.js new file mode 100644 index 0000000..a8ecd46 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pickAll.js @@ -0,0 +1 @@ +module.exports = require('./pick'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pickBy.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pickBy.js new file mode 100644 index 0000000..d832d16 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pickBy.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('pickBy', require('../pickBy')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pipe.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pipe.js new file mode 100644 index 0000000..b2e1e2c --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pipe.js @@ -0,0 +1 @@ +module.exports = require('./flow'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/placeholder.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/placeholder.js new file mode 100644 index 0000000..1ce1739 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/placeholder.js @@ -0,0 +1,6 @@ +/** + * The default argument placeholder value for methods. + * + * @type {Object} + */ +module.exports = {}; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/plant.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/plant.js new file mode 100644 index 0000000..eca8f32 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/plant.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('plant', require('../plant'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pluck.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pluck.js new file mode 100644 index 0000000..0d1e1ab --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pluck.js @@ -0,0 +1 @@ +module.exports = require('./map'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/prop.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/prop.js new file mode 100644 index 0000000..b29cfb2 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/prop.js @@ -0,0 +1 @@ +module.exports = require('./get'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/propEq.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/propEq.js new file mode 100644 index 0000000..36c027a --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/propEq.js @@ -0,0 +1 @@ +module.exports = require('./matchesProperty'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/propOr.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/propOr.js new file mode 100644 index 0000000..4ab5820 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/propOr.js @@ -0,0 +1 @@ +module.exports = require('./getOr'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/property.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/property.js new file mode 100644 index 0000000..b29cfb2 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/property.js @@ -0,0 +1 @@ +module.exports = require('./get'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/propertyOf.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/propertyOf.js new file mode 100644 index 0000000..f6273ee --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/propertyOf.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('propertyOf', require('../get')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/props.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/props.js new file mode 100644 index 0000000..1eb7950 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/props.js @@ -0,0 +1 @@ +module.exports = require('./at'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pull.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pull.js new file mode 100644 index 0000000..8d7084f --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pull.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('pull', require('../pull')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pullAll.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pullAll.js new file mode 100644 index 0000000..98d5c9a --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pullAll.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('pullAll', require('../pullAll')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pullAllBy.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pullAllBy.js new file mode 100644 index 0000000..876bc3b --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pullAllBy.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('pullAllBy', require('../pullAllBy')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pullAllWith.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pullAllWith.js new file mode 100644 index 0000000..f71ba4d --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pullAllWith.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('pullAllWith', require('../pullAllWith')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pullAt.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pullAt.js new file mode 100644 index 0000000..e8b3bb6 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/pullAt.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('pullAt', require('../pullAt')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/random.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/random.js new file mode 100644 index 0000000..99d852e --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/random.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('random', require('../random')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/range.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/range.js new file mode 100644 index 0000000..a6bb591 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/range.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('range', require('../range')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/rangeRight.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/rangeRight.js new file mode 100644 index 0000000..fdb712f --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/rangeRight.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('rangeRight', require('../rangeRight')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/rangeStep.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/rangeStep.js new file mode 100644 index 0000000..d72dfc2 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/rangeStep.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('rangeStep', require('../range')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/rangeStepRight.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/rangeStepRight.js new file mode 100644 index 0000000..8b2a67b --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/rangeStepRight.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('rangeStepRight', require('../rangeRight')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/rearg.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/rearg.js new file mode 100644 index 0000000..678e02a --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/rearg.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('rearg', require('../rearg')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/reduce.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/reduce.js new file mode 100644 index 0000000..4cef0a0 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/reduce.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('reduce', require('../reduce')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/reduceRight.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/reduceRight.js new file mode 100644 index 0000000..caf5bb5 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/reduceRight.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('reduceRight', require('../reduceRight')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/reject.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/reject.js new file mode 100644 index 0000000..c163273 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/reject.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('reject', require('../reject')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/remove.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/remove.js new file mode 100644 index 0000000..e9d1327 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/remove.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('remove', require('../remove')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/repeat.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/repeat.js new file mode 100644 index 0000000..08470f2 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/repeat.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('repeat', require('../repeat')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/replace.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/replace.js new file mode 100644 index 0000000..2227db6 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/replace.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('replace', require('../replace')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/rest.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/rest.js new file mode 100644 index 0000000..c1f3d64 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/rest.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('rest', require('../rest')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/restFrom.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/restFrom.js new file mode 100644 index 0000000..714e42b --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/restFrom.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('restFrom', require('../rest')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/result.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/result.js new file mode 100644 index 0000000..f86ce07 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/result.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('result', require('../result')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/reverse.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/reverse.js new file mode 100644 index 0000000..07c9f5e --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/reverse.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('reverse', require('../reverse')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/round.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/round.js new file mode 100644 index 0000000..4c0e5c8 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/round.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('round', require('../round')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sample.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sample.js new file mode 100644 index 0000000..6bea125 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sample.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('sample', require('../sample'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sampleSize.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sampleSize.js new file mode 100644 index 0000000..359ed6f --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sampleSize.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('sampleSize', require('../sampleSize')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/seq.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/seq.js new file mode 100644 index 0000000..d8f42b0 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/seq.js @@ -0,0 +1,2 @@ +var convert = require('./convert'); +module.exports = convert(require('../seq')); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/set.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/set.js new file mode 100644 index 0000000..0b56a56 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/set.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('set', require('../set')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/setWith.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/setWith.js new file mode 100644 index 0000000..0b58495 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/setWith.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('setWith', require('../setWith')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/shuffle.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/shuffle.js new file mode 100644 index 0000000..aa3a1ca --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/shuffle.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('shuffle', require('../shuffle'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/size.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/size.js new file mode 100644 index 0000000..7490136 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/size.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('size', require('../size'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/slice.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/slice.js new file mode 100644 index 0000000..15945d3 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/slice.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('slice', require('../slice')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/snakeCase.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/snakeCase.js new file mode 100644 index 0000000..a0ff780 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/snakeCase.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('snakeCase', require('../snakeCase'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/some.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/some.js new file mode 100644 index 0000000..a4fa2d0 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/some.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('some', require('../some')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sortBy.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sortBy.js new file mode 100644 index 0000000..e0790ad --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sortBy.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('sortBy', require('../sortBy')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sortedIndex.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sortedIndex.js new file mode 100644 index 0000000..364a054 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sortedIndex.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('sortedIndex', require('../sortedIndex')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sortedIndexBy.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sortedIndexBy.js new file mode 100644 index 0000000..9593dbd --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sortedIndexBy.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('sortedIndexBy', require('../sortedIndexBy')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sortedIndexOf.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sortedIndexOf.js new file mode 100644 index 0000000..c9084ca --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sortedIndexOf.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('sortedIndexOf', require('../sortedIndexOf')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sortedLastIndex.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sortedLastIndex.js new file mode 100644 index 0000000..47fe241 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sortedLastIndex.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('sortedLastIndex', require('../sortedLastIndex')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sortedLastIndexBy.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sortedLastIndexBy.js new file mode 100644 index 0000000..0f9a347 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sortedLastIndexBy.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('sortedLastIndexBy', require('../sortedLastIndexBy')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sortedLastIndexOf.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sortedLastIndexOf.js new file mode 100644 index 0000000..0d4d932 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sortedLastIndexOf.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('sortedLastIndexOf', require('../sortedLastIndexOf')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sortedUniq.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sortedUniq.js new file mode 100644 index 0000000..882d283 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sortedUniq.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('sortedUniq', require('../sortedUniq'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sortedUniqBy.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sortedUniqBy.js new file mode 100644 index 0000000..033db91 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sortedUniqBy.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('sortedUniqBy', require('../sortedUniqBy')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/split.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/split.js new file mode 100644 index 0000000..14de1a7 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/split.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('split', require('../split')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/spread.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/spread.js new file mode 100644 index 0000000..2d11b70 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/spread.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('spread', require('../spread')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/spreadFrom.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/spreadFrom.js new file mode 100644 index 0000000..0b630df --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/spreadFrom.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('spreadFrom', require('../spread')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/startCase.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/startCase.js new file mode 100644 index 0000000..ada98c9 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/startCase.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('startCase', require('../startCase'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/startsWith.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/startsWith.js new file mode 100644 index 0000000..985e2f2 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/startsWith.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('startsWith', require('../startsWith')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/string.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/string.js new file mode 100644 index 0000000..773b037 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/string.js @@ -0,0 +1,2 @@ +var convert = require('./convert'); +module.exports = convert(require('../string')); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/stubArray.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/stubArray.js new file mode 100644 index 0000000..cd604cb --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/stubArray.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('stubArray', require('../stubArray'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/stubFalse.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/stubFalse.js new file mode 100644 index 0000000..3296664 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/stubFalse.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('stubFalse', require('../stubFalse'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/stubObject.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/stubObject.js new file mode 100644 index 0000000..c6c8ec4 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/stubObject.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('stubObject', require('../stubObject'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/stubString.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/stubString.js new file mode 100644 index 0000000..701051e --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/stubString.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('stubString', require('../stubString'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/stubTrue.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/stubTrue.js new file mode 100644 index 0000000..9249082 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/stubTrue.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('stubTrue', require('../stubTrue'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/subtract.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/subtract.js new file mode 100644 index 0000000..d32b16d --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/subtract.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('subtract', require('../subtract')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sum.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sum.js new file mode 100644 index 0000000..5cce12b --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sum.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('sum', require('../sum'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sumBy.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sumBy.js new file mode 100644 index 0000000..c882656 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/sumBy.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('sumBy', require('../sumBy')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/symmetricDifference.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/symmetricDifference.js new file mode 100644 index 0000000..78c16ad --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/symmetricDifference.js @@ -0,0 +1 @@ +module.exports = require('./xor'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/symmetricDifferenceBy.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/symmetricDifferenceBy.js new file mode 100644 index 0000000..298fc7f --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/symmetricDifferenceBy.js @@ -0,0 +1 @@ +module.exports = require('./xorBy'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/symmetricDifferenceWith.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/symmetricDifferenceWith.js new file mode 100644 index 0000000..70bc6fa --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/symmetricDifferenceWith.js @@ -0,0 +1 @@ +module.exports = require('./xorWith'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/tail.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/tail.js new file mode 100644 index 0000000..f122f0a --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/tail.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('tail', require('../tail'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/take.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/take.js new file mode 100644 index 0000000..9af98a7 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/take.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('take', require('../take')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/takeLast.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/takeLast.js new file mode 100644 index 0000000..e98c84a --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/takeLast.js @@ -0,0 +1 @@ +module.exports = require('./takeRight'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/takeLastWhile.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/takeLastWhile.js new file mode 100644 index 0000000..5367968 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/takeLastWhile.js @@ -0,0 +1 @@ +module.exports = require('./takeRightWhile'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/takeRight.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/takeRight.js new file mode 100644 index 0000000..b82950a --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/takeRight.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('takeRight', require('../takeRight')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/takeRightWhile.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/takeRightWhile.js new file mode 100644 index 0000000..8ffb0a2 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/takeRightWhile.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('takeRightWhile', require('../takeRightWhile')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/takeWhile.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/takeWhile.js new file mode 100644 index 0000000..2813664 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/takeWhile.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('takeWhile', require('../takeWhile')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/tap.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/tap.js new file mode 100644 index 0000000..d33ad6e --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/tap.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('tap', require('../tap')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/template.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/template.js new file mode 100644 index 0000000..74857e1 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/template.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('template', require('../template')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/templateSettings.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/templateSettings.js new file mode 100644 index 0000000..7bcc0a8 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/templateSettings.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('templateSettings', require('../templateSettings'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/throttle.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/throttle.js new file mode 100644 index 0000000..77fff14 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/throttle.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('throttle', require('../throttle')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/thru.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/thru.js new file mode 100644 index 0000000..d42b3b1 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/thru.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('thru', require('../thru')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/times.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/times.js new file mode 100644 index 0000000..0dab06d --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/times.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('times', require('../times')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toArray.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toArray.js new file mode 100644 index 0000000..f0c360a --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toArray.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('toArray', require('../toArray'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toFinite.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toFinite.js new file mode 100644 index 0000000..3a47687 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toFinite.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('toFinite', require('../toFinite'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toInteger.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toInteger.js new file mode 100644 index 0000000..e0af6a7 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toInteger.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('toInteger', require('../toInteger'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toIterator.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toIterator.js new file mode 100644 index 0000000..65e6baa --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toIterator.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('toIterator', require('../toIterator'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toJSON.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toJSON.js new file mode 100644 index 0000000..2d718d0 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toJSON.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('toJSON', require('../toJSON'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toLength.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toLength.js new file mode 100644 index 0000000..b97cdd9 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toLength.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('toLength', require('../toLength'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toLower.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toLower.js new file mode 100644 index 0000000..616ef36 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toLower.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('toLower', require('../toLower'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toNumber.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toNumber.js new file mode 100644 index 0000000..d0c6f4d --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toNumber.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('toNumber', require('../toNumber'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toPairs.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toPairs.js new file mode 100644 index 0000000..af78378 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toPairs.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('toPairs', require('../toPairs'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toPairsIn.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toPairsIn.js new file mode 100644 index 0000000..66504ab --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toPairsIn.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('toPairsIn', require('../toPairsIn'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toPath.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toPath.js new file mode 100644 index 0000000..b4d5e50 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toPath.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('toPath', require('../toPath'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toPlainObject.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toPlainObject.js new file mode 100644 index 0000000..278bb86 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toPlainObject.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('toPlainObject', require('../toPlainObject'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toSafeInteger.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toSafeInteger.js new file mode 100644 index 0000000..367a26f --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toSafeInteger.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('toSafeInteger', require('../toSafeInteger'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toString.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toString.js new file mode 100644 index 0000000..cec4f8e --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toString.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('toString', require('../toString'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toUpper.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toUpper.js new file mode 100644 index 0000000..54f9a56 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/toUpper.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('toUpper', require('../toUpper'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/transform.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/transform.js new file mode 100644 index 0000000..759d088 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/transform.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('transform', require('../transform')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/trim.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/trim.js new file mode 100644 index 0000000..e6319a7 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/trim.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('trim', require('../trim')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/trimChars.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/trimChars.js new file mode 100644 index 0000000..c9294de --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/trimChars.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('trimChars', require('../trim')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/trimCharsEnd.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/trimCharsEnd.js new file mode 100644 index 0000000..284bc2f --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/trimCharsEnd.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('trimCharsEnd', require('../trimEnd')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/trimCharsStart.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/trimCharsStart.js new file mode 100644 index 0000000..ff0ee65 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/trimCharsStart.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('trimCharsStart', require('../trimStart')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/trimEnd.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/trimEnd.js new file mode 100644 index 0000000..7190880 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/trimEnd.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('trimEnd', require('../trimEnd')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/trimStart.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/trimStart.js new file mode 100644 index 0000000..fda902c --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/trimStart.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('trimStart', require('../trimStart')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/truncate.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/truncate.js new file mode 100644 index 0000000..d265c1d --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/truncate.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('truncate', require('../truncate')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/unapply.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/unapply.js new file mode 100644 index 0000000..c5dfe77 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/unapply.js @@ -0,0 +1 @@ +module.exports = require('./rest'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/unary.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/unary.js new file mode 100644 index 0000000..286c945 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/unary.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('unary', require('../unary'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/unescape.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/unescape.js new file mode 100644 index 0000000..fddcb46 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/unescape.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('unescape', require('../unescape'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/union.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/union.js new file mode 100644 index 0000000..ef8228d --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/union.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('union', require('../union')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/unionBy.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/unionBy.js new file mode 100644 index 0000000..603687a --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/unionBy.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('unionBy', require('../unionBy')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/unionWith.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/unionWith.js new file mode 100644 index 0000000..65bb3a7 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/unionWith.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('unionWith', require('../unionWith')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/uniq.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/uniq.js new file mode 100644 index 0000000..bc18524 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/uniq.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('uniq', require('../uniq'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/uniqBy.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/uniqBy.js new file mode 100644 index 0000000..634c6a8 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/uniqBy.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('uniqBy', require('../uniqBy')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/uniqWith.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/uniqWith.js new file mode 100644 index 0000000..0ec601a --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/uniqWith.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('uniqWith', require('../uniqWith')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/uniqueId.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/uniqueId.js new file mode 100644 index 0000000..aa8fc2f --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/uniqueId.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('uniqueId', require('../uniqueId')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/unnest.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/unnest.js new file mode 100644 index 0000000..5d34060 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/unnest.js @@ -0,0 +1 @@ +module.exports = require('./flatten'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/unset.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/unset.js new file mode 100644 index 0000000..ea203a0 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/unset.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('unset', require('../unset')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/unzip.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/unzip.js new file mode 100644 index 0000000..cc364b3 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/unzip.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('unzip', require('../unzip'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/unzipWith.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/unzipWith.js new file mode 100644 index 0000000..182eaa1 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/unzipWith.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('unzipWith', require('../unzipWith')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/update.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/update.js new file mode 100644 index 0000000..b8ce2cc --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/update.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('update', require('../update')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/updateWith.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/updateWith.js new file mode 100644 index 0000000..d5e8282 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/updateWith.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('updateWith', require('../updateWith')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/upperCase.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/upperCase.js new file mode 100644 index 0000000..c886f20 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/upperCase.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('upperCase', require('../upperCase'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/upperFirst.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/upperFirst.js new file mode 100644 index 0000000..d8c04df --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/upperFirst.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('upperFirst', require('../upperFirst'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/useWith.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/useWith.js new file mode 100644 index 0000000..d8b3df5 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/useWith.js @@ -0,0 +1 @@ +module.exports = require('./overArgs'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/util.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/util.js new file mode 100644 index 0000000..18c00ba --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/util.js @@ -0,0 +1,2 @@ +var convert = require('./convert'); +module.exports = convert(require('../util')); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/value.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/value.js new file mode 100644 index 0000000..555eec7 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/value.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('value', require('../value'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/valueOf.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/valueOf.js new file mode 100644 index 0000000..f968807 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/valueOf.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('valueOf', require('../valueOf'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/values.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/values.js new file mode 100644 index 0000000..2dfc561 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/values.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('values', require('../values'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/valuesIn.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/valuesIn.js new file mode 100644 index 0000000..a1b2bb8 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/valuesIn.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('valuesIn', require('../valuesIn'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/where.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/where.js new file mode 100644 index 0000000..3247f64 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/where.js @@ -0,0 +1 @@ +module.exports = require('./conformsTo'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/whereEq.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/whereEq.js new file mode 100644 index 0000000..29d1e1e --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/whereEq.js @@ -0,0 +1 @@ +module.exports = require('./isMatch'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/without.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/without.js new file mode 100644 index 0000000..bad9e12 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/without.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('without', require('../without')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/words.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/words.js new file mode 100644 index 0000000..4a90141 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/words.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('words', require('../words')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/wrap.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/wrap.js new file mode 100644 index 0000000..e93bd8a --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/wrap.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('wrap', require('../wrap')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/wrapperAt.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/wrapperAt.js new file mode 100644 index 0000000..8f0a310 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/wrapperAt.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('wrapperAt', require('../wrapperAt'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/wrapperChain.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/wrapperChain.js new file mode 100644 index 0000000..2a48ea2 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/wrapperChain.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('wrapperChain', require('../wrapperChain'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/wrapperLodash.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/wrapperLodash.js new file mode 100644 index 0000000..a7162d0 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/wrapperLodash.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('wrapperLodash', require('../wrapperLodash'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/wrapperReverse.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/wrapperReverse.js new file mode 100644 index 0000000..e1481aa --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/wrapperReverse.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('wrapperReverse', require('../wrapperReverse'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/wrapperValue.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/wrapperValue.js new file mode 100644 index 0000000..8eb9112 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/wrapperValue.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('wrapperValue', require('../wrapperValue'), require('./_falseOptions')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/xor.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/xor.js new file mode 100644 index 0000000..29e2819 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/xor.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('xor', require('../xor')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/xorBy.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/xorBy.js new file mode 100644 index 0000000..b355686 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/xorBy.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('xorBy', require('../xorBy')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/xorWith.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/xorWith.js new file mode 100644 index 0000000..8e05739 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/xorWith.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('xorWith', require('../xorWith')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/zip.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/zip.js new file mode 100644 index 0000000..69e147a --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/zip.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('zip', require('../zip')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/zipAll.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/zipAll.js new file mode 100644 index 0000000..efa8ccb --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/zipAll.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('zipAll', require('../zip')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/zipObj.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/zipObj.js new file mode 100644 index 0000000..f4a3453 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/zipObj.js @@ -0,0 +1 @@ +module.exports = require('./zipObject'); diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/zipObject.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/zipObject.js new file mode 100644 index 0000000..462dbb6 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/zipObject.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('zipObject', require('../zipObject')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/zipObjectDeep.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/zipObjectDeep.js new file mode 100644 index 0000000..53a5d33 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/zipObjectDeep.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('zipObjectDeep', require('../zipObjectDeep')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/zipWith.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/zipWith.js new file mode 100644 index 0000000..c5cf9e2 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fp/zipWith.js @@ -0,0 +1,5 @@ +var convert = require('./convert'), + func = convert('zipWith', require('../zipWith')); + +func.placeholder = require('./placeholder'); +module.exports = func; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/fromPairs.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/fromPairs.js new file mode 100644 index 0000000..39f5fb3 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/fromPairs.js @@ -0,0 +1,28 @@ +/** + * The inverse of `_.toPairs`; this method returns an object composed + * from key-value `pairs`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {Array} pairs The key-value pairs. + * @returns {Object} Returns the new object. + * @example + * + * _.fromPairs([['a', 1], ['b', 2]]); + * // => { 'a': 1, 'b': 2 } + */ +function fromPairs(pairs) { + var index = -1, + length = pairs ? pairs.length : 0, + result = {}; + + while (++index < length) { + var pair = pairs[index]; + result[pair[0]] = pair[1]; + } + return result; +} + +module.exports = fromPairs; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/function.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/function.js new file mode 100644 index 0000000..b0fc6d9 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/function.js @@ -0,0 +1,25 @@ +module.exports = { + 'after': require('./after'), + 'ary': require('./ary'), + 'before': require('./before'), + 'bind': require('./bind'), + 'bindKey': require('./bindKey'), + 'curry': require('./curry'), + 'curryRight': require('./curryRight'), + 'debounce': require('./debounce'), + 'defer': require('./defer'), + 'delay': require('./delay'), + 'flip': require('./flip'), + 'memoize': require('./memoize'), + 'negate': require('./negate'), + 'once': require('./once'), + 'overArgs': require('./overArgs'), + 'partial': require('./partial'), + 'partialRight': require('./partialRight'), + 'rearg': require('./rearg'), + 'rest': require('./rest'), + 'spread': require('./spread'), + 'throttle': require('./throttle'), + 'unary': require('./unary'), + 'wrap': require('./wrap') +}; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/functions.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/functions.js new file mode 100644 index 0000000..9722928 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/functions.js @@ -0,0 +1,31 @@ +var baseFunctions = require('./_baseFunctions'), + keys = require('./keys'); + +/** + * Creates an array of function property names from own enumerable properties + * of `object`. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Object + * @param {Object} object The object to inspect. + * @returns {Array} Returns the function names. + * @see _.functionsIn + * @example + * + * function Foo() { + * this.a = _.constant('a'); + * this.b = _.constant('b'); + * } + * + * Foo.prototype.c = _.constant('c'); + * + * _.functions(new Foo); + * // => ['a', 'b'] + */ +function functions(object) { + return object == null ? [] : baseFunctions(object, keys(object)); +} + +module.exports = functions; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/functionsIn.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/functionsIn.js new file mode 100644 index 0000000..f00345d --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/functionsIn.js @@ -0,0 +1,31 @@ +var baseFunctions = require('./_baseFunctions'), + keysIn = require('./keysIn'); + +/** + * Creates an array of function property names from own and inherited + * enumerable properties of `object`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Object + * @param {Object} object The object to inspect. + * @returns {Array} Returns the function names. + * @see _.functions + * @example + * + * function Foo() { + * this.a = _.constant('a'); + * this.b = _.constant('b'); + * } + * + * Foo.prototype.c = _.constant('c'); + * + * _.functionsIn(new Foo); + * // => ['a', 'b', 'c'] + */ +function functionsIn(object) { + return object == null ? [] : baseFunctions(object, keysIn(object)); +} + +module.exports = functionsIn; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/get.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/get.js new file mode 100644 index 0000000..8805ff9 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/get.js @@ -0,0 +1,33 @@ +var baseGet = require('./_baseGet'); + +/** + * Gets the value at `path` of `object`. If the resolved value is + * `undefined`, the `defaultValue` is returned in its place. + * + * @static + * @memberOf _ + * @since 3.7.0 + * @category Object + * @param {Object} object The object to query. + * @param {Array|string} path The path of the property to get. + * @param {*} [defaultValue] The value returned for `undefined` resolved values. + * @returns {*} Returns the resolved value. + * @example + * + * var object = { 'a': [{ 'b': { 'c': 3 } }] }; + * + * _.get(object, 'a[0].b.c'); + * // => 3 + * + * _.get(object, ['a', '0', 'b', 'c']); + * // => 3 + * + * _.get(object, 'a.b.c', 'default'); + * // => 'default' + */ +function get(object, path, defaultValue) { + var result = object == null ? undefined : baseGet(object, path); + return result === undefined ? defaultValue : result; +} + +module.exports = get; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/groupBy.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/groupBy.js new file mode 100644 index 0000000..5b73b41 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/groupBy.js @@ -0,0 +1,42 @@ +var baseAssignValue = require('./_baseAssignValue'), + createAggregator = require('./_createAggregator'); + +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** Used to check objects for own properties. */ +var hasOwnProperty = objectProto.hasOwnProperty; + +/** + * Creates an object composed of keys generated from the results of running + * each element of `collection` thru `iteratee`. The order of grouped values + * is determined by the order they occur in `collection`. The corresponding + * value of each key is an array of elements responsible for generating the + * key. The iteratee is invoked with one argument: (value). + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [iteratee=_.identity] + * The iteratee to transform keys. + * @returns {Object} Returns the composed aggregate object. + * @example + * + * _.groupBy([6.1, 4.2, 6.3], Math.floor); + * // => { '4': [4.2], '6': [6.1, 6.3] } + * + * // The `_.property` iteratee shorthand. + * _.groupBy(['one', 'two', 'three'], 'length'); + * // => { '3': ['one', 'two'], '5': ['three'] } + */ +var groupBy = createAggregator(function(result, value, key) { + if (hasOwnProperty.call(result, key)) { + result[key].push(value); + } else { + baseAssignValue(result, key, [value]); + } +}); + +module.exports = groupBy; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/gt.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/gt.js new file mode 100644 index 0000000..3a66282 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/gt.js @@ -0,0 +1,29 @@ +var baseGt = require('./_baseGt'), + createRelationalOperation = require('./_createRelationalOperation'); + +/** + * Checks if `value` is greater than `other`. + * + * @static + * @memberOf _ + * @since 3.9.0 + * @category Lang + * @param {*} value The value to compare. + * @param {*} other The other value to compare. + * @returns {boolean} Returns `true` if `value` is greater than `other`, + * else `false`. + * @see _.lt + * @example + * + * _.gt(3, 1); + * // => true + * + * _.gt(3, 3); + * // => false + * + * _.gt(1, 3); + * // => false + */ +var gt = createRelationalOperation(baseGt); + +module.exports = gt; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/gte.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/gte.js new file mode 100644 index 0000000..4180a68 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/gte.js @@ -0,0 +1,30 @@ +var createRelationalOperation = require('./_createRelationalOperation'); + +/** + * Checks if `value` is greater than or equal to `other`. + * + * @static + * @memberOf _ + * @since 3.9.0 + * @category Lang + * @param {*} value The value to compare. + * @param {*} other The other value to compare. + * @returns {boolean} Returns `true` if `value` is greater than or equal to + * `other`, else `false`. + * @see _.lte + * @example + * + * _.gte(3, 1); + * // => true + * + * _.gte(3, 3); + * // => true + * + * _.gte(1, 3); + * // => false + */ +var gte = createRelationalOperation(function(value, other) { + return value >= other; +}); + +module.exports = gte; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/has.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/has.js new file mode 100644 index 0000000..34df55e --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/has.js @@ -0,0 +1,35 @@ +var baseHas = require('./_baseHas'), + hasPath = require('./_hasPath'); + +/** + * Checks if `path` is a direct property of `object`. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Object + * @param {Object} object The object to query. + * @param {Array|string} path The path to check. + * @returns {boolean} Returns `true` if `path` exists, else `false`. + * @example + * + * var object = { 'a': { 'b': 2 } }; + * var other = _.create({ 'a': _.create({ 'b': 2 }) }); + * + * _.has(object, 'a'); + * // => true + * + * _.has(object, 'a.b'); + * // => true + * + * _.has(object, ['a', 'b']); + * // => true + * + * _.has(other, 'a'); + * // => false + */ +function has(object, path) { + return object != null && hasPath(object, path, baseHas); +} + +module.exports = has; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/hasIn.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/hasIn.js new file mode 100644 index 0000000..06a3686 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/hasIn.js @@ -0,0 +1,34 @@ +var baseHasIn = require('./_baseHasIn'), + hasPath = require('./_hasPath'); + +/** + * Checks if `path` is a direct or inherited property of `object`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Object + * @param {Object} object The object to query. + * @param {Array|string} path The path to check. + * @returns {boolean} Returns `true` if `path` exists, else `false`. + * @example + * + * var object = _.create({ 'a': _.create({ 'b': 2 }) }); + * + * _.hasIn(object, 'a'); + * // => true + * + * _.hasIn(object, 'a.b'); + * // => true + * + * _.hasIn(object, ['a', 'b']); + * // => true + * + * _.hasIn(object, 'b'); + * // => false + */ +function hasIn(object, path) { + return object != null && hasPath(object, path, baseHasIn); +} + +module.exports = hasIn; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/head.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/head.js new file mode 100644 index 0000000..dee9d1f --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/head.js @@ -0,0 +1,23 @@ +/** + * Gets the first element of `array`. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @alias first + * @category Array + * @param {Array} array The array to query. + * @returns {*} Returns the first element of `array`. + * @example + * + * _.head([1, 2, 3]); + * // => 1 + * + * _.head([]); + * // => undefined + */ +function head(array) { + return (array && array.length) ? array[0] : undefined; +} + +module.exports = head; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/identity.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/identity.js new file mode 100644 index 0000000..2d5d963 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/identity.js @@ -0,0 +1,21 @@ +/** + * This method returns the first argument it receives. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Util + * @param {*} value Any value. + * @returns {*} Returns `value`. + * @example + * + * var object = { 'a': 1 }; + * + * console.log(_.identity(object) === object); + * // => true + */ +function identity(value) { + return value; +} + +module.exports = identity; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/inRange.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/inRange.js new file mode 100644 index 0000000..f20728d --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/inRange.js @@ -0,0 +1,55 @@ +var baseInRange = require('./_baseInRange'), + toFinite = require('./toFinite'), + toNumber = require('./toNumber'); + +/** + * Checks if `n` is between `start` and up to, but not including, `end`. If + * `end` is not specified, it's set to `start` with `start` then set to `0`. + * If `start` is greater than `end` the params are swapped to support + * negative ranges. + * + * @static + * @memberOf _ + * @since 3.3.0 + * @category Number + * @param {number} number The number to check. + * @param {number} [start=0] The start of the range. + * @param {number} end The end of the range. + * @returns {boolean} Returns `true` if `number` is in the range, else `false`. + * @see _.range, _.rangeRight + * @example + * + * _.inRange(3, 2, 4); + * // => true + * + * _.inRange(4, 8); + * // => true + * + * _.inRange(4, 2); + * // => false + * + * _.inRange(2, 2); + * // => false + * + * _.inRange(1.2, 2); + * // => true + * + * _.inRange(5.2, 4); + * // => false + * + * _.inRange(-3, -2, -6); + * // => true + */ +function inRange(number, start, end) { + start = toFinite(start); + if (end === undefined) { + end = start; + start = 0; + } else { + end = toFinite(end); + } + number = toNumber(number); + return baseInRange(number, start, end); +} + +module.exports = inRange; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/includes.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/includes.js new file mode 100644 index 0000000..ae0deed --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/includes.js @@ -0,0 +1,53 @@ +var baseIndexOf = require('./_baseIndexOf'), + isArrayLike = require('./isArrayLike'), + isString = require('./isString'), + toInteger = require('./toInteger'), + values = require('./values'); + +/* Built-in method references for those with the same name as other `lodash` methods. */ +var nativeMax = Math.max; + +/** + * Checks if `value` is in `collection`. If `collection` is a string, it's + * checked for a substring of `value`, otherwise + * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero) + * is used for equality comparisons. If `fromIndex` is negative, it's used as + * the offset from the end of `collection`. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Collection + * @param {Array|Object|string} collection The collection to inspect. + * @param {*} value The value to search for. + * @param {number} [fromIndex=0] The index to search from. + * @param- {Object} [guard] Enables use as an iteratee for methods like `_.reduce`. + * @returns {boolean} Returns `true` if `value` is found, else `false`. + * @example + * + * _.includes([1, 2, 3], 1); + * // => true + * + * _.includes([1, 2, 3], 1, 2); + * // => false + * + * _.includes({ 'a': 1, 'b': 2 }, 1); + * // => true + * + * _.includes('abcd', 'bc'); + * // => true + */ +function includes(collection, value, fromIndex, guard) { + collection = isArrayLike(collection) ? collection : values(collection); + fromIndex = (fromIndex && !guard) ? toInteger(fromIndex) : 0; + + var length = collection.length; + if (fromIndex < 0) { + fromIndex = nativeMax(length + fromIndex, 0); + } + return isString(collection) + ? (fromIndex <= length && collection.indexOf(value, fromIndex) > -1) + : (!!length && baseIndexOf(collection, value, fromIndex) > -1); +} + +module.exports = includes; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/index.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/index.js new file mode 100644 index 0000000..5d063e2 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/index.js @@ -0,0 +1 @@ +module.exports = require('./lodash'); \ No newline at end of file diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/indexOf.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/indexOf.js new file mode 100644 index 0000000..8c9b86d --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/indexOf.js @@ -0,0 +1,42 @@ +var baseIndexOf = require('./_baseIndexOf'), + toInteger = require('./toInteger'); + +/* Built-in method references for those with the same name as other `lodash` methods. */ +var nativeMax = Math.max; + +/** + * Gets the index at which the first occurrence of `value` is found in `array` + * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero) + * for equality comparisons. If `fromIndex` is negative, it's used as the + * offset from the end of `array`. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Array + * @param {Array} array The array to inspect. + * @param {*} value The value to search for. + * @param {number} [fromIndex=0] The index to search from. + * @returns {number} Returns the index of the matched value, else `-1`. + * @example + * + * _.indexOf([1, 2, 1, 2], 2); + * // => 1 + * + * // Search from the `fromIndex`. + * _.indexOf([1, 2, 1, 2], 2, 2); + * // => 3 + */ +function indexOf(array, value, fromIndex) { + var length = array ? array.length : 0; + if (!length) { + return -1; + } + var index = fromIndex == null ? 0 : toInteger(fromIndex); + if (index < 0) { + index = nativeMax(length + index, 0); + } + return baseIndexOf(array, value, index); +} + +module.exports = indexOf; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/initial.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/initial.js new file mode 100644 index 0000000..63e0c93 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/initial.js @@ -0,0 +1,22 @@ +var baseSlice = require('./_baseSlice'); + +/** + * Gets all but the last element of `array`. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Array + * @param {Array} array The array to query. + * @returns {Array} Returns the slice of `array`. + * @example + * + * _.initial([1, 2, 3]); + * // => [1, 2] + */ +function initial(array) { + var length = array ? array.length : 0; + return length ? baseSlice(array, 0, -1) : []; +} + +module.exports = initial; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/intersection.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/intersection.js new file mode 100644 index 0000000..a94c135 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/intersection.js @@ -0,0 +1,30 @@ +var arrayMap = require('./_arrayMap'), + baseIntersection = require('./_baseIntersection'), + baseRest = require('./_baseRest'), + castArrayLikeObject = require('./_castArrayLikeObject'); + +/** + * Creates an array of unique values that are included in all given arrays + * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero) + * for equality comparisons. The order and references of result values are + * determined by the first array. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Array + * @param {...Array} [arrays] The arrays to inspect. + * @returns {Array} Returns the new array of intersecting values. + * @example + * + * _.intersection([2, 1], [2, 3]); + * // => [2] + */ +var intersection = baseRest(function(arrays) { + var mapped = arrayMap(arrays, castArrayLikeObject); + return (mapped.length && mapped[0] === arrays[0]) + ? baseIntersection(mapped) + : []; +}); + +module.exports = intersection; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/intersectionBy.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/intersectionBy.js new file mode 100644 index 0000000..31461aa --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/intersectionBy.js @@ -0,0 +1,45 @@ +var arrayMap = require('./_arrayMap'), + baseIntersection = require('./_baseIntersection'), + baseIteratee = require('./_baseIteratee'), + baseRest = require('./_baseRest'), + castArrayLikeObject = require('./_castArrayLikeObject'), + last = require('./last'); + +/** + * This method is like `_.intersection` except that it accepts `iteratee` + * which is invoked for each element of each `arrays` to generate the criterion + * by which they're compared. The order and references of result values are + * determined by the first array. The iteratee is invoked with one argument: + * (value). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {...Array} [arrays] The arrays to inspect. + * @param {Function} [iteratee=_.identity] The iteratee invoked per element. + * @returns {Array} Returns the new array of intersecting values. + * @example + * + * _.intersectionBy([2.1, 1.2], [2.3, 3.4], Math.floor); + * // => [2.1] + * + * // The `_.property` iteratee shorthand. + * _.intersectionBy([{ 'x': 1 }], [{ 'x': 2 }, { 'x': 1 }], 'x'); + * // => [{ 'x': 1 }] + */ +var intersectionBy = baseRest(function(arrays) { + var iteratee = last(arrays), + mapped = arrayMap(arrays, castArrayLikeObject); + + if (iteratee === last(mapped)) { + iteratee = undefined; + } else { + mapped.pop(); + } + return (mapped.length && mapped[0] === arrays[0]) + ? baseIntersection(mapped, baseIteratee(iteratee, 2)) + : []; +}); + +module.exports = intersectionBy; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/intersectionWith.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/intersectionWith.js new file mode 100644 index 0000000..0ba2f9a --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/intersectionWith.js @@ -0,0 +1,42 @@ +var arrayMap = require('./_arrayMap'), + baseIntersection = require('./_baseIntersection'), + baseRest = require('./_baseRest'), + castArrayLikeObject = require('./_castArrayLikeObject'), + last = require('./last'); + +/** + * This method is like `_.intersection` except that it accepts `comparator` + * which is invoked to compare elements of `arrays`. The order and references + * of result values are determined by the first array. The comparator is + * invoked with two arguments: (arrVal, othVal). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {...Array} [arrays] The arrays to inspect. + * @param {Function} [comparator] The comparator invoked per element. + * @returns {Array} Returns the new array of intersecting values. + * @example + * + * var objects = [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }]; + * var others = [{ 'x': 1, 'y': 1 }, { 'x': 1, 'y': 2 }]; + * + * _.intersectionWith(objects, others, _.isEqual); + * // => [{ 'x': 1, 'y': 2 }] + */ +var intersectionWith = baseRest(function(arrays) { + var comparator = last(arrays), + mapped = arrayMap(arrays, castArrayLikeObject); + + if (comparator === last(mapped)) { + comparator = undefined; + } else { + mapped.pop(); + } + return (mapped.length && mapped[0] === arrays[0]) + ? baseIntersection(mapped, undefined, comparator) + : []; +}); + +module.exports = intersectionWith; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/invert.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/invert.js new file mode 100644 index 0000000..21d10ab --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/invert.js @@ -0,0 +1,27 @@ +var constant = require('./constant'), + createInverter = require('./_createInverter'), + identity = require('./identity'); + +/** + * Creates an object composed of the inverted keys and values of `object`. + * If `object` contains duplicate values, subsequent values overwrite + * property assignments of previous values. + * + * @static + * @memberOf _ + * @since 0.7.0 + * @category Object + * @param {Object} object The object to invert. + * @returns {Object} Returns the new inverted object. + * @example + * + * var object = { 'a': 1, 'b': 2, 'c': 1 }; + * + * _.invert(object); + * // => { '1': 'c', '2': 'b' } + */ +var invert = createInverter(function(result, value, key) { + result[value] = key; +}, constant(identity)); + +module.exports = invert; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/invertBy.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/invertBy.js new file mode 100644 index 0000000..e5ba0f7 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/invertBy.js @@ -0,0 +1,44 @@ +var baseIteratee = require('./_baseIteratee'), + createInverter = require('./_createInverter'); + +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** Used to check objects for own properties. */ +var hasOwnProperty = objectProto.hasOwnProperty; + +/** + * This method is like `_.invert` except that the inverted object is generated + * from the results of running each element of `object` thru `iteratee`. The + * corresponding inverted value of each inverted key is an array of keys + * responsible for generating the inverted value. The iteratee is invoked + * with one argument: (value). + * + * @static + * @memberOf _ + * @since 4.1.0 + * @category Object + * @param {Object} object The object to invert. + * @param {Function} [iteratee=_.identity] The iteratee invoked per element. + * @returns {Object} Returns the new inverted object. + * @example + * + * var object = { 'a': 1, 'b': 2, 'c': 1 }; + * + * _.invertBy(object); + * // => { '1': ['a', 'c'], '2': ['b'] } + * + * _.invertBy(object, function(value) { + * return 'group' + value; + * }); + * // => { 'group1': ['a', 'c'], 'group2': ['b'] } + */ +var invertBy = createInverter(function(result, value, key) { + if (hasOwnProperty.call(result, value)) { + result[value].push(key); + } else { + result[value] = [key]; + } +}, baseIteratee); + +module.exports = invertBy; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/invoke.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/invoke.js new file mode 100644 index 0000000..97d51eb --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/invoke.js @@ -0,0 +1,24 @@ +var baseInvoke = require('./_baseInvoke'), + baseRest = require('./_baseRest'); + +/** + * Invokes the method at `path` of `object`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Object + * @param {Object} object The object to query. + * @param {Array|string} path The path of the method to invoke. + * @param {...*} [args] The arguments to invoke the method with. + * @returns {*} Returns the result of the invoked method. + * @example + * + * var object = { 'a': [{ 'b': { 'c': [1, 2, 3, 4] } }] }; + * + * _.invoke(object, 'a[0].b.c.slice', 1, 3); + * // => [2, 3] + */ +var invoke = baseRest(baseInvoke); + +module.exports = invoke; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/invokeMap.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/invokeMap.js new file mode 100644 index 0000000..f3302db --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/invokeMap.js @@ -0,0 +1,44 @@ +var apply = require('./_apply'), + baseEach = require('./_baseEach'), + baseInvoke = require('./_baseInvoke'), + baseRest = require('./_baseRest'), + isArrayLike = require('./isArrayLike'), + isKey = require('./_isKey'); + +/** + * Invokes the method at `path` of each element in `collection`, returning + * an array of the results of each invoked method. Any additional arguments + * are provided to each invoked method. If `path` is a function, it's invoked + * for, and `this` bound to, each element in `collection`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Array|Function|string} path The path of the method to invoke or + * the function invoked per iteration. + * @param {...*} [args] The arguments to invoke each method with. + * @returns {Array} Returns the array of results. + * @example + * + * _.invokeMap([[5, 1, 7], [3, 2, 1]], 'sort'); + * // => [[1, 5, 7], [1, 2, 3]] + * + * _.invokeMap([123, 456], String.prototype.split, ''); + * // => [['1', '2', '3'], ['4', '5', '6']] + */ +var invokeMap = baseRest(function(collection, path, args) { + var index = -1, + isFunc = typeof path == 'function', + isProp = isKey(path), + result = isArrayLike(collection) ? Array(collection.length) : []; + + baseEach(collection, function(value) { + var func = isFunc ? path : ((isProp && value != null) ? value[path] : undefined); + result[++index] = func ? apply(func, value, args) : baseInvoke(value, path, args); + }); + return result; +}); + +module.exports = invokeMap; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/isArguments.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/isArguments.js new file mode 100644 index 0000000..8b9ed66 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/isArguments.js @@ -0,0 +1,36 @@ +var baseIsArguments = require('./_baseIsArguments'), + isObjectLike = require('./isObjectLike'); + +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** Used to check objects for own properties. */ +var hasOwnProperty = objectProto.hasOwnProperty; + +/** Built-in value references. */ +var propertyIsEnumerable = objectProto.propertyIsEnumerable; + +/** + * Checks if `value` is likely an `arguments` object. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is an `arguments` object, + * else `false`. + * @example + * + * _.isArguments(function() { return arguments; }()); + * // => true + * + * _.isArguments([1, 2, 3]); + * // => false + */ +var isArguments = baseIsArguments(function() { return arguments; }()) ? baseIsArguments : function(value) { + return isObjectLike(value) && hasOwnProperty.call(value, 'callee') && + !propertyIsEnumerable.call(value, 'callee'); +}; + +module.exports = isArguments; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/isArray.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/isArray.js new file mode 100644 index 0000000..88ab55f --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/isArray.js @@ -0,0 +1,26 @@ +/** + * Checks if `value` is classified as an `Array` object. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is an array, else `false`. + * @example + * + * _.isArray([1, 2, 3]); + * // => true + * + * _.isArray(document.body.children); + * // => false + * + * _.isArray('abc'); + * // => false + * + * _.isArray(_.noop); + * // => false + */ +var isArray = Array.isArray; + +module.exports = isArray; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/isArrayBuffer.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/isArrayBuffer.js new file mode 100644 index 0000000..12904a6 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/isArrayBuffer.js @@ -0,0 +1,27 @@ +var baseIsArrayBuffer = require('./_baseIsArrayBuffer'), + baseUnary = require('./_baseUnary'), + nodeUtil = require('./_nodeUtil'); + +/* Node.js helper references. */ +var nodeIsArrayBuffer = nodeUtil && nodeUtil.isArrayBuffer; + +/** + * Checks if `value` is classified as an `ArrayBuffer` object. + * + * @static + * @memberOf _ + * @since 4.3.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is an array buffer, else `false`. + * @example + * + * _.isArrayBuffer(new ArrayBuffer(2)); + * // => true + * + * _.isArrayBuffer(new Array(2)); + * // => false + */ +var isArrayBuffer = nodeIsArrayBuffer ? baseUnary(nodeIsArrayBuffer) : baseIsArrayBuffer; + +module.exports = isArrayBuffer; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/isArrayLike.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/isArrayLike.js new file mode 100644 index 0000000..0f96680 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/isArrayLike.js @@ -0,0 +1,33 @@ +var isFunction = require('./isFunction'), + isLength = require('./isLength'); + +/** + * Checks if `value` is array-like. A value is considered array-like if it's + * not a function and has a `value.length` that's an integer greater than or + * equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is array-like, else `false`. + * @example + * + * _.isArrayLike([1, 2, 3]); + * // => true + * + * _.isArrayLike(document.body.children); + * // => true + * + * _.isArrayLike('abc'); + * // => true + * + * _.isArrayLike(_.noop); + * // => false + */ +function isArrayLike(value) { + return value != null && isLength(value.length) && !isFunction(value); +} + +module.exports = isArrayLike; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/isArrayLikeObject.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/isArrayLikeObject.js new file mode 100644 index 0000000..6c4812a --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/isArrayLikeObject.js @@ -0,0 +1,33 @@ +var isArrayLike = require('./isArrayLike'), + isObjectLike = require('./isObjectLike'); + +/** + * This method is like `_.isArrayLike` except that it also checks if `value` + * is an object. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is an array-like object, + * else `false`. + * @example + * + * _.isArrayLikeObject([1, 2, 3]); + * // => true + * + * _.isArrayLikeObject(document.body.children); + * // => true + * + * _.isArrayLikeObject('abc'); + * // => false + * + * _.isArrayLikeObject(_.noop); + * // => false + */ +function isArrayLikeObject(value) { + return isObjectLike(value) && isArrayLike(value); +} + +module.exports = isArrayLikeObject; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/isBoolean.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/isBoolean.js new file mode 100644 index 0000000..45cbdc1 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/isBoolean.js @@ -0,0 +1,38 @@ +var isObjectLike = require('./isObjectLike'); + +/** `Object#toString` result references. */ +var boolTag = '[object Boolean]'; + +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** + * Used to resolve the + * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring) + * of values. + */ +var objectToString = objectProto.toString; + +/** + * Checks if `value` is classified as a boolean primitive or object. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a boolean, else `false`. + * @example + * + * _.isBoolean(false); + * // => true + * + * _.isBoolean(null); + * // => false + */ +function isBoolean(value) { + return value === true || value === false || + (isObjectLike(value) && objectToString.call(value) == boolTag); +} + +module.exports = isBoolean; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/isBuffer.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/isBuffer.js new file mode 100644 index 0000000..c103cc7 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/isBuffer.js @@ -0,0 +1,38 @@ +var root = require('./_root'), + stubFalse = require('./stubFalse'); + +/** Detect free variable `exports`. */ +var freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports; + +/** Detect free variable `module`. */ +var freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module; + +/** Detect the popular CommonJS extension `module.exports`. */ +var moduleExports = freeModule && freeModule.exports === freeExports; + +/** Built-in value references. */ +var Buffer = moduleExports ? root.Buffer : undefined; + +/* Built-in method references for those with the same name as other `lodash` methods. */ +var nativeIsBuffer = Buffer ? Buffer.isBuffer : undefined; + +/** + * Checks if `value` is a buffer. + * + * @static + * @memberOf _ + * @since 4.3.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a buffer, else `false`. + * @example + * + * _.isBuffer(new Buffer(2)); + * // => true + * + * _.isBuffer(new Uint8Array(2)); + * // => false + */ +var isBuffer = nativeIsBuffer || stubFalse; + +module.exports = isBuffer; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/isDate.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/isDate.js new file mode 100644 index 0000000..7f0209f --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/isDate.js @@ -0,0 +1,27 @@ +var baseIsDate = require('./_baseIsDate'), + baseUnary = require('./_baseUnary'), + nodeUtil = require('./_nodeUtil'); + +/* Node.js helper references. */ +var nodeIsDate = nodeUtil && nodeUtil.isDate; + +/** + * Checks if `value` is classified as a `Date` object. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a date object, else `false`. + * @example + * + * _.isDate(new Date); + * // => true + * + * _.isDate('Mon April 23 2012'); + * // => false + */ +var isDate = nodeIsDate ? baseUnary(nodeIsDate) : baseIsDate; + +module.exports = isDate; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/isElement.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/isElement.js new file mode 100644 index 0000000..0c151a4 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/isElement.js @@ -0,0 +1,25 @@ +var isObjectLike = require('./isObjectLike'), + isPlainObject = require('./isPlainObject'); + +/** + * Checks if `value` is likely a DOM element. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a DOM element, else `false`. + * @example + * + * _.isElement(document.body); + * // => true + * + * _.isElement(''); + * // => false + */ +function isElement(value) { + return value != null && value.nodeType === 1 && isObjectLike(value) && !isPlainObject(value); +} + +module.exports = isElement; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/isEmpty.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/isEmpty.js new file mode 100644 index 0000000..e190425 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/isEmpty.js @@ -0,0 +1,74 @@ +var baseKeys = require('./_baseKeys'), + getTag = require('./_getTag'), + isArguments = require('./isArguments'), + isArray = require('./isArray'), + isArrayLike = require('./isArrayLike'), + isBuffer = require('./isBuffer'), + isPrototype = require('./_isPrototype'), + isTypedArray = require('./isTypedArray'); + +/** `Object#toString` result references. */ +var mapTag = '[object Map]', + setTag = '[object Set]'; + +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** Used to check objects for own properties. */ +var hasOwnProperty = objectProto.hasOwnProperty; + +/** + * Checks if `value` is an empty object, collection, map, or set. + * + * Objects are considered empty if they have no own enumerable string keyed + * properties. + * + * Array-like values such as `arguments` objects, arrays, buffers, strings, or + * jQuery-like collections are considered empty if they have a `length` of `0`. + * Similarly, maps and sets are considered empty if they have a `size` of `0`. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is empty, else `false`. + * @example + * + * _.isEmpty(null); + * // => true + * + * _.isEmpty(true); + * // => true + * + * _.isEmpty(1); + * // => true + * + * _.isEmpty([1, 2, 3]); + * // => false + * + * _.isEmpty({ 'a': 1 }); + * // => false + */ +function isEmpty(value) { + if (isArrayLike(value) && + (isArray(value) || typeof value == 'string' || typeof value.splice == 'function' || + isBuffer(value) || isTypedArray(value) || isArguments(value))) { + return !value.length; + } + var tag = getTag(value); + if (tag == mapTag || tag == setTag) { + return !value.size; + } + if (isPrototype(value)) { + return !baseKeys(value).length; + } + for (var key in value) { + if (hasOwnProperty.call(value, key)) { + return false; + } + } + return true; +} + +module.exports = isEmpty; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/isEqual.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/isEqual.js new file mode 100644 index 0000000..8a54126 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/isEqual.js @@ -0,0 +1,35 @@ +var baseIsEqual = require('./_baseIsEqual'); + +/** + * Performs a deep comparison between two values to determine if they are + * equivalent. + * + * **Note:** This method supports comparing arrays, array buffers, booleans, + * date objects, error objects, maps, numbers, `Object` objects, regexes, + * sets, strings, symbols, and typed arrays. `Object` objects are compared + * by their own, not inherited, enumerable properties. Functions and DOM + * nodes are **not** supported. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to compare. + * @param {*} other The other value to compare. + * @returns {boolean} Returns `true` if the values are equivalent, else `false`. + * @example + * + * var object = { 'a': 1 }; + * var other = { 'a': 1 }; + * + * _.isEqual(object, other); + * // => true + * + * object === other; + * // => false + */ +function isEqual(value, other) { + return baseIsEqual(value, other); +} + +module.exports = isEqual; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/isEqualWith.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/isEqualWith.js new file mode 100644 index 0000000..fb83d50 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/isEqualWith.js @@ -0,0 +1,41 @@ +var baseIsEqual = require('./_baseIsEqual'); + +/** + * This method is like `_.isEqual` except that it accepts `customizer` which + * is invoked to compare values. If `customizer` returns `undefined`, comparisons + * are handled by the method instead. The `customizer` is invoked with up to + * six arguments: (objValue, othValue [, index|key, object, other, stack]). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to compare. + * @param {*} other The other value to compare. + * @param {Function} [customizer] The function to customize comparisons. + * @returns {boolean} Returns `true` if the values are equivalent, else `false`. + * @example + * + * function isGreeting(value) { + * return /^h(?:i|ello)$/.test(value); + * } + * + * function customizer(objValue, othValue) { + * if (isGreeting(objValue) && isGreeting(othValue)) { + * return true; + * } + * } + * + * var array = ['hello', 'goodbye']; + * var other = ['hi', 'goodbye']; + * + * _.isEqualWith(array, other, customizer); + * // => true + */ +function isEqualWith(value, other, customizer) { + customizer = typeof customizer == 'function' ? customizer : undefined; + var result = customizer ? customizer(value, other) : undefined; + return result === undefined ? baseIsEqual(value, other, customizer) : !!result; +} + +module.exports = isEqualWith; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/isError.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/isError.js new file mode 100644 index 0000000..85884b5 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/isError.js @@ -0,0 +1,42 @@ +var isObjectLike = require('./isObjectLike'); + +/** `Object#toString` result references. */ +var errorTag = '[object Error]'; + +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** + * Used to resolve the + * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring) + * of values. + */ +var objectToString = objectProto.toString; + +/** + * Checks if `value` is an `Error`, `EvalError`, `RangeError`, `ReferenceError`, + * `SyntaxError`, `TypeError`, or `URIError` object. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is an error object, else `false`. + * @example + * + * _.isError(new Error); + * // => true + * + * _.isError(Error); + * // => false + */ +function isError(value) { + if (!isObjectLike(value)) { + return false; + } + return (objectToString.call(value) == errorTag) || + (typeof value.message == 'string' && typeof value.name == 'string'); +} + +module.exports = isError; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/isFinite.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/isFinite.js new file mode 100644 index 0000000..601842b --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/isFinite.js @@ -0,0 +1,36 @@ +var root = require('./_root'); + +/* Built-in method references for those with the same name as other `lodash` methods. */ +var nativeIsFinite = root.isFinite; + +/** + * Checks if `value` is a finite primitive number. + * + * **Note:** This method is based on + * [`Number.isFinite`](https://mdn.io/Number/isFinite). + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a finite number, else `false`. + * @example + * + * _.isFinite(3); + * // => true + * + * _.isFinite(Number.MIN_VALUE); + * // => true + * + * _.isFinite(Infinity); + * // => false + * + * _.isFinite('3'); + * // => false + */ +function isFinite(value) { + return typeof value == 'number' && nativeIsFinite(value); +} + +module.exports = isFinite; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/isFunction.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/isFunction.js new file mode 100644 index 0000000..17ccf32 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/isFunction.js @@ -0,0 +1,42 @@ +var isObject = require('./isObject'); + +/** `Object#toString` result references. */ +var funcTag = '[object Function]', + genTag = '[object GeneratorFunction]', + proxyTag = '[object Proxy]'; + +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** + * Used to resolve the + * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring) + * of values. + */ +var objectToString = objectProto.toString; + +/** + * Checks if `value` is classified as a `Function` object. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a function, else `false`. + * @example + * + * _.isFunction(_); + * // => true + * + * _.isFunction(/abc/); + * // => false + */ +function isFunction(value) { + // The use of `Object#toString` avoids issues with the `typeof` operator + // in Safari 9 which returns 'object' for typed array and other constructors. + var tag = isObject(value) ? objectToString.call(value) : ''; + return tag == funcTag || tag == genTag || tag == proxyTag; +} + +module.exports = isFunction; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/isInteger.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/isInteger.js new file mode 100644 index 0000000..66aa87d --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/isInteger.js @@ -0,0 +1,33 @@ +var toInteger = require('./toInteger'); + +/** + * Checks if `value` is an integer. + * + * **Note:** This method is based on + * [`Number.isInteger`](https://mdn.io/Number/isInteger). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is an integer, else `false`. + * @example + * + * _.isInteger(3); + * // => true + * + * _.isInteger(Number.MIN_VALUE); + * // => false + * + * _.isInteger(Infinity); + * // => false + * + * _.isInteger('3'); + * // => false + */ +function isInteger(value) { + return typeof value == 'number' && value == toInteger(value); +} + +module.exports = isInteger; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/isLength.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/isLength.js new file mode 100644 index 0000000..3a95caa --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/isLength.js @@ -0,0 +1,35 @@ +/** Used as references for various `Number` constants. */ +var MAX_SAFE_INTEGER = 9007199254740991; + +/** + * Checks if `value` is a valid array-like length. + * + * **Note:** This method is loosely based on + * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a valid length, else `false`. + * @example + * + * _.isLength(3); + * // => true + * + * _.isLength(Number.MIN_VALUE); + * // => false + * + * _.isLength(Infinity); + * // => false + * + * _.isLength('3'); + * // => false + */ +function isLength(value) { + return typeof value == 'number' && + value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER; +} + +module.exports = isLength; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/isMap.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/isMap.js new file mode 100644 index 0000000..44f8517 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/isMap.js @@ -0,0 +1,27 @@ +var baseIsMap = require('./_baseIsMap'), + baseUnary = require('./_baseUnary'), + nodeUtil = require('./_nodeUtil'); + +/* Node.js helper references. */ +var nodeIsMap = nodeUtil && nodeUtil.isMap; + +/** + * Checks if `value` is classified as a `Map` object. + * + * @static + * @memberOf _ + * @since 4.3.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a map, else `false`. + * @example + * + * _.isMap(new Map); + * // => true + * + * _.isMap(new WeakMap); + * // => false + */ +var isMap = nodeIsMap ? baseUnary(nodeIsMap) : baseIsMap; + +module.exports = isMap; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/isMatch.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/isMatch.js new file mode 100644 index 0000000..9773a18 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/isMatch.js @@ -0,0 +1,36 @@ +var baseIsMatch = require('./_baseIsMatch'), + getMatchData = require('./_getMatchData'); + +/** + * Performs a partial deep comparison between `object` and `source` to + * determine if `object` contains equivalent property values. + * + * **Note:** This method is equivalent to `_.matches` when `source` is + * partially applied. + * + * Partial comparisons will match empty array and empty object `source` + * values against any array or object value, respectively. See `_.isEqual` + * for a list of supported value comparisons. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Lang + * @param {Object} object The object to inspect. + * @param {Object} source The object of property values to match. + * @returns {boolean} Returns `true` if `object` is a match, else `false`. + * @example + * + * var object = { 'a': 1, 'b': 2 }; + * + * _.isMatch(object, { 'b': 2 }); + * // => true + * + * _.isMatch(object, { 'b': 1 }); + * // => false + */ +function isMatch(object, source) { + return object === source || baseIsMatch(object, source, getMatchData(source)); +} + +module.exports = isMatch; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/isMatchWith.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/isMatchWith.js new file mode 100644 index 0000000..187b6a6 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/isMatchWith.js @@ -0,0 +1,41 @@ +var baseIsMatch = require('./_baseIsMatch'), + getMatchData = require('./_getMatchData'); + +/** + * This method is like `_.isMatch` except that it accepts `customizer` which + * is invoked to compare values. If `customizer` returns `undefined`, comparisons + * are handled by the method instead. The `customizer` is invoked with five + * arguments: (objValue, srcValue, index|key, object, source). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {Object} object The object to inspect. + * @param {Object} source The object of property values to match. + * @param {Function} [customizer] The function to customize comparisons. + * @returns {boolean} Returns `true` if `object` is a match, else `false`. + * @example + * + * function isGreeting(value) { + * return /^h(?:i|ello)$/.test(value); + * } + * + * function customizer(objValue, srcValue) { + * if (isGreeting(objValue) && isGreeting(srcValue)) { + * return true; + * } + * } + * + * var object = { 'greeting': 'hello' }; + * var source = { 'greeting': 'hi' }; + * + * _.isMatchWith(object, source, customizer); + * // => true + */ +function isMatchWith(object, source, customizer) { + customizer = typeof customizer == 'function' ? customizer : undefined; + return baseIsMatch(object, source, getMatchData(source), customizer); +} + +module.exports = isMatchWith; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/isNaN.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/isNaN.js new file mode 100644 index 0000000..7d0d783 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/isNaN.js @@ -0,0 +1,38 @@ +var isNumber = require('./isNumber'); + +/** + * Checks if `value` is `NaN`. + * + * **Note:** This method is based on + * [`Number.isNaN`](https://mdn.io/Number/isNaN) and is not the same as + * global [`isNaN`](https://mdn.io/isNaN) which returns `true` for + * `undefined` and other non-number values. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is `NaN`, else `false`. + * @example + * + * _.isNaN(NaN); + * // => true + * + * _.isNaN(new Number(NaN)); + * // => true + * + * isNaN(undefined); + * // => true + * + * _.isNaN(undefined); + * // => false + */ +function isNaN(value) { + // An `NaN` primitive is the only value that is not equal to itself. + // Perform the `toStringTag` check first to avoid errors with some + // ActiveX objects in IE. + return isNumber(value) && value != +value; +} + +module.exports = isNaN; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/isNative.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/isNative.js new file mode 100644 index 0000000..310b39d --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/isNative.js @@ -0,0 +1,40 @@ +var baseIsNative = require('./_baseIsNative'), + isMaskable = require('./_isMaskable'); + +/** Error message constants. */ +var CORE_ERROR_TEXT = 'Unsupported core-js use. Try https://github.com/es-shims.'; + +/** + * Checks if `value` is a pristine native function. + * + * **Note:** This method can't reliably detect native functions in the presence + * of the core-js package because core-js circumvents this kind of detection. + * Despite multiple requests, the core-js maintainer has made it clear: any + * attempt to fix the detection will be obstructed. As a result, we're left + * with little choice but to throw an error. Unfortunately, this also affects + * packages, like [babel-polyfill](https://www.npmjs.com/package/babel-polyfill), + * which rely on core-js. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a native function, + * else `false`. + * @example + * + * _.isNative(Array.prototype.push); + * // => true + * + * _.isNative(_); + * // => false + */ +function isNative(value) { + if (isMaskable(value)) { + throw new Error(CORE_ERROR_TEXT); + } + return baseIsNative(value); +} + +module.exports = isNative; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/isNil.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/isNil.js new file mode 100644 index 0000000..79f0505 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/isNil.js @@ -0,0 +1,25 @@ +/** + * Checks if `value` is `null` or `undefined`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is nullish, else `false`. + * @example + * + * _.isNil(null); + * // => true + * + * _.isNil(void 0); + * // => true + * + * _.isNil(NaN); + * // => false + */ +function isNil(value) { + return value == null; +} + +module.exports = isNil; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/isNull.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/isNull.js new file mode 100644 index 0000000..c0a374d --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/isNull.js @@ -0,0 +1,22 @@ +/** + * Checks if `value` is `null`. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is `null`, else `false`. + * @example + * + * _.isNull(null); + * // => true + * + * _.isNull(void 0); + * // => false + */ +function isNull(value) { + return value === null; +} + +module.exports = isNull; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/isNumber.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/isNumber.js new file mode 100644 index 0000000..b866292 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/isNumber.js @@ -0,0 +1,47 @@ +var isObjectLike = require('./isObjectLike'); + +/** `Object#toString` result references. */ +var numberTag = '[object Number]'; + +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** + * Used to resolve the + * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring) + * of values. + */ +var objectToString = objectProto.toString; + +/** + * Checks if `value` is classified as a `Number` primitive or object. + * + * **Note:** To exclude `Infinity`, `-Infinity`, and `NaN`, which are + * classified as numbers, use the `_.isFinite` method. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a number, else `false`. + * @example + * + * _.isNumber(3); + * // => true + * + * _.isNumber(Number.MIN_VALUE); + * // => true + * + * _.isNumber(Infinity); + * // => true + * + * _.isNumber('3'); + * // => false + */ +function isNumber(value) { + return typeof value == 'number' || + (isObjectLike(value) && objectToString.call(value) == numberTag); +} + +module.exports = isNumber; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/isObject.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/isObject.js new file mode 100644 index 0000000..1dc8939 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/isObject.js @@ -0,0 +1,31 @@ +/** + * Checks if `value` is the + * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types) + * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`) + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is an object, else `false`. + * @example + * + * _.isObject({}); + * // => true + * + * _.isObject([1, 2, 3]); + * // => true + * + * _.isObject(_.noop); + * // => true + * + * _.isObject(null); + * // => false + */ +function isObject(value) { + var type = typeof value; + return value != null && (type == 'object' || type == 'function'); +} + +module.exports = isObject; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/isObjectLike.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/isObjectLike.js new file mode 100644 index 0000000..301716b --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/isObjectLike.js @@ -0,0 +1,29 @@ +/** + * Checks if `value` is object-like. A value is object-like if it's not `null` + * and has a `typeof` result of "object". + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is object-like, else `false`. + * @example + * + * _.isObjectLike({}); + * // => true + * + * _.isObjectLike([1, 2, 3]); + * // => true + * + * _.isObjectLike(_.noop); + * // => false + * + * _.isObjectLike(null); + * // => false + */ +function isObjectLike(value) { + return value != null && typeof value == 'object'; +} + +module.exports = isObjectLike; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/isPlainObject.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/isPlainObject.js new file mode 100644 index 0000000..035fbb2 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/isPlainObject.js @@ -0,0 +1,68 @@ +var getPrototype = require('./_getPrototype'), + isObjectLike = require('./isObjectLike'); + +/** `Object#toString` result references. */ +var objectTag = '[object Object]'; + +/** Used for built-in method references. */ +var funcProto = Function.prototype, + objectProto = Object.prototype; + +/** Used to resolve the decompiled source of functions. */ +var funcToString = funcProto.toString; + +/** Used to check objects for own properties. */ +var hasOwnProperty = objectProto.hasOwnProperty; + +/** Used to infer the `Object` constructor. */ +var objectCtorString = funcToString.call(Object); + +/** + * Used to resolve the + * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring) + * of values. + */ +var objectToString = objectProto.toString; + +/** + * Checks if `value` is a plain object, that is, an object created by the + * `Object` constructor or one with a `[[Prototype]]` of `null`. + * + * @static + * @memberOf _ + * @since 0.8.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a plain object, else `false`. + * @example + * + * function Foo() { + * this.a = 1; + * } + * + * _.isPlainObject(new Foo); + * // => false + * + * _.isPlainObject([1, 2, 3]); + * // => false + * + * _.isPlainObject({ 'x': 0, 'y': 0 }); + * // => true + * + * _.isPlainObject(Object.create(null)); + * // => true + */ +function isPlainObject(value) { + if (!isObjectLike(value) || objectToString.call(value) != objectTag) { + return false; + } + var proto = getPrototype(value); + if (proto === null) { + return true; + } + var Ctor = hasOwnProperty.call(proto, 'constructor') && proto.constructor; + return (typeof Ctor == 'function' && + Ctor instanceof Ctor && funcToString.call(Ctor) == objectCtorString); +} + +module.exports = isPlainObject; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/isRegExp.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/isRegExp.js new file mode 100644 index 0000000..76c9b6e --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/isRegExp.js @@ -0,0 +1,27 @@ +var baseIsRegExp = require('./_baseIsRegExp'), + baseUnary = require('./_baseUnary'), + nodeUtil = require('./_nodeUtil'); + +/* Node.js helper references. */ +var nodeIsRegExp = nodeUtil && nodeUtil.isRegExp; + +/** + * Checks if `value` is classified as a `RegExp` object. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a regexp, else `false`. + * @example + * + * _.isRegExp(/abc/); + * // => true + * + * _.isRegExp('/abc/'); + * // => false + */ +var isRegExp = nodeIsRegExp ? baseUnary(nodeIsRegExp) : baseIsRegExp; + +module.exports = isRegExp; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/isSafeInteger.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/isSafeInteger.js new file mode 100644 index 0000000..2a48526 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/isSafeInteger.js @@ -0,0 +1,37 @@ +var isInteger = require('./isInteger'); + +/** Used as references for various `Number` constants. */ +var MAX_SAFE_INTEGER = 9007199254740991; + +/** + * Checks if `value` is a safe integer. An integer is safe if it's an IEEE-754 + * double precision number which isn't the result of a rounded unsafe integer. + * + * **Note:** This method is based on + * [`Number.isSafeInteger`](https://mdn.io/Number/isSafeInteger). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a safe integer, else `false`. + * @example + * + * _.isSafeInteger(3); + * // => true + * + * _.isSafeInteger(Number.MIN_VALUE); + * // => false + * + * _.isSafeInteger(Infinity); + * // => false + * + * _.isSafeInteger('3'); + * // => false + */ +function isSafeInteger(value) { + return isInteger(value) && value >= -MAX_SAFE_INTEGER && value <= MAX_SAFE_INTEGER; +} + +module.exports = isSafeInteger; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/isSet.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/isSet.js new file mode 100644 index 0000000..ab88bdf --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/isSet.js @@ -0,0 +1,27 @@ +var baseIsSet = require('./_baseIsSet'), + baseUnary = require('./_baseUnary'), + nodeUtil = require('./_nodeUtil'); + +/* Node.js helper references. */ +var nodeIsSet = nodeUtil && nodeUtil.isSet; + +/** + * Checks if `value` is classified as a `Set` object. + * + * @static + * @memberOf _ + * @since 4.3.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a set, else `false`. + * @example + * + * _.isSet(new Set); + * // => true + * + * _.isSet(new WeakSet); + * // => false + */ +var isSet = nodeIsSet ? baseUnary(nodeIsSet) : baseIsSet; + +module.exports = isSet; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/isString.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/isString.js new file mode 100644 index 0000000..7b8be86 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/isString.js @@ -0,0 +1,39 @@ +var isArray = require('./isArray'), + isObjectLike = require('./isObjectLike'); + +/** `Object#toString` result references. */ +var stringTag = '[object String]'; + +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** + * Used to resolve the + * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring) + * of values. + */ +var objectToString = objectProto.toString; + +/** + * Checks if `value` is classified as a `String` primitive or object. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a string, else `false`. + * @example + * + * _.isString('abc'); + * // => true + * + * _.isString(1); + * // => false + */ +function isString(value) { + return typeof value == 'string' || + (!isArray(value) && isObjectLike(value) && objectToString.call(value) == stringTag); +} + +module.exports = isString; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/isSymbol.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/isSymbol.js new file mode 100644 index 0000000..aef5115 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/isSymbol.js @@ -0,0 +1,38 @@ +var isObjectLike = require('./isObjectLike'); + +/** `Object#toString` result references. */ +var symbolTag = '[object Symbol]'; + +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** + * Used to resolve the + * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring) + * of values. + */ +var objectToString = objectProto.toString; + +/** + * Checks if `value` is classified as a `Symbol` primitive or object. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a symbol, else `false`. + * @example + * + * _.isSymbol(Symbol.iterator); + * // => true + * + * _.isSymbol('abc'); + * // => false + */ +function isSymbol(value) { + return typeof value == 'symbol' || + (isObjectLike(value) && objectToString.call(value) == symbolTag); +} + +module.exports = isSymbol; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/isTypedArray.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/isTypedArray.js new file mode 100644 index 0000000..da3f8dd --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/isTypedArray.js @@ -0,0 +1,27 @@ +var baseIsTypedArray = require('./_baseIsTypedArray'), + baseUnary = require('./_baseUnary'), + nodeUtil = require('./_nodeUtil'); + +/* Node.js helper references. */ +var nodeIsTypedArray = nodeUtil && nodeUtil.isTypedArray; + +/** + * Checks if `value` is classified as a typed array. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a typed array, else `false`. + * @example + * + * _.isTypedArray(new Uint8Array); + * // => true + * + * _.isTypedArray([]); + * // => false + */ +var isTypedArray = nodeIsTypedArray ? baseUnary(nodeIsTypedArray) : baseIsTypedArray; + +module.exports = isTypedArray; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/isUndefined.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/isUndefined.js new file mode 100644 index 0000000..377d121 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/isUndefined.js @@ -0,0 +1,22 @@ +/** + * Checks if `value` is `undefined`. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is `undefined`, else `false`. + * @example + * + * _.isUndefined(void 0); + * // => true + * + * _.isUndefined(null); + * // => false + */ +function isUndefined(value) { + return value === undefined; +} + +module.exports = isUndefined; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/isWeakMap.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/isWeakMap.js new file mode 100644 index 0000000..8d36f66 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/isWeakMap.js @@ -0,0 +1,28 @@ +var getTag = require('./_getTag'), + isObjectLike = require('./isObjectLike'); + +/** `Object#toString` result references. */ +var weakMapTag = '[object WeakMap]'; + +/** + * Checks if `value` is classified as a `WeakMap` object. + * + * @static + * @memberOf _ + * @since 4.3.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a weak map, else `false`. + * @example + * + * _.isWeakMap(new WeakMap); + * // => true + * + * _.isWeakMap(new Map); + * // => false + */ +function isWeakMap(value) { + return isObjectLike(value) && getTag(value) == weakMapTag; +} + +module.exports = isWeakMap; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/isWeakSet.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/isWeakSet.js new file mode 100644 index 0000000..290164b --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/isWeakSet.js @@ -0,0 +1,37 @@ +var isObjectLike = require('./isObjectLike'); + +/** `Object#toString` result references. */ +var weakSetTag = '[object WeakSet]'; + +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** + * Used to resolve the + * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring) + * of values. + */ +var objectToString = objectProto.toString; + +/** + * Checks if `value` is classified as a `WeakSet` object. + * + * @static + * @memberOf _ + * @since 4.3.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a weak set, else `false`. + * @example + * + * _.isWeakSet(new WeakSet); + * // => true + * + * _.isWeakSet(new Set); + * // => false + */ +function isWeakSet(value) { + return isObjectLike(value) && objectToString.call(value) == weakSetTag; +} + +module.exports = isWeakSet; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/iteratee.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/iteratee.js new file mode 100644 index 0000000..8ec0588 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/iteratee.js @@ -0,0 +1,50 @@ +var baseClone = require('./_baseClone'), + baseIteratee = require('./_baseIteratee'); + +/** + * Creates a function that invokes `func` with the arguments of the created + * function. If `func` is a property name, the created function returns the + * property value for a given element. If `func` is an array or object, the + * created function returns `true` for elements that contain the equivalent + * source properties, otherwise it returns `false`. + * + * @static + * @since 4.0.0 + * @memberOf _ + * @category Util + * @param {*} [func=_.identity] The value to convert to a callback. + * @returns {Function} Returns the callback. + * @example + * + * var users = [ + * { 'user': 'barney', 'age': 36, 'active': true }, + * { 'user': 'fred', 'age': 40, 'active': false } + * ]; + * + * // The `_.matches` iteratee shorthand. + * _.filter(users, _.iteratee({ 'user': 'barney', 'active': true })); + * // => [{ 'user': 'barney', 'age': 36, 'active': true }] + * + * // The `_.matchesProperty` iteratee shorthand. + * _.filter(users, _.iteratee(['user', 'fred'])); + * // => [{ 'user': 'fred', 'age': 40 }] + * + * // The `_.property` iteratee shorthand. + * _.map(users, _.iteratee('user')); + * // => ['barney', 'fred'] + * + * // Create custom iteratee shorthands. + * _.iteratee = _.wrap(_.iteratee, function(iteratee, func) { + * return !_.isRegExp(func) ? iteratee(func) : function(string) { + * return func.test(string); + * }; + * }); + * + * _.filter(['abc', 'def'], /ef/); + * // => ['def'] + */ +function iteratee(func) { + return baseIteratee(typeof func == 'function' ? func : baseClone(func, true)); +} + +module.exports = iteratee; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/join.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/join.js new file mode 100644 index 0000000..fe31067 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/join.js @@ -0,0 +1,26 @@ +/** Used for built-in method references. */ +var arrayProto = Array.prototype; + +/* Built-in method references for those with the same name as other `lodash` methods. */ +var nativeJoin = arrayProto.join; + +/** + * Converts all elements in `array` into a string separated by `separator`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {Array} array The array to convert. + * @param {string} [separator=','] The element separator. + * @returns {string} Returns the joined string. + * @example + * + * _.join(['a', 'b', 'c'], '~'); + * // => 'a~b~c' + */ +function join(array, separator) { + return array ? nativeJoin.call(array, separator) : ''; +} + +module.exports = join; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/kebabCase.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/kebabCase.js new file mode 100644 index 0000000..8a52be6 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/kebabCase.js @@ -0,0 +1,28 @@ +var createCompounder = require('./_createCompounder'); + +/** + * Converts `string` to + * [kebab case](https://en.wikipedia.org/wiki/Letter_case#Special_case_styles). + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category String + * @param {string} [string=''] The string to convert. + * @returns {string} Returns the kebab cased string. + * @example + * + * _.kebabCase('Foo Bar'); + * // => 'foo-bar' + * + * _.kebabCase('fooBar'); + * // => 'foo-bar' + * + * _.kebabCase('__FOO_BAR__'); + * // => 'foo-bar' + */ +var kebabCase = createCompounder(function(result, word, index) { + return result + (index ? '-' : '') + word.toLowerCase(); +}); + +module.exports = kebabCase; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/keyBy.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/keyBy.js new file mode 100644 index 0000000..d0047a5 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/keyBy.js @@ -0,0 +1,37 @@ +var baseAssignValue = require('./_baseAssignValue'), + createAggregator = require('./_createAggregator'); + +/** + * Creates an object composed of keys generated from the results of running + * each element of `collection` thru `iteratee`. The corresponding value of + * each key is the last element responsible for generating the key. The + * iteratee is invoked with one argument: (value). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [iteratee=_.identity] + * The iteratee to transform keys. + * @returns {Object} Returns the composed aggregate object. + * @example + * + * var array = [ + * { 'dir': 'left', 'code': 97 }, + * { 'dir': 'right', 'code': 100 } + * ]; + * + * _.keyBy(array, function(o) { + * return String.fromCharCode(o.code); + * }); + * // => { 'a': { 'dir': 'left', 'code': 97 }, 'd': { 'dir': 'right', 'code': 100 } } + * + * _.keyBy(array, 'dir'); + * // => { 'left': { 'dir': 'left', 'code': 97 }, 'right': { 'dir': 'right', 'code': 100 } } + */ +var keyBy = createAggregator(function(result, value, key) { + baseAssignValue(result, key, value); +}); + +module.exports = keyBy; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/keys.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/keys.js new file mode 100644 index 0000000..d143c71 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/keys.js @@ -0,0 +1,37 @@ +var arrayLikeKeys = require('./_arrayLikeKeys'), + baseKeys = require('./_baseKeys'), + isArrayLike = require('./isArrayLike'); + +/** + * Creates an array of the own enumerable property names of `object`. + * + * **Note:** Non-object values are coerced to objects. See the + * [ES spec](http://ecma-international.org/ecma-262/7.0/#sec-object.keys) + * for more details. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Object + * @param {Object} object The object to query. + * @returns {Array} Returns the array of property names. + * @example + * + * function Foo() { + * this.a = 1; + * this.b = 2; + * } + * + * Foo.prototype.c = 3; + * + * _.keys(new Foo); + * // => ['a', 'b'] (iteration order is not guaranteed) + * + * _.keys('hi'); + * // => ['0', '1'] + */ +function keys(object) { + return isArrayLike(object) ? arrayLikeKeys(object) : baseKeys(object); +} + +module.exports = keys; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/keysIn.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/keysIn.js new file mode 100644 index 0000000..a62308f --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/keysIn.js @@ -0,0 +1,32 @@ +var arrayLikeKeys = require('./_arrayLikeKeys'), + baseKeysIn = require('./_baseKeysIn'), + isArrayLike = require('./isArrayLike'); + +/** + * Creates an array of the own and inherited enumerable property names of `object`. + * + * **Note:** Non-object values are coerced to objects. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Object + * @param {Object} object The object to query. + * @returns {Array} Returns the array of property names. + * @example + * + * function Foo() { + * this.a = 1; + * this.b = 2; + * } + * + * Foo.prototype.c = 3; + * + * _.keysIn(new Foo); + * // => ['a', 'b', 'c'] (iteration order is not guaranteed) + */ +function keysIn(object) { + return isArrayLike(object) ? arrayLikeKeys(object, true) : baseKeysIn(object); +} + +module.exports = keysIn; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/lang.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/lang.js new file mode 100644 index 0000000..a396216 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/lang.js @@ -0,0 +1,58 @@ +module.exports = { + 'castArray': require('./castArray'), + 'clone': require('./clone'), + 'cloneDeep': require('./cloneDeep'), + 'cloneDeepWith': require('./cloneDeepWith'), + 'cloneWith': require('./cloneWith'), + 'conformsTo': require('./conformsTo'), + 'eq': require('./eq'), + 'gt': require('./gt'), + 'gte': require('./gte'), + 'isArguments': require('./isArguments'), + 'isArray': require('./isArray'), + 'isArrayBuffer': require('./isArrayBuffer'), + 'isArrayLike': require('./isArrayLike'), + 'isArrayLikeObject': require('./isArrayLikeObject'), + 'isBoolean': require('./isBoolean'), + 'isBuffer': require('./isBuffer'), + 'isDate': require('./isDate'), + 'isElement': require('./isElement'), + 'isEmpty': require('./isEmpty'), + 'isEqual': require('./isEqual'), + 'isEqualWith': require('./isEqualWith'), + 'isError': require('./isError'), + 'isFinite': require('./isFinite'), + 'isFunction': require('./isFunction'), + 'isInteger': require('./isInteger'), + 'isLength': require('./isLength'), + 'isMap': require('./isMap'), + 'isMatch': require('./isMatch'), + 'isMatchWith': require('./isMatchWith'), + 'isNaN': require('./isNaN'), + 'isNative': require('./isNative'), + 'isNil': require('./isNil'), + 'isNull': require('./isNull'), + 'isNumber': require('./isNumber'), + 'isObject': require('./isObject'), + 'isObjectLike': require('./isObjectLike'), + 'isPlainObject': require('./isPlainObject'), + 'isRegExp': require('./isRegExp'), + 'isSafeInteger': require('./isSafeInteger'), + 'isSet': require('./isSet'), + 'isString': require('./isString'), + 'isSymbol': require('./isSymbol'), + 'isTypedArray': require('./isTypedArray'), + 'isUndefined': require('./isUndefined'), + 'isWeakMap': require('./isWeakMap'), + 'isWeakSet': require('./isWeakSet'), + 'lt': require('./lt'), + 'lte': require('./lte'), + 'toArray': require('./toArray'), + 'toFinite': require('./toFinite'), + 'toInteger': require('./toInteger'), + 'toLength': require('./toLength'), + 'toNumber': require('./toNumber'), + 'toPlainObject': require('./toPlainObject'), + 'toSafeInteger': require('./toSafeInteger'), + 'toString': require('./toString') +}; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/last.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/last.js new file mode 100644 index 0000000..6402a4c --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/last.js @@ -0,0 +1,20 @@ +/** + * Gets the last element of `array`. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Array + * @param {Array} array The array to query. + * @returns {*} Returns the last element of `array`. + * @example + * + * _.last([1, 2, 3]); + * // => 3 + */ +function last(array) { + var length = array ? array.length : 0; + return length ? array[length - 1] : undefined; +} + +module.exports = last; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/lastIndexOf.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/lastIndexOf.js new file mode 100644 index 0000000..9201cb9 --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/lastIndexOf.js @@ -0,0 +1,46 @@ +var baseFindIndex = require('./_baseFindIndex'), + baseIsNaN = require('./_baseIsNaN'), + strictLastIndexOf = require('./_strictLastIndexOf'), + toInteger = require('./toInteger'); + +/* Built-in method references for those with the same name as other `lodash` methods. */ +var nativeMax = Math.max, + nativeMin = Math.min; + +/** + * This method is like `_.indexOf` except that it iterates over elements of + * `array` from right to left. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Array + * @param {Array} array The array to inspect. + * @param {*} value The value to search for. + * @param {number} [fromIndex=array.length-1] The index to search from. + * @returns {number} Returns the index of the matched value, else `-1`. + * @example + * + * _.lastIndexOf([1, 2, 1, 2], 2); + * // => 3 + * + * // Search from the `fromIndex`. + * _.lastIndexOf([1, 2, 1, 2], 2, 2); + * // => 1 + */ +function lastIndexOf(array, value, fromIndex) { + var length = array ? array.length : 0; + if (!length) { + return -1; + } + var index = length; + if (fromIndex !== undefined) { + index = toInteger(fromIndex); + index = index < 0 ? nativeMax(length + index, 0) : nativeMin(index, length - 1); + } + return value === value + ? strictLastIndexOf(array, value, index) + : baseFindIndex(array, baseIsNaN, index, true); +} + +module.exports = lastIndexOf; diff --git a/node_modules/mongoose/node_modules/async/node_modules/lodash/lodash.js b/node_modules/mongoose/node_modules/async/node_modules/lodash/lodash.js new file mode 100644 index 0000000..361e74d --- /dev/null +++ b/node_modules/mongoose/node_modules/async/node_modules/lodash/lodash.js @@ -0,0 +1,16982 @@ +/** + * @license + * lodash + * Copyright jQuery Foundation and other contributors + * Released under MIT license + * Based on Underscore.js 1.8.3 + * Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors + */ +;(function() { + + /** Used as a safe reference for `undefined` in pre-ES5 environments. */ + var undefined; + + /** Used as the semantic version number. */ + var VERSION = '4.16.4'; + + /** Used as the size to enable large array optimizations. */ + var LARGE_ARRAY_SIZE = 200; + + /** Error message constants. */ + var CORE_ERROR_TEXT = 'Unsupported core-js use. Try https://github.com/es-shims.', + FUNC_ERROR_TEXT = 'Expected a function'; + + /** Used to stand-in for `undefined` hash values. */ + var HASH_UNDEFINED = '__lodash_hash_undefined__'; + + /** Used as the maximum memoize cache size. */ + var MAX_MEMOIZE_SIZE = 500; + + /** Used as the internal argument placeholder. */ + var PLACEHOLDER = '__lodash_placeholder__'; + + /** Used to compose bitmasks for function metadata. */ + var BIND_FLAG = 1, + BIND_KEY_FLAG = 2, + CURRY_BOUND_FLAG = 4, + CURRY_FLAG = 8, + CURRY_RIGHT_FLAG = 16, + PARTIAL_FLAG = 32, + PARTIAL_RIGHT_FLAG = 64, + ARY_FLAG = 128, + REARG_FLAG = 256, + FLIP_FLAG = 512; + + /** Used to compose bitmasks for comparison styles. */ + var UNORDERED_COMPARE_FLAG = 1, + PARTIAL_COMPARE_FLAG = 2; + + /** Used as default options for `_.truncate`. */ + var DEFAULT_TRUNC_LENGTH = 30, + DEFAULT_TRUNC_OMISSION = '...'; + + /** Used to detect hot functions by number of calls within a span of milliseconds. */ + var HOT_COUNT = 500, + HOT_SPAN = 16; + + /** Used to indicate the type of lazy iteratees. */ + var LAZY_FILTER_FLAG = 1, + LAZY_MAP_FLAG = 2, + LAZY_WHILE_FLAG = 3; + + /** Used as references for various `Number` constants. */ + var INFINITY = 1 / 0, + MAX_SAFE_INTEGER = 9007199254740991, + MAX_INTEGER = 1.7976931348623157e+308, + NAN = 0 / 0; + + /** Used as references for the maximum length and index of an array. */ + var MAX_ARRAY_LENGTH = 4294967295, + MAX_ARRAY_INDEX = MAX_ARRAY_LENGTH - 1, + HALF_MAX_ARRAY_LENGTH = MAX_ARRAY_LENGTH >>> 1; + + /** Used to associate wrap methods with their bit flags. */ + var wrapFlags = [ + ['ary', ARY_FLAG], + ['bind', BIND_FLAG], + ['bindKey', BIND_KEY_FLAG], + ['curry', CURRY_FLAG], + ['curryRight', CURRY_RIGHT_FLAG], + ['flip', FLIP_FLAG], + ['partial', PARTIAL_FLAG], + ['partialRight', PARTIAL_RIGHT_FLAG], + ['rearg', REARG_FLAG] + ]; + + /** `Object#toString` result references. */ + var argsTag = '[object Arguments]', + arrayTag = '[object Array]', + boolTag = '[object Boolean]', + dateTag = '[object Date]', + errorTag = '[object Error]', + funcTag = '[object Function]', + genTag = '[object GeneratorFunction]', + mapTag = '[object Map]', + numberTag = '[object Number]', + objectTag = '[object Object]', + promiseTag = '[object Promise]', + proxyTag = '[object Proxy]', + regexpTag = '[object RegExp]', + setTag = '[object Set]', + stringTag = '[object String]', + symbolTag = '[object Symbol]', + weakMapTag = '[object WeakMap]', + weakSetTag = '[object WeakSet]'; + + var arrayBufferTag = '[object ArrayBuffer]', + dataViewTag = '[object DataView]', + float32Tag = '[object Float32Array]', + float64Tag = '[object Float64Array]', + int8Tag = '[object Int8Array]', + int16Tag = '[object Int16Array]', + int32Tag = '[object Int32Array]', + uint8Tag = '[object Uint8Array]', + uint8ClampedTag = '[object Uint8ClampedArray]', + uint16Tag = '[object Uint16Array]', + uint32Tag = '[object Uint32Array]'; + + /** Used to match empty string literals in compiled template source. */ + var reEmptyStringLeading = /\b__p \+= '';/g, + reEmptyStringMiddle = /\b(__p \+=) '' \+/g, + reEmptyStringTrailing = /(__e\(.*?\)|\b__t\)) \+\n'';/g; + + /** Used to match HTML entities and HTML characters. */ + var reEscapedHtml = /&(?:amp|lt|gt|quot|#39);/g, + reUnescapedHtml = /[&<>"']/g, + reHasEscapedHtml = RegExp(reEscapedHtml.source), + reHasUnescapedHtml = RegExp(reUnescapedHtml.source); + + /** Used to match template delimiters. */ + var reEscape = /<%-([\s\S]+?)%>/g, + reEvaluate = /<%([\s\S]+?)%>/g, + reInterpolate = /<%=([\s\S]+?)%>/g; + + /** Used to match property names within property paths. */ + var reIsDeepProp = /\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/, + reIsPlainProp = /^\w*$/, + reLeadingDot = /^\./, + rePropName = /[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g; + + /** + * Used to match `RegExp` + * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns). + */ + var reRegExpChar = /[\\^$.*+?()[\]{}|]/g, + reHasRegExpChar = RegExp(reRegExpChar.source); + + /** Used to match leading and trailing whitespace. */ + var reTrim = /^\s+|\s+$/g, + reTrimStart = /^\s+/, + reTrimEnd = /\s+$/; + + /** Used to match wrap detail comments. */ + var reWrapComment = /\{(?:\n\/\* \[wrapped with .+\] \*\/)?\n?/, + reWrapDetails = /\{\n\/\* \[wrapped with (.+)\] \*/, + reSplitDetails = /,? & /; + + /** Used to match words composed of alphanumeric characters. */ + var reAsciiWord = /[^\x00-\x2f\x3a-\x40\x5b-\x60\x7b-\x7f]+/g; + + /** Used to match backslashes in property paths. */ + var reEscapeChar = /\\(\\)?/g; + + /** + * Used to match + * [ES template delimiters](http://ecma-international.org/ecma-262/7.0/#sec-template-literal-lexical-components). + */ + var reEsTemplate = /\$\{([^\\}]*(?:\\.[^\\}]*)*)\}/g; + + /** Used to match `RegExp` flags from their coerced string values. */ + var reFlags = /\w*$/; + + /** Used to detect bad signed hexadecimal string values. */ + var reIsBadHex = /^[-+]0x[0-9a-f]+$/i; + + /** Used to detect binary string values. */ + var reIsBinary = /^0b[01]+$/i; + + /** Used to detect host constructors (Safari). */ + var reIsHostCtor = /^\[object .+?Constructor\]$/; + + /** Used to detect octal string values. */ + var reIsOctal = /^0o[0-7]+$/i; + + /** Used to detect unsigned integer values. */ + var reIsUint = /^(?:0|[1-9]\d*)$/; + + /** Used to match Latin Unicode letters (excluding mathematical operators). */ + var reLatin = /[\xc0-\xd6\xd8-\xf6\xf8-\xff\u0100-\u017f]/g; + + /** Used to ensure capturing order of template delimiters. */ + var reNoMatch = /($^)/; + + /** Used to match unescaped characters in compiled string literals. */ + var reUnescapedString = /['\n\r\u2028\u2029\\]/g; + + /** Used to compose unicode character classes. */ + var rsAstralRange = '\\ud800-\\udfff', + rsComboMarksRange = '\\u0300-\\u036f\\ufe20-\\ufe23', + rsComboSymbolsRange = '\\u20d0-\\u20f0', + rsDingbatRange = '\\u2700-\\u27bf', + rsLowerRange = 'a-z\\xdf-\\xf6\\xf8-\\xff', + rsMathOpRange = '\\xac\\xb1\\xd7\\xf7', + rsNonCharRange = '\\x00-\\x2f\\x3a-\\x40\\x5b-\\x60\\x7b-\\xbf', + rsPunctuationRange = '\\u2000-\\u206f', + rsSpaceRange = ' \\t\\x0b\\f\\xa0\\ufeff\\n\\r\\u2028\\u2029\\u1680\\u180e\\u2000\\u2001\\u2002\\u2003\\u2004\\u2005\\u2006\\u2007\\u2008\\u2009\\u200a\\u202f\\u205f\\u3000', + rsUpperRange = 'A-Z\\xc0-\\xd6\\xd8-\\xde', + rsVarRange = '\\ufe0e\\ufe0f', + rsBreakRange = rsMathOpRange + rsNonCharRange + rsPunctuationRange + rsSpaceRange; + + /** Used to compose unicode capture groups. */ + var rsApos = "['\u2019]", + rsAstral = '[' + rsAstralRange + ']', + rsBreak = '[' + rsBreakRange + ']', + rsCombo = '[' + rsComboMarksRange + rsComboSymbolsRange + ']', + rsDigits = '\\d+', + rsDingbat = '[' + rsDingbatRange + ']', + rsLower = '[' + rsLowerRange + ']', + rsMisc = '[^' + rsAstralRange + rsBreakRange + rsDigits + rsDingbatRange + rsLowerRange + rsUpperRange + ']', + rsFitz = '\\ud83c[\\udffb-\\udfff]', + rsModifier = '(?:' + rsCombo + '|' + rsFitz + ')', + rsNonAstral = '[^' + rsAstralRange + ']', + rsRegional = '(?:\\ud83c[\\udde6-\\uddff]){2}', + rsSurrPair = '[\\ud800-\\udbff][\\udc00-\\udfff]', + rsUpper = '[' + rsUpperRange + ']', + rsZWJ = '\\u200d'; + + /** Used to compose unicode regexes. */ + var rsLowerMisc = '(?:' + rsLower + '|' + rsMisc + ')', + rsUpperMisc = '(?:' + rsUpper + '|' + rsMisc + ')', + rsOptLowerContr = '(?:' + rsApos + '(?:d|ll|m|re|s|t|ve))?', + rsOptUpperContr = '(?:' + rsApos + '(?:D|LL|M|RE|S|T|VE))?', + reOptMod = rsModifier + '?', + rsOptVar = '[' + rsVarRange + ']?', + rsOptJoin = '(?:' + rsZWJ + '(?:' + [rsNonAstral, rsRegional, rsSurrPair].join('|') + ')' + rsOptVar + reOptMod + ')*', + rsSeq = rsOptVar + reOptMod + rsOptJoin, + rsEmoji = '(?:' + [rsDingbat, rsRegional, rsSurrPair].join('|') + ')' + rsSeq, + rsSymbol = '(?:' + [rsNonAstral + rsCombo + '?', rsCombo, rsRegional, rsSurrPair, rsAstral].join('|') + ')'; + + /** Used to match apostrophes. */ + var reApos = RegExp(rsApos, 'g'); + + /** + * Used to match [combining diacritical marks](https://en.wikipedia.org/wiki/Combining_Diacritical_Marks) and + * [combining diacritical marks for symbols](https://en.wikipedia.org/wiki/Combining_Diacritical_Marks_for_Symbols). + */ + var reComboMark = RegExp(rsCombo, 'g'); + + /** Used to match [string symbols](https://mathiasbynens.be/notes/javascript-unicode). */ + var reUnicode = RegExp(rsFitz + '(?=' + rsFitz + ')|' + rsSymbol + rsSeq, 'g'); + + /** Used to match complex or compound words. */ + var reUnicodeWord = RegExp([ + rsUpper + '?' + rsLower + '+' + rsOptLowerContr + '(?=' + [rsBreak, rsUpper, '$'].join('|') + ')', + rsUpperMisc + '+' + rsOptUpperContr + '(?=' + [rsBreak, rsUpper + rsLowerMisc, '$'].join('|') + ')', + rsUpper + '?' + rsLowerMisc + '+' + rsOptLowerContr, + rsUpper + '+' + rsOptUpperContr, + rsDigits, + rsEmoji + ].join('|'), 'g'); + + /** Used to detect strings with [zero-width joiners or code points from the astral planes](http://eev.ee/blog/2015/09/12/dark-corners-of-unicode/). */ + var reHasUnicode = RegExp('[' + rsZWJ + rsAstralRange + rsComboMarksRange + rsComboSymbolsRange + rsVarRange + ']'); + + /** Used to detect strings that need a more robust regexp to match words. */ + var reHasUnicodeWord = /[a-z][A-Z]|[A-Z]{2,}[a-z]|[0-9][a-zA-Z]|[a-zA-Z][0-9]|[^a-zA-Z0-9 ]/; + + /** Used to assign default `context` object properties. */ + var contextProps = [ + 'Array', 'Buffer', 'DataView', 'Date', 'Error', 'Float32Array', 'Float64Array', + 'Function', 'Int8Array', 'Int16Array', 'Int32Array', 'Map', 'Math', 'Object', + 'Promise', 'RegExp', 'Set', 'String', 'Symbol', 'TypeError', 'Uint8Array', + 'Uint8ClampedArray', 'Uint16Array', 'Uint32Array', 'WeakMap', + '_', 'clearTimeout', 'isFinite', 'parseInt', 'setTimeout' + ]; + + /** Used to make template sourceURLs easier to identify. */ + var templateCounter = -1; + + /** Used to identify `toStringTag` values of typed arrays. */ + var typedArrayTags = {}; + typedArrayTags[float32Tag] = typedArrayTags[float64Tag] = + typedArrayTags[int8Tag] = typedArrayTags[int16Tag] = + typedArrayTags[int32Tag] = typedArrayTags[uint8Tag] = + typedArrayTags[uint8ClampedTag] = typedArrayTags[uint16Tag] = + typedArrayTags[uint32Tag] = true; + typedArrayTags[argsTag] = typedArrayTags[arrayTag] = + typedArrayTags[arrayBufferTag] = typedArrayTags[boolTag] = + typedArrayTags[dataViewTag] = typedArrayTags[dateTag] = + typedArrayTags[errorTag] = typedArrayTags[funcTag] = + typedArrayTags[mapTag] = typedArrayTags[numberTag] = + typedArrayTags[objectTag] = typedArrayTags[regexpTag] = + typedArrayTags[setTag] = typedArrayTags[stringTag] = + typedArrayTags[weakMapTag] = false; + + /** Used to identify `toStringTag` values supported by `_.clone`. */ + var cloneableTags = {}; + cloneableTags[argsTag] = cloneableTags[arrayTag] = + cloneableTags[arrayBufferTag] = cloneableTags[dataViewTag] = + cloneableTags[boolTag] = cloneableTags[dateTag] = + cloneableTags[float32Tag] = cloneableTags[float64Tag] = + cloneableTags[int8Tag] = cloneableTags[int16Tag] = + cloneableTags[int32Tag] = cloneableTags[mapTag] = + cloneableTags[numberTag] = cloneableTags[objectTag] = + cloneableTags[regexpTag] = cloneableTags[setTag] = + cloneableTags[stringTag] = cloneableTags[symbolTag] = + cloneableTags[uint8Tag] = cloneableTags[uint8ClampedTag] = + cloneableTags[uint16Tag] = cloneableTags[uint32Tag] = true; + cloneableTags[errorTag] = cloneableTags[funcTag] = + cloneableTags[weakMapTag] = false; + + /** Used to map Latin Unicode letters to basic Latin letters. */ + var deburredLetters = { + // Latin-1 Supplement block. + '\xc0': 'A', '\xc1': 'A', '\xc2': 'A', '\xc3': 'A', '\xc4': 'A', '\xc5': 'A', + '\xe0': 'a', '\xe1': 'a', '\xe2': 'a', '\xe3': 'a', '\xe4': 'a', '\xe5': 'a', + '\xc7': 'C', '\xe7': 'c', + '\xd0': 'D', '\xf0': 'd', + '\xc8': 'E', '\xc9': 'E', '\xca': 'E', '\xcb': 'E', + '\xe8': 'e', '\xe9': 'e', '\xea': 'e', '\xeb': 'e', + '\xcc': 'I', '\xcd': 'I', '\xce': 'I', '\xcf': 'I', + '\xec': 'i', '\xed': 'i', '\xee': 'i', '\xef': 'i', + '\xd1': 'N', '\xf1': 'n', + '\xd2': 'O', '\xd3': 'O', '\xd4': 'O', '\xd5': 'O', '\xd6': 'O', '\xd8': 'O', + '\xf2': 'o', '\xf3': 'o', '\xf4': 'o', '\xf5': 'o', '\xf6': 'o', '\xf8': 'o', + '\xd9': 'U', '\xda': 'U', '\xdb': 'U', '\xdc': 'U', + '\xf9': 'u', '\xfa': 'u', '\xfb': 'u', '\xfc': 'u', + '\xdd': 'Y', '\xfd': 'y', '\xff': 'y', + '\xc6': 'Ae', '\xe6': 'ae', + '\xde': 'Th', '\xfe': 'th', + '\xdf': 'ss', + // Latin Extended-A block. + '\u0100': 'A', '\u0102': 'A', '\u0104': 'A', + '\u0101': 'a', '\u0103': 'a', '\u0105': 'a', + '\u0106': 'C', '\u0108': 'C', '\u010a': 'C', '\u010c': 'C', + '\u0107': 'c', '\u0109': 'c', '\u010b': 'c', '\u010d': 'c', + '\u010e': 'D', '\u0110': 'D', '\u010f': 'd', '\u0111': 'd', + '\u0112': 'E', '\u0114': 'E', '\u0116': 'E', '\u0118': 'E', '\u011a': 'E', + '\u0113': 'e', '\u0115': 'e', '\u0117': 'e', '\u0119': 'e', '\u011b': 'e', + '\u011c': 'G', '\u011e': 'G', '\u0120': 'G', '\u0122': 'G', + '\u011d': 'g', '\u011f': 'g', '\u0121': 'g', '\u0123': 'g', + '\u0124': 'H', '\u0126': 'H', '\u0125': 'h', '\u0127': 'h', + '\u0128': 'I', '\u012a': 'I', '\u012c': 'I', '\u012e': 'I', '\u0130': 'I', + '\u0129': 'i', '\u012b': 'i', '\u012d': 'i', '\u012f': 'i', '\u0131': 'i', + '\u0134': 'J', '\u0135': 'j', + '\u0136': 'K', '\u0137': 'k', '\u0138': 'k', + '\u0139': 'L', '\u013b': 'L', '\u013d': 'L', '\u013f': 'L', '\u0141': 'L', + '\u013a': 'l', '\u013c': 'l', '\u013e': 'l', '\u0140': 'l', '\u0142': 'l', + '\u0143': 'N', '\u0145': 'N', '\u0147': 'N', '\u014a': 'N', + '\u0144': 'n', '\u0146': 'n', '\u0148': 'n', '\u014b': 'n', + '\u014c': 'O', '\u014e': 'O', '\u0150': 'O', + '\u014d': 'o', '\u014f': 'o', '\u0151': 'o', + '\u0154': 'R', '\u0156': 'R', '\u0158': 'R', + '\u0155': 'r', '\u0157': 'r', '\u0159': 'r', + '\u015a': 'S', '\u015c': 'S', '\u015e': 'S', '\u0160': 'S', + '\u015b': 's', '\u015d': 's', '\u015f': 's', '\u0161': 's', + '\u0162': 'T', '\u0164': 'T', '\u0166': 'T', + '\u0163': 't', '\u0165': 't', '\u0167': 't', + '\u0168': 'U', '\u016a': 'U', '\u016c': 'U', '\u016e': 'U', '\u0170': 'U', '\u0172': 'U', + '\u0169': 'u', '\u016b': 'u', '\u016d': 'u', '\u016f': 'u', '\u0171': 'u', '\u0173': 'u', + '\u0174': 'W', '\u0175': 'w', + '\u0176': 'Y', '\u0177': 'y', '\u0178': 'Y', + '\u0179': 'Z', '\u017b': 'Z', '\u017d': 'Z', + '\u017a': 'z', '\u017c': 'z', '\u017e': 'z', + '\u0132': 'IJ', '\u0133': 'ij', + '\u0152': 'Oe', '\u0153': 'oe', + '\u0149': "'n", '\u017f': 's' + }; + + /** Used to map characters to HTML entities. */ + var htmlEscapes = { + '&': '&', + '<': '<', + '>': '>', + '"': '"', + "'": ''' + }; + + /** Used to map HTML entities to characters. */ + var htmlUnescapes = { + '&': '&', + '<': '<', + '>': '>', + '"': '"', + ''': "'" + }; + + /** Used to escape characters for inclusion in compiled string literals. */ + var stringEscapes = { + '\\': '\\', + "'": "'", + '\n': 'n', + '\r': 'r', + '\u2028': 'u2028', + '\u2029': 'u2029' + }; + + /** Built-in method references without a dependency on `root`. */ + var freeParseFloat = parseFloat, + freeParseInt = parseInt; + + /** Detect free variable `global` from Node.js. */ + var freeGlobal = typeof global == 'object' && global && global.Object === Object && global; + + /** Detect free variable `self`. */ + var freeSelf = typeof self == 'object' && self && self.Object === Object && self; + + /** Used as a reference to the global object. */ + var root = freeGlobal || freeSelf || Function('return this')(); + + /** Detect free variable `exports`. */ + var freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports; + + /** Detect free variable `module`. */ + var freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module; + + /** Detect the popular CommonJS extension `module.exports`. */ + var moduleExports = freeModule && freeModule.exports === freeExports; + + /** Detect free variable `process` from Node.js. */ + var freeProcess = moduleExports && freeGlobal.process; + + /** Used to access faster Node.js helpers. */ + var nodeUtil = (function() { + try { + return freeProcess && freeProcess.binding('util'); + } catch (e) {} + }()); + + /* Node.js helper references. */ + var nodeIsArrayBuffer = nodeUtil && nodeUtil.isArrayBuffer, + nodeIsDate = nodeUtil && nodeUtil.isDate, + nodeIsMap = nodeUtil && nodeUtil.isMap, + nodeIsRegExp = nodeUtil && nodeUtil.isRegExp, + nodeIsSet = nodeUtil && nodeUtil.isSet, + nodeIsTypedArray = nodeUtil && nodeUtil.isTypedArray; + + /*--------------------------------------------------------------------------*/ + + /** + * Adds the key-value `pair` to `map`. + * + * @private + * @param {Object} map The map to modify. + * @param {Array} pair The key-value pair to add. + * @returns {Object} Returns `map`. + */ + function addMapEntry(map, pair) { + // Don't return `map.set` because it's not chainable in IE 11. + map.set(pair[0], pair[1]); + return map; + } + + /** + * Adds `value` to `set`. + * + * @private + * @param {Object} set The set to modify. + * @param {*} value The value to add. + * @returns {Object} Returns `set`. + */ + function addSetEntry(set, value) { + // Don't return `set.add` because it's not chainable in IE 11. + set.add(value); + return set; + } + + /** + * A faster alternative to `Function#apply`, this function invokes `func` + * with the `this` binding of `thisArg` and the arguments of `args`. + * + * @private + * @param {Function} func The function to invoke. + * @param {*} thisArg The `this` binding of `func`. + * @param {Array} args The arguments to invoke `func` with. + * @returns {*} Returns the result of `func`. + */ + function apply(func, thisArg, args) { + switch (args.length) { + case 0: return func.call(thisArg); + case 1: return func.call(thisArg, args[0]); + case 2: return func.call(thisArg, args[0], args[1]); + case 3: return func.call(thisArg, args[0], args[1], args[2]); + } + return func.apply(thisArg, args); + } + + /** + * A specialized version of `baseAggregator` for arrays. + * + * @private + * @param {Array} [array] The array to iterate over. + * @param {Function} setter The function to set `accumulator` values. + * @param {Function} iteratee The iteratee to transform keys. + * @param {Object} accumulator The initial aggregated object. + * @returns {Function} Returns `accumulator`. + */ + function arrayAggregator(array, setter, iteratee, accumulator) { + var index = -1, + length = array ? array.length : 0; + + while (++index < length) { + var value = array[index]; + setter(accumulator, value, iteratee(value), array); + } + return accumulator; + } + + /** + * A specialized version of `_.forEach` for arrays without support for + * iteratee shorthands. + * + * @private + * @param {Array} [array] The array to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @returns {Array} Returns `array`. + */ + function arrayEach(array, iteratee) { + var index = -1, + length = array ? array.length : 0; + + while (++index < length) { + if (iteratee(array[index], index, array) === false) { + break; + } + } + return array; + } + + /** + * A specialized version of `_.forEachRight` for arrays without support for + * iteratee shorthands. + * + * @private + * @param {Array} [array] The array to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @returns {Array} Returns `array`. + */ + function arrayEachRight(array, iteratee) { + var length = array ? array.length : 0; + + while (length--) { + if (iteratee(array[length], length, array) === false) { + break; + } + } + return array; + } + + /** + * A specialized version of `_.every` for arrays without support for + * iteratee shorthands. + * + * @private + * @param {Array} [array] The array to iterate over. + * @param {Function} predicate The function invoked per iteration. + * @returns {boolean} Returns `true` if all elements pass the predicate check, + * else `false`. + */ + function arrayEvery(array, predicate) { + var index = -1, + length = array ? array.length : 0; + + while (++index < length) { + if (!predicate(array[index], index, array)) { + return false; + } + } + return true; + } + + /** + * A specialized version of `_.filter` for arrays without support for + * iteratee shorthands. + * + * @private + * @param {Array} [array] The array to iterate over. + * @param {Function} predicate The function invoked per iteration. + * @returns {Array} Returns the new filtered array. + */ + function arrayFilter(array, predicate) { + var index = -1, + length = array ? array.length : 0, + resIndex = 0, + result = []; + + while (++index < length) { + var value = array[index]; + if (predicate(value, index, array)) { + result[resIndex++] = value; + } + } + return result; + } + + /** + * A specialized version of `_.includes` for arrays without support for + * specifying an index to search from. + * + * @private + * @param {Array} [array] The array to inspect. + * @param {*} target The value to search for. + * @returns {boolean} Returns `true` if `target` is found, else `false`. + */ + function arrayIncludes(array, value) { + var length = array ? array.length : 0; + return !!length && baseIndexOf(array, value, 0) > -1; + } + + /** + * This function is like `arrayIncludes` except that it accepts a comparator. + * + * @private + * @param {Array} [array] The array to inspect. + * @param {*} target The value to search for. + * @param {Function} comparator The comparator invoked per element. + * @returns {boolean} Returns `true` if `target` is found, else `false`. + */ + function arrayIncludesWith(array, value, comparator) { + var index = -1, + length = array ? array.length : 0; + + while (++index < length) { + if (comparator(value, array[index])) { + return true; + } + } + return false; + } + + /** + * A specialized version of `_.map` for arrays without support for iteratee + * shorthands. + * + * @private + * @param {Array} [array] The array to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @returns {Array} Returns the new mapped array. + */ + function arrayMap(array, iteratee) { + var index = -1, + length = array ? array.length : 0, + result = Array(length); + + while (++index < length) { + result[index] = iteratee(array[index], index, array); + } + return result; + } + + /** + * Appends the elements of `values` to `array`. + * + * @private + * @param {Array} array The array to modify. + * @param {Array} values The values to append. + * @returns {Array} Returns `array`. + */ + function arrayPush(array, values) { + var index = -1, + length = values.length, + offset = array.length; + + while (++index < length) { + array[offset + index] = values[index]; + } + return array; + } + + /** + * A specialized version of `_.reduce` for arrays without support for + * iteratee shorthands. + * + * @private + * @param {Array} [array] The array to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @param {*} [accumulator] The initial value. + * @param {boolean} [initAccum] Specify using the first element of `array` as + * the initial value. + * @returns {*} Returns the accumulated value. + */ + function arrayReduce(array, iteratee, accumulator, initAccum) { + var index = -1, + length = array ? array.length : 0; + + if (initAccum && length) { + accumulator = array[++index]; + } + while (++index < length) { + accumulator = iteratee(accumulator, array[index], index, array); + } + return accumulator; + } + + /** + * A specialized version of `_.reduceRight` for arrays without support for + * iteratee shorthands. + * + * @private + * @param {Array} [array] The array to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @param {*} [accumulator] The initial value. + * @param {boolean} [initAccum] Specify using the last element of `array` as + * the initial value. + * @returns {*} Returns the accumulated value. + */ + function arrayReduceRight(array, iteratee, accumulator, initAccum) { + var length = array ? array.length : 0; + if (initAccum && length) { + accumulator = array[--length]; + } + while (length--) { + accumulator = iteratee(accumulator, array[length], length, array); + } + return accumulator; + } + + /** + * A specialized version of `_.some` for arrays without support for iteratee + * shorthands. + * + * @private + * @param {Array} [array] The array to iterate over. + * @param {Function} predicate The function invoked per iteration. + * @returns {boolean} Returns `true` if any element passes the predicate check, + * else `false`. + */ + function arraySome(array, predicate) { + var index = -1, + length = array ? array.length : 0; + + while (++index < length) { + if (predicate(array[index], index, array)) { + return true; + } + } + return false; + } + + /** + * Gets the size of an ASCII `string`. + * + * @private + * @param {string} string The string inspect. + * @returns {number} Returns the string size. + */ + var asciiSize = baseProperty('length'); + + /** + * Converts an ASCII `string` to an array. + * + * @private + * @param {string} string The string to convert. + * @returns {Array} Returns the converted array. + */ + function asciiToArray(string) { + return string.split(''); + } + + /** + * Splits an ASCII `string` into an array of its words. + * + * @private + * @param {string} The string to inspect. + * @returns {Array} Returns the words of `string`. + */ + function asciiWords(string) { + return string.match(reAsciiWord) || []; + } + + /** + * The base implementation of methods like `_.findKey` and `_.findLastKey`, + * without support for iteratee shorthands, which iterates over `collection` + * using `eachFunc`. + * + * @private + * @param {Array|Object} collection The collection to inspect. + * @param {Function} predicate The function invoked per iteration. + * @param {Function} eachFunc The function to iterate over `collection`. + * @returns {*} Returns the found element or its key, else `undefined`. + */ + function baseFindKey(collection, predicate, eachFunc) { + var result; + eachFunc(collection, function(value, key, collection) { + if (predicate(value, key, collection)) { + result = key; + return false; + } + }); + return result; + } + + /** + * The base implementation of `_.findIndex` and `_.findLastIndex` without + * support for iteratee shorthands. + * + * @private + * @param {Array} array The array to inspect. + * @param {Function} predicate The function invoked per iteration. + * @param {number} fromIndex The index to search from. + * @param {boolean} [fromRight] Specify iterating from right to left. + * @returns {number} Returns the index of the matched value, else `-1`. + */ + function baseFindIndex(array, predicate, fromIndex, fromRight) { + var length = array.length, + index = fromIndex + (fromRight ? 1 : -1); + + while ((fromRight ? index-- : ++index < length)) { + if (predicate(array[index], index, array)) { + return index; + } + } + return -1; + } + + /** + * The base implementation of `_.indexOf` without `fromIndex` bounds checks. + * + * @private + * @param {Array} array The array to inspect. + * @param {*} value The value to search for. + * @param {number} fromIndex The index to search from. + * @returns {number} Returns the index of the matched value, else `-1`. + */ + function baseIndexOf(array, value, fromIndex) { + return value === value + ? strictIndexOf(array, value, fromIndex) + : baseFindIndex(array, baseIsNaN, fromIndex); + } + + /** + * This function is like `baseIndexOf` except that it accepts a comparator. + * + * @private + * @param {Array} array The array to inspect. + * @param {*} value The value to search for. + * @param {number} fromIndex The index to search from. + * @param {Function} comparator The comparator invoked per element. + * @returns {number} Returns the index of the matched value, else `-1`. + */ + function baseIndexOfWith(array, value, fromIndex, comparator) { + var index = fromIndex - 1, + length = array.length; + + while (++index < length) { + if (comparator(array[index], value)) { + return index; + } + } + return -1; + } + + /** + * The base implementation of `_.isNaN` without support for number objects. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is `NaN`, else `false`. + */ + function baseIsNaN(value) { + return value !== value; + } + + /** + * The base implementation of `_.mean` and `_.meanBy` without support for + * iteratee shorthands. + * + * @private + * @param {Array} array The array to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @returns {number} Returns the mean. + */ + function baseMean(array, iteratee) { + var length = array ? array.length : 0; + return length ? (baseSum(array, iteratee) / length) : NAN; + } + + /** + * The base implementation of `_.property` without support for deep paths. + * + * @private + * @param {string} key The key of the property to get. + * @returns {Function} Returns the new accessor function. + */ + function baseProperty(key) { + return function(object) { + return object == null ? undefined : object[key]; + }; + } + + /** + * The base implementation of `_.propertyOf` without support for deep paths. + * + * @private + * @param {Object} object The object to query. + * @returns {Function} Returns the new accessor function. + */ + function basePropertyOf(object) { + return function(key) { + return object == null ? undefined : object[key]; + }; + } + + /** + * The base implementation of `_.reduce` and `_.reduceRight`, without support + * for iteratee shorthands, which iterates over `collection` using `eachFunc`. + * + * @private + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @param {*} accumulator The initial value. + * @param {boolean} initAccum Specify using the first or last element of + * `collection` as the initial value. + * @param {Function} eachFunc The function to iterate over `collection`. + * @returns {*} Returns the accumulated value. + */ + function baseReduce(collection, iteratee, accumulator, initAccum, eachFunc) { + eachFunc(collection, function(value, index, collection) { + accumulator = initAccum + ? (initAccum = false, value) + : iteratee(accumulator, value, index, collection); + }); + return accumulator; + } + + /** + * The base implementation of `_.sortBy` which uses `comparer` to define the + * sort order of `array` and replaces criteria objects with their corresponding + * values. + * + * @private + * @param {Array} array The array to sort. + * @param {Function} comparer The function to define sort order. + * @returns {Array} Returns `array`. + */ + function baseSortBy(array, comparer) { + var length = array.length; + + array.sort(comparer); + while (length--) { + array[length] = array[length].value; + } + return array; + } + + /** + * The base implementation of `_.sum` and `_.sumBy` without support for + * iteratee shorthands. + * + * @private + * @param {Array} array The array to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @returns {number} Returns the sum. + */ + function baseSum(array, iteratee) { + var result, + index = -1, + length = array.length; + + while (++index < length) { + var current = iteratee(array[index]); + if (current !== undefined) { + result = result === undefined ? current : (result + current); + } + } + return result; + } + + /** + * The base implementation of `_.times` without support for iteratee shorthands + * or max array length checks. + * + * @private + * @param {number} n The number of times to invoke `iteratee`. + * @param {Function} iteratee The function invoked per iteration. + * @returns {Array} Returns the array of results. + */ + function baseTimes(n, iteratee) { + var index = -1, + result = Array(n); + + while (++index < n) { + result[index] = iteratee(index); + } + return result; + } + + /** + * The base implementation of `_.toPairs` and `_.toPairsIn` which creates an array + * of key-value pairs for `object` corresponding to the property names of `props`. + * + * @private + * @param {Object} object The object to query. + * @param {Array} props The property names to get values for. + * @returns {Object} Returns the key-value pairs. + */ + function baseToPairs(object, props) { + return arrayMap(props, function(key) { + return [key, object[key]]; + }); + } + + /** + * The base implementation of `_.unary` without support for storing metadata. + * + * @private + * @param {Function} func The function to cap arguments for. + * @returns {Function} Returns the new capped function. + */ + function baseUnary(func) { + return function(value) { + return func(value); + }; + } + + /** + * The base implementation of `_.values` and `_.valuesIn` which creates an + * array of `object` property values corresponding to the property names + * of `props`. + * + * @private + * @param {Object} object The object to query. + * @param {Array} props The property names to get values for. + * @returns {Object} Returns the array of property values. + */ + function baseValues(object, props) { + return arrayMap(props, function(key) { + return object[key]; + }); + } + + /** + * Checks if a `cache` value for `key` exists. + * + * @private + * @param {Object} cache The cache to query. + * @param {string} key The key of the entry to check. + * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`. + */ + function cacheHas(cache, key) { + return cache.has(key); + } + + /** + * Used by `_.trim` and `_.trimStart` to get the index of the first string symbol + * that is not found in the character symbols. + * + * @private + * @param {Array} strSymbols The string symbols to inspect. + * @param {Array} chrSymbols The character symbols to find. + * @returns {number} Returns the index of the first unmatched string symbol. + */ + function charsStartIndex(strSymbols, chrSymbols) { + var index = -1, + length = strSymbols.length; + + while (++index < length && baseIndexOf(chrSymbols, strSymbols[index], 0) > -1) {} + return index; + } + + /** + * Used by `_.trim` and `_.trimEnd` to get the index of the last string symbol + * that is not found in the character symbols. + * + * @private + * @param {Array} strSymbols The string symbols to inspect. + * @param {Array} chrSymbols The character symbols to find. + * @returns {number} Returns the index of the last unmatched string symbol. + */ + function charsEndIndex(strSymbols, chrSymbols) { + var index = strSymbols.length; + + while (index-- && baseIndexOf(chrSymbols, strSymbols[index], 0) > -1) {} + return index; + } + + /** + * Gets the number of `placeholder` occurrences in `array`. + * + * @private + * @param {Array} array The array to inspect. + * @param {*} placeholder The placeholder to search for. + * @returns {number} Returns the placeholder count. + */ + function countHolders(array, placeholder) { + var length = array.length, + result = 0; + + while (length--) { + if (array[length] === placeholder) { + ++result; + } + } + return result; + } + + /** + * Used by `_.deburr` to convert Latin-1 Supplement and Latin Extended-A + * letters to basic Latin letters. + * + * @private + * @param {string} letter The matched letter to deburr. + * @returns {string} Returns the deburred letter. + */ + var deburrLetter = basePropertyOf(deburredLetters); + + /** + * Used by `_.escape` to convert characters to HTML entities. + * + * @private + * @param {string} chr The matched character to escape. + * @returns {string} Returns the escaped character. + */ + var escapeHtmlChar = basePropertyOf(htmlEscapes); + + /** + * Used by `_.template` to escape characters for inclusion in compiled string literals. + * + * @private + * @param {string} chr The matched character to escape. + * @returns {string} Returns the escaped character. + */ + function escapeStringChar(chr) { + return '\\' + stringEscapes[chr]; + } + + /** + * Gets the value at `key` of `object`. + * + * @private + * @param {Object} [object] The object to query. + * @param {string} key The key of the property to get. + * @returns {*} Returns the property value. + */ + function getValue(object, key) { + return object == null ? undefined : object[key]; + } + + /** + * Checks if `string` contains Unicode symbols. + * + * @private + * @param {string} string The string to inspect. + * @returns {boolean} Returns `true` if a symbol is found, else `false`. + */ + function hasUnicode(string) { + return reHasUnicode.test(string); + } + + /** + * Checks if `string` contains a word composed of Unicode symbols. + * + * @private + * @param {string} string The string to inspect. + * @returns {boolean} Returns `true` if a word is found, else `false`. + */ + function hasUnicodeWord(string) { + return reHasUnicodeWord.test(string); + } + + /** + * Converts `iterator` to an array. + * + * @private + * @param {Object} iterator The iterator to convert. + * @returns {Array} Returns the converted array. + */ + function iteratorToArray(iterator) { + var data, + result = []; + + while (!(data = iterator.next()).done) { + result.push(data.value); + } + return result; + } + + /** + * Converts `map` to its key-value pairs. + * + * @private + * @param {Object} map The map to convert. + * @returns {Array} Returns the key-value pairs. + */ + function mapToArray(map) { + var index = -1, + result = Array(map.size); + + map.forEach(function(value, key) { + result[++index] = [key, value]; + }); + return result; + } + + /** + * Creates a unary function that invokes `func` with its argument transformed. + * + * @private + * @param {Function} func The function to wrap. + * @param {Function} transform The argument transform. + * @returns {Function} Returns the new function. + */ + function overArg(func, transform) { + return function(arg) { + return func(transform(arg)); + }; + } + + /** + * Replaces all `placeholder` elements in `array` with an internal placeholder + * and returns an array of their indexes. + * + * @private + * @param {Array} array The array to modify. + * @param {*} placeholder The placeholder to replace. + * @returns {Array} Returns the new array of placeholder indexes. + */ + function replaceHolders(array, placeholder) { + var index = -1, + length = array.length, + resIndex = 0, + result = []; + + while (++index < length) { + var value = array[index]; + if (value === placeholder || value === PLACEHOLDER) { + array[index] = PLACEHOLDER; + result[resIndex++] = index; + } + } + return result; + } + + /** + * Converts `set` to an array of its values. + * + * @private + * @param {Object} set The set to convert. + * @returns {Array} Returns the values. + */ + function setToArray(set) { + var index = -1, + result = Array(set.size); + + set.forEach(function(value) { + result[++index] = value; + }); + return result; + } + + /** + * Converts `set` to its value-value pairs. + * + * @private + * @param {Object} set The set to convert. + * @returns {Array} Returns the value-value pairs. + */ + function setToPairs(set) { + var index = -1, + result = Array(set.size); + + set.forEach(function(value) { + result[++index] = [value, value]; + }); + return result; + } + + /** + * A specialized version of `_.indexOf` which performs strict equality + * comparisons of values, i.e. `===`. + * + * @private + * @param {Array} array The array to inspect. + * @param {*} value The value to search for. + * @param {number} fromIndex The index to search from. + * @returns {number} Returns the index of the matched value, else `-1`. + */ + function strictIndexOf(array, value, fromIndex) { + var index = fromIndex - 1, + length = array.length; + + while (++index < length) { + if (array[index] === value) { + return index; + } + } + return -1; + } + + /** + * A specialized version of `_.lastIndexOf` which performs strict equality + * comparisons of values, i.e. `===`. + * + * @private + * @param {Array} array The array to inspect. + * @param {*} value The value to search for. + * @param {number} fromIndex The index to search from. + * @returns {number} Returns the index of the matched value, else `-1`. + */ + function strictLastIndexOf(array, value, fromIndex) { + var index = fromIndex + 1; + while (index--) { + if (array[index] === value) { + return index; + } + } + return index; + } + + /** + * Gets the number of symbols in `string`. + * + * @private + * @param {string} string The string to inspect. + * @returns {number} Returns the string size. + */ + function stringSize(string) { + return hasUnicode(string) + ? unicodeSize(string) + : asciiSize(string); + } + + /** + * Converts `string` to an array. + * + * @private + * @param {string} string The string to convert. + * @returns {Array} Returns the converted array. + */ + function stringToArray(string) { + return hasUnicode(string) + ? unicodeToArray(string) + : asciiToArray(string); + } + + /** + * Used by `_.unescape` to convert HTML entities to characters. + * + * @private + * @param {string} chr The matched character to unescape. + * @returns {string} Returns the unescaped character. + */ + var unescapeHtmlChar = basePropertyOf(htmlUnescapes); + + /** + * Gets the size of a Unicode `string`. + * + * @private + * @param {string} string The string inspect. + * @returns {number} Returns the string size. + */ + function unicodeSize(string) { + var result = reUnicode.lastIndex = 0; + while (reUnicode.test(string)) { + ++result; + } + return result; + } + + /** + * Converts a Unicode `string` to an array. + * + * @private + * @param {string} string The string to convert. + * @returns {Array} Returns the converted array. + */ + function unicodeToArray(string) { + return string.match(reUnicode) || []; + } + + /** + * Splits a Unicode `string` into an array of its words. + * + * @private + * @param {string} The string to inspect. + * @returns {Array} Returns the words of `string`. + */ + function unicodeWords(string) { + return string.match(reUnicodeWord) || []; + } + + /*--------------------------------------------------------------------------*/ + + /** + * Create a new pristine `lodash` function using the `context` object. + * + * @static + * @memberOf _ + * @since 1.1.0 + * @category Util + * @param {Object} [context=root] The context object. + * @returns {Function} Returns a new `lodash` function. + * @example + * + * _.mixin({ 'foo': _.constant('foo') }); + * + * var lodash = _.runInContext(); + * lodash.mixin({ 'bar': lodash.constant('bar') }); + * + * _.isFunction(_.foo); + * // => true + * _.isFunction(_.bar); + * // => false + * + * lodash.isFunction(lodash.foo); + * // => false + * lodash.isFunction(lodash.bar); + * // => true + * + * // Create a suped-up `defer` in Node.js. + * var defer = _.runInContext({ 'setTimeout': setImmediate }).defer; + */ + var runInContext = (function runInContext(context) { + context = context ? _.defaults(root.Object(), context, _.pick(root, contextProps)) : root; + + /** Built-in constructor references. */ + var Array = context.Array, + Date = context.Date, + Error = context.Error, + Function = context.Function, + Math = context.Math, + Object = context.Object, + RegExp = context.RegExp, + String = context.String, + TypeError = context.TypeError; + + /** Used for built-in method references. */ + var arrayProto = Array.prototype, + funcProto = Function.prototype, + objectProto = Object.prototype; + + /** Used to detect overreaching core-js shims. */ + var coreJsData = context['__core-js_shared__']; + + /** Used to detect methods masquerading as native. */ + var maskSrcKey = (function() { + var uid = /[^.]+$/.exec(coreJsData && coreJsData.keys && coreJsData.keys.IE_PROTO || ''); + return uid ? ('Symbol(src)_1.' + uid) : ''; + }()); + + /** Used to resolve the decompiled source of functions. */ + var funcToString = funcProto.toString; + + /** Used to check objects for own properties. */ + var hasOwnProperty = objectProto.hasOwnProperty; + + /** Used to generate unique IDs. */ + var idCounter = 0; + + /** Used to infer the `Object` constructor. */ + var objectCtorString = funcToString.call(Object); + + /** + * Used to resolve the + * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring) + * of values. + */ + var objectToString = objectProto.toString; + + /** Used to restore the original `_` reference in `_.noConflict`. */ + var oldDash = root._; + + /** Used to detect if a method is native. */ + var reIsNative = RegExp('^' + + funcToString.call(hasOwnProperty).replace(reRegExpChar, '\\$&') + .replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g, '$1.*?') + '$' + ); + + /** Built-in value references. */ + var Buffer = moduleExports ? context.Buffer : undefined, + Symbol = context.Symbol, + Uint8Array = context.Uint8Array, + allocUnsafe = Buffer ? Buffer.allocUnsafe : undefined, + getPrototype = overArg(Object.getPrototypeOf, Object), + iteratorSymbol = Symbol ? Symbol.iterator : undefined, + objectCreate = Object.create, + propertyIsEnumerable = objectProto.propertyIsEnumerable, + splice = arrayProto.splice, + spreadableSymbol = Symbol ? Symbol.isConcatSpreadable : undefined; + + var defineProperty = (function() { + try { + var func = getNative(Object, 'defineProperty'); + func({}, '', {}); + return func; + } catch (e) {} + }()); + + /** Mocked built-ins. */ + var ctxClearTimeout = context.clearTimeout !== root.clearTimeout && context.clearTimeout, + ctxNow = Date && Date.now !== root.Date.now && Date.now, + ctxSetTimeout = context.setTimeout !== root.setTimeout && context.setTimeout; + + /* Built-in method references for those with the same name as other `lodash` methods. */ + var nativeCeil = Math.ceil, + nativeFloor = Math.floor, + nativeGetSymbols = Object.getOwnPropertySymbols, + nativeIsBuffer = Buffer ? Buffer.isBuffer : undefined, + nativeIsFinite = context.isFinite, + nativeJoin = arrayProto.join, + nativeKeys = overArg(Object.keys, Object), + nativeMax = Math.max, + nativeMin = Math.min, + nativeNow = Date.now, + nativeParseInt = context.parseInt, + nativeRandom = Math.random, + nativeReverse = arrayProto.reverse; + + /* Built-in method references that are verified to be native. */ + var DataView = getNative(context, 'DataView'), + Map = getNative(context, 'Map'), + Promise = getNative(context, 'Promise'), + Set = getNative(context, 'Set'), + WeakMap = getNative(context, 'WeakMap'), + nativeCreate = getNative(Object, 'create'); + + /** Used to store function metadata. */ + var metaMap = WeakMap && new WeakMap; + + /** Used to lookup unminified function names. */ + var realNames = {}; + + /** Used to detect maps, sets, and weakmaps. */ + var dataViewCtorString = toSource(DataView), + mapCtorString = toSource(Map), + promiseCtorString = toSource(Promise), + setCtorString = toSource(Set), + weakMapCtorString = toSource(WeakMap); + + /** Used to convert symbols to primitives and strings. */ + var symbolProto = Symbol ? Symbol.prototype : undefined, + symbolValueOf = symbolProto ? symbolProto.valueOf : undefined, + symbolToString = symbolProto ? symbolProto.toString : undefined; + + /*------------------------------------------------------------------------*/ + + /** + * Creates a `lodash` object which wraps `value` to enable implicit method + * chain sequences. Methods that operate on and return arrays, collections, + * and functions can be chained together. Methods that retrieve a single value + * or may return a primitive value will automatically end the chain sequence + * and return the unwrapped value. Otherwise, the value must be unwrapped + * with `_#value`. + * + * Explicit chain sequences, which must be unwrapped with `_#value`, may be + * enabled using `_.chain`. + * + * The execution of chained methods is lazy, that is, it's deferred until + * `_#value` is implicitly or explicitly called. + * + * Lazy evaluation allows several methods to support shortcut fusion. + * Shortcut fusion is an optimization to merge iteratee calls; this avoids + * the creation of intermediate arrays and can greatly reduce the number of + * iteratee executions. Sections of a chain sequence qualify for shortcut + * fusion if the section is applied to an array of at least `200` elements + * and any iteratees accept only one argument. The heuristic for whether a + * section qualifies for shortcut fusion is subject to change. + * + * Chaining is supported in custom builds as long as the `_#value` method is + * directly or indirectly included in the build. + * + * In addition to lodash methods, wrappers have `Array` and `String` methods. + * + * The wrapper `Array` methods are: + * `concat`, `join`, `pop`, `push`, `shift`, `sort`, `splice`, and `unshift` + * + * The wrapper `String` methods are: + * `replace` and `split` + * + * The wrapper methods that support shortcut fusion are: + * `at`, `compact`, `drop`, `dropRight`, `dropWhile`, `filter`, `find`, + * `findLast`, `head`, `initial`, `last`, `map`, `reject`, `reverse`, `slice`, + * `tail`, `take`, `takeRight`, `takeRightWhile`, `takeWhile`, and `toArray` + * + * The chainable wrapper methods are: + * `after`, `ary`, `assign`, `assignIn`, `assignInWith`, `assignWith`, `at`, + * `before`, `bind`, `bindAll`, `bindKey`, `castArray`, `chain`, `chunk`, + * `commit`, `compact`, `concat`, `conforms`, `constant`, `countBy`, `create`, + * `curry`, `debounce`, `defaults`, `defaultsDeep`, `defer`, `delay`, + * `difference`, `differenceBy`, `differenceWith`, `drop`, `dropRight`, + * `dropRightWhile`, `dropWhile`, `extend`, `extendWith`, `fill`, `filter`, + * `flatMap`, `flatMapDeep`, `flatMapDepth`, `flatten`, `flattenDeep`, + * `flattenDepth`, `flip`, `flow`, `flowRight`, `fromPairs`, `functions`, + * `functionsIn`, `groupBy`, `initial`, `intersection`, `intersectionBy`, + * `intersectionWith`, `invert`, `invertBy`, `invokeMap`, `iteratee`, `keyBy`, + * `keys`, `keysIn`, `map`, `mapKeys`, `mapValues`, `matches`, `matchesProperty`, + * `memoize`, `merge`, `mergeWith`, `method`, `methodOf`, `mixin`, `negate`, + * `nthArg`, `omit`, `omitBy`, `once`, `orderBy`, `over`, `overArgs`, + * `overEvery`, `overSome`, `partial`, `partialRight`, `partition`, `pick`, + * `pickBy`, `plant`, `property`, `propertyOf`, `pull`, `pullAll`, `pullAllBy`, + * `pullAllWith`, `pullAt`, `push`, `range`, `rangeRight`, `rearg`, `reject`, + * `remove`, `rest`, `reverse`, `sampleSize`, `set`, `setWith`, `shuffle`, + * `slice`, `sort`, `sortBy`, `splice`, `spread`, `tail`, `take`, `takeRight`, + * `takeRightWhile`, `takeWhile`, `tap`, `throttle`, `thru`, `toArray`, + * `toPairs`, `toPairsIn`, `toPath`, `toPlainObject`, `transform`, `unary`, + * `union`, `unionBy`, `unionWith`, `uniq`, `uniqBy`, `uniqWith`, `unset`, + * `unshift`, `unzip`, `unzipWith`, `update`, `updateWith`, `values`, + * `valuesIn`, `without`, `wrap`, `xor`, `xorBy`, `xorWith`, `zip`, + * `zipObject`, `zipObjectDeep`, and `zipWith` + * + * The wrapper methods that are **not** chainable by default are: + * `add`, `attempt`, `camelCase`, `capitalize`, `ceil`, `clamp`, `clone`, + * `cloneDeep`, `cloneDeepWith`, `cloneWith`, `conformsTo`, `deburr`, + * `defaultTo`, `divide`, `each`, `eachRight`, `endsWith`, `eq`, `escape`, + * `escapeRegExp`, `every`, `find`, `findIndex`, `findKey`, `findLast`, + * `findLastIndex`, `findLastKey`, `first`, `floor`, `forEach`, `forEachRight`, + * `forIn`, `forInRight`, `forOwn`, `forOwnRight`, `get`, `gt`, `gte`, `has`, + * `hasIn`, `head`, `identity`, `includes`, `indexOf`, `inRange`, `invoke`, + * `isArguments`, `isArray`, `isArrayBuffer`, `isArrayLike`, `isArrayLikeObject`, + * `isBoolean`, `isBuffer`, `isDate`, `isElement`, `isEmpty`, `isEqual`, + * `isEqualWith`, `isError`, `isFinite`, `isFunction`, `isInteger`, `isLength`, + * `isMap`, `isMatch`, `isMatchWith`, `isNaN`, `isNative`, `isNil`, `isNull`, + * `isNumber`, `isObject`, `isObjectLike`, `isPlainObject`, `isRegExp`, + * `isSafeInteger`, `isSet`, `isString`, `isUndefined`, `isTypedArray`, + * `isWeakMap`, `isWeakSet`, `join`, `kebabCase`, `last`, `lastIndexOf`, + * `lowerCase`, `lowerFirst`, `lt`, `lte`, `max`, `maxBy`, `mean`, `meanBy`, + * `min`, `minBy`, `multiply`, `noConflict`, `noop`, `now`, `nth`, `pad`, + * `padEnd`, `padStart`, `parseInt`, `pop`, `random`, `reduce`, `reduceRight`, + * `repeat`, `result`, `round`, `runInContext`, `sample`, `shift`, `size`, + * `snakeCase`, `some`, `sortedIndex`, `sortedIndexBy`, `sortedLastIndex`, + * `sortedLastIndexBy`, `startCase`, `startsWith`, `stubArray`, `stubFalse`, + * `stubObject`, `stubString`, `stubTrue`, `subtract`, `sum`, `sumBy`, + * `template`, `times`, `toFinite`, `toInteger`, `toJSON`, `toLength`, + * `toLower`, `toNumber`, `toSafeInteger`, `toString`, `toUpper`, `trim`, + * `trimEnd`, `trimStart`, `truncate`, `unescape`, `uniqueId`, `upperCase`, + * `upperFirst`, `value`, and `words` + * + * @name _ + * @constructor + * @category Seq + * @param {*} value The value to wrap in a `lodash` instance. + * @returns {Object} Returns the new `lodash` wrapper instance. + * @example + * + * function square(n) { + * return n * n; + * } + * + * var wrapped = _([1, 2, 3]); + * + * // Returns an unwrapped value. + * wrapped.reduce(_.add); + * // => 6 + * + * // Returns a wrapped value. + * var squares = wrapped.map(square); + * + * _.isArray(squares); + * // => false + * + * _.isArray(squares.value()); + * // => true + */ + function lodash(value) { + if (isObjectLike(value) && !isArray(value) && !(value instanceof LazyWrapper)) { + if (value instanceof LodashWrapper) { + return value; + } + if (hasOwnProperty.call(value, '__wrapped__')) { + return wrapperClone(value); + } + } + return new LodashWrapper(value); + } + + /** + * The base implementation of `_.create` without support for assigning + * properties to the created object. + * + * @private + * @param {Object} proto The object to inherit from. + * @returns {Object} Returns the new object. + */ + var baseCreate = (function() { + function object() {} + return function(proto) { + if (!isObject(proto)) { + return {}; + } + if (objectCreate) { + return objectCreate(proto); + } + object.prototype = proto; + var result = new object; + object.prototype = undefined; + return result; + }; + }()); + + /** + * The function whose prototype chain sequence wrappers inherit from. + * + * @private + */ + function baseLodash() { + // No operation performed. + } + + /** + * The base constructor for creating `lodash` wrapper objects. + * + * @private + * @param {*} value The value to wrap. + * @param {boolean} [chainAll] Enable explicit method chain sequences. + */ + function LodashWrapper(value, chainAll) { + this.__wrapped__ = value; + this.__actions__ = []; + this.__chain__ = !!chainAll; + this.__index__ = 0; + this.__values__ = undefined; + } + + /** + * By default, the template delimiters used by lodash are like those in + * embedded Ruby (ERB). Change the following template settings to use + * alternative delimiters. + * + * @static + * @memberOf _ + * @type {Object} + */ + lodash.templateSettings = { + + /** + * Used to detect `data` property values to be HTML-escaped. + * + * @memberOf _.templateSettings + * @type {RegExp} + */ + 'escape': reEscape, + + /** + * Used to detect code to be evaluated. + * + * @memberOf _.templateSettings + * @type {RegExp} + */ + 'evaluate': reEvaluate, + + /** + * Used to detect `data` property values to inject. + * + * @memberOf _.templateSettings + * @type {RegExp} + */ + 'interpolate': reInterpolate, + + /** + * Used to reference the data object in the template text. + * + * @memberOf _.templateSettings + * @type {string} + */ + 'variable': '', + + /** + * Used to import variables into the compiled template. + * + * @memberOf _.templateSettings + * @type {Object} + */ + 'imports': { + + /** + * A reference to the `lodash` function. + * + * @memberOf _.templateSettings.imports + * @type {Function} + */ + '_': lodash + } + }; + + // Ensure wrappers are instances of `baseLodash`. + lodash.prototype = baseLodash.prototype; + lodash.prototype.constructor = lodash; + + LodashWrapper.prototype = baseCreate(baseLodash.prototype); + LodashWrapper.prototype.constructor = LodashWrapper; + + /*------------------------------------------------------------------------*/ + + /** + * Creates a lazy wrapper object which wraps `value` to enable lazy evaluation. + * + * @private + * @constructor + * @param {*} value The value to wrap. + */ + function LazyWrapper(value) { + this.__wrapped__ = value; + this.__actions__ = []; + this.__dir__ = 1; + this.__filtered__ = false; + this.__iteratees__ = []; + this.__takeCount__ = MAX_ARRAY_LENGTH; + this.__views__ = []; + } + + /** + * Creates a clone of the lazy wrapper object. + * + * @private + * @name clone + * @memberOf LazyWrapper + * @returns {Object} Returns the cloned `LazyWrapper` object. + */ + function lazyClone() { + var result = new LazyWrapper(this.__wrapped__); + result.__actions__ = copyArray(this.__actions__); + result.__dir__ = this.__dir__; + result.__filtered__ = this.__filtered__; + result.__iteratees__ = copyArray(this.__iteratees__); + result.__takeCount__ = this.__takeCount__; + result.__views__ = copyArray(this.__views__); + return result; + } + + /** + * Reverses the direction of lazy iteration. + * + * @private + * @name reverse + * @memberOf LazyWrapper + * @returns {Object} Returns the new reversed `LazyWrapper` object. + */ + function lazyReverse() { + if (this.__filtered__) { + var result = new LazyWrapper(this); + result.__dir__ = -1; + result.__filtered__ = true; + } else { + result = this.clone(); + result.__dir__ *= -1; + } + return result; + } + + /** + * Extracts the unwrapped value from its lazy wrapper. + * + * @private + * @name value + * @memberOf LazyWrapper + * @returns {*} Returns the unwrapped value. + */ + function lazyValue() { + var array = this.__wrapped__.value(), + dir = this.__dir__, + isArr = isArray(array), + isRight = dir < 0, + arrLength = isArr ? array.length : 0, + view = getView(0, arrLength, this.__views__), + start = view.start, + end = view.end, + length = end - start, + index = isRight ? end : (start - 1), + iteratees = this.__iteratees__, + iterLength = iteratees.length, + resIndex = 0, + takeCount = nativeMin(length, this.__takeCount__); + + if (!isArr || arrLength < LARGE_ARRAY_SIZE || + (arrLength == length && takeCount == length)) { + return baseWrapperValue(array, this.__actions__); + } + var result = []; + + outer: + while (length-- && resIndex < takeCount) { + index += dir; + + var iterIndex = -1, + value = array[index]; + + while (++iterIndex < iterLength) { + var data = iteratees[iterIndex], + iteratee = data.iteratee, + type = data.type, + computed = iteratee(value); + + if (type == LAZY_MAP_FLAG) { + value = computed; + } else if (!computed) { + if (type == LAZY_FILTER_FLAG) { + continue outer; + } else { + break outer; + } + } + } + result[resIndex++] = value; + } + return result; + } + + // Ensure `LazyWrapper` is an instance of `baseLodash`. + LazyWrapper.prototype = baseCreate(baseLodash.prototype); + LazyWrapper.prototype.constructor = LazyWrapper; + + /*------------------------------------------------------------------------*/ + + /** + * Creates a hash object. + * + * @private + * @constructor + * @param {Array} [entries] The key-value pairs to cache. + */ + function Hash(entries) { + var index = -1, + length = entries ? entries.length : 0; + + this.clear(); + while (++index < length) { + var entry = entries[index]; + this.set(entry[0], entry[1]); + } + } + + /** + * Removes all key-value entries from the hash. + * + * @private + * @name clear + * @memberOf Hash + */ + function hashClear() { + this.__data__ = nativeCreate ? nativeCreate(null) : {}; + this.size = 0; + } + + /** + * Removes `key` and its value from the hash. + * + * @private + * @name delete + * @memberOf Hash + * @param {Object} hash The hash to modify. + * @param {string} key The key of the value to remove. + * @returns {boolean} Returns `true` if the entry was removed, else `false`. + */ + function hashDelete(key) { + var result = this.has(key) && delete this.__data__[key]; + this.size -= result ? 1 : 0; + return result; + } + + /** + * Gets the hash value for `key`. + * + * @private + * @name get + * @memberOf Hash + * @param {string} key The key of the value to get. + * @returns {*} Returns the entry value. + */ + function hashGet(key) { + var data = this.__data__; + if (nativeCreate) { + var result = data[key]; + return result === HASH_UNDEFINED ? undefined : result; + } + return hasOwnProperty.call(data, key) ? data[key] : undefined; + } + + /** + * Checks if a hash value for `key` exists. + * + * @private + * @name has + * @memberOf Hash + * @param {string} key The key of the entry to check. + * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`. + */ + function hashHas(key) { + var data = this.__data__; + return nativeCreate ? data[key] !== undefined : hasOwnProperty.call(data, key); + } + + /** + * Sets the hash `key` to `value`. + * + * @private + * @name set + * @memberOf Hash + * @param {string} key The key of the value to set. + * @param {*} value The value to set. + * @returns {Object} Returns the hash instance. + */ + function hashSet(key, value) { + var data = this.__data__; + this.size += this.has(key) ? 0 : 1; + data[key] = (nativeCreate && value === undefined) ? HASH_UNDEFINED : value; + return this; + } + + // Add methods to `Hash`. + Hash.prototype.clear = hashClear; + Hash.prototype['delete'] = hashDelete; + Hash.prototype.get = hashGet; + Hash.prototype.has = hashHas; + Hash.prototype.set = hashSet; + + /*------------------------------------------------------------------------*/ + + /** + * Creates an list cache object. + * + * @private + * @constructor + * @param {Array} [entries] The key-value pairs to cache. + */ + function ListCache(entries) { + var index = -1, + length = entries ? entries.length : 0; + + this.clear(); + while (++index < length) { + var entry = entries[index]; + this.set(entry[0], entry[1]); + } + } + + /** + * Removes all key-value entries from the list cache. + * + * @private + * @name clear + * @memberOf ListCache + */ + function listCacheClear() { + this.__data__ = []; + this.size = 0; + } + + /** + * Removes `key` and its value from the list cache. + * + * @private + * @name delete + * @memberOf ListCache + * @param {string} key The key of the value to remove. + * @returns {boolean} Returns `true` if the entry was removed, else `false`. + */ + function listCacheDelete(key) { + var data = this.__data__, + index = assocIndexOf(data, key); + + if (index < 0) { + return false; + } + var lastIndex = data.length - 1; + if (index == lastIndex) { + data.pop(); + } else { + splice.call(data, index, 1); + } + --this.size; + return true; + } + + /** + * Gets the list cache value for `key`. + * + * @private + * @name get + * @memberOf ListCache + * @param {string} key The key of the value to get. + * @returns {*} Returns the entry value. + */ + function listCacheGet(key) { + var data = this.__data__, + index = assocIndexOf(data, key); + + return index < 0 ? undefined : data[index][1]; + } + + /** + * Checks if a list cache value for `key` exists. + * + * @private + * @name has + * @memberOf ListCache + * @param {string} key The key of the entry to check. + * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`. + */ + function listCacheHas(key) { + return assocIndexOf(this.__data__, key) > -1; + } + + /** + * Sets the list cache `key` to `value`. + * + * @private + * @name set + * @memberOf ListCache + * @param {string} key The key of the value to set. + * @param {*} value The value to set. + * @returns {Object} Returns the list cache instance. + */ + function listCacheSet(key, value) { + var data = this.__data__, + index = assocIndexOf(data, key); + + if (index < 0) { + ++this.size; + data.push([key, value]); + } else { + data[index][1] = value; + } + return this; + } + + // Add methods to `ListCache`. + ListCache.prototype.clear = listCacheClear; + ListCache.prototype['delete'] = listCacheDelete; + ListCache.prototype.get = listCacheGet; + ListCache.prototype.has = listCacheHas; + ListCache.prototype.set = listCacheSet; + + /*------------------------------------------------------------------------*/ + + /** + * Creates a map cache object to store key-value pairs. + * + * @private + * @constructor + * @param {Array} [entries] The key-value pairs to cache. + */ + function MapCache(entries) { + var index = -1, + length = entries ? entries.length : 0; + + this.clear(); + while (++index < length) { + var entry = entries[index]; + this.set(entry[0], entry[1]); + } + } + + /** + * Removes all key-value entries from the map. + * + * @private + * @name clear + * @memberOf MapCache + */ + function mapCacheClear() { + this.size = 0; + this.__data__ = { + 'hash': new Hash, + 'map': new (Map || ListCache), + 'string': new Hash + }; + } + + /** + * Removes `key` and its value from the map. + * + * @private + * @name delete + * @memberOf MapCache + * @param {string} key The key of the value to remove. + * @returns {boolean} Returns `true` if the entry was removed, else `false`. + */ + function mapCacheDelete(key) { + var result = getMapData(this, key)['delete'](key); + this.size -= result ? 1 : 0; + return result; + } + + /** + * Gets the map value for `key`. + * + * @private + * @name get + * @memberOf MapCache + * @param {string} key The key of the value to get. + * @returns {*} Returns the entry value. + */ + function mapCacheGet(key) { + return getMapData(this, key).get(key); + } + + /** + * Checks if a map value for `key` exists. + * + * @private + * @name has + * @memberOf MapCache + * @param {string} key The key of the entry to check. + * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`. + */ + function mapCacheHas(key) { + return getMapData(this, key).has(key); + } + + /** + * Sets the map `key` to `value`. + * + * @private + * @name set + * @memberOf MapCache + * @param {string} key The key of the value to set. + * @param {*} value The value to set. + * @returns {Object} Returns the map cache instance. + */ + function mapCacheSet(key, value) { + var data = getMapData(this, key), + size = data.size; + + data.set(key, value); + this.size += data.size == size ? 0 : 1; + return this; + } + + // Add methods to `MapCache`. + MapCache.prototype.clear = mapCacheClear; + MapCache.prototype['delete'] = mapCacheDelete; + MapCache.prototype.get = mapCacheGet; + MapCache.prototype.has = mapCacheHas; + MapCache.prototype.set = mapCacheSet; + + /*------------------------------------------------------------------------*/ + + /** + * + * Creates an array cache object to store unique values. + * + * @private + * @constructor + * @param {Array} [values] The values to cache. + */ + function SetCache(values) { + var index = -1, + length = values ? values.length : 0; + + this.__data__ = new MapCache; + while (++index < length) { + this.add(values[index]); + } + } + + /** + * Adds `value` to the array cache. + * + * @private + * @name add + * @memberOf SetCache + * @alias push + * @param {*} value The value to cache. + * @returns {Object} Returns the cache instance. + */ + function setCacheAdd(value) { + this.__data__.set(value, HASH_UNDEFINED); + return this; + } + + /** + * Checks if `value` is in the array cache. + * + * @private + * @name has + * @memberOf SetCache + * @param {*} value The value to search for. + * @returns {number} Returns `true` if `value` is found, else `false`. + */ + function setCacheHas(value) { + return this.__data__.has(value); + } + + // Add methods to `SetCache`. + SetCache.prototype.add = SetCache.prototype.push = setCacheAdd; + SetCache.prototype.has = setCacheHas; + + /*------------------------------------------------------------------------*/ + + /** + * Creates a stack cache object to store key-value pairs. + * + * @private + * @constructor + * @param {Array} [entries] The key-value pairs to cache. + */ + function Stack(entries) { + var data = this.__data__ = new ListCache(entries); + this.size = data.size; + } + + /** + * Removes all key-value entries from the stack. + * + * @private + * @name clear + * @memberOf Stack + */ + function stackClear() { + this.__data__ = new ListCache; + this.size = 0; + } + + /** + * Removes `key` and its value from the stack. + * + * @private + * @name delete + * @memberOf Stack + * @param {string} key The key of the value to remove. + * @returns {boolean} Returns `true` if the entry was removed, else `false`. + */ + function stackDelete(key) { + var data = this.__data__, + result = data['delete'](key); + + this.size = data.size; + return result; + } + + /** + * Gets the stack value for `key`. + * + * @private + * @name get + * @memberOf Stack + * @param {string} key The key of the value to get. + * @returns {*} Returns the entry value. + */ + function stackGet(key) { + return this.__data__.get(key); + } + + /** + * Checks if a stack value for `key` exists. + * + * @private + * @name has + * @memberOf Stack + * @param {string} key The key of the entry to check. + * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`. + */ + function stackHas(key) { + return this.__data__.has(key); + } + + /** + * Sets the stack `key` to `value`. + * + * @private + * @name set + * @memberOf Stack + * @param {string} key The key of the value to set. + * @param {*} value The value to set. + * @returns {Object} Returns the stack cache instance. + */ + function stackSet(key, value) { + var data = this.__data__; + if (data instanceof ListCache) { + var pairs = data.__data__; + if (!Map || (pairs.length < LARGE_ARRAY_SIZE - 1)) { + pairs.push([key, value]); + this.size = ++data.size; + return this; + } + data = this.__data__ = new MapCache(pairs); + } + data.set(key, value); + this.size = data.size; + return this; + } + + // Add methods to `Stack`. + Stack.prototype.clear = stackClear; + Stack.prototype['delete'] = stackDelete; + Stack.prototype.get = stackGet; + Stack.prototype.has = stackHas; + Stack.prototype.set = stackSet; + + /*------------------------------------------------------------------------*/ + + /** + * Creates an array of the enumerable property names of the array-like `value`. + * + * @private + * @param {*} value The value to query. + * @param {boolean} inherited Specify returning inherited property names. + * @returns {Array} Returns the array of property names. + */ + function arrayLikeKeys(value, inherited) { + var isArr = isArray(value), + isArg = !isArr && isArguments(value), + isBuff = !isArr && !isArg && isBuffer(value), + isType = !isArr && !isArg && !isBuff && isTypedArray(value), + skipIndexes = isArr || isArg || isBuff || isType, + result = skipIndexes ? baseTimes(value.length, String) : [], + length = result.length; + + for (var key in value) { + if ((inherited || hasOwnProperty.call(value, key)) && + !(skipIndexes && ( + // Safari 9 has enumerable `arguments.length` in strict mode. + key == 'length' || + // Node.js 0.10 has enumerable non-index properties on buffers. + (isBuff && (key == 'offset' || key == 'parent')) || + // PhantomJS 2 has enumerable non-index properties on typed arrays. + (isType && (key == 'buffer' || key == 'byteLength' || key == 'byteOffset')) || + // Skip index properties. + isIndex(key, length) + ))) { + result.push(key); + } + } + return result; + } + + /** + * A specialized version of `_.sample` for arrays. + * + * @private + * @param {Array} array The array to sample. + * @returns {*} Returns the random element. + */ + function arraySample(array) { + var length = array.length; + return length ? array[baseRandom(0, length - 1)] : undefined; + } + + /** + * A specialized version of `_.sampleSize` for arrays. + * + * @private + * @param {Array} array The array to sample. + * @param {number} n The number of elements to sample. + * @returns {Array} Returns the random elements. + */ + function arraySampleSize(array, n) { + return shuffleSelf(copyArray(array), baseClamp(n, 0, array.length)); + } + + /** + * A specialized version of `_.shuffle` for arrays. + * + * @private + * @param {Array} array The array to shuffle. + * @returns {Array} Returns the new shuffled array. + */ + function arrayShuffle(array) { + return shuffleSelf(copyArray(array)); + } + + /** + * Used by `_.defaults` to customize its `_.assignIn` use. + * + * @private + * @param {*} objValue The destination value. + * @param {*} srcValue The source value. + * @param {string} key The key of the property to assign. + * @param {Object} object The parent object of `objValue`. + * @returns {*} Returns the value to assign. + */ + function assignInDefaults(objValue, srcValue, key, object) { + if (objValue === undefined || + (eq(objValue, objectProto[key]) && !hasOwnProperty.call(object, key))) { + return srcValue; + } + return objValue; + } + + /** + * This function is like `assignValue` except that it doesn't assign + * `undefined` values. + * + * @private + * @param {Object} object The object to modify. + * @param {string} key The key of the property to assign. + * @param {*} value The value to assign. + */ + function assignMergeValue(object, key, value) { + if ((value !== undefined && !eq(object[key], value)) || + (value === undefined && !(key in object))) { + baseAssignValue(object, key, value); + } + } + + /** + * Assigns `value` to `key` of `object` if the existing value is not equivalent + * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero) + * for equality comparisons. + * + * @private + * @param {Object} object The object to modify. + * @param {string} key The key of the property to assign. + * @param {*} value The value to assign. + */ + function assignValue(object, key, value) { + var objValue = object[key]; + if (!(hasOwnProperty.call(object, key) && eq(objValue, value)) || + (value === undefined && !(key in object))) { + baseAssignValue(object, key, value); + } + } + + /** + * Gets the index at which the `key` is found in `array` of key-value pairs. + * + * @private + * @param {Array} array The array to inspect. + * @param {*} key The key to search for. + * @returns {number} Returns the index of the matched value, else `-1`. + */ + function assocIndexOf(array, key) { + var length = array.length; + while (length--) { + if (eq(array[length][0], key)) { + return length; + } + } + return -1; + } + + /** + * Aggregates elements of `collection` on `accumulator` with keys transformed + * by `iteratee` and values set by `setter`. + * + * @private + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} setter The function to set `accumulator` values. + * @param {Function} iteratee The iteratee to transform keys. + * @param {Object} accumulator The initial aggregated object. + * @returns {Function} Returns `accumulator`. + */ + function baseAggregator(collection, setter, iteratee, accumulator) { + baseEach(collection, function(value, key, collection) { + setter(accumulator, value, iteratee(value), collection); + }); + return accumulator; + } + + /** + * The base implementation of `_.assign` without support for multiple sources + * or `customizer` functions. + * + * @private + * @param {Object} object The destination object. + * @param {Object} source The source object. + * @returns {Object} Returns `object`. + */ + function baseAssign(object, source) { + return object && copyObject(source, keys(source), object); + } + + /** + * The base implementation of `assignValue` and `assignMergeValue` without + * value checks. + * + * @private + * @param {Object} object The object to modify. + * @param {string} key The key of the property to assign. + * @param {*} value The value to assign. + */ + function baseAssignValue(object, key, value) { + if (key == '__proto__' && defineProperty) { + defineProperty(object, key, { + 'configurable': true, + 'enumerable': true, + 'value': value, + 'writable': true + }); + } else { + object[key] = value; + } + } + + /** + * The base implementation of `_.at` without support for individual paths. + * + * @private + * @param {Object} object The object to iterate over. + * @param {string[]} paths The property paths of elements to pick. + * @returns {Array} Returns the picked elements. + */ + function baseAt(object, paths) { + var index = -1, + isNil = object == null, + length = paths.length, + result = Array(length); + + while (++index < length) { + result[index] = isNil ? undefined : get(object, paths[index]); + } + return result; + } + + /** + * The base implementation of `_.clamp` which doesn't coerce arguments. + * + * @private + * @param {number} number The number to clamp. + * @param {number} [lower] The lower bound. + * @param {number} upper The upper bound. + * @returns {number} Returns the clamped number. + */ + function baseClamp(number, lower, upper) { + if (number === number) { + if (upper !== undefined) { + number = number <= upper ? number : upper; + } + if (lower !== undefined) { + number = number >= lower ? number : lower; + } + } + return number; + } + + /** + * The base implementation of `_.clone` and `_.cloneDeep` which tracks + * traversed objects. + * + * @private + * @param {*} value The value to clone. + * @param {boolean} [isDeep] Specify a deep clone. + * @param {boolean} [isFull] Specify a clone including symbols. + * @param {Function} [customizer] The function to customize cloning. + * @param {string} [key] The key of `value`. + * @param {Object} [object] The parent object of `value`. + * @param {Object} [stack] Tracks traversed objects and their clone counterparts. + * @returns {*} Returns the cloned value. + */ + function baseClone(value, isDeep, isFull, customizer, key, object, stack) { + var result; + if (customizer) { + result = object ? customizer(value, key, object, stack) : customizer(value); + } + if (result !== undefined) { + return result; + } + if (!isObject(value)) { + return value; + } + var isArr = isArray(value); + if (isArr) { + result = initCloneArray(value); + if (!isDeep) { + return copyArray(value, result); + } + } else { + var tag = getTag(value), + isFunc = tag == funcTag || tag == genTag; + + if (isBuffer(value)) { + return cloneBuffer(value, isDeep); + } + if (tag == objectTag || tag == argsTag || (isFunc && !object)) { + result = initCloneObject(isFunc ? {} : value); + if (!isDeep) { + return copySymbols(value, baseAssign(result, value)); + } + } else { + if (!cloneableTags[tag]) { + return object ? value : {}; + } + result = initCloneByTag(value, tag, baseClone, isDeep); + } + } + // Check for circular references and return its corresponding clone. + stack || (stack = new Stack); + var stacked = stack.get(value); + if (stacked) { + return stacked; + } + stack.set(value, result); + + var props = isArr ? undefined : (isFull ? getAllKeys : keys)(value); + arrayEach(props || value, function(subValue, key) { + if (props) { + key = subValue; + subValue = value[key]; + } + // Recursively populate clone (susceptible to call stack limits). + assignValue(result, key, baseClone(subValue, isDeep, isFull, customizer, key, value, stack)); + }); + return result; + } + + /** + * The base implementation of `_.conforms` which doesn't clone `source`. + * + * @private + * @param {Object} source The object of property predicates to conform to. + * @returns {Function} Returns the new spec function. + */ + function baseConforms(source) { + var props = keys(source); + return function(object) { + return baseConformsTo(object, source, props); + }; + } + + /** + * The base implementation of `_.conformsTo` which accepts `props` to check. + * + * @private + * @param {Object} object The object to inspect. + * @param {Object} source The object of property predicates to conform to. + * @returns {boolean} Returns `true` if `object` conforms, else `false`. + */ + function baseConformsTo(object, source, props) { + var length = props.length; + if (object == null) { + return !length; + } + object = Object(object); + while (length--) { + var key = props[length], + predicate = source[key], + value = object[key]; + + if ((value === undefined && !(key in object)) || !predicate(value)) { + return false; + } + } + return true; + } + + /** + * The base implementation of `_.delay` and `_.defer` which accepts `args` + * to provide to `func`. + * + * @private + * @param {Function} func The function to delay. + * @param {number} wait The number of milliseconds to delay invocation. + * @param {Array} args The arguments to provide to `func`. + * @returns {number|Object} Returns the timer id or timeout object. + */ + function baseDelay(func, wait, args) { + if (typeof func != 'function') { + throw new TypeError(FUNC_ERROR_TEXT); + } + return setTimeout(function() { func.apply(undefined, args); }, wait); + } + + /** + * The base implementation of methods like `_.difference` without support + * for excluding multiple arrays or iteratee shorthands. + * + * @private + * @param {Array} array The array to inspect. + * @param {Array} values The values to exclude. + * @param {Function} [iteratee] The iteratee invoked per element. + * @param {Function} [comparator] The comparator invoked per element. + * @returns {Array} Returns the new array of filtered values. + */ + function baseDifference(array, values, iteratee, comparator) { + var index = -1, + includes = arrayIncludes, + isCommon = true, + length = array.length, + result = [], + valuesLength = values.length; + + if (!length) { + return result; + } + if (iteratee) { + values = arrayMap(values, baseUnary(iteratee)); + } + if (comparator) { + includes = arrayIncludesWith; + isCommon = false; + } + else if (values.length >= LARGE_ARRAY_SIZE) { + includes = cacheHas; + isCommon = false; + values = new SetCache(values); + } + outer: + while (++index < length) { + var value = array[index], + computed = iteratee ? iteratee(value) : value; + + value = (comparator || value !== 0) ? value : 0; + if (isCommon && computed === computed) { + var valuesIndex = valuesLength; + while (valuesIndex--) { + if (values[valuesIndex] === computed) { + continue outer; + } + } + result.push(value); + } + else if (!includes(values, computed, comparator)) { + result.push(value); + } + } + return result; + } + + /** + * The base implementation of `_.forEach` without support for iteratee shorthands. + * + * @private + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @returns {Array|Object} Returns `collection`. + */ + var baseEach = createBaseEach(baseForOwn); + + /** + * The base implementation of `_.forEachRight` without support for iteratee shorthands. + * + * @private + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @returns {Array|Object} Returns `collection`. + */ + var baseEachRight = createBaseEach(baseForOwnRight, true); + + /** + * The base implementation of `_.every` without support for iteratee shorthands. + * + * @private + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} predicate The function invoked per iteration. + * @returns {boolean} Returns `true` if all elements pass the predicate check, + * else `false` + */ + function baseEvery(collection, predicate) { + var result = true; + baseEach(collection, function(value, index, collection) { + result = !!predicate(value, index, collection); + return result; + }); + return result; + } + + /** + * The base implementation of methods like `_.max` and `_.min` which accepts a + * `comparator` to determine the extremum value. + * + * @private + * @param {Array} array The array to iterate over. + * @param {Function} iteratee The iteratee invoked per iteration. + * @param {Function} comparator The comparator used to compare values. + * @returns {*} Returns the extremum value. + */ + function baseExtremum(array, iteratee, comparator) { + var index = -1, + length = array.length; + + while (++index < length) { + var value = array[index], + current = iteratee(value); + + if (current != null && (computed === undefined + ? (current === current && !isSymbol(current)) + : comparator(current, computed) + )) { + var computed = current, + result = value; + } + } + return result; + } + + /** + * The base implementation of `_.fill` without an iteratee call guard. + * + * @private + * @param {Array} array The array to fill. + * @param {*} value The value to fill `array` with. + * @param {number} [start=0] The start position. + * @param {number} [end=array.length] The end position. + * @returns {Array} Returns `array`. + */ + function baseFill(array, value, start, end) { + var length = array.length; + + start = toInteger(start); + if (start < 0) { + start = -start > length ? 0 : (length + start); + } + end = (end === undefined || end > length) ? length : toInteger(end); + if (end < 0) { + end += length; + } + end = start > end ? 0 : toLength(end); + while (start < end) { + array[start++] = value; + } + return array; + } + + /** + * The base implementation of `_.filter` without support for iteratee shorthands. + * + * @private + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} predicate The function invoked per iteration. + * @returns {Array} Returns the new filtered array. + */ + function baseFilter(collection, predicate) { + var result = []; + baseEach(collection, function(value, index, collection) { + if (predicate(value, index, collection)) { + result.push(value); + } + }); + return result; + } + + /** + * The base implementation of `_.flatten` with support for restricting flattening. + * + * @private + * @param {Array} array The array to flatten. + * @param {number} depth The maximum recursion depth. + * @param {boolean} [predicate=isFlattenable] The function invoked per iteration. + * @param {boolean} [isStrict] Restrict to values that pass `predicate` checks. + * @param {Array} [result=[]] The initial result value. + * @returns {Array} Returns the new flattened array. + */ + function baseFlatten(array, depth, predicate, isStrict, result) { + var index = -1, + length = array.length; + + predicate || (predicate = isFlattenable); + result || (result = []); + + while (++index < length) { + var value = array[index]; + if (depth > 0 && predicate(value)) { + if (depth > 1) { + // Recursively flatten arrays (susceptible to call stack limits). + baseFlatten(value, depth - 1, predicate, isStrict, result); + } else { + arrayPush(result, value); + } + } else if (!isStrict) { + result[result.length] = value; + } + } + return result; + } + + /** + * The base implementation of `baseForOwn` which iterates over `object` + * properties returned by `keysFunc` and invokes `iteratee` for each property. + * Iteratee functions may exit iteration early by explicitly returning `false`. + * + * @private + * @param {Object} object The object to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @param {Function} keysFunc The function to get the keys of `object`. + * @returns {Object} Returns `object`. + */ + var baseFor = createBaseFor(); + + /** + * This function is like `baseFor` except that it iterates over properties + * in the opposite order. + * + * @private + * @param {Object} object The object to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @param {Function} keysFunc The function to get the keys of `object`. + * @returns {Object} Returns `object`. + */ + var baseForRight = createBaseFor(true); + + /** + * The base implementation of `_.forOwn` without support for iteratee shorthands. + * + * @private + * @param {Object} object The object to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @returns {Object} Returns `object`. + */ + function baseForOwn(object, iteratee) { + return object && baseFor(object, iteratee, keys); + } + + /** + * The base implementation of `_.forOwnRight` without support for iteratee shorthands. + * + * @private + * @param {Object} object The object to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @returns {Object} Returns `object`. + */ + function baseForOwnRight(object, iteratee) { + return object && baseForRight(object, iteratee, keys); + } + + /** + * The base implementation of `_.functions` which creates an array of + * `object` function property names filtered from `props`. + * + * @private + * @param {Object} object The object to inspect. + * @param {Array} props The property names to filter. + * @returns {Array} Returns the function names. + */ + function baseFunctions(object, props) { + return arrayFilter(props, function(key) { + return isFunction(object[key]); + }); + } + + /** + * The base implementation of `_.get` without support for default values. + * + * @private + * @param {Object} object The object to query. + * @param {Array|string} path The path of the property to get. + * @returns {*} Returns the resolved value. + */ + function baseGet(object, path) { + path = isKey(path, object) ? [path] : castPath(path); + + var index = 0, + length = path.length; + + while (object != null && index < length) { + object = object[toKey(path[index++])]; + } + return (index && index == length) ? object : undefined; + } + + /** + * The base implementation of `getAllKeys` and `getAllKeysIn` which uses + * `keysFunc` and `symbolsFunc` to get the enumerable property names and + * symbols of `object`. + * + * @private + * @param {Object} object The object to query. + * @param {Function} keysFunc The function to get the keys of `object`. + * @param {Function} symbolsFunc The function to get the symbols of `object`. + * @returns {Array} Returns the array of property names and symbols. + */ + function baseGetAllKeys(object, keysFunc, symbolsFunc) { + var result = keysFunc(object); + return isArray(object) ? result : arrayPush(result, symbolsFunc(object)); + } + + /** + * The base implementation of `getTag`. + * + * @private + * @param {*} value The value to query. + * @returns {string} Returns the `toStringTag`. + */ + function baseGetTag(value) { + return objectToString.call(value); + } + + /** + * The base implementation of `_.gt` which doesn't coerce arguments. + * + * @private + * @param {*} value The value to compare. + * @param {*} other The other value to compare. + * @returns {boolean} Returns `true` if `value` is greater than `other`, + * else `false`. + */ + function baseGt(value, other) { + return value > other; + } + + /** + * The base implementation of `_.has` without support for deep paths. + * + * @private + * @param {Object} [object] The object to query. + * @param {Array|string} key The key to check. + * @returns {boolean} Returns `true` if `key` exists, else `false`. + */ + function baseHas(object, key) { + return object != null && hasOwnProperty.call(object, key); + } + + /** + * The base implementation of `_.hasIn` without support for deep paths. + * + * @private + * @param {Object} [object] The object to query. + * @param {Array|string} key The key to check. + * @returns {boolean} Returns `true` if `key` exists, else `false`. + */ + function baseHasIn(object, key) { + return object != null && key in Object(object); + } + + /** + * The base implementation of `_.inRange` which doesn't coerce arguments. + * + * @private + * @param {number} number The number to check. + * @param {number} start The start of the range. + * @param {number} end The end of the range. + * @returns {boolean} Returns `true` if `number` is in the range, else `false`. + */ + function baseInRange(number, start, end) { + return number >= nativeMin(start, end) && number < nativeMax(start, end); + } + + /** + * The base implementation of methods like `_.intersection`, without support + * for iteratee shorthands, that accepts an array of arrays to inspect. + * + * @private + * @param {Array} arrays The arrays to inspect. + * @param {Function} [iteratee] The iteratee invoked per element. + * @param {Function} [comparator] The comparator invoked per element. + * @returns {Array} Returns the new array of shared values. + */ + function baseIntersection(arrays, iteratee, comparator) { + var includes = comparator ? arrayIncludesWith : arrayIncludes, + length = arrays[0].length, + othLength = arrays.length, + othIndex = othLength, + caches = Array(othLength), + maxLength = Infinity, + result = []; + + while (othIndex--) { + var array = arrays[othIndex]; + if (othIndex && iteratee) { + array = arrayMap(array, baseUnary(iteratee)); + } + maxLength = nativeMin(array.length, maxLength); + caches[othIndex] = !comparator && (iteratee || (length >= 120 && array.length >= 120)) + ? new SetCache(othIndex && array) + : undefined; + } + array = arrays[0]; + + var index = -1, + seen = caches[0]; + + outer: + while (++index < length && result.length < maxLength) { + var value = array[index], + computed = iteratee ? iteratee(value) : value; + + value = (comparator || value !== 0) ? value : 0; + if (!(seen + ? cacheHas(seen, computed) + : includes(result, computed, comparator) + )) { + othIndex = othLength; + while (--othIndex) { + var cache = caches[othIndex]; + if (!(cache + ? cacheHas(cache, computed) + : includes(arrays[othIndex], computed, comparator)) + ) { + continue outer; + } + } + if (seen) { + seen.push(computed); + } + result.push(value); + } + } + return result; + } + + /** + * The base implementation of `_.invert` and `_.invertBy` which inverts + * `object` with values transformed by `iteratee` and set by `setter`. + * + * @private + * @param {Object} object The object to iterate over. + * @param {Function} setter The function to set `accumulator` values. + * @param {Function} iteratee The iteratee to transform values. + * @param {Object} accumulator The initial inverted object. + * @returns {Function} Returns `accumulator`. + */ + function baseInverter(object, setter, iteratee, accumulator) { + baseForOwn(object, function(value, key, object) { + setter(accumulator, iteratee(value), key, object); + }); + return accumulator; + } + + /** + * The base implementation of `_.invoke` without support for individual + * method arguments. + * + * @private + * @param {Object} object The object to query. + * @param {Array|string} path The path of the method to invoke. + * @param {Array} args The arguments to invoke the method with. + * @returns {*} Returns the result of the invoked method. + */ + function baseInvoke(object, path, args) { + if (!isKey(path, object)) { + path = castPath(path); + object = parent(object, path); + path = last(path); + } + var func = object == null ? object : object[toKey(path)]; + return func == null ? undefined : apply(func, object, args); + } + + /** + * The base implementation of `_.isArguments`. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is an `arguments` object, + */ + function baseIsArguments(value) { + return isObjectLike(value) && objectToString.call(value) == argsTag; + } + + /** + * The base implementation of `_.isArrayBuffer` without Node.js optimizations. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is an array buffer, else `false`. + */ + function baseIsArrayBuffer(value) { + return isObjectLike(value) && objectToString.call(value) == arrayBufferTag; + } + + /** + * The base implementation of `_.isDate` without Node.js optimizations. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a date object, else `false`. + */ + function baseIsDate(value) { + return isObjectLike(value) && objectToString.call(value) == dateTag; + } + + /** + * The base implementation of `_.isEqual` which supports partial comparisons + * and tracks traversed objects. + * + * @private + * @param {*} value The value to compare. + * @param {*} other The other value to compare. + * @param {Function} [customizer] The function to customize comparisons. + * @param {boolean} [bitmask] The bitmask of comparison flags. + * The bitmask may be composed of the following flags: + * 1 - Unordered comparison + * 2 - Partial comparison + * @param {Object} [stack] Tracks traversed `value` and `other` objects. + * @returns {boolean} Returns `true` if the values are equivalent, else `false`. + */ + function baseIsEqual(value, other, customizer, bitmask, stack) { + if (value === other) { + return true; + } + if (value == null || other == null || (!isObject(value) && !isObjectLike(other))) { + return value !== value && other !== other; + } + return baseIsEqualDeep(value, other, baseIsEqual, customizer, bitmask, stack); + } + + /** + * A specialized version of `baseIsEqual` for arrays and objects which performs + * deep comparisons and tracks traversed objects enabling objects with circular + * references to be compared. + * + * @private + * @param {Object} object The object to compare. + * @param {Object} other The other object to compare. + * @param {Function} equalFunc The function to determine equivalents of values. + * @param {Function} [customizer] The function to customize comparisons. + * @param {number} [bitmask] The bitmask of comparison flags. See `baseIsEqual` + * for more details. + * @param {Object} [stack] Tracks traversed `object` and `other` objects. + * @returns {boolean} Returns `true` if the objects are equivalent, else `false`. + */ + function baseIsEqualDeep(object, other, equalFunc, customizer, bitmask, stack) { + var objIsArr = isArray(object), + othIsArr = isArray(other), + objTag = arrayTag, + othTag = arrayTag; + + if (!objIsArr) { + objTag = getTag(object); + objTag = objTag == argsTag ? objectTag : objTag; + } + if (!othIsArr) { + othTag = getTag(other); + othTag = othTag == argsTag ? objectTag : othTag; + } + var objIsObj = objTag == objectTag, + othIsObj = othTag == objectTag, + isSameTag = objTag == othTag; + + if (isSameTag && isBuffer(object)) { + if (!isBuffer(other)) { + return false; + } + objIsArr = true; + objIsObj = false; + } + if (isSameTag && !objIsObj) { + stack || (stack = new Stack); + return (objIsArr || isTypedArray(object)) + ? equalArrays(object, other, equalFunc, customizer, bitmask, stack) + : equalByTag(object, other, objTag, equalFunc, customizer, bitmask, stack); + } + if (!(bitmask & PARTIAL_COMPARE_FLAG)) { + var objIsWrapped = objIsObj && hasOwnProperty.call(object, '__wrapped__'), + othIsWrapped = othIsObj && hasOwnProperty.call(other, '__wrapped__'); + + if (objIsWrapped || othIsWrapped) { + var objUnwrapped = objIsWrapped ? object.value() : object, + othUnwrapped = othIsWrapped ? other.value() : other; + + stack || (stack = new Stack); + return equalFunc(objUnwrapped, othUnwrapped, customizer, bitmask, stack); + } + } + if (!isSameTag) { + return false; + } + stack || (stack = new Stack); + return equalObjects(object, other, equalFunc, customizer, bitmask, stack); + } + + /** + * The base implementation of `_.isMap` without Node.js optimizations. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a map, else `false`. + */ + function baseIsMap(value) { + return isObjectLike(value) && getTag(value) == mapTag; + } + + /** + * The base implementation of `_.isMatch` without support for iteratee shorthands. + * + * @private + * @param {Object} object The object to inspect. + * @param {Object} source The object of property values to match. + * @param {Array} matchData The property names, values, and compare flags to match. + * @param {Function} [customizer] The function to customize comparisons. + * @returns {boolean} Returns `true` if `object` is a match, else `false`. + */ + function baseIsMatch(object, source, matchData, customizer) { + var index = matchData.length, + length = index, + noCustomizer = !customizer; + + if (object == null) { + return !length; + } + object = Object(object); + while (index--) { + var data = matchData[index]; + if ((noCustomizer && data[2]) + ? data[1] !== object[data[0]] + : !(data[0] in object) + ) { + return false; + } + } + while (++index < length) { + data = matchData[index]; + var key = data[0], + objValue = object[key], + srcValue = data[1]; + + if (noCustomizer && data[2]) { + if (objValue === undefined && !(key in object)) { + return false; + } + } else { + var stack = new Stack; + if (customizer) { + var result = customizer(objValue, srcValue, key, object, source, stack); + } + if (!(result === undefined + ? baseIsEqual(srcValue, objValue, customizer, UNORDERED_COMPARE_FLAG | PARTIAL_COMPARE_FLAG, stack) + : result + )) { + return false; + } + } + } + return true; + } + + /** + * The base implementation of `_.isNative` without bad shim checks. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a native function, + * else `false`. + */ + function baseIsNative(value) { + if (!isObject(value) || isMasked(value)) { + return false; + } + var pattern = isFunction(value) ? reIsNative : reIsHostCtor; + return pattern.test(toSource(value)); + } + + /** + * The base implementation of `_.isRegExp` without Node.js optimizations. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a regexp, else `false`. + */ + function baseIsRegExp(value) { + return isObject(value) && objectToString.call(value) == regexpTag; + } + + /** + * The base implementation of `_.isSet` without Node.js optimizations. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a set, else `false`. + */ + function baseIsSet(value) { + return isObjectLike(value) && getTag(value) == setTag; + } + + /** + * The base implementation of `_.isTypedArray` without Node.js optimizations. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a typed array, else `false`. + */ + function baseIsTypedArray(value) { + return isObjectLike(value) && + isLength(value.length) && !!typedArrayTags[objectToString.call(value)]; + } + + /** + * The base implementation of `_.iteratee`. + * + * @private + * @param {*} [value=_.identity] The value to convert to an iteratee. + * @returns {Function} Returns the iteratee. + */ + function baseIteratee(value) { + // Don't store the `typeof` result in a variable to avoid a JIT bug in Safari 9. + // See https://bugs.webkit.org/show_bug.cgi?id=156034 for more details. + if (typeof value == 'function') { + return value; + } + if (value == null) { + return identity; + } + if (typeof value == 'object') { + return isArray(value) + ? baseMatchesProperty(value[0], value[1]) + : baseMatches(value); + } + return property(value); + } + + /** + * The base implementation of `_.keys` which doesn't treat sparse arrays as dense. + * + * @private + * @param {Object} object The object to query. + * @returns {Array} Returns the array of property names. + */ + function baseKeys(object) { + if (!isPrototype(object)) { + return nativeKeys(object); + } + var result = []; + for (var key in Object(object)) { + if (hasOwnProperty.call(object, key) && key != 'constructor') { + result.push(key); + } + } + return result; + } + + /** + * The base implementation of `_.keysIn` which doesn't treat sparse arrays as dense. + * + * @private + * @param {Object} object The object to query. + * @returns {Array} Returns the array of property names. + */ + function baseKeysIn(object) { + if (!isObject(object)) { + return nativeKeysIn(object); + } + var isProto = isPrototype(object), + result = []; + + for (var key in object) { + if (!(key == 'constructor' && (isProto || !hasOwnProperty.call(object, key)))) { + result.push(key); + } + } + return result; + } + + /** + * The base implementation of `_.lt` which doesn't coerce arguments. + * + * @private + * @param {*} value The value to compare. + * @param {*} other The other value to compare. + * @returns {boolean} Returns `true` if `value` is less than `other`, + * else `false`. + */ + function baseLt(value, other) { + return value < other; + } + + /** + * The base implementation of `_.map` without support for iteratee shorthands. + * + * @private + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @returns {Array} Returns the new mapped array. + */ + function baseMap(collection, iteratee) { + var index = -1, + result = isArrayLike(collection) ? Array(collection.length) : []; + + baseEach(collection, function(value, key, collection) { + result[++index] = iteratee(value, key, collection); + }); + return result; + } + + /** + * The base implementation of `_.matches` which doesn't clone `source`. + * + * @private + * @param {Object} source The object of property values to match. + * @returns {Function} Returns the new spec function. + */ + function baseMatches(source) { + var matchData = getMatchData(source); + if (matchData.length == 1 && matchData[0][2]) { + return matchesStrictComparable(matchData[0][0], matchData[0][1]); + } + return function(object) { + return object === source || baseIsMatch(object, source, matchData); + }; + } + + /** + * The base implementation of `_.matchesProperty` which doesn't clone `srcValue`. + * + * @private + * @param {string} path The path of the property to get. + * @param {*} srcValue The value to match. + * @returns {Function} Returns the new spec function. + */ + function baseMatchesProperty(path, srcValue) { + if (isKey(path) && isStrictComparable(srcValue)) { + return matchesStrictComparable(toKey(path), srcValue); + } + return function(object) { + var objValue = get(object, path); + return (objValue === undefined && objValue === srcValue) + ? hasIn(object, path) + : baseIsEqual(srcValue, objValue, undefined, UNORDERED_COMPARE_FLAG | PARTIAL_COMPARE_FLAG); + }; + } + + /** + * The base implementation of `_.merge` without support for multiple sources. + * + * @private + * @param {Object} object The destination object. + * @param {Object} source The source object. + * @param {number} srcIndex The index of `source`. + * @param {Function} [customizer] The function to customize merged values. + * @param {Object} [stack] Tracks traversed source values and their merged + * counterparts. + */ + function baseMerge(object, source, srcIndex, customizer, stack) { + if (object === source) { + return; + } + baseFor(source, function(srcValue, key) { + if (isObject(srcValue)) { + stack || (stack = new Stack); + baseMergeDeep(object, source, key, srcIndex, baseMerge, customizer, stack); + } + else { + var newValue = customizer + ? customizer(object[key], srcValue, (key + ''), object, source, stack) + : undefined; + + if (newValue === undefined) { + newValue = srcValue; + } + assignMergeValue(object, key, newValue); + } + }, keysIn); + } + + /** + * A specialized version of `baseMerge` for arrays and objects which performs + * deep merges and tracks traversed objects enabling objects with circular + * references to be merged. + * + * @private + * @param {Object} object The destination object. + * @param {Object} source The source object. + * @param {string} key The key of the value to merge. + * @param {number} srcIndex The index of `source`. + * @param {Function} mergeFunc The function to merge values. + * @param {Function} [customizer] The function to customize assigned values. + * @param {Object} [stack] Tracks traversed source values and their merged + * counterparts. + */ + function baseMergeDeep(object, source, key, srcIndex, mergeFunc, customizer, stack) { + var objValue = object[key], + srcValue = source[key], + stacked = stack.get(srcValue); + + if (stacked) { + assignMergeValue(object, key, stacked); + return; + } + var newValue = customizer + ? customizer(objValue, srcValue, (key + ''), object, source, stack) + : undefined; + + var isCommon = newValue === undefined; + + if (isCommon) { + var isArr = isArray(srcValue), + isBuff = !isArr && isBuffer(srcValue), + isTyped = !isArr && !isBuff && isTypedArray(srcValue); + + newValue = srcValue; + if (isArr || isBuff || isTyped) { + if (isArray(objValue)) { + newValue = objValue; + } + else if (isArrayLikeObject(objValue)) { + newValue = copyArray(objValue); + } + else if (isBuff) { + isCommon = false; + newValue = cloneBuffer(srcValue, true); + } + else if (isTyped) { + isCommon = false; + newValue = cloneTypedArray(srcValue, true); + } + else { + newValue = []; + } + } + else if (isPlainObject(srcValue) || isArguments(srcValue)) { + newValue = objValue; + if (isArguments(objValue)) { + newValue = toPlainObject(objValue); + } + else if (!isObject(objValue) || (srcIndex && isFunction(objValue))) { + newValue = initCloneObject(srcValue); + } + } + else { + isCommon = false; + } + } + if (isCommon) { + // Recursively merge objects and arrays (susceptible to call stack limits). + stack.set(srcValue, newValue); + mergeFunc(newValue, srcValue, srcIndex, customizer, stack); + stack['delete'](srcValue); + } + assignMergeValue(object, key, newValue); + } + + /** + * The base implementation of `_.nth` which doesn't coerce arguments. + * + * @private + * @param {Array} array The array to query. + * @param {number} n The index of the element to return. + * @returns {*} Returns the nth element of `array`. + */ + function baseNth(array, n) { + var length = array.length; + if (!length) { + return; + } + n += n < 0 ? length : 0; + return isIndex(n, length) ? array[n] : undefined; + } + + /** + * The base implementation of `_.orderBy` without param guards. + * + * @private + * @param {Array|Object} collection The collection to iterate over. + * @param {Function[]|Object[]|string[]} iteratees The iteratees to sort by. + * @param {string[]} orders The sort orders of `iteratees`. + * @returns {Array} Returns the new sorted array. + */ + function baseOrderBy(collection, iteratees, orders) { + var index = -1; + iteratees = arrayMap(iteratees.length ? iteratees : [identity], baseUnary(getIteratee())); + + var result = baseMap(collection, function(value, key, collection) { + var criteria = arrayMap(iteratees, function(iteratee) { + return iteratee(value); + }); + return { 'criteria': criteria, 'index': ++index, 'value': value }; + }); + + return baseSortBy(result, function(object, other) { + return compareMultiple(object, other, orders); + }); + } + + /** + * The base implementation of `_.pick` without support for individual + * property identifiers. + * + * @private + * @param {Object} object The source object. + * @param {string[]} props The property identifiers to pick. + * @returns {Object} Returns the new object. + */ + function basePick(object, props) { + object = Object(object); + return basePickBy(object, props, function(value, key) { + return key in object; + }); + } + + /** + * The base implementation of `_.pickBy` without support for iteratee shorthands. + * + * @private + * @param {Object} object The source object. + * @param {string[]} props The property identifiers to pick from. + * @param {Function} predicate The function invoked per property. + * @returns {Object} Returns the new object. + */ + function basePickBy(object, props, predicate) { + var index = -1, + length = props.length, + result = {}; + + while (++index < length) { + var key = props[index], + value = object[key]; + + if (predicate(value, key)) { + baseAssignValue(result, key, value); + } + } + return result; + } + + /** + * A specialized version of `baseProperty` which supports deep paths. + * + * @private + * @param {Array|string} path The path of the property to get. + * @returns {Function} Returns the new accessor function. + */ + function basePropertyDeep(path) { + return function(object) { + return baseGet(object, path); + }; + } + + /** + * The base implementation of `_.pullAllBy` without support for iteratee + * shorthands. + * + * @private + * @param {Array} array The array to modify. + * @param {Array} values The values to remove. + * @param {Function} [iteratee] The iteratee invoked per element. + * @param {Function} [comparator] The comparator invoked per element. + * @returns {Array} Returns `array`. + */ + function basePullAll(array, values, iteratee, comparator) { + var indexOf = comparator ? baseIndexOfWith : baseIndexOf, + index = -1, + length = values.length, + seen = array; + + if (array === values) { + values = copyArray(values); + } + if (iteratee) { + seen = arrayMap(array, baseUnary(iteratee)); + } + while (++index < length) { + var fromIndex = 0, + value = values[index], + computed = iteratee ? iteratee(value) : value; + + while ((fromIndex = indexOf(seen, computed, fromIndex, comparator)) > -1) { + if (seen !== array) { + splice.call(seen, fromIndex, 1); + } + splice.call(array, fromIndex, 1); + } + } + return array; + } + + /** + * The base implementation of `_.pullAt` without support for individual + * indexes or capturing the removed elements. + * + * @private + * @param {Array} array The array to modify. + * @param {number[]} indexes The indexes of elements to remove. + * @returns {Array} Returns `array`. + */ + function basePullAt(array, indexes) { + var length = array ? indexes.length : 0, + lastIndex = length - 1; + + while (length--) { + var index = indexes[length]; + if (length == lastIndex || index !== previous) { + var previous = index; + if (isIndex(index)) { + splice.call(array, index, 1); + } + else if (!isKey(index, array)) { + var path = castPath(index), + object = parent(array, path); + + if (object != null) { + delete object[toKey(last(path))]; + } + } + else { + delete array[toKey(index)]; + } + } + } + return array; + } + + /** + * The base implementation of `_.random` without support for returning + * floating-point numbers. + * + * @private + * @param {number} lower The lower bound. + * @param {number} upper The upper bound. + * @returns {number} Returns the random number. + */ + function baseRandom(lower, upper) { + return lower + nativeFloor(nativeRandom() * (upper - lower + 1)); + } + + /** + * The base implementation of `_.range` and `_.rangeRight` which doesn't + * coerce arguments. + * + * @private + * @param {number} start The start of the range. + * @param {number} end The end of the range. + * @param {number} step The value to increment or decrement by. + * @param {boolean} [fromRight] Specify iterating from right to left. + * @returns {Array} Returns the range of numbers. + */ + function baseRange(start, end, step, fromRight) { + var index = -1, + length = nativeMax(nativeCeil((end - start) / (step || 1)), 0), + result = Array(length); + + while (length--) { + result[fromRight ? length : ++index] = start; + start += step; + } + return result; + } + + /** + * The base implementation of `_.repeat` which doesn't coerce arguments. + * + * @private + * @param {string} string The string to repeat. + * @param {number} n The number of times to repeat the string. + * @returns {string} Returns the repeated string. + */ + function baseRepeat(string, n) { + var result = ''; + if (!string || n < 1 || n > MAX_SAFE_INTEGER) { + return result; + } + // Leverage the exponentiation by squaring algorithm for a faster repeat. + // See https://en.wikipedia.org/wiki/Exponentiation_by_squaring for more details. + do { + if (n % 2) { + result += string; + } + n = nativeFloor(n / 2); + if (n) { + string += string; + } + } while (n); + + return result; + } + + /** + * The base implementation of `_.rest` which doesn't validate or coerce arguments. + * + * @private + * @param {Function} func The function to apply a rest parameter to. + * @param {number} [start=func.length-1] The start position of the rest parameter. + * @returns {Function} Returns the new function. + */ + function baseRest(func, start) { + return setToString(overRest(func, start, identity), func + ''); + } + + /** + * The base implementation of `_.sample`. + * + * @private + * @param {Array|Object} collection The collection to sample. + * @returns {*} Returns the random element. + */ + function baseSample(collection) { + return arraySample(values(collection)); + } + + /** + * The base implementation of `_.sampleSize` without param guards. + * + * @private + * @param {Array|Object} collection The collection to sample. + * @param {number} n The number of elements to sample. + * @returns {Array} Returns the random elements. + */ + function baseSampleSize(collection, n) { + var array = values(collection); + return shuffleSelf(array, baseClamp(n, 0, array.length)); + } + + /** + * The base implementation of `_.set`. + * + * @private + * @param {Object} object The object to modify. + * @param {Array|string} path The path of the property to set. + * @param {*} value The value to set. + * @param {Function} [customizer] The function to customize path creation. + * @returns {Object} Returns `object`. + */ + function baseSet(object, path, value, customizer) { + if (!isObject(object)) { + return object; + } + path = isKey(path, object) ? [path] : castPath(path); + + var index = -1, + length = path.length, + lastIndex = length - 1, + nested = object; + + while (nested != null && ++index < length) { + var key = toKey(path[index]), + newValue = value; + + if (index != lastIndex) { + var objValue = nested[key]; + newValue = customizer ? customizer(objValue, key, nested) : undefined; + if (newValue === undefined) { + newValue = isObject(objValue) + ? objValue + : (isIndex(path[index + 1]) ? [] : {}); + } + } + assignValue(nested, key, newValue); + nested = nested[key]; + } + return object; + } + + /** + * The base implementation of `setData` without support for hot loop shorting. + * + * @private + * @param {Function} func The function to associate metadata with. + * @param {*} data The metadata. + * @returns {Function} Returns `func`. + */ + var baseSetData = !metaMap ? identity : function(func, data) { + metaMap.set(func, data); + return func; + }; + + /** + * The base implementation of `setToString` without support for hot loop shorting. + * + * @private + * @param {Function} func The function to modify. + * @param {Function} string The `toString` result. + * @returns {Function} Returns `func`. + */ + var baseSetToString = !defineProperty ? identity : function(func, string) { + return defineProperty(func, 'toString', { + 'configurable': true, + 'enumerable': false, + 'value': constant(string), + 'writable': true + }); + }; + + /** + * The base implementation of `_.shuffle`. + * + * @private + * @param {Array|Object} collection The collection to shuffle. + * @returns {Array} Returns the new shuffled array. + */ + function baseShuffle(collection) { + return shuffleSelf(values(collection)); + } + + /** + * The base implementation of `_.slice` without an iteratee call guard. + * + * @private + * @param {Array} array The array to slice. + * @param {number} [start=0] The start position. + * @param {number} [end=array.length] The end position. + * @returns {Array} Returns the slice of `array`. + */ + function baseSlice(array, start, end) { + var index = -1, + length = array.length; + + if (start < 0) { + start = -start > length ? 0 : (length + start); + } + end = end > length ? length : end; + if (end < 0) { + end += length; + } + length = start > end ? 0 : ((end - start) >>> 0); + start >>>= 0; + + var result = Array(length); + while (++index < length) { + result[index] = array[index + start]; + } + return result; + } + + /** + * The base implementation of `_.some` without support for iteratee shorthands. + * + * @private + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} predicate The function invoked per iteration. + * @returns {boolean} Returns `true` if any element passes the predicate check, + * else `false`. + */ + function baseSome(collection, predicate) { + var result; + + baseEach(collection, function(value, index, collection) { + result = predicate(value, index, collection); + return !result; + }); + return !!result; + } + + /** + * The base implementation of `_.sortedIndex` and `_.sortedLastIndex` which + * performs a binary search of `array` to determine the index at which `value` + * should be inserted into `array` in order to maintain its sort order. + * + * @private + * @param {Array} array The sorted array to inspect. + * @param {*} value The value to evaluate. + * @param {boolean} [retHighest] Specify returning the highest qualified index. + * @returns {number} Returns the index at which `value` should be inserted + * into `array`. + */ + function baseSortedIndex(array, value, retHighest) { + var low = 0, + high = array ? array.length : low; + + if (typeof value == 'number' && value === value && high <= HALF_MAX_ARRAY_LENGTH) { + while (low < high) { + var mid = (low + high) >>> 1, + computed = array[mid]; + + if (computed !== null && !isSymbol(computed) && + (retHighest ? (computed <= value) : (computed < value))) { + low = mid + 1; + } else { + high = mid; + } + } + return high; + } + return baseSortedIndexBy(array, value, identity, retHighest); + } + + /** + * The base implementation of `_.sortedIndexBy` and `_.sortedLastIndexBy` + * which invokes `iteratee` for `value` and each element of `array` to compute + * their sort ranking. The iteratee is invoked with one argument; (value). + * + * @private + * @param {Array} array The sorted array to inspect. + * @param {*} value The value to evaluate. + * @param {Function} iteratee The iteratee invoked per element. + * @param {boolean} [retHighest] Specify returning the highest qualified index. + * @returns {number} Returns the index at which `value` should be inserted + * into `array`. + */ + function baseSortedIndexBy(array, value, iteratee, retHighest) { + value = iteratee(value); + + var low = 0, + high = array ? array.length : 0, + valIsNaN = value !== value, + valIsNull = value === null, + valIsSymbol = isSymbol(value), + valIsUndefined = value === undefined; + + while (low < high) { + var mid = nativeFloor((low + high) / 2), + computed = iteratee(array[mid]), + othIsDefined = computed !== undefined, + othIsNull = computed === null, + othIsReflexive = computed === computed, + othIsSymbol = isSymbol(computed); + + if (valIsNaN) { + var setLow = retHighest || othIsReflexive; + } else if (valIsUndefined) { + setLow = othIsReflexive && (retHighest || othIsDefined); + } else if (valIsNull) { + setLow = othIsReflexive && othIsDefined && (retHighest || !othIsNull); + } else if (valIsSymbol) { + setLow = othIsReflexive && othIsDefined && !othIsNull && (retHighest || !othIsSymbol); + } else if (othIsNull || othIsSymbol) { + setLow = false; + } else { + setLow = retHighest ? (computed <= value) : (computed < value); + } + if (setLow) { + low = mid + 1; + } else { + high = mid; + } + } + return nativeMin(high, MAX_ARRAY_INDEX); + } + + /** + * The base implementation of `_.sortedUniq` and `_.sortedUniqBy` without + * support for iteratee shorthands. + * + * @private + * @param {Array} array The array to inspect. + * @param {Function} [iteratee] The iteratee invoked per element. + * @returns {Array} Returns the new duplicate free array. + */ + function baseSortedUniq(array, iteratee) { + var index = -1, + length = array.length, + resIndex = 0, + result = []; + + while (++index < length) { + var value = array[index], + computed = iteratee ? iteratee(value) : value; + + if (!index || !eq(computed, seen)) { + var seen = computed; + result[resIndex++] = value === 0 ? 0 : value; + } + } + return result; + } + + /** + * The base implementation of `_.toNumber` which doesn't ensure correct + * conversions of binary, hexadecimal, or octal string values. + * + * @private + * @param {*} value The value to process. + * @returns {number} Returns the number. + */ + function baseToNumber(value) { + if (typeof value == 'number') { + return value; + } + if (isSymbol(value)) { + return NAN; + } + return +value; + } + + /** + * The base implementation of `_.toString` which doesn't convert nullish + * values to empty strings. + * + * @private + * @param {*} value The value to process. + * @returns {string} Returns the string. + */ + function baseToString(value) { + // Exit early for strings to avoid a performance hit in some environments. + if (typeof value == 'string') { + return value; + } + if (isArray(value)) { + // Recursively convert values (susceptible to call stack limits). + return arrayMap(value, baseToString) + ''; + } + if (isSymbol(value)) { + return symbolToString ? symbolToString.call(value) : ''; + } + var result = (value + ''); + return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result; + } + + /** + * The base implementation of `_.uniqBy` without support for iteratee shorthands. + * + * @private + * @param {Array} array The array to inspect. + * @param {Function} [iteratee] The iteratee invoked per element. + * @param {Function} [comparator] The comparator invoked per element. + * @returns {Array} Returns the new duplicate free array. + */ + function baseUniq(array, iteratee, comparator) { + var index = -1, + includes = arrayIncludes, + length = array.length, + isCommon = true, + result = [], + seen = result; + + if (comparator) { + isCommon = false; + includes = arrayIncludesWith; + } + else if (length >= LARGE_ARRAY_SIZE) { + var set = iteratee ? null : createSet(array); + if (set) { + return setToArray(set); + } + isCommon = false; + includes = cacheHas; + seen = new SetCache; + } + else { + seen = iteratee ? [] : result; + } + outer: + while (++index < length) { + var value = array[index], + computed = iteratee ? iteratee(value) : value; + + value = (comparator || value !== 0) ? value : 0; + if (isCommon && computed === computed) { + var seenIndex = seen.length; + while (seenIndex--) { + if (seen[seenIndex] === computed) { + continue outer; + } + } + if (iteratee) { + seen.push(computed); + } + result.push(value); + } + else if (!includes(seen, computed, comparator)) { + if (seen !== result) { + seen.push(computed); + } + result.push(value); + } + } + return result; + } + + /** + * The base implementation of `_.unset`. + * + * @private + * @param {Object} object The object to modify. + * @param {Array|string} path The path of the property to unset. + * @returns {boolean} Returns `true` if the property is deleted, else `false`. + */ + function baseUnset(object, path) { + path = isKey(path, object) ? [path] : castPath(path); + object = parent(object, path); + + var key = toKey(last(path)); + return !(object != null && hasOwnProperty.call(object, key)) || delete object[key]; + } + + /** + * The base implementation of `_.update`. + * + * @private + * @param {Object} object The object to modify. + * @param {Array|string} path The path of the property to update. + * @param {Function} updater The function to produce the updated value. + * @param {Function} [customizer] The function to customize path creation. + * @returns {Object} Returns `object`. + */ + function baseUpdate(object, path, updater, customizer) { + return baseSet(object, path, updater(baseGet(object, path)), customizer); + } + + /** + * The base implementation of methods like `_.dropWhile` and `_.takeWhile` + * without support for iteratee shorthands. + * + * @private + * @param {Array} array The array to query. + * @param {Function} predicate The function invoked per iteration. + * @param {boolean} [isDrop] Specify dropping elements instead of taking them. + * @param {boolean} [fromRight] Specify iterating from right to left. + * @returns {Array} Returns the slice of `array`. + */ + function baseWhile(array, predicate, isDrop, fromRight) { + var length = array.length, + index = fromRight ? length : -1; + + while ((fromRight ? index-- : ++index < length) && + predicate(array[index], index, array)) {} + + return isDrop + ? baseSlice(array, (fromRight ? 0 : index), (fromRight ? index + 1 : length)) + : baseSlice(array, (fromRight ? index + 1 : 0), (fromRight ? length : index)); + } + + /** + * The base implementation of `wrapperValue` which returns the result of + * performing a sequence of actions on the unwrapped `value`, where each + * successive action is supplied the return value of the previous. + * + * @private + * @param {*} value The unwrapped value. + * @param {Array} actions Actions to perform to resolve the unwrapped value. + * @returns {*} Returns the resolved value. + */ + function baseWrapperValue(value, actions) { + var result = value; + if (result instanceof LazyWrapper) { + result = result.value(); + } + return arrayReduce(actions, function(result, action) { + return action.func.apply(action.thisArg, arrayPush([result], action.args)); + }, result); + } + + /** + * The base implementation of methods like `_.xor`, without support for + * iteratee shorthands, that accepts an array of arrays to inspect. + * + * @private + * @param {Array} arrays The arrays to inspect. + * @param {Function} [iteratee] The iteratee invoked per element. + * @param {Function} [comparator] The comparator invoked per element. + * @returns {Array} Returns the new array of values. + */ + function baseXor(arrays, iteratee, comparator) { + var index = -1, + length = arrays.length; + + while (++index < length) { + var result = result + ? arrayPush( + baseDifference(result, arrays[index], iteratee, comparator), + baseDifference(arrays[index], result, iteratee, comparator) + ) + : arrays[index]; + } + return (result && result.length) ? baseUniq(result, iteratee, comparator) : []; + } + + /** + * This base implementation of `_.zipObject` which assigns values using `assignFunc`. + * + * @private + * @param {Array} props The property identifiers. + * @param {Array} values The property values. + * @param {Function} assignFunc The function to assign values. + * @returns {Object} Returns the new object. + */ + function baseZipObject(props, values, assignFunc) { + var index = -1, + length = props.length, + valsLength = values.length, + result = {}; + + while (++index < length) { + var value = index < valsLength ? values[index] : undefined; + assignFunc(result, props[index], value); + } + return result; + } + + /** + * Casts `value` to an empty array if it's not an array like object. + * + * @private + * @param {*} value The value to inspect. + * @returns {Array|Object} Returns the cast array-like object. + */ + function castArrayLikeObject(value) { + return isArrayLikeObject(value) ? value : []; + } + + /** + * Casts `value` to `identity` if it's not a function. + * + * @private + * @param {*} value The value to inspect. + * @returns {Function} Returns cast function. + */ + function castFunction(value) { + return typeof value == 'function' ? value : identity; + } + + /** + * Casts `value` to a path array if it's not one. + * + * @private + * @param {*} value The value to inspect. + * @returns {Array} Returns the cast property path array. + */ + function castPath(value) { + return isArray(value) ? value : stringToPath(value); + } + + /** + * A `baseRest` alias which can be replaced with `identity` by module + * replacement plugins. + * + * @private + * @type {Function} + * @param {Function} func The function to apply a rest parameter to. + * @returns {Function} Returns the new function. + */ + var castRest = baseRest; + + /** + * Casts `array` to a slice if it's needed. + * + * @private + * @param {Array} array The array to inspect. + * @param {number} start The start position. + * @param {number} [end=array.length] The end position. + * @returns {Array} Returns the cast slice. + */ + function castSlice(array, start, end) { + var length = array.length; + end = end === undefined ? length : end; + return (!start && end >= length) ? array : baseSlice(array, start, end); + } + + /** + * A simple wrapper around the global [`clearTimeout`](https://mdn.io/clearTimeout). + * + * @private + * @param {number|Object} id The timer id or timeout object of the timer to clear. + */ + var clearTimeout = ctxClearTimeout || function(id) { + return root.clearTimeout(id); + }; + + /** + * Creates a clone of `buffer`. + * + * @private + * @param {Buffer} buffer The buffer to clone. + * @param {boolean} [isDeep] Specify a deep clone. + * @returns {Buffer} Returns the cloned buffer. + */ + function cloneBuffer(buffer, isDeep) { + if (isDeep) { + return buffer.slice(); + } + var length = buffer.length, + result = allocUnsafe ? allocUnsafe(length) : new buffer.constructor(length); + + buffer.copy(result); + return result; + } + + /** + * Creates a clone of `arrayBuffer`. + * + * @private + * @param {ArrayBuffer} arrayBuffer The array buffer to clone. + * @returns {ArrayBuffer} Returns the cloned array buffer. + */ + function cloneArrayBuffer(arrayBuffer) { + var result = new arrayBuffer.constructor(arrayBuffer.byteLength); + new Uint8Array(result).set(new Uint8Array(arrayBuffer)); + return result; + } + + /** + * Creates a clone of `dataView`. + * + * @private + * @param {Object} dataView The data view to clone. + * @param {boolean} [isDeep] Specify a deep clone. + * @returns {Object} Returns the cloned data view. + */ + function cloneDataView(dataView, isDeep) { + var buffer = isDeep ? cloneArrayBuffer(dataView.buffer) : dataView.buffer; + return new dataView.constructor(buffer, dataView.byteOffset, dataView.byteLength); + } + + /** + * Creates a clone of `map`. + * + * @private + * @param {Object} map The map to clone. + * @param {Function} cloneFunc The function to clone values. + * @param {boolean} [isDeep] Specify a deep clone. + * @returns {Object} Returns the cloned map. + */ + function cloneMap(map, isDeep, cloneFunc) { + var array = isDeep ? cloneFunc(mapToArray(map), true) : mapToArray(map); + return arrayReduce(array, addMapEntry, new map.constructor); + } + + /** + * Creates a clone of `regexp`. + * + * @private + * @param {Object} regexp The regexp to clone. + * @returns {Object} Returns the cloned regexp. + */ + function cloneRegExp(regexp) { + var result = new regexp.constructor(regexp.source, reFlags.exec(regexp)); + result.lastIndex = regexp.lastIndex; + return result; + } + + /** + * Creates a clone of `set`. + * + * @private + * @param {Object} set The set to clone. + * @param {Function} cloneFunc The function to clone values. + * @param {boolean} [isDeep] Specify a deep clone. + * @returns {Object} Returns the cloned set. + */ + function cloneSet(set, isDeep, cloneFunc) { + var array = isDeep ? cloneFunc(setToArray(set), true) : setToArray(set); + return arrayReduce(array, addSetEntry, new set.constructor); + } + + /** + * Creates a clone of the `symbol` object. + * + * @private + * @param {Object} symbol The symbol object to clone. + * @returns {Object} Returns the cloned symbol object. + */ + function cloneSymbol(symbol) { + return symbolValueOf ? Object(symbolValueOf.call(symbol)) : {}; + } + + /** + * Creates a clone of `typedArray`. + * + * @private + * @param {Object} typedArray The typed array to clone. + * @param {boolean} [isDeep] Specify a deep clone. + * @returns {Object} Returns the cloned typed array. + */ + function cloneTypedArray(typedArray, isDeep) { + var buffer = isDeep ? cloneArrayBuffer(typedArray.buffer) : typedArray.buffer; + return new typedArray.constructor(buffer, typedArray.byteOffset, typedArray.length); + } + + /** + * Compares values to sort them in ascending order. + * + * @private + * @param {*} value The value to compare. + * @param {*} other The other value to compare. + * @returns {number} Returns the sort order indicator for `value`. + */ + function compareAscending(value, other) { + if (value !== other) { + var valIsDefined = value !== undefined, + valIsNull = value === null, + valIsReflexive = value === value, + valIsSymbol = isSymbol(value); + + var othIsDefined = other !== undefined, + othIsNull = other === null, + othIsReflexive = other === other, + othIsSymbol = isSymbol(other); + + if ((!othIsNull && !othIsSymbol && !valIsSymbol && value > other) || + (valIsSymbol && othIsDefined && othIsReflexive && !othIsNull && !othIsSymbol) || + (valIsNull && othIsDefined && othIsReflexive) || + (!valIsDefined && othIsReflexive) || + !valIsReflexive) { + return 1; + } + if ((!valIsNull && !valIsSymbol && !othIsSymbol && value < other) || + (othIsSymbol && valIsDefined && valIsReflexive && !valIsNull && !valIsSymbol) || + (othIsNull && valIsDefined && valIsReflexive) || + (!othIsDefined && valIsReflexive) || + !othIsReflexive) { + return -1; + } + } + return 0; + } + + /** + * Used by `_.orderBy` to compare multiple properties of a value to another + * and stable sort them. + * + * If `orders` is unspecified, all values are sorted in ascending order. Otherwise, + * specify an order of "desc" for descending or "asc" for ascending sort order + * of corresponding values. + * + * @private + * @param {Object} object The object to compare. + * @param {Object} other The other object to compare. + * @param {boolean[]|string[]} orders The order to sort by for each property. + * @returns {number} Returns the sort order indicator for `object`. + */ + function compareMultiple(object, other, orders) { + var index = -1, + objCriteria = object.criteria, + othCriteria = other.criteria, + length = objCriteria.length, + ordersLength = orders.length; + + while (++index < length) { + var result = compareAscending(objCriteria[index], othCriteria[index]); + if (result) { + if (index >= ordersLength) { + return result; + } + var order = orders[index]; + return result * (order == 'desc' ? -1 : 1); + } + } + // Fixes an `Array#sort` bug in the JS engine embedded in Adobe applications + // that causes it, under certain circumstances, to provide the same value for + // `object` and `other`. See https://github.com/jashkenas/underscore/pull/1247 + // for more details. + // + // This also ensures a stable sort in V8 and other engines. + // See https://bugs.chromium.org/p/v8/issues/detail?id=90 for more details. + return object.index - other.index; + } + + /** + * Creates an array that is the composition of partially applied arguments, + * placeholders, and provided arguments into a single array of arguments. + * + * @private + * @param {Array} args The provided arguments. + * @param {Array} partials The arguments to prepend to those provided. + * @param {Array} holders The `partials` placeholder indexes. + * @params {boolean} [isCurried] Specify composing for a curried function. + * @returns {Array} Returns the new array of composed arguments. + */ + function composeArgs(args, partials, holders, isCurried) { + var argsIndex = -1, + argsLength = args.length, + holdersLength = holders.length, + leftIndex = -1, + leftLength = partials.length, + rangeLength = nativeMax(argsLength - holdersLength, 0), + result = Array(leftLength + rangeLength), + isUncurried = !isCurried; + + while (++leftIndex < leftLength) { + result[leftIndex] = partials[leftIndex]; + } + while (++argsIndex < holdersLength) { + if (isUncurried || argsIndex < argsLength) { + result[holders[argsIndex]] = args[argsIndex]; + } + } + while (rangeLength--) { + result[leftIndex++] = args[argsIndex++]; + } + return result; + } + + /** + * This function is like `composeArgs` except that the arguments composition + * is tailored for `_.partialRight`. + * + * @private + * @param {Array} args The provided arguments. + * @param {Array} partials The arguments to append to those provided. + * @param {Array} holders The `partials` placeholder indexes. + * @params {boolean} [isCurried] Specify composing for a curried function. + * @returns {Array} Returns the new array of composed arguments. + */ + function composeArgsRight(args, partials, holders, isCurried) { + var argsIndex = -1, + argsLength = args.length, + holdersIndex = -1, + holdersLength = holders.length, + rightIndex = -1, + rightLength = partials.length, + rangeLength = nativeMax(argsLength - holdersLength, 0), + result = Array(rangeLength + rightLength), + isUncurried = !isCurried; + + while (++argsIndex < rangeLength) { + result[argsIndex] = args[argsIndex]; + } + var offset = argsIndex; + while (++rightIndex < rightLength) { + result[offset + rightIndex] = partials[rightIndex]; + } + while (++holdersIndex < holdersLength) { + if (isUncurried || argsIndex < argsLength) { + result[offset + holders[holdersIndex]] = args[argsIndex++]; + } + } + return result; + } + + /** + * Copies the values of `source` to `array`. + * + * @private + * @param {Array} source The array to copy values from. + * @param {Array} [array=[]] The array to copy values to. + * @returns {Array} Returns `array`. + */ + function copyArray(source, array) { + var index = -1, + length = source.length; + + array || (array = Array(length)); + while (++index < length) { + array[index] = source[index]; + } + return array; + } + + /** + * Copies properties of `source` to `object`. + * + * @private + * @param {Object} source The object to copy properties from. + * @param {Array} props The property identifiers to copy. + * @param {Object} [object={}] The object to copy properties to. + * @param {Function} [customizer] The function to customize copied values. + * @returns {Object} Returns `object`. + */ + function copyObject(source, props, object, customizer) { + var isNew = !object; + object || (object = {}); + + var index = -1, + length = props.length; + + while (++index < length) { + var key = props[index]; + + var newValue = customizer + ? customizer(object[key], source[key], key, object, source) + : undefined; + + if (newValue === undefined) { + newValue = source[key]; + } + if (isNew) { + baseAssignValue(object, key, newValue); + } else { + assignValue(object, key, newValue); + } + } + return object; + } + + /** + * Copies own symbol properties of `source` to `object`. + * + * @private + * @param {Object} source The object to copy symbols from. + * @param {Object} [object={}] The object to copy symbols to. + * @returns {Object} Returns `object`. + */ + function copySymbols(source, object) { + return copyObject(source, getSymbols(source), object); + } + + /** + * Creates a function like `_.groupBy`. + * + * @private + * @param {Function} setter The function to set accumulator values. + * @param {Function} [initializer] The accumulator object initializer. + * @returns {Function} Returns the new aggregator function. + */ + function createAggregator(setter, initializer) { + return function(collection, iteratee) { + var func = isArray(collection) ? arrayAggregator : baseAggregator, + accumulator = initializer ? initializer() : {}; + + return func(collection, setter, getIteratee(iteratee, 2), accumulator); + }; + } + + /** + * Creates a function like `_.assign`. + * + * @private + * @param {Function} assigner The function to assign values. + * @returns {Function} Returns the new assigner function. + */ + function createAssigner(assigner) { + return baseRest(function(object, sources) { + var index = -1, + length = sources.length, + customizer = length > 1 ? sources[length - 1] : undefined, + guard = length > 2 ? sources[2] : undefined; + + customizer = (assigner.length > 3 && typeof customizer == 'function') + ? (length--, customizer) + : undefined; + + if (guard && isIterateeCall(sources[0], sources[1], guard)) { + customizer = length < 3 ? undefined : customizer; + length = 1; + } + object = Object(object); + while (++index < length) { + var source = sources[index]; + if (source) { + assigner(object, source, index, customizer); + } + } + return object; + }); + } + + /** + * Creates a `baseEach` or `baseEachRight` function. + * + * @private + * @param {Function} eachFunc The function to iterate over a collection. + * @param {boolean} [fromRight] Specify iterating from right to left. + * @returns {Function} Returns the new base function. + */ + function createBaseEach(eachFunc, fromRight) { + return function(collection, iteratee) { + if (collection == null) { + return collection; + } + if (!isArrayLike(collection)) { + return eachFunc(collection, iteratee); + } + var length = collection.length, + index = fromRight ? length : -1, + iterable = Object(collection); + + while ((fromRight ? index-- : ++index < length)) { + if (iteratee(iterable[index], index, iterable) === false) { + break; + } + } + return collection; + }; + } + + /** + * Creates a base function for methods like `_.forIn` and `_.forOwn`. + * + * @private + * @param {boolean} [fromRight] Specify iterating from right to left. + * @returns {Function} Returns the new base function. + */ + function createBaseFor(fromRight) { + return function(object, iteratee, keysFunc) { + var index = -1, + iterable = Object(object), + props = keysFunc(object), + length = props.length; + + while (length--) { + var key = props[fromRight ? length : ++index]; + if (iteratee(iterable[key], key, iterable) === false) { + break; + } + } + return object; + }; + } + + /** + * Creates a function that wraps `func` to invoke it with the optional `this` + * binding of `thisArg`. + * + * @private + * @param {Function} func The function to wrap. + * @param {number} bitmask The bitmask flags. See `createWrap` for more details. + * @param {*} [thisArg] The `this` binding of `func`. + * @returns {Function} Returns the new wrapped function. + */ + function createBind(func, bitmask, thisArg) { + var isBind = bitmask & BIND_FLAG, + Ctor = createCtor(func); + + function wrapper() { + var fn = (this && this !== root && this instanceof wrapper) ? Ctor : func; + return fn.apply(isBind ? thisArg : this, arguments); + } + return wrapper; + } + + /** + * Creates a function like `_.lowerFirst`. + * + * @private + * @param {string} methodName The name of the `String` case method to use. + * @returns {Function} Returns the new case function. + */ + function createCaseFirst(methodName) { + return function(string) { + string = toString(string); + + var strSymbols = hasUnicode(string) + ? stringToArray(string) + : undefined; + + var chr = strSymbols + ? strSymbols[0] + : string.charAt(0); + + var trailing = strSymbols + ? castSlice(strSymbols, 1).join('') + : string.slice(1); + + return chr[methodName]() + trailing; + }; + } + + /** + * Creates a function like `_.camelCase`. + * + * @private + * @param {Function} callback The function to combine each word. + * @returns {Function} Returns the new compounder function. + */ + function createCompounder(callback) { + return function(string) { + return arrayReduce(words(deburr(string).replace(reApos, '')), callback, ''); + }; + } + + /** + * Creates a function that produces an instance of `Ctor` regardless of + * whether it was invoked as part of a `new` expression or by `call` or `apply`. + * + * @private + * @param {Function} Ctor The constructor to wrap. + * @returns {Function} Returns the new wrapped function. + */ + function createCtor(Ctor) { + return function() { + // Use a `switch` statement to work with class constructors. See + // http://ecma-international.org/ecma-262/7.0/#sec-ecmascript-function-objects-call-thisargument-argumentslist + // for more details. + var args = arguments; + switch (args.length) { + case 0: return new Ctor; + case 1: return new Ctor(args[0]); + case 2: return new Ctor(args[0], args[1]); + case 3: return new Ctor(args[0], args[1], args[2]); + case 4: return new Ctor(args[0], args[1], args[2], args[3]); + case 5: return new Ctor(args[0], args[1], args[2], args[3], args[4]); + case 6: return new Ctor(args[0], args[1], args[2], args[3], args[4], args[5]); + case 7: return new Ctor(args[0], args[1], args[2], args[3], args[4], args[5], args[6]); + } + var thisBinding = baseCreate(Ctor.prototype), + result = Ctor.apply(thisBinding, args); + + // Mimic the constructor's `return` behavior. + // See https://es5.github.io/#x13.2.2 for more details. + return isObject(result) ? result : thisBinding; + }; + } + + /** + * Creates a function that wraps `func` to enable currying. + * + * @private + * @param {Function} func The function to wrap. + * @param {number} bitmask The bitmask flags. See `createWrap` for more details. + * @param {number} arity The arity of `func`. + * @returns {Function} Returns the new wrapped function. + */ + function createCurry(func, bitmask, arity) { + var Ctor = createCtor(func); + + function wrapper() { + var length = arguments.length, + args = Array(length), + index = length, + placeholder = getHolder(wrapper); + + while (index--) { + args[index] = arguments[index]; + } + var holders = (length < 3 && args[0] !== placeholder && args[length - 1] !== placeholder) + ? [] + : replaceHolders(args, placeholder); + + length -= holders.length; + if (length < arity) { + return createRecurry( + func, bitmask, createHybrid, wrapper.placeholder, undefined, + args, holders, undefined, undefined, arity - length); + } + var fn = (this && this !== root && this instanceof wrapper) ? Ctor : func; + return apply(fn, this, args); + } + return wrapper; + } + + /** + * Creates a `_.find` or `_.findLast` function. + * + * @private + * @param {Function} findIndexFunc The function to find the collection index. + * @returns {Function} Returns the new find function. + */ + function createFind(findIndexFunc) { + return function(collection, predicate, fromIndex) { + var iterable = Object(collection); + if (!isArrayLike(collection)) { + var iteratee = getIteratee(predicate, 3); + collection = keys(collection); + predicate = function(key) { return iteratee(iterable[key], key, iterable); }; + } + var index = findIndexFunc(collection, predicate, fromIndex); + return index > -1 ? iterable[iteratee ? collection[index] : index] : undefined; + }; + } + + /** + * Creates a `_.flow` or `_.flowRight` function. + * + * @private + * @param {boolean} [fromRight] Specify iterating from right to left. + * @returns {Function} Returns the new flow function. + */ + function createFlow(fromRight) { + return flatRest(function(funcs) { + var length = funcs.length, + index = length, + prereq = LodashWrapper.prototype.thru; + + if (fromRight) { + funcs.reverse(); + } + while (index--) { + var func = funcs[index]; + if (typeof func != 'function') { + throw new TypeError(FUNC_ERROR_TEXT); + } + if (prereq && !wrapper && getFuncName(func) == 'wrapper') { + var wrapper = new LodashWrapper([], true); + } + } + index = wrapper ? index : length; + while (++index < length) { + func = funcs[index]; + + var funcName = getFuncName(func), + data = funcName == 'wrapper' ? getData(func) : undefined; + + if (data && isLaziable(data[0]) && + data[1] == (ARY_FLAG | CURRY_FLAG | PARTIAL_FLAG | REARG_FLAG) && + !data[4].length && data[9] == 1 + ) { + wrapper = wrapper[getFuncName(data[0])].apply(wrapper, data[3]); + } else { + wrapper = (func.length == 1 && isLaziable(func)) + ? wrapper[funcName]() + : wrapper.thru(func); + } + } + return function() { + var args = arguments, + value = args[0]; + + if (wrapper && args.length == 1 && + isArray(value) && value.length >= LARGE_ARRAY_SIZE) { + return wrapper.plant(value).value(); + } + var index = 0, + result = length ? funcs[index].apply(this, args) : value; + + while (++index < length) { + result = funcs[index].call(this, result); + } + return result; + }; + }); + } + + /** + * Creates a function that wraps `func` to invoke it with optional `this` + * binding of `thisArg`, partial application, and currying. + * + * @private + * @param {Function|string} func The function or method name to wrap. + * @param {number} bitmask The bitmask flags. See `createWrap` for more details. + * @param {*} [thisArg] The `this` binding of `func`. + * @param {Array} [partials] The arguments to prepend to those provided to + * the new function. + * @param {Array} [holders] The `partials` placeholder indexes. + * @param {Array} [partialsRight] The arguments to append to those provided + * to the new function. + * @param {Array} [holdersRight] The `partialsRight` placeholder indexes. + * @param {Array} [argPos] The argument positions of the new function. + * @param {number} [ary] The arity cap of `func`. + * @param {number} [arity] The arity of `func`. + * @returns {Function} Returns the new wrapped function. + */ + function createHybrid(func, bitmask, thisArg, partials, holders, partialsRight, holdersRight, argPos, ary, arity) { + var isAry = bitmask & ARY_FLAG, + isBind = bitmask & BIND_FLAG, + isBindKey = bitmask & BIND_KEY_FLAG, + isCurried = bitmask & (CURRY_FLAG | CURRY_RIGHT_FLAG), + isFlip = bitmask & FLIP_FLAG, + Ctor = isBindKey ? undefined : createCtor(func); + + function wrapper() { + var length = arguments.length, + args = Array(length), + index = length; + + while (index--) { + args[index] = arguments[index]; + } + if (isCurried) { + var placeholder = getHolder(wrapper), + holdersCount = countHolders(args, placeholder); + } + if (partials) { + args = composeArgs(args, partials, holders, isCurried); + } + if (partialsRight) { + args = composeArgsRight(args, partialsRight, holdersRight, isCurried); + } + length -= holdersCount; + if (isCurried && length < arity) { + var newHolders = replaceHolders(args, placeholder); + return createRecurry( + func, bitmask, createHybrid, wrapper.placeholder, thisArg, + args, newHolders, argPos, ary, arity - length + ); + } + var thisBinding = isBind ? thisArg : this, + fn = isBindKey ? thisBinding[func] : func; + + length = args.length; + if (argPos) { + args = reorder(args, argPos); + } else if (isFlip && length > 1) { + args.reverse(); + } + if (isAry && ary < length) { + args.length = ary; + } + if (this && this !== root && this instanceof wrapper) { + fn = Ctor || createCtor(fn); + } + return fn.apply(thisBinding, args); + } + return wrapper; + } + + /** + * Creates a function like `_.invertBy`. + * + * @private + * @param {Function} setter The function to set accumulator values. + * @param {Function} toIteratee The function to resolve iteratees. + * @returns {Function} Returns the new inverter function. + */ + function createInverter(setter, toIteratee) { + return function(object, iteratee) { + return baseInverter(object, setter, toIteratee(iteratee), {}); + }; + } + + /** + * Creates a function that performs a mathematical operation on two values. + * + * @private + * @param {Function} operator The function to perform the operation. + * @param {number} [defaultValue] The value used for `undefined` arguments. + * @returns {Function} Returns the new mathematical operation function. + */ + function createMathOperation(operator, defaultValue) { + return function(value, other) { + var result; + if (value === undefined && other === undefined) { + return defaultValue; + } + if (value !== undefined) { + result = value; + } + if (other !== undefined) { + if (result === undefined) { + return other; + } + if (typeof value == 'string' || typeof other == 'string') { + value = baseToString(value); + other = baseToString(other); + } else { + value = baseToNumber(value); + other = baseToNumber(other); + } + result = operator(value, other); + } + return result; + }; + } + + /** + * Creates a function like `_.over`. + * + * @private + * @param {Function} arrayFunc The function to iterate over iteratees. + * @returns {Function} Returns the new over function. + */ + function createOver(arrayFunc) { + return flatRest(function(iteratees) { + iteratees = arrayMap(iteratees, baseUnary(getIteratee())); + return baseRest(function(args) { + var thisArg = this; + return arrayFunc(iteratees, function(iteratee) { + return apply(iteratee, thisArg, args); + }); + }); + }); + } + + /** + * Creates the padding for `string` based on `length`. The `chars` string + * is truncated if the number of characters exceeds `length`. + * + * @private + * @param {number} length The padding length. + * @param {string} [chars=' '] The string used as padding. + * @returns {string} Returns the padding for `string`. + */ + function createPadding(length, chars) { + chars = chars === undefined ? ' ' : baseToString(chars); + + var charsLength = chars.length; + if (charsLength < 2) { + return charsLength ? baseRepeat(chars, length) : chars; + } + var result = baseRepeat(chars, nativeCeil(length / stringSize(chars))); + return hasUnicode(chars) + ? castSlice(stringToArray(result), 0, length).join('') + : result.slice(0, length); + } + + /** + * Creates a function that wraps `func` to invoke it with the `this` binding + * of `thisArg` and `partials` prepended to the arguments it receives. + * + * @private + * @param {Function} func The function to wrap. + * @param {number} bitmask The bitmask flags. See `createWrap` for more details. + * @param {*} thisArg The `this` binding of `func`. + * @param {Array} partials The arguments to prepend to those provided to + * the new function. + * @returns {Function} Returns the new wrapped function. + */ + function createPartial(func, bitmask, thisArg, partials) { + var isBind = bitmask & BIND_FLAG, + Ctor = createCtor(func); + + function wrapper() { + var argsIndex = -1, + argsLength = arguments.length, + leftIndex = -1, + leftLength = partials.length, + args = Array(leftLength + argsLength), + fn = (this && this !== root && this instanceof wrapper) ? Ctor : func; + + while (++leftIndex < leftLength) { + args[leftIndex] = partials[leftIndex]; + } + while (argsLength--) { + args[leftIndex++] = arguments[++argsIndex]; + } + return apply(fn, isBind ? thisArg : this, args); + } + return wrapper; + } + + /** + * Creates a `_.range` or `_.rangeRight` function. + * + * @private + * @param {boolean} [fromRight] Specify iterating from right to left. + * @returns {Function} Returns the new range function. + */ + function createRange(fromRight) { + return function(start, end, step) { + if (step && typeof step != 'number' && isIterateeCall(start, end, step)) { + end = step = undefined; + } + // Ensure the sign of `-0` is preserved. + start = toFinite(start); + if (end === undefined) { + end = start; + start = 0; + } else { + end = toFinite(end); + } + step = step === undefined ? (start < end ? 1 : -1) : toFinite(step); + return baseRange(start, end, step, fromRight); + }; + } + + /** + * Creates a function that performs a relational operation on two values. + * + * @private + * @param {Function} operator The function to perform the operation. + * @returns {Function} Returns the new relational operation function. + */ + function createRelationalOperation(operator) { + return function(value, other) { + if (!(typeof value == 'string' && typeof other == 'string')) { + value = toNumber(value); + other = toNumber(other); + } + return operator(value, other); + }; + } + + /** + * Creates a function that wraps `func` to continue currying. + * + * @private + * @param {Function} func The function to wrap. + * @param {number} bitmask The bitmask flags. See `createWrap` for more details. + * @param {Function} wrapFunc The function to create the `func` wrapper. + * @param {*} placeholder The placeholder value. + * @param {*} [thisArg] The `this` binding of `func`. + * @param {Array} [partials] The arguments to prepend to those provided to + * the new function. + * @param {Array} [holders] The `partials` placeholder indexes. + * @param {Array} [argPos] The argument positions of the new function. + * @param {number} [ary] The arity cap of `func`. + * @param {number} [arity] The arity of `func`. + * @returns {Function} Returns the new wrapped function. + */ + function createRecurry(func, bitmask, wrapFunc, placeholder, thisArg, partials, holders, argPos, ary, arity) { + var isCurry = bitmask & CURRY_FLAG, + newHolders = isCurry ? holders : undefined, + newHoldersRight = isCurry ? undefined : holders, + newPartials = isCurry ? partials : undefined, + newPartialsRight = isCurry ? undefined : partials; + + bitmask |= (isCurry ? PARTIAL_FLAG : PARTIAL_RIGHT_FLAG); + bitmask &= ~(isCurry ? PARTIAL_RIGHT_FLAG : PARTIAL_FLAG); + + if (!(bitmask & CURRY_BOUND_FLAG)) { + bitmask &= ~(BIND_FLAG | BIND_KEY_FLAG); + } + var newData = [ + func, bitmask, thisArg, newPartials, newHolders, newPartialsRight, + newHoldersRight, argPos, ary, arity + ]; + + var result = wrapFunc.apply(undefined, newData); + if (isLaziable(func)) { + setData(result, newData); + } + result.placeholder = placeholder; + return setWrapToString(result, func, bitmask); + } + + /** + * Creates a function like `_.round`. + * + * @private + * @param {string} methodName The name of the `Math` method to use when rounding. + * @returns {Function} Returns the new round function. + */ + function createRound(methodName) { + var func = Math[methodName]; + return function(number, precision) { + number = toNumber(number); + precision = nativeMin(toInteger(precision), 292); + if (precision) { + // Shift with exponential notation to avoid floating-point issues. + // See [MDN](https://mdn.io/round#Examples) for more details. + var pair = (toString(number) + 'e').split('e'), + value = func(pair[0] + 'e' + (+pair[1] + precision)); + + pair = (toString(value) + 'e').split('e'); + return +(pair[0] + 'e' + (+pair[1] - precision)); + } + return func(number); + }; + } + + /** + * Creates a set object of `values`. + * + * @private + * @param {Array} values The values to add to the set. + * @returns {Object} Returns the new set. + */ + var createSet = !(Set && (1 / setToArray(new Set([,-0]))[1]) == INFINITY) ? noop : function(values) { + return new Set(values); + }; + + /** + * Creates a `_.toPairs` or `_.toPairsIn` function. + * + * @private + * @param {Function} keysFunc The function to get the keys of a given object. + * @returns {Function} Returns the new pairs function. + */ + function createToPairs(keysFunc) { + return function(object) { + var tag = getTag(object); + if (tag == mapTag) { + return mapToArray(object); + } + if (tag == setTag) { + return setToPairs(object); + } + return baseToPairs(object, keysFunc(object)); + }; + } + + /** + * Creates a function that either curries or invokes `func` with optional + * `this` binding and partially applied arguments. + * + * @private + * @param {Function|string} func The function or method name to wrap. + * @param {number} bitmask The bitmask flags. + * The bitmask may be composed of the following flags: + * 1 - `_.bind` + * 2 - `_.bindKey` + * 4 - `_.curry` or `_.curryRight` of a bound function + * 8 - `_.curry` + * 16 - `_.curryRight` + * 32 - `_.partial` + * 64 - `_.partialRight` + * 128 - `_.rearg` + * 256 - `_.ary` + * 512 - `_.flip` + * @param {*} [thisArg] The `this` binding of `func`. + * @param {Array} [partials] The arguments to be partially applied. + * @param {Array} [holders] The `partials` placeholder indexes. + * @param {Array} [argPos] The argument positions of the new function. + * @param {number} [ary] The arity cap of `func`. + * @param {number} [arity] The arity of `func`. + * @returns {Function} Returns the new wrapped function. + */ + function createWrap(func, bitmask, thisArg, partials, holders, argPos, ary, arity) { + var isBindKey = bitmask & BIND_KEY_FLAG; + if (!isBindKey && typeof func != 'function') { + throw new TypeError(FUNC_ERROR_TEXT); + } + var length = partials ? partials.length : 0; + if (!length) { + bitmask &= ~(PARTIAL_FLAG | PARTIAL_RIGHT_FLAG); + partials = holders = undefined; + } + ary = ary === undefined ? ary : nativeMax(toInteger(ary), 0); + arity = arity === undefined ? arity : toInteger(arity); + length -= holders ? holders.length : 0; + + if (bitmask & PARTIAL_RIGHT_FLAG) { + var partialsRight = partials, + holdersRight = holders; + + partials = holders = undefined; + } + var data = isBindKey ? undefined : getData(func); + + var newData = [ + func, bitmask, thisArg, partials, holders, partialsRight, holdersRight, + argPos, ary, arity + ]; + + if (data) { + mergeData(newData, data); + } + func = newData[0]; + bitmask = newData[1]; + thisArg = newData[2]; + partials = newData[3]; + holders = newData[4]; + arity = newData[9] = newData[9] == null + ? (isBindKey ? 0 : func.length) + : nativeMax(newData[9] - length, 0); + + if (!arity && bitmask & (CURRY_FLAG | CURRY_RIGHT_FLAG)) { + bitmask &= ~(CURRY_FLAG | CURRY_RIGHT_FLAG); + } + if (!bitmask || bitmask == BIND_FLAG) { + var result = createBind(func, bitmask, thisArg); + } else if (bitmask == CURRY_FLAG || bitmask == CURRY_RIGHT_FLAG) { + result = createCurry(func, bitmask, arity); + } else if ((bitmask == PARTIAL_FLAG || bitmask == (BIND_FLAG | PARTIAL_FLAG)) && !holders.length) { + result = createPartial(func, bitmask, thisArg, partials); + } else { + result = createHybrid.apply(undefined, newData); + } + var setter = data ? baseSetData : setData; + return setWrapToString(setter(result, newData), func, bitmask); + } + + /** + * A specialized version of `baseIsEqualDeep` for arrays with support for + * partial deep comparisons. + * + * @private + * @param {Array} array The array to compare. + * @param {Array} other The other array to compare. + * @param {Function} equalFunc The function to determine equivalents of values. + * @param {Function} customizer The function to customize comparisons. + * @param {number} bitmask The bitmask of comparison flags. See `baseIsEqual` + * for more details. + * @param {Object} stack Tracks traversed `array` and `other` objects. + * @returns {boolean} Returns `true` if the arrays are equivalent, else `false`. + */ + function equalArrays(array, other, equalFunc, customizer, bitmask, stack) { + var isPartial = bitmask & PARTIAL_COMPARE_FLAG, + arrLength = array.length, + othLength = other.length; + + if (arrLength != othLength && !(isPartial && othLength > arrLength)) { + return false; + } + // Assume cyclic values are equal. + var stacked = stack.get(array); + if (stacked && stack.get(other)) { + return stacked == other; + } + var index = -1, + result = true, + seen = (bitmask & UNORDERED_COMPARE_FLAG) ? new SetCache : undefined; + + stack.set(array, other); + stack.set(other, array); + + // Ignore non-index properties. + while (++index < arrLength) { + var arrValue = array[index], + othValue = other[index]; + + if (customizer) { + var compared = isPartial + ? customizer(othValue, arrValue, index, other, array, stack) + : customizer(arrValue, othValue, index, array, other, stack); + } + if (compared !== undefined) { + if (compared) { + continue; + } + result = false; + break; + } + // Recursively compare arrays (susceptible to call stack limits). + if (seen) { + if (!arraySome(other, function(othValue, othIndex) { + if (!cacheHas(seen, othIndex) && + (arrValue === othValue || equalFunc(arrValue, othValue, customizer, bitmask, stack))) { + return seen.push(othIndex); + } + })) { + result = false; + break; + } + } else if (!( + arrValue === othValue || + equalFunc(arrValue, othValue, customizer, bitmask, stack) + )) { + result = false; + break; + } + } + stack['delete'](array); + stack['delete'](other); + return result; + } + + /** + * A specialized version of `baseIsEqualDeep` for comparing objects of + * the same `toStringTag`. + * + * **Note:** This function only supports comparing values with tags of + * `Boolean`, `Date`, `Error`, `Number`, `RegExp`, or `String`. + * + * @private + * @param {Object} object The object to compare. + * @param {Object} other The other object to compare. + * @param {string} tag The `toStringTag` of the objects to compare. + * @param {Function} equalFunc The function to determine equivalents of values. + * @param {Function} customizer The function to customize comparisons. + * @param {number} bitmask The bitmask of comparison flags. See `baseIsEqual` + * for more details. + * @param {Object} stack Tracks traversed `object` and `other` objects. + * @returns {boolean} Returns `true` if the objects are equivalent, else `false`. + */ + function equalByTag(object, other, tag, equalFunc, customizer, bitmask, stack) { + switch (tag) { + case dataViewTag: + if ((object.byteLength != other.byteLength) || + (object.byteOffset != other.byteOffset)) { + return false; + } + object = object.buffer; + other = other.buffer; + + case arrayBufferTag: + if ((object.byteLength != other.byteLength) || + !equalFunc(new Uint8Array(object), new Uint8Array(other))) { + return false; + } + return true; + + case boolTag: + case dateTag: + case numberTag: + // Coerce booleans to `1` or `0` and dates to milliseconds. + // Invalid dates are coerced to `NaN`. + return eq(+object, +other); + + case errorTag: + return object.name == other.name && object.message == other.message; + + case regexpTag: + case stringTag: + // Coerce regexes to strings and treat strings, primitives and objects, + // as equal. See http://www.ecma-international.org/ecma-262/7.0/#sec-regexp.prototype.tostring + // for more details. + return object == (other + ''); + + case mapTag: + var convert = mapToArray; + + case setTag: + var isPartial = bitmask & PARTIAL_COMPARE_FLAG; + convert || (convert = setToArray); + + if (object.size != other.size && !isPartial) { + return false; + } + // Assume cyclic values are equal. + var stacked = stack.get(object); + if (stacked) { + return stacked == other; + } + bitmask |= UNORDERED_COMPARE_FLAG; + + // Recursively compare objects (susceptible to call stack limits). + stack.set(object, other); + var result = equalArrays(convert(object), convert(other), equalFunc, customizer, bitmask, stack); + stack['delete'](object); + return result; + + case symbolTag: + if (symbolValueOf) { + return symbolValueOf.call(object) == symbolValueOf.call(other); + } + } + return false; + } + + /** + * A specialized version of `baseIsEqualDeep` for objects with support for + * partial deep comparisons. + * + * @private + * @param {Object} object The object to compare. + * @param {Object} other The other object to compare. + * @param {Function} equalFunc The function to determine equivalents of values. + * @param {Function} customizer The function to customize comparisons. + * @param {number} bitmask The bitmask of comparison flags. See `baseIsEqual` + * for more details. + * @param {Object} stack Tracks traversed `object` and `other` objects. + * @returns {boolean} Returns `true` if the objects are equivalent, else `false`. + */ + function equalObjects(object, other, equalFunc, customizer, bitmask, stack) { + var isPartial = bitmask & PARTIAL_COMPARE_FLAG, + objProps = keys(object), + objLength = objProps.length, + othProps = keys(other), + othLength = othProps.length; + + if (objLength != othLength && !isPartial) { + return false; + } + var index = objLength; + while (index--) { + var key = objProps[index]; + if (!(isPartial ? key in other : hasOwnProperty.call(other, key))) { + return false; + } + } + // Assume cyclic values are equal. + var stacked = stack.get(object); + if (stacked && stack.get(other)) { + return stacked == other; + } + var result = true; + stack.set(object, other); + stack.set(other, object); + + var skipCtor = isPartial; + while (++index < objLength) { + key = objProps[index]; + var objValue = object[key], + othValue = other[key]; + + if (customizer) { + var compared = isPartial + ? customizer(othValue, objValue, key, other, object, stack) + : customizer(objValue, othValue, key, object, other, stack); + } + // Recursively compare objects (susceptible to call stack limits). + if (!(compared === undefined + ? (objValue === othValue || equalFunc(objValue, othValue, customizer, bitmask, stack)) + : compared + )) { + result = false; + break; + } + skipCtor || (skipCtor = key == 'constructor'); + } + if (result && !skipCtor) { + var objCtor = object.constructor, + othCtor = other.constructor; + + // Non `Object` object instances with different constructors are not equal. + if (objCtor != othCtor && + ('constructor' in object && 'constructor' in other) && + !(typeof objCtor == 'function' && objCtor instanceof objCtor && + typeof othCtor == 'function' && othCtor instanceof othCtor)) { + result = false; + } + } + stack['delete'](object); + stack['delete'](other); + return result; + } + + /** + * A specialized version of `baseRest` which flattens the rest array. + * + * @private + * @param {Function} func The function to apply a rest parameter to. + * @returns {Function} Returns the new function. + */ + function flatRest(func) { + return setToString(overRest(func, undefined, flatten), func + ''); + } + + /** + * Creates an array of own enumerable property names and symbols of `object`. + * + * @private + * @param {Object} object The object to query. + * @returns {Array} Returns the array of property names and symbols. + */ + function getAllKeys(object) { + return baseGetAllKeys(object, keys, getSymbols); + } + + /** + * Creates an array of own and inherited enumerable property names and + * symbols of `object`. + * + * @private + * @param {Object} object The object to query. + * @returns {Array} Returns the array of property names and symbols. + */ + function getAllKeysIn(object) { + return baseGetAllKeys(object, keysIn, getSymbolsIn); + } + + /** + * Gets metadata for `func`. + * + * @private + * @param {Function} func The function to query. + * @returns {*} Returns the metadata for `func`. + */ + var getData = !metaMap ? noop : function(func) { + return metaMap.get(func); + }; + + /** + * Gets the name of `func`. + * + * @private + * @param {Function} func The function to query. + * @returns {string} Returns the function name. + */ + function getFuncName(func) { + var result = (func.name + ''), + array = realNames[result], + length = hasOwnProperty.call(realNames, result) ? array.length : 0; + + while (length--) { + var data = array[length], + otherFunc = data.func; + if (otherFunc == null || otherFunc == func) { + return data.name; + } + } + return result; + } + + /** + * Gets the argument placeholder value for `func`. + * + * @private + * @param {Function} func The function to inspect. + * @returns {*} Returns the placeholder value. + */ + function getHolder(func) { + var object = hasOwnProperty.call(lodash, 'placeholder') ? lodash : func; + return object.placeholder; + } + + /** + * Gets the appropriate "iteratee" function. If `_.iteratee` is customized, + * this function returns the custom method, otherwise it returns `baseIteratee`. + * If arguments are provided, the chosen function is invoked with them and + * its result is returned. + * + * @private + * @param {*} [value] The value to convert to an iteratee. + * @param {number} [arity] The arity of the created iteratee. + * @returns {Function} Returns the chosen function or its result. + */ + function getIteratee() { + var result = lodash.iteratee || iteratee; + result = result === iteratee ? baseIteratee : result; + return arguments.length ? result(arguments[0], arguments[1]) : result; + } + + /** + * Gets the data for `map`. + * + * @private + * @param {Object} map The map to query. + * @param {string} key The reference key. + * @returns {*} Returns the map data. + */ + function getMapData(map, key) { + var data = map.__data__; + return isKeyable(key) + ? data[typeof key == 'string' ? 'string' : 'hash'] + : data.map; + } + + /** + * Gets the property names, values, and compare flags of `object`. + * + * @private + * @param {Object} object The object to query. + * @returns {Array} Returns the match data of `object`. + */ + function getMatchData(object) { + var result = keys(object), + length = result.length; + + while (length--) { + var key = result[length], + value = object[key]; + + result[length] = [key, value, isStrictComparable(value)]; + } + return result; + } + + /** + * Gets the native function at `key` of `object`. + * + * @private + * @param {Object} object The object to query. + * @param {string} key The key of the method to get. + * @returns {*} Returns the function if it's native, else `undefined`. + */ + function getNative(object, key) { + var value = getValue(object, key); + return baseIsNative(value) ? value : undefined; + } + + /** + * Creates an array of the own enumerable symbol properties of `object`. + * + * @private + * @param {Object} object The object to query. + * @returns {Array} Returns the array of symbols. + */ + var getSymbols = nativeGetSymbols ? overArg(nativeGetSymbols, Object) : stubArray; + + /** + * Creates an array of the own and inherited enumerable symbol properties + * of `object`. + * + * @private + * @param {Object} object The object to query. + * @returns {Array} Returns the array of symbols. + */ + var getSymbolsIn = !nativeGetSymbols ? stubArray : function(object) { + var result = []; + while (object) { + arrayPush(result, getSymbols(object)); + object = getPrototype(object); + } + return result; + }; + + /** + * Gets the `toStringTag` of `value`. + * + * @private + * @param {*} value The value to query. + * @returns {string} Returns the `toStringTag`. + */ + var getTag = baseGetTag; + + // Fallback for data views, maps, sets, and weak maps in IE 11 and promises in Node.js < 6. + if ((DataView && getTag(new DataView(new ArrayBuffer(1))) != dataViewTag) || + (Map && getTag(new Map) != mapTag) || + (Promise && getTag(Promise.resolve()) != promiseTag) || + (Set && getTag(new Set) != setTag) || + (WeakMap && getTag(new WeakMap) != weakMapTag)) { + getTag = function(value) { + var result = objectToString.call(value), + Ctor = result == objectTag ? value.constructor : undefined, + ctorString = Ctor ? toSource(Ctor) : undefined; + + if (ctorString) { + switch (ctorString) { + case dataViewCtorString: return dataViewTag; + case mapCtorString: return mapTag; + case promiseCtorString: return promiseTag; + case setCtorString: return setTag; + case weakMapCtorString: return weakMapTag; + } + } + return result; + }; + } + + /** + * Gets the view, applying any `transforms` to the `start` and `end` positions. + * + * @private + * @param {number} start The start of the view. + * @param {number} end The end of the view. + * @param {Array} transforms The transformations to apply to the view. + * @returns {Object} Returns an object containing the `start` and `end` + * positions of the view. + */ + function getView(start, end, transforms) { + var index = -1, + length = transforms.length; + + while (++index < length) { + var data = transforms[index], + size = data.size; + + switch (data.type) { + case 'drop': start += size; break; + case 'dropRight': end -= size; break; + case 'take': end = nativeMin(end, start + size); break; + case 'takeRight': start = nativeMax(start, end - size); break; + } + } + return { 'start': start, 'end': end }; + } + + /** + * Extracts wrapper details from the `source` body comment. + * + * @private + * @param {string} source The source to inspect. + * @returns {Array} Returns the wrapper details. + */ + function getWrapDetails(source) { + var match = source.match(reWrapDetails); + return match ? match[1].split(reSplitDetails) : []; + } + + /** + * Checks if `path` exists on `object`. + * + * @private + * @param {Object} object The object to query. + * @param {Array|string} path The path to check. + * @param {Function} hasFunc The function to check properties. + * @returns {boolean} Returns `true` if `path` exists, else `false`. + */ + function hasPath(object, path, hasFunc) { + path = isKey(path, object) ? [path] : castPath(path); + + var index = -1, + length = path.length, + result = false; + + while (++index < length) { + var key = toKey(path[index]); + if (!(result = object != null && hasFunc(object, key))) { + break; + } + object = object[key]; + } + if (result || ++index != length) { + return result; + } + length = object ? object.length : 0; + return !!length && isLength(length) && isIndex(key, length) && + (isArray(object) || isArguments(object)); + } + + /** + * Initializes an array clone. + * + * @private + * @param {Array} array The array to clone. + * @returns {Array} Returns the initialized clone. + */ + function initCloneArray(array) { + var length = array.length, + result = array.constructor(length); + + // Add properties assigned by `RegExp#exec`. + if (length && typeof array[0] == 'string' && hasOwnProperty.call(array, 'index')) { + result.index = array.index; + result.input = array.input; + } + return result; + } + + /** + * Initializes an object clone. + * + * @private + * @param {Object} object The object to clone. + * @returns {Object} Returns the initialized clone. + */ + function initCloneObject(object) { + return (typeof object.constructor == 'function' && !isPrototype(object)) + ? baseCreate(getPrototype(object)) + : {}; + } + + /** + * Initializes an object clone based on its `toStringTag`. + * + * **Note:** This function only supports cloning values with tags of + * `Boolean`, `Date`, `Error`, `Number`, `RegExp`, or `String`. + * + * @private + * @param {Object} object The object to clone. + * @param {string} tag The `toStringTag` of the object to clone. + * @param {Function} cloneFunc The function to clone values. + * @param {boolean} [isDeep] Specify a deep clone. + * @returns {Object} Returns the initialized clone. + */ + function initCloneByTag(object, tag, cloneFunc, isDeep) { + var Ctor = object.constructor; + switch (tag) { + case arrayBufferTag: + return cloneArrayBuffer(object); + + case boolTag: + case dateTag: + return new Ctor(+object); + + case dataViewTag: + return cloneDataView(object, isDeep); + + case float32Tag: case float64Tag: + case int8Tag: case int16Tag: case int32Tag: + case uint8Tag: case uint8ClampedTag: case uint16Tag: case uint32Tag: + return cloneTypedArray(object, isDeep); + + case mapTag: + return cloneMap(object, isDeep, cloneFunc); + + case numberTag: + case stringTag: + return new Ctor(object); + + case regexpTag: + return cloneRegExp(object); + + case setTag: + return cloneSet(object, isDeep, cloneFunc); + + case symbolTag: + return cloneSymbol(object); + } + } + + /** + * Inserts wrapper `details` in a comment at the top of the `source` body. + * + * @private + * @param {string} source The source to modify. + * @returns {Array} details The details to insert. + * @returns {string} Returns the modified source. + */ + function insertWrapDetails(source, details) { + var length = details.length; + if (!length) { + return source; + } + var lastIndex = length - 1; + details[lastIndex] = (length > 1 ? '& ' : '') + details[lastIndex]; + details = details.join(length > 2 ? ', ' : ' '); + return source.replace(reWrapComment, '{\n/* [wrapped with ' + details + '] */\n'); + } + + /** + * Checks if `value` is a flattenable `arguments` object or array. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is flattenable, else `false`. + */ + function isFlattenable(value) { + return isArray(value) || isArguments(value) || + !!(spreadableSymbol && value && value[spreadableSymbol]); + } + + /** + * Checks if `value` is a valid array-like index. + * + * @private + * @param {*} value The value to check. + * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index. + * @returns {boolean} Returns `true` if `value` is a valid index, else `false`. + */ + function isIndex(value, length) { + length = length == null ? MAX_SAFE_INTEGER : length; + return !!length && + (typeof value == 'number' || reIsUint.test(value)) && + (value > -1 && value % 1 == 0 && value < length); + } + + /** + * Checks if the given arguments are from an iteratee call. + * + * @private + * @param {*} value The potential iteratee value argument. + * @param {*} index The potential iteratee index or key argument. + * @param {*} object The potential iteratee object argument. + * @returns {boolean} Returns `true` if the arguments are from an iteratee call, + * else `false`. + */ + function isIterateeCall(value, index, object) { + if (!isObject(object)) { + return false; + } + var type = typeof index; + if (type == 'number' + ? (isArrayLike(object) && isIndex(index, object.length)) + : (type == 'string' && index in object) + ) { + return eq(object[index], value); + } + return false; + } + + /** + * Checks if `value` is a property name and not a property path. + * + * @private + * @param {*} value The value to check. + * @param {Object} [object] The object to query keys on. + * @returns {boolean} Returns `true` if `value` is a property name, else `false`. + */ + function isKey(value, object) { + if (isArray(value)) { + return false; + } + var type = typeof value; + if (type == 'number' || type == 'symbol' || type == 'boolean' || + value == null || isSymbol(value)) { + return true; + } + return reIsPlainProp.test(value) || !reIsDeepProp.test(value) || + (object != null && value in Object(object)); + } + + /** + * Checks if `value` is suitable for use as unique object key. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is suitable, else `false`. + */ + function isKeyable(value) { + var type = typeof value; + return (type == 'string' || type == 'number' || type == 'symbol' || type == 'boolean') + ? (value !== '__proto__') + : (value === null); + } + + /** + * Checks if `func` has a lazy counterpart. + * + * @private + * @param {Function} func The function to check. + * @returns {boolean} Returns `true` if `func` has a lazy counterpart, + * else `false`. + */ + function isLaziable(func) { + var funcName = getFuncName(func), + other = lodash[funcName]; + + if (typeof other != 'function' || !(funcName in LazyWrapper.prototype)) { + return false; + } + if (func === other) { + return true; + } + var data = getData(other); + return !!data && func === data[0]; + } + + /** + * Checks if `func` has its source masked. + * + * @private + * @param {Function} func The function to check. + * @returns {boolean} Returns `true` if `func` is masked, else `false`. + */ + function isMasked(func) { + return !!maskSrcKey && (maskSrcKey in func); + } + + /** + * Checks if `func` is capable of being masked. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `func` is maskable, else `false`. + */ + var isMaskable = coreJsData ? isFunction : stubFalse; + + /** + * Checks if `value` is likely a prototype object. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a prototype, else `false`. + */ + function isPrototype(value) { + var Ctor = value && value.constructor, + proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto; + + return value === proto; + } + + /** + * Checks if `value` is suitable for strict equality comparisons, i.e. `===`. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` if suitable for strict + * equality comparisons, else `false`. + */ + function isStrictComparable(value) { + return value === value && !isObject(value); + } + + /** + * A specialized version of `matchesProperty` for source values suitable + * for strict equality comparisons, i.e. `===`. + * + * @private + * @param {string} key The key of the property to get. + * @param {*} srcValue The value to match. + * @returns {Function} Returns the new spec function. + */ + function matchesStrictComparable(key, srcValue) { + return function(object) { + if (object == null) { + return false; + } + return object[key] === srcValue && + (srcValue !== undefined || (key in Object(object))); + }; + } + + /** + * A specialized version of `_.memoize` which clears the memoized function's + * cache when it exceeds `MAX_MEMOIZE_SIZE`. + * + * @private + * @param {Function} func The function to have its output memoized. + * @returns {Function} Returns the new memoized function. + */ + function memoizeCapped(func) { + var result = memoize(func, function(key) { + if (cache.size === MAX_MEMOIZE_SIZE) { + cache.clear(); + } + return key; + }); + + var cache = result.cache; + return result; + } + + /** + * Merges the function metadata of `source` into `data`. + * + * Merging metadata reduces the number of wrappers used to invoke a function. + * This is possible because methods like `_.bind`, `_.curry`, and `_.partial` + * may be applied regardless of execution order. Methods like `_.ary` and + * `_.rearg` modify function arguments, making the order in which they are + * executed important, preventing the merging of metadata. However, we make + * an exception for a safe combined case where curried functions have `_.ary` + * and or `_.rearg` applied. + * + * @private + * @param {Array} data The destination metadata. + * @param {Array} source The source metadata. + * @returns {Array} Returns `data`. + */ + function mergeData(data, source) { + var bitmask = data[1], + srcBitmask = source[1], + newBitmask = bitmask | srcBitmask, + isCommon = newBitmask < (BIND_FLAG | BIND_KEY_FLAG | ARY_FLAG); + + var isCombo = + ((srcBitmask == ARY_FLAG) && (bitmask == CURRY_FLAG)) || + ((srcBitmask == ARY_FLAG) && (bitmask == REARG_FLAG) && (data[7].length <= source[8])) || + ((srcBitmask == (ARY_FLAG | REARG_FLAG)) && (source[7].length <= source[8]) && (bitmask == CURRY_FLAG)); + + // Exit early if metadata can't be merged. + if (!(isCommon || isCombo)) { + return data; + } + // Use source `thisArg` if available. + if (srcBitmask & BIND_FLAG) { + data[2] = source[2]; + // Set when currying a bound function. + newBitmask |= bitmask & BIND_FLAG ? 0 : CURRY_BOUND_FLAG; + } + // Compose partial arguments. + var value = source[3]; + if (value) { + var partials = data[3]; + data[3] = partials ? composeArgs(partials, value, source[4]) : value; + data[4] = partials ? replaceHolders(data[3], PLACEHOLDER) : source[4]; + } + // Compose partial right arguments. + value = source[5]; + if (value) { + partials = data[5]; + data[5] = partials ? composeArgsRight(partials, value, source[6]) : value; + data[6] = partials ? replaceHolders(data[5], PLACEHOLDER) : source[6]; + } + // Use source `argPos` if available. + value = source[7]; + if (value) { + data[7] = value; + } + // Use source `ary` if it's smaller. + if (srcBitmask & ARY_FLAG) { + data[8] = data[8] == null ? source[8] : nativeMin(data[8], source[8]); + } + // Use source `arity` if one is not provided. + if (data[9] == null) { + data[9] = source[9]; + } + // Use source `func` and merge bitmasks. + data[0] = source[0]; + data[1] = newBitmask; + + return data; + } + + /** + * Used by `_.defaultsDeep` to customize its `_.merge` use. + * + * @private + * @param {*} objValue The destination value. + * @param {*} srcValue The source value. + * @param {string} key The key of the property to merge. + * @param {Object} object The parent object of `objValue`. + * @param {Object} source The parent object of `srcValue`. + * @param {Object} [stack] Tracks traversed source values and their merged + * counterparts. + * @returns {*} Returns the value to assign. + */ + function mergeDefaults(objValue, srcValue, key, object, source, stack) { + if (isObject(objValue) && isObject(srcValue)) { + // Recursively merge objects and arrays (susceptible to call stack limits). + stack.set(srcValue, objValue); + baseMerge(objValue, srcValue, undefined, mergeDefaults, stack); + stack['delete'](srcValue); + } + return objValue; + } + + /** + * This function is like + * [`Object.keys`](http://ecma-international.org/ecma-262/7.0/#sec-object.keys) + * except that it includes inherited enumerable properties. + * + * @private + * @param {Object} object The object to query. + * @returns {Array} Returns the array of property names. + */ + function nativeKeysIn(object) { + var result = []; + if (object != null) { + for (var key in Object(object)) { + result.push(key); + } + } + return result; + } + + /** + * A specialized version of `baseRest` which transforms the rest array. + * + * @private + * @param {Function} func The function to apply a rest parameter to. + * @param {number} [start=func.length-1] The start position of the rest parameter. + * @param {Function} transform The rest array transform. + * @returns {Function} Returns the new function. + */ + function overRest(func, start, transform) { + start = nativeMax(start === undefined ? (func.length - 1) : start, 0); + return function() { + var args = arguments, + index = -1, + length = nativeMax(args.length - start, 0), + array = Array(length); + + while (++index < length) { + array[index] = args[start + index]; + } + index = -1; + var otherArgs = Array(start + 1); + while (++index < start) { + otherArgs[index] = args[index]; + } + otherArgs[start] = transform(array); + return apply(func, this, otherArgs); + }; + } + + /** + * Gets the parent value at `path` of `object`. + * + * @private + * @param {Object} object The object to query. + * @param {Array} path The path to get the parent value of. + * @returns {*} Returns the parent value. + */ + function parent(object, path) { + return path.length == 1 ? object : baseGet(object, baseSlice(path, 0, -1)); + } + + /** + * Reorder `array` according to the specified indexes where the element at + * the first index is assigned as the first element, the element at + * the second index is assigned as the second element, and so on. + * + * @private + * @param {Array} array The array to reorder. + * @param {Array} indexes The arranged array indexes. + * @returns {Array} Returns `array`. + */ + function reorder(array, indexes) { + var arrLength = array.length, + length = nativeMin(indexes.length, arrLength), + oldArray = copyArray(array); + + while (length--) { + var index = indexes[length]; + array[length] = isIndex(index, arrLength) ? oldArray[index] : undefined; + } + return array; + } + + /** + * Sets metadata for `func`. + * + * **Note:** If this function becomes hot, i.e. is invoked a lot in a short + * period of time, it will trip its breaker and transition to an identity + * function to avoid garbage collection pauses in V8. See + * [V8 issue 2070](https://bugs.chromium.org/p/v8/issues/detail?id=2070) + * for more details. + * + * @private + * @param {Function} func The function to associate metadata with. + * @param {*} data The metadata. + * @returns {Function} Returns `func`. + */ + var setData = shortOut(baseSetData); + + /** + * A simple wrapper around the global [`setTimeout`](https://mdn.io/setTimeout). + * + * @private + * @param {Function} func The function to delay. + * @param {number} wait The number of milliseconds to delay invocation. + * @returns {number|Object} Returns the timer id or timeout object. + */ + var setTimeout = ctxSetTimeout || function(func, wait) { + return root.setTimeout(func, wait); + }; + + /** + * Sets the `toString` method of `func` to return `string`. + * + * @private + * @param {Function} func The function to modify. + * @param {Function} string The `toString` result. + * @returns {Function} Returns `func`. + */ + var setToString = shortOut(baseSetToString); + + /** + * Sets the `toString` method of `wrapper` to mimic the source of `reference` + * with wrapper details in a comment at the top of the source body. + * + * @private + * @param {Function} wrapper The function to modify. + * @param {Function} reference The reference function. + * @param {number} bitmask The bitmask flags. See `createWrap` for more details. + * @returns {Function} Returns `wrapper`. + */ + function setWrapToString(wrapper, reference, bitmask) { + var source = (reference + ''); + return setToString(wrapper, insertWrapDetails(source, updateWrapDetails(getWrapDetails(source), bitmask))); + } + + /** + * Creates a function that'll short out and invoke `identity` instead + * of `func` when it's called `HOT_COUNT` or more times in `HOT_SPAN` + * milliseconds. + * + * @private + * @param {Function} func The function to restrict. + * @returns {Function} Returns the new shortable function. + */ + function shortOut(func) { + var count = 0, + lastCalled = 0; + + return function() { + var stamp = nativeNow(), + remaining = HOT_SPAN - (stamp - lastCalled); + + lastCalled = stamp; + if (remaining > 0) { + if (++count >= HOT_COUNT) { + return arguments[0]; + } + } else { + count = 0; + } + return func.apply(undefined, arguments); + }; + } + + /** + * A specialized version of `_.shuffle` which mutates and sets the size of `array`. + * + * @private + * @param {Array} array The array to shuffle. + * @param {number} [size=array.length] The size of `array`. + * @returns {Array} Returns `array`. + */ + function shuffleSelf(array, size) { + var index = -1, + length = array.length, + lastIndex = length - 1; + + size = size === undefined ? length : size; + while (++index < size) { + var rand = baseRandom(index, lastIndex), + value = array[rand]; + + array[rand] = array[index]; + array[index] = value; + } + array.length = size; + return array; + } + + /** + * Converts `string` to a property path array. + * + * @private + * @param {string} string The string to convert. + * @returns {Array} Returns the property path array. + */ + var stringToPath = memoizeCapped(function(string) { + string = toString(string); + + var result = []; + if (reLeadingDot.test(string)) { + result.push(''); + } + string.replace(rePropName, function(match, number, quote, string) { + result.push(quote ? string.replace(reEscapeChar, '$1') : (number || match)); + }); + return result; + }); + + /** + * Converts `value` to a string key if it's not a string or symbol. + * + * @private + * @param {*} value The value to inspect. + * @returns {string|symbol} Returns the key. + */ + function toKey(value) { + if (typeof value == 'string' || isSymbol(value)) { + return value; + } + var result = (value + ''); + return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result; + } + + /** + * Converts `func` to its source code. + * + * @private + * @param {Function} func The function to process. + * @returns {string} Returns the source code. + */ + function toSource(func) { + if (func != null) { + try { + return funcToString.call(func); + } catch (e) {} + try { + return (func + ''); + } catch (e) {} + } + return ''; + } + + /** + * Updates wrapper `details` based on `bitmask` flags. + * + * @private + * @returns {Array} details The details to modify. + * @param {number} bitmask The bitmask flags. See `createWrap` for more details. + * @returns {Array} Returns `details`. + */ + function updateWrapDetails(details, bitmask) { + arrayEach(wrapFlags, function(pair) { + var value = '_.' + pair[0]; + if ((bitmask & pair[1]) && !arrayIncludes(details, value)) { + details.push(value); + } + }); + return details.sort(); + } + + /** + * Creates a clone of `wrapper`. + * + * @private + * @param {Object} wrapper The wrapper to clone. + * @returns {Object} Returns the cloned wrapper. + */ + function wrapperClone(wrapper) { + if (wrapper instanceof LazyWrapper) { + return wrapper.clone(); + } + var result = new LodashWrapper(wrapper.__wrapped__, wrapper.__chain__); + result.__actions__ = copyArray(wrapper.__actions__); + result.__index__ = wrapper.__index__; + result.__values__ = wrapper.__values__; + return result; + } + + /*------------------------------------------------------------------------*/ + + /** + * Creates an array of elements split into groups the length of `size`. + * If `array` can't be split evenly, the final chunk will be the remaining + * elements. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Array + * @param {Array} array The array to process. + * @param {number} [size=1] The length of each chunk + * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`. + * @returns {Array} Returns the new array of chunks. + * @example + * + * _.chunk(['a', 'b', 'c', 'd'], 2); + * // => [['a', 'b'], ['c', 'd']] + * + * _.chunk(['a', 'b', 'c', 'd'], 3); + * // => [['a', 'b', 'c'], ['d']] + */ + function chunk(array, size, guard) { + if ((guard ? isIterateeCall(array, size, guard) : size === undefined)) { + size = 1; + } else { + size = nativeMax(toInteger(size), 0); + } + var length = array ? array.length : 0; + if (!length || size < 1) { + return []; + } + var index = 0, + resIndex = 0, + result = Array(nativeCeil(length / size)); + + while (index < length) { + result[resIndex++] = baseSlice(array, index, (index += size)); + } + return result; + } + + /** + * Creates an array with all falsey values removed. The values `false`, `null`, + * `0`, `""`, `undefined`, and `NaN` are falsey. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Array + * @param {Array} array The array to compact. + * @returns {Array} Returns the new array of filtered values. + * @example + * + * _.compact([0, 1, false, 2, '', 3]); + * // => [1, 2, 3] + */ + function compact(array) { + var index = -1, + length = array ? array.length : 0, + resIndex = 0, + result = []; + + while (++index < length) { + var value = array[index]; + if (value) { + result[resIndex++] = value; + } + } + return result; + } + + /** + * Creates a new array concatenating `array` with any additional arrays + * and/or values. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {Array} array The array to concatenate. + * @param {...*} [values] The values to concatenate. + * @returns {Array} Returns the new concatenated array. + * @example + * + * var array = [1]; + * var other = _.concat(array, 2, [3], [[4]]); + * + * console.log(other); + * // => [1, 2, 3, [4]] + * + * console.log(array); + * // => [1] + */ + function concat() { + var length = arguments.length; + if (!length) { + return []; + } + var args = Array(length - 1), + array = arguments[0], + index = length; + + while (index--) { + args[index - 1] = arguments[index]; + } + return arrayPush(isArray(array) ? copyArray(array) : [array], baseFlatten(args, 1)); + } + + /** + * Creates an array of `array` values not included in the other given arrays + * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero) + * for equality comparisons. The order and references of result values are + * determined by the first array. + * + * **Note:** Unlike `_.pullAll`, this method returns a new array. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Array + * @param {Array} array The array to inspect. + * @param {...Array} [values] The values to exclude. + * @returns {Array} Returns the new array of filtered values. + * @see _.without, _.xor + * @example + * + * _.difference([2, 1], [2, 3]); + * // => [1] + */ + var difference = baseRest(function(array, values) { + return isArrayLikeObject(array) + ? baseDifference(array, baseFlatten(values, 1, isArrayLikeObject, true)) + : []; + }); + + /** + * This method is like `_.difference` except that it accepts `iteratee` which + * is invoked for each element of `array` and `values` to generate the criterion + * by which they're compared. The order and references of result values are + * determined by the first array. The iteratee is invoked with one argument: + * (value). + * + * **Note:** Unlike `_.pullAllBy`, this method returns a new array. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {Array} array The array to inspect. + * @param {...Array} [values] The values to exclude. + * @param {Function} [iteratee=_.identity] The iteratee invoked per element. + * @returns {Array} Returns the new array of filtered values. + * @example + * + * _.differenceBy([2.1, 1.2], [2.3, 3.4], Math.floor); + * // => [1.2] + * + * // The `_.property` iteratee shorthand. + * _.differenceBy([{ 'x': 2 }, { 'x': 1 }], [{ 'x': 1 }], 'x'); + * // => [{ 'x': 2 }] + */ + var differenceBy = baseRest(function(array, values) { + var iteratee = last(values); + if (isArrayLikeObject(iteratee)) { + iteratee = undefined; + } + return isArrayLikeObject(array) + ? baseDifference(array, baseFlatten(values, 1, isArrayLikeObject, true), getIteratee(iteratee, 2)) + : []; + }); + + /** + * This method is like `_.difference` except that it accepts `comparator` + * which is invoked to compare elements of `array` to `values`. The order and + * references of result values are determined by the first array. The comparator + * is invoked with two arguments: (arrVal, othVal). + * + * **Note:** Unlike `_.pullAllWith`, this method returns a new array. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {Array} array The array to inspect. + * @param {...Array} [values] The values to exclude. + * @param {Function} [comparator] The comparator invoked per element. + * @returns {Array} Returns the new array of filtered values. + * @example + * + * var objects = [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }]; + * + * _.differenceWith(objects, [{ 'x': 1, 'y': 2 }], _.isEqual); + * // => [{ 'x': 2, 'y': 1 }] + */ + var differenceWith = baseRest(function(array, values) { + var comparator = last(values); + if (isArrayLikeObject(comparator)) { + comparator = undefined; + } + return isArrayLikeObject(array) + ? baseDifference(array, baseFlatten(values, 1, isArrayLikeObject, true), undefined, comparator) + : []; + }); + + /** + * Creates a slice of `array` with `n` elements dropped from the beginning. + * + * @static + * @memberOf _ + * @since 0.5.0 + * @category Array + * @param {Array} array The array to query. + * @param {number} [n=1] The number of elements to drop. + * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`. + * @returns {Array} Returns the slice of `array`. + * @example + * + * _.drop([1, 2, 3]); + * // => [2, 3] + * + * _.drop([1, 2, 3], 2); + * // => [3] + * + * _.drop([1, 2, 3], 5); + * // => [] + * + * _.drop([1, 2, 3], 0); + * // => [1, 2, 3] + */ + function drop(array, n, guard) { + var length = array ? array.length : 0; + if (!length) { + return []; + } + n = (guard || n === undefined) ? 1 : toInteger(n); + return baseSlice(array, n < 0 ? 0 : n, length); + } + + /** + * Creates a slice of `array` with `n` elements dropped from the end. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Array + * @param {Array} array The array to query. + * @param {number} [n=1] The number of elements to drop. + * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`. + * @returns {Array} Returns the slice of `array`. + * @example + * + * _.dropRight([1, 2, 3]); + * // => [1, 2] + * + * _.dropRight([1, 2, 3], 2); + * // => [1] + * + * _.dropRight([1, 2, 3], 5); + * // => [] + * + * _.dropRight([1, 2, 3], 0); + * // => [1, 2, 3] + */ + function dropRight(array, n, guard) { + var length = array ? array.length : 0; + if (!length) { + return []; + } + n = (guard || n === undefined) ? 1 : toInteger(n); + n = length - n; + return baseSlice(array, 0, n < 0 ? 0 : n); + } + + /** + * Creates a slice of `array` excluding elements dropped from the end. + * Elements are dropped until `predicate` returns falsey. The predicate is + * invoked with three arguments: (value, index, array). + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Array + * @param {Array} array The array to query. + * @param {Function} [predicate=_.identity] The function invoked per iteration. + * @returns {Array} Returns the slice of `array`. + * @example + * + * var users = [ + * { 'user': 'barney', 'active': true }, + * { 'user': 'fred', 'active': false }, + * { 'user': 'pebbles', 'active': false } + * ]; + * + * _.dropRightWhile(users, function(o) { return !o.active; }); + * // => objects for ['barney'] + * + * // The `_.matches` iteratee shorthand. + * _.dropRightWhile(users, { 'user': 'pebbles', 'active': false }); + * // => objects for ['barney', 'fred'] + * + * // The `_.matchesProperty` iteratee shorthand. + * _.dropRightWhile(users, ['active', false]); + * // => objects for ['barney'] + * + * // The `_.property` iteratee shorthand. + * _.dropRightWhile(users, 'active'); + * // => objects for ['barney', 'fred', 'pebbles'] + */ + function dropRightWhile(array, predicate) { + return (array && array.length) + ? baseWhile(array, getIteratee(predicate, 3), true, true) + : []; + } + + /** + * Creates a slice of `array` excluding elements dropped from the beginning. + * Elements are dropped until `predicate` returns falsey. The predicate is + * invoked with three arguments: (value, index, array). + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Array + * @param {Array} array The array to query. + * @param {Function} [predicate=_.identity] + * The function invoked per iteration. + * @returns {Array} Returns the slice of `array`. + * @example + * + * var users = [ + * { 'user': 'barney', 'active': false }, + * { 'user': 'fred', 'active': false }, + * { 'user': 'pebbles', 'active': true } + * ]; + * + * _.dropWhile(users, function(o) { return !o.active; }); + * // => objects for ['pebbles'] + * + * // The `_.matches` iteratee shorthand. + * _.dropWhile(users, { 'user': 'barney', 'active': false }); + * // => objects for ['fred', 'pebbles'] + * + * // The `_.matchesProperty` iteratee shorthand. + * _.dropWhile(users, ['active', false]); + * // => objects for ['pebbles'] + * + * // The `_.property` iteratee shorthand. + * _.dropWhile(users, 'active'); + * // => objects for ['barney', 'fred', 'pebbles'] + */ + function dropWhile(array, predicate) { + return (array && array.length) + ? baseWhile(array, getIteratee(predicate, 3), true) + : []; + } + + /** + * Fills elements of `array` with `value` from `start` up to, but not + * including, `end`. + * + * **Note:** This method mutates `array`. + * + * @static + * @memberOf _ + * @since 3.2.0 + * @category Array + * @param {Array} array The array to fill. + * @param {*} value The value to fill `array` with. + * @param {number} [start=0] The start position. + * @param {number} [end=array.length] The end position. + * @returns {Array} Returns `array`. + * @example + * + * var array = [1, 2, 3]; + * + * _.fill(array, 'a'); + * console.log(array); + * // => ['a', 'a', 'a'] + * + * _.fill(Array(3), 2); + * // => [2, 2, 2] + * + * _.fill([4, 6, 8, 10], '*', 1, 3); + * // => [4, '*', '*', 10] + */ + function fill(array, value, start, end) { + var length = array ? array.length : 0; + if (!length) { + return []; + } + if (start && typeof start != 'number' && isIterateeCall(array, value, start)) { + start = 0; + end = length; + } + return baseFill(array, value, start, end); + } + + /** + * This method is like `_.find` except that it returns the index of the first + * element `predicate` returns truthy for instead of the element itself. + * + * @static + * @memberOf _ + * @since 1.1.0 + * @category Array + * @param {Array} array The array to inspect. + * @param {Function} [predicate=_.identity] + * The function invoked per iteration. + * @param {number} [fromIndex=0] The index to search from. + * @returns {number} Returns the index of the found element, else `-1`. + * @example + * + * var users = [ + * { 'user': 'barney', 'active': false }, + * { 'user': 'fred', 'active': false }, + * { 'user': 'pebbles', 'active': true } + * ]; + * + * _.findIndex(users, function(o) { return o.user == 'barney'; }); + * // => 0 + * + * // The `_.matches` iteratee shorthand. + * _.findIndex(users, { 'user': 'fred', 'active': false }); + * // => 1 + * + * // The `_.matchesProperty` iteratee shorthand. + * _.findIndex(users, ['active', false]); + * // => 0 + * + * // The `_.property` iteratee shorthand. + * _.findIndex(users, 'active'); + * // => 2 + */ + function findIndex(array, predicate, fromIndex) { + var length = array ? array.length : 0; + if (!length) { + return -1; + } + var index = fromIndex == null ? 0 : toInteger(fromIndex); + if (index < 0) { + index = nativeMax(length + index, 0); + } + return baseFindIndex(array, getIteratee(predicate, 3), index); + } + + /** + * This method is like `_.findIndex` except that it iterates over elements + * of `collection` from right to left. + * + * @static + * @memberOf _ + * @since 2.0.0 + * @category Array + * @param {Array} array The array to inspect. + * @param {Function} [predicate=_.identity] + * The function invoked per iteration. + * @param {number} [fromIndex=array.length-1] The index to search from. + * @returns {number} Returns the index of the found element, else `-1`. + * @example + * + * var users = [ + * { 'user': 'barney', 'active': true }, + * { 'user': 'fred', 'active': false }, + * { 'user': 'pebbles', 'active': false } + * ]; + * + * _.findLastIndex(users, function(o) { return o.user == 'pebbles'; }); + * // => 2 + * + * // The `_.matches` iteratee shorthand. + * _.findLastIndex(users, { 'user': 'barney', 'active': true }); + * // => 0 + * + * // The `_.matchesProperty` iteratee shorthand. + * _.findLastIndex(users, ['active', false]); + * // => 2 + * + * // The `_.property` iteratee shorthand. + * _.findLastIndex(users, 'active'); + * // => 0 + */ + function findLastIndex(array, predicate, fromIndex) { + var length = array ? array.length : 0; + if (!length) { + return -1; + } + var index = length - 1; + if (fromIndex !== undefined) { + index = toInteger(fromIndex); + index = fromIndex < 0 + ? nativeMax(length + index, 0) + : nativeMin(index, length - 1); + } + return baseFindIndex(array, getIteratee(predicate, 3), index, true); + } + + /** + * Flattens `array` a single level deep. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Array + * @param {Array} array The array to flatten. + * @returns {Array} Returns the new flattened array. + * @example + * + * _.flatten([1, [2, [3, [4]], 5]]); + * // => [1, 2, [3, [4]], 5] + */ + function flatten(array) { + var length = array ? array.length : 0; + return length ? baseFlatten(array, 1) : []; + } + + /** + * Recursively flattens `array`. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Array + * @param {Array} array The array to flatten. + * @returns {Array} Returns the new flattened array. + * @example + * + * _.flattenDeep([1, [2, [3, [4]], 5]]); + * // => [1, 2, 3, 4, 5] + */ + function flattenDeep(array) { + var length = array ? array.length : 0; + return length ? baseFlatten(array, INFINITY) : []; + } + + /** + * Recursively flatten `array` up to `depth` times. + * + * @static + * @memberOf _ + * @since 4.4.0 + * @category Array + * @param {Array} array The array to flatten. + * @param {number} [depth=1] The maximum recursion depth. + * @returns {Array} Returns the new flattened array. + * @example + * + * var array = [1, [2, [3, [4]], 5]]; + * + * _.flattenDepth(array, 1); + * // => [1, 2, [3, [4]], 5] + * + * _.flattenDepth(array, 2); + * // => [1, 2, 3, [4], 5] + */ + function flattenDepth(array, depth) { + var length = array ? array.length : 0; + if (!length) { + return []; + } + depth = depth === undefined ? 1 : toInteger(depth); + return baseFlatten(array, depth); + } + + /** + * The inverse of `_.toPairs`; this method returns an object composed + * from key-value `pairs`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {Array} pairs The key-value pairs. + * @returns {Object} Returns the new object. + * @example + * + * _.fromPairs([['a', 1], ['b', 2]]); + * // => { 'a': 1, 'b': 2 } + */ + function fromPairs(pairs) { + var index = -1, + length = pairs ? pairs.length : 0, + result = {}; + + while (++index < length) { + var pair = pairs[index]; + result[pair[0]] = pair[1]; + } + return result; + } + + /** + * Gets the first element of `array`. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @alias first + * @category Array + * @param {Array} array The array to query. + * @returns {*} Returns the first element of `array`. + * @example + * + * _.head([1, 2, 3]); + * // => 1 + * + * _.head([]); + * // => undefined + */ + function head(array) { + return (array && array.length) ? array[0] : undefined; + } + + /** + * Gets the index at which the first occurrence of `value` is found in `array` + * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero) + * for equality comparisons. If `fromIndex` is negative, it's used as the + * offset from the end of `array`. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Array + * @param {Array} array The array to inspect. + * @param {*} value The value to search for. + * @param {number} [fromIndex=0] The index to search from. + * @returns {number} Returns the index of the matched value, else `-1`. + * @example + * + * _.indexOf([1, 2, 1, 2], 2); + * // => 1 + * + * // Search from the `fromIndex`. + * _.indexOf([1, 2, 1, 2], 2, 2); + * // => 3 + */ + function indexOf(array, value, fromIndex) { + var length = array ? array.length : 0; + if (!length) { + return -1; + } + var index = fromIndex == null ? 0 : toInteger(fromIndex); + if (index < 0) { + index = nativeMax(length + index, 0); + } + return baseIndexOf(array, value, index); + } + + /** + * Gets all but the last element of `array`. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Array + * @param {Array} array The array to query. + * @returns {Array} Returns the slice of `array`. + * @example + * + * _.initial([1, 2, 3]); + * // => [1, 2] + */ + function initial(array) { + var length = array ? array.length : 0; + return length ? baseSlice(array, 0, -1) : []; + } + + /** + * Creates an array of unique values that are included in all given arrays + * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero) + * for equality comparisons. The order and references of result values are + * determined by the first array. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Array + * @param {...Array} [arrays] The arrays to inspect. + * @returns {Array} Returns the new array of intersecting values. + * @example + * + * _.intersection([2, 1], [2, 3]); + * // => [2] + */ + var intersection = baseRest(function(arrays) { + var mapped = arrayMap(arrays, castArrayLikeObject); + return (mapped.length && mapped[0] === arrays[0]) + ? baseIntersection(mapped) + : []; + }); + + /** + * This method is like `_.intersection` except that it accepts `iteratee` + * which is invoked for each element of each `arrays` to generate the criterion + * by which they're compared. The order and references of result values are + * determined by the first array. The iteratee is invoked with one argument: + * (value). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {...Array} [arrays] The arrays to inspect. + * @param {Function} [iteratee=_.identity] The iteratee invoked per element. + * @returns {Array} Returns the new array of intersecting values. + * @example + * + * _.intersectionBy([2.1, 1.2], [2.3, 3.4], Math.floor); + * // => [2.1] + * + * // The `_.property` iteratee shorthand. + * _.intersectionBy([{ 'x': 1 }], [{ 'x': 2 }, { 'x': 1 }], 'x'); + * // => [{ 'x': 1 }] + */ + var intersectionBy = baseRest(function(arrays) { + var iteratee = last(arrays), + mapped = arrayMap(arrays, castArrayLikeObject); + + if (iteratee === last(mapped)) { + iteratee = undefined; + } else { + mapped.pop(); + } + return (mapped.length && mapped[0] === arrays[0]) + ? baseIntersection(mapped, getIteratee(iteratee, 2)) + : []; + }); + + /** + * This method is like `_.intersection` except that it accepts `comparator` + * which is invoked to compare elements of `arrays`. The order and references + * of result values are determined by the first array. The comparator is + * invoked with two arguments: (arrVal, othVal). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {...Array} [arrays] The arrays to inspect. + * @param {Function} [comparator] The comparator invoked per element. + * @returns {Array} Returns the new array of intersecting values. + * @example + * + * var objects = [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }]; + * var others = [{ 'x': 1, 'y': 1 }, { 'x': 1, 'y': 2 }]; + * + * _.intersectionWith(objects, others, _.isEqual); + * // => [{ 'x': 1, 'y': 2 }] + */ + var intersectionWith = baseRest(function(arrays) { + var comparator = last(arrays), + mapped = arrayMap(arrays, castArrayLikeObject); + + if (comparator === last(mapped)) { + comparator = undefined; + } else { + mapped.pop(); + } + return (mapped.length && mapped[0] === arrays[0]) + ? baseIntersection(mapped, undefined, comparator) + : []; + }); + + /** + * Converts all elements in `array` into a string separated by `separator`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {Array} array The array to convert. + * @param {string} [separator=','] The element separator. + * @returns {string} Returns the joined string. + * @example + * + * _.join(['a', 'b', 'c'], '~'); + * // => 'a~b~c' + */ + function join(array, separator) { + return array ? nativeJoin.call(array, separator) : ''; + } + + /** + * Gets the last element of `array`. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Array + * @param {Array} array The array to query. + * @returns {*} Returns the last element of `array`. + * @example + * + * _.last([1, 2, 3]); + * // => 3 + */ + function last(array) { + var length = array ? array.length : 0; + return length ? array[length - 1] : undefined; + } + + /** + * This method is like `_.indexOf` except that it iterates over elements of + * `array` from right to left. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Array + * @param {Array} array The array to inspect. + * @param {*} value The value to search for. + * @param {number} [fromIndex=array.length-1] The index to search from. + * @returns {number} Returns the index of the matched value, else `-1`. + * @example + * + * _.lastIndexOf([1, 2, 1, 2], 2); + * // => 3 + * + * // Search from the `fromIndex`. + * _.lastIndexOf([1, 2, 1, 2], 2, 2); + * // => 1 + */ + function lastIndexOf(array, value, fromIndex) { + var length = array ? array.length : 0; + if (!length) { + return -1; + } + var index = length; + if (fromIndex !== undefined) { + index = toInteger(fromIndex); + index = index < 0 ? nativeMax(length + index, 0) : nativeMin(index, length - 1); + } + return value === value + ? strictLastIndexOf(array, value, index) + : baseFindIndex(array, baseIsNaN, index, true); + } + + /** + * Gets the element at index `n` of `array`. If `n` is negative, the nth + * element from the end is returned. + * + * @static + * @memberOf _ + * @since 4.11.0 + * @category Array + * @param {Array} array The array to query. + * @param {number} [n=0] The index of the element to return. + * @returns {*} Returns the nth element of `array`. + * @example + * + * var array = ['a', 'b', 'c', 'd']; + * + * _.nth(array, 1); + * // => 'b' + * + * _.nth(array, -2); + * // => 'c'; + */ + function nth(array, n) { + return (array && array.length) ? baseNth(array, toInteger(n)) : undefined; + } + + /** + * Removes all given values from `array` using + * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero) + * for equality comparisons. + * + * **Note:** Unlike `_.without`, this method mutates `array`. Use `_.remove` + * to remove elements from an array by predicate. + * + * @static + * @memberOf _ + * @since 2.0.0 + * @category Array + * @param {Array} array The array to modify. + * @param {...*} [values] The values to remove. + * @returns {Array} Returns `array`. + * @example + * + * var array = ['a', 'b', 'c', 'a', 'b', 'c']; + * + * _.pull(array, 'a', 'c'); + * console.log(array); + * // => ['b', 'b'] + */ + var pull = baseRest(pullAll); + + /** + * This method is like `_.pull` except that it accepts an array of values to remove. + * + * **Note:** Unlike `_.difference`, this method mutates `array`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {Array} array The array to modify. + * @param {Array} values The values to remove. + * @returns {Array} Returns `array`. + * @example + * + * var array = ['a', 'b', 'c', 'a', 'b', 'c']; + * + * _.pullAll(array, ['a', 'c']); + * console.log(array); + * // => ['b', 'b'] + */ + function pullAll(array, values) { + return (array && array.length && values && values.length) + ? basePullAll(array, values) + : array; + } + + /** + * This method is like `_.pullAll` except that it accepts `iteratee` which is + * invoked for each element of `array` and `values` to generate the criterion + * by which they're compared. The iteratee is invoked with one argument: (value). + * + * **Note:** Unlike `_.differenceBy`, this method mutates `array`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {Array} array The array to modify. + * @param {Array} values The values to remove. + * @param {Function} [iteratee=_.identity] + * The iteratee invoked per element. + * @returns {Array} Returns `array`. + * @example + * + * var array = [{ 'x': 1 }, { 'x': 2 }, { 'x': 3 }, { 'x': 1 }]; + * + * _.pullAllBy(array, [{ 'x': 1 }, { 'x': 3 }], 'x'); + * console.log(array); + * // => [{ 'x': 2 }] + */ + function pullAllBy(array, values, iteratee) { + return (array && array.length && values && values.length) + ? basePullAll(array, values, getIteratee(iteratee, 2)) + : array; + } + + /** + * This method is like `_.pullAll` except that it accepts `comparator` which + * is invoked to compare elements of `array` to `values`. The comparator is + * invoked with two arguments: (arrVal, othVal). + * + * **Note:** Unlike `_.differenceWith`, this method mutates `array`. + * + * @static + * @memberOf _ + * @since 4.6.0 + * @category Array + * @param {Array} array The array to modify. + * @param {Array} values The values to remove. + * @param {Function} [comparator] The comparator invoked per element. + * @returns {Array} Returns `array`. + * @example + * + * var array = [{ 'x': 1, 'y': 2 }, { 'x': 3, 'y': 4 }, { 'x': 5, 'y': 6 }]; + * + * _.pullAllWith(array, [{ 'x': 3, 'y': 4 }], _.isEqual); + * console.log(array); + * // => [{ 'x': 1, 'y': 2 }, { 'x': 5, 'y': 6 }] + */ + function pullAllWith(array, values, comparator) { + return (array && array.length && values && values.length) + ? basePullAll(array, values, undefined, comparator) + : array; + } + + /** + * Removes elements from `array` corresponding to `indexes` and returns an + * array of removed elements. + * + * **Note:** Unlike `_.at`, this method mutates `array`. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Array + * @param {Array} array The array to modify. + * @param {...(number|number[])} [indexes] The indexes of elements to remove. + * @returns {Array} Returns the new array of removed elements. + * @example + * + * var array = ['a', 'b', 'c', 'd']; + * var pulled = _.pullAt(array, [1, 3]); + * + * console.log(array); + * // => ['a', 'c'] + * + * console.log(pulled); + * // => ['b', 'd'] + */ + var pullAt = flatRest(function(array, indexes) { + var length = array ? array.length : 0, + result = baseAt(array, indexes); + + basePullAt(array, arrayMap(indexes, function(index) { + return isIndex(index, length) ? +index : index; + }).sort(compareAscending)); + + return result; + }); + + /** + * Removes all elements from `array` that `predicate` returns truthy for + * and returns an array of the removed elements. The predicate is invoked + * with three arguments: (value, index, array). + * + * **Note:** Unlike `_.filter`, this method mutates `array`. Use `_.pull` + * to pull elements from an array by value. + * + * @static + * @memberOf _ + * @since 2.0.0 + * @category Array + * @param {Array} array The array to modify. + * @param {Function} [predicate=_.identity] + * The function invoked per iteration. + * @returns {Array} Returns the new array of removed elements. + * @example + * + * var array = [1, 2, 3, 4]; + * var evens = _.remove(array, function(n) { + * return n % 2 == 0; + * }); + * + * console.log(array); + * // => [1, 3] + * + * console.log(evens); + * // => [2, 4] + */ + function remove(array, predicate) { + var result = []; + if (!(array && array.length)) { + return result; + } + var index = -1, + indexes = [], + length = array.length; + + predicate = getIteratee(predicate, 3); + while (++index < length) { + var value = array[index]; + if (predicate(value, index, array)) { + result.push(value); + indexes.push(index); + } + } + basePullAt(array, indexes); + return result; + } + + /** + * Reverses `array` so that the first element becomes the last, the second + * element becomes the second to last, and so on. + * + * **Note:** This method mutates `array` and is based on + * [`Array#reverse`](https://mdn.io/Array/reverse). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {Array} array The array to modify. + * @returns {Array} Returns `array`. + * @example + * + * var array = [1, 2, 3]; + * + * _.reverse(array); + * // => [3, 2, 1] + * + * console.log(array); + * // => [3, 2, 1] + */ + function reverse(array) { + return array ? nativeReverse.call(array) : array; + } + + /** + * Creates a slice of `array` from `start` up to, but not including, `end`. + * + * **Note:** This method is used instead of + * [`Array#slice`](https://mdn.io/Array/slice) to ensure dense arrays are + * returned. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Array + * @param {Array} array The array to slice. + * @param {number} [start=0] The start position. + * @param {number} [end=array.length] The end position. + * @returns {Array} Returns the slice of `array`. + */ + function slice(array, start, end) { + var length = array ? array.length : 0; + if (!length) { + return []; + } + if (end && typeof end != 'number' && isIterateeCall(array, start, end)) { + start = 0; + end = length; + } + else { + start = start == null ? 0 : toInteger(start); + end = end === undefined ? length : toInteger(end); + } + return baseSlice(array, start, end); + } + + /** + * Uses a binary search to determine the lowest index at which `value` + * should be inserted into `array` in order to maintain its sort order. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Array + * @param {Array} array The sorted array to inspect. + * @param {*} value The value to evaluate. + * @returns {number} Returns the index at which `value` should be inserted + * into `array`. + * @example + * + * _.sortedIndex([30, 50], 40); + * // => 1 + */ + function sortedIndex(array, value) { + return baseSortedIndex(array, value); + } + + /** + * This method is like `_.sortedIndex` except that it accepts `iteratee` + * which is invoked for `value` and each element of `array` to compute their + * sort ranking. The iteratee is invoked with one argument: (value). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {Array} array The sorted array to inspect. + * @param {*} value The value to evaluate. + * @param {Function} [iteratee=_.identity] + * The iteratee invoked per element. + * @returns {number} Returns the index at which `value` should be inserted + * into `array`. + * @example + * + * var objects = [{ 'x': 4 }, { 'x': 5 }]; + * + * _.sortedIndexBy(objects, { 'x': 4 }, function(o) { return o.x; }); + * // => 0 + * + * // The `_.property` iteratee shorthand. + * _.sortedIndexBy(objects, { 'x': 4 }, 'x'); + * // => 0 + */ + function sortedIndexBy(array, value, iteratee) { + return baseSortedIndexBy(array, value, getIteratee(iteratee, 2)); + } + + /** + * This method is like `_.indexOf` except that it performs a binary + * search on a sorted `array`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {Array} array The array to inspect. + * @param {*} value The value to search for. + * @returns {number} Returns the index of the matched value, else `-1`. + * @example + * + * _.sortedIndexOf([4, 5, 5, 5, 6], 5); + * // => 1 + */ + function sortedIndexOf(array, value) { + var length = array ? array.length : 0; + if (length) { + var index = baseSortedIndex(array, value); + if (index < length && eq(array[index], value)) { + return index; + } + } + return -1; + } + + /** + * This method is like `_.sortedIndex` except that it returns the highest + * index at which `value` should be inserted into `array` in order to + * maintain its sort order. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Array + * @param {Array} array The sorted array to inspect. + * @param {*} value The value to evaluate. + * @returns {number} Returns the index at which `value` should be inserted + * into `array`. + * @example + * + * _.sortedLastIndex([4, 5, 5, 5, 6], 5); + * // => 4 + */ + function sortedLastIndex(array, value) { + return baseSortedIndex(array, value, true); + } + + /** + * This method is like `_.sortedLastIndex` except that it accepts `iteratee` + * which is invoked for `value` and each element of `array` to compute their + * sort ranking. The iteratee is invoked with one argument: (value). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {Array} array The sorted array to inspect. + * @param {*} value The value to evaluate. + * @param {Function} [iteratee=_.identity] + * The iteratee invoked per element. + * @returns {number} Returns the index at which `value` should be inserted + * into `array`. + * @example + * + * var objects = [{ 'x': 4 }, { 'x': 5 }]; + * + * _.sortedLastIndexBy(objects, { 'x': 4 }, function(o) { return o.x; }); + * // => 1 + * + * // The `_.property` iteratee shorthand. + * _.sortedLastIndexBy(objects, { 'x': 4 }, 'x'); + * // => 1 + */ + function sortedLastIndexBy(array, value, iteratee) { + return baseSortedIndexBy(array, value, getIteratee(iteratee, 2), true); + } + + /** + * This method is like `_.lastIndexOf` except that it performs a binary + * search on a sorted `array`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {Array} array The array to inspect. + * @param {*} value The value to search for. + * @returns {number} Returns the index of the matched value, else `-1`. + * @example + * + * _.sortedLastIndexOf([4, 5, 5, 5, 6], 5); + * // => 3 + */ + function sortedLastIndexOf(array, value) { + var length = array ? array.length : 0; + if (length) { + var index = baseSortedIndex(array, value, true) - 1; + if (eq(array[index], value)) { + return index; + } + } + return -1; + } + + /** + * This method is like `_.uniq` except that it's designed and optimized + * for sorted arrays. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {Array} array The array to inspect. + * @returns {Array} Returns the new duplicate free array. + * @example + * + * _.sortedUniq([1, 1, 2]); + * // => [1, 2] + */ + function sortedUniq(array) { + return (array && array.length) + ? baseSortedUniq(array) + : []; + } + + /** + * This method is like `_.uniqBy` except that it's designed and optimized + * for sorted arrays. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {Array} array The array to inspect. + * @param {Function} [iteratee] The iteratee invoked per element. + * @returns {Array} Returns the new duplicate free array. + * @example + * + * _.sortedUniqBy([1.1, 1.2, 2.3, 2.4], Math.floor); + * // => [1.1, 2.3] + */ + function sortedUniqBy(array, iteratee) { + return (array && array.length) + ? baseSortedUniq(array, getIteratee(iteratee, 2)) + : []; + } + + /** + * Gets all but the first element of `array`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {Array} array The array to query. + * @returns {Array} Returns the slice of `array`. + * @example + * + * _.tail([1, 2, 3]); + * // => [2, 3] + */ + function tail(array) { + var length = array ? array.length : 0; + return length ? baseSlice(array, 1, length) : []; + } + + /** + * Creates a slice of `array` with `n` elements taken from the beginning. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Array + * @param {Array} array The array to query. + * @param {number} [n=1] The number of elements to take. + * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`. + * @returns {Array} Returns the slice of `array`. + * @example + * + * _.take([1, 2, 3]); + * // => [1] + * + * _.take([1, 2, 3], 2); + * // => [1, 2] + * + * _.take([1, 2, 3], 5); + * // => [1, 2, 3] + * + * _.take([1, 2, 3], 0); + * // => [] + */ + function take(array, n, guard) { + if (!(array && array.length)) { + return []; + } + n = (guard || n === undefined) ? 1 : toInteger(n); + return baseSlice(array, 0, n < 0 ? 0 : n); + } + + /** + * Creates a slice of `array` with `n` elements taken from the end. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Array + * @param {Array} array The array to query. + * @param {number} [n=1] The number of elements to take. + * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`. + * @returns {Array} Returns the slice of `array`. + * @example + * + * _.takeRight([1, 2, 3]); + * // => [3] + * + * _.takeRight([1, 2, 3], 2); + * // => [2, 3] + * + * _.takeRight([1, 2, 3], 5); + * // => [1, 2, 3] + * + * _.takeRight([1, 2, 3], 0); + * // => [] + */ + function takeRight(array, n, guard) { + var length = array ? array.length : 0; + if (!length) { + return []; + } + n = (guard || n === undefined) ? 1 : toInteger(n); + n = length - n; + return baseSlice(array, n < 0 ? 0 : n, length); + } + + /** + * Creates a slice of `array` with elements taken from the end. Elements are + * taken until `predicate` returns falsey. The predicate is invoked with + * three arguments: (value, index, array). + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Array + * @param {Array} array The array to query. + * @param {Function} [predicate=_.identity] + * The function invoked per iteration. + * @returns {Array} Returns the slice of `array`. + * @example + * + * var users = [ + * { 'user': 'barney', 'active': true }, + * { 'user': 'fred', 'active': false }, + * { 'user': 'pebbles', 'active': false } + * ]; + * + * _.takeRightWhile(users, function(o) { return !o.active; }); + * // => objects for ['fred', 'pebbles'] + * + * // The `_.matches` iteratee shorthand. + * _.takeRightWhile(users, { 'user': 'pebbles', 'active': false }); + * // => objects for ['pebbles'] + * + * // The `_.matchesProperty` iteratee shorthand. + * _.takeRightWhile(users, ['active', false]); + * // => objects for ['fred', 'pebbles'] + * + * // The `_.property` iteratee shorthand. + * _.takeRightWhile(users, 'active'); + * // => [] + */ + function takeRightWhile(array, predicate) { + return (array && array.length) + ? baseWhile(array, getIteratee(predicate, 3), false, true) + : []; + } + + /** + * Creates a slice of `array` with elements taken from the beginning. Elements + * are taken until `predicate` returns falsey. The predicate is invoked with + * three arguments: (value, index, array). + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Array + * @param {Array} array The array to query. + * @param {Function} [predicate=_.identity] + * The function invoked per iteration. + * @returns {Array} Returns the slice of `array`. + * @example + * + * var users = [ + * { 'user': 'barney', 'active': false }, + * { 'user': 'fred', 'active': false}, + * { 'user': 'pebbles', 'active': true } + * ]; + * + * _.takeWhile(users, function(o) { return !o.active; }); + * // => objects for ['barney', 'fred'] + * + * // The `_.matches` iteratee shorthand. + * _.takeWhile(users, { 'user': 'barney', 'active': false }); + * // => objects for ['barney'] + * + * // The `_.matchesProperty` iteratee shorthand. + * _.takeWhile(users, ['active', false]); + * // => objects for ['barney', 'fred'] + * + * // The `_.property` iteratee shorthand. + * _.takeWhile(users, 'active'); + * // => [] + */ + function takeWhile(array, predicate) { + return (array && array.length) + ? baseWhile(array, getIteratee(predicate, 3)) + : []; + } + + /** + * Creates an array of unique values, in order, from all given arrays using + * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero) + * for equality comparisons. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Array + * @param {...Array} [arrays] The arrays to inspect. + * @returns {Array} Returns the new array of combined values. + * @example + * + * _.union([2], [1, 2]); + * // => [2, 1] + */ + var union = baseRest(function(arrays) { + return baseUniq(baseFlatten(arrays, 1, isArrayLikeObject, true)); + }); + + /** + * This method is like `_.union` except that it accepts `iteratee` which is + * invoked for each element of each `arrays` to generate the criterion by + * which uniqueness is computed. Result values are chosen from the first + * array in which the value occurs. The iteratee is invoked with one argument: + * (value). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {...Array} [arrays] The arrays to inspect. + * @param {Function} [iteratee=_.identity] + * The iteratee invoked per element. + * @returns {Array} Returns the new array of combined values. + * @example + * + * _.unionBy([2.1], [1.2, 2.3], Math.floor); + * // => [2.1, 1.2] + * + * // The `_.property` iteratee shorthand. + * _.unionBy([{ 'x': 1 }], [{ 'x': 2 }, { 'x': 1 }], 'x'); + * // => [{ 'x': 1 }, { 'x': 2 }] + */ + var unionBy = baseRest(function(arrays) { + var iteratee = last(arrays); + if (isArrayLikeObject(iteratee)) { + iteratee = undefined; + } + return baseUniq(baseFlatten(arrays, 1, isArrayLikeObject, true), getIteratee(iteratee, 2)); + }); + + /** + * This method is like `_.union` except that it accepts `comparator` which + * is invoked to compare elements of `arrays`. Result values are chosen from + * the first array in which the value occurs. The comparator is invoked + * with two arguments: (arrVal, othVal). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {...Array} [arrays] The arrays to inspect. + * @param {Function} [comparator] The comparator invoked per element. + * @returns {Array} Returns the new array of combined values. + * @example + * + * var objects = [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }]; + * var others = [{ 'x': 1, 'y': 1 }, { 'x': 1, 'y': 2 }]; + * + * _.unionWith(objects, others, _.isEqual); + * // => [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }, { 'x': 1, 'y': 1 }] + */ + var unionWith = baseRest(function(arrays) { + var comparator = last(arrays); + if (isArrayLikeObject(comparator)) { + comparator = undefined; + } + return baseUniq(baseFlatten(arrays, 1, isArrayLikeObject, true), undefined, comparator); + }); + + /** + * Creates a duplicate-free version of an array, using + * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero) + * for equality comparisons, in which only the first occurrence of each element + * is kept. The order of result values is determined by the order they occur + * in the array. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Array + * @param {Array} array The array to inspect. + * @returns {Array} Returns the new duplicate free array. + * @example + * + * _.uniq([2, 1, 2]); + * // => [2, 1] + */ + function uniq(array) { + return (array && array.length) + ? baseUniq(array) + : []; + } + + /** + * This method is like `_.uniq` except that it accepts `iteratee` which is + * invoked for each element in `array` to generate the criterion by which + * uniqueness is computed. The order of result values is determined by the + * order they occur in the array. The iteratee is invoked with one argument: + * (value). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {Array} array The array to inspect. + * @param {Function} [iteratee=_.identity] + * The iteratee invoked per element. + * @returns {Array} Returns the new duplicate free array. + * @example + * + * _.uniqBy([2.1, 1.2, 2.3], Math.floor); + * // => [2.1, 1.2] + * + * // The `_.property` iteratee shorthand. + * _.uniqBy([{ 'x': 1 }, { 'x': 2 }, { 'x': 1 }], 'x'); + * // => [{ 'x': 1 }, { 'x': 2 }] + */ + function uniqBy(array, iteratee) { + return (array && array.length) + ? baseUniq(array, getIteratee(iteratee, 2)) + : []; + } + + /** + * This method is like `_.uniq` except that it accepts `comparator` which + * is invoked to compare elements of `array`. The order of result values is + * determined by the order they occur in the array.The comparator is invoked + * with two arguments: (arrVal, othVal). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {Array} array The array to inspect. + * @param {Function} [comparator] The comparator invoked per element. + * @returns {Array} Returns the new duplicate free array. + * @example + * + * var objects = [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }, { 'x': 1, 'y': 2 }]; + * + * _.uniqWith(objects, _.isEqual); + * // => [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }] + */ + function uniqWith(array, comparator) { + return (array && array.length) + ? baseUniq(array, undefined, comparator) + : []; + } + + /** + * This method is like `_.zip` except that it accepts an array of grouped + * elements and creates an array regrouping the elements to their pre-zip + * configuration. + * + * @static + * @memberOf _ + * @since 1.2.0 + * @category Array + * @param {Array} array The array of grouped elements to process. + * @returns {Array} Returns the new array of regrouped elements. + * @example + * + * var zipped = _.zip(['a', 'b'], [1, 2], [true, false]); + * // => [['a', 1, true], ['b', 2, false]] + * + * _.unzip(zipped); + * // => [['a', 'b'], [1, 2], [true, false]] + */ + function unzip(array) { + if (!(array && array.length)) { + return []; + } + var length = 0; + array = arrayFilter(array, function(group) { + if (isArrayLikeObject(group)) { + length = nativeMax(group.length, length); + return true; + } + }); + return baseTimes(length, function(index) { + return arrayMap(array, baseProperty(index)); + }); + } + + /** + * This method is like `_.unzip` except that it accepts `iteratee` to specify + * how regrouped values should be combined. The iteratee is invoked with the + * elements of each group: (...group). + * + * @static + * @memberOf _ + * @since 3.8.0 + * @category Array + * @param {Array} array The array of grouped elements to process. + * @param {Function} [iteratee=_.identity] The function to combine + * regrouped values. + * @returns {Array} Returns the new array of regrouped elements. + * @example + * + * var zipped = _.zip([1, 2], [10, 20], [100, 200]); + * // => [[1, 10, 100], [2, 20, 200]] + * + * _.unzipWith(zipped, _.add); + * // => [3, 30, 300] + */ + function unzipWith(array, iteratee) { + if (!(array && array.length)) { + return []; + } + var result = unzip(array); + if (iteratee == null) { + return result; + } + return arrayMap(result, function(group) { + return apply(iteratee, undefined, group); + }); + } + + /** + * Creates an array excluding all given values using + * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero) + * for equality comparisons. + * + * **Note:** Unlike `_.pull`, this method returns a new array. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Array + * @param {Array} array The array to inspect. + * @param {...*} [values] The values to exclude. + * @returns {Array} Returns the new array of filtered values. + * @see _.difference, _.xor + * @example + * + * _.without([2, 1, 2, 3], 1, 2); + * // => [3] + */ + var without = baseRest(function(array, values) { + return isArrayLikeObject(array) + ? baseDifference(array, values) + : []; + }); + + /** + * Creates an array of unique values that is the + * [symmetric difference](https://en.wikipedia.org/wiki/Symmetric_difference) + * of the given arrays. The order of result values is determined by the order + * they occur in the arrays. + * + * @static + * @memberOf _ + * @since 2.4.0 + * @category Array + * @param {...Array} [arrays] The arrays to inspect. + * @returns {Array} Returns the new array of filtered values. + * @see _.difference, _.without + * @example + * + * _.xor([2, 1], [2, 3]); + * // => [1, 3] + */ + var xor = baseRest(function(arrays) { + return baseXor(arrayFilter(arrays, isArrayLikeObject)); + }); + + /** + * This method is like `_.xor` except that it accepts `iteratee` which is + * invoked for each element of each `arrays` to generate the criterion by + * which by which they're compared. The order of result values is determined + * by the order they occur in the arrays. The iteratee is invoked with one + * argument: (value). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {...Array} [arrays] The arrays to inspect. + * @param {Function} [iteratee=_.identity] + * The iteratee invoked per element. + * @returns {Array} Returns the new array of filtered values. + * @example + * + * _.xorBy([2.1, 1.2], [2.3, 3.4], Math.floor); + * // => [1.2, 3.4] + * + * // The `_.property` iteratee shorthand. + * _.xorBy([{ 'x': 1 }], [{ 'x': 2 }, { 'x': 1 }], 'x'); + * // => [{ 'x': 2 }] + */ + var xorBy = baseRest(function(arrays) { + var iteratee = last(arrays); + if (isArrayLikeObject(iteratee)) { + iteratee = undefined; + } + return baseXor(arrayFilter(arrays, isArrayLikeObject), getIteratee(iteratee, 2)); + }); + + /** + * This method is like `_.xor` except that it accepts `comparator` which is + * invoked to compare elements of `arrays`. The order of result values is + * determined by the order they occur in the arrays. The comparator is invoked + * with two arguments: (arrVal, othVal). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {...Array} [arrays] The arrays to inspect. + * @param {Function} [comparator] The comparator invoked per element. + * @returns {Array} Returns the new array of filtered values. + * @example + * + * var objects = [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }]; + * var others = [{ 'x': 1, 'y': 1 }, { 'x': 1, 'y': 2 }]; + * + * _.xorWith(objects, others, _.isEqual); + * // => [{ 'x': 2, 'y': 1 }, { 'x': 1, 'y': 1 }] + */ + var xorWith = baseRest(function(arrays) { + var comparator = last(arrays); + if (isArrayLikeObject(comparator)) { + comparator = undefined; + } + return baseXor(arrayFilter(arrays, isArrayLikeObject), undefined, comparator); + }); + + /** + * Creates an array of grouped elements, the first of which contains the + * first elements of the given arrays, the second of which contains the + * second elements of the given arrays, and so on. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Array + * @param {...Array} [arrays] The arrays to process. + * @returns {Array} Returns the new array of grouped elements. + * @example + * + * _.zip(['a', 'b'], [1, 2], [true, false]); + * // => [['a', 1, true], ['b', 2, false]] + */ + var zip = baseRest(unzip); + + /** + * This method is like `_.fromPairs` except that it accepts two arrays, + * one of property identifiers and one of corresponding values. + * + * @static + * @memberOf _ + * @since 0.4.0 + * @category Array + * @param {Array} [props=[]] The property identifiers. + * @param {Array} [values=[]] The property values. + * @returns {Object} Returns the new object. + * @example + * + * _.zipObject(['a', 'b'], [1, 2]); + * // => { 'a': 1, 'b': 2 } + */ + function zipObject(props, values) { + return baseZipObject(props || [], values || [], assignValue); + } + + /** + * This method is like `_.zipObject` except that it supports property paths. + * + * @static + * @memberOf _ + * @since 4.1.0 + * @category Array + * @param {Array} [props=[]] The property identifiers. + * @param {Array} [values=[]] The property values. + * @returns {Object} Returns the new object. + * @example + * + * _.zipObjectDeep(['a.b[0].c', 'a.b[1].d'], [1, 2]); + * // => { 'a': { 'b': [{ 'c': 1 }, { 'd': 2 }] } } + */ + function zipObjectDeep(props, values) { + return baseZipObject(props || [], values || [], baseSet); + } + + /** + * This method is like `_.zip` except that it accepts `iteratee` to specify + * how grouped values should be combined. The iteratee is invoked with the + * elements of each group: (...group). + * + * @static + * @memberOf _ + * @since 3.8.0 + * @category Array + * @param {...Array} [arrays] The arrays to process. + * @param {Function} [iteratee=_.identity] The function to combine grouped values. + * @returns {Array} Returns the new array of grouped elements. + * @example + * + * _.zipWith([1, 2], [10, 20], [100, 200], function(a, b, c) { + * return a + b + c; + * }); + * // => [111, 222] + */ + var zipWith = baseRest(function(arrays) { + var length = arrays.length, + iteratee = length > 1 ? arrays[length - 1] : undefined; + + iteratee = typeof iteratee == 'function' ? (arrays.pop(), iteratee) : undefined; + return unzipWith(arrays, iteratee); + }); + + /*------------------------------------------------------------------------*/ + + /** + * Creates a `lodash` wrapper instance that wraps `value` with explicit method + * chain sequences enabled. The result of such sequences must be unwrapped + * with `_#value`. + * + * @static + * @memberOf _ + * @since 1.3.0 + * @category Seq + * @param {*} value The value to wrap. + * @returns {Object} Returns the new `lodash` wrapper instance. + * @example + * + * var users = [ + * { 'user': 'barney', 'age': 36 }, + * { 'user': 'fred', 'age': 40 }, + * { 'user': 'pebbles', 'age': 1 } + * ]; + * + * var youngest = _ + * .chain(users) + * .sortBy('age') + * .map(function(o) { + * return o.user + ' is ' + o.age; + * }) + * .head() + * .value(); + * // => 'pebbles is 1' + */ + function chain(value) { + var result = lodash(value); + result.__chain__ = true; + return result; + } + + /** + * This method invokes `interceptor` and returns `value`. The interceptor + * is invoked with one argument; (value). The purpose of this method is to + * "tap into" a method chain sequence in order to modify intermediate results. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Seq + * @param {*} value The value to provide to `interceptor`. + * @param {Function} interceptor The function to invoke. + * @returns {*} Returns `value`. + * @example + * + * _([1, 2, 3]) + * .tap(function(array) { + * // Mutate input array. + * array.pop(); + * }) + * .reverse() + * .value(); + * // => [2, 1] + */ + function tap(value, interceptor) { + interceptor(value); + return value; + } + + /** + * This method is like `_.tap` except that it returns the result of `interceptor`. + * The purpose of this method is to "pass thru" values replacing intermediate + * results in a method chain sequence. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Seq + * @param {*} value The value to provide to `interceptor`. + * @param {Function} interceptor The function to invoke. + * @returns {*} Returns the result of `interceptor`. + * @example + * + * _(' abc ') + * .chain() + * .trim() + * .thru(function(value) { + * return [value]; + * }) + * .value(); + * // => ['abc'] + */ + function thru(value, interceptor) { + return interceptor(value); + } + + /** + * This method is the wrapper version of `_.at`. + * + * @name at + * @memberOf _ + * @since 1.0.0 + * @category Seq + * @param {...(string|string[])} [paths] The property paths of elements to pick. + * @returns {Object} Returns the new `lodash` wrapper instance. + * @example + * + * var object = { 'a': [{ 'b': { 'c': 3 } }, 4] }; + * + * _(object).at(['a[0].b.c', 'a[1]']).value(); + * // => [3, 4] + */ + var wrapperAt = flatRest(function(paths) { + var length = paths.length, + start = length ? paths[0] : 0, + value = this.__wrapped__, + interceptor = function(object) { return baseAt(object, paths); }; + + if (length > 1 || this.__actions__.length || + !(value instanceof LazyWrapper) || !isIndex(start)) { + return this.thru(interceptor); + } + value = value.slice(start, +start + (length ? 1 : 0)); + value.__actions__.push({ + 'func': thru, + 'args': [interceptor], + 'thisArg': undefined + }); + return new LodashWrapper(value, this.__chain__).thru(function(array) { + if (length && !array.length) { + array.push(undefined); + } + return array; + }); + }); + + /** + * Creates a `lodash` wrapper instance with explicit method chain sequences enabled. + * + * @name chain + * @memberOf _ + * @since 0.1.0 + * @category Seq + * @returns {Object} Returns the new `lodash` wrapper instance. + * @example + * + * var users = [ + * { 'user': 'barney', 'age': 36 }, + * { 'user': 'fred', 'age': 40 } + * ]; + * + * // A sequence without explicit chaining. + * _(users).head(); + * // => { 'user': 'barney', 'age': 36 } + * + * // A sequence with explicit chaining. + * _(users) + * .chain() + * .head() + * .pick('user') + * .value(); + * // => { 'user': 'barney' } + */ + function wrapperChain() { + return chain(this); + } + + /** + * Executes the chain sequence and returns the wrapped result. + * + * @name commit + * @memberOf _ + * @since 3.2.0 + * @category Seq + * @returns {Object} Returns the new `lodash` wrapper instance. + * @example + * + * var array = [1, 2]; + * var wrapped = _(array).push(3); + * + * console.log(array); + * // => [1, 2] + * + * wrapped = wrapped.commit(); + * console.log(array); + * // => [1, 2, 3] + * + * wrapped.last(); + * // => 3 + * + * console.log(array); + * // => [1, 2, 3] + */ + function wrapperCommit() { + return new LodashWrapper(this.value(), this.__chain__); + } + + /** + * Gets the next value on a wrapped object following the + * [iterator protocol](https://mdn.io/iteration_protocols#iterator). + * + * @name next + * @memberOf _ + * @since 4.0.0 + * @category Seq + * @returns {Object} Returns the next iterator value. + * @example + * + * var wrapped = _([1, 2]); + * + * wrapped.next(); + * // => { 'done': false, 'value': 1 } + * + * wrapped.next(); + * // => { 'done': false, 'value': 2 } + * + * wrapped.next(); + * // => { 'done': true, 'value': undefined } + */ + function wrapperNext() { + if (this.__values__ === undefined) { + this.__values__ = toArray(this.value()); + } + var done = this.__index__ >= this.__values__.length, + value = done ? undefined : this.__values__[this.__index__++]; + + return { 'done': done, 'value': value }; + } + + /** + * Enables the wrapper to be iterable. + * + * @name Symbol.iterator + * @memberOf _ + * @since 4.0.0 + * @category Seq + * @returns {Object} Returns the wrapper object. + * @example + * + * var wrapped = _([1, 2]); + * + * wrapped[Symbol.iterator]() === wrapped; + * // => true + * + * Array.from(wrapped); + * // => [1, 2] + */ + function wrapperToIterator() { + return this; + } + + /** + * Creates a clone of the chain sequence planting `value` as the wrapped value. + * + * @name plant + * @memberOf _ + * @since 3.2.0 + * @category Seq + * @param {*} value The value to plant. + * @returns {Object} Returns the new `lodash` wrapper instance. + * @example + * + * function square(n) { + * return n * n; + * } + * + * var wrapped = _([1, 2]).map(square); + * var other = wrapped.plant([3, 4]); + * + * other.value(); + * // => [9, 16] + * + * wrapped.value(); + * // => [1, 4] + */ + function wrapperPlant(value) { + var result, + parent = this; + + while (parent instanceof baseLodash) { + var clone = wrapperClone(parent); + clone.__index__ = 0; + clone.__values__ = undefined; + if (result) { + previous.__wrapped__ = clone; + } else { + result = clone; + } + var previous = clone; + parent = parent.__wrapped__; + } + previous.__wrapped__ = value; + return result; + } + + /** + * This method is the wrapper version of `_.reverse`. + * + * **Note:** This method mutates the wrapped array. + * + * @name reverse + * @memberOf _ + * @since 0.1.0 + * @category Seq + * @returns {Object} Returns the new `lodash` wrapper instance. + * @example + * + * var array = [1, 2, 3]; + * + * _(array).reverse().value() + * // => [3, 2, 1] + * + * console.log(array); + * // => [3, 2, 1] + */ + function wrapperReverse() { + var value = this.__wrapped__; + if (value instanceof LazyWrapper) { + var wrapped = value; + if (this.__actions__.length) { + wrapped = new LazyWrapper(this); + } + wrapped = wrapped.reverse(); + wrapped.__actions__.push({ + 'func': thru, + 'args': [reverse], + 'thisArg': undefined + }); + return new LodashWrapper(wrapped, this.__chain__); + } + return this.thru(reverse); + } + + /** + * Executes the chain sequence to resolve the unwrapped value. + * + * @name value + * @memberOf _ + * @since 0.1.0 + * @alias toJSON, valueOf + * @category Seq + * @returns {*} Returns the resolved unwrapped value. + * @example + * + * _([1, 2, 3]).value(); + * // => [1, 2, 3] + */ + function wrapperValue() { + return baseWrapperValue(this.__wrapped__, this.__actions__); + } + + /*------------------------------------------------------------------------*/ + + /** + * Creates an object composed of keys generated from the results of running + * each element of `collection` thru `iteratee`. The corresponding value of + * each key is the number of times the key was returned by `iteratee`. The + * iteratee is invoked with one argument: (value). + * + * @static + * @memberOf _ + * @since 0.5.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [iteratee=_.identity] + * The iteratee to transform keys. + * @returns {Object} Returns the composed aggregate object. + * @example + * + * _.countBy([6.1, 4.2, 6.3], Math.floor); + * // => { '4': 1, '6': 2 } + * + * // The `_.property` iteratee shorthand. + * _.countBy(['one', 'two', 'three'], 'length'); + * // => { '3': 2, '5': 1 } + */ + var countBy = createAggregator(function(result, value, key) { + if (hasOwnProperty.call(result, key)) { + ++result[key]; + } else { + baseAssignValue(result, key, 1); + } + }); + + /** + * Checks if `predicate` returns truthy for **all** elements of `collection`. + * Iteration is stopped once `predicate` returns falsey. The predicate is + * invoked with three arguments: (value, index|key, collection). + * + * **Note:** This method returns `true` for + * [empty collections](https://en.wikipedia.org/wiki/Empty_set) because + * [everything is true](https://en.wikipedia.org/wiki/Vacuous_truth) of + * elements of empty collections. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [predicate=_.identity] + * The function invoked per iteration. + * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`. + * @returns {boolean} Returns `true` if all elements pass the predicate check, + * else `false`. + * @example + * + * _.every([true, 1, null, 'yes'], Boolean); + * // => false + * + * var users = [ + * { 'user': 'barney', 'age': 36, 'active': false }, + * { 'user': 'fred', 'age': 40, 'active': false } + * ]; + * + * // The `_.matches` iteratee shorthand. + * _.every(users, { 'user': 'barney', 'active': false }); + * // => false + * + * // The `_.matchesProperty` iteratee shorthand. + * _.every(users, ['active', false]); + * // => true + * + * // The `_.property` iteratee shorthand. + * _.every(users, 'active'); + * // => false + */ + function every(collection, predicate, guard) { + var func = isArray(collection) ? arrayEvery : baseEvery; + if (guard && isIterateeCall(collection, predicate, guard)) { + predicate = undefined; + } + return func(collection, getIteratee(predicate, 3)); + } + + /** + * Iterates over elements of `collection`, returning an array of all elements + * `predicate` returns truthy for. The predicate is invoked with three + * arguments: (value, index|key, collection). + * + * **Note:** Unlike `_.remove`, this method returns a new array. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [predicate=_.identity] + * The function invoked per iteration. + * @returns {Array} Returns the new filtered array. + * @see _.reject + * @example + * + * var users = [ + * { 'user': 'barney', 'age': 36, 'active': true }, + * { 'user': 'fred', 'age': 40, 'active': false } + * ]; + * + * _.filter(users, function(o) { return !o.active; }); + * // => objects for ['fred'] + * + * // The `_.matches` iteratee shorthand. + * _.filter(users, { 'age': 36, 'active': true }); + * // => objects for ['barney'] + * + * // The `_.matchesProperty` iteratee shorthand. + * _.filter(users, ['active', false]); + * // => objects for ['fred'] + * + * // The `_.property` iteratee shorthand. + * _.filter(users, 'active'); + * // => objects for ['barney'] + */ + function filter(collection, predicate) { + var func = isArray(collection) ? arrayFilter : baseFilter; + return func(collection, getIteratee(predicate, 3)); + } + + /** + * Iterates over elements of `collection`, returning the first element + * `predicate` returns truthy for. The predicate is invoked with three + * arguments: (value, index|key, collection). + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Collection + * @param {Array|Object} collection The collection to inspect. + * @param {Function} [predicate=_.identity] + * The function invoked per iteration. + * @param {number} [fromIndex=0] The index to search from. + * @returns {*} Returns the matched element, else `undefined`. + * @example + * + * var users = [ + * { 'user': 'barney', 'age': 36, 'active': true }, + * { 'user': 'fred', 'age': 40, 'active': false }, + * { 'user': 'pebbles', 'age': 1, 'active': true } + * ]; + * + * _.find(users, function(o) { return o.age < 40; }); + * // => object for 'barney' + * + * // The `_.matches` iteratee shorthand. + * _.find(users, { 'age': 1, 'active': true }); + * // => object for 'pebbles' + * + * // The `_.matchesProperty` iteratee shorthand. + * _.find(users, ['active', false]); + * // => object for 'fred' + * + * // The `_.property` iteratee shorthand. + * _.find(users, 'active'); + * // => object for 'barney' + */ + var find = createFind(findIndex); + + /** + * This method is like `_.find` except that it iterates over elements of + * `collection` from right to left. + * + * @static + * @memberOf _ + * @since 2.0.0 + * @category Collection + * @param {Array|Object} collection The collection to inspect. + * @param {Function} [predicate=_.identity] + * The function invoked per iteration. + * @param {number} [fromIndex=collection.length-1] The index to search from. + * @returns {*} Returns the matched element, else `undefined`. + * @example + * + * _.findLast([1, 2, 3, 4], function(n) { + * return n % 2 == 1; + * }); + * // => 3 + */ + var findLast = createFind(findLastIndex); + + /** + * Creates a flattened array of values by running each element in `collection` + * thru `iteratee` and flattening the mapped results. The iteratee is invoked + * with three arguments: (value, index|key, collection). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [iteratee=_.identity] + * The function invoked per iteration. + * @returns {Array} Returns the new flattened array. + * @example + * + * function duplicate(n) { + * return [n, n]; + * } + * + * _.flatMap([1, 2], duplicate); + * // => [1, 1, 2, 2] + */ + function flatMap(collection, iteratee) { + return baseFlatten(map(collection, iteratee), 1); + } + + /** + * This method is like `_.flatMap` except that it recursively flattens the + * mapped results. + * + * @static + * @memberOf _ + * @since 4.7.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [iteratee=_.identity] + * The function invoked per iteration. + * @returns {Array} Returns the new flattened array. + * @example + * + * function duplicate(n) { + * return [[[n, n]]]; + * } + * + * _.flatMapDeep([1, 2], duplicate); + * // => [1, 1, 2, 2] + */ + function flatMapDeep(collection, iteratee) { + return baseFlatten(map(collection, iteratee), INFINITY); + } + + /** + * This method is like `_.flatMap` except that it recursively flattens the + * mapped results up to `depth` times. + * + * @static + * @memberOf _ + * @since 4.7.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [iteratee=_.identity] + * The function invoked per iteration. + * @param {number} [depth=1] The maximum recursion depth. + * @returns {Array} Returns the new flattened array. + * @example + * + * function duplicate(n) { + * return [[[n, n]]]; + * } + * + * _.flatMapDepth([1, 2], duplicate, 2); + * // => [[1, 1], [2, 2]] + */ + function flatMapDepth(collection, iteratee, depth) { + depth = depth === undefined ? 1 : toInteger(depth); + return baseFlatten(map(collection, iteratee), depth); + } + + /** + * Iterates over elements of `collection` and invokes `iteratee` for each element. + * The iteratee is invoked with three arguments: (value, index|key, collection). + * Iteratee functions may exit iteration early by explicitly returning `false`. + * + * **Note:** As with other "Collections" methods, objects with a "length" + * property are iterated like arrays. To avoid this behavior use `_.forIn` + * or `_.forOwn` for object iteration. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @alias each + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [iteratee=_.identity] The function invoked per iteration. + * @returns {Array|Object} Returns `collection`. + * @see _.forEachRight + * @example + * + * _.forEach([1, 2], function(value) { + * console.log(value); + * }); + * // => Logs `1` then `2`. + * + * _.forEach({ 'a': 1, 'b': 2 }, function(value, key) { + * console.log(key); + * }); + * // => Logs 'a' then 'b' (iteration order is not guaranteed). + */ + function forEach(collection, iteratee) { + var func = isArray(collection) ? arrayEach : baseEach; + return func(collection, getIteratee(iteratee, 3)); + } + + /** + * This method is like `_.forEach` except that it iterates over elements of + * `collection` from right to left. + * + * @static + * @memberOf _ + * @since 2.0.0 + * @alias eachRight + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [iteratee=_.identity] The function invoked per iteration. + * @returns {Array|Object} Returns `collection`. + * @see _.forEach + * @example + * + * _.forEachRight([1, 2], function(value) { + * console.log(value); + * }); + * // => Logs `2` then `1`. + */ + function forEachRight(collection, iteratee) { + var func = isArray(collection) ? arrayEachRight : baseEachRight; + return func(collection, getIteratee(iteratee, 3)); + } + + /** + * Creates an object composed of keys generated from the results of running + * each element of `collection` thru `iteratee`. The order of grouped values + * is determined by the order they occur in `collection`. The corresponding + * value of each key is an array of elements responsible for generating the + * key. The iteratee is invoked with one argument: (value). + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [iteratee=_.identity] + * The iteratee to transform keys. + * @returns {Object} Returns the composed aggregate object. + * @example + * + * _.groupBy([6.1, 4.2, 6.3], Math.floor); + * // => { '4': [4.2], '6': [6.1, 6.3] } + * + * // The `_.property` iteratee shorthand. + * _.groupBy(['one', 'two', 'three'], 'length'); + * // => { '3': ['one', 'two'], '5': ['three'] } + */ + var groupBy = createAggregator(function(result, value, key) { + if (hasOwnProperty.call(result, key)) { + result[key].push(value); + } else { + baseAssignValue(result, key, [value]); + } + }); + + /** + * Checks if `value` is in `collection`. If `collection` is a string, it's + * checked for a substring of `value`, otherwise + * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero) + * is used for equality comparisons. If `fromIndex` is negative, it's used as + * the offset from the end of `collection`. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Collection + * @param {Array|Object|string} collection The collection to inspect. + * @param {*} value The value to search for. + * @param {number} [fromIndex=0] The index to search from. + * @param- {Object} [guard] Enables use as an iteratee for methods like `_.reduce`. + * @returns {boolean} Returns `true` if `value` is found, else `false`. + * @example + * + * _.includes([1, 2, 3], 1); + * // => true + * + * _.includes([1, 2, 3], 1, 2); + * // => false + * + * _.includes({ 'a': 1, 'b': 2 }, 1); + * // => true + * + * _.includes('abcd', 'bc'); + * // => true + */ + function includes(collection, value, fromIndex, guard) { + collection = isArrayLike(collection) ? collection : values(collection); + fromIndex = (fromIndex && !guard) ? toInteger(fromIndex) : 0; + + var length = collection.length; + if (fromIndex < 0) { + fromIndex = nativeMax(length + fromIndex, 0); + } + return isString(collection) + ? (fromIndex <= length && collection.indexOf(value, fromIndex) > -1) + : (!!length && baseIndexOf(collection, value, fromIndex) > -1); + } + + /** + * Invokes the method at `path` of each element in `collection`, returning + * an array of the results of each invoked method. Any additional arguments + * are provided to each invoked method. If `path` is a function, it's invoked + * for, and `this` bound to, each element in `collection`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Array|Function|string} path The path of the method to invoke or + * the function invoked per iteration. + * @param {...*} [args] The arguments to invoke each method with. + * @returns {Array} Returns the array of results. + * @example + * + * _.invokeMap([[5, 1, 7], [3, 2, 1]], 'sort'); + * // => [[1, 5, 7], [1, 2, 3]] + * + * _.invokeMap([123, 456], String.prototype.split, ''); + * // => [['1', '2', '3'], ['4', '5', '6']] + */ + var invokeMap = baseRest(function(collection, path, args) { + var index = -1, + isFunc = typeof path == 'function', + isProp = isKey(path), + result = isArrayLike(collection) ? Array(collection.length) : []; + + baseEach(collection, function(value) { + var func = isFunc ? path : ((isProp && value != null) ? value[path] : undefined); + result[++index] = func ? apply(func, value, args) : baseInvoke(value, path, args); + }); + return result; + }); + + /** + * Creates an object composed of keys generated from the results of running + * each element of `collection` thru `iteratee`. The corresponding value of + * each key is the last element responsible for generating the key. The + * iteratee is invoked with one argument: (value). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [iteratee=_.identity] + * The iteratee to transform keys. + * @returns {Object} Returns the composed aggregate object. + * @example + * + * var array = [ + * { 'dir': 'left', 'code': 97 }, + * { 'dir': 'right', 'code': 100 } + * ]; + * + * _.keyBy(array, function(o) { + * return String.fromCharCode(o.code); + * }); + * // => { 'a': { 'dir': 'left', 'code': 97 }, 'd': { 'dir': 'right', 'code': 100 } } + * + * _.keyBy(array, 'dir'); + * // => { 'left': { 'dir': 'left', 'code': 97 }, 'right': { 'dir': 'right', 'code': 100 } } + */ + var keyBy = createAggregator(function(result, value, key) { + baseAssignValue(result, key, value); + }); + + /** + * Creates an array of values by running each element in `collection` thru + * `iteratee`. The iteratee is invoked with three arguments: + * (value, index|key, collection). + * + * Many lodash methods are guarded to work as iteratees for methods like + * `_.every`, `_.filter`, `_.map`, `_.mapValues`, `_.reject`, and `_.some`. + * + * The guarded methods are: + * `ary`, `chunk`, `curry`, `curryRight`, `drop`, `dropRight`, `every`, + * `fill`, `invert`, `parseInt`, `random`, `range`, `rangeRight`, `repeat`, + * `sampleSize`, `slice`, `some`, `sortBy`, `split`, `take`, `takeRight`, + * `template`, `trim`, `trimEnd`, `trimStart`, and `words` + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [iteratee=_.identity] The function invoked per iteration. + * @returns {Array} Returns the new mapped array. + * @example + * + * function square(n) { + * return n * n; + * } + * + * _.map([4, 8], square); + * // => [16, 64] + * + * _.map({ 'a': 4, 'b': 8 }, square); + * // => [16, 64] (iteration order is not guaranteed) + * + * var users = [ + * { 'user': 'barney' }, + * { 'user': 'fred' } + * ]; + * + * // The `_.property` iteratee shorthand. + * _.map(users, 'user'); + * // => ['barney', 'fred'] + */ + function map(collection, iteratee) { + var func = isArray(collection) ? arrayMap : baseMap; + return func(collection, getIteratee(iteratee, 3)); + } + + /** + * This method is like `_.sortBy` except that it allows specifying the sort + * orders of the iteratees to sort by. If `orders` is unspecified, all values + * are sorted in ascending order. Otherwise, specify an order of "desc" for + * descending or "asc" for ascending sort order of corresponding values. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Array[]|Function[]|Object[]|string[]} [iteratees=[_.identity]] + * The iteratees to sort by. + * @param {string[]} [orders] The sort orders of `iteratees`. + * @param- {Object} [guard] Enables use as an iteratee for methods like `_.reduce`. + * @returns {Array} Returns the new sorted array. + * @example + * + * var users = [ + * { 'user': 'fred', 'age': 48 }, + * { 'user': 'barney', 'age': 34 }, + * { 'user': 'fred', 'age': 40 }, + * { 'user': 'barney', 'age': 36 } + * ]; + * + * // Sort by `user` in ascending order and by `age` in descending order. + * _.orderBy(users, ['user', 'age'], ['asc', 'desc']); + * // => objects for [['barney', 36], ['barney', 34], ['fred', 48], ['fred', 40]] + */ + function orderBy(collection, iteratees, orders, guard) { + if (collection == null) { + return []; + } + if (!isArray(iteratees)) { + iteratees = iteratees == null ? [] : [iteratees]; + } + orders = guard ? undefined : orders; + if (!isArray(orders)) { + orders = orders == null ? [] : [orders]; + } + return baseOrderBy(collection, iteratees, orders); + } + + /** + * Creates an array of elements split into two groups, the first of which + * contains elements `predicate` returns truthy for, the second of which + * contains elements `predicate` returns falsey for. The predicate is + * invoked with one argument: (value). + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [predicate=_.identity] The function invoked per iteration. + * @returns {Array} Returns the array of grouped elements. + * @example + * + * var users = [ + * { 'user': 'barney', 'age': 36, 'active': false }, + * { 'user': 'fred', 'age': 40, 'active': true }, + * { 'user': 'pebbles', 'age': 1, 'active': false } + * ]; + * + * _.partition(users, function(o) { return o.active; }); + * // => objects for [['fred'], ['barney', 'pebbles']] + * + * // The `_.matches` iteratee shorthand. + * _.partition(users, { 'age': 1, 'active': false }); + * // => objects for [['pebbles'], ['barney', 'fred']] + * + * // The `_.matchesProperty` iteratee shorthand. + * _.partition(users, ['active', false]); + * // => objects for [['barney', 'pebbles'], ['fred']] + * + * // The `_.property` iteratee shorthand. + * _.partition(users, 'active'); + * // => objects for [['fred'], ['barney', 'pebbles']] + */ + var partition = createAggregator(function(result, value, key) { + result[key ? 0 : 1].push(value); + }, function() { return [[], []]; }); + + /** + * Reduces `collection` to a value which is the accumulated result of running + * each element in `collection` thru `iteratee`, where each successive + * invocation is supplied the return value of the previous. If `accumulator` + * is not given, the first element of `collection` is used as the initial + * value. The iteratee is invoked with four arguments: + * (accumulator, value, index|key, collection). + * + * Many lodash methods are guarded to work as iteratees for methods like + * `_.reduce`, `_.reduceRight`, and `_.transform`. + * + * The guarded methods are: + * `assign`, `defaults`, `defaultsDeep`, `includes`, `merge`, `orderBy`, + * and `sortBy` + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [iteratee=_.identity] The function invoked per iteration. + * @param {*} [accumulator] The initial value. + * @returns {*} Returns the accumulated value. + * @see _.reduceRight + * @example + * + * _.reduce([1, 2], function(sum, n) { + * return sum + n; + * }, 0); + * // => 3 + * + * _.reduce({ 'a': 1, 'b': 2, 'c': 1 }, function(result, value, key) { + * (result[value] || (result[value] = [])).push(key); + * return result; + * }, {}); + * // => { '1': ['a', 'c'], '2': ['b'] } (iteration order is not guaranteed) + */ + function reduce(collection, iteratee, accumulator) { + var func = isArray(collection) ? arrayReduce : baseReduce, + initAccum = arguments.length < 3; + + return func(collection, getIteratee(iteratee, 4), accumulator, initAccum, baseEach); + } + + /** + * This method is like `_.reduce` except that it iterates over elements of + * `collection` from right to left. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [iteratee=_.identity] The function invoked per iteration. + * @param {*} [accumulator] The initial value. + * @returns {*} Returns the accumulated value. + * @see _.reduce + * @example + * + * var array = [[0, 1], [2, 3], [4, 5]]; + * + * _.reduceRight(array, function(flattened, other) { + * return flattened.concat(other); + * }, []); + * // => [4, 5, 2, 3, 0, 1] + */ + function reduceRight(collection, iteratee, accumulator) { + var func = isArray(collection) ? arrayReduceRight : baseReduce, + initAccum = arguments.length < 3; + + return func(collection, getIteratee(iteratee, 4), accumulator, initAccum, baseEachRight); + } + + /** + * The opposite of `_.filter`; this method returns the elements of `collection` + * that `predicate` does **not** return truthy for. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [predicate=_.identity] The function invoked per iteration. + * @returns {Array} Returns the new filtered array. + * @see _.filter + * @example + * + * var users = [ + * { 'user': 'barney', 'age': 36, 'active': false }, + * { 'user': 'fred', 'age': 40, 'active': true } + * ]; + * + * _.reject(users, function(o) { return !o.active; }); + * // => objects for ['fred'] + * + * // The `_.matches` iteratee shorthand. + * _.reject(users, { 'age': 40, 'active': true }); + * // => objects for ['barney'] + * + * // The `_.matchesProperty` iteratee shorthand. + * _.reject(users, ['active', false]); + * // => objects for ['fred'] + * + * // The `_.property` iteratee shorthand. + * _.reject(users, 'active'); + * // => objects for ['barney'] + */ + function reject(collection, predicate) { + var func = isArray(collection) ? arrayFilter : baseFilter; + return func(collection, negate(getIteratee(predicate, 3))); + } + + /** + * Gets a random element from `collection`. + * + * @static + * @memberOf _ + * @since 2.0.0 + * @category Collection + * @param {Array|Object} collection The collection to sample. + * @returns {*} Returns the random element. + * @example + * + * _.sample([1, 2, 3, 4]); + * // => 2 + */ + function sample(collection) { + var func = isArray(collection) ? arraySample : baseSample; + return func(collection); + } + + /** + * Gets `n` random elements at unique keys from `collection` up to the + * size of `collection`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Collection + * @param {Array|Object} collection The collection to sample. + * @param {number} [n=1] The number of elements to sample. + * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`. + * @returns {Array} Returns the random elements. + * @example + * + * _.sampleSize([1, 2, 3], 2); + * // => [3, 1] + * + * _.sampleSize([1, 2, 3], 4); + * // => [2, 3, 1] + */ + function sampleSize(collection, n, guard) { + if ((guard ? isIterateeCall(collection, n, guard) : n === undefined)) { + n = 1; + } else { + n = toInteger(n); + } + var func = isArray(collection) ? arraySampleSize : baseSampleSize; + return func(collection, n); + } + + /** + * Creates an array of shuffled values, using a version of the + * [Fisher-Yates shuffle](https://en.wikipedia.org/wiki/Fisher-Yates_shuffle). + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Collection + * @param {Array|Object} collection The collection to shuffle. + * @returns {Array} Returns the new shuffled array. + * @example + * + * _.shuffle([1, 2, 3, 4]); + * // => [4, 1, 3, 2] + */ + function shuffle(collection) { + var func = isArray(collection) ? arrayShuffle : baseShuffle; + return func(collection); + } + + /** + * Gets the size of `collection` by returning its length for array-like + * values or the number of own enumerable string keyed properties for objects. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Collection + * @param {Array|Object|string} collection The collection to inspect. + * @returns {number} Returns the collection size. + * @example + * + * _.size([1, 2, 3]); + * // => 3 + * + * _.size({ 'a': 1, 'b': 2 }); + * // => 2 + * + * _.size('pebbles'); + * // => 7 + */ + function size(collection) { + if (collection == null) { + return 0; + } + if (isArrayLike(collection)) { + return isString(collection) ? stringSize(collection) : collection.length; + } + var tag = getTag(collection); + if (tag == mapTag || tag == setTag) { + return collection.size; + } + return baseKeys(collection).length; + } + + /** + * Checks if `predicate` returns truthy for **any** element of `collection`. + * Iteration is stopped once `predicate` returns truthy. The predicate is + * invoked with three arguments: (value, index|key, collection). + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [predicate=_.identity] The function invoked per iteration. + * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`. + * @returns {boolean} Returns `true` if any element passes the predicate check, + * else `false`. + * @example + * + * _.some([null, 0, 'yes', false], Boolean); + * // => true + * + * var users = [ + * { 'user': 'barney', 'active': true }, + * { 'user': 'fred', 'active': false } + * ]; + * + * // The `_.matches` iteratee shorthand. + * _.some(users, { 'user': 'barney', 'active': false }); + * // => false + * + * // The `_.matchesProperty` iteratee shorthand. + * _.some(users, ['active', false]); + * // => true + * + * // The `_.property` iteratee shorthand. + * _.some(users, 'active'); + * // => true + */ + function some(collection, predicate, guard) { + var func = isArray(collection) ? arraySome : baseSome; + if (guard && isIterateeCall(collection, predicate, guard)) { + predicate = undefined; + } + return func(collection, getIteratee(predicate, 3)); + } + + /** + * Creates an array of elements, sorted in ascending order by the results of + * running each element in a collection thru each iteratee. This method + * performs a stable sort, that is, it preserves the original sort order of + * equal elements. The iteratees are invoked with one argument: (value). + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {...(Function|Function[])} [iteratees=[_.identity]] + * The iteratees to sort by. + * @returns {Array} Returns the new sorted array. + * @example + * + * var users = [ + * { 'user': 'fred', 'age': 48 }, + * { 'user': 'barney', 'age': 36 }, + * { 'user': 'fred', 'age': 40 }, + * { 'user': 'barney', 'age': 34 } + * ]; + * + * _.sortBy(users, [function(o) { return o.user; }]); + * // => objects for [['barney', 36], ['barney', 34], ['fred', 48], ['fred', 40]] + * + * _.sortBy(users, ['user', 'age']); + * // => objects for [['barney', 34], ['barney', 36], ['fred', 40], ['fred', 48]] + */ + var sortBy = baseRest(function(collection, iteratees) { + if (collection == null) { + return []; + } + var length = iteratees.length; + if (length > 1 && isIterateeCall(collection, iteratees[0], iteratees[1])) { + iteratees = []; + } else if (length > 2 && isIterateeCall(iteratees[0], iteratees[1], iteratees[2])) { + iteratees = [iteratees[0]]; + } + return baseOrderBy(collection, baseFlatten(iteratees, 1), []); + }); + + /*------------------------------------------------------------------------*/ + + /** + * Gets the timestamp of the number of milliseconds that have elapsed since + * the Unix epoch (1 January 1970 00:00:00 UTC). + * + * @static + * @memberOf _ + * @since 2.4.0 + * @category Date + * @returns {number} Returns the timestamp. + * @example + * + * _.defer(function(stamp) { + * console.log(_.now() - stamp); + * }, _.now()); + * // => Logs the number of milliseconds it took for the deferred invocation. + */ + var now = ctxNow || function() { + return root.Date.now(); + }; + + /*------------------------------------------------------------------------*/ + + /** + * The opposite of `_.before`; this method creates a function that invokes + * `func` once it's called `n` or more times. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Function + * @param {number} n The number of calls before `func` is invoked. + * @param {Function} func The function to restrict. + * @returns {Function} Returns the new restricted function. + * @example + * + * var saves = ['profile', 'settings']; + * + * var done = _.after(saves.length, function() { + * console.log('done saving!'); + * }); + * + * _.forEach(saves, function(type) { + * asyncSave({ 'type': type, 'complete': done }); + * }); + * // => Logs 'done saving!' after the two async saves have completed. + */ + function after(n, func) { + if (typeof func != 'function') { + throw new TypeError(FUNC_ERROR_TEXT); + } + n = toInteger(n); + return function() { + if (--n < 1) { + return func.apply(this, arguments); + } + }; + } + + /** + * Creates a function that invokes `func`, with up to `n` arguments, + * ignoring any additional arguments. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Function + * @param {Function} func The function to cap arguments for. + * @param {number} [n=func.length] The arity cap. + * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`. + * @returns {Function} Returns the new capped function. + * @example + * + * _.map(['6', '8', '10'], _.ary(parseInt, 1)); + * // => [6, 8, 10] + */ + function ary(func, n, guard) { + n = guard ? undefined : n; + n = (func && n == null) ? func.length : n; + return createWrap(func, ARY_FLAG, undefined, undefined, undefined, undefined, n); + } + + /** + * Creates a function that invokes `func`, with the `this` binding and arguments + * of the created function, while it's called less than `n` times. Subsequent + * calls to the created function return the result of the last `func` invocation. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Function + * @param {number} n The number of calls at which `func` is no longer invoked. + * @param {Function} func The function to restrict. + * @returns {Function} Returns the new restricted function. + * @example + * + * jQuery(element).on('click', _.before(5, addContactToList)); + * // => Allows adding up to 4 contacts to the list. + */ + function before(n, func) { + var result; + if (typeof func != 'function') { + throw new TypeError(FUNC_ERROR_TEXT); + } + n = toInteger(n); + return function() { + if (--n > 0) { + result = func.apply(this, arguments); + } + if (n <= 1) { + func = undefined; + } + return result; + }; + } + + /** + * Creates a function that invokes `func` with the `this` binding of `thisArg` + * and `partials` prepended to the arguments it receives. + * + * The `_.bind.placeholder` value, which defaults to `_` in monolithic builds, + * may be used as a placeholder for partially applied arguments. + * + * **Note:** Unlike native `Function#bind`, this method doesn't set the "length" + * property of bound functions. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Function + * @param {Function} func The function to bind. + * @param {*} thisArg The `this` binding of `func`. + * @param {...*} [partials] The arguments to be partially applied. + * @returns {Function} Returns the new bound function. + * @example + * + * function greet(greeting, punctuation) { + * return greeting + ' ' + this.user + punctuation; + * } + * + * var object = { 'user': 'fred' }; + * + * var bound = _.bind(greet, object, 'hi'); + * bound('!'); + * // => 'hi fred!' + * + * // Bound with placeholders. + * var bound = _.bind(greet, object, _, '!'); + * bound('hi'); + * // => 'hi fred!' + */ + var bind = baseRest(function(func, thisArg, partials) { + var bitmask = BIND_FLAG; + if (partials.length) { + var holders = replaceHolders(partials, getHolder(bind)); + bitmask |= PARTIAL_FLAG; + } + return createWrap(func, bitmask, thisArg, partials, holders); + }); + + /** + * Creates a function that invokes the method at `object[key]` with `partials` + * prepended to the arguments it receives. + * + * This method differs from `_.bind` by allowing bound functions to reference + * methods that may be redefined or don't yet exist. See + * [Peter Michaux's article](http://peter.michaux.ca/articles/lazy-function-definition-pattern) + * for more details. + * + * The `_.bindKey.placeholder` value, which defaults to `_` in monolithic + * builds, may be used as a placeholder for partially applied arguments. + * + * @static + * @memberOf _ + * @since 0.10.0 + * @category Function + * @param {Object} object The object to invoke the method on. + * @param {string} key The key of the method. + * @param {...*} [partials] The arguments to be partially applied. + * @returns {Function} Returns the new bound function. + * @example + * + * var object = { + * 'user': 'fred', + * 'greet': function(greeting, punctuation) { + * return greeting + ' ' + this.user + punctuation; + * } + * }; + * + * var bound = _.bindKey(object, 'greet', 'hi'); + * bound('!'); + * // => 'hi fred!' + * + * object.greet = function(greeting, punctuation) { + * return greeting + 'ya ' + this.user + punctuation; + * }; + * + * bound('!'); + * // => 'hiya fred!' + * + * // Bound with placeholders. + * var bound = _.bindKey(object, 'greet', _, '!'); + * bound('hi'); + * // => 'hiya fred!' + */ + var bindKey = baseRest(function(object, key, partials) { + var bitmask = BIND_FLAG | BIND_KEY_FLAG; + if (partials.length) { + var holders = replaceHolders(partials, getHolder(bindKey)); + bitmask |= PARTIAL_FLAG; + } + return createWrap(key, bitmask, object, partials, holders); + }); + + /** + * Creates a function that accepts arguments of `func` and either invokes + * `func` returning its result, if at least `arity` number of arguments have + * been provided, or returns a function that accepts the remaining `func` + * arguments, and so on. The arity of `func` may be specified if `func.length` + * is not sufficient. + * + * The `_.curry.placeholder` value, which defaults to `_` in monolithic builds, + * may be used as a placeholder for provided arguments. + * + * **Note:** This method doesn't set the "length" property of curried functions. + * + * @static + * @memberOf _ + * @since 2.0.0 + * @category Function + * @param {Function} func The function to curry. + * @param {number} [arity=func.length] The arity of `func`. + * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`. + * @returns {Function} Returns the new curried function. + * @example + * + * var abc = function(a, b, c) { + * return [a, b, c]; + * }; + * + * var curried = _.curry(abc); + * + * curried(1)(2)(3); + * // => [1, 2, 3] + * + * curried(1, 2)(3); + * // => [1, 2, 3] + * + * curried(1, 2, 3); + * // => [1, 2, 3] + * + * // Curried with placeholders. + * curried(1)(_, 3)(2); + * // => [1, 2, 3] + */ + function curry(func, arity, guard) { + arity = guard ? undefined : arity; + var result = createWrap(func, CURRY_FLAG, undefined, undefined, undefined, undefined, undefined, arity); + result.placeholder = curry.placeholder; + return result; + } + + /** + * This method is like `_.curry` except that arguments are applied to `func` + * in the manner of `_.partialRight` instead of `_.partial`. + * + * The `_.curryRight.placeholder` value, which defaults to `_` in monolithic + * builds, may be used as a placeholder for provided arguments. + * + * **Note:** This method doesn't set the "length" property of curried functions. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Function + * @param {Function} func The function to curry. + * @param {number} [arity=func.length] The arity of `func`. + * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`. + * @returns {Function} Returns the new curried function. + * @example + * + * var abc = function(a, b, c) { + * return [a, b, c]; + * }; + * + * var curried = _.curryRight(abc); + * + * curried(3)(2)(1); + * // => [1, 2, 3] + * + * curried(2, 3)(1); + * // => [1, 2, 3] + * + * curried(1, 2, 3); + * // => [1, 2, 3] + * + * // Curried with placeholders. + * curried(3)(1, _)(2); + * // => [1, 2, 3] + */ + function curryRight(func, arity, guard) { + arity = guard ? undefined : arity; + var result = createWrap(func, CURRY_RIGHT_FLAG, undefined, undefined, undefined, undefined, undefined, arity); + result.placeholder = curryRight.placeholder; + return result; + } + + /** + * Creates a debounced function that delays invoking `func` until after `wait` + * milliseconds have elapsed since the last time the debounced function was + * invoked. The debounced function comes with a `cancel` method to cancel + * delayed `func` invocations and a `flush` method to immediately invoke them. + * Provide `options` to indicate whether `func` should be invoked on the + * leading and/or trailing edge of the `wait` timeout. The `func` is invoked + * with the last arguments provided to the debounced function. Subsequent + * calls to the debounced function return the result of the last `func` + * invocation. + * + * **Note:** If `leading` and `trailing` options are `true`, `func` is + * invoked on the trailing edge of the timeout only if the debounced function + * is invoked more than once during the `wait` timeout. + * + * If `wait` is `0` and `leading` is `false`, `func` invocation is deferred + * until to the next tick, similar to `setTimeout` with a timeout of `0`. + * + * See [David Corbacho's article](https://css-tricks.com/debouncing-throttling-explained-examples/) + * for details over the differences between `_.debounce` and `_.throttle`. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Function + * @param {Function} func The function to debounce. + * @param {number} [wait=0] The number of milliseconds to delay. + * @param {Object} [options={}] The options object. + * @param {boolean} [options.leading=false] + * Specify invoking on the leading edge of the timeout. + * @param {number} [options.maxWait] + * The maximum time `func` is allowed to be delayed before it's invoked. + * @param {boolean} [options.trailing=true] + * Specify invoking on the trailing edge of the timeout. + * @returns {Function} Returns the new debounced function. + * @example + * + * // Avoid costly calculations while the window size is in flux. + * jQuery(window).on('resize', _.debounce(calculateLayout, 150)); + * + * // Invoke `sendMail` when clicked, debouncing subsequent calls. + * jQuery(element).on('click', _.debounce(sendMail, 300, { + * 'leading': true, + * 'trailing': false + * })); + * + * // Ensure `batchLog` is invoked once after 1 second of debounced calls. + * var debounced = _.debounce(batchLog, 250, { 'maxWait': 1000 }); + * var source = new EventSource('/stream'); + * jQuery(source).on('message', debounced); + * + * // Cancel the trailing debounced invocation. + * jQuery(window).on('popstate', debounced.cancel); + */ + function debounce(func, wait, options) { + var lastArgs, + lastThis, + maxWait, + result, + timerId, + lastCallTime, + lastInvokeTime = 0, + leading = false, + maxing = false, + trailing = true; + + if (typeof func != 'function') { + throw new TypeError(FUNC_ERROR_TEXT); + } + wait = toNumber(wait) || 0; + if (isObject(options)) { + leading = !!options.leading; + maxing = 'maxWait' in options; + maxWait = maxing ? nativeMax(toNumber(options.maxWait) || 0, wait) : maxWait; + trailing = 'trailing' in options ? !!options.trailing : trailing; + } + + function invokeFunc(time) { + var args = lastArgs, + thisArg = lastThis; + + lastArgs = lastThis = undefined; + lastInvokeTime = time; + result = func.apply(thisArg, args); + return result; + } + + function leadingEdge(time) { + // Reset any `maxWait` timer. + lastInvokeTime = time; + // Start the timer for the trailing edge. + timerId = setTimeout(timerExpired, wait); + // Invoke the leading edge. + return leading ? invokeFunc(time) : result; + } + + function remainingWait(time) { + var timeSinceLastCall = time - lastCallTime, + timeSinceLastInvoke = time - lastInvokeTime, + result = wait - timeSinceLastCall; + + return maxing ? nativeMin(result, maxWait - timeSinceLastInvoke) : result; + } + + function shouldInvoke(time) { + var timeSinceLastCall = time - lastCallTime, + timeSinceLastInvoke = time - lastInvokeTime; + + // Either this is the first call, activity has stopped and we're at the + // trailing edge, the system time has gone backwards and we're treating + // it as the trailing edge, or we've hit the `maxWait` limit. + return (lastCallTime === undefined || (timeSinceLastCall >= wait) || + (timeSinceLastCall < 0) || (maxing && timeSinceLastInvoke >= maxWait)); + } + + function timerExpired() { + var time = now(); + if (shouldInvoke(time)) { + return trailingEdge(time); + } + // Restart the timer. + timerId = setTimeout(timerExpired, remainingWait(time)); + } + + function trailingEdge(time) { + timerId = undefined; + + // Only invoke if we have `lastArgs` which means `func` has been + // debounced at least once. + if (trailing && lastArgs) { + return invokeFunc(time); + } + lastArgs = lastThis = undefined; + return result; + } + + function cancel() { + if (timerId !== undefined) { + clearTimeout(timerId); + } + lastInvokeTime = 0; + lastArgs = lastCallTime = lastThis = timerId = undefined; + } + + function flush() { + return timerId === undefined ? result : trailingEdge(now()); + } + + function debounced() { + var time = now(), + isInvoking = shouldInvoke(time); + + lastArgs = arguments; + lastThis = this; + lastCallTime = time; + + if (isInvoking) { + if (timerId === undefined) { + return leadingEdge(lastCallTime); + } + if (maxing) { + // Handle invocations in a tight loop. + timerId = setTimeout(timerExpired, wait); + return invokeFunc(lastCallTime); + } + } + if (timerId === undefined) { + timerId = setTimeout(timerExpired, wait); + } + return result; + } + debounced.cancel = cancel; + debounced.flush = flush; + return debounced; + } + + /** + * Defers invoking the `func` until the current call stack has cleared. Any + * additional arguments are provided to `func` when it's invoked. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Function + * @param {Function} func The function to defer. + * @param {...*} [args] The arguments to invoke `func` with. + * @returns {number} Returns the timer id. + * @example + * + * _.defer(function(text) { + * console.log(text); + * }, 'deferred'); + * // => Logs 'deferred' after one millisecond. + */ + var defer = baseRest(function(func, args) { + return baseDelay(func, 1, args); + }); + + /** + * Invokes `func` after `wait` milliseconds. Any additional arguments are + * provided to `func` when it's invoked. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Function + * @param {Function} func The function to delay. + * @param {number} wait The number of milliseconds to delay invocation. + * @param {...*} [args] The arguments to invoke `func` with. + * @returns {number} Returns the timer id. + * @example + * + * _.delay(function(text) { + * console.log(text); + * }, 1000, 'later'); + * // => Logs 'later' after one second. + */ + var delay = baseRest(function(func, wait, args) { + return baseDelay(func, toNumber(wait) || 0, args); + }); + + /** + * Creates a function that invokes `func` with arguments reversed. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Function + * @param {Function} func The function to flip arguments for. + * @returns {Function} Returns the new flipped function. + * @example + * + * var flipped = _.flip(function() { + * return _.toArray(arguments); + * }); + * + * flipped('a', 'b', 'c', 'd'); + * // => ['d', 'c', 'b', 'a'] + */ + function flip(func) { + return createWrap(func, FLIP_FLAG); + } + + /** + * Creates a function that memoizes the result of `func`. If `resolver` is + * provided, it determines the cache key for storing the result based on the + * arguments provided to the memoized function. By default, the first argument + * provided to the memoized function is used as the map cache key. The `func` + * is invoked with the `this` binding of the memoized function. + * + * **Note:** The cache is exposed as the `cache` property on the memoized + * function. Its creation may be customized by replacing the `_.memoize.Cache` + * constructor with one whose instances implement the + * [`Map`](http://ecma-international.org/ecma-262/7.0/#sec-properties-of-the-map-prototype-object) + * method interface of `delete`, `get`, `has`, and `set`. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Function + * @param {Function} func The function to have its output memoized. + * @param {Function} [resolver] The function to resolve the cache key. + * @returns {Function} Returns the new memoized function. + * @example + * + * var object = { 'a': 1, 'b': 2 }; + * var other = { 'c': 3, 'd': 4 }; + * + * var values = _.memoize(_.values); + * values(object); + * // => [1, 2] + * + * values(other); + * // => [3, 4] + * + * object.a = 2; + * values(object); + * // => [1, 2] + * + * // Modify the result cache. + * values.cache.set(object, ['a', 'b']); + * values(object); + * // => ['a', 'b'] + * + * // Replace `_.memoize.Cache`. + * _.memoize.Cache = WeakMap; + */ + function memoize(func, resolver) { + if (typeof func != 'function' || (resolver && typeof resolver != 'function')) { + throw new TypeError(FUNC_ERROR_TEXT); + } + var memoized = function() { + var args = arguments, + key = resolver ? resolver.apply(this, args) : args[0], + cache = memoized.cache; + + if (cache.has(key)) { + return cache.get(key); + } + var result = func.apply(this, args); + memoized.cache = cache.set(key, result) || cache; + return result; + }; + memoized.cache = new (memoize.Cache || MapCache); + return memoized; + } + + // Expose `MapCache`. + memoize.Cache = MapCache; + + /** + * Creates a function that negates the result of the predicate `func`. The + * `func` predicate is invoked with the `this` binding and arguments of the + * created function. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Function + * @param {Function} predicate The predicate to negate. + * @returns {Function} Returns the new negated function. + * @example + * + * function isEven(n) { + * return n % 2 == 0; + * } + * + * _.filter([1, 2, 3, 4, 5, 6], _.negate(isEven)); + * // => [1, 3, 5] + */ + function negate(predicate) { + if (typeof predicate != 'function') { + throw new TypeError(FUNC_ERROR_TEXT); + } + return function() { + var args = arguments; + switch (args.length) { + case 0: return !predicate.call(this); + case 1: return !predicate.call(this, args[0]); + case 2: return !predicate.call(this, args[0], args[1]); + case 3: return !predicate.call(this, args[0], args[1], args[2]); + } + return !predicate.apply(this, args); + }; + } + + /** + * Creates a function that is restricted to invoking `func` once. Repeat calls + * to the function return the value of the first invocation. The `func` is + * invoked with the `this` binding and arguments of the created function. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Function + * @param {Function} func The function to restrict. + * @returns {Function} Returns the new restricted function. + * @example + * + * var initialize = _.once(createApplication); + * initialize(); + * initialize(); + * // => `createApplication` is invoked once + */ + function once(func) { + return before(2, func); + } + + /** + * Creates a function that invokes `func` with its arguments transformed. + * + * @static + * @since 4.0.0 + * @memberOf _ + * @category Function + * @param {Function} func The function to wrap. + * @param {...(Function|Function[])} [transforms=[_.identity]] + * The argument transforms. + * @returns {Function} Returns the new function. + * @example + * + * function doubled(n) { + * return n * 2; + * } + * + * function square(n) { + * return n * n; + * } + * + * var func = _.overArgs(function(x, y) { + * return [x, y]; + * }, [square, doubled]); + * + * func(9, 3); + * // => [81, 6] + * + * func(10, 5); + * // => [100, 10] + */ + var overArgs = castRest(function(func, transforms) { + transforms = (transforms.length == 1 && isArray(transforms[0])) + ? arrayMap(transforms[0], baseUnary(getIteratee())) + : arrayMap(baseFlatten(transforms, 1), baseUnary(getIteratee())); + + var funcsLength = transforms.length; + return baseRest(function(args) { + var index = -1, + length = nativeMin(args.length, funcsLength); + + while (++index < length) { + args[index] = transforms[index].call(this, args[index]); + } + return apply(func, this, args); + }); + }); + + /** + * Creates a function that invokes `func` with `partials` prepended to the + * arguments it receives. This method is like `_.bind` except it does **not** + * alter the `this` binding. + * + * The `_.partial.placeholder` value, which defaults to `_` in monolithic + * builds, may be used as a placeholder for partially applied arguments. + * + * **Note:** This method doesn't set the "length" property of partially + * applied functions. + * + * @static + * @memberOf _ + * @since 0.2.0 + * @category Function + * @param {Function} func The function to partially apply arguments to. + * @param {...*} [partials] The arguments to be partially applied. + * @returns {Function} Returns the new partially applied function. + * @example + * + * function greet(greeting, name) { + * return greeting + ' ' + name; + * } + * + * var sayHelloTo = _.partial(greet, 'hello'); + * sayHelloTo('fred'); + * // => 'hello fred' + * + * // Partially applied with placeholders. + * var greetFred = _.partial(greet, _, 'fred'); + * greetFred('hi'); + * // => 'hi fred' + */ + var partial = baseRest(function(func, partials) { + var holders = replaceHolders(partials, getHolder(partial)); + return createWrap(func, PARTIAL_FLAG, undefined, partials, holders); + }); + + /** + * This method is like `_.partial` except that partially applied arguments + * are appended to the arguments it receives. + * + * The `_.partialRight.placeholder` value, which defaults to `_` in monolithic + * builds, may be used as a placeholder for partially applied arguments. + * + * **Note:** This method doesn't set the "length" property of partially + * applied functions. + * + * @static + * @memberOf _ + * @since 1.0.0 + * @category Function + * @param {Function} func The function to partially apply arguments to. + * @param {...*} [partials] The arguments to be partially applied. + * @returns {Function} Returns the new partially applied function. + * @example + * + * function greet(greeting, name) { + * return greeting + ' ' + name; + * } + * + * var greetFred = _.partialRight(greet, 'fred'); + * greetFred('hi'); + * // => 'hi fred' + * + * // Partially applied with placeholders. + * var sayHelloTo = _.partialRight(greet, 'hello', _); + * sayHelloTo('fred'); + * // => 'hello fred' + */ + var partialRight = baseRest(function(func, partials) { + var holders = replaceHolders(partials, getHolder(partialRight)); + return createWrap(func, PARTIAL_RIGHT_FLAG, undefined, partials, holders); + }); + + /** + * Creates a function that invokes `func` with arguments arranged according + * to the specified `indexes` where the argument value at the first index is + * provided as the first argument, the argument value at the second index is + * provided as the second argument, and so on. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Function + * @param {Function} func The function to rearrange arguments for. + * @param {...(number|number[])} indexes The arranged argument indexes. + * @returns {Function} Returns the new function. + * @example + * + * var rearged = _.rearg(function(a, b, c) { + * return [a, b, c]; + * }, [2, 0, 1]); + * + * rearged('b', 'c', 'a') + * // => ['a', 'b', 'c'] + */ + var rearg = flatRest(function(func, indexes) { + return createWrap(func, REARG_FLAG, undefined, undefined, undefined, indexes); + }); + + /** + * Creates a function that invokes `func` with the `this` binding of the + * created function and arguments from `start` and beyond provided as + * an array. + * + * **Note:** This method is based on the + * [rest parameter](https://mdn.io/rest_parameters). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Function + * @param {Function} func The function to apply a rest parameter to. + * @param {number} [start=func.length-1] The start position of the rest parameter. + * @returns {Function} Returns the new function. + * @example + * + * var say = _.rest(function(what, names) { + * return what + ' ' + _.initial(names).join(', ') + + * (_.size(names) > 1 ? ', & ' : '') + _.last(names); + * }); + * + * say('hello', 'fred', 'barney', 'pebbles'); + * // => 'hello fred, barney, & pebbles' + */ + function rest(func, start) { + if (typeof func != 'function') { + throw new TypeError(FUNC_ERROR_TEXT); + } + start = start === undefined ? start : toInteger(start); + return baseRest(func, start); + } + + /** + * Creates a function that invokes `func` with the `this` binding of the + * create function and an array of arguments much like + * [`Function#apply`](http://www.ecma-international.org/ecma-262/7.0/#sec-function.prototype.apply). + * + * **Note:** This method is based on the + * [spread operator](https://mdn.io/spread_operator). + * + * @static + * @memberOf _ + * @since 3.2.0 + * @category Function + * @param {Function} func The function to spread arguments over. + * @param {number} [start=0] The start position of the spread. + * @returns {Function} Returns the new function. + * @example + * + * var say = _.spread(function(who, what) { + * return who + ' says ' + what; + * }); + * + * say(['fred', 'hello']); + * // => 'fred says hello' + * + * var numbers = Promise.all([ + * Promise.resolve(40), + * Promise.resolve(36) + * ]); + * + * numbers.then(_.spread(function(x, y) { + * return x + y; + * })); + * // => a Promise of 76 + */ + function spread(func, start) { + if (typeof func != 'function') { + throw new TypeError(FUNC_ERROR_TEXT); + } + start = start === undefined ? 0 : nativeMax(toInteger(start), 0); + return baseRest(function(args) { + var array = args[start], + otherArgs = castSlice(args, 0, start); + + if (array) { + arrayPush(otherArgs, array); + } + return apply(func, this, otherArgs); + }); + } + + /** + * Creates a throttled function that only invokes `func` at most once per + * every `wait` milliseconds. The throttled function comes with a `cancel` + * method to cancel delayed `func` invocations and a `flush` method to + * immediately invoke them. Provide `options` to indicate whether `func` + * should be invoked on the leading and/or trailing edge of the `wait` + * timeout. The `func` is invoked with the last arguments provided to the + * throttled function. Subsequent calls to the throttled function return the + * result of the last `func` invocation. + * + * **Note:** If `leading` and `trailing` options are `true`, `func` is + * invoked on the trailing edge of the timeout only if the throttled function + * is invoked more than once during the `wait` timeout. + * + * If `wait` is `0` and `leading` is `false`, `func` invocation is deferred + * until to the next tick, similar to `setTimeout` with a timeout of `0`. + * + * See [David Corbacho's article](https://css-tricks.com/debouncing-throttling-explained-examples/) + * for details over the differences between `_.throttle` and `_.debounce`. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Function + * @param {Function} func The function to throttle. + * @param {number} [wait=0] The number of milliseconds to throttle invocations to. + * @param {Object} [options={}] The options object. + * @param {boolean} [options.leading=true] + * Specify invoking on the leading edge of the timeout. + * @param {boolean} [options.trailing=true] + * Specify invoking on the trailing edge of the timeout. + * @returns {Function} Returns the new throttled function. + * @example + * + * // Avoid excessively updating the position while scrolling. + * jQuery(window).on('scroll', _.throttle(updatePosition, 100)); + * + * // Invoke `renewToken` when the click event is fired, but not more than once every 5 minutes. + * var throttled = _.throttle(renewToken, 300000, { 'trailing': false }); + * jQuery(element).on('click', throttled); + * + * // Cancel the trailing throttled invocation. + * jQuery(window).on('popstate', throttled.cancel); + */ + function throttle(func, wait, options) { + var leading = true, + trailing = true; + + if (typeof func != 'function') { + throw new TypeError(FUNC_ERROR_TEXT); + } + if (isObject(options)) { + leading = 'leading' in options ? !!options.leading : leading; + trailing = 'trailing' in options ? !!options.trailing : trailing; + } + return debounce(func, wait, { + 'leading': leading, + 'maxWait': wait, + 'trailing': trailing + }); + } + + /** + * Creates a function that accepts up to one argument, ignoring any + * additional arguments. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Function + * @param {Function} func The function to cap arguments for. + * @returns {Function} Returns the new capped function. + * @example + * + * _.map(['6', '8', '10'], _.unary(parseInt)); + * // => [6, 8, 10] + */ + function unary(func) { + return ary(func, 1); + } + + /** + * Creates a function that provides `value` to `wrapper` as its first + * argument. Any additional arguments provided to the function are appended + * to those provided to the `wrapper`. The wrapper is invoked with the `this` + * binding of the created function. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Function + * @param {*} value The value to wrap. + * @param {Function} [wrapper=identity] The wrapper function. + * @returns {Function} Returns the new function. + * @example + * + * var p = _.wrap(_.escape, function(func, text) { + * return '

' + func(text) + '

'; + * }); + * + * p('fred, barney, & pebbles'); + * // => '

fred, barney, & pebbles

' + */ + function wrap(value, wrapper) { + wrapper = wrapper == null ? identity : wrapper; + return partial(wrapper, value); + } + + /*------------------------------------------------------------------------*/ + + /** + * Casts `value` as an array if it's not one. + * + * @static + * @memberOf _ + * @since 4.4.0 + * @category Lang + * @param {*} value The value to inspect. + * @returns {Array} Returns the cast array. + * @example + * + * _.castArray(1); + * // => [1] + * + * _.castArray({ 'a': 1 }); + * // => [{ 'a': 1 }] + * + * _.castArray('abc'); + * // => ['abc'] + * + * _.castArray(null); + * // => [null] + * + * _.castArray(undefined); + * // => [undefined] + * + * _.castArray(); + * // => [] + * + * var array = [1, 2, 3]; + * console.log(_.castArray(array) === array); + * // => true + */ + function castArray() { + if (!arguments.length) { + return []; + } + var value = arguments[0]; + return isArray(value) ? value : [value]; + } + + /** + * Creates a shallow clone of `value`. + * + * **Note:** This method is loosely based on the + * [structured clone algorithm](https://mdn.io/Structured_clone_algorithm) + * and supports cloning arrays, array buffers, booleans, date objects, maps, + * numbers, `Object` objects, regexes, sets, strings, symbols, and typed + * arrays. The own enumerable properties of `arguments` objects are cloned + * as plain objects. An empty object is returned for uncloneable values such + * as error objects, functions, DOM nodes, and WeakMaps. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to clone. + * @returns {*} Returns the cloned value. + * @see _.cloneDeep + * @example + * + * var objects = [{ 'a': 1 }, { 'b': 2 }]; + * + * var shallow = _.clone(objects); + * console.log(shallow[0] === objects[0]); + * // => true + */ + function clone(value) { + return baseClone(value, false, true); + } + + /** + * This method is like `_.clone` except that it accepts `customizer` which + * is invoked to produce the cloned value. If `customizer` returns `undefined`, + * cloning is handled by the method instead. The `customizer` is invoked with + * up to four arguments; (value [, index|key, object, stack]). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to clone. + * @param {Function} [customizer] The function to customize cloning. + * @returns {*} Returns the cloned value. + * @see _.cloneDeepWith + * @example + * + * function customizer(value) { + * if (_.isElement(value)) { + * return value.cloneNode(false); + * } + * } + * + * var el = _.cloneWith(document.body, customizer); + * + * console.log(el === document.body); + * // => false + * console.log(el.nodeName); + * // => 'BODY' + * console.log(el.childNodes.length); + * // => 0 + */ + function cloneWith(value, customizer) { + return baseClone(value, false, true, customizer); + } + + /** + * This method is like `_.clone` except that it recursively clones `value`. + * + * @static + * @memberOf _ + * @since 1.0.0 + * @category Lang + * @param {*} value The value to recursively clone. + * @returns {*} Returns the deep cloned value. + * @see _.clone + * @example + * + * var objects = [{ 'a': 1 }, { 'b': 2 }]; + * + * var deep = _.cloneDeep(objects); + * console.log(deep[0] === objects[0]); + * // => false + */ + function cloneDeep(value) { + return baseClone(value, true, true); + } + + /** + * This method is like `_.cloneWith` except that it recursively clones `value`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to recursively clone. + * @param {Function} [customizer] The function to customize cloning. + * @returns {*} Returns the deep cloned value. + * @see _.cloneWith + * @example + * + * function customizer(value) { + * if (_.isElement(value)) { + * return value.cloneNode(true); + * } + * } + * + * var el = _.cloneDeepWith(document.body, customizer); + * + * console.log(el === document.body); + * // => false + * console.log(el.nodeName); + * // => 'BODY' + * console.log(el.childNodes.length); + * // => 20 + */ + function cloneDeepWith(value, customizer) { + return baseClone(value, true, true, customizer); + } + + /** + * Checks if `object` conforms to `source` by invoking the predicate + * properties of `source` with the corresponding property values of `object`. + * + * **Note:** This method is equivalent to `_.conforms` when `source` is + * partially applied. + * + * @static + * @memberOf _ + * @since 4.14.0 + * @category Lang + * @param {Object} object The object to inspect. + * @param {Object} source The object of property predicates to conform to. + * @returns {boolean} Returns `true` if `object` conforms, else `false`. + * @example + * + * var object = { 'a': 1, 'b': 2 }; + * + * _.conformsTo(object, { 'b': function(n) { return n > 1; } }); + * // => true + * + * _.conformsTo(object, { 'b': function(n) { return n > 2; } }); + * // => false + */ + function conformsTo(object, source) { + return source == null || baseConformsTo(object, source, keys(source)); + } + + /** + * Performs a + * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero) + * comparison between two values to determine if they are equivalent. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to compare. + * @param {*} other The other value to compare. + * @returns {boolean} Returns `true` if the values are equivalent, else `false`. + * @example + * + * var object = { 'a': 1 }; + * var other = { 'a': 1 }; + * + * _.eq(object, object); + * // => true + * + * _.eq(object, other); + * // => false + * + * _.eq('a', 'a'); + * // => true + * + * _.eq('a', Object('a')); + * // => false + * + * _.eq(NaN, NaN); + * // => true + */ + function eq(value, other) { + return value === other || (value !== value && other !== other); + } + + /** + * Checks if `value` is greater than `other`. + * + * @static + * @memberOf _ + * @since 3.9.0 + * @category Lang + * @param {*} value The value to compare. + * @param {*} other The other value to compare. + * @returns {boolean} Returns `true` if `value` is greater than `other`, + * else `false`. + * @see _.lt + * @example + * + * _.gt(3, 1); + * // => true + * + * _.gt(3, 3); + * // => false + * + * _.gt(1, 3); + * // => false + */ + var gt = createRelationalOperation(baseGt); + + /** + * Checks if `value` is greater than or equal to `other`. + * + * @static + * @memberOf _ + * @since 3.9.0 + * @category Lang + * @param {*} value The value to compare. + * @param {*} other The other value to compare. + * @returns {boolean} Returns `true` if `value` is greater than or equal to + * `other`, else `false`. + * @see _.lte + * @example + * + * _.gte(3, 1); + * // => true + * + * _.gte(3, 3); + * // => true + * + * _.gte(1, 3); + * // => false + */ + var gte = createRelationalOperation(function(value, other) { + return value >= other; + }); + + /** + * Checks if `value` is likely an `arguments` object. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is an `arguments` object, + * else `false`. + * @example + * + * _.isArguments(function() { return arguments; }()); + * // => true + * + * _.isArguments([1, 2, 3]); + * // => false + */ + var isArguments = baseIsArguments(function() { return arguments; }()) ? baseIsArguments : function(value) { + return isObjectLike(value) && hasOwnProperty.call(value, 'callee') && + !propertyIsEnumerable.call(value, 'callee'); + }; + + /** + * Checks if `value` is classified as an `Array` object. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is an array, else `false`. + * @example + * + * _.isArray([1, 2, 3]); + * // => true + * + * _.isArray(document.body.children); + * // => false + * + * _.isArray('abc'); + * // => false + * + * _.isArray(_.noop); + * // => false + */ + var isArray = Array.isArray; + + /** + * Checks if `value` is classified as an `ArrayBuffer` object. + * + * @static + * @memberOf _ + * @since 4.3.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is an array buffer, else `false`. + * @example + * + * _.isArrayBuffer(new ArrayBuffer(2)); + * // => true + * + * _.isArrayBuffer(new Array(2)); + * // => false + */ + var isArrayBuffer = nodeIsArrayBuffer ? baseUnary(nodeIsArrayBuffer) : baseIsArrayBuffer; + + /** + * Checks if `value` is array-like. A value is considered array-like if it's + * not a function and has a `value.length` that's an integer greater than or + * equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is array-like, else `false`. + * @example + * + * _.isArrayLike([1, 2, 3]); + * // => true + * + * _.isArrayLike(document.body.children); + * // => true + * + * _.isArrayLike('abc'); + * // => true + * + * _.isArrayLike(_.noop); + * // => false + */ + function isArrayLike(value) { + return value != null && isLength(value.length) && !isFunction(value); + } + + /** + * This method is like `_.isArrayLike` except that it also checks if `value` + * is an object. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is an array-like object, + * else `false`. + * @example + * + * _.isArrayLikeObject([1, 2, 3]); + * // => true + * + * _.isArrayLikeObject(document.body.children); + * // => true + * + * _.isArrayLikeObject('abc'); + * // => false + * + * _.isArrayLikeObject(_.noop); + * // => false + */ + function isArrayLikeObject(value) { + return isObjectLike(value) && isArrayLike(value); + } + + /** + * Checks if `value` is classified as a boolean primitive or object. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a boolean, else `false`. + * @example + * + * _.isBoolean(false); + * // => true + * + * _.isBoolean(null); + * // => false + */ + function isBoolean(value) { + return value === true || value === false || + (isObjectLike(value) && objectToString.call(value) == boolTag); + } + + /** + * Checks if `value` is a buffer. + * + * @static + * @memberOf _ + * @since 4.3.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a buffer, else `false`. + * @example + * + * _.isBuffer(new Buffer(2)); + * // => true + * + * _.isBuffer(new Uint8Array(2)); + * // => false + */ + var isBuffer = nativeIsBuffer || stubFalse; + + /** + * Checks if `value` is classified as a `Date` object. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a date object, else `false`. + * @example + * + * _.isDate(new Date); + * // => true + * + * _.isDate('Mon April 23 2012'); + * // => false + */ + var isDate = nodeIsDate ? baseUnary(nodeIsDate) : baseIsDate; + + /** + * Checks if `value` is likely a DOM element. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a DOM element, else `false`. + * @example + * + * _.isElement(document.body); + * // => true + * + * _.isElement(''); + * // => false + */ + function isElement(value) { + return value != null && value.nodeType === 1 && isObjectLike(value) && !isPlainObject(value); + } + + /** + * Checks if `value` is an empty object, collection, map, or set. + * + * Objects are considered empty if they have no own enumerable string keyed + * properties. + * + * Array-like values such as `arguments` objects, arrays, buffers, strings, or + * jQuery-like collections are considered empty if they have a `length` of `0`. + * Similarly, maps and sets are considered empty if they have a `size` of `0`. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is empty, else `false`. + * @example + * + * _.isEmpty(null); + * // => true + * + * _.isEmpty(true); + * // => true + * + * _.isEmpty(1); + * // => true + * + * _.isEmpty([1, 2, 3]); + * // => false + * + * _.isEmpty({ 'a': 1 }); + * // => false + */ + function isEmpty(value) { + if (isArrayLike(value) && + (isArray(value) || typeof value == 'string' || typeof value.splice == 'function' || + isBuffer(value) || isTypedArray(value) || isArguments(value))) { + return !value.length; + } + var tag = getTag(value); + if (tag == mapTag || tag == setTag) { + return !value.size; + } + if (isPrototype(value)) { + return !baseKeys(value).length; + } + for (var key in value) { + if (hasOwnProperty.call(value, key)) { + return false; + } + } + return true; + } + + /** + * Performs a deep comparison between two values to determine if they are + * equivalent. + * + * **Note:** This method supports comparing arrays, array buffers, booleans, + * date objects, error objects, maps, numbers, `Object` objects, regexes, + * sets, strings, symbols, and typed arrays. `Object` objects are compared + * by their own, not inherited, enumerable properties. Functions and DOM + * nodes are **not** supported. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to compare. + * @param {*} other The other value to compare. + * @returns {boolean} Returns `true` if the values are equivalent, else `false`. + * @example + * + * var object = { 'a': 1 }; + * var other = { 'a': 1 }; + * + * _.isEqual(object, other); + * // => true + * + * object === other; + * // => false + */ + function isEqual(value, other) { + return baseIsEqual(value, other); + } + + /** + * This method is like `_.isEqual` except that it accepts `customizer` which + * is invoked to compare values. If `customizer` returns `undefined`, comparisons + * are handled by the method instead. The `customizer` is invoked with up to + * six arguments: (objValue, othValue [, index|key, object, other, stack]). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to compare. + * @param {*} other The other value to compare. + * @param {Function} [customizer] The function to customize comparisons. + * @returns {boolean} Returns `true` if the values are equivalent, else `false`. + * @example + * + * function isGreeting(value) { + * return /^h(?:i|ello)$/.test(value); + * } + * + * function customizer(objValue, othValue) { + * if (isGreeting(objValue) && isGreeting(othValue)) { + * return true; + * } + * } + * + * var array = ['hello', 'goodbye']; + * var other = ['hi', 'goodbye']; + * + * _.isEqualWith(array, other, customizer); + * // => true + */ + function isEqualWith(value, other, customizer) { + customizer = typeof customizer == 'function' ? customizer : undefined; + var result = customizer ? customizer(value, other) : undefined; + return result === undefined ? baseIsEqual(value, other, customizer) : !!result; + } + + /** + * Checks if `value` is an `Error`, `EvalError`, `RangeError`, `ReferenceError`, + * `SyntaxError`, `TypeError`, or `URIError` object. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is an error object, else `false`. + * @example + * + * _.isError(new Error); + * // => true + * + * _.isError(Error); + * // => false + */ + function isError(value) { + if (!isObjectLike(value)) { + return false; + } + return (objectToString.call(value) == errorTag) || + (typeof value.message == 'string' && typeof value.name == 'string'); + } + + /** + * Checks if `value` is a finite primitive number. + * + * **Note:** This method is based on + * [`Number.isFinite`](https://mdn.io/Number/isFinite). + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a finite number, else `false`. + * @example + * + * _.isFinite(3); + * // => true + * + * _.isFinite(Number.MIN_VALUE); + * // => true + * + * _.isFinite(Infinity); + * // => false + * + * _.isFinite('3'); + * // => false + */ + function isFinite(value) { + return typeof value == 'number' && nativeIsFinite(value); + } + + /** + * Checks if `value` is classified as a `Function` object. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a function, else `false`. + * @example + * + * _.isFunction(_); + * // => true + * + * _.isFunction(/abc/); + * // => false + */ + function isFunction(value) { + // The use of `Object#toString` avoids issues with the `typeof` operator + // in Safari 9 which returns 'object' for typed array and other constructors. + var tag = isObject(value) ? objectToString.call(value) : ''; + return tag == funcTag || tag == genTag || tag == proxyTag; + } + + /** + * Checks if `value` is an integer. + * + * **Note:** This method is based on + * [`Number.isInteger`](https://mdn.io/Number/isInteger). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is an integer, else `false`. + * @example + * + * _.isInteger(3); + * // => true + * + * _.isInteger(Number.MIN_VALUE); + * // => false + * + * _.isInteger(Infinity); + * // => false + * + * _.isInteger('3'); + * // => false + */ + function isInteger(value) { + return typeof value == 'number' && value == toInteger(value); + } + + /** + * Checks if `value` is a valid array-like length. + * + * **Note:** This method is loosely based on + * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a valid length, else `false`. + * @example + * + * _.isLength(3); + * // => true + * + * _.isLength(Number.MIN_VALUE); + * // => false + * + * _.isLength(Infinity); + * // => false + * + * _.isLength('3'); + * // => false + */ + function isLength(value) { + return typeof value == 'number' && + value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER; + } + + /** + * Checks if `value` is the + * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types) + * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`) + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is an object, else `false`. + * @example + * + * _.isObject({}); + * // => true + * + * _.isObject([1, 2, 3]); + * // => true + * + * _.isObject(_.noop); + * // => true + * + * _.isObject(null); + * // => false + */ + function isObject(value) { + var type = typeof value; + return value != null && (type == 'object' || type == 'function'); + } + + /** + * Checks if `value` is object-like. A value is object-like if it's not `null` + * and has a `typeof` result of "object". + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is object-like, else `false`. + * @example + * + * _.isObjectLike({}); + * // => true + * + * _.isObjectLike([1, 2, 3]); + * // => true + * + * _.isObjectLike(_.noop); + * // => false + * + * _.isObjectLike(null); + * // => false + */ + function isObjectLike(value) { + return value != null && typeof value == 'object'; + } + + /** + * Checks if `value` is classified as a `Map` object. + * + * @static + * @memberOf _ + * @since 4.3.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a map, else `false`. + * @example + * + * _.isMap(new Map); + * // => true + * + * _.isMap(new WeakMap); + * // => false + */ + var isMap = nodeIsMap ? baseUnary(nodeIsMap) : baseIsMap; + + /** + * Performs a partial deep comparison between `object` and `source` to + * determine if `object` contains equivalent property values. + * + * **Note:** This method is equivalent to `_.matches` when `source` is + * partially applied. + * + * Partial comparisons will match empty array and empty object `source` + * values against any array or object value, respectively. See `_.isEqual` + * for a list of supported value comparisons. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Lang + * @param {Object} object The object to inspect. + * @param {Object} source The object of property values to match. + * @returns {boolean} Returns `true` if `object` is a match, else `false`. + * @example + * + * var object = { 'a': 1, 'b': 2 }; + * + * _.isMatch(object, { 'b': 2 }); + * // => true + * + * _.isMatch(object, { 'b': 1 }); + * // => false + */ + function isMatch(object, source) { + return object === source || baseIsMatch(object, source, getMatchData(source)); + } + + /** + * This method is like `_.isMatch` except that it accepts `customizer` which + * is invoked to compare values. If `customizer` returns `undefined`, comparisons + * are handled by the method instead. The `customizer` is invoked with five + * arguments: (objValue, srcValue, index|key, object, source). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {Object} object The object to inspect. + * @param {Object} source The object of property values to match. + * @param {Function} [customizer] The function to customize comparisons. + * @returns {boolean} Returns `true` if `object` is a match, else `false`. + * @example + * + * function isGreeting(value) { + * return /^h(?:i|ello)$/.test(value); + * } + * + * function customizer(objValue, srcValue) { + * if (isGreeting(objValue) && isGreeting(srcValue)) { + * return true; + * } + * } + * + * var object = { 'greeting': 'hello' }; + * var source = { 'greeting': 'hi' }; + * + * _.isMatchWith(object, source, customizer); + * // => true + */ + function isMatchWith(object, source, customizer) { + customizer = typeof customizer == 'function' ? customizer : undefined; + return baseIsMatch(object, source, getMatchData(source), customizer); + } + + /** + * Checks if `value` is `NaN`. + * + * **Note:** This method is based on + * [`Number.isNaN`](https://mdn.io/Number/isNaN) and is not the same as + * global [`isNaN`](https://mdn.io/isNaN) which returns `true` for + * `undefined` and other non-number values. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is `NaN`, else `false`. + * @example + * + * _.isNaN(NaN); + * // => true + * + * _.isNaN(new Number(NaN)); + * // => true + * + * isNaN(undefined); + * // => true + * + * _.isNaN(undefined); + * // => false + */ + function isNaN(value) { + // An `NaN` primitive is the only value that is not equal to itself. + // Perform the `toStringTag` check first to avoid errors with some + // ActiveX objects in IE. + return isNumber(value) && value != +value; + } + + /** + * Checks if `value` is a pristine native function. + * + * **Note:** This method can't reliably detect native functions in the presence + * of the core-js package because core-js circumvents this kind of detection. + * Despite multiple requests, the core-js maintainer has made it clear: any + * attempt to fix the detection will be obstructed. As a result, we're left + * with little choice but to throw an error. Unfortunately, this also affects + * packages, like [babel-polyfill](https://www.npmjs.com/package/babel-polyfill), + * which rely on core-js. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a native function, + * else `false`. + * @example + * + * _.isNative(Array.prototype.push); + * // => true + * + * _.isNative(_); + * // => false + */ + function isNative(value) { + if (isMaskable(value)) { + throw new Error(CORE_ERROR_TEXT); + } + return baseIsNative(value); + } + + /** + * Checks if `value` is `null`. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is `null`, else `false`. + * @example + * + * _.isNull(null); + * // => true + * + * _.isNull(void 0); + * // => false + */ + function isNull(value) { + return value === null; + } + + /** + * Checks if `value` is `null` or `undefined`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is nullish, else `false`. + * @example + * + * _.isNil(null); + * // => true + * + * _.isNil(void 0); + * // => true + * + * _.isNil(NaN); + * // => false + */ + function isNil(value) { + return value == null; + } + + /** + * Checks if `value` is classified as a `Number` primitive or object. + * + * **Note:** To exclude `Infinity`, `-Infinity`, and `NaN`, which are + * classified as numbers, use the `_.isFinite` method. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a number, else `false`. + * @example + * + * _.isNumber(3); + * // => true + * + * _.isNumber(Number.MIN_VALUE); + * // => true + * + * _.isNumber(Infinity); + * // => true + * + * _.isNumber('3'); + * // => false + */ + function isNumber(value) { + return typeof value == 'number' || + (isObjectLike(value) && objectToString.call(value) == numberTag); + } + + /** + * Checks if `value` is a plain object, that is, an object created by the + * `Object` constructor or one with a `[[Prototype]]` of `null`. + * + * @static + * @memberOf _ + * @since 0.8.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a plain object, else `false`. + * @example + * + * function Foo() { + * this.a = 1; + * } + * + * _.isPlainObject(new Foo); + * // => false + * + * _.isPlainObject([1, 2, 3]); + * // => false + * + * _.isPlainObject({ 'x': 0, 'y': 0 }); + * // => true + * + * _.isPlainObject(Object.create(null)); + * // => true + */ + function isPlainObject(value) { + if (!isObjectLike(value) || objectToString.call(value) != objectTag) { + return false; + } + var proto = getPrototype(value); + if (proto === null) { + return true; + } + var Ctor = hasOwnProperty.call(proto, 'constructor') && proto.constructor; + return (typeof Ctor == 'function' && + Ctor instanceof Ctor && funcToString.call(Ctor) == objectCtorString); + } + + /** + * Checks if `value` is classified as a `RegExp` object. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a regexp, else `false`. + * @example + * + * _.isRegExp(/abc/); + * // => true + * + * _.isRegExp('/abc/'); + * // => false + */ + var isRegExp = nodeIsRegExp ? baseUnary(nodeIsRegExp) : baseIsRegExp; + + /** + * Checks if `value` is a safe integer. An integer is safe if it's an IEEE-754 + * double precision number which isn't the result of a rounded unsafe integer. + * + * **Note:** This method is based on + * [`Number.isSafeInteger`](https://mdn.io/Number/isSafeInteger). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a safe integer, else `false`. + * @example + * + * _.isSafeInteger(3); + * // => true + * + * _.isSafeInteger(Number.MIN_VALUE); + * // => false + * + * _.isSafeInteger(Infinity); + * // => false + * + * _.isSafeInteger('3'); + * // => false + */ + function isSafeInteger(value) { + return isInteger(value) && value >= -MAX_SAFE_INTEGER && value <= MAX_SAFE_INTEGER; + } + + /** + * Checks if `value` is classified as a `Set` object. + * + * @static + * @memberOf _ + * @since 4.3.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a set, else `false`. + * @example + * + * _.isSet(new Set); + * // => true + * + * _.isSet(new WeakSet); + * // => false + */ + var isSet = nodeIsSet ? baseUnary(nodeIsSet) : baseIsSet; + + /** + * Checks if `value` is classified as a `String` primitive or object. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a string, else `false`. + * @example + * + * _.isString('abc'); + * // => true + * + * _.isString(1); + * // => false + */ + function isString(value) { + return typeof value == 'string' || + (!isArray(value) && isObjectLike(value) && objectToString.call(value) == stringTag); + } + + /** + * Checks if `value` is classified as a `Symbol` primitive or object. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a symbol, else `false`. + * @example + * + * _.isSymbol(Symbol.iterator); + * // => true + * + * _.isSymbol('abc'); + * // => false + */ + function isSymbol(value) { + return typeof value == 'symbol' || + (isObjectLike(value) && objectToString.call(value) == symbolTag); + } + + /** + * Checks if `value` is classified as a typed array. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a typed array, else `false`. + * @example + * + * _.isTypedArray(new Uint8Array); + * // => true + * + * _.isTypedArray([]); + * // => false + */ + var isTypedArray = nodeIsTypedArray ? baseUnary(nodeIsTypedArray) : baseIsTypedArray; + + /** + * Checks if `value` is `undefined`. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is `undefined`, else `false`. + * @example + * + * _.isUndefined(void 0); + * // => true + * + * _.isUndefined(null); + * // => false + */ + function isUndefined(value) { + return value === undefined; + } + + /** + * Checks if `value` is classified as a `WeakMap` object. + * + * @static + * @memberOf _ + * @since 4.3.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a weak map, else `false`. + * @example + * + * _.isWeakMap(new WeakMap); + * // => true + * + * _.isWeakMap(new Map); + * // => false + */ + function isWeakMap(value) { + return isObjectLike(value) && getTag(value) == weakMapTag; + } + + /** + * Checks if `value` is classified as a `WeakSet` object. + * + * @static + * @memberOf _ + * @since 4.3.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a weak set, else `false`. + * @example + * + * _.isWeakSet(new WeakSet); + * // => true + * + * _.isWeakSet(new Set); + * // => false + */ + function isWeakSet(value) { + return isObjectLike(value) && objectToString.call(value) == weakSetTag; + } + + /** + * Checks if `value` is less than `other`. + * + * @static + * @memberOf _ + * @since 3.9.0 + * @category Lang + * @param {*} value The value to compare. + * @param {*} other The other value to compare. + * @returns {boolean} Returns `true` if `value` is less than `other`, + * else `false`. + * @see _.gt + * @example + * + * _.lt(1, 3); + * // => true + * + * _.lt(3, 3); + * // => false + * + * _.lt(3, 1); + * // => false + */ + var lt = createRelationalOperation(baseLt); + + /** + * Checks if `value` is less than or equal to `other`. + * + * @static + * @memberOf _ + * @since 3.9.0 + * @category Lang + * @param {*} value The value to compare. + * @param {*} other The other value to compare. + * @returns {boolean} Returns `true` if `value` is less than or equal to + * `other`, else `false`. + * @see _.gte + * @example + * + * _.lte(1, 3); + * // => true + * + * _.lte(3, 3); + * // => true + * + * _.lte(3, 1); + * // => false + */ + var lte = createRelationalOperation(function(value, other) { + return value <= other; + }); + + /** + * Converts `value` to an array. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Lang + * @param {*} value The value to convert. + * @returns {Array} Returns the converted array. + * @example + * + * _.toArray({ 'a': 1, 'b': 2 }); + * // => [1, 2] + * + * _.toArray('abc'); + * // => ['a', 'b', 'c'] + * + * _.toArray(1); + * // => [] + * + * _.toArray(null); + * // => [] + */ + function toArray(value) { + if (!value) { + return []; + } + if (isArrayLike(value)) { + return isString(value) ? stringToArray(value) : copyArray(value); + } + if (iteratorSymbol && value[iteratorSymbol]) { + return iteratorToArray(value[iteratorSymbol]()); + } + var tag = getTag(value), + func = tag == mapTag ? mapToArray : (tag == setTag ? setToArray : values); + + return func(value); + } + + /** + * Converts `value` to a finite number. + * + * @static + * @memberOf _ + * @since 4.12.0 + * @category Lang + * @param {*} value The value to convert. + * @returns {number} Returns the converted number. + * @example + * + * _.toFinite(3.2); + * // => 3.2 + * + * _.toFinite(Number.MIN_VALUE); + * // => 5e-324 + * + * _.toFinite(Infinity); + * // => 1.7976931348623157e+308 + * + * _.toFinite('3.2'); + * // => 3.2 + */ + function toFinite(value) { + if (!value) { + return value === 0 ? value : 0; + } + value = toNumber(value); + if (value === INFINITY || value === -INFINITY) { + var sign = (value < 0 ? -1 : 1); + return sign * MAX_INTEGER; + } + return value === value ? value : 0; + } + + /** + * Converts `value` to an integer. + * + * **Note:** This method is loosely based on + * [`ToInteger`](http://www.ecma-international.org/ecma-262/7.0/#sec-tointeger). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to convert. + * @returns {number} Returns the converted integer. + * @example + * + * _.toInteger(3.2); + * // => 3 + * + * _.toInteger(Number.MIN_VALUE); + * // => 0 + * + * _.toInteger(Infinity); + * // => 1.7976931348623157e+308 + * + * _.toInteger('3.2'); + * // => 3 + */ + function toInteger(value) { + var result = toFinite(value), + remainder = result % 1; + + return result === result ? (remainder ? result - remainder : result) : 0; + } + + /** + * Converts `value` to an integer suitable for use as the length of an + * array-like object. + * + * **Note:** This method is based on + * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to convert. + * @returns {number} Returns the converted integer. + * @example + * + * _.toLength(3.2); + * // => 3 + * + * _.toLength(Number.MIN_VALUE); + * // => 0 + * + * _.toLength(Infinity); + * // => 4294967295 + * + * _.toLength('3.2'); + * // => 3 + */ + function toLength(value) { + return value ? baseClamp(toInteger(value), 0, MAX_ARRAY_LENGTH) : 0; + } + + /** + * Converts `value` to a number. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to process. + * @returns {number} Returns the number. + * @example + * + * _.toNumber(3.2); + * // => 3.2 + * + * _.toNumber(Number.MIN_VALUE); + * // => 5e-324 + * + * _.toNumber(Infinity); + * // => Infinity + * + * _.toNumber('3.2'); + * // => 3.2 + */ + function toNumber(value) { + if (typeof value == 'number') { + return value; + } + if (isSymbol(value)) { + return NAN; + } + if (isObject(value)) { + var other = typeof value.valueOf == 'function' ? value.valueOf() : value; + value = isObject(other) ? (other + '') : other; + } + if (typeof value != 'string') { + return value === 0 ? value : +value; + } + value = value.replace(reTrim, ''); + var isBinary = reIsBinary.test(value); + return (isBinary || reIsOctal.test(value)) + ? freeParseInt(value.slice(2), isBinary ? 2 : 8) + : (reIsBadHex.test(value) ? NAN : +value); + } + + /** + * Converts `value` to a plain object flattening inherited enumerable string + * keyed properties of `value` to own properties of the plain object. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Lang + * @param {*} value The value to convert. + * @returns {Object} Returns the converted plain object. + * @example + * + * function Foo() { + * this.b = 2; + * } + * + * Foo.prototype.c = 3; + * + * _.assign({ 'a': 1 }, new Foo); + * // => { 'a': 1, 'b': 2 } + * + * _.assign({ 'a': 1 }, _.toPlainObject(new Foo)); + * // => { 'a': 1, 'b': 2, 'c': 3 } + */ + function toPlainObject(value) { + return copyObject(value, keysIn(value)); + } + + /** + * Converts `value` to a safe integer. A safe integer can be compared and + * represented correctly. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to convert. + * @returns {number} Returns the converted integer. + * @example + * + * _.toSafeInteger(3.2); + * // => 3 + * + * _.toSafeInteger(Number.MIN_VALUE); + * // => 0 + * + * _.toSafeInteger(Infinity); + * // => 9007199254740991 + * + * _.toSafeInteger('3.2'); + * // => 3 + */ + function toSafeInteger(value) { + return baseClamp(toInteger(value), -MAX_SAFE_INTEGER, MAX_SAFE_INTEGER); + } + + /** + * Converts `value` to a string. An empty string is returned for `null` + * and `undefined` values. The sign of `-0` is preserved. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to convert. + * @returns {string} Returns the converted string. + * @example + * + * _.toString(null); + * // => '' + * + * _.toString(-0); + * // => '-0' + * + * _.toString([1, 2, 3]); + * // => '1,2,3' + */ + function toString(value) { + return value == null ? '' : baseToString(value); + } + + /*------------------------------------------------------------------------*/ + + /** + * Assigns own enumerable string keyed properties of source objects to the + * destination object. Source objects are applied from left to right. + * Subsequent sources overwrite property assignments of previous sources. + * + * **Note:** This method mutates `object` and is loosely based on + * [`Object.assign`](https://mdn.io/Object/assign). + * + * @static + * @memberOf _ + * @since 0.10.0 + * @category Object + * @param {Object} object The destination object. + * @param {...Object} [sources] The source objects. + * @returns {Object} Returns `object`. + * @see _.assignIn + * @example + * + * function Foo() { + * this.a = 1; + * } + * + * function Bar() { + * this.c = 3; + * } + * + * Foo.prototype.b = 2; + * Bar.prototype.d = 4; + * + * _.assign({ 'a': 0 }, new Foo, new Bar); + * // => { 'a': 1, 'c': 3 } + */ + var assign = createAssigner(function(object, source) { + if (isPrototype(source) || isArrayLike(source)) { + copyObject(source, keys(source), object); + return; + } + for (var key in source) { + if (hasOwnProperty.call(source, key)) { + assignValue(object, key, source[key]); + } + } + }); + + /** + * This method is like `_.assign` except that it iterates over own and + * inherited source properties. + * + * **Note:** This method mutates `object`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @alias extend + * @category Object + * @param {Object} object The destination object. + * @param {...Object} [sources] The source objects. + * @returns {Object} Returns `object`. + * @see _.assign + * @example + * + * function Foo() { + * this.a = 1; + * } + * + * function Bar() { + * this.c = 3; + * } + * + * Foo.prototype.b = 2; + * Bar.prototype.d = 4; + * + * _.assignIn({ 'a': 0 }, new Foo, new Bar); + * // => { 'a': 1, 'b': 2, 'c': 3, 'd': 4 } + */ + var assignIn = createAssigner(function(object, source) { + copyObject(source, keysIn(source), object); + }); + + /** + * This method is like `_.assignIn` except that it accepts `customizer` + * which is invoked to produce the assigned values. If `customizer` returns + * `undefined`, assignment is handled by the method instead. The `customizer` + * is invoked with five arguments: (objValue, srcValue, key, object, source). + * + * **Note:** This method mutates `object`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @alias extendWith + * @category Object + * @param {Object} object The destination object. + * @param {...Object} sources The source objects. + * @param {Function} [customizer] The function to customize assigned values. + * @returns {Object} Returns `object`. + * @see _.assignWith + * @example + * + * function customizer(objValue, srcValue) { + * return _.isUndefined(objValue) ? srcValue : objValue; + * } + * + * var defaults = _.partialRight(_.assignInWith, customizer); + * + * defaults({ 'a': 1 }, { 'b': 2 }, { 'a': 3 }); + * // => { 'a': 1, 'b': 2 } + */ + var assignInWith = createAssigner(function(object, source, srcIndex, customizer) { + copyObject(source, keysIn(source), object, customizer); + }); + + /** + * This method is like `_.assign` except that it accepts `customizer` + * which is invoked to produce the assigned values. If `customizer` returns + * `undefined`, assignment is handled by the method instead. The `customizer` + * is invoked with five arguments: (objValue, srcValue, key, object, source). + * + * **Note:** This method mutates `object`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Object + * @param {Object} object The destination object. + * @param {...Object} sources The source objects. + * @param {Function} [customizer] The function to customize assigned values. + * @returns {Object} Returns `object`. + * @see _.assignInWith + * @example + * + * function customizer(objValue, srcValue) { + * return _.isUndefined(objValue) ? srcValue : objValue; + * } + * + * var defaults = _.partialRight(_.assignWith, customizer); + * + * defaults({ 'a': 1 }, { 'b': 2 }, { 'a': 3 }); + * // => { 'a': 1, 'b': 2 } + */ + var assignWith = createAssigner(function(object, source, srcIndex, customizer) { + copyObject(source, keys(source), object, customizer); + }); + + /** + * Creates an array of values corresponding to `paths` of `object`. + * + * @static + * @memberOf _ + * @since 1.0.0 + * @category Object + * @param {Object} object The object to iterate over. + * @param {...(string|string[])} [paths] The property paths of elements to pick. + * @returns {Array} Returns the picked values. + * @example + * + * var object = { 'a': [{ 'b': { 'c': 3 } }, 4] }; + * + * _.at(object, ['a[0].b.c', 'a[1]']); + * // => [3, 4] + */ + var at = flatRest(baseAt); + + /** + * Creates an object that inherits from the `prototype` object. If a + * `properties` object is given, its own enumerable string keyed properties + * are assigned to the created object. + * + * @static + * @memberOf _ + * @since 2.3.0 + * @category Object + * @param {Object} prototype The object to inherit from. + * @param {Object} [properties] The properties to assign to the object. + * @returns {Object} Returns the new object. + * @example + * + * function Shape() { + * this.x = 0; + * this.y = 0; + * } + * + * function Circle() { + * Shape.call(this); + * } + * + * Circle.prototype = _.create(Shape.prototype, { + * 'constructor': Circle + * }); + * + * var circle = new Circle; + * circle instanceof Circle; + * // => true + * + * circle instanceof Shape; + * // => true + */ + function create(prototype, properties) { + var result = baseCreate(prototype); + return properties ? baseAssign(result, properties) : result; + } + + /** + * Assigns own and inherited enumerable string keyed properties of source + * objects to the destination object for all destination properties that + * resolve to `undefined`. Source objects are applied from left to right. + * Once a property is set, additional values of the same property are ignored. + * + * **Note:** This method mutates `object`. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Object + * @param {Object} object The destination object. + * @param {...Object} [sources] The source objects. + * @returns {Object} Returns `object`. + * @see _.defaultsDeep + * @example + * + * _.defaults({ 'a': 1 }, { 'b': 2 }, { 'a': 3 }); + * // => { 'a': 1, 'b': 2 } + */ + var defaults = baseRest(function(args) { + args.push(undefined, assignInDefaults); + return apply(assignInWith, undefined, args); + }); + + /** + * This method is like `_.defaults` except that it recursively assigns + * default properties. + * + * **Note:** This method mutates `object`. + * + * @static + * @memberOf _ + * @since 3.10.0 + * @category Object + * @param {Object} object The destination object. + * @param {...Object} [sources] The source objects. + * @returns {Object} Returns `object`. + * @see _.defaults + * @example + * + * _.defaultsDeep({ 'a': { 'b': 2 } }, { 'a': { 'b': 1, 'c': 3 } }); + * // => { 'a': { 'b': 2, 'c': 3 } } + */ + var defaultsDeep = baseRest(function(args) { + args.push(undefined, mergeDefaults); + return apply(mergeWith, undefined, args); + }); + + /** + * This method is like `_.find` except that it returns the key of the first + * element `predicate` returns truthy for instead of the element itself. + * + * @static + * @memberOf _ + * @since 1.1.0 + * @category Object + * @param {Object} object The object to inspect. + * @param {Function} [predicate=_.identity] The function invoked per iteration. + * @returns {string|undefined} Returns the key of the matched element, + * else `undefined`. + * @example + * + * var users = { + * 'barney': { 'age': 36, 'active': true }, + * 'fred': { 'age': 40, 'active': false }, + * 'pebbles': { 'age': 1, 'active': true } + * }; + * + * _.findKey(users, function(o) { return o.age < 40; }); + * // => 'barney' (iteration order is not guaranteed) + * + * // The `_.matches` iteratee shorthand. + * _.findKey(users, { 'age': 1, 'active': true }); + * // => 'pebbles' + * + * // The `_.matchesProperty` iteratee shorthand. + * _.findKey(users, ['active', false]); + * // => 'fred' + * + * // The `_.property` iteratee shorthand. + * _.findKey(users, 'active'); + * // => 'barney' + */ + function findKey(object, predicate) { + return baseFindKey(object, getIteratee(predicate, 3), baseForOwn); + } + + /** + * This method is like `_.findKey` except that it iterates over elements of + * a collection in the opposite order. + * + * @static + * @memberOf _ + * @since 2.0.0 + * @category Object + * @param {Object} object The object to inspect. + * @param {Function} [predicate=_.identity] The function invoked per iteration. + * @returns {string|undefined} Returns the key of the matched element, + * else `undefined`. + * @example + * + * var users = { + * 'barney': { 'age': 36, 'active': true }, + * 'fred': { 'age': 40, 'active': false }, + * 'pebbles': { 'age': 1, 'active': true } + * }; + * + * _.findLastKey(users, function(o) { return o.age < 40; }); + * // => returns 'pebbles' assuming `_.findKey` returns 'barney' + * + * // The `_.matches` iteratee shorthand. + * _.findLastKey(users, { 'age': 36, 'active': true }); + * // => 'barney' + * + * // The `_.matchesProperty` iteratee shorthand. + * _.findLastKey(users, ['active', false]); + * // => 'fred' + * + * // The `_.property` iteratee shorthand. + * _.findLastKey(users, 'active'); + * // => 'pebbles' + */ + function findLastKey(object, predicate) { + return baseFindKey(object, getIteratee(predicate, 3), baseForOwnRight); + } + + /** + * Iterates over own and inherited enumerable string keyed properties of an + * object and invokes `iteratee` for each property. The iteratee is invoked + * with three arguments: (value, key, object). Iteratee functions may exit + * iteration early by explicitly returning `false`. + * + * @static + * @memberOf _ + * @since 0.3.0 + * @category Object + * @param {Object} object The object to iterate over. + * @param {Function} [iteratee=_.identity] The function invoked per iteration. + * @returns {Object} Returns `object`. + * @see _.forInRight + * @example + * + * function Foo() { + * this.a = 1; + * this.b = 2; + * } + * + * Foo.prototype.c = 3; + * + * _.forIn(new Foo, function(value, key) { + * console.log(key); + * }); + * // => Logs 'a', 'b', then 'c' (iteration order is not guaranteed). + */ + function forIn(object, iteratee) { + return object == null + ? object + : baseFor(object, getIteratee(iteratee, 3), keysIn); + } + + /** + * This method is like `_.forIn` except that it iterates over properties of + * `object` in the opposite order. + * + * @static + * @memberOf _ + * @since 2.0.0 + * @category Object + * @param {Object} object The object to iterate over. + * @param {Function} [iteratee=_.identity] The function invoked per iteration. + * @returns {Object} Returns `object`. + * @see _.forIn + * @example + * + * function Foo() { + * this.a = 1; + * this.b = 2; + * } + * + * Foo.prototype.c = 3; + * + * _.forInRight(new Foo, function(value, key) { + * console.log(key); + * }); + * // => Logs 'c', 'b', then 'a' assuming `_.forIn` logs 'a', 'b', then 'c'. + */ + function forInRight(object, iteratee) { + return object == null + ? object + : baseForRight(object, getIteratee(iteratee, 3), keysIn); + } + + /** + * Iterates over own enumerable string keyed properties of an object and + * invokes `iteratee` for each property. The iteratee is invoked with three + * arguments: (value, key, object). Iteratee functions may exit iteration + * early by explicitly returning `false`. + * + * @static + * @memberOf _ + * @since 0.3.0 + * @category Object + * @param {Object} object The object to iterate over. + * @param {Function} [iteratee=_.identity] The function invoked per iteration. + * @returns {Object} Returns `object`. + * @see _.forOwnRight + * @example + * + * function Foo() { + * this.a = 1; + * this.b = 2; + * } + * + * Foo.prototype.c = 3; + * + * _.forOwn(new Foo, function(value, key) { + * console.log(key); + * }); + * // => Logs 'a' then 'b' (iteration order is not guaranteed). + */ + function forOwn(object, iteratee) { + return object && baseForOwn(object, getIteratee(iteratee, 3)); + } + + /** + * This method is like `_.forOwn` except that it iterates over properties of + * `object` in the opposite order. + * + * @static + * @memberOf _ + * @since 2.0.0 + * @category Object + * @param {Object} object The object to iterate over. + * @param {Function} [iteratee=_.identity] The function invoked per iteration. + * @returns {Object} Returns `object`. + * @see _.forOwn + * @example + * + * function Foo() { + * this.a = 1; + * this.b = 2; + * } + * + * Foo.prototype.c = 3; + * + * _.forOwnRight(new Foo, function(value, key) { + * console.log(key); + * }); + * // => Logs 'b' then 'a' assuming `_.forOwn` logs 'a' then 'b'. + */ + function forOwnRight(object, iteratee) { + return object && baseForOwnRight(object, getIteratee(iteratee, 3)); + } + + /** + * Creates an array of function property names from own enumerable properties + * of `object`. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Object + * @param {Object} object The object to inspect. + * @returns {Array} Returns the function names. + * @see _.functionsIn + * @example + * + * function Foo() { + * this.a = _.constant('a'); + * this.b = _.constant('b'); + * } + * + * Foo.prototype.c = _.constant('c'); + * + * _.functions(new Foo); + * // => ['a', 'b'] + */ + function functions(object) { + return object == null ? [] : baseFunctions(object, keys(object)); + } + + /** + * Creates an array of function property names from own and inherited + * enumerable properties of `object`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Object + * @param {Object} object The object to inspect. + * @returns {Array} Returns the function names. + * @see _.functions + * @example + * + * function Foo() { + * this.a = _.constant('a'); + * this.b = _.constant('b'); + * } + * + * Foo.prototype.c = _.constant('c'); + * + * _.functionsIn(new Foo); + * // => ['a', 'b', 'c'] + */ + function functionsIn(object) { + return object == null ? [] : baseFunctions(object, keysIn(object)); + } + + /** + * Gets the value at `path` of `object`. If the resolved value is + * `undefined`, the `defaultValue` is returned in its place. + * + * @static + * @memberOf _ + * @since 3.7.0 + * @category Object + * @param {Object} object The object to query. + * @param {Array|string} path The path of the property to get. + * @param {*} [defaultValue] The value returned for `undefined` resolved values. + * @returns {*} Returns the resolved value. + * @example + * + * var object = { 'a': [{ 'b': { 'c': 3 } }] }; + * + * _.get(object, 'a[0].b.c'); + * // => 3 + * + * _.get(object, ['a', '0', 'b', 'c']); + * // => 3 + * + * _.get(object, 'a.b.c', 'default'); + * // => 'default' + */ + function get(object, path, defaultValue) { + var result = object == null ? undefined : baseGet(object, path); + return result === undefined ? defaultValue : result; + } + + /** + * Checks if `path` is a direct property of `object`. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Object + * @param {Object} object The object to query. + * @param {Array|string} path The path to check. + * @returns {boolean} Returns `true` if `path` exists, else `false`. + * @example + * + * var object = { 'a': { 'b': 2 } }; + * var other = _.create({ 'a': _.create({ 'b': 2 }) }); + * + * _.has(object, 'a'); + * // => true + * + * _.has(object, 'a.b'); + * // => true + * + * _.has(object, ['a', 'b']); + * // => true + * + * _.has(other, 'a'); + * // => false + */ + function has(object, path) { + return object != null && hasPath(object, path, baseHas); + } + + /** + * Checks if `path` is a direct or inherited property of `object`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Object + * @param {Object} object The object to query. + * @param {Array|string} path The path to check. + * @returns {boolean} Returns `true` if `path` exists, else `false`. + * @example + * + * var object = _.create({ 'a': _.create({ 'b': 2 }) }); + * + * _.hasIn(object, 'a'); + * // => true + * + * _.hasIn(object, 'a.b'); + * // => true + * + * _.hasIn(object, ['a', 'b']); + * // => true + * + * _.hasIn(object, 'b'); + * // => false + */ + function hasIn(object, path) { + return object != null && hasPath(object, path, baseHasIn); + } + + /** + * Creates an object composed of the inverted keys and values of `object`. + * If `object` contains duplicate values, subsequent values overwrite + * property assignments of previous values. + * + * @static + * @memberOf _ + * @since 0.7.0 + * @category Object + * @param {Object} object The object to invert. + * @returns {Object} Returns the new inverted object. + * @example + * + * var object = { 'a': 1, 'b': 2, 'c': 1 }; + * + * _.invert(object); + * // => { '1': 'c', '2': 'b' } + */ + var invert = createInverter(function(result, value, key) { + result[value] = key; + }, constant(identity)); + + /** + * This method is like `_.invert` except that the inverted object is generated + * from the results of running each element of `object` thru `iteratee`. The + * corresponding inverted value of each inverted key is an array of keys + * responsible for generating the inverted value. The iteratee is invoked + * with one argument: (value). + * + * @static + * @memberOf _ + * @since 4.1.0 + * @category Object + * @param {Object} object The object to invert. + * @param {Function} [iteratee=_.identity] The iteratee invoked per element. + * @returns {Object} Returns the new inverted object. + * @example + * + * var object = { 'a': 1, 'b': 2, 'c': 1 }; + * + * _.invertBy(object); + * // => { '1': ['a', 'c'], '2': ['b'] } + * + * _.invertBy(object, function(value) { + * return 'group' + value; + * }); + * // => { 'group1': ['a', 'c'], 'group2': ['b'] } + */ + var invertBy = createInverter(function(result, value, key) { + if (hasOwnProperty.call(result, value)) { + result[value].push(key); + } else { + result[value] = [key]; + } + }, getIteratee); + + /** + * Invokes the method at `path` of `object`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Object + * @param {Object} object The object to query. + * @param {Array|string} path The path of the method to invoke. + * @param {...*} [args] The arguments to invoke the method with. + * @returns {*} Returns the result of the invoked method. + * @example + * + * var object = { 'a': [{ 'b': { 'c': [1, 2, 3, 4] } }] }; + * + * _.invoke(object, 'a[0].b.c.slice', 1, 3); + * // => [2, 3] + */ + var invoke = baseRest(baseInvoke); + + /** + * Creates an array of the own enumerable property names of `object`. + * + * **Note:** Non-object values are coerced to objects. See the + * [ES spec](http://ecma-international.org/ecma-262/7.0/#sec-object.keys) + * for more details. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Object + * @param {Object} object The object to query. + * @returns {Array} Returns the array of property names. + * @example + * + * function Foo() { + * this.a = 1; + * this.b = 2; + * } + * + * Foo.prototype.c = 3; + * + * _.keys(new Foo); + * // => ['a', 'b'] (iteration order is not guaranteed) + * + * _.keys('hi'); + * // => ['0', '1'] + */ + function keys(object) { + return isArrayLike(object) ? arrayLikeKeys(object) : baseKeys(object); + } + + /** + * Creates an array of the own and inherited enumerable property names of `object`. + * + * **Note:** Non-object values are coerced to objects. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Object + * @param {Object} object The object to query. + * @returns {Array} Returns the array of property names. + * @example + * + * function Foo() { + * this.a = 1; + * this.b = 2; + * } + * + * Foo.prototype.c = 3; + * + * _.keysIn(new Foo); + * // => ['a', 'b', 'c'] (iteration order is not guaranteed) + */ + function keysIn(object) { + return isArrayLike(object) ? arrayLikeKeys(object, true) : baseKeysIn(object); + } + + /** + * The opposite of `_.mapValues`; this method creates an object with the + * same values as `object` and keys generated by running each own enumerable + * string keyed property of `object` thru `iteratee`. The iteratee is invoked + * with three arguments: (value, key, object). + * + * @static + * @memberOf _ + * @since 3.8.0 + * @category Object + * @param {Object} object The object to iterate over. + * @param {Function} [iteratee=_.identity] The function invoked per iteration. + * @returns {Object} Returns the new mapped object. + * @see _.mapValues + * @example + * + * _.mapKeys({ 'a': 1, 'b': 2 }, function(value, key) { + * return key + value; + * }); + * // => { 'a1': 1, 'b2': 2 } + */ + function mapKeys(object, iteratee) { + var result = {}; + iteratee = getIteratee(iteratee, 3); + + baseForOwn(object, function(value, key, object) { + baseAssignValue(result, iteratee(value, key, object), value); + }); + return result; + } + + /** + * Creates an object with the same keys as `object` and values generated + * by running each own enumerable string keyed property of `object` thru + * `iteratee`. The iteratee is invoked with three arguments: + * (value, key, object). + * + * @static + * @memberOf _ + * @since 2.4.0 + * @category Object + * @param {Object} object The object to iterate over. + * @param {Function} [iteratee=_.identity] The function invoked per iteration. + * @returns {Object} Returns the new mapped object. + * @see _.mapKeys + * @example + * + * var users = { + * 'fred': { 'user': 'fred', 'age': 40 }, + * 'pebbles': { 'user': 'pebbles', 'age': 1 } + * }; + * + * _.mapValues(users, function(o) { return o.age; }); + * // => { 'fred': 40, 'pebbles': 1 } (iteration order is not guaranteed) + * + * // The `_.property` iteratee shorthand. + * _.mapValues(users, 'age'); + * // => { 'fred': 40, 'pebbles': 1 } (iteration order is not guaranteed) + */ + function mapValues(object, iteratee) { + var result = {}; + iteratee = getIteratee(iteratee, 3); + + baseForOwn(object, function(value, key, object) { + baseAssignValue(result, key, iteratee(value, key, object)); + }); + return result; + } + + /** + * This method is like `_.assign` except that it recursively merges own and + * inherited enumerable string keyed properties of source objects into the + * destination object. Source properties that resolve to `undefined` are + * skipped if a destination value exists. Array and plain object properties + * are merged recursively. Other objects and value types are overridden by + * assignment. Source objects are applied from left to right. Subsequent + * sources overwrite property assignments of previous sources. + * + * **Note:** This method mutates `object`. + * + * @static + * @memberOf _ + * @since 0.5.0 + * @category Object + * @param {Object} object The destination object. + * @param {...Object} [sources] The source objects. + * @returns {Object} Returns `object`. + * @example + * + * var object = { + * 'a': [{ 'b': 2 }, { 'd': 4 }] + * }; + * + * var other = { + * 'a': [{ 'c': 3 }, { 'e': 5 }] + * }; + * + * _.merge(object, other); + * // => { 'a': [{ 'b': 2, 'c': 3 }, { 'd': 4, 'e': 5 }] } + */ + var merge = createAssigner(function(object, source, srcIndex) { + baseMerge(object, source, srcIndex); + }); + + /** + * This method is like `_.merge` except that it accepts `customizer` which + * is invoked to produce the merged values of the destination and source + * properties. If `customizer` returns `undefined`, merging is handled by the + * method instead. The `customizer` is invoked with six arguments: + * (objValue, srcValue, key, object, source, stack). + * + * **Note:** This method mutates `object`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Object + * @param {Object} object The destination object. + * @param {...Object} sources The source objects. + * @param {Function} customizer The function to customize assigned values. + * @returns {Object} Returns `object`. + * @example + * + * function customizer(objValue, srcValue) { + * if (_.isArray(objValue)) { + * return objValue.concat(srcValue); + * } + * } + * + * var object = { 'a': [1], 'b': [2] }; + * var other = { 'a': [3], 'b': [4] }; + * + * _.mergeWith(object, other, customizer); + * // => { 'a': [1, 3], 'b': [2, 4] } + */ + var mergeWith = createAssigner(function(object, source, srcIndex, customizer) { + baseMerge(object, source, srcIndex, customizer); + }); + + /** + * The opposite of `_.pick`; this method creates an object composed of the + * own and inherited enumerable string keyed properties of `object` that are + * not omitted. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Object + * @param {Object} object The source object. + * @param {...(string|string[])} [props] The property identifiers to omit. + * @returns {Object} Returns the new object. + * @example + * + * var object = { 'a': 1, 'b': '2', 'c': 3 }; + * + * _.omit(object, ['a', 'c']); + * // => { 'b': '2' } + */ + var omit = flatRest(function(object, props) { + if (object == null) { + return {}; + } + props = arrayMap(props, toKey); + return basePick(object, baseDifference(getAllKeysIn(object), props)); + }); + + /** + * The opposite of `_.pickBy`; this method creates an object composed of + * the own and inherited enumerable string keyed properties of `object` that + * `predicate` doesn't return truthy for. The predicate is invoked with two + * arguments: (value, key). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Object + * @param {Object} object The source object. + * @param {Function} [predicate=_.identity] The function invoked per property. + * @returns {Object} Returns the new object. + * @example + * + * var object = { 'a': 1, 'b': '2', 'c': 3 }; + * + * _.omitBy(object, _.isNumber); + * // => { 'b': '2' } + */ + function omitBy(object, predicate) { + return pickBy(object, negate(getIteratee(predicate))); + } + + /** + * Creates an object composed of the picked `object` properties. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Object + * @param {Object} object The source object. + * @param {...(string|string[])} [props] The property identifiers to pick. + * @returns {Object} Returns the new object. + * @example + * + * var object = { 'a': 1, 'b': '2', 'c': 3 }; + * + * _.pick(object, ['a', 'c']); + * // => { 'a': 1, 'c': 3 } + */ + var pick = flatRest(function(object, props) { + return object == null ? {} : basePick(object, arrayMap(props, toKey)); + }); + + /** + * Creates an object composed of the `object` properties `predicate` returns + * truthy for. The predicate is invoked with two arguments: (value, key). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Object + * @param {Object} object The source object. + * @param {Function} [predicate=_.identity] The function invoked per property. + * @returns {Object} Returns the new object. + * @example + * + * var object = { 'a': 1, 'b': '2', 'c': 3 }; + * + * _.pickBy(object, _.isNumber); + * // => { 'a': 1, 'c': 3 } + */ + function pickBy(object, predicate) { + return object == null ? {} : basePickBy(object, getAllKeysIn(object), getIteratee(predicate)); + } + + /** + * This method is like `_.get` except that if the resolved value is a + * function it's invoked with the `this` binding of its parent object and + * its result is returned. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Object + * @param {Object} object The object to query. + * @param {Array|string} path The path of the property to resolve. + * @param {*} [defaultValue] The value returned for `undefined` resolved values. + * @returns {*} Returns the resolved value. + * @example + * + * var object = { 'a': [{ 'b': { 'c1': 3, 'c2': _.constant(4) } }] }; + * + * _.result(object, 'a[0].b.c1'); + * // => 3 + * + * _.result(object, 'a[0].b.c2'); + * // => 4 + * + * _.result(object, 'a[0].b.c3', 'default'); + * // => 'default' + * + * _.result(object, 'a[0].b.c3', _.constant('default')); + * // => 'default' + */ + function result(object, path, defaultValue) { + path = isKey(path, object) ? [path] : castPath(path); + + var index = -1, + length = path.length; + + // Ensure the loop is entered when path is empty. + if (!length) { + object = undefined; + length = 1; + } + while (++index < length) { + var value = object == null ? undefined : object[toKey(path[index])]; + if (value === undefined) { + index = length; + value = defaultValue; + } + object = isFunction(value) ? value.call(object) : value; + } + return object; + } + + /** + * Sets the value at `path` of `object`. If a portion of `path` doesn't exist, + * it's created. Arrays are created for missing index properties while objects + * are created for all other missing properties. Use `_.setWith` to customize + * `path` creation. + * + * **Note:** This method mutates `object`. + * + * @static + * @memberOf _ + * @since 3.7.0 + * @category Object + * @param {Object} object The object to modify. + * @param {Array|string} path The path of the property to set. + * @param {*} value The value to set. + * @returns {Object} Returns `object`. + * @example + * + * var object = { 'a': [{ 'b': { 'c': 3 } }] }; + * + * _.set(object, 'a[0].b.c', 4); + * console.log(object.a[0].b.c); + * // => 4 + * + * _.set(object, ['x', '0', 'y', 'z'], 5); + * console.log(object.x[0].y.z); + * // => 5 + */ + function set(object, path, value) { + return object == null ? object : baseSet(object, path, value); + } + + /** + * This method is like `_.set` except that it accepts `customizer` which is + * invoked to produce the objects of `path`. If `customizer` returns `undefined` + * path creation is handled by the method instead. The `customizer` is invoked + * with three arguments: (nsValue, key, nsObject). + * + * **Note:** This method mutates `object`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Object + * @param {Object} object The object to modify. + * @param {Array|string} path The path of the property to set. + * @param {*} value The value to set. + * @param {Function} [customizer] The function to customize assigned values. + * @returns {Object} Returns `object`. + * @example + * + * var object = {}; + * + * _.setWith(object, '[0][1]', 'a', Object); + * // => { '0': { '1': 'a' } } + */ + function setWith(object, path, value, customizer) { + customizer = typeof customizer == 'function' ? customizer : undefined; + return object == null ? object : baseSet(object, path, value, customizer); + } + + /** + * Creates an array of own enumerable string keyed-value pairs for `object` + * which can be consumed by `_.fromPairs`. If `object` is a map or set, its + * entries are returned. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @alias entries + * @category Object + * @param {Object} object The object to query. + * @returns {Array} Returns the key-value pairs. + * @example + * + * function Foo() { + * this.a = 1; + * this.b = 2; + * } + * + * Foo.prototype.c = 3; + * + * _.toPairs(new Foo); + * // => [['a', 1], ['b', 2]] (iteration order is not guaranteed) + */ + var toPairs = createToPairs(keys); + + /** + * Creates an array of own and inherited enumerable string keyed-value pairs + * for `object` which can be consumed by `_.fromPairs`. If `object` is a map + * or set, its entries are returned. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @alias entriesIn + * @category Object + * @param {Object} object The object to query. + * @returns {Array} Returns the key-value pairs. + * @example + * + * function Foo() { + * this.a = 1; + * this.b = 2; + * } + * + * Foo.prototype.c = 3; + * + * _.toPairsIn(new Foo); + * // => [['a', 1], ['b', 2], ['c', 3]] (iteration order is not guaranteed) + */ + var toPairsIn = createToPairs(keysIn); + + /** + * An alternative to `_.reduce`; this method transforms `object` to a new + * `accumulator` object which is the result of running each of its own + * enumerable string keyed properties thru `iteratee`, with each invocation + * potentially mutating the `accumulator` object. If `accumulator` is not + * provided, a new object with the same `[[Prototype]]` will be used. The + * iteratee is invoked with four arguments: (accumulator, value, key, object). + * Iteratee functions may exit iteration early by explicitly returning `false`. + * + * @static + * @memberOf _ + * @since 1.3.0 + * @category Object + * @param {Object} object The object to iterate over. + * @param {Function} [iteratee=_.identity] The function invoked per iteration. + * @param {*} [accumulator] The custom accumulator value. + * @returns {*} Returns the accumulated value. + * @example + * + * _.transform([2, 3, 4], function(result, n) { + * result.push(n *= n); + * return n % 2 == 0; + * }, []); + * // => [4, 9] + * + * _.transform({ 'a': 1, 'b': 2, 'c': 1 }, function(result, value, key) { + * (result[value] || (result[value] = [])).push(key); + * }, {}); + * // => { '1': ['a', 'c'], '2': ['b'] } + */ + function transform(object, iteratee, accumulator) { + var isArr = isArray(object), + isArrLike = isArr || isBuffer(object) || isTypedArray(object); + + iteratee = getIteratee(iteratee, 4); + if (accumulator == null) { + var Ctor = object && object.constructor; + if (isArrLike) { + accumulator = isArr ? new Ctor : []; + } + else if (isObject(object)) { + accumulator = isFunction(Ctor) ? baseCreate(getPrototype(object)) : {}; + } + else { + accumulator = {}; + } + } + (isArrLike ? arrayEach : baseForOwn)(object, function(value, index, object) { + return iteratee(accumulator, value, index, object); + }); + return accumulator; + } + + /** + * Removes the property at `path` of `object`. + * + * **Note:** This method mutates `object`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Object + * @param {Object} object The object to modify. + * @param {Array|string} path The path of the property to unset. + * @returns {boolean} Returns `true` if the property is deleted, else `false`. + * @example + * + * var object = { 'a': [{ 'b': { 'c': 7 } }] }; + * _.unset(object, 'a[0].b.c'); + * // => true + * + * console.log(object); + * // => { 'a': [{ 'b': {} }] }; + * + * _.unset(object, ['a', '0', 'b', 'c']); + * // => true + * + * console.log(object); + * // => { 'a': [{ 'b': {} }] }; + */ + function unset(object, path) { + return object == null ? true : baseUnset(object, path); + } + + /** + * This method is like `_.set` except that accepts `updater` to produce the + * value to set. Use `_.updateWith` to customize `path` creation. The `updater` + * is invoked with one argument: (value). + * + * **Note:** This method mutates `object`. + * + * @static + * @memberOf _ + * @since 4.6.0 + * @category Object + * @param {Object} object The object to modify. + * @param {Array|string} path The path of the property to set. + * @param {Function} updater The function to produce the updated value. + * @returns {Object} Returns `object`. + * @example + * + * var object = { 'a': [{ 'b': { 'c': 3 } }] }; + * + * _.update(object, 'a[0].b.c', function(n) { return n * n; }); + * console.log(object.a[0].b.c); + * // => 9 + * + * _.update(object, 'x[0].y.z', function(n) { return n ? n + 1 : 0; }); + * console.log(object.x[0].y.z); + * // => 0 + */ + function update(object, path, updater) { + return object == null ? object : baseUpdate(object, path, castFunction(updater)); + } + + /** + * This method is like `_.update` except that it accepts `customizer` which is + * invoked to produce the objects of `path`. If `customizer` returns `undefined` + * path creation is handled by the method instead. The `customizer` is invoked + * with three arguments: (nsValue, key, nsObject). + * + * **Note:** This method mutates `object`. + * + * @static + * @memberOf _ + * @since 4.6.0 + * @category Object + * @param {Object} object The object to modify. + * @param {Array|string} path The path of the property to set. + * @param {Function} updater The function to produce the updated value. + * @param {Function} [customizer] The function to customize assigned values. + * @returns {Object} Returns `object`. + * @example + * + * var object = {}; + * + * _.updateWith(object, '[0][1]', _.constant('a'), Object); + * // => { '0': { '1': 'a' } } + */ + function updateWith(object, path, updater, customizer) { + customizer = typeof customizer == 'function' ? customizer : undefined; + return object == null ? object : baseUpdate(object, path, castFunction(updater), customizer); + } + + /** + * Creates an array of the own enumerable string keyed property values of `object`. + * + * **Note:** Non-object values are coerced to objects. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Object + * @param {Object} object The object to query. + * @returns {Array} Returns the array of property values. + * @example + * + * function Foo() { + * this.a = 1; + * this.b = 2; + * } + * + * Foo.prototype.c = 3; + * + * _.values(new Foo); + * // => [1, 2] (iteration order is not guaranteed) + * + * _.values('hi'); + * // => ['h', 'i'] + */ + function values(object) { + return object ? baseValues(object, keys(object)) : []; + } + + /** + * Creates an array of the own and inherited enumerable string keyed property + * values of `object`. + * + * **Note:** Non-object values are coerced to objects. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Object + * @param {Object} object The object to query. + * @returns {Array} Returns the array of property values. + * @example + * + * function Foo() { + * this.a = 1; + * this.b = 2; + * } + * + * Foo.prototype.c = 3; + * + * _.valuesIn(new Foo); + * // => [1, 2, 3] (iteration order is not guaranteed) + */ + function valuesIn(object) { + return object == null ? [] : baseValues(object, keysIn(object)); + } + + /*------------------------------------------------------------------------*/ + + /** + * Clamps `number` within the inclusive `lower` and `upper` bounds. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Number + * @param {number} number The number to clamp. + * @param {number} [lower] The lower bound. + * @param {number} upper The upper bound. + * @returns {number} Returns the clamped number. + * @example + * + * _.clamp(-10, -5, 5); + * // => -5 + * + * _.clamp(10, -5, 5); + * // => 5 + */ + function clamp(number, lower, upper) { + if (upper === undefined) { + upper = lower; + lower = undefined; + } + if (upper !== undefined) { + upper = toNumber(upper); + upper = upper === upper ? upper : 0; + } + if (lower !== undefined) { + lower = toNumber(lower); + lower = lower === lower ? lower : 0; + } + return baseClamp(toNumber(number), lower, upper); + } + + /** + * Checks if `n` is between `start` and up to, but not including, `end`. If + * `end` is not specified, it's set to `start` with `start` then set to `0`. + * If `start` is greater than `end` the params are swapped to support + * negative ranges. + * + * @static + * @memberOf _ + * @since 3.3.0 + * @category Number + * @param {number} number The number to check. + * @param {number} [start=0] The start of the range. + * @param {number} end The end of the range. + * @returns {boolean} Returns `true` if `number` is in the range, else `false`. + * @see _.range, _.rangeRight + * @example + * + * _.inRange(3, 2, 4); + * // => true + * + * _.inRange(4, 8); + * // => true + * + * _.inRange(4, 2); + * // => false + * + * _.inRange(2, 2); + * // => false + * + * _.inRange(1.2, 2); + * // => true + * + * _.inRange(5.2, 4); + * // => false + * + * _.inRange(-3, -2, -6); + * // => true + */ + function inRange(number, start, end) { + start = toFinite(start); + if (end === undefined) { + end = start; + start = 0; + } else { + end = toFinite(end); + } + number = toNumber(number); + return baseInRange(number, start, end); + } + + /** + * Produces a random number between the inclusive `lower` and `upper` bounds. + * If only one argument is provided a number between `0` and the given number + * is returned. If `floating` is `true`, or either `lower` or `upper` are + * floats, a floating-point number is returned instead of an integer. + * + * **Note:** JavaScript follows the IEEE-754 standard for resolving + * floating-point values which can produce unexpected results. + * + * @static + * @memberOf _ + * @since 0.7.0 + * @category Number + * @param {number} [lower=0] The lower bound. + * @param {number} [upper=1] The upper bound. + * @param {boolean} [floating] Specify returning a floating-point number. + * @returns {number} Returns the random number. + * @example + * + * _.random(0, 5); + * // => an integer between 0 and 5 + * + * _.random(5); + * // => also an integer between 0 and 5 + * + * _.random(5, true); + * // => a floating-point number between 0 and 5 + * + * _.random(1.2, 5.2); + * // => a floating-point number between 1.2 and 5.2 + */ + function random(lower, upper, floating) { + if (floating && typeof floating != 'boolean' && isIterateeCall(lower, upper, floating)) { + upper = floating = undefined; + } + if (floating === undefined) { + if (typeof upper == 'boolean') { + floating = upper; + upper = undefined; + } + else if (typeof lower == 'boolean') { + floating = lower; + lower = undefined; + } + } + if (lower === undefined && upper === undefined) { + lower = 0; + upper = 1; + } + else { + lower = toFinite(lower); + if (upper === undefined) { + upper = lower; + lower = 0; + } else { + upper = toFinite(upper); + } + } + if (lower > upper) { + var temp = lower; + lower = upper; + upper = temp; + } + if (floating || lower % 1 || upper % 1) { + var rand = nativeRandom(); + return nativeMin(lower + (rand * (upper - lower + freeParseFloat('1e-' + ((rand + '').length - 1)))), upper); + } + return baseRandom(lower, upper); + } + + /*------------------------------------------------------------------------*/ + + /** + * Converts `string` to [camel case](https://en.wikipedia.org/wiki/CamelCase). + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category String + * @param {string} [string=''] The string to convert. + * @returns {string} Returns the camel cased string. + * @example + * + * _.camelCase('Foo Bar'); + * // => 'fooBar' + * + * _.camelCase('--foo-bar--'); + * // => 'fooBar' + * + * _.camelCase('__FOO_BAR__'); + * // => 'fooBar' + */ + var camelCase = createCompounder(function(result, word, index) { + word = word.toLowerCase(); + return result + (index ? capitalize(word) : word); + }); + + /** + * Converts the first character of `string` to upper case and the remaining + * to lower case. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category String + * @param {string} [string=''] The string to capitalize. + * @returns {string} Returns the capitalized string. + * @example + * + * _.capitalize('FRED'); + * // => 'Fred' + */ + function capitalize(string) { + return upperFirst(toString(string).toLowerCase()); + } + + /** + * Deburrs `string` by converting + * [Latin-1 Supplement](https://en.wikipedia.org/wiki/Latin-1_Supplement_(Unicode_block)#Character_table) + * and [Latin Extended-A](https://en.wikipedia.org/wiki/Latin_Extended-A) + * letters to basic Latin letters and removing + * [combining diacritical marks](https://en.wikipedia.org/wiki/Combining_Diacritical_Marks). + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category String + * @param {string} [string=''] The string to deburr. + * @returns {string} Returns the deburred string. + * @example + * + * _.deburr('déjà vu'); + * // => 'deja vu' + */ + function deburr(string) { + string = toString(string); + return string && string.replace(reLatin, deburrLetter).replace(reComboMark, ''); + } + + /** + * Checks if `string` ends with the given target string. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category String + * @param {string} [string=''] The string to inspect. + * @param {string} [target] The string to search for. + * @param {number} [position=string.length] The position to search up to. + * @returns {boolean} Returns `true` if `string` ends with `target`, + * else `false`. + * @example + * + * _.endsWith('abc', 'c'); + * // => true + * + * _.endsWith('abc', 'b'); + * // => false + * + * _.endsWith('abc', 'b', 2); + * // => true + */ + function endsWith(string, target, position) { + string = toString(string); + target = baseToString(target); + + var length = string.length; + position = position === undefined + ? length + : baseClamp(toInteger(position), 0, length); + + var end = position; + position -= target.length; + return position >= 0 && string.slice(position, end) == target; + } + + /** + * Converts the characters "&", "<", ">", '"', and "'" in `string` to their + * corresponding HTML entities. + * + * **Note:** No other characters are escaped. To escape additional + * characters use a third-party library like [_he_](https://mths.be/he). + * + * Though the ">" character is escaped for symmetry, characters like + * ">" and "/" don't need escaping in HTML and have no special meaning + * unless they're part of a tag or unquoted attribute value. See + * [Mathias Bynens's article](https://mathiasbynens.be/notes/ambiguous-ampersands) + * (under "semi-related fun fact") for more details. + * + * When working with HTML you should always + * [quote attribute values](http://wonko.com/post/html-escaping) to reduce + * XSS vectors. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category String + * @param {string} [string=''] The string to escape. + * @returns {string} Returns the escaped string. + * @example + * + * _.escape('fred, barney, & pebbles'); + * // => 'fred, barney, & pebbles' + */ + function escape(string) { + string = toString(string); + return (string && reHasUnescapedHtml.test(string)) + ? string.replace(reUnescapedHtml, escapeHtmlChar) + : string; + } + + /** + * Escapes the `RegExp` special characters "^", "$", "\", ".", "*", "+", + * "?", "(", ")", "[", "]", "{", "}", and "|" in `string`. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category String + * @param {string} [string=''] The string to escape. + * @returns {string} Returns the escaped string. + * @example + * + * _.escapeRegExp('[lodash](https://lodash.com/)'); + * // => '\[lodash\]\(https://lodash\.com/\)' + */ + function escapeRegExp(string) { + string = toString(string); + return (string && reHasRegExpChar.test(string)) + ? string.replace(reRegExpChar, '\\$&') + : string; + } + + /** + * Converts `string` to + * [kebab case](https://en.wikipedia.org/wiki/Letter_case#Special_case_styles). + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category String + * @param {string} [string=''] The string to convert. + * @returns {string} Returns the kebab cased string. + * @example + * + * _.kebabCase('Foo Bar'); + * // => 'foo-bar' + * + * _.kebabCase('fooBar'); + * // => 'foo-bar' + * + * _.kebabCase('__FOO_BAR__'); + * // => 'foo-bar' + */ + var kebabCase = createCompounder(function(result, word, index) { + return result + (index ? '-' : '') + word.toLowerCase(); + }); + + /** + * Converts `string`, as space separated words, to lower case. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category String + * @param {string} [string=''] The string to convert. + * @returns {string} Returns the lower cased string. + * @example + * + * _.lowerCase('--Foo-Bar--'); + * // => 'foo bar' + * + * _.lowerCase('fooBar'); + * // => 'foo bar' + * + * _.lowerCase('__FOO_BAR__'); + * // => 'foo bar' + */ + var lowerCase = createCompounder(function(result, word, index) { + return result + (index ? ' ' : '') + word.toLowerCase(); + }); + + /** + * Converts the first character of `string` to lower case. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category String + * @param {string} [string=''] The string to convert. + * @returns {string} Returns the converted string. + * @example + * + * _.lowerFirst('Fred'); + * // => 'fred' + * + * _.lowerFirst('FRED'); + * // => 'fRED' + */ + var lowerFirst = createCaseFirst('toLowerCase'); + + /** + * Pads `string` on the left and right sides if it's shorter than `length`. + * Padding characters are truncated if they can't be evenly divided by `length`. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category String + * @param {string} [string=''] The string to pad. + * @param {number} [length=0] The padding length. + * @param {string} [chars=' '] The string used as padding. + * @returns {string} Returns the padded string. + * @example + * + * _.pad('abc', 8); + * // => ' abc ' + * + * _.pad('abc', 8, '_-'); + * // => '_-abc_-_' + * + * _.pad('abc', 3); + * // => 'abc' + */ + function pad(string, length, chars) { + string = toString(string); + length = toInteger(length); + + var strLength = length ? stringSize(string) : 0; + if (!length || strLength >= length) { + return string; + } + var mid = (length - strLength) / 2; + return ( + createPadding(nativeFloor(mid), chars) + + string + + createPadding(nativeCeil(mid), chars) + ); + } + + /** + * Pads `string` on the right side if it's shorter than `length`. Padding + * characters are truncated if they exceed `length`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category String + * @param {string} [string=''] The string to pad. + * @param {number} [length=0] The padding length. + * @param {string} [chars=' '] The string used as padding. + * @returns {string} Returns the padded string. + * @example + * + * _.padEnd('abc', 6); + * // => 'abc ' + * + * _.padEnd('abc', 6, '_-'); + * // => 'abc_-_' + * + * _.padEnd('abc', 3); + * // => 'abc' + */ + function padEnd(string, length, chars) { + string = toString(string); + length = toInteger(length); + + var strLength = length ? stringSize(string) : 0; + return (length && strLength < length) + ? (string + createPadding(length - strLength, chars)) + : string; + } + + /** + * Pads `string` on the left side if it's shorter than `length`. Padding + * characters are truncated if they exceed `length`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category String + * @param {string} [string=''] The string to pad. + * @param {number} [length=0] The padding length. + * @param {string} [chars=' '] The string used as padding. + * @returns {string} Returns the padded string. + * @example + * + * _.padStart('abc', 6); + * // => ' abc' + * + * _.padStart('abc', 6, '_-'); + * // => '_-_abc' + * + * _.padStart('abc', 3); + * // => 'abc' + */ + function padStart(string, length, chars) { + string = toString(string); + length = toInteger(length); + + var strLength = length ? stringSize(string) : 0; + return (length && strLength < length) + ? (createPadding(length - strLength, chars) + string) + : string; + } + + /** + * Converts `string` to an integer of the specified radix. If `radix` is + * `undefined` or `0`, a `radix` of `10` is used unless `value` is a + * hexadecimal, in which case a `radix` of `16` is used. + * + * **Note:** This method aligns with the + * [ES5 implementation](https://es5.github.io/#x15.1.2.2) of `parseInt`. + * + * @static + * @memberOf _ + * @since 1.1.0 + * @category String + * @param {string} string The string to convert. + * @param {number} [radix=10] The radix to interpret `value` by. + * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`. + * @returns {number} Returns the converted integer. + * @example + * + * _.parseInt('08'); + * // => 8 + * + * _.map(['6', '08', '10'], _.parseInt); + * // => [6, 8, 10] + */ + function parseInt(string, radix, guard) { + if (guard || radix == null) { + radix = 0; + } else if (radix) { + radix = +radix; + } + return nativeParseInt(toString(string).replace(reTrimStart, ''), radix || 0); + } + + /** + * Repeats the given string `n` times. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category String + * @param {string} [string=''] The string to repeat. + * @param {number} [n=1] The number of times to repeat the string. + * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`. + * @returns {string} Returns the repeated string. + * @example + * + * _.repeat('*', 3); + * // => '***' + * + * _.repeat('abc', 2); + * // => 'abcabc' + * + * _.repeat('abc', 0); + * // => '' + */ + function repeat(string, n, guard) { + if ((guard ? isIterateeCall(string, n, guard) : n === undefined)) { + n = 1; + } else { + n = toInteger(n); + } + return baseRepeat(toString(string), n); + } + + /** + * Replaces matches for `pattern` in `string` with `replacement`. + * + * **Note:** This method is based on + * [`String#replace`](https://mdn.io/String/replace). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category String + * @param {string} [string=''] The string to modify. + * @param {RegExp|string} pattern The pattern to replace. + * @param {Function|string} replacement The match replacement. + * @returns {string} Returns the modified string. + * @example + * + * _.replace('Hi Fred', 'Fred', 'Barney'); + * // => 'Hi Barney' + */ + function replace() { + var args = arguments, + string = toString(args[0]); + + return args.length < 3 ? string : string.replace(args[1], args[2]); + } + + /** + * Converts `string` to + * [snake case](https://en.wikipedia.org/wiki/Snake_case). + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category String + * @param {string} [string=''] The string to convert. + * @returns {string} Returns the snake cased string. + * @example + * + * _.snakeCase('Foo Bar'); + * // => 'foo_bar' + * + * _.snakeCase('fooBar'); + * // => 'foo_bar' + * + * _.snakeCase('--FOO-BAR--'); + * // => 'foo_bar' + */ + var snakeCase = createCompounder(function(result, word, index) { + return result + (index ? '_' : '') + word.toLowerCase(); + }); + + /** + * Splits `string` by `separator`. + * + * **Note:** This method is based on + * [`String#split`](https://mdn.io/String/split). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category String + * @param {string} [string=''] The string to split. + * @param {RegExp|string} separator The separator pattern to split by. + * @param {number} [limit] The length to truncate results to. + * @returns {Array} Returns the string segments. + * @example + * + * _.split('a-b-c', '-', 2); + * // => ['a', 'b'] + */ + function split(string, separator, limit) { + if (limit && typeof limit != 'number' && isIterateeCall(string, separator, limit)) { + separator = limit = undefined; + } + limit = limit === undefined ? MAX_ARRAY_LENGTH : limit >>> 0; + if (!limit) { + return []; + } + string = toString(string); + if (string && ( + typeof separator == 'string' || + (separator != null && !isRegExp(separator)) + )) { + separator = baseToString(separator); + if (!separator && hasUnicode(string)) { + return castSlice(stringToArray(string), 0, limit); + } + } + return string.split(separator, limit); + } + + /** + * Converts `string` to + * [start case](https://en.wikipedia.org/wiki/Letter_case#Stylistic_or_specialised_usage). + * + * @static + * @memberOf _ + * @since 3.1.0 + * @category String + * @param {string} [string=''] The string to convert. + * @returns {string} Returns the start cased string. + * @example + * + * _.startCase('--foo-bar--'); + * // => 'Foo Bar' + * + * _.startCase('fooBar'); + * // => 'Foo Bar' + * + * _.startCase('__FOO_BAR__'); + * // => 'FOO BAR' + */ + var startCase = createCompounder(function(result, word, index) { + return result + (index ? ' ' : '') + upperFirst(word); + }); + + /** + * Checks if `string` starts with the given target string. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category String + * @param {string} [string=''] The string to inspect. + * @param {string} [target] The string to search for. + * @param {number} [position=0] The position to search from. + * @returns {boolean} Returns `true` if `string` starts with `target`, + * else `false`. + * @example + * + * _.startsWith('abc', 'a'); + * // => true + * + * _.startsWith('abc', 'b'); + * // => false + * + * _.startsWith('abc', 'b', 1); + * // => true + */ + function startsWith(string, target, position) { + string = toString(string); + position = baseClamp(toInteger(position), 0, string.length); + target = baseToString(target); + return string.slice(position, position + target.length) == target; + } + + /** + * Creates a compiled template function that can interpolate data properties + * in "interpolate" delimiters, HTML-escape interpolated data properties in + * "escape" delimiters, and execute JavaScript in "evaluate" delimiters. Data + * properties may be accessed as free variables in the template. If a setting + * object is given, it takes precedence over `_.templateSettings` values. + * + * **Note:** In the development build `_.template` utilizes + * [sourceURLs](http://www.html5rocks.com/en/tutorials/developertools/sourcemaps/#toc-sourceurl) + * for easier debugging. + * + * For more information on precompiling templates see + * [lodash's custom builds documentation](https://lodash.com/custom-builds). + * + * For more information on Chrome extension sandboxes see + * [Chrome's extensions documentation](https://developer.chrome.com/extensions/sandboxingEval). + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category String + * @param {string} [string=''] The template string. + * @param {Object} [options={}] The options object. + * @param {RegExp} [options.escape=_.templateSettings.escape] + * The HTML "escape" delimiter. + * @param {RegExp} [options.evaluate=_.templateSettings.evaluate] + * The "evaluate" delimiter. + * @param {Object} [options.imports=_.templateSettings.imports] + * An object to import into the template as free variables. + * @param {RegExp} [options.interpolate=_.templateSettings.interpolate] + * The "interpolate" delimiter. + * @param {string} [options.sourceURL='lodash.templateSources[n]'] + * The sourceURL of the compiled template. + * @param {string} [options.variable='obj'] + * The data object variable name. + * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`. + * @returns {Function} Returns the compiled template function. + * @example + * + * // Use the "interpolate" delimiter to create a compiled template. + * var compiled = _.template('hello <%= user %>!'); + * compiled({ 'user': 'fred' }); + * // => 'hello fred!' + * + * // Use the HTML "escape" delimiter to escape data property values. + * var compiled = _.template('<%- value %>'); + * compiled({ 'value': '` + +3. use toastr to display a toast for info, success, warning or error + ```js + // Display an info toast with no title + toastr.info('Are you the 6 fingered man?') + ``` + +### Other Options +```js +// Display a warning toast, with no title +toastr.warning('My name is Inigo Montoya. You killed my father, prepare to die!') + +// Display a success toast, with a title +toastr.success('Have fun storming the castle!', 'Miracle Max Says') + +// Display an error toast, with a title +toastr.error('I do not think that word means what you think it means.', 'Inconceivable!') + +// Immediately remove current toasts without using animation +toastr.remove() + +// Remove current toasts using animation +toastr.clear() + +// Override global options +toastr.success('We do have the Kapua suite available.', 'Turtle Bay Resort', {timeOut: 5000}) +``` + +### Escape HTML characters +In case you want to escape HTML charaters in title and message + + toastr.options.escapeHtml = true; + +### Close Button +Optionally enable a close button +```js +toastr.options.closeButton = true; +```` + +Optionally override the close button's HTML. + +```js +toastr.options.closeHtml = ''; +``` + +You can also override the CSS/LESS for `#toast-container .toast-close-button` + +Optionally override the hide animation when the close button is clicked (falls back to hide configuration). +```js +toastr.options.closeMethod = 'fadeOut'; +toastr.options.closeDuration = 300; +toastr.options.closeEasing = 'swing'; +``` + +### Display Sequence +Show newest toast at bottom (top is default) +```js +toastr.options.newestOnTop = false; +``` + +### Callbacks +```js +// Define a callback for when the toast is shown/hidden +toastr.options.onShown = function() { console.log('hello'); } +toastr.options.onHidden = function() { console.log('goodbye'); } +``` + +### Animation Options +Toastr will supply default animations, so you do not have to provide any of these settings. However you have the option to override the animations if you like. + +####Easings +Optionally override the animation easing to show or hide the toasts. Default is swing. swing and linear are built into jQuery. +```js +toastr.options.showEasing = 'swing'; +toastr.options.hideEasing = 'linear'; +toastr.options.closeEasing = 'linear'; +``` + +Using the jQuery Easing plugin (http://www.gsgd.co.uk/sandbox/jquery/easing/) +```js +toastr.options.showEasing = 'easeOutBounce'; +toastr.options.hideEasing = 'easeInBack'; +toastr.options.closeEasing = 'easeInBack'; +``` + +####Animation Method +Use the jQuery show/hide method of your choice. These default to fadeIn/fadeOut. The methods fadeIn/fadeOut, slideDown/slideUp, and show/hide are built into jQuery. +```js +toastr.options.showMethod = 'slideDown'; +toastr.options.hideMethod = 'slideUp'; +toastr.options.closeMethod = 'slideUp'; +``` + +###Prevent Duplicates +Rather than having identical toasts stack, set the preventDuplicates property to true. Duplicates are matched to the previous toast based on their message content. +```js +toastr.options.preventDuplicates = true; +``` + +###Timeouts +Control how toastr interacts with users by setting timeouts appropriately. Timeouts can be disabled by setting them to 0. +```js +toastr.options.timeOut = 30; // How long the toast will display without user interaction +toastr.options.extendedTimeOut = 60; // How long the toast will display after a user hovers over it +``` + + +###Progress Bar +Visually indicate how long before a toast expires. +```js +toastr.options.progressBar = true; +``` + +## Building Toastr + +To build the minified and css versions of Toastr you will need [node](http://nodejs.org) installed. (Use Homebrew or Chocolatey.) + +``` +npm install -g gulp karma-cli +npm install +``` + +At this point the dependencies have been installed and you can build Toastr + +- Run the analytics `gulp analyze` +- Run the test `gulp test` +- Run the build `gulp` + +## Contributing + +For a pull request to be considered it must resolve a bug, or add a feature which is beneficial to a large audience. + +Pull requests must pass existing unit tests, CI processes, and add additional tests to indicate successful operation of a new feature, or the resolution of an identified bug. + +Requests must be made against the `develop` branch. Pull requests submitted against the `master` branch will not be considered. + +All pull requests are subject to approval by the repository owners, who have sole discretion over acceptance or denial. + +## Authors +**John Papa** + ++ [http://twitter.com/John_Papa](http://twitter.com/John_Papa) + +**Tim Ferrell** + ++ [http://twitter.com/ferrell_tim](http://twitter.com/ferrell_tim) + +**Hans Fjällemark** + ++ [http://twitter.com/hfjallemark](http://twitter.com/hfjallemark) + +## Credits +Inspired by https://github.com/Srirangan/notifer.js/. + +## Copyright +Copyright © 2012-2015 + +## License +toastr is under MIT license - http://www.opensource.org/licenses/mit-license.php diff --git a/node_modules/toastr/build/toastr.css b/node_modules/toastr/build/toastr.css new file mode 100644 index 0000000..0e33542 --- /dev/null +++ b/node_modules/toastr/build/toastr.css @@ -0,0 +1,200 @@ +.toast-title { + font-weight: bold; +} +.toast-message { + -ms-word-wrap: break-word; + word-wrap: break-word; +} +.toast-message a, +.toast-message label { + color: #ffffff; +} +.toast-message a:hover { + color: #cccccc; + text-decoration: none; +} +.toast-close-button { + position: relative; + right: -0.3em; + top: -0.3em; + float: right; + font-size: 20px; + font-weight: bold; + color: #ffffff; + -webkit-text-shadow: 0 1px 0 #ffffff; + text-shadow: 0 1px 0 #ffffff; + opacity: 0.8; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=80); + filter: alpha(opacity=80); +} +.toast-close-button:hover, +.toast-close-button:focus { + color: #000000; + text-decoration: none; + cursor: pointer; + opacity: 0.4; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=40); + filter: alpha(opacity=40); +} +/*Additional properties for button version + iOS requires the button element instead of an anchor tag. + If you want the anchor version, it requires `href="#"`.*/ +button.toast-close-button { + padding: 0; + cursor: pointer; + background: transparent; + border: 0; + -webkit-appearance: none; +} +.toast-top-center { + top: 0; + right: 0; + width: 100%; +} +.toast-bottom-center { + bottom: 0; + right: 0; + width: 100%; +} +.toast-top-full-width { + top: 0; + right: 0; + width: 100%; +} +.toast-bottom-full-width { + bottom: 0; + right: 0; + width: 100%; +} +.toast-top-left { + top: 12px; + left: 12px; +} +.toast-top-right { + top: 12px; + right: 12px; +} +.toast-bottom-right { + right: 12px; + bottom: 12px; +} +.toast-bottom-left { + bottom: 12px; + left: 12px; +} +#toast-container { + position: fixed; + z-index: 999999; + pointer-events: none; + /*overrides*/ +} +#toast-container * { + -moz-box-sizing: border-box; + -webkit-box-sizing: border-box; + box-sizing: border-box; +} +#toast-container > div { + position: relative; + pointer-events: auto; + overflow: hidden; + margin: 0 0 6px; + padding: 15px 15px 15px 50px; + width: 300px; + -moz-border-radius: 3px 3px 3px 3px; + -webkit-border-radius: 3px 3px 3px 3px; + border-radius: 3px 3px 3px 3px; + background-position: 15px center; + background-repeat: no-repeat; + -moz-box-shadow: 0 0 12px #999999; + -webkit-box-shadow: 0 0 12px #999999; + box-shadow: 0 0 12px #999999; + color: #ffffff; + opacity: 0.8; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=80); + filter: alpha(opacity=80); +} +#toast-container > :hover { + -moz-box-shadow: 0 0 12px #000000; + -webkit-box-shadow: 0 0 12px #000000; + box-shadow: 0 0 12px #000000; + opacity: 1; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=100); + filter: alpha(opacity=100); + cursor: pointer; +} +#toast-container > .toast-info { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGwSURBVEhLtZa9SgNBEMc9sUxxRcoUKSzSWIhXpFMhhYWFhaBg4yPYiWCXZxBLERsLRS3EQkEfwCKdjWJAwSKCgoKCcudv4O5YLrt7EzgXhiU3/4+b2ckmwVjJSpKkQ6wAi4gwhT+z3wRBcEz0yjSseUTrcRyfsHsXmD0AmbHOC9Ii8VImnuXBPglHpQ5wwSVM7sNnTG7Za4JwDdCjxyAiH3nyA2mtaTJufiDZ5dCaqlItILh1NHatfN5skvjx9Z38m69CgzuXmZgVrPIGE763Jx9qKsRozWYw6xOHdER+nn2KkO+Bb+UV5CBN6WC6QtBgbRVozrahAbmm6HtUsgtPC19tFdxXZYBOfkbmFJ1VaHA1VAHjd0pp70oTZzvR+EVrx2Ygfdsq6eu55BHYR8hlcki+n+kERUFG8BrA0BwjeAv2M8WLQBtcy+SD6fNsmnB3AlBLrgTtVW1c2QN4bVWLATaIS60J2Du5y1TiJgjSBvFVZgTmwCU+dAZFoPxGEEs8nyHC9Bwe2GvEJv2WXZb0vjdyFT4Cxk3e/kIqlOGoVLwwPevpYHT+00T+hWwXDf4AJAOUqWcDhbwAAAAASUVORK5CYII=") !important; +} +#toast-container > .toast-error { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAHOSURBVEhLrZa/SgNBEMZzh0WKCClSCKaIYOED+AAKeQQLG8HWztLCImBrYadgIdY+gIKNYkBFSwu7CAoqCgkkoGBI/E28PdbLZmeDLgzZzcx83/zZ2SSXC1j9fr+I1Hq93g2yxH4iwM1vkoBWAdxCmpzTxfkN2RcyZNaHFIkSo10+8kgxkXIURV5HGxTmFuc75B2RfQkpxHG8aAgaAFa0tAHqYFfQ7Iwe2yhODk8+J4C7yAoRTWI3w/4klGRgR4lO7Rpn9+gvMyWp+uxFh8+H+ARlgN1nJuJuQAYvNkEnwGFck18Er4q3egEc/oO+mhLdKgRyhdNFiacC0rlOCbhNVz4H9FnAYgDBvU3QIioZlJFLJtsoHYRDfiZoUyIxqCtRpVlANq0EU4dApjrtgezPFad5S19Wgjkc0hNVnuF4HjVA6C7QrSIbylB+oZe3aHgBsqlNqKYH48jXyJKMuAbiyVJ8KzaB3eRc0pg9VwQ4niFryI68qiOi3AbjwdsfnAtk0bCjTLJKr6mrD9g8iq/S/B81hguOMlQTnVyG40wAcjnmgsCNESDrjme7wfftP4P7SP4N3CJZdvzoNyGq2c/HWOXJGsvVg+RA/k2MC/wN6I2YA2Pt8GkAAAAASUVORK5CYII=") !important; +} +#toast-container > .toast-success { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAADsSURBVEhLY2AYBfQMgf///3P8+/evAIgvA/FsIF+BavYDDWMBGroaSMMBiE8VC7AZDrIFaMFnii3AZTjUgsUUWUDA8OdAH6iQbQEhw4HyGsPEcKBXBIC4ARhex4G4BsjmweU1soIFaGg/WtoFZRIZdEvIMhxkCCjXIVsATV6gFGACs4Rsw0EGgIIH3QJYJgHSARQZDrWAB+jawzgs+Q2UO49D7jnRSRGoEFRILcdmEMWGI0cm0JJ2QpYA1RDvcmzJEWhABhD/pqrL0S0CWuABKgnRki9lLseS7g2AlqwHWQSKH4oKLrILpRGhEQCw2LiRUIa4lwAAAABJRU5ErkJggg==") !important; +} +#toast-container > .toast-warning { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGYSURBVEhL5ZSvTsNQFMbXZGICMYGYmJhAQIJAICYQPAACiSDB8AiICQQJT4CqQEwgJvYASAQCiZiYmJhAIBATCARJy+9rTsldd8sKu1M0+dLb057v6/lbq/2rK0mS/TRNj9cWNAKPYIJII7gIxCcQ51cvqID+GIEX8ASG4B1bK5gIZFeQfoJdEXOfgX4QAQg7kH2A65yQ87lyxb27sggkAzAuFhbbg1K2kgCkB1bVwyIR9m2L7PRPIhDUIXgGtyKw575yz3lTNs6X4JXnjV+LKM/m3MydnTbtOKIjtz6VhCBq4vSm3ncdrD2lk0VgUXSVKjVDJXJzijW1RQdsU7F77He8u68koNZTz8Oz5yGa6J3H3lZ0xYgXBK2QymlWWA+RWnYhskLBv2vmE+hBMCtbA7KX5drWyRT/2JsqZ2IvfB9Y4bWDNMFbJRFmC9E74SoS0CqulwjkC0+5bpcV1CZ8NMej4pjy0U+doDQsGyo1hzVJttIjhQ7GnBtRFN1UarUlH8F3xict+HY07rEzoUGPlWcjRFRr4/gChZgc3ZL2d8oAAAAASUVORK5CYII=") !important; +} +#toast-container.toast-top-center > div, +#toast-container.toast-bottom-center > div { + width: 300px; + margin-left: auto; + margin-right: auto; +} +#toast-container.toast-top-full-width > div, +#toast-container.toast-bottom-full-width > div { + width: 96%; + margin-left: auto; + margin-right: auto; +} +.toast { + background-color: #030303; +} +.toast-success { + background-color: #51a351; +} +.toast-error { + background-color: #bd362f; +} +.toast-info { + background-color: #2f96b4; +} +.toast-warning { + background-color: #f89406; +} +.toast-progress { + position: absolute; + left: 0; + bottom: 0; + height: 4px; + background-color: #000000; + opacity: 0.4; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=40); + filter: alpha(opacity=40); +} +/*Responsive Design*/ +@media all and (max-width: 240px) { + #toast-container > div { + padding: 8px 8px 8px 50px; + width: 11em; + } + #toast-container .toast-close-button { + right: -0.2em; + top: -0.2em; + } +} +@media all and (min-width: 241px) and (max-width: 480px) { + #toast-container > div { + padding: 8px 8px 8px 50px; + width: 18em; + } + #toast-container .toast-close-button { + right: -0.2em; + top: -0.2em; + } +} +@media all and (min-width: 481px) and (max-width: 768px) { + #toast-container > div { + padding: 15px 15px 15px 50px; + width: 25em; + } +} diff --git a/node_modules/toastr/build/toastr.js.map b/node_modules/toastr/build/toastr.js.map new file mode 100644 index 0000000..01d3f7a --- /dev/null +++ b/node_modules/toastr/build/toastr.js.map @@ -0,0 +1 @@ +{"version":3,"sources":["toastr.js"],"names":["define","$","error","message","title","optionsOverride","notify","type","toastType","iconClass","getOptions","iconClasses","getContainer","options","create","$container","containerId","length","createContainer","info","subscribe","callback","listener","success","warning","clear","$toastElement","clearOptions","clearToast","clearContainer","remove","removeToast","children","toastsToClear","i","force","hideMethod","duration","hideDuration","easing","hideEasing","complete","attr","addClass","positionClass","appendTo","target","getDefaults","tapToDismiss","toastClass","debug","showMethod","showDuration","showEasing","onShown","undefined","onHidden","closeMethod","closeDuration","closeEasing","extendedTimeOut","timeOut","titleClass","messageClass","escapeHtml","closeHtml","newestOnTop","preventDuplicates","progressBar","publish","args","map","source","String","replace","personalizeToast","setIcon","setTitle","setMessage","setCloseButton","setProgressBar","setSequence","handleEvents","hover","stickAround","delayedHideToast","onclick","click","hideToast","closeButton","$closeElement","event","stopPropagation","cancelBubble","displayToast","hide","intervalId","setTimeout","maxHideTime","parseFloat","hideEta","Date","getTime","setInterval","updateProgress","prepend","append","$titleElement","$messageElement","$progressElement","shouldExit","previousToast","override","method","clearTimeout","response","state","endTime","stop","percentage","width","extend","toastId","startTime","console","log","toastr","is","version","amd","deps","factory","module","exports","require","window","jQuery"],"mappings":"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","file":"toastr.js","sourcesContent":["/*\n * Toastr\n * Copyright 2012-2015\n * Authors: John Papa, Hans Fjällemark, and Tim Ferrell.\n * All Rights Reserved.\n * Use, reproduction, distribution, and modification of this code is subject to the terms and\n * conditions of the MIT license, available at http://www.opensource.org/licenses/mit-license.php\n *\n * ARIA Support: Greta Krafsig\n *\n * Project: https://github.com/CodeSeven/toastr\n */\n/* global define */\n; (function (define) {\n define(['jquery'], function ($) {\n return (function () {\n var $container;\n var listener;\n var toastId = 0;\n var toastType = {\n error: 'error',\n info: 'info',\n success: 'success',\n warning: 'warning'\n };\n\n var toastr = {\n clear: clear,\n remove: remove,\n error: error,\n getContainer: getContainer,\n info: info,\n options: {},\n subscribe: subscribe,\n success: success,\n version: '2.1.2',\n warning: warning\n };\n\n var previousToast;\n\n return toastr;\n\n ////////////////\n\n function error(message, title, optionsOverride) {\n return notify({\n type: toastType.error,\n iconClass: getOptions().iconClasses.error,\n message: message,\n optionsOverride: optionsOverride,\n title: title\n });\n }\n\n function getContainer(options, create) {\n if (!options) { options = getOptions(); }\n $container = $('#' + options.containerId);\n if ($container.length) {\n return $container;\n }\n if (create) {\n $container = createContainer(options);\n }\n return $container;\n }\n\n function info(message, title, optionsOverride) {\n return notify({\n type: toastType.info,\n iconClass: getOptions().iconClasses.info,\n message: message,\n optionsOverride: optionsOverride,\n title: title\n });\n }\n\n function subscribe(callback) {\n listener = callback;\n }\n\n function success(message, title, optionsOverride) {\n return notify({\n type: toastType.success,\n iconClass: getOptions().iconClasses.success,\n message: message,\n optionsOverride: optionsOverride,\n title: title\n });\n }\n\n function warning(message, title, optionsOverride) {\n return notify({\n type: toastType.warning,\n iconClass: getOptions().iconClasses.warning,\n message: message,\n optionsOverride: optionsOverride,\n title: title\n });\n }\n\n function clear($toastElement, clearOptions) {\n var options = getOptions();\n if (!$container) { getContainer(options); }\n if (!clearToast($toastElement, options, clearOptions)) {\n clearContainer(options);\n }\n }\n\n function remove($toastElement) {\n var options = getOptions();\n if (!$container) { getContainer(options); }\n if ($toastElement && $(':focus', $toastElement).length === 0) {\n removeToast($toastElement);\n return;\n }\n if ($container.children().length) {\n $container.remove();\n }\n }\n\n // internal functions\n\n function clearContainer (options) {\n var toastsToClear = $container.children();\n for (var i = toastsToClear.length - 1; i >= 0; i--) {\n clearToast($(toastsToClear[i]), options);\n }\n }\n\n function clearToast ($toastElement, options, clearOptions) {\n var force = clearOptions && clearOptions.force ? clearOptions.force : false;\n if ($toastElement && (force || $(':focus', $toastElement).length === 0)) {\n $toastElement[options.hideMethod]({\n duration: options.hideDuration,\n easing: options.hideEasing,\n complete: function () { removeToast($toastElement); }\n });\n return true;\n }\n return false;\n }\n\n function createContainer(options) {\n $container = $('
')\n .attr('id', options.containerId)\n .addClass(options.positionClass)\n .attr('aria-live', 'polite')\n .attr('role', 'alert');\n\n $container.appendTo($(options.target));\n return $container;\n }\n\n function getDefaults() {\n return {\n tapToDismiss: true,\n toastClass: 'toast',\n containerId: 'toast-container',\n debug: false,\n\n showMethod: 'fadeIn', //fadeIn, slideDown, and show are built into jQuery\n showDuration: 300,\n showEasing: 'swing', //swing and linear are built into jQuery\n onShown: undefined,\n hideMethod: 'fadeOut',\n hideDuration: 1000,\n hideEasing: 'swing',\n onHidden: undefined,\n closeMethod: false,\n closeDuration: false,\n closeEasing: false,\n\n extendedTimeOut: 1000,\n iconClasses: {\n error: 'toast-error',\n info: 'toast-info',\n success: 'toast-success',\n warning: 'toast-warning'\n },\n iconClass: 'toast-info',\n positionClass: 'toast-top-right',\n timeOut: 5000, // Set timeOut and extendedTimeOut to 0 to make it sticky\n titleClass: 'toast-title',\n messageClass: 'toast-message',\n escapeHtml: false,\n target: 'body',\n closeHtml: '',\n newestOnTop: true,\n preventDuplicates: false,\n progressBar: false\n };\n }\n\n function publish(args) {\n if (!listener) { return; }\n listener(args);\n }\n\n function notify(map) {\n var options = getOptions();\n var iconClass = map.iconClass || options.iconClass;\n\n if (typeof (map.optionsOverride) !== 'undefined') {\n options = $.extend(options, map.optionsOverride);\n iconClass = map.optionsOverride.iconClass || iconClass;\n }\n\n if (shouldExit(options, map)) { return; }\n\n toastId++;\n\n $container = getContainer(options, true);\n\n var intervalId = null;\n var $toastElement = $('
');\n var $titleElement = $('
');\n var $messageElement = $('
');\n var $progressElement = $('
');\n var $closeElement = $(options.closeHtml);\n var progressBar = {\n intervalId: null,\n hideEta: null,\n maxHideTime: null\n };\n var response = {\n toastId: toastId,\n state: 'visible',\n startTime: new Date(),\n options: options,\n map: map\n };\n\n personalizeToast();\n\n displayToast();\n\n handleEvents();\n\n publish(response);\n\n if (options.debug && console) {\n console.log(response);\n }\n\n return $toastElement;\n\n function escapeHtml(source) {\n if (source == null)\n source = \"\";\n\n return new String(source)\n .replace(/&/g, '&')\n .replace(/\"/g, '"')\n .replace(/'/g, ''')\n .replace(//g, '>');\n }\n\n function personalizeToast() {\n setIcon();\n setTitle();\n setMessage();\n setCloseButton();\n setProgressBar();\n setSequence();\n }\n\n function handleEvents() {\n $toastElement.hover(stickAround, delayedHideToast);\n if (!options.onclick && options.tapToDismiss) {\n $toastElement.click(hideToast);\n }\n\n if (options.closeButton && $closeElement) {\n $closeElement.click(function (event) {\n if (event.stopPropagation) {\n event.stopPropagation();\n } else if (event.cancelBubble !== undefined && event.cancelBubble !== true) {\n event.cancelBubble = true;\n }\n hideToast(true);\n });\n }\n\n if (options.onclick) {\n $toastElement.click(function (event) {\n options.onclick(event);\n hideToast();\n });\n }\n }\n\n function displayToast() {\n $toastElement.hide();\n\n $toastElement[options.showMethod](\n {duration: options.showDuration, easing: options.showEasing, complete: options.onShown}\n );\n\n if (options.timeOut > 0) {\n intervalId = setTimeout(hideToast, options.timeOut);\n progressBar.maxHideTime = parseFloat(options.timeOut);\n progressBar.hideEta = new Date().getTime() + progressBar.maxHideTime;\n if (options.progressBar) {\n progressBar.intervalId = setInterval(updateProgress, 10);\n }\n }\n }\n\n function setIcon() {\n if (map.iconClass) {\n $toastElement.addClass(options.toastClass).addClass(iconClass);\n }\n }\n\n function setSequence() {\n if (options.newestOnTop) {\n $container.prepend($toastElement);\n } else {\n $container.append($toastElement);\n }\n }\n\n function setTitle() {\n if (map.title) {\n $titleElement.append(!options.escapeHtml ? map.title : escapeHtml(map.title)).addClass(options.titleClass);\n $toastElement.append($titleElement);\n }\n }\n\n function setMessage() {\n if (map.message) {\n $messageElement.append(!options.escapeHtml ? map.message : escapeHtml(map.message)).addClass(options.messageClass);\n $toastElement.append($messageElement);\n }\n }\n\n function setCloseButton() {\n if (options.closeButton) {\n $closeElement.addClass('toast-close-button').attr('role', 'button');\n $toastElement.prepend($closeElement);\n }\n }\n\n function setProgressBar() {\n if (options.progressBar) {\n $progressElement.addClass('toast-progress');\n $toastElement.prepend($progressElement);\n }\n }\n\n function shouldExit(options, map) {\n if (options.preventDuplicates) {\n if (map.message === previousToast) {\n return true;\n } else {\n previousToast = map.message;\n }\n }\n return false;\n }\n\n function hideToast(override) {\n var method = override && options.closeMethod !== false ? options.closeMethod : options.hideMethod;\n var duration = override && options.closeDuration !== false ?\n options.closeDuration : options.hideDuration;\n var easing = override && options.closeEasing !== false ? options.closeEasing : options.hideEasing;\n if ($(':focus', $toastElement).length && !override) {\n return;\n }\n clearTimeout(progressBar.intervalId);\n return $toastElement[method]({\n duration: duration,\n easing: easing,\n complete: function () {\n removeToast($toastElement);\n if (options.onHidden && response.state !== 'hidden') {\n options.onHidden();\n }\n response.state = 'hidden';\n response.endTime = new Date();\n publish(response);\n }\n });\n }\n\n function delayedHideToast() {\n if (options.timeOut > 0 || options.extendedTimeOut > 0) {\n intervalId = setTimeout(hideToast, options.extendedTimeOut);\n progressBar.maxHideTime = parseFloat(options.extendedTimeOut);\n progressBar.hideEta = new Date().getTime() + progressBar.maxHideTime;\n }\n }\n\n function stickAround() {\n clearTimeout(intervalId);\n progressBar.hideEta = 0;\n $toastElement.stop(true, true)[options.showMethod](\n {duration: options.showDuration, easing: options.showEasing}\n );\n }\n\n function updateProgress() {\n var percentage = ((progressBar.hideEta - (new Date().getTime())) / progressBar.maxHideTime) * 100;\n $progressElement.width(percentage + '%');\n }\n }\n\n function getOptions() {\n return $.extend({}, getDefaults(), toastr.options);\n }\n\n function removeToast($toastElement) {\n if (!$container) { $container = getContainer(); }\n if ($toastElement.is(':visible')) {\n return;\n }\n $toastElement.remove();\n $toastElement = null;\n if ($container.children().length === 0) {\n $container.remove();\n previousToast = undefined;\n }\n }\n\n })();\n });\n}(typeof define === 'function' && define.amd ? define : function (deps, factory) {\n if (typeof module !== 'undefined' && module.exports) { //Node\n module.exports = factory(require('jquery'));\n } else {\n window.toastr = factory(window.jQuery);\n }\n}));\n"],"sourceRoot":"/source/"} \ No newline at end of file diff --git a/node_modules/toastr/build/toastr.min.css b/node_modules/toastr/build/toastr.min.css new file mode 100644 index 0000000..d109d13 --- /dev/null +++ b/node_modules/toastr/build/toastr.min.css @@ -0,0 +1 @@ +.toast-title{font-weight:700}.toast-message{-ms-word-wrap:break-word;word-wrap:break-word}.toast-message a,.toast-message label{color:#fff}.toast-message a:hover{color:#ccc;text-decoration:none}.toast-close-button{position:relative;right:-.3em;top:-.3em;float:right;font-size:20px;font-weight:700;color:#fff;-webkit-text-shadow:0 1px 0 #fff;text-shadow:0 1px 0 #fff;opacity:.8;-ms-filter:progid:DXImageTransform.Microsoft.Alpha(Opacity=80);filter:alpha(opacity=80)}.toast-close-button:focus,.toast-close-button:hover{color:#000;text-decoration:none;cursor:pointer;opacity:.4;-ms-filter:progid:DXImageTransform.Microsoft.Alpha(Opacity=40);filter:alpha(opacity=40)}button.toast-close-button{padding:0;cursor:pointer;background:0 0;border:0;-webkit-appearance:none}.toast-top-center{top:0;right:0;width:100%}.toast-bottom-center{bottom:0;right:0;width:100%}.toast-top-full-width{top:0;right:0;width:100%}.toast-bottom-full-width{bottom:0;right:0;width:100%}.toast-top-left{top:12px;left:12px}.toast-top-right{top:12px;right:12px}.toast-bottom-right{right:12px;bottom:12px}.toast-bottom-left{bottom:12px;left:12px}#toast-container{position:fixed;z-index:999999;pointer-events:none}#toast-container *{-moz-box-sizing:border-box;-webkit-box-sizing:border-box;box-sizing:border-box}#toast-container>div{position:relative;pointer-events:auto;overflow:hidden;margin:0 0 6px;padding:15px 15px 15px 50px;width:300px;-moz-border-radius:3px;-webkit-border-radius:3px;border-radius:3px;background-position:15px center;background-repeat:no-repeat;-moz-box-shadow:0 0 12px #999;-webkit-box-shadow:0 0 12px #999;box-shadow:0 0 12px #999;color:#fff;opacity:.8;-ms-filter:progid:DXImageTransform.Microsoft.Alpha(Opacity=80);filter:alpha(opacity=80)}#toast-container>:hover{-moz-box-shadow:0 0 12px #000;-webkit-box-shadow:0 0 12px #000;box-shadow:0 0 12px #000;opacity:1;-ms-filter:progid:DXImageTransform.Microsoft.Alpha(Opacity=100);filter:alpha(opacity=100);cursor:pointer}#toast-container>.toast-info{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGwSURBVEhLtZa9SgNBEMc9sUxxRcoUKSzSWIhXpFMhhYWFhaBg4yPYiWCXZxBLERsLRS3EQkEfwCKdjWJAwSKCgoKCcudv4O5YLrt7EzgXhiU3/4+b2ckmwVjJSpKkQ6wAi4gwhT+z3wRBcEz0yjSseUTrcRyfsHsXmD0AmbHOC9Ii8VImnuXBPglHpQ5wwSVM7sNnTG7Za4JwDdCjxyAiH3nyA2mtaTJufiDZ5dCaqlItILh1NHatfN5skvjx9Z38m69CgzuXmZgVrPIGE763Jx9qKsRozWYw6xOHdER+nn2KkO+Bb+UV5CBN6WC6QtBgbRVozrahAbmm6HtUsgtPC19tFdxXZYBOfkbmFJ1VaHA1VAHjd0pp70oTZzvR+EVrx2Ygfdsq6eu55BHYR8hlcki+n+kERUFG8BrA0BwjeAv2M8WLQBtcy+SD6fNsmnB3AlBLrgTtVW1c2QN4bVWLATaIS60J2Du5y1TiJgjSBvFVZgTmwCU+dAZFoPxGEEs8nyHC9Bwe2GvEJv2WXZb0vjdyFT4Cxk3e/kIqlOGoVLwwPevpYHT+00T+hWwXDf4AJAOUqWcDhbwAAAAASUVORK5CYII=)!important}#toast-container>.toast-error{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAHOSURBVEhLrZa/SgNBEMZzh0WKCClSCKaIYOED+AAKeQQLG8HWztLCImBrYadgIdY+gIKNYkBFSwu7CAoqCgkkoGBI/E28PdbLZmeDLgzZzcx83/zZ2SSXC1j9fr+I1Hq93g2yxH4iwM1vkoBWAdxCmpzTxfkN2RcyZNaHFIkSo10+8kgxkXIURV5HGxTmFuc75B2RfQkpxHG8aAgaAFa0tAHqYFfQ7Iwe2yhODk8+J4C7yAoRTWI3w/4klGRgR4lO7Rpn9+gvMyWp+uxFh8+H+ARlgN1nJuJuQAYvNkEnwGFck18Er4q3egEc/oO+mhLdKgRyhdNFiacC0rlOCbhNVz4H9FnAYgDBvU3QIioZlJFLJtsoHYRDfiZoUyIxqCtRpVlANq0EU4dApjrtgezPFad5S19Wgjkc0hNVnuF4HjVA6C7QrSIbylB+oZe3aHgBsqlNqKYH48jXyJKMuAbiyVJ8KzaB3eRc0pg9VwQ4niFryI68qiOi3AbjwdsfnAtk0bCjTLJKr6mrD9g8iq/S/B81hguOMlQTnVyG40wAcjnmgsCNESDrjme7wfftP4P7SP4N3CJZdvzoNyGq2c/HWOXJGsvVg+RA/k2MC/wN6I2YA2Pt8GkAAAAASUVORK5CYII=)!important}#toast-container>.toast-success{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAADsSURBVEhLY2AYBfQMgf///3P8+/evAIgvA/FsIF+BavYDDWMBGroaSMMBiE8VC7AZDrIFaMFnii3AZTjUgsUUWUDA8OdAH6iQbQEhw4HyGsPEcKBXBIC4ARhex4G4BsjmweU1soIFaGg/WtoFZRIZdEvIMhxkCCjXIVsATV6gFGACs4Rsw0EGgIIH3QJYJgHSARQZDrWAB+jawzgs+Q2UO49D7jnRSRGoEFRILcdmEMWGI0cm0JJ2QpYA1RDvcmzJEWhABhD/pqrL0S0CWuABKgnRki9lLseS7g2AlqwHWQSKH4oKLrILpRGhEQCw2LiRUIa4lwAAAABJRU5ErkJggg==)!important}#toast-container>.toast-warning{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGYSURBVEhL5ZSvTsNQFMbXZGICMYGYmJhAQIJAICYQPAACiSDB8AiICQQJT4CqQEwgJvYASAQCiZiYmJhAIBATCARJy+9rTsldd8sKu1M0+dLb057v6/lbq/2rK0mS/TRNj9cWNAKPYIJII7gIxCcQ51cvqID+GIEX8ASG4B1bK5gIZFeQfoJdEXOfgX4QAQg7kH2A65yQ87lyxb27sggkAzAuFhbbg1K2kgCkB1bVwyIR9m2L7PRPIhDUIXgGtyKw575yz3lTNs6X4JXnjV+LKM/m3MydnTbtOKIjtz6VhCBq4vSm3ncdrD2lk0VgUXSVKjVDJXJzijW1RQdsU7F77He8u68koNZTz8Oz5yGa6J3H3lZ0xYgXBK2QymlWWA+RWnYhskLBv2vmE+hBMCtbA7KX5drWyRT/2JsqZ2IvfB9Y4bWDNMFbJRFmC9E74SoS0CqulwjkC0+5bpcV1CZ8NMej4pjy0U+doDQsGyo1hzVJttIjhQ7GnBtRFN1UarUlH8F3xict+HY07rEzoUGPlWcjRFRr4/gChZgc3ZL2d8oAAAAASUVORK5CYII=)!important}#toast-container.toast-bottom-center>div,#toast-container.toast-top-center>div{width:300px;margin-left:auto;margin-right:auto}#toast-container.toast-bottom-full-width>div,#toast-container.toast-top-full-width>div{width:96%;margin-left:auto;margin-right:auto}.toast{background-color:#030303}.toast-success{background-color:#51a351}.toast-error{background-color:#bd362f}.toast-info{background-color:#2f96b4}.toast-warning{background-color:#f89406}.toast-progress{position:absolute;left:0;bottom:0;height:4px;background-color:#000;opacity:.4;-ms-filter:progid:DXImageTransform.Microsoft.Alpha(Opacity=40);filter:alpha(opacity=40)}@media all and (max-width:240px){#toast-container>div{padding:8px 8px 8px 50px;width:11em}#toast-container .toast-close-button{right:-.2em;top:-.2em}}@media all and (min-width:241px) and (max-width:480px){#toast-container>div{padding:8px 8px 8px 50px;width:18em}#toast-container .toast-close-button{right:-.2em;top:-.2em}}@media all and (min-width:481px) and (max-width:768px){#toast-container>div{padding:15px 15px 15px 50px;width:25em}} \ No newline at end of file diff --git a/node_modules/toastr/build/toastr.min.js b/node_modules/toastr/build/toastr.min.js new file mode 100644 index 0000000..227d9e1 --- /dev/null +++ b/node_modules/toastr/build/toastr.min.js @@ -0,0 +1,2 @@ +!function(e){e(["jquery"],function(e){return function(){function t(e,t,n){return g({type:O.error,iconClass:m().iconClasses.error,message:e,optionsOverride:n,title:t})}function n(t,n){return t||(t=m()),v=e("#"+t.containerId),v.length?v:(n&&(v=u(t)),v)}function i(e,t,n){return g({type:O.info,iconClass:m().iconClasses.info,message:e,optionsOverride:n,title:t})}function o(e){w=e}function s(e,t,n){return g({type:O.success,iconClass:m().iconClasses.success,message:e,optionsOverride:n,title:t})}function a(e,t,n){return g({type:O.warning,iconClass:m().iconClasses.warning,message:e,optionsOverride:n,title:t})}function r(e,t){var i=m();v||n(i),l(e,i,t)||d(i)}function c(t){var i=m();return v||n(i),t&&0===e(":focus",t).length?void h(t):void(v.children().length&&v.remove())}function d(t){for(var n=v.children(),i=n.length-1;i>=0;i--)l(e(n[i]),t)}function l(t,n,i){var o=i&&i.force?i.force:!1;return t&&(o||0===e(":focus",t).length)?(t[n.hideMethod]({duration:n.hideDuration,easing:n.hideEasing,complete:function(){h(t)}}),!0):!1}function u(t){return v=e("
").attr("id",t.containerId).addClass(t.positionClass).attr("aria-live","polite").attr("role","alert"),v.appendTo(e(t.target)),v}function p(){return{tapToDismiss:!0,toastClass:"toast",containerId:"toast-container",debug:!1,showMethod:"fadeIn",showDuration:300,showEasing:"swing",onShown:void 0,hideMethod:"fadeOut",hideDuration:1e3,hideEasing:"swing",onHidden:void 0,closeMethod:!1,closeDuration:!1,closeEasing:!1,extendedTimeOut:1e3,iconClasses:{error:"toast-error",info:"toast-info",success:"toast-success",warning:"toast-warning"},iconClass:"toast-info",positionClass:"toast-top-right",timeOut:5e3,titleClass:"toast-title",messageClass:"toast-message",escapeHtml:!1,target:"body",closeHtml:'',newestOnTop:!0,preventDuplicates:!1,progressBar:!1}}function f(e){w&&w(e)}function g(t){function i(e){return null==e&&(e=""),new String(e).replace(/&/g,"&").replace(/"/g,""").replace(/'/g,"'").replace(//g,">")}function o(){r(),d(),l(),u(),p(),c()}function s(){y.hover(b,O),!x.onclick&&x.tapToDismiss&&y.click(w),x.closeButton&&k&&k.click(function(e){e.stopPropagation?e.stopPropagation():void 0!==e.cancelBubble&&e.cancelBubble!==!0&&(e.cancelBubble=!0),w(!0)}),x.onclick&&y.click(function(e){x.onclick(e),w()})}function a(){y.hide(),y[x.showMethod]({duration:x.showDuration,easing:x.showEasing,complete:x.onShown}),x.timeOut>0&&(H=setTimeout(w,x.timeOut),q.maxHideTime=parseFloat(x.timeOut),q.hideEta=(new Date).getTime()+q.maxHideTime,x.progressBar&&(q.intervalId=setInterval(D,10)))}function r(){t.iconClass&&y.addClass(x.toastClass).addClass(E)}function c(){x.newestOnTop?v.prepend(y):v.append(y)}function d(){t.title&&(I.append(x.escapeHtml?i(t.title):t.title).addClass(x.titleClass),y.append(I))}function l(){t.message&&(M.append(x.escapeHtml?i(t.message):t.message).addClass(x.messageClass),y.append(M))}function u(){x.closeButton&&(k.addClass("toast-close-button").attr("role","button"),y.prepend(k))}function p(){x.progressBar&&(B.addClass("toast-progress"),y.prepend(B))}function g(e,t){if(e.preventDuplicates){if(t.message===C)return!0;C=t.message}return!1}function w(t){var n=t&&x.closeMethod!==!1?x.closeMethod:x.hideMethod,i=t&&x.closeDuration!==!1?x.closeDuration:x.hideDuration,o=t&&x.closeEasing!==!1?x.closeEasing:x.hideEasing;return!e(":focus",y).length||t?(clearTimeout(q.intervalId),y[n]({duration:i,easing:o,complete:function(){h(y),x.onHidden&&"hidden"!==j.state&&x.onHidden(),j.state="hidden",j.endTime=new Date,f(j)}})):void 0}function O(){(x.timeOut>0||x.extendedTimeOut>0)&&(H=setTimeout(w,x.extendedTimeOut),q.maxHideTime=parseFloat(x.extendedTimeOut),q.hideEta=(new Date).getTime()+q.maxHideTime)}function b(){clearTimeout(H),q.hideEta=0,y.stop(!0,!0)[x.showMethod]({duration:x.showDuration,easing:x.showEasing})}function D(){var e=(q.hideEta-(new Date).getTime())/q.maxHideTime*100;B.width(e+"%")}var x=m(),E=t.iconClass||x.iconClass;if("undefined"!=typeof t.optionsOverride&&(x=e.extend(x,t.optionsOverride),E=t.optionsOverride.iconClass||E),!g(x,t)){T++,v=n(x,!0);var H=null,y=e("
"),I=e("
"),M=e("
"),B=e("
"),k=e(x.closeHtml),q={intervalId:null,hideEta:null,maxHideTime:null},j={toastId:T,state:"visible",startTime:new Date,options:x,map:t};return o(),a(),s(),f(j),x.debug&&console&&console.log(j),y}}function m(){return e.extend({},p(),b.options)}function h(e){v||(v=n()),e.is(":visible")||(e.remove(),e=null,0===v.children().length&&(v.remove(),C=void 0))}var v,w,C,T=0,O={error:"error",info:"info",success:"success",warning:"warning"},b={clear:r,remove:c,error:t,getContainer:n,info:i,options:{},subscribe:o,success:s,version:"2.1.2",warning:a};return b}()})}("function"==typeof define&&define.amd?define:function(e,t){"undefined"!=typeof module&&module.exports?module.exports=t(require("jquery")):window.toastr=t(window.jQuery)}); +//# sourceMappingURL=toastr.js.map \ No newline at end of file diff --git a/node_modules/toastr/demo.html b/node_modules/toastr/demo.html new file mode 100644 index 0000000..50ebd55 --- /dev/null +++ b/node_modules/toastr/demo.html @@ -0,0 +1,325 @@ + + + + + toastr examples + + + + + + + +
+

toastr

+ +
+
+
+
+
+ + + + +
+
+
+
+ +
+
+ +
+
+ +
+
+ +
+
+ +
+
+ +
+
+ +
+
+
+ +
+
+
+ + + + + +
+
+
+
+ + + + + + + + + +
+
+
+ +
+
+
+ + + + + + + + + + + +
+
+
+ +
+
+
+ + + + + + + + + + + +
+
+
+
+ +
+ + + +
+ +
+

+        
+
+
+ + + + + + + + + diff --git a/node_modules/toastr/gulpfile.js b/node_modules/toastr/gulpfile.js new file mode 100644 index 0000000..db8eebc --- /dev/null +++ b/node_modules/toastr/gulpfile.js @@ -0,0 +1,200 @@ +/* jshint node:true, camelcase:false */ +var gulp = require('gulp'); +var del = require('del'); +var glob = require('glob'); +var karma = require('karma').server; +var merge = require('merge-stream'); +var plato = require('plato'); +var plug = require('gulp-load-plugins')(); + +var paths = { + js: './toastr.js', + less: './toastr.less', + report: './report', + build: './build' +}; + +var colors = plug.util.colors; +var log = plug.util.log; + +/** + * List the available gulp tasks + */ +gulp.task('help', plug.taskListing); + +/** + * Lint the code, create coverage report, and a visualizer + * @return {Stream} + */ +gulp.task('analyze', function() { + log('Analyzing source with JSHint, JSCS, and Plato'); + + var jshint = analyzejshint([paths.js]); + var jscs = analyzejscs([paths.js]); + + startPlatoVisualizer(); + + return merge(jshint, jscs); +}); + +/** + * Minify and bundle the app's JavaScript + * @return {Stream} + */ +gulp.task('js', function() { + log('Bundling, minifying, and copying the app\'s JavaScript'); + + return gulp + .src(paths.js) + .pipe(plug.sourcemaps.init()) + .pipe(plug.bytediff.start()) + .pipe(plug.uglify({})) + .pipe(plug.bytediff.stop(bytediffFormatter)) + .pipe(plug.sourcemaps.write('.')) + .pipe(plug.rename(function(path) { + if (path.extname === '.js') { + path.basename += '.min'; + } + })) + .pipe(gulp.dest(paths.build)); +}); + +/** + * Minify and bundle the CSS + * @return {Stream} + */ +gulp.task('css', function() { + log('Bundling, minifying, and copying the app\'s CSS'); + + return gulp.src(paths.less) + .pipe(plug.less()) +// .pipe(plug.autoprefixer('last 2 version', '> 5%')) + .pipe(gulp.dest(paths.build)) + .pipe(plug.bytediff.start()) + .pipe(plug.minifyCss({})) + .pipe(plug.bytediff.stop(bytediffFormatter)) + .pipe(plug.rename('toastr.min.css')) + .pipe(gulp.dest(paths.build)); +}); + +/** + * Build js and css + */ +gulp.task('default', ['js', 'css'], function() { + log('Analyze, Build CSS and JS'); +}); + +/** + * Remove all files from the build folder + * One way to run clean before all tasks is to run + * from the cmd line: gulp clean && gulp build + * @return {Stream} + */ +gulp.task('clean', function(cb) { + log('Cleaning: ' + plug.util.colors.blue(paths.report)); + log('Cleaning: ' + plug.util.colors.blue(paths.build)); + + var delPaths = [paths.build, paths.report]; + del(delPaths, cb); +}); + +/** + * Run specs once and exit + * To start servers and run midway specs as well: + * gulp test --startServers + * @return {Stream} + */ +gulp.task('test', function(done) { + startTests(true /*singleRun*/ , done); +}); + +//////////////// + +/** + * Execute JSHint on given source files + * @param {Array} sources + * @param {String} overrideRcFile + * @return {Stream} + */ +function analyzejshint(sources, overrideRcFile) { + var jshintrcFile = overrideRcFile || './.jshintrc'; + log('Running JSHint'); + return gulp + .src(sources) + .pipe(plug.jshint(jshintrcFile)) + .pipe(plug.jshint.reporter('jshint-stylish')); +} + +/** + * Execute JSCS on given source files + * @param {Array} sources + * @return {Stream} + */ +function analyzejscs(sources) { + log('Running JSCS'); + return gulp + .src(sources) + .pipe(plug.jscs('./.jscsrc')); +} + +/** + * Start Plato inspector and visualizer + */ +function startPlatoVisualizer() { + log('Running Plato'); + + var files = glob.sync('toastr.js'); + + var options = { + title: 'Plato Inspections Report' + }; + var outputDir = './report/plato'; + + plato.inspect(files, outputDir, options, platoCompleted); + + function platoCompleted(report) { + var overview = plato.getOverviewReport(report); + log(overview.summary); + } +} + +/** + * Start the tests using karma. + * @param {boolean} singleRun - True means run once and end (CI), or keep running (dev) + * @param {Function} done - Callback to fire when karma is done + * @return {undefined} + */ +function startTests(singleRun, done) { + karma.start({ + configFile: __dirname + '/karma.conf.js', + singleRun: !!singleRun + }, karmaCompleted); + + //////////////// + + function karmaCompleted() { + done(); + } +} + +/** + * Formatter for bytediff to display the size changes after processing + * @param {Object} data - byte data + * @return {String} Difference in bytes, formatted + */ +function bytediffFormatter(data) { + var difference = (data.savings > 0) ? ' smaller.' : ' larger.'; + return data.fileName + ' went from ' + + (data.startSize / 1000).toFixed(2) + ' kB to ' + (data.endSize / 1000).toFixed(2) + ' kB' + + ' and is ' + formatPercent(1 - data.percent, 2) + '%' + difference; +} + +/** + * Format a number as a percentage + * @param {Number} num Number to format as a percent + * @param {Number} precision Precision of the decimal + * @return {Number} Formatted perentage + */ +function formatPercent(num, precision) { + return (num * 100).toFixed(precision); +} diff --git a/node_modules/toastr/karma.conf.js b/node_modules/toastr/karma.conf.js new file mode 100644 index 0000000..f9ff8c4 --- /dev/null +++ b/node_modules/toastr/karma.conf.js @@ -0,0 +1,79 @@ +// Karma configuration +// Generated on Thu Sep 04 2014 07:41:43 GMT-0400 (EDT) + +module.exports = function(config) { + config.set({ + + // base path that will be used to resolve all patterns (eg. files, exclude) + basePath: '', + + + // frameworks to use + // available frameworks: https://npmjs.org/browse/keyword/karma-adapter + frameworks: ['qunit'], + +// plugins: ['karma-qunit', 'karma-coverage', 'phantomjs', 'karma-phantomjs-launcher'], + + + // list of files / patterns to load in the browser + files: [ +// 'http://code.jquery.com/jquery.js', + 'node_modules/jquery/dist/jquery.min.js', + 'build/toastr.css', + 'toastr.js', + 'node_modules/qunitjs/qunit/qunit.js', + 'tests/unit/qunit-helper.js', + //'tests/unit/x.js' + 'tests/unit/toastr-tests.js' + ], + + + // list of files to exclude + exclude: [ + ], + + + // preprocess matching files before serving them to the browser + // available preprocessors: https://npmjs.org/browse/keyword/karma-preprocessor + preprocessors: { + 'toastr.js': 'coverage' + }, + + + // test results reporter to use + // possible values: 'dots', 'progress' + // available reporters: https://npmjs.org/browse/keyword/karma-reporter + reporters: ['progress', 'coverage'], + + coverageReporter: { + type: 'lcov', + dir: 'tests/coverage' + }, + + // web server port + port: 9876, + + + // enable / disable colors in the output (reporters and logs) + colors: true, + + + // level of logging + // possible values: config.LOG_DISABLE || config.LOG_ERROR || config.LOG_WARN || config.LOG_INFO || config.LOG_DEBUG + logLevel: config.LOG_INFO, + + + // enable / disable watching file and executing tests whenever any file changes + autoWatch: false, + + + // start these browsers + // available browser launchers: https://npmjs.org/browse/keyword/karma-launcher + browsers: ['PhantomJS'], + + + // Continuous Integration mode + // if true, Karma captures browsers, runs the tests and exits + singleRun: true + }); +}; diff --git a/node_modules/toastr/nuget/content/content/toastr.css b/node_modules/toastr/nuget/content/content/toastr.css new file mode 100644 index 0000000..d86235a --- /dev/null +++ b/node_modules/toastr/nuget/content/content/toastr.css @@ -0,0 +1,180 @@ +/* + * Toastr + * Copyright 2012-2014 John Papa and Hans Fjällemark. + * All Rights Reserved. + * Use, reproduction, distribution, and modification of this code is subject to the terms and + * conditions of the MIT license, available at http://www.opensource.org/licenses/mit-license.php + * + * Author: John Papa and Hans Fjällemark + * Project: https://github.com/CodeSeven/toastr + */ +.toast-title { + font-weight: bold; +} +.toast-message { + -ms-word-wrap: break-word; + word-wrap: break-word; +} +.toast-message a, +.toast-message label { + color: #ffffff; +} +.toast-message a:hover { + color: #cccccc; + text-decoration: none; +} +.toast-close-button { + position: relative; + right: -0.3em; + top: -0.3em; + float: right; + font-size: 20px; + font-weight: bold; + color: #ffffff; + -webkit-text-shadow: 0 1px 0 #ffffff; + text-shadow: 0 1px 0 #ffffff; + opacity: 0.8; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=80); + filter: alpha(opacity=80); +} +.toast-close-button:hover, +.toast-close-button:focus { + color: #000000; + text-decoration: none; + cursor: pointer; + opacity: 0.4; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=40); + filter: alpha(opacity=40); +} +/*Additional properties for button version + iOS requires the button element instead of an anchor tag. + If you want the anchor version, it requires `href="#"`.*/ +button.toast-close-button { + padding: 0; + cursor: pointer; + background: transparent; + border: 0; + -webkit-appearance: none; +} +.toast-top-full-width { + top: 0; + right: 0; + width: 100%; +} +.toast-bottom-full-width { + bottom: 0; + right: 0; + width: 100%; +} +.toast-top-left { + top: 12px; + left: 12px; +} +.toast-top-right { + top: 12px; + right: 12px; +} +.toast-bottom-right { + right: 12px; + bottom: 12px; +} +.toast-bottom-left { + bottom: 12px; + left: 12px; +} +#toast-container { + position: fixed; + z-index: 999999; + /*overrides*/ + +} +#toast-container * { + -moz-box-sizing: border-box; + -webkit-box-sizing: border-box; + box-sizing: border-box; +} +#toast-container > div { + margin: 0 0 6px; + padding: 15px 15px 15px 50px; + width: 300px; + -moz-border-radius: 3px 3px 3px 3px; + -webkit-border-radius: 3px 3px 3px 3px; + border-radius: 3px 3px 3px 3px; + background-position: 15px center; + background-repeat: no-repeat; + -moz-box-shadow: 0 0 12px #999999; + -webkit-box-shadow: 0 0 12px #999999; + box-shadow: 0 0 12px #999999; + color: #ffffff; + opacity: 0.8; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=80); + filter: alpha(opacity=80); +} +#toast-container > :hover { + -moz-box-shadow: 0 0 12px #000000; + -webkit-box-shadow: 0 0 12px #000000; + box-shadow: 0 0 12px #000000; + opacity: 1; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=100); + filter: alpha(opacity=100); + cursor: pointer; +} +#toast-container > .toast-info { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGwSURBVEhLtZa9SgNBEMc9sUxxRcoUKSzSWIhXpFMhhYWFhaBg4yPYiWCXZxBLERsLRS3EQkEfwCKdjWJAwSKCgoKCcudv4O5YLrt7EzgXhiU3/4+b2ckmwVjJSpKkQ6wAi4gwhT+z3wRBcEz0yjSseUTrcRyfsHsXmD0AmbHOC9Ii8VImnuXBPglHpQ5wwSVM7sNnTG7Za4JwDdCjxyAiH3nyA2mtaTJufiDZ5dCaqlItILh1NHatfN5skvjx9Z38m69CgzuXmZgVrPIGE763Jx9qKsRozWYw6xOHdER+nn2KkO+Bb+UV5CBN6WC6QtBgbRVozrahAbmm6HtUsgtPC19tFdxXZYBOfkbmFJ1VaHA1VAHjd0pp70oTZzvR+EVrx2Ygfdsq6eu55BHYR8hlcki+n+kERUFG8BrA0BwjeAv2M8WLQBtcy+SD6fNsmnB3AlBLrgTtVW1c2QN4bVWLATaIS60J2Du5y1TiJgjSBvFVZgTmwCU+dAZFoPxGEEs8nyHC9Bwe2GvEJv2WXZb0vjdyFT4Cxk3e/kIqlOGoVLwwPevpYHT+00T+hWwXDf4AJAOUqWcDhbwAAAAASUVORK5CYII=") !important; +} +#toast-container > .toast-error { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAHOSURBVEhLrZa/SgNBEMZzh0WKCClSCKaIYOED+AAKeQQLG8HWztLCImBrYadgIdY+gIKNYkBFSwu7CAoqCgkkoGBI/E28PdbLZmeDLgzZzcx83/zZ2SSXC1j9fr+I1Hq93g2yxH4iwM1vkoBWAdxCmpzTxfkN2RcyZNaHFIkSo10+8kgxkXIURV5HGxTmFuc75B2RfQkpxHG8aAgaAFa0tAHqYFfQ7Iwe2yhODk8+J4C7yAoRTWI3w/4klGRgR4lO7Rpn9+gvMyWp+uxFh8+H+ARlgN1nJuJuQAYvNkEnwGFck18Er4q3egEc/oO+mhLdKgRyhdNFiacC0rlOCbhNVz4H9FnAYgDBvU3QIioZlJFLJtsoHYRDfiZoUyIxqCtRpVlANq0EU4dApjrtgezPFad5S19Wgjkc0hNVnuF4HjVA6C7QrSIbylB+oZe3aHgBsqlNqKYH48jXyJKMuAbiyVJ8KzaB3eRc0pg9VwQ4niFryI68qiOi3AbjwdsfnAtk0bCjTLJKr6mrD9g8iq/S/B81hguOMlQTnVyG40wAcjnmgsCNESDrjme7wfftP4P7SP4N3CJZdvzoNyGq2c/HWOXJGsvVg+RA/k2MC/wN6I2YA2Pt8GkAAAAASUVORK5CYII=") !important; +} +#toast-container > .toast-success { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAADsSURBVEhLY2AYBfQMgf///3P8+/evAIgvA/FsIF+BavYDDWMBGroaSMMBiE8VC7AZDrIFaMFnii3AZTjUgsUUWUDA8OdAH6iQbQEhw4HyGsPEcKBXBIC4ARhex4G4BsjmweU1soIFaGg/WtoFZRIZdEvIMhxkCCjXIVsATV6gFGACs4Rsw0EGgIIH3QJYJgHSARQZDrWAB+jawzgs+Q2UO49D7jnRSRGoEFRILcdmEMWGI0cm0JJ2QpYA1RDvcmzJEWhABhD/pqrL0S0CWuABKgnRki9lLseS7g2AlqwHWQSKH4oKLrILpRGhEQCw2LiRUIa4lwAAAABJRU5ErkJggg==") !important; +} +#toast-container > .toast-warning { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGYSURBVEhL5ZSvTsNQFMbXZGICMYGYmJhAQIJAICYQPAACiSDB8AiICQQJT4CqQEwgJvYASAQCiZiYmJhAIBATCARJy+9rTsldd8sKu1M0+dLb057v6/lbq/2rK0mS/TRNj9cWNAKPYIJII7gIxCcQ51cvqID+GIEX8ASG4B1bK5gIZFeQfoJdEXOfgX4QAQg7kH2A65yQ87lyxb27sggkAzAuFhbbg1K2kgCkB1bVwyIR9m2L7PRPIhDUIXgGtyKw575yz3lTNs6X4JXnjV+LKM/m3MydnTbtOKIjtz6VhCBq4vSm3ncdrD2lk0VgUXSVKjVDJXJzijW1RQdsU7F77He8u68koNZTz8Oz5yGa6J3H3lZ0xYgXBK2QymlWWA+RWnYhskLBv2vmE+hBMCtbA7KX5drWyRT/2JsqZ2IvfB9Y4bWDNMFbJRFmC9E74SoS0CqulwjkC0+5bpcV1CZ8NMej4pjy0U+doDQsGyo1hzVJttIjhQ7GnBtRFN1UarUlH8F3xict+HY07rEzoUGPlWcjRFRr4/gChZgc3ZL2d8oAAAAASUVORK5CYII=") !important; +} +#toast-container.toast-top-full-width > div, +#toast-container.toast-bottom-full-width > div { + width: 96%; + margin: auto; +} +.toast { + background-color: #030303; +} +.toast-success { + background-color: #51a351; +} +.toast-error { + background-color: #bd362f; +} +.toast-info { + background-color: #2f96b4; +} +.toast-warning { + background-color: #f89406; +} +/*Responsive Design*/ +@media all and (max-width: 240px) { + #toast-container > div { + padding: 8px 8px 8px 50px; + width: 11em; + } + #toast-container .toast-close-button { + right: -0.2em; + top: -0.2em; + } +} +@media all and (min-width: 241px) and (max-width: 480px) { + #toast-container > div { + padding: 8px 8px 8px 50px; + width: 18em; + } + #toast-container .toast-close-button { + right: -0.2em; + top: -0.2em; + } +} +@media all and (min-width: 481px) and (max-width: 768px) { + #toast-container > div { + padding: 15px 15px 15px 50px; + width: 25em; + } +} diff --git a/node_modules/toastr/nuget/content/content/toastr.less b/node_modules/toastr/nuget/content/content/toastr.less new file mode 100644 index 0000000..146fabe --- /dev/null +++ b/node_modules/toastr/nuget/content/content/toastr.less @@ -0,0 +1,232 @@ +// Mix-ins +.borderRadius(@radius) { + -moz-border-radius: @radius; + -webkit-border-radius: @radius; + border-radius: @radius; +} + +.boxShadow(@boxShadow) { + -moz-box-shadow: @boxShadow; + -webkit-box-shadow: @boxShadow; + box-shadow: @boxShadow; +} + +.opacity(@opacity) { + @opacityPercent: @opacity * 100; + opacity: @opacity; + -ms-filter: ~"progid:DXImageTransform.Microsoft.Alpha(Opacity=@{opacityPercent})"; + filter: ~"alpha(opacity=@{opacityPercent})"; +} + +.wordWrap(@wordWrap: break-word) { + -ms-word-wrap: @wordWrap; + word-wrap: @wordWrap; +} + +// Variables +@black: #000000; +@grey: #999999; +@light-grey: #CCCCCC; +@white: #FFFFFF; +@near-black: #030303; +@green: #51A351; +@red: #BD362F; +@blue: #2F96B4; +@orange: #F89406; + +// Styles +.toast-title { + font-weight: bold; +} + +.toast-message { + .wordWrap(); + + a, + label { + color: @white; + } + + a:hover { + color: @light-grey; + text-decoration: none; + } +} + +.toast-close-button { + position: relative; + right: -0.3em; + top: -0.3em; + float: right; + font-size: 20px; + font-weight: bold; + color: @white; + -webkit-text-shadow: 0 1px 0 rgba(255,255,255,1); + text-shadow: 0 1px 0 rgba(255,255,255,1); + .opacity(0.8); + + &:hover, + &:focus { + color: @black; + text-decoration: none; + cursor: pointer; + .opacity(0.4); + } +} + +/*Additional properties for button version + iOS requires the button element instead of an anchor tag. + If you want the anchor version, it requires `href="#"`.*/ +button.toast-close-button { + padding: 0; + cursor: pointer; + background: transparent; + border: 0; + -webkit-appearance: none; +} + +//#endregion + +.toast-top-full-width { + top: 0; + right: 0; + width: 100%; +} + +.toast-bottom-full-width { + bottom: 0; + right: 0; + width: 100%; +} + +.toast-top-left { + top: 12px; + left: 12px; +} + +.toast-top-right { + top: 12px; + right: 12px; +} + +.toast-bottom-right { + right: 12px; + bottom: 12px; +} + +.toast-bottom-left { + bottom: 12px; + left: 12px; +} + +#toast-container { + position: fixed; + z-index: 999999; + + * { + -moz-box-sizing: border-box; + -webkit-box-sizing: border-box; + box-sizing: border-box; + } + + > div { + margin: 0 0 6px; + padding: 15px 15px 15px 50px; + width: 300px; + .borderRadius(3px 3px 3px 3px); + background-position: 15px center; + background-repeat: no-repeat; + .boxShadow(0 0 12px @grey); + color: @white; + .opacity(0.8); + } + + > :hover { + .boxShadow(0 0 12px @black); + .opacity(1); + cursor: pointer; + } + + > .toast-info { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGwSURBVEhLtZa9SgNBEMc9sUxxRcoUKSzSWIhXpFMhhYWFhaBg4yPYiWCXZxBLERsLRS3EQkEfwCKdjWJAwSKCgoKCcudv4O5YLrt7EzgXhiU3/4+b2ckmwVjJSpKkQ6wAi4gwhT+z3wRBcEz0yjSseUTrcRyfsHsXmD0AmbHOC9Ii8VImnuXBPglHpQ5wwSVM7sNnTG7Za4JwDdCjxyAiH3nyA2mtaTJufiDZ5dCaqlItILh1NHatfN5skvjx9Z38m69CgzuXmZgVrPIGE763Jx9qKsRozWYw6xOHdER+nn2KkO+Bb+UV5CBN6WC6QtBgbRVozrahAbmm6HtUsgtPC19tFdxXZYBOfkbmFJ1VaHA1VAHjd0pp70oTZzvR+EVrx2Ygfdsq6eu55BHYR8hlcki+n+kERUFG8BrA0BwjeAv2M8WLQBtcy+SD6fNsmnB3AlBLrgTtVW1c2QN4bVWLATaIS60J2Du5y1TiJgjSBvFVZgTmwCU+dAZFoPxGEEs8nyHC9Bwe2GvEJv2WXZb0vjdyFT4Cxk3e/kIqlOGoVLwwPevpYHT+00T+hWwXDf4AJAOUqWcDhbwAAAAASUVORK5CYII=") !important; + } + + > .toast-error { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAHOSURBVEhLrZa/SgNBEMZzh0WKCClSCKaIYOED+AAKeQQLG8HWztLCImBrYadgIdY+gIKNYkBFSwu7CAoqCgkkoGBI/E28PdbLZmeDLgzZzcx83/zZ2SSXC1j9fr+I1Hq93g2yxH4iwM1vkoBWAdxCmpzTxfkN2RcyZNaHFIkSo10+8kgxkXIURV5HGxTmFuc75B2RfQkpxHG8aAgaAFa0tAHqYFfQ7Iwe2yhODk8+J4C7yAoRTWI3w/4klGRgR4lO7Rpn9+gvMyWp+uxFh8+H+ARlgN1nJuJuQAYvNkEnwGFck18Er4q3egEc/oO+mhLdKgRyhdNFiacC0rlOCbhNVz4H9FnAYgDBvU3QIioZlJFLJtsoHYRDfiZoUyIxqCtRpVlANq0EU4dApjrtgezPFad5S19Wgjkc0hNVnuF4HjVA6C7QrSIbylB+oZe3aHgBsqlNqKYH48jXyJKMuAbiyVJ8KzaB3eRc0pg9VwQ4niFryI68qiOi3AbjwdsfnAtk0bCjTLJKr6mrD9g8iq/S/B81hguOMlQTnVyG40wAcjnmgsCNESDrjme7wfftP4P7SP4N3CJZdvzoNyGq2c/HWOXJGsvVg+RA/k2MC/wN6I2YA2Pt8GkAAAAASUVORK5CYII=") !important; + } + + > .toast-success { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAADsSURBVEhLY2AYBfQMgf///3P8+/evAIgvA/FsIF+BavYDDWMBGroaSMMBiE8VC7AZDrIFaMFnii3AZTjUgsUUWUDA8OdAH6iQbQEhw4HyGsPEcKBXBIC4ARhex4G4BsjmweU1soIFaGg/WtoFZRIZdEvIMhxkCCjXIVsATV6gFGACs4Rsw0EGgIIH3QJYJgHSARQZDrWAB+jawzgs+Q2UO49D7jnRSRGoEFRILcdmEMWGI0cm0JJ2QpYA1RDvcmzJEWhABhD/pqrL0S0CWuABKgnRki9lLseS7g2AlqwHWQSKH4oKLrILpRGhEQCw2LiRUIa4lwAAAABJRU5ErkJggg==") !important; + } + + > .toast-warning { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGYSURBVEhL5ZSvTsNQFMbXZGICMYGYmJhAQIJAICYQPAACiSDB8AiICQQJT4CqQEwgJvYASAQCiZiYmJhAIBATCARJy+9rTsldd8sKu1M0+dLb057v6/lbq/2rK0mS/TRNj9cWNAKPYIJII7gIxCcQ51cvqID+GIEX8ASG4B1bK5gIZFeQfoJdEXOfgX4QAQg7kH2A65yQ87lyxb27sggkAzAuFhbbg1K2kgCkB1bVwyIR9m2L7PRPIhDUIXgGtyKw575yz3lTNs6X4JXnjV+LKM/m3MydnTbtOKIjtz6VhCBq4vSm3ncdrD2lk0VgUXSVKjVDJXJzijW1RQdsU7F77He8u68koNZTz8Oz5yGa6J3H3lZ0xYgXBK2QymlWWA+RWnYhskLBv2vmE+hBMCtbA7KX5drWyRT/2JsqZ2IvfB9Y4bWDNMFbJRFmC9E74SoS0CqulwjkC0+5bpcV1CZ8NMej4pjy0U+doDQsGyo1hzVJttIjhQ7GnBtRFN1UarUlH8F3xict+HY07rEzoUGPlWcjRFRr4/gChZgc3ZL2d8oAAAAASUVORK5CYII=") !important; + } + + /*overrides*/ + &.toast-top-full-width > div, + &.toast-bottom-full-width > div { + width: 96%; + margin: auto; + } +} + +.toast { + background-color: @near-black; +} + +.toast-success { + background-color: @green; +} + +.toast-error { + background-color: @red; +} + +.toast-info { + background-color: @blue; +} + +.toast-warning { + background-color: @orange; +} + +/*Responsive Design*/ + +@media all and (max-width: 240px) { + #toast-container { + + > div { + padding: 8px 8px 8px 50px; + width: 11em; + } + + & .toast-close-button { + right: -0.2em; + top: -0.2em; + } + } +} + +@media all and (min-width: 241px) and (max-width: 480px) { + #toast-container { + > div { + padding: 8px 8px 8px 50px; + width: 18em; + } + + & .toast-close-button { + right: -0.2em; + top: -0.2em; + } + } +} + +@media all and (min-width: 481px) and (max-width: 768px) { + #toast-container { + > div { + padding: 15px 15px 15px 50px; + width: 25em; + } + } +} \ No newline at end of file diff --git a/node_modules/toastr/nuget/content/content/toastr.min.css b/node_modules/toastr/nuget/content/content/toastr.min.css new file mode 100644 index 0000000..40975cb --- /dev/null +++ b/node_modules/toastr/nuget/content/content/toastr.min.css @@ -0,0 +1 @@ +.toast-title{font-weight:bold}.toast-message{-ms-word-wrap:break-word;word-wrap:break-word}.toast-message a,.toast-message label{color:#fff}.toast-message a:hover{color:#ccc;text-decoration:none}.toast-close-button{position:relative;right:-0.3em;top:-0.3em;float:right;font-size:20px;font-weight:bold;color:#fff;-webkit-text-shadow:0 1px 0 #fff;text-shadow:0 1px 0 #fff;opacity:.8;-ms-filter:alpha(opacity=80);filter:alpha(opacity=80)}.toast-close-button:hover,.toast-close-button:focus{color:#000;text-decoration:none;cursor:pointer;opacity:.4;-ms-filter:alpha(opacity=40);filter:alpha(opacity=40)}button.toast-close-button{padding:0;cursor:pointer;background:transparent;border:0;-webkit-appearance:none}.toast-top-full-width{top:0;right:0;width:100%}.toast-bottom-full-width{bottom:0;right:0;width:100%}.toast-top-left{top:12px;left:12px}.toast-top-right{top:12px;right:12px}.toast-bottom-right{right:12px;bottom:12px}.toast-bottom-left{bottom:12px;left:12px}#toast-container{position:fixed;z-index:999999}#toast-container *{-moz-box-sizing:border-box;-webkit-box-sizing:border-box;box-sizing:border-box}#toast-container>div{margin:0 0 6px;padding:15px 15px 15px 50px;width:300px;-moz-border-radius:3px 3px 3px 3px;-webkit-border-radius:3px 3px 3px 3px;border-radius:3px 3px 3px 3px;background-position:15px center;background-repeat:no-repeat;-moz-box-shadow:0 0 12px #999;-webkit-box-shadow:0 0 12px #999;box-shadow:0 0 12px #999;color:#fff;opacity:.8;-ms-filter:alpha(opacity=80);filter:alpha(opacity=80)}#toast-container>:hover{-moz-box-shadow:0 0 12px #000;-webkit-box-shadow:0 0 12px #000;box-shadow:0 0 12px #000;opacity:1;-ms-filter:alpha(opacity=100);filter:alpha(opacity=100);cursor:pointer}#toast-container>.toast-info{background-image:url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGwSURBVEhLtZa9SgNBEMc9sUxxRcoUKSzSWIhXpFMhhYWFhaBg4yPYiWCXZxBLERsLRS3EQkEfwCKdjWJAwSKCgoKCcudv4O5YLrt7EzgXhiU3/4+b2ckmwVjJSpKkQ6wAi4gwhT+z3wRBcEz0yjSseUTrcRyfsHsXmD0AmbHOC9Ii8VImnuXBPglHpQ5wwSVM7sNnTG7Za4JwDdCjxyAiH3nyA2mtaTJufiDZ5dCaqlItILh1NHatfN5skvjx9Z38m69CgzuXmZgVrPIGE763Jx9qKsRozWYw6xOHdER+nn2KkO+Bb+UV5CBN6WC6QtBgbRVozrahAbmm6HtUsgtPC19tFdxXZYBOfkbmFJ1VaHA1VAHjd0pp70oTZzvR+EVrx2Ygfdsq6eu55BHYR8hlcki+n+kERUFG8BrA0BwjeAv2M8WLQBtcy+SD6fNsmnB3AlBLrgTtVW1c2QN4bVWLATaIS60J2Du5y1TiJgjSBvFVZgTmwCU+dAZFoPxGEEs8nyHC9Bwe2GvEJv2WXZb0vjdyFT4Cxk3e/kIqlOGoVLwwPevpYHT+00T+hWwXDf4AJAOUqWcDhbwAAAAASUVORK5CYII=")!important}#toast-container>.toast-error{background-image:url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAHOSURBVEhLrZa/SgNBEMZzh0WKCClSCKaIYOED+AAKeQQLG8HWztLCImBrYadgIdY+gIKNYkBFSwu7CAoqCgkkoGBI/E28PdbLZmeDLgzZzcx83/zZ2SSXC1j9fr+I1Hq93g2yxH4iwM1vkoBWAdxCmpzTxfkN2RcyZNaHFIkSo10+8kgxkXIURV5HGxTmFuc75B2RfQkpxHG8aAgaAFa0tAHqYFfQ7Iwe2yhODk8+J4C7yAoRTWI3w/4klGRgR4lO7Rpn9+gvMyWp+uxFh8+H+ARlgN1nJuJuQAYvNkEnwGFck18Er4q3egEc/oO+mhLdKgRyhdNFiacC0rlOCbhNVz4H9FnAYgDBvU3QIioZlJFLJtsoHYRDfiZoUyIxqCtRpVlANq0EU4dApjrtgezPFad5S19Wgjkc0hNVnuF4HjVA6C7QrSIbylB+oZe3aHgBsqlNqKYH48jXyJKMuAbiyVJ8KzaB3eRc0pg9VwQ4niFryI68qiOi3AbjwdsfnAtk0bCjTLJKr6mrD9g8iq/S/B81hguOMlQTnVyG40wAcjnmgsCNESDrjme7wfftP4P7SP4N3CJZdvzoNyGq2c/HWOXJGsvVg+RA/k2MC/wN6I2YA2Pt8GkAAAAASUVORK5CYII=")!important}#toast-container>.toast-success{background-image:url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAADsSURBVEhLY2AYBfQMgf///3P8+/evAIgvA/FsIF+BavYDDWMBGroaSMMBiE8VC7AZDrIFaMFnii3AZTjUgsUUWUDA8OdAH6iQbQEhw4HyGsPEcKBXBIC4ARhex4G4BsjmweU1soIFaGg/WtoFZRIZdEvIMhxkCCjXIVsATV6gFGACs4Rsw0EGgIIH3QJYJgHSARQZDrWAB+jawzgs+Q2UO49D7jnRSRGoEFRILcdmEMWGI0cm0JJ2QpYA1RDvcmzJEWhABhD/pqrL0S0CWuABKgnRki9lLseS7g2AlqwHWQSKH4oKLrILpRGhEQCw2LiRUIa4lwAAAABJRU5ErkJggg==")!important}#toast-container>.toast-warning{background-image:url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGYSURBVEhL5ZSvTsNQFMbXZGICMYGYmJhAQIJAICYQPAACiSDB8AiICQQJT4CqQEwgJvYASAQCiZiYmJhAIBATCARJy+9rTsldd8sKu1M0+dLb057v6/lbq/2rK0mS/TRNj9cWNAKPYIJII7gIxCcQ51cvqID+GIEX8ASG4B1bK5gIZFeQfoJdEXOfgX4QAQg7kH2A65yQ87lyxb27sggkAzAuFhbbg1K2kgCkB1bVwyIR9m2L7PRPIhDUIXgGtyKw575yz3lTNs6X4JXnjV+LKM/m3MydnTbtOKIjtz6VhCBq4vSm3ncdrD2lk0VgUXSVKjVDJXJzijW1RQdsU7F77He8u68koNZTz8Oz5yGa6J3H3lZ0xYgXBK2QymlWWA+RWnYhskLBv2vmE+hBMCtbA7KX5drWyRT/2JsqZ2IvfB9Y4bWDNMFbJRFmC9E74SoS0CqulwjkC0+5bpcV1CZ8NMej4pjy0U+doDQsGyo1hzVJttIjhQ7GnBtRFN1UarUlH8F3xict+HY07rEzoUGPlWcjRFRr4/gChZgc3ZL2d8oAAAAASUVORK5CYII=")!important}#toast-container.toast-top-full-width>div,#toast-container.toast-bottom-full-width>div{width:96%;margin:auto}.toast{background-color:#030303}.toast-success{background-color:#51a351}.toast-error{background-color:#bd362f}.toast-info{background-color:#2f96b4}.toast-warning{background-color:#f89406}@media all and (max-width:240px){#toast-container>div{padding:8px 8px 8px 50px;width:11em}#toast-container .toast-close-button{right:-0.2em;top:-0.2em}}@media all and (min-width:241px) and (max-width:480px){#toast-container>div{padding:8px 8px 8px 50px;width:18em}#toast-container .toast-close-button{right:-0.2em;top:-0.2em}}@media all and (min-width:481px) and (max-width:768px){#toast-container>div{padding:15px 15px 15px 50px;width:25em}} \ No newline at end of file diff --git a/node_modules/toastr/nuget/content/content/toastr.scss b/node_modules/toastr/nuget/content/content/toastr.scss new file mode 100644 index 0000000..71f017b --- /dev/null +++ b/node_modules/toastr/nuget/content/content/toastr.scss @@ -0,0 +1,183 @@ +/* + * Toastr + * Version 2.0.1 + * Copyright 2012 John Papa and Hans Fjällemark. + * All Rights Reserved. + * Use, reproduction, distribution, and modification of this code is subject to the terms and + * conditions of the MIT license, available at http://www.opensource.org/licenses/mit-license.php + * + * Author: John Papa and Hans Fjällemark + * Project: https://github.com/CodeSeven/toastr + */ +.toast-title { + font-weight: bold; +} +.toast-message { + -ms-word-wrap: break-word; + word-wrap: break-word; +} +.toast-message a, +.toast-message label { + color: #ffffff; +} +.toast-message a:hover { + color: #cccccc; + text-decoration: none; +} + +.toast-close-button { + position: relative; + right: -0.3em; + top: -0.3em; + float: right; + font-size: 20px; + font-weight: bold; + color: #ffffff; + -webkit-text-shadow: 0 1px 0 #ffffff; + text-shadow: 0 1px 0 #ffffff; + opacity: 0.8; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=80); + filter: alpha(opacity=80); +} +.toast-close-button:hover, +.toast-close-button:focus { + color: #000000; + text-decoration: none; + cursor: pointer; + opacity: 0.4; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=40); + filter: alpha(opacity=40); +} + +/*Additional properties for button version + iOS requires the button element instead of an anchor tag. + If you want the anchor version, it requires `href="#"`.*/ +button.toast-close-button { + padding: 0; + cursor: pointer; + background: transparent; + border: 0; + -webkit-appearance: none; +} +.toast-top-full-width { + top: 0; + right: 0; + width: 100%; +} +.toast-bottom-full-width { + bottom: 0; + right: 0; + width: 100%; +} +.toast-top-left { + top: 12px; + left: 12px; +} +.toast-top-right { + top: 12px; + right: 12px; +} +.toast-bottom-right { + right: 12px; + bottom: 12px; +} +.toast-bottom-left { + bottom: 12px; + left: 12px; +} +#toast-container { + position: fixed; + z-index: 999999; + /*overrides*/ + +} +#toast-container * { + -moz-box-sizing: border-box; + -webkit-box-sizing: border-box; + box-sizing: border-box; +} +#toast-container > div { + margin: 0 0 6px; + padding: 15px 15px 15px 50px; + width: 300px; + -moz-border-radius: 3px 3px 3px 3px; + -webkit-border-radius: 3px 3px 3px 3px; + border-radius: 3px 3px 3px 3px; + background-position: 15px center; + background-repeat: no-repeat; + -moz-box-shadow: 0 0 12px #999999; + -webkit-box-shadow: 0 0 12px #999999; + box-shadow: 0 0 12px #999999; + color: #ffffff; + opacity: 0.8; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=80); + filter: alpha(opacity=80); +} +#toast-container > :hover { + -moz-box-shadow: 0 0 12px #000000; + -webkit-box-shadow: 0 0 12px #000000; + box-shadow: 0 0 12px #000000; + opacity: 1; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=100); + filter: alpha(opacity=100); + cursor: pointer; +} +#toast-container > .toast-info { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGwSURBVEhLtZa9SgNBEMc9sUxxRcoUKSzSWIhXpFMhhYWFhaBg4yPYiWCXZxBLERsLRS3EQkEfwCKdjWJAwSKCgoKCcudv4O5YLrt7EzgXhiU3/4+b2ckmwVjJSpKkQ6wAi4gwhT+z3wRBcEz0yjSseUTrcRyfsHsXmD0AmbHOC9Ii8VImnuXBPglHpQ5wwSVM7sNnTG7Za4JwDdCjxyAiH3nyA2mtaTJufiDZ5dCaqlItILh1NHatfN5skvjx9Z38m69CgzuXmZgVrPIGE763Jx9qKsRozWYw6xOHdER+nn2KkO+Bb+UV5CBN6WC6QtBgbRVozrahAbmm6HtUsgtPC19tFdxXZYBOfkbmFJ1VaHA1VAHjd0pp70oTZzvR+EVrx2Ygfdsq6eu55BHYR8hlcki+n+kERUFG8BrA0BwjeAv2M8WLQBtcy+SD6fNsmnB3AlBLrgTtVW1c2QN4bVWLATaIS60J2Du5y1TiJgjSBvFVZgTmwCU+dAZFoPxGEEs8nyHC9Bwe2GvEJv2WXZb0vjdyFT4Cxk3e/kIqlOGoVLwwPevpYHT+00T+hWwXDf4AJAOUqWcDhbwAAAAASUVORK5CYII=") !important; +} +#toast-container > .toast-error { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAHOSURBVEhLrZa/SgNBEMZzh0WKCClSCKaIYOED+AAKeQQLG8HWztLCImBrYadgIdY+gIKNYkBFSwu7CAoqCgkkoGBI/E28PdbLZmeDLgzZzcx83/zZ2SSXC1j9fr+I1Hq93g2yxH4iwM1vkoBWAdxCmpzTxfkN2RcyZNaHFIkSo10+8kgxkXIURV5HGxTmFuc75B2RfQkpxHG8aAgaAFa0tAHqYFfQ7Iwe2yhODk8+J4C7yAoRTWI3w/4klGRgR4lO7Rpn9+gvMyWp+uxFh8+H+ARlgN1nJuJuQAYvNkEnwGFck18Er4q3egEc/oO+mhLdKgRyhdNFiacC0rlOCbhNVz4H9FnAYgDBvU3QIioZlJFLJtsoHYRDfiZoUyIxqCtRpVlANq0EU4dApjrtgezPFad5S19Wgjkc0hNVnuF4HjVA6C7QrSIbylB+oZe3aHgBsqlNqKYH48jXyJKMuAbiyVJ8KzaB3eRc0pg9VwQ4niFryI68qiOi3AbjwdsfnAtk0bCjTLJKr6mrD9g8iq/S/B81hguOMlQTnVyG40wAcjnmgsCNESDrjme7wfftP4P7SP4N3CJZdvzoNyGq2c/HWOXJGsvVg+RA/k2MC/wN6I2YA2Pt8GkAAAAASUVORK5CYII=") !important; +} +#toast-container > .toast-success { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAADsSURBVEhLY2AYBfQMgf///3P8+/evAIgvA/FsIF+BavYDDWMBGroaSMMBiE8VC7AZDrIFaMFnii3AZTjUgsUUWUDA8OdAH6iQbQEhw4HyGsPEcKBXBIC4ARhex4G4BsjmweU1soIFaGg/WtoFZRIZdEvIMhxkCCjXIVsATV6gFGACs4Rsw0EGgIIH3QJYJgHSARQZDrWAB+jawzgs+Q2UO49D7jnRSRGoEFRILcdmEMWGI0cm0JJ2QpYA1RDvcmzJEWhABhD/pqrL0S0CWuABKgnRki9lLseS7g2AlqwHWQSKH4oKLrILpRGhEQCw2LiRUIa4lwAAAABJRU5ErkJggg==") !important; +} +#toast-container > .toast-warning { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGYSURBVEhL5ZSvTsNQFMbXZGICMYGYmJhAQIJAICYQPAACiSDB8AiICQQJT4CqQEwgJvYASAQCiZiYmJhAIBATCARJy+9rTsldd8sKu1M0+dLb057v6/lbq/2rK0mS/TRNj9cWNAKPYIJII7gIxCcQ51cvqID+GIEX8ASG4B1bK5gIZFeQfoJdEXOfgX4QAQg7kH2A65yQ87lyxb27sggkAzAuFhbbg1K2kgCkB1bVwyIR9m2L7PRPIhDUIXgGtyKw575yz3lTNs6X4JXnjV+LKM/m3MydnTbtOKIjtz6VhCBq4vSm3ncdrD2lk0VgUXSVKjVDJXJzijW1RQdsU7F77He8u68koNZTz8Oz5yGa6J3H3lZ0xYgXBK2QymlWWA+RWnYhskLBv2vmE+hBMCtbA7KX5drWyRT/2JsqZ2IvfB9Y4bWDNMFbJRFmC9E74SoS0CqulwjkC0+5bpcV1CZ8NMej4pjy0U+doDQsGyo1hzVJttIjhQ7GnBtRFN1UarUlH8F3xict+HY07rEzoUGPlWcjRFRr4/gChZgc3ZL2d8oAAAAASUVORK5CYII=") !important; +} +#toast-container.toast-top-full-width > div, +#toast-container.toast-bottom-full-width > div { + width: 96%; + margin: auto; +} +.toast { + background-color: #030303; +} +.toast-success { + background-color: #51a351; +} +.toast-error { + background-color: #bd362f; +} +.toast-info { + background-color: #2f96b4; +} +.toast-warning { + background-color: #f89406; +} +/*Responsive Design*/ +@media all and (max-width: 239px) { + #toast-container > div { + padding: 8px 8px 8px 50px; + width: 11em; + } + #toast-container .toast-close-button { + right: -0.2em; + top: -0.2em; + } +} +@media all and (min-width: 240px) and (max-width: 479px) { + #toast-container > div { + padding: 8px 8px 8px 50px; + width: 18em; + } + #toast-container .toast-close-button { + right: -0.2em; + top: -0.2em; + } +} +@media all and (min-width: 480px) and (max-width: 767px) { + #toast-container > div { + padding: 15px 15px 15px 50px; + width: 25em; + } +} \ No newline at end of file diff --git a/node_modules/toastr/nuget/content/scripts/toastr.js b/node_modules/toastr/nuget/content/scripts/toastr.js new file mode 100644 index 0000000..87ae449 --- /dev/null +++ b/node_modules/toastr/nuget/content/scripts/toastr.js @@ -0,0 +1,338 @@ +/* + * Toastr + * Copyright 2012-2014 John Papa and Hans Fjällemark. + * All Rights Reserved. + * Use, reproduction, distribution, and modification of this code is subject to the terms and + * conditions of the MIT license, available at http://www.opensource.org/licenses/mit-license.php + * + * Author: John Papa and Hans Fjällemark + * ARIA Support: Greta Krafsig + * Project: https://github.com/CodeSeven/toastr + */ +; (function (define) { + define(['jquery'], function ($) { + return (function () { + var $container; + var listener; + var toastId = 0; + var toastType = { + error: 'error', + info: 'info', + success: 'success', + warning: 'warning' + }; + + var toastr = { + clear: clear, + remove: remove, + error: error, + getContainer: getContainer, + info: info, + options: {}, + subscribe: subscribe, + success: success, + version: '2.0.3', + warning: warning + }; + + return toastr; + + //#region Accessible Methods + function error(message, title, optionsOverride) { + return notify({ + type: toastType.error, + iconClass: getOptions().iconClasses.error, + message: message, + optionsOverride: optionsOverride, + title: title + }); + } + + function getContainer(options, create) { + if (!options) { options = getOptions(); } + $container = $('#' + options.containerId); + if ($container.length) { + return $container; + } + if(create) { + $container = createContainer(options); + } + return $container; + } + + function info(message, title, optionsOverride) { + return notify({ + type: toastType.info, + iconClass: getOptions().iconClasses.info, + message: message, + optionsOverride: optionsOverride, + title: title + }); + } + + function subscribe(callback) { + listener = callback; + } + + function success(message, title, optionsOverride) { + return notify({ + type: toastType.success, + iconClass: getOptions().iconClasses.success, + message: message, + optionsOverride: optionsOverride, + title: title + }); + } + + function warning(message, title, optionsOverride) { + return notify({ + type: toastType.warning, + iconClass: getOptions().iconClasses.warning, + message: message, + optionsOverride: optionsOverride, + title: title + }); + } + + function clear($toastElement) { + var options = getOptions(); + if (!$container) { getContainer(options); } + if (!clearToast($toastElement, options)) { + clearContainer(options); + } + } + + function remove($toastElement) { + var options = getOptions(); + if (!$container) { getContainer(options); } + if ($toastElement && $(':focus', $toastElement).length === 0) { + removeToast($toastElement); + return; + } + if ($container.children().length) { + $container.remove(); + } + } + //#endregion + + //#region Internal Methods + + function clearContainer(options){ + var toastsToClear = $container.children(); + for (var i = toastsToClear.length - 1; i >= 0; i--) { + clearToast($(toastsToClear[i]), options); + }; + } + + function clearToast($toastElement, options){ + if ($toastElement && $(':focus', $toastElement).length === 0) { + $toastElement[options.hideMethod]({ + duration: options.hideDuration, + easing: options.hideEasing, + complete: function () { removeToast($toastElement); } + }); + return true; + } + return false; + } + + function createContainer(options) { + $container = $('
') + .attr('id', options.containerId) + .addClass(options.positionClass) + .attr('aria-live', 'polite') + .attr('role', 'alert'); + + $container.appendTo($(options.target)); + return $container; + } + + function getDefaults() { + return { + tapToDismiss: true, + toastClass: 'toast', + containerId: 'toast-container', + debug: false, + + showMethod: 'fadeIn', //fadeIn, slideDown, and show are built into jQuery + showDuration: 300, + showEasing: 'swing', //swing and linear are built into jQuery + onShown: undefined, + hideMethod: 'fadeOut', + hideDuration: 1000, + hideEasing: 'swing', + onHidden: undefined, + + extendedTimeOut: 1000, + iconClasses: { + error: 'toast-error', + info: 'toast-info', + success: 'toast-success', + warning: 'toast-warning' + }, + iconClass: 'toast-info', + positionClass: 'toast-top-right', + timeOut: 5000, // Set timeOut and extendedTimeout to 0 to make it sticky + titleClass: 'toast-title', + messageClass: 'toast-message', + target: 'body', + closeHtml: '', + newestOnTop: true + }; + } + + function publish(args) { + if (!listener) { return; } + listener(args); + } + + function notify(map) { + var options = getOptions(), + iconClass = map.iconClass || options.iconClass; + + if (typeof (map.optionsOverride) !== 'undefined') { + options = $.extend(options, map.optionsOverride); + iconClass = map.optionsOverride.iconClass || iconClass; + } + + toastId++; + + $container = getContainer(options, true); + var intervalId = null, + $toastElement = $('
'), + $titleElement = $('
'), + $messageElement = $('
'), + $closeElement = $(options.closeHtml), + response = { + toastId: toastId, + state: 'visible', + startTime: new Date(), + options: options, + map: map + }; + + if (map.iconClass) { + $toastElement.addClass(options.toastClass).addClass(iconClass); + } + + if (map.title) { + $titleElement.append(map.title).addClass(options.titleClass); + $toastElement.append($titleElement); + } + + if (map.message) { + $messageElement.append(map.message).addClass(options.messageClass); + $toastElement.append($messageElement); + } + + if (options.closeButton) { + $closeElement.addClass('toast-close-button').attr("role", "button"); + $toastElement.prepend($closeElement); + } + + $toastElement.hide(); + if (options.newestOnTop) { + $container.prepend($toastElement); + } else { + $container.append($toastElement); + } + + + $toastElement[options.showMethod]( + { duration: options.showDuration, easing: options.showEasing, complete: options.onShown } + ); + + if (options.timeOut > 0) { + intervalId = setTimeout(hideToast, options.timeOut); + } + + $toastElement.hover(stickAround, delayedHideToast); + if (!options.onclick && options.tapToDismiss) { + $toastElement.click(hideToast); + } + + if (options.closeButton && $closeElement) { + $closeElement.click(function (event) { + if( event.stopPropagation ) { + event.stopPropagation(); + } else if( event.cancelBubble !== undefined && event.cancelBubble !== true ) { + event.cancelBubble = true; + } + hideToast(true); + }); + } + + if (options.onclick) { + $toastElement.click(function () { + options.onclick(); + hideToast(); + }); + } + + publish(response); + + if (options.debug && console) { + console.log(response); + } + + return $toastElement; + + function hideToast(override) { + if ($(':focus', $toastElement).length && !override) { + return; + } + return $toastElement[options.hideMethod]({ + duration: options.hideDuration, + easing: options.hideEasing, + complete: function () { + removeToast($toastElement); + if (options.onHidden && response.state !== 'hidden') { + options.onHidden(); + } + response.state = 'hidden'; + response.endTime = new Date(); + publish(response); + } + }); + } + + function delayedHideToast() { + if (options.timeOut > 0 || options.extendedTimeOut > 0) { + intervalId = setTimeout(hideToast, options.extendedTimeOut); + } + } + + function stickAround() { + clearTimeout(intervalId); + $toastElement.stop(true, true)[options.showMethod]( + { duration: options.showDuration, easing: options.showEasing } + ); + } + } + + function getOptions() { + return $.extend({}, getDefaults(), toastr.options); + } + + function removeToast($toastElement) { + if (!$container) { $container = getContainer(); } + if ($toastElement.is(':visible')) { + return; + } + $toastElement.remove(); + $toastElement = null; + if ($container.children().length === 0) { + $container.remove(); + } + } + //#endregion + + })(); + }); +}(typeof define === 'function' && define.amd ? define : function (deps, factory) { + if (typeof module !== 'undefined' && module.exports) { //Node + module.exports = factory(require('jquery')); + } else { + window['toastr'] = factory(window['jQuery']); + } +})); \ No newline at end of file diff --git a/node_modules/toastr/nuget/content/scripts/toastr.min.js b/node_modules/toastr/nuget/content/scripts/toastr.min.js new file mode 100644 index 0000000..3450888 --- /dev/null +++ b/node_modules/toastr/nuget/content/scripts/toastr.min.js @@ -0,0 +1 @@ +!function(a){a(["jquery"],function(a){return function(){function b(a,b,c){return o({type:u.error,iconClass:p().iconClasses.error,message:a,optionsOverride:c,title:b})}function c(b,c){return b||(b=p()),r=a("#"+b.containerId),r.length?r:(c&&(r=l(b)),r)}function d(a,b,c){return o({type:u.info,iconClass:p().iconClasses.info,message:a,optionsOverride:c,title:b})}function e(a){s=a}function f(a,b,c){return o({type:u.success,iconClass:p().iconClasses.success,message:a,optionsOverride:c,title:b})}function g(a,b,c){return o({type:u.warning,iconClass:p().iconClasses.warning,message:a,optionsOverride:c,title:b})}function h(a){var b=p();r||c(b),k(a,b)||j(b)}function i(b){var d=p();return r||c(d),b&&0===a(":focus",b).length?void q(b):void(r.children().length&&r.remove())}function j(b){for(var c=r.children(),d=c.length-1;d>=0;d--)k(a(c[d]),b)}function k(b,c){return b&&0===a(":focus",b).length?(b[c.hideMethod]({duration:c.hideDuration,easing:c.hideEasing,complete:function(){q(b)}}),!0):!1}function l(b){return r=a("
").attr("id",b.containerId).addClass(b.positionClass).attr("aria-live","polite").attr("role","alert"),r.appendTo(a(b.target)),r}function m(){return{tapToDismiss:!0,toastClass:"toast",containerId:"toast-container",debug:!1,showMethod:"fadeIn",showDuration:300,showEasing:"swing",onShown:void 0,hideMethod:"fadeOut",hideDuration:1e3,hideEasing:"swing",onHidden:void 0,extendedTimeOut:1e3,iconClasses:{error:"toast-error",info:"toast-info",success:"toast-success",warning:"toast-warning"},iconClass:"toast-info",positionClass:"toast-top-right",timeOut:5e3,titleClass:"toast-title",messageClass:"toast-message",target:"body",closeHtml:"",newestOnTop:!0}}function n(a){s&&s(a)}function o(b){function d(b){return!a(":focus",j).length||b?j[g.hideMethod]({duration:g.hideDuration,easing:g.hideEasing,complete:function(){q(j),g.onHidden&&"hidden"!==o.state&&g.onHidden(),o.state="hidden",o.endTime=new Date,n(o)}}):void 0}function e(){(g.timeOut>0||g.extendedTimeOut>0)&&(i=setTimeout(d,g.extendedTimeOut))}function f(){clearTimeout(i),j.stop(!0,!0)[g.showMethod]({duration:g.showDuration,easing:g.showEasing})}var g=p(),h=b.iconClass||g.iconClass;"undefined"!=typeof b.optionsOverride&&(g=a.extend(g,b.optionsOverride),h=b.optionsOverride.iconClass||h),t++,r=c(g,!0);var i=null,j=a("
"),k=a("
"),l=a("
"),m=a(g.closeHtml),o={toastId:t,state:"visible",startTime:new Date,options:g,map:b};return b.iconClass&&j.addClass(g.toastClass).addClass(h),b.title&&(k.append(b.title).addClass(g.titleClass),j.append(k)),b.message&&(l.append(b.message).addClass(g.messageClass),j.append(l)),g.closeButton&&(m.addClass("toast-close-button").attr("role","button"),j.prepend(m)),j.hide(),g.newestOnTop?r.prepend(j):r.append(j),j[g.showMethod]({duration:g.showDuration,easing:g.showEasing,complete:g.onShown}),g.timeOut>0&&(i=setTimeout(d,g.timeOut)),j.hover(f,e),!g.onclick&&g.tapToDismiss&&j.click(d),g.closeButton&&m&&m.click(function(a){a.stopPropagation?a.stopPropagation():void 0!==a.cancelBubble&&a.cancelBubble!==!0&&(a.cancelBubble=!0),d(!0)}),g.onclick&&j.click(function(){g.onclick(),d()}),n(o),g.debug&&console&&console.log(o),j}function p(){return a.extend({},m(),v.options)}function q(a){r||(r=c()),a.is(":visible")||(a.remove(),a=null,0===r.children().length&&r.remove())}var r,s,t=0,u={error:"error",info:"info",success:"success",warning:"warning"},v={clear:h,remove:i,error:b,getContainer:c,info:d,options:{},subscribe:e,success:f,version:"2.0.3",warning:g};return v}()})}("function"==typeof define&&define.amd?define:function(a,b){"undefined"!=typeof module&&module.exports?module.exports=b(require("jquery")):window.toastr=b(window.jQuery)}); \ No newline at end of file diff --git a/node_modules/toastr/nuget/content/scripts/toastr.min.js.map b/node_modules/toastr/nuget/content/scripts/toastr.min.js.map new file mode 100644 index 0000000..2f6c09a --- /dev/null +++ b/node_modules/toastr/nuget/content/scripts/toastr.min.js.map @@ -0,0 +1,8 @@ +{ +"version":3, +"file":"toastr.min.js", +"lineCount":1, +"mappings":"CAWG,QAAS,CAACA,CAAD,CAAS,CACpBA,CAAM,CAAC,CAAC,QAAD,CAAU,CAAE,QAAS,CAACC,CAAD,CAAI,CAC/B,OAAQ,QAAS,CAAA,CAAG,CA2BnBC,SAASA,CAAK,CAACC,CAAO,CAAEC,CAAK,CAAEC,CAAjB,CAAkC,CAC/C,OAAOC,CAAM,CAAC,CACb,IAAI,CAAEC,CAASL,MAAM,CACrB,SAAS,CAAEM,CAAU,CAAA,CAAEC,YAAYP,MAAM,CACzC,OAAO,CAAEC,CAAO,CAChB,eAAe,CAAEE,CAAe,CAChC,KAAK,CAAED,CALM,CAAD,CADkC,CAUhDM,SAASA,CAAI,CAACP,CAAO,CAAEC,CAAK,CAAEC,CAAjB,CAAkC,CAC9C,OAAOC,CAAM,CAAC,CACb,IAAI,CAAEC,CAASG,KAAK,CACpB,SAAS,CAAEF,CAAU,CAAA,CAAEC,YAAYC,KAAK,CACxC,OAAO,CAAEP,CAAO,CAChB,eAAe,CAAEE,CAAe,CAChC,KAAK,CAAED,CALM,CAAD,CADiC,CAU/CO,SAASA,CAAS,CAACC,CAAD,CAAW,CAC5BC,CAAS,CAAED,CADiB,CAI7BE,SAASA,CAAO,CAACX,CAAO,CAAEC,CAAK,CAAEC,CAAjB,CAAkC,CACjD,OAAOC,CAAM,CAAC,CACb,IAAI,CAAEC,CAASO,QAAQ,CACvB,SAAS,CAAEN,CAAU,CAAA,CAAEC,YAAYK,QAAQ,CAC3C,OAAO,CAAEX,CAAO,CAChB,eAAe,CAAEE,CAAe,CAChC,KAAK,CAAED,CALM,CAAD,CADoC,CAUlDW,SAASA,CAAO,CAACZ,CAAO,CAAEC,CAAK,CAAEC,CAAjB,CAAkC,CACjD,OAAOC,CAAM,CAAC,CACb,IAAI,CAAEC,CAASQ,QAAQ,CACvB,SAAS,CAAEP,CAAU,CAAA,CAAEC,YAAYM,QAAQ,CAC3C,OAAO,CAAEZ,CAAO,CAChB,eAAe,CAAEE,CAAe,CAChC,KAAK,CAAED,CALM,CAAD,CADoC,CAUlDY,SAASA,CAAK,CAACC,CAAD,CAAgB,CAC7B,IAAIC,EAAUV,CAAU,CAAA,CAAE,CAE1B,GADKW,C,EAAcC,CAAY,CAACF,CAAD,CAAS,CACpCD,CAAc,EAAGhB,CAAC,CAAC,QAAQ,CAAEgB,CAAX,CAAyBI,OAAQ,GAAI,EAAG,CAC7DJ,CAAc,CAAAC,CAAOI,WAAP,CAAmB,CAAC,CACjC,QAAQ,CAAEJ,CAAOK,aAAa,CAC9B,MAAM,CAAEL,CAAOM,WAAW,CAC1B,QAAQ,CAAEC,QAAS,CAAA,CAAG,CAAEC,CAAW,CAACT,CAAD,CAAb,CAHW,CAAD,CAI/B,CACF,MAN6D,CAQ1DE,CAAUQ,SAAS,CAAA,CAAEN,O,EACxBF,CAAW,CAAAD,CAAOI,WAAP,CAAmB,CAAC,CAC9B,QAAQ,CAAEJ,CAAOK,aAAa,CAC9B,MAAM,CAAEL,CAAOM,WAAW,CAC1B,QAAQ,CAAEC,QAAS,CAAA,CAAG,CAAEN,CAAUS,OAAO,CAAA,CAAnB,CAHQ,CAAD,CAZF,CAuB9BC,SAASA,CAAW,CAAA,CAAG,CACtB,MAAO,CACN,YAAY,CAAE,CAAA,CAAI,CAClB,UAAU,CAAE,OAAO,CACnB,WAAW,CAAE,iBAAiB,CAC9B,KAAK,CAAE,CAAA,CAAK,CAEZ,UAAU,CAAE,QAAQ,CACpB,YAAY,CAAE,GAAG,CACjB,UAAU,CAAE,OAAO,CACnB,OAAO,CAAEC,SAAS,CAClB,UAAU,CAAE,SAAS,CACrB,YAAY,CAAE,GAAI,CAClB,UAAU,CAAE,OAAO,CACnB,QAAQ,CAAEA,SAAS,CAEnB,eAAe,CAAE,GAAI,CACrB,WAAW,CAAE,CACZ,KAAK,CAAE,aAAa,CACpB,IAAI,CAAE,YAAY,CAClB,OAAO,CAAE,eAAe,CACxB,OAAO,CAAE,eAJG,CAKZ,CACD,SAAS,CAAE,YAAY,CACvB,aAAa,CAAE,iBAAiB,CAChC,OAAO,CAAE,GAAI,CACb,UAAU,CAAE,aAAa,CACzB,YAAY,CAAE,eAAe,CAC7B,MAAM,CAAE,MAAM,CACd,SAAS,CAAE,2BAA0B,CACrC,WAAW,CAAE,CAAA,CA7BP,CADe,CAkCvBC,SAASA,CAAO,CAACC,CAAD,CAAO,CACjBnB,C,EAGLA,CAAQ,CAACmB,CAAD,CAJc,CAOvB1B,SAASA,CAAM,CAAC2B,CAAD,CAAM,CAuFpBC,SAASA,CAAS,CAACC,CAAD,CAAW,C,GACxB,CAAAlC,CAAC,CAAC,QAAQ,CAAEgB,CAAX,CAAyBI,OAAQ,EAAIc,E,OAGnClB,CAAc,CAAAC,CAAOI,WAAP,CAAmB,CAAC,CACxC,QAAQ,CAAEJ,CAAOK,aAAa,CAC9B,MAAM,CAAEL,CAAOM,WAAW,CAC1B,QAAQ,CAAEC,QAAS,CAAA,CAAG,CACrBC,CAAW,CAACT,CAAD,CAAe,CACtBC,CAAOkB,S,EACVlB,CAAOkB,SAAS,CAAA,CAAE,CAEnBC,CAAQC,MAAO,CAAE,QAAQ,CACzBD,CAAQE,QAAS,CAAE,IAAIC,I,CACvBT,CAAO,CAACM,CAAD,CAPc,CAHkB,CAAD,CAJZ,CAmB7BI,SAASA,CAAgB,CAAA,CAAG,EACvBvB,CAAOwB,QAAS,CAAE,CAAE,EAAGxB,CAAOyB,gBAAiB,CAAE,E,GACpDC,CAAW,CAAEC,UAAU,CAACX,CAAS,CAAEhB,CAAOyB,gBAAnB,EAFG,CAM5BG,SAASA,CAAW,CAAA,CAAG,CACtBC,YAAY,CAACH,CAAD,CAAY,CACxB3B,CAAa+B,KAAK,CAAC,CAAA,CAAD,CAAO,CAAA,CAAP,CAAa,CAAA9B,CAAO+B,WAAP,CAAmB,CACjD,CAAE,QAAQ,CAAE/B,CAAOgC,aAAa,CAAE,MAAM,CAAEhC,CAAOiC,WAAjD,CADiD,CAF5B,CA/GvB,IACCjC,EAAUV,CAAU,CAAA,EACpB4C,EAAYnB,CAAGmB,UAAW,EAAGlC,CAAOkC,UAAU,CAE3C,OAAQnB,CAAG5B,gBAAkB,EAAI,W,GACpCa,CAAQ,CAAEjB,CAACoD,OAAO,CAACnC,CAAO,CAAEe,CAAG5B,gBAAb,CAA8B,CAChD+C,CAAU,CAAEnB,CAAG5B,gBAAgB+C,UAAW,EAAGA,EAAS,CAGvDE,CAAO,EAAE,CAETnC,CAAW,CAAEC,CAAY,CAACF,CAAD,CAAS,CAClC,IACC0B,EAAa,KACb3B,EAAgBhB,CAAC,CAAC,QAAD,EACjBsD,EAAgBtD,CAAC,CAAC,QAAD,EACjBuD,EAAkBvD,CAAC,CAAC,QAAD,EACnBwD,EAAgBxD,CAAC,CAACiB,CAAOwC,UAAR,EACjBrB,EAAW,CACV,OAAO,CAAEiB,CAAO,CAChB,KAAK,CAAE,SAAS,CAChB,SAAS,CAAE,IAAId,IAAM,CACrB,OAAO,CAAEtB,CAAO,CAChB,GAAG,CAAEe,CALK,CAMV,CA4DF,OA1DIA,CAAGmB,U,EACNnC,CAAa0C,SAAS,CAACzC,CAAO0C,WAAR,CAAoBD,SAAS,CAACP,CAAD,CAAW,CAG3DnB,CAAG7B,M,GACNmD,CAAaM,OAAO,CAAC5B,CAAG7B,MAAJ,CAAWuD,SAAS,CAACzC,CAAO4C,WAAR,CAAoB,CAC5D7C,CAAa4C,OAAO,CAACN,CAAD,EAAe,CAGhCtB,CAAG9B,Q,GACNqD,CAAeK,OAAO,CAAC5B,CAAG9B,QAAJ,CAAawD,SAAS,CAACzC,CAAO6C,aAAR,CAAsB,CAClE9C,CAAa4C,OAAO,CAACL,CAAD,EAAiB,CAGlCtC,CAAO8C,Y,GACVP,CAAaE,SAAS,CAAC,oBAAD,CAAsB,CAC5C1C,CAAagD,QAAQ,CAACR,CAAD,EAAe,CAGrCxC,CAAaiD,KAAK,CAAA,CAAE,CAChBhD,CAAOiD,YAAX,CACChD,CAAU8C,QAAQ,CAAChD,CAAD,CADnB,CAGCE,CAAU0C,OAAO,CAAC5C,CAAD,C,CAIlBA,CAAc,CAAAC,CAAO+B,WAAP,CAAmB,CAChC,CAAE,QAAQ,CAAE/B,CAAOgC,aAAa,CAAE,MAAM,CAAEhC,CAAOiC,WAAW,CAAE,QAAQ,CAAEjC,CAAOkD,QAA/E,CADgC,CAEhC,CACGlD,CAAOwB,QAAS,CAAE,C,GACrBE,CAAW,CAAEC,UAAU,CAACX,CAAS,CAAEhB,CAAOwB,QAAnB,EAA4B,CAGpDzB,CAAaoD,MAAM,CAACvB,CAAW,CAAEL,CAAd,CAA+B,CAC9C,CAACvB,CAAOoD,QAAS,EAAGpD,CAAOqD,a,EAC9BtD,CAAauD,MAAM,CAACtC,CAAD,CAAW,CAE3BhB,CAAO8C,YAAa,EAAGP,C,EAC1BA,CAAae,MAAM,CAAC,QAAS,CAACC,CAAD,CAAQ,CACpCA,CAAKC,gBAAgB,CAAA,CAAE,CACvBxC,CAAS,CAAC,CAAA,CAAD,CAF2B,CAAlB,CAGjB,CAGChB,CAAOoD,Q,EACVrD,CAAauD,MAAM,CAAC,QAAS,CAAA,CAAG,CAC/BtD,CAAOoD,QAAQ,CAAA,CAAE,CACjBpC,CAAS,CAAA,CAFsB,CAAb,CAGjB,CAGHH,CAAO,CAACM,CAAD,CAAU,CAEbnB,CAAOyD,MAAO,EAAGC,O,EACpBA,OAAOC,IAAI,CAACxC,CAAD,CAAU,CAGfpB,CArFa,CAuHrBG,SAASA,CAAY,CAACF,CAAD,CAAU,CAU9B,OATKA,C,GAAWA,CAAQ,CAAEV,CAAU,CAAA,EAAE,CACtCW,CAAW,CAAElB,CAAC,CAAC,GAAI,CAAEiB,CAAO4D,YAAd,CAA2B,CACrC3D,CAAUE,Q,CACNF,C,EAERA,CAAW,CAAElB,CAAC,CAAC,QAAD,CACb8E,KAAK,CAAC,IAAI,CAAE7D,CAAO4D,YAAd,CACLnB,SAAS,CAACzC,CAAO8D,cAAR,CAAuB,CACjC7D,CAAU8D,SAAS,CAAChF,CAAC,CAACiB,CAAOgE,OAAR,CAAF,CAAmB,CAC/B/D,EAVuB,CAa/BX,SAASA,CAAU,CAAA,CAAG,CACrB,OAAOP,CAACoD,OAAO,CAAC,CAAA,CAAE,CAAExB,CAAW,CAAA,CAAE,CAAEsD,CAAMjE,QAA1B,CADM,CAItBQ,SAASA,CAAW,CAACT,CAAD,CAAgB,EAC9BE,C,GAAcA,CAAW,CAAEC,CAAY,CAAA,EAAE,CAC1CH,CAAamE,GAAG,CAAC,UAAD,E,GAGpBnE,CAAaW,OAAO,CAAA,CAAE,CACtBX,CAAc,CAAE,IAAI,CAChBE,CAAUQ,SAAS,CAAA,CAAEN,OAAQ,GAAI,C,EACpCF,CAAUS,OAAO,CAAA,EARiB,CA9QpC,IACIT,EACAN,EACAyC,EAAU,EACV/C,EAAY,CACf,KAAK,CAAE,OAAO,CACd,IAAI,CAAE,MAAM,CACZ,OAAO,CAAE,SAAS,CAClB,OAAO,CAAE,SAJM,EAOZ4E,EAAS,CACZ,KAAK,CAAEnE,CAAK,CACZ,KAAK,CAAEd,CAAK,CACZ,YAAY,CAAEkB,CAAY,CAC1B,IAAI,CAAEV,CAAI,CACV,OAAO,CAAE,CAAA,CAAE,CACX,SAAS,CAAEC,CAAS,CACpB,OAAO,CAAEG,CAAO,CAChB,OAAO,CAnBM,OAmBG,CAChB,OAAO,CAAEC,CATG,CAXQ,CAuBrB,OAAOoE,CAxBY,CA4RlB,CAAA,CA7R6B,CAA1B,CADc,EAgSpB,CAAC,OAAOnF,MAAO,EAAI,UAAW,EAAGA,MAAMqF,IAAK,CAAErF,MAAO,CAAE,QAAS,CAACsF,CAAI,CAAEC,CAAP,CAAgB,CAC5E,OAAOC,MAAO,EAAI,WAAY,EAAGA,MAAMC,QAA3C,CACCD,MAAMC,QAAS,CAAEF,CAAO,CAACG,OAAO,CAACJ,CAAK,CAAA,CAAA,CAAN,CAAR,CADzB,CAGCK,MAAOR,OAAU,CAAEI,CAAO,CAACI,MAAOC,OAAR,CAJqD,CAAhF,C", +"sources":["toastr.js"], +"names":["define","$","error","message","title","optionsOverride","notify","toastType","getOptions","iconClasses","info","subscribe","callback","listener","success","warning","clear","$toastElement","options","$container","getContainer","length","hideMethod","hideDuration","hideEasing","complete","removeToast","children","remove","getDefaults","undefined","publish","args","map","hideToast","override","onHidden","response","state","endTime","Date","delayedhideToast","timeOut","extendedTimeOut","intervalId","setTimeout","stickAround","clearTimeout","stop","showMethod","showDuration","showEasing","iconClass","extend","toastId","$titleElement","$messageElement","$closeElement","closeHtml","addClass","toastClass","append","titleClass","messageClass","closeButton","prepend","hide","newestOnTop","onShown","hover","onclick","tapToDismiss","click","event","stopPropagation","debug","console","log","containerId","attr","positionClass","appendTo","target","toastr","is","amd","deps","factory","module","exports","require","window","jQuery"] +} diff --git a/node_modules/toastr/nuget/toastr.1.0.0.nupkg b/node_modules/toastr/nuget/toastr.1.0.0.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..0be0d704bd51fea2af6b9a044449c971ff83ef91 GIT binary patch literal 7341 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 + + + 1.0.0 + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + https://github.com/CodeSeven/toastr + + + + toastr + toastr + false + 3 Easy Steps: + +1) Link to toastr.css and toastr-responsive.css +2) Link to toastr.js +3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + toastr is a Javascript library for Gnome / Growl type non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + Copyright © 2012 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/nuget/toastr.1.0.1.nupkg b/node_modules/toastr/nuget/toastr.1.0.1.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..afb7a2269e6428d962220254794e2d6acdccc732 GIT binary patch literal 7745 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 B(vAQC literal 0 HcmV?d00001 diff --git a/node_modules/toastr/nuget/toastr.1.0.1.nuspec b/node_modules/toastr/nuget/toastr.1.0.1.nuspec new file mode 100644 index 0000000000000000000000000000000000000000..d73cd002ac3799639ba341567b4ba79bcd110941 GIT binary patch literal 3764 zcmb`K-HsbY5QXd767SIBf&j|e>>>dI<0t|WhyVqJz2nAfPi$}2GiGKSXL%#ui{}8& zSM6qI>~R(nH1hm(SJ%&}Q`POi{v6u_du408v0yJPv(hSCSz)<-Y46&(4ecX6gJyD@ zX?(8P+!j8&wc4KBnWR3E%mbU)J2tSfZEPyp7rHOBF6{N^(u~ffR@IXE+(x=8NiHR| zmUJa+Yw4fKi$Y(8wAUKL?pm^Kz0r%2UC6(4T_Zg|(>=GXR&Jzmrj@VsK9|ktS&%PW zV`^1!J(e4>>_;1YAp-3GLrS! zZqN05Fcku|FfBZn6MLe!rEm%MR8fH8efw5-@)7KjUE3eBg*9?eDsOmtsHNXlVLR!G zta(#QT^;>)Zk!cxu#&Y)d3hsjx=h;1mz{E6c=nMjghVMGWIkGojU%mtUrAG?5g1pC z#od{qv@G=li|$Oa-tXx~77Jkt|LP-8t3B%%ZgVOBu3G&5N-O7D`Ak2UlFRlX_xkns z`%+5Bud=a{Pnmt+iTt7b1BZ<)zy;nXs<)}41!Lm=@9X>hASUX(ln2<0{bgbwi+|t9 zVr92_d!`xu0i%JgbNfJ}c%6%r!I6k}R#1y{hDsOJM-215RGL5Y2_j9So3_7t4|5^XO-Lr?XN3^$EvvrO1 z>Y#p4G|@vm%N%?9N3MO~o{%DgANoa)iE$V10rEkbpW1hN&a{T^6JrP4h;Fn4bJki7 z8&9#QpL5{4-gmUygFXsIu!j6R(fy@^$I~*^jb-rb_wxL6%@DT-nO^xKlIN)Dh@%7C|ESd=%9!(`TF|nuZ+)_l6eI&^Sw?U_3ZOlYh2b{p8h!SU*$a(hUcmg=n+jCt_ zETG9LtBWNT$X(_dISZw}+>cs6%4B>aPJzcl9@oN`y{0=B?00z(&r=tAd;J+9*n7$v ztolN-$7hV_X`khOAL*Ioa;qn&#)*E^(53c;xCbB3_v>LdTR4N7oRr>In{T=--0G`D z=IGk?lY8~r}OD>^}}2=>;MzF>8qd~dzMV6 z^-sl-3qP@sPS{Jm^llH4eEmsz?41lQo{FxKpe8wu;VHbxg(Dc%_RGg>~9)bI*Gh(3~fDc=WTlztdy5_9)_xe%9(W+-v3U^p{KAd OA)464So>ceec^8;D{$ig literal 0 HcmV?d00001 diff --git a/node_modules/toastr/nuget/toastr.1.0.2.nupkg b/node_modules/toastr/nuget/toastr.1.0.2.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..3ebbc75571a73186612e9a1e796a8dffd84e2ff4 GIT binary patch literal 7794 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 literal 0 HcmV?d00001 diff --git a/node_modules/toastr/nuget/toastr.1.0.2.nuspec b/node_modules/toastr/nuget/toastr.1.0.2.nuspec new file mode 100644 index 0000000000000000000000000000000000000000..79dd9a25b2c75b861555c0fe94cc6a6894c122b3 GIT binary patch literal 3914 zcmb`K+m0JW5Qgj867SIBf&j|e*+l{b#!>W2=+p)b_&nz?JILjOHUOWfz zf7Nd0;BgibWZ52f*YU5vs@s44Ikt!P$~Jaw!Cu1N6nc_RuYozZ_^_kgLnm4jIljbWu&*d{l78DDw zv8*j*d8)msf4BE*xwRxFlE^)}N^yU#M`x^A){$aE(l$EGI&Nj-`8`g`ov0*2`fA46^b`b zxUkou$6!|B*f2SReRbfEE=LdR%^0x?%U4>>_Iqi@3|hGi|IvTn?%5;xBimc)Y~3QW zI%wXLO^lGp7LGmhBhxu>Pe@V05B?hi7XO4mqtf4+n^!ZZnCO?DXS*tS(truR&RJq5F9;Zj}3Ov?6^NZ87 zk|gI&L^#t#xzu{D3}5V#iaYQh?8rRz0w-V4)c9FZgAeS9F}8bf?sCsmNBk^h9rThc zoCHyHu#F5k!u*Z%k`+$VSk-Qp@B_VA6}WWiHfD;7j^h+w+izN<(^AJRbjsq3{$pq8 z)#~EkUnSz;}3>ULl8WEufMqjdruL;_0J`H zc=L(e?DO0oBa>AbF)Quws5e>3}GJay{M2ll|7 zZqH?j-&cON$7w+MwR_?@Vl;6Ar8RzV|NRX zpdQ>g>C*q-`f(iL4!OT+X6b(PwmCHIyj`@-v$<4Vnspee4@zg&U3mXHE8R$8TS7Fk LiM8f`QRc$m#6XIZ literal 0 HcmV?d00001 diff --git a/node_modules/toastr/nuget/toastr.1.0.3.nupkg b/node_modules/toastr/nuget/toastr.1.0.3.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..71335bed42e32a3e7906e76e774da1d2b54c31bd GIT binary patch literal 7761 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 IVmmndKYT(dNB{r; literal 0 HcmV?d00001 diff --git a/node_modules/toastr/nuget/toastr.1.0.3.nuspec b/node_modules/toastr/nuget/toastr.1.0.3.nuspec new file mode 100644 index 0000000..94071f6 --- /dev/null +++ b/node_modules/toastr/nuget/toastr.1.0.3.nuspec @@ -0,0 +1,38 @@ + + + + toastr + 1.0.2 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + https://github.com/CodeSeven/toastr + false + 3 Easy Steps: + +1) Link to toastr.css and toastr-responsive.css +2) Link to toastr.js +3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + toastr is a Javascript library for Gnome / Growl type non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + Minor updates for long unbroken string going outside toast and new feature to keep the toast around after hover-off for an extended timeout. + +Set extendedTimeOut and timeOut to 0 to avoid toastr from fading away. + Copyright © 2012 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/nuget/toastr.1.1.0.nupkg b/node_modules/toastr/nuget/toastr.1.1.0.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..555e321ad11fd7da94e5ead21ccf202c8924503c GIT binary patch literal 7789 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 literal 0 HcmV?d00001 diff --git a/node_modules/toastr/nuget/toastr.1.1.0.nuspec b/node_modules/toastr/nuget/toastr.1.1.0.nuspec new file mode 100644 index 0000000..a65e371 --- /dev/null +++ b/node_modules/toastr/nuget/toastr.1.1.0.nuspec @@ -0,0 +1,35 @@ + + + + toastr + 1.1.0 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + https://github.com/CodeSeven/toastr + false + 3 Easy Steps: + +(1) Link to toastr.css +(2) Link to toastr.js +(3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + toastr is a Javascript library for Gnome / Growl type non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + Added AMD support (and backwards compat with non AMD), toastr.clear() method, optionsOverride API to be able to override options for each toast, added onclick callback option which fires when a user clicks the toast. Also cleaned CSS, merged CSS files into 1 file, and reduced jQuery dependency to v1.6.3 + Copyright © 2012 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/nuget/toastr.1.1.1.nupkg b/node_modules/toastr/nuget/toastr.1.1.1.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..b5cf330adea0a44af48eade28deca9f20b0e4c56 GIT binary patch literal 7789 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 l(7z7 + + + toastr + 1.1.1 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + https://github.com/CodeSeven/toastr + false + 3 Easy Steps: + +(1) Link to toastr.css +(2) Link to toastr.js +(3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + toastr is a Javascript library for Gnome / Growl type non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + Added AMD support (and backwards compat with non AMD), toastr.clear() method, optionsOverride API to be able to override options for each toast, added onclick callback option which fires when a user clicks the toast. Also cleaned CSS, merged CSS files into 1 file, and reduced jQuery dependency to v1.6.3 + Copyright © 2012 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/nuget/toastr.1.1.2.nupkg b/node_modules/toastr/nuget/toastr.1.1.2.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..ecca818d8e60035716df4de73d8fdde3828b8141 GIT binary patch literal 7850 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 literal 0 HcmV?d00001 diff --git a/node_modules/toastr/nuget/toastr.1.1.2.nuspec b/node_modules/toastr/nuget/toastr.1.1.2.nuspec new file mode 100644 index 0000000..96caba5 --- /dev/null +++ b/node_modules/toastr/nuget/toastr.1.1.2.nuspec @@ -0,0 +1,35 @@ + + + + toastr + 1.1.2 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + https://github.com/CodeSeven/toastr + false + 3 Easy Steps: + +(1) Link to toastr.css +(2) Link to toastr.js +(3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + toastr is a Javascript library for Gnome / Growl type non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + Added AMD support (and backwards compat with non AMD), toastr.clear() method clears 1 or all toasts, optionsOverride API to be able to override options for each toast, added onclick callback option which fires when a user clicks the toast. Also cleaned CSS, merged CSS files into 1 file, and reduced jQuery dependency to v1.6.3 + Copyright © 2012 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/nuget/toastr.1.1.3.nupkg b/node_modules/toastr/nuget/toastr.1.1.3.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..068a54114d40797f14f66f2bb67c9b558953b222 GIT binary patch literal 11781 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 PU2K3cDg;8gzJL2KJ1&oG literal 0 HcmV?d00001 diff --git a/node_modules/toastr/nuget/toastr.1.1.4.1.nuspec b/node_modules/toastr/nuget/toastr.1.1.4.1.nuspec new file mode 100644 index 0000000..c3fe237 --- /dev/null +++ b/node_modules/toastr/nuget/toastr.1.1.4.1.nuspec @@ -0,0 +1,40 @@ + + + + toastr + 1.1.4.1 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + https://github.com/CodeSeven/toastr + http://johnpapa.net/wp-content/images/toastr-icon.png + false + 3 Easy Steps: + +(1) Link to toastr.css +(2) Link to toastr.js +(3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + toastr is a Javascript library for Gnome / Growl type non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + Added AMD support (and backwards compat with non AMD), toastr.clear() method clears 1 or all toasts, optionsOverride API to be able to override options for each toast, added onclick callback option which fires when a user clicks the toast. Also cleaned CSS, merged CSS files into 1 file, and reduced jQuery dependency to v1.6.3 + +Fix to the toastr.min.js file + Copyright © 2012 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/nuget/toastr.1.1.4.2.nupkg b/node_modules/toastr/nuget/toastr.1.1.4.2.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..e92fdd46e409b4a8742af5a05686d5ea49b15969 GIT binary patch literal 11772 zcmb`N1z1$uyZ`Af0i`9RyBkEh1f*MrnW13@W++LOQc{pcx=T`}ySrPFPU#YXJ9<3l zc+UNu^S}T5+<9hip4n@?-}SC{uVSr_mKrJ=4$}8esF{LnXCy_~HZl^@_X`(^8tJhM z*a61F{rygtNsh#tPWmJ3-*0<$O_KLL93AM~z%DRbh?5ipA2%-p9oPv70ogiPOEI{@ zt++%P?n_H*gB<{HL=KpZEfhwFFmZxOG1$Q2P;nj}7|;gn2!L@zpkOCNiWS7g5dcU0 zbg|}v0)X}aYcLN#FRw5U!ka%e82+kBr|Ss?|2IWPTc8UB2C;&310jw-#SnfWKZ%P8Z-}4TeiG@W3Ge7~F;1$rT0#0~zR4KvE3a0(@dXfUqb)R8*K> zP*50AL!SRh>HlB#;c*1R0U!VzzypN1fVrS92x}L(Eg1HTZ@)(a26l0?1%hG!Xu|^# z1_@e<3iE-1BK(4UqLyO(KuZ8X1SrT4666Jl0l1+sM-UMDvwp$?AYl)lEp+q!bh~1zeMfdT1=pxnbWc`kuTY> z1m3sda8#qP7|U{-+n9>)X57jh-$P+YNt9|;OwoNAOCQ!Z`%(e4I8~Tix5dAzC0?gL zVG#S|opNC%`gM8i?Zp64rw#SV=%ndT+)M}FFsq4;j``4RnMr-pLb0@(3(LfVI4nF7 zxKxoW^fAtZ!d6A?Nt;!!8ME%!j_v+n3}?@B)0d$JtyL>p;7Hy61ibS;D!huQ2N9Ro z>SRS0Oz3I2=88dl%@h14R*ymPH3cbhGEH?nML@*Wmw(ZHJKE_8imN7^+{fD`m zYc(?%@pV)vHc8D)R?E!+CH*U%lG~K6UXR}@W<+!Wt!QXxCpr3yc{;EdMmEaGMG}il zxf#wv#y#tlZZm6JPHG1iE}SNPnne*g_g7TMkv})I1V1F5N-ZbqofnaB*PxoBcU?PWV~SR>SD+XY+Ygf8JbY># z5yTppbsThgd-~Z&lQc%z=Ix%LK@4eF@yXpM&dyPc9)3dTQ6^u*=Wb%F1g(szVqv-+gwI2*)Q#5>0!5_<+D7 z|75bVM)ON}IsP+$k&k!nu~>qs%ZwcCiwMl(Ix!l?RNV};FfM6LK$=$6YI>l3l3*QU zBlkScj6+t`!|-e>gL|xf1sVoHsu&s_&2ji#=yMxsVve>r%}QT#pJBuJI&O+#cCQ0I z&G}aulZ8D$aerIGK4?U{SPYy#m2wx8`@QRwfCbAK)-Jk2LE+PT=rdim;Y$WjHaMmOMO!}` z+6H|wlwT5}j4Ng;b&Jex?3L2Q*iLew%>&fV4KS}x`-l}Mrdy#nil&2`RJ_D$1WPQt z4a-r?@=71&aUTYQPxII(^VJB{1+q`D=F{ z6_O_vK+G0XcaV@M5#1dKae{-L;E18>x4%ETKM?k>v&DenW<-(Voom|7#^)>}$|}lT zU&T~ze-)0lY*-`YLDw|m?xxA)nLkJ^&g#+{!ZJNMfky{uw|D1CxbpYe|B zw7<{%7^Fb*dI(jLP{u3Vd6kONcS%Vo~a!lu{F>xitQO}yf5&B?R~*#cgy^?98DX_Ui-L5ZX7*w ztA1X-h8F%lt7AB|=rD%2DePOmXK7kL8$d8XE_iC^#qfew#GaBEwa3HAg~~osA7n2> zUTPoP#-5jbyqBYdy~(2oSui0Bj6LhU^$lTYO#Zb?Fb}4f!#$SfZ@zTpCfgu^2*JF9Oib%k#E zLa$$Ww|uA-li%c>n;V(xs_=j1*SFK*Fs<#D6JrpZ+3#zrU~Z(_k#T)1yKDHu4Mw|d zO?>rb+q(SjvZ#Cd(!Gs~Q&*mAmKMMM?RzlNrbhD#RoBycK-Oj092{kTb0yY9D^B5p zg5_n4HThXDTQ6aUwKuO5Usi~LbcxQI+yn2<@Oxxv;$H8A{3sgco9<^Z9+yh393Qbi zLB2xij!|Zg{CpE885I6ig%)DJ{L%x-W4)r5dCO3qu=>nAQ@TlgBzA6h!!-Ak@2*5O z%*&db7Iq%9t=kfIPS2koKAXu;h|615of}+C5DXbVLE)q{Y{Nvo!qqUvw`iKw)kOm< zcnGZ8X~7iIw2+3)=7qC!HVm>>$}@JWpIcW``VLYoUJSfw65lV$EqdJ&)HmyPhtgDM zr`JUH$y9-PM&GQ0KnK)sMIT_3Xu6>lweembH0o8C6<2J`rH5}F8z5CxwbPZ0X8bT0 zKtJ|z1`;wbZX9=#($MTfzImP?W7@A)F&Vr%}X zvok8|a_!SPX>J+?hM|4XiaRM^%To1KNZfI$SSn|p1;rmpS7tnNQb>I>1T8R0SyAQU z&Yc*n4PUHek6uqmaUkkdfCE)^wi8u`UMD>(wIhum#eSL$7RZ?7FobOOWUhU4f|!i2 zMSY-Pd5EWkM1qP{9(gwsRy92nuc%;{wZn^h_uG~r?%)_3lOa1rt~oKiSaez8-~po^ z%4@r2B*E#Ig7G+dUQ(HSm2I`XE;yKM)tsM8h5KIwv)Q)_^)pS2WeUqNg^6ii_HajA z6hFeZo`%L(S4EsRuf25as&r6TYmni|7j8ZeilywIpW~iw_Z`~Bs#V*!ND0YzvQ1q>oDP@WDH zibQtTEXxw#B1+GNO7-Ma!u9((|KW{>Z*sA(?ZQqH|$j|F;e|RP`gYzqgdm7kvv`q zkK1JMAa51~XcaverZ@Fn!=e{%4ol_8VXpO2r4OW8j6f>bdR?kn!9)bA-(&K0#c&#@ zB4&F`jYFtQDAgJ`!Y+T;8O$@-tyA>^y4YFrn8rnmC10(pE{8F`vKVwHDog|DsQxO3 zC{?6LcV<;_h{OiBUUbMp;jK|P+cIau`(U{Srgtz$wPI)EimNs4Vz27}PhiXZ4pXBY zUP!)0iUr4$`BG~JD`W?g81F-C+?^}0*e2i$z6sz9Bl5ER=M~R_4?MykDj;e>nE-rp zSZp`_>oG$-U@2=OC$(dBCPSRyhFDpm_Dag_c%`=1nL5MZ*wSQi)b4P?0Hf>=I8^Tf zhL0xVPC#~=F9eatc{i|9(+frIQGK*;%i-OP7^q!z(5v!!cgp|}KMb!Y3&+_Bqge5f zF$gfOX6=)EL<&`?U}UwC(Ze8MPLGuV88PNWcwz$gl;@ zX9V<)ppeAc*6%QsTVdr#QP66x5>IH&N}{R;)g;M>!i~^psV(WGs-G3uRLGDXR*=Rk z#S$6?I+cU7w=(6j-RJn33ckMPBEgnDKiZ2OxO^Ywr!=!andOlCZgQuvy0v7!VIcIl zcd0}j=P84#Og0x-0xeuHh~WX_=t~Ct8xNL1$Bc198B`panGqWE?B)oJ!tr~dE(SS` zn)-*H6|%SdHZ#XO1*r1A*oMXOC)qB)sf{2@t-&~)BxZV)B3GUz1r|R@is`1S@BX5a zj{i03!y)NQVKUZW*~6KuHKelu6jD)5G`#-Y2HC-}Mp(HgIsk=xu|KdBmxVu0Mx0_k z{2keZLJ-%wi7Q7?82113IA|(gN(x8i)KglY7oHuxF@b>iN_hnC zWfzc)*ifW;`Sw`YKBLt7WFJIL6;>6`{m4N>x8v=xm`EBfvS;cmmGXD)WG=A8(|Umz zD6*zwRpnx8G+)k;_83}--I~53lUiX*Qka6Qox&7%Lf>V<4b>4=K;R`}v9n*o}9OcLhcynD5tzULTJip`XMDCmZxFAIwF?ZjXIE zdGeV32J^4W(4nGN{+ZZFNViCkknaBTGSt!5iTnS#6t#`aQXakLXpl0tRaCF8aRA1z zO(a`5J@!X#6B%6T#OVL5e{95jlCJx8?@cje;V^~E^-h1#`0Uw#TC!9 ze&^>qMFv*j>TgVVZ6X+b`3}#w&_8>A1d<#NJg4;luL?RFafVi4nfE6h9ut{Y>|}&q zF@F^oj^6;f(&B#gi09%Xy*k64=St4)e{3SD;%fsBeT5Eyoke`kyFQq#z26WtPvhMs zdEtfsgy1^hveei6ORL1N*SNu!!Bam^lqbN$ln>-AJGzqxK2KUd5Ps|0mNPwn&}14m zMYVr(;e09N&Q4CIc1-fsR=8GLtdW)s`r@JHRo>ovHu0_0wE!8&5TU0h&85M`gA*+= zU+;qW_7JZVAL^NvT<0T_am}iT_}0RD((AUgdv)&JxG$OW&9{pdNks>gL)Y`-xlajQ zSI)uiv`dbo(pUT%okbsgkj}LZ-c(1f_8cr(8Tw}2g`C{#oS80IUDwfToqk*zVJRJb zp(Un36Q_3#Ch^iUiU%B_gYvpBT+cw)n1R=)7Y8%bHTJ!GN!I+{K0@Q`chlQYpcD67Y4HLm%kHPDrp$u~?m_1(K5iE(ov)$pqrPkzFT;Clq9M}xehhyvKuxU;Dq1n$mFe&I^7e|ZXJqGqUUZ=wCVuw(8hY*nYU>^ zdCqZXrz^V6uR2_L@A*aIKgn~;?{6axo6;Y<6t=t7bom4p!gR;*} zk`_EdjrY7JI9!eD>~hIzH0POLa>j&GQ%1LaeED$A=Il60Z@aqiR&jI%psU;0QZ;=H zgb~NTZ1yc~{$YvhME?wjq++>-x^jC*gWz76{HTUYVZS(0Oj#&FckG7lEb#3{l#OdT zExRU7t8sqh1rB-*$4){ZxlT|5S^T|*;6$i)u2~*MvS$Mq!MAxgs%N7Uel+wmOkcq=MjEpblS zc?y*{P41zk>AlKqUWEq_b7xZN1brM-x5^b1gzIJ1>uaFROQvCmo3~jFS%d~1U1m9s z)bYB)G+Gg>#02Dkb|uX`G2^>C_C*ZEk4`?I%QZ<4J?n$3;>M{eB*u3tKg}*Kgh?tG zAm!9CB5^fl^jFJ@eDt>|GWt+*^o&_X@hyjk4Iar66s%SoRD*%3G;Wn2@RoZFS)!d- zU9ff)kLvDW#KCs7?p289W2lWUly2;yjl@cMX$UK^qWJ;K_8VC_HGm0Qo_#~Uo z3MqNLR`rG7TE^4LA}LOiOT#c__VUZ@;PVMe^WCB;o%R*G&y8R(XNNC@^iI`TmV zS@(xI3rFKo=6x^b`(}hb2~N%vR68a2pq7QPMve*PH3rU zHZ7ua)%UVzq6Stp*e5ibO&3z!G8C+@Co6&TW$E#R$T z*BqP5)1#n_<2jYf)+&>s8}15&LnGGfNwcP3N|GRh8dPfJ4sCY(v}hRo`Z^-I()Hc} z=WXmwRRArwo1byiPGBp9sY%3qs2(3*HN-07eW&I_bSW^F&vFlSPM~)yn@~e#qIt1) zo!YMufJ?$$5FGL4C9V?A3uLQ)(*nT}8h%Q)U4JN=^3=M6R~*;V?C52>o@89;a!VBJ z#n!NV`jZW8?l2Ad(1aokXT>+mX6i^Ho8QDaWnwb9W2h&iO$QF`s{M7nQ*B6+S{XcM z9QjwZ$Wb*jY4)QTf`ux<)q1fjE%mrCc`Ul%GdAZ_GG9-isZRfFR#AKQo@-K?i?s&XfbAw)KEyci2G0RWbow3DD|p z`l>PGqS%^@i$ZwSKv0BHuf@xnng%^i1H;zSL%(N&gjp}`}FemJQB2n@>)eLBkRQ2 zEo5*KDmL{q|?2dh>Tdd6z>dfYdp|aeA zBc35WgqVmzZ6*@2LRZkCyF;Pys`I9_veiw?jw>BG@Wt+V1eq<=!k-<#J5zi-aZjh( zyG59F>8%-D9AX{QFQvJ!st9v*(R$z0D)3(Bqe&*?OBm~ESe`oHTd7cv0J52T=vA*C zCU9tG*ub6=$3+j_b*Gn%#?e}oyba||CcqII3i{ZwE)>A_;TbMj4R??S?8!o0Kffx$M3rLp2wsSowWns(mFsAGGVX;frq)<+0?g zvKr7MtHLRk5J`0x0p(6T=i0qx1q&vRfdN;D)VrT3K`7d zudA}h3*fqG*sUsWA2Dr5zkcwl!0Qk%th`{CS-D$>KYiItxklU0m$iJuPWj7Tm9xs61ym`I%W5)nKIH|YSwgmU}ad>#+4RKWS zjjzl%7G&&iZ~Pfg&QQ7cX)zfK+))Ot$2C!}S3Ew?CFg7}JWoyT`*dHXQEa)U>&CbE z=-hjsk6`g#VEsbV)!$Zr;W9TYt{6y2AO<8PieFZKFrbSq6b}3S)W+^#_aAqShn(hw z$(sl_B+3l6dfwcVSa5q3PoVJ5lA^5IzEWodm1|U(#7I}AH*w^vj<9Uj z7rOGs+-@5$H>2do&(6B`F3(@}fAae#=H;;`uuo(`PKo*CI9Iw!q9 zI?Da#XV0yt{H{{hJy2&JqWD`qNm^gbv0PeYT1#-`vy;B+Js{;Z<$qbIPGqc(%wWn} zk-sIvpQumQ1`%F*YWJ0(tkRdSlaNb)*NYq8KQZ_*16FzKXc=q_l4-_|7*E zaaI`H0!Q)QN3B3#0g=!RaUbPY&g||w%Bo$w(dTT#1{Wn}tXJaS%3EV%o66CCw-<8vN`_{JID-c|uE=szg)x@+PEsz+!gSYN%21vwHB-@5+84#b{ zOtP=x`&#pgvMHkUlYYW(rijk)NNN>mYep8su4ZvQZi9$I*1ehanI3oEe!b>LNt8H) zV~JLgfFn{Y{m%u#S`^N&l2Z`w+%0cAZNm1vg*h@Bag1zO{gXLc17^bK!f19$Wz>ak=rxW*-WDjyZmt)UP$Bo6gp2q-V+e%`_@)&v&Qbrgd6_C|QSuA`2!)VbKE*tT7;j8nIImw_Y$oZcl?$o*D} zx9<$(vlGHjfT$4A43R%>^umsJw0wlu>_n92k>WEf11SOlQUBMnn_u!%?GjDR%qg+Q zW>eYHbGSi6@1tMSd9yes2Lm3Jqmb%Gt#T8zCkb(JaHdWzEvr~|*kumjpoQ@9J6>Z& zo$hE}q9W^u%NXAr27FvOFwD+*OZE`o8A;^SiS@g0c)1-O$7T?$mpC{v9aPTFD-}7#_Q^ut8+ss;6ca+c+#vTmGreJM0+or3h zn4SVGKO?Kv9A9L&J_LxE*H;n@&ZuE_5*Lhc$K%n3-YxbIBL<|hQxK@ zgX5jtEzD`mdjr_x7OY|k^IX?vY4oq(B>pJz^qYVP%fdCslt3*OoVij~Mcp))NZuU?WZ^C4!uLNmyfW zb<{&tyXsn_UwIWdSavLDP3qlRU$Q}}v(N(8Iy88slCZb5bY~(Nn5gC^H!3kj9&0x! z-e0a&uiN<~=2|E1*rJ~{GW6rreXy>u+%jK}3!V|sdA;ZSNe?;~&}S)UsDW9T+~4_dZFKRlq?O_FZW zs|D%8o}|wR2&!lpIFBJ=RuSS8mP}@eB&?C1EYI~(wMm!k){FUHpAQQM`54=52adGN zn(4{1MgNov zt;)$vLI)N74(id=wALSiXeH{muJ*#m(qU*F+X^r-~c^w7==o0*NU^IVju z-!GZES|_v~Mc3jf z$)~}%0_P(Rq4EpVz|A~8MGv$)2Kv?U#t!zZlR<(_GD-T=K|Hq`&_-wi2H*D;(LL{; zz^lxT6L%S(7w6&;lpZv~RyPbl-R7W`%8M?X^y0mL3Z+*~t)+i6?v|b9O#leaBTa1I zpm_o@IyME7FyKx?YpPGem7U*SRFhs3PKA`s8;8GQ%{UBX>g%h}#5Z}@9H!NB_%2YS zL5EyYD*wU0NMF#h>Q4)P{h3j?Q3sqHOk)|{&n5NQDAy)PR5PgF5vx+m(tH6tKjHso2Lm~+6N5p(x z8BAw-9wNbfI2wf<%+4HE@9FT#x z5|g6OeRW_zv2zG70Y6tluXYXokxva9&*lA4*!3S@cbKW^FPP4zB5N!e;`M{@mb;^ z;2%I0)YZk|2ap8<@_-${j)=p57!Mye9}mMHdEsCe$3K~_Uk!ew{E^cGX8VV%ySqEL zyTA`&1mVTUWB5>A=LZbNW$Ofk1Dt^1pZb4T{7+f2f266TB|$)OpbHoPhqy?qLTsGq zv;a^5r!v3^MyF`kmhFJ39l*t2lINFf-%UW^-~QJ?Fl^ESbP52NC!G!)426l~;IQ(s z(W%=y+0(%xi0==4?ECgJ9S$r1e@j4&>Nu6sN3l0ts51st)c1}OC|Fm|uh1<|MA$+lg zJAiS1dh}h6mF0m8n9dX8N(Z+A(+SgAAq2rLU=SUGgS*edhJ(Y-&Q7O@C;@^Jxcm+2{39|vKi(vw86l%^A^q8q{z~Ki9lHI6&Hc^rpRmkd4S7+JkbaH?zs3IV zrhi4eel?{6CwJ{kJ`!zsvk} z(fzB84gEjL{I&%DP3q4#^VjM8S1BVVr2qTL{qM#9b%gn~cm+13|1{ocsi7m@9uk7u P#X>ShG=VUV@4x;Fyv>uu literal 0 HcmV?d00001 diff --git a/node_modules/toastr/nuget/toastr.1.1.4.2.nuspec b/node_modules/toastr/nuget/toastr.1.1.4.2.nuspec new file mode 100644 index 0000000..e9c1ff4 --- /dev/null +++ b/node_modules/toastr/nuget/toastr.1.1.4.2.nuspec @@ -0,0 +1,40 @@ + + + + toastr + 1.1.4.2 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + https://github.com/CodeSeven/toastr + http://johnpapa.net/wp-content/images/toastr-icon.png + false + 3 Easy Steps: + +(1) Link to toastr.css +(2) Link to toastr.js +(3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + toastr is a Javascript library for Gnome / Growl type non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + Added AMD support (and backwards compat with non AMD), toastr.clear() method clears 1 or all toasts, optionsOverride API to be able to override options for each toast, added onclick callback option which fires when a user clicks the toast. Also cleaned CSS, merged CSS files into 1 file, and reduced jQuery dependency to v1.6.3 + +Fix to the toastr.min.js file + Copyright © 2012 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/nuget/toastr.1.1.4.nupkg b/node_modules/toastr/nuget/toastr.1.1.4.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..badab22354ec099b9bbd27e78cb42552a32a2d0d GIT binary patch literal 11802 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 AK>z>% literal 0 HcmV?d00001 diff --git a/node_modules/toastr/nuget/toastr.1.1.4.nuspec b/node_modules/toastr/nuget/toastr.1.1.4.nuspec new file mode 100644 index 0000000..5578b3f --- /dev/null +++ b/node_modules/toastr/nuget/toastr.1.1.4.nuspec @@ -0,0 +1,40 @@ + + + + toastr + 1.1.4 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + https://github.com/CodeSeven/toastr + http://johnpapa.net/wp-content/images/toastr-icon.png + false + 3 Easy Steps: + +(1) Link to toastr.css +(2) Link to toastr.js +(3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + toastr is a Javascript library for Gnome / Growl type non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + Added AMD support (and backwards compat with non AMD), toastr.clear() method clears 1 or all toasts, optionsOverride API to be able to override options for each toast, added onclick callback option which fires when a user clicks the toast. Also cleaned CSS, merged CSS files into 1 file, and reduced jQuery dependency to v1.6.3 + +Fix to the toastr.min.js file + Copyright © 2012 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/nuget/toastr.1.1.5.nupkg b/node_modules/toastr/nuget/toastr.1.1.5.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..9dc04428750b03b31c15c87516a50bb5417d1a29 GIT binary patch literal 11634 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 M6{ + + + toastr + 1.1.5 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + https://github.com/CodeSeven/toastr + http://johnpapa.net/wp-content/images/toastr-icon.png + false + 3 Easy Steps: + +(1) Link to toastr.css +(2) Link to toastr.js +(3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + toastr is a Javascript library for Gnome / Growl type non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + Now using SemVer for JavaScript files. + Copyright © 2012 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/nuget/toastr.1.2.0.nupkg b/node_modules/toastr/nuget/toastr.1.2.0.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..a63ec724b7b5dcc1851dbc027152d1b9678116c2 GIT binary patch literal 11716 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 Sp`qwoTr@LO6ENWVcJ*Ju;C-L~ literal 0 HcmV?d00001 diff --git a/node_modules/toastr/nuget/toastr.1.2.0.nuspec b/node_modules/toastr/nuget/toastr.1.2.0.nuspec new file mode 100644 index 0000000..d667d56 --- /dev/null +++ b/node_modules/toastr/nuget/toastr.1.2.0.nuspec @@ -0,0 +1,40 @@ + + + + toastr + 1.2.0 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + https://github.com/CodeSeven/toastr + http://johnpapa.net/wp-content/images/toastr-icon.png + false + 3 Easy Steps: + +(1) Link to toastr.css +(2) Link to toastr.js +(3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + toastr is a Javascript library for Gnome / Growl type non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + Added getContainer(). +Fixed clear() bug. +Removed semver from file name. + Copyright © 2012 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/nuget/toastr.1.2.1.nupkg b/node_modules/toastr/nuget/toastr.1.2.1.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..34bc06054b03e4a9b9fe5be6720a1d0996b82129 GIT binary patch literal 11728 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 gwRj3Pl>ctN(NV`hZp@(|Nn9)x6J!^#h($ literal 0 HcmV?d00001 diff --git a/node_modules/toastr/nuget/toastr.1.2.1.nuspec b/node_modules/toastr/nuget/toastr.1.2.1.nuspec new file mode 100644 index 0000000..bbd307f --- /dev/null +++ b/node_modules/toastr/nuget/toastr.1.2.1.nuspec @@ -0,0 +1,40 @@ + + + + toastr + 1.2.1 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + https://github.com/CodeSeven/toastr + http://johnpapa.net/wp-content/images/toastr-icon.png + false + 3 Easy Steps: + +(1) Link to toastr.css +(2) Link to toastr.js +(3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + toastr is a Javascript library for Gnome / Growl type non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + Added getContainer(). +Fixed clear() bug. +Removed semver from file name. + Copyright © 2012 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/nuget/toastr.1.2.2.nupkg b/node_modules/toastr/nuget/toastr.1.2.2.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..75ee4ae591e6f5584760da953566a91b1f00eabd GIT binary patch literal 11719 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 Xse+Eo#{rN4?hSwuati3Pe*5%aW{yfS literal 0 HcmV?d00001 diff --git a/node_modules/toastr/nuget/toastr.1.2.2.nuspec b/node_modules/toastr/nuget/toastr.1.2.2.nuspec new file mode 100644 index 0000000..cca8187 --- /dev/null +++ b/node_modules/toastr/nuget/toastr.1.2.2.nuspec @@ -0,0 +1,40 @@ + + + + toastr + 1.2.2 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + https://github.com/CodeSeven/toastr + http://johnpapa.net/wp-content/images/toastr-icon.png + false + 3 Easy Steps: + +(1) Link to toastr.css +(2) Link to toastr.js +(3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + toastr is a Javascript library for Gnome / Growl type non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + Added getContainer(). +Fixed clear() bug. +Removed semver from file name. + Copyright © 2012 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/nuget/toastr.1.3.0.nupkg b/node_modules/toastr/nuget/toastr.1.3.0.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..b4dfe38ff44c553f391df402ed4901dfe046b099 GIT binary patch literal 15020 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 + + + toastr + 1.3.0 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + https://github.com/CodeSeven/toastr + http://johnpapa.net/wp-content/images/toastr-icon.png + false + 3 Easy Steps: + +(1) Link to toastr.css +(2) Link to toastr.js +(3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + toastr is a Javascript library for Gnome / Growl type non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + Added onFadeIn and onFadeOut callbacks. + toastr.options.onFadeIn = function() { console.log('hello'); } +Added option <code>newestOnTop</code> to show toasts in oldest or newest first order. + toastr.options.newestOnTop = false; +Fixed margins on full width toasts +Added LESS file. +Added min file for JS and CSS +Added missing vendor prefixes in CSS. +Various minor bug fixes. +Added unit tests for new features. + Copyright © 2012 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/nuget/toastr.1.3.1.nupkg b/node_modules/toastr/nuget/toastr.1.3.1.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..a1eb1ca399aea4dc5ed838b95d5fce764d98f2b5 GIT binary patch literal 15568 zcmb`u1za4-y8n#^*C4@yySo$I-Q5RgkQpqv6WoJ)a0%`f+%;%$f(IuAe@S-Fp5487 z&;P#nbAcYFyXyIs^wU+U&Z+mW~eoI%zOKtVEACKfUh0MN|A+!|;pNag~zVB{ft zBP5^-urmQa#{gMbJAz1_O@JUlGAl6Hk&l@fWM&1hHvus@I0AsrAr=nK_9o!xQ)f$N zM-ww!6H5Ry8w(2;^K)+gtwHuzO%invN5Fqkw6`{Mb^tk8fSJr3?0*+~&eyXXD+@CV zH?zG7(Aok30+W%bn>bqnz=CAVUujN z%wxvO2>_Uxv9q#saG060^Kh_pm{?e_0XWQ9%uTq>m>fa&=4Ot+m(SFUmxqPdoP&#% z$ArUz`?=W9eMH};cjA$Ul8$gZ(hYBs1+lD%i>oF{ z-R2FcX-g9ZQ*SJG(ut4X_}({rIW1c)XWwyUm3 zg%3RVH!m^X40^#Fw6#m(!A%MmCxyGT4n=m>QC2#IhM*xwUJk&>*-APYs2N62o4z1l zYc-3P*RZz9{JcTgA)@!l)! zNoCgx3(~g^qsM08+=>_rmlDsf+q;nF>r4XSl7eh<8%(;#u{UCrQ2bDb;fuH&lID`XTbZW2&%7w@nWG@P*cz2ldBO|u8 zN$fD=${;}_Z6Pn$XHT(6Zz&wPgSD%N;(S08ZSdy4u)y_Q3C>I=qD_9>e0Z+~S185l zSzz9h<*`EQQ_)%R$u6l|&A>VhG*s>jRb6ysgc|&>5t z9ipBrxu2vhr3}x#T)_=nSV@m);8JHB2F=WsUr(b_DLv}8KY z*L^ki?@HR~-i?o|5g&XmyGkQerhAYO!zcg&I~xz>=SHq>4e>=wVcIb%hcX8kJ%&vZ zFzJ183>Ud5urP}dEp8xI@v;3SlQ36YZ@QD`MCDd`r_+d0F02MWxVRZ=xahYNK6V>* zLVM$8biH?=6~Kt%54;;lHYOe&I4NV%kVBhA96KA}6in&yxaTD)on#*I7+AWW+DxA@ zMW2NPH9aPNC-!Eeh>(hjmm3+8zM{z=U|UN6dQ+g6n{Z}1%kIhtDb&BU2BCjGr8Qae z1pM^5^RErx64t>W?sLC+f(-$I|J?AIIRL=`Ao#h_{_X$o4WSw6KlYoSwHM>d1~I&| z!*1XfUq+|k6-vR!2Hp1a=pRLJ3Hz-_DfFR2^^%2lj-owMJOx<0T(_?@-mRuqKd^n6 z6rCF?7t_=XAN75@FnYrstj6u8Fk8^QeX{1mo|+Nf)_fQMA2RmP%c%O))3|oOwd|1P zr=vWN>J_jGxH8aEe>BkI{R&?RMcs@bBrxh@y;H%uTg06=>lAqDgk2>aao}^lvd^{3 z?MRGcuiW16+31u%4dV^kg)>y)RZ!o)PG}np)JjgvYvVVVzO0P6r}E<97(S-n8xy|T ziynv|*!E!)o9b+<*}zdyGj|vj2={&e0glVs(Z=vJ#RT9x;}PrI=2hWb`;aw0ljo3_ z^{R8yGwNRaQLZ#w+b6_J?y^-%!Xc8GdN|vyjNxFcC%>^9g`~$ruu9yHdJWF^d#W+D`TY^smfYuMlWR~;Z7`aBl-DOh z_T5n>xZ4WK-l(MkY>sK62^W_aJ+`}{(MI5yO815HAvfad<66ca_@`Qs4$j@?s)^CK zoIS;->^B>{^qG0!w$M8n9c-5Klhpi_D348LUJq}&(xY94Z4C*7jI?YK-H`F?Rw?q% z*gZ6Ef{EL4`v!N;J0In?QDLJq#J2>U-So_Uorpj70v4Z+{8+KQ$DoOe+T}Ff9Et0Q zD@~nu=w;PNBxZ*fah%Z>+YNe9?o_L{Geqk&Roi6LqlST zt|$yGM;$Pl?ScDfWgKOMd|AbFMglQVQJ6kjnqp-~|SZV!K|-MoNo~o{z*W z^{CS%dCXh)Tj)4kKzG&=i5|Slj=qBwhsr{O7{T8qF;K)XoA6%ZEixsq>{--wOq+2v zq_+Q3WtTCELyvFBJTMv}S&!@C+T8WQ$0gaez9~(!anCJaqEtG|%(+I426rloSHT{a zs$Cf$v87Z+pPm{9n9LX?S!GgNWLXw+ahGqe(yF#;k-@=E2sw&O(krB!ELX>~Fs~`0 zoqxcJly!gG2G4ZCOQ}tVS7?Yy${YW&bo`7$12XYo6QXV*gkv7@vpaMiYs5^$xHBRg zZGGi>F6(G&D6QTn&QVStp1cNO%E;!?&_&XC<8l>7%Z1Zem%8X5T|4346SZ~thaOYAIf-K~yn!_wFk zitriv^Xkp;U?6yv6FHR-cj|R!OeHmvx5TCz(P@VD=yQ20S{baBGpti6V3ppf;gDZ< zv^LcG>GYI&U%kc5Hnf+YiN0ho%%l^~K-k4bt_D_$O5D#(#vzXod>qCL1z*|P})5@iIlXF|<%N0|ca6 z;o*Q^ZmwwI6arenUfOcb^@DU4utR$Sp9`^gkv0I0GD%`UWC4HIu80fdxy$6wDRkoj z05?8PPt(rX@4Yxhl*hDcsnjD=M3ZbADlng$NC~MJukPrZ`>SQHH3WmN!b7 zv$%24e8aZ-W+w(lKKV&xCZY%^6sdVBk&3H9=oyR6LO2_JirFp%|WEPNyn@~^rsr&g1aEkMW#5m7pY(HPLd z-K%YRWq;~u!v$+umiMi;q6y(HsBkOaYIfb2fn)%>g=)4%Oy_lYo*#WYrHBZ0DVsA3 zWN@#dTQFyy@ols=>j;k)XA-lvBKCY%b~Ql)t_rglC4!nP(x`gjRZUrM8flKGg>F_E zXK8Mo2V^2Li1VH1ehX?HWv}qtV;Hq5bAOs`7s^VxBs87ib&;%ubIJKzHY5-Ut#V|cYf4dF4(`kujVuVT&gPl;j2a@W53-81 zDf3gg1dEs5zozPuoG_|j_EBPaE~)LXR|!TSe~LJYgIRi|$F7wnHnjuwRb5)h^GoJ> zoU$L(`*(i+eO}6g0KQA6hH_H*E^Pg#NtX@zeoSfV{FW({yq4jQSI$+(eX&!0qp=8T!XuOoBLEsB{^7KoeE37!;JD52VIo z%>v`1r#ZvNQcHi-cWfuik&-YYvC%es-;h17yzqC!!DL!5iTaKspvqQ=tYeb~p)&Rb z@z7kMUOT;7TH1cEA6D*$=b9d*jHV`EI>ANNKy3rSs2sB6&Y&;Rm#kW#%*8f~&1Sa7 zrRE49U72RLs8axPi^wOQ`9&)+z~;~1E02CEBjt>G6*?S0Q6l-ZfqkXqQk{giEvD@S z1_M~9dR}z*x@5nPu1K>NYdRN2@Qb0Dkj_1K>g7YjPzBfHe#BlQN<41grJ6yT?)}%E zk)@?(j=qupp7gD2eayTcJ%<`Gn{qObIshTi>CI8n@Ew}L1Y%_j^T&C{VmJD9O95A1 zM*U6fM>(BsGk{zrJov1b?Lh_Qpl0x}7==n+S&HS!>Gm79?+DZz=l)@aOrGX9H$tG> zR_YTI7~Su01n{49cQ+-n0|+CAcCQDh`Xc7AZYXXCqNda9^Y3StYD4Sa6a|?*Imj+J z6b6}{sFDpnaeu)6u1AZp-I|z;bbhURs~WhUi8Di9_5|_Qp(gWjLH+Y&3`7JD1O&l9 z4>j!o|F5y8UTvOsjn694)Km8i5h$6j+R@1^(Sg21Q} zpYH}l3v<2ge8zE@hqZc;zQ>JbthhOeTp2Brn)x1a+w=aeZ|rhrrGLzhn-+hFKlfVBAuO+A zhkpZ542`w>5J-#-{JwCPogJ-%=)D`aid2oTVsAlpLprvpB)2v`Eg*=MEeyUKMLSFn zSnIgovaRj(y)Q}ciIA+_QhH*1vNr^5xiGTFJZHl|@O$|vXOEAkZ#p2Nq5bgv$|<|0 z?Ir)EqQ^_2($t$m>}CZB?`pCcRASFJ`72W_-u|h}JUhEOZgoL}p@vhP2_?r?Lmzf= zfnp}D`5!1MQ?IhIqn9QOa??2y&(I_Ldy?au6+ueV`3Q3ex>L=cgQ{y0-Zci*IdLB) zzGNrN^y+}t3U3j6D3Km(+r#z2XwGCuwN~Xgn}xC$NRk|{rFY1vPTw7)b8TZ@eOTD{ zX7ROGjI(Z5;eIqOQc0`NvZY>Vxws}+&VO(C<;XS*cMTk2(4;Ztrr+9a^uwBcpF$x^ zy{%uZVBm3sP~u_Q4Y5jXG4{2mfulvEHF$pIhZ#YGuO~YtJ!3eBPuW+=2eoirhB!|e zLuKS@v(LkIv%9U0WSQpuWv=p| zrv?VNPUq!U9!*>>vrc6LtDq+CUL)P()d%+y)5p(B#sr22GIrA0Mo#Ta7ALH$wu`M| zD4U@>ch^~4M!*g1bi7M~46BROFFQXRIf#m0zK)LhTsHHno&C#u_aGsR4j;Zq{8g>a z7;a^SnokUZ)QV4i{FzG)RLzTeg`dB0cARknHE>kgd)cQU?KWSSkk5%E>^j3Ix+Tfn_iRk+=F^-%3Lo`?2^ z*TO`|HK?1_Kbw)=jrvDbhiv6n%uEmq>{zv`>+9OUG3>=GKSjv)oBUi5(FP;rkydyl zBFTu8Cs{oVZ=9%cr6|k^5KP!KVpb?gEk@cl3?2YVJjr#0Y4kJoEpiN4X_B1NCI_K$) ziYhb%(`bde(2qJ+SDFhfgy4^-A@r*ZsAW#C4FhZ}BE#I-^4G80Vo-`L2>i_o6XLYT z6fg7@tI`Y=OF2(i*y1S`1oX)Zf{$idB`T@#IpYv9b!*ZL*=L|N36*}BzV9&=L$QQC zRQD94o)4W2*KsON6L?kXhemkmo{_gd*JNlOq*9AGv(Y`I^zvHZbwV4{OGEQep?DHf z@)PZ75_Z3Mz3 zz?I`+1dH+@QW?G@!TVWMC%^8(^l-D33~8IJw73ruPPme7#!IUoC*{^>k8p}g9k)?M zH?S(2)eREA_O}zd_(bIF;hfbuD-k=A1Y8{#EY?{j8A#LdyD&}+Br?HwK3rB`8~J$2 z*M5=@cbo1VtKqnl+eYa08BQ2wfol|Ct$bZNMoXt!+)TS?8zKpj(i&g44sY0sgCrX^ zB+pGm!@~y^d?Sk{qe(lVhFCz27-BLU_sOq2EXs^Aa^VB+sg3@(@K-36FA8ZqZC;I{ z;*lZW%-F$Hw`@9f>Z3B7$l7$36#sBv(F}DA9&)uWm(Ri$r6kIO$M{6|1&LpW=t93f zYOz+3C?Ulw_LEs3CU-C+hX^if`(F=SEZ7-^CwBof+&iUkav&I|@e3QEsQA2DX| zCfZKuRCidbS>aUBj_8$WWn@<)Op+=Xx{}MBs*z(Z25WCyCm>vQb59#Es#BN7#@N7U zQYS8Mpz^%Xfm}HZ;moXN%dlpFx35!qpP`e1rp}UEs9FfGNfak-(?p&SYVH%RS=2nf zCH}Fh@8%qtp;J@B)Q58@j(&L$V|-Ti)648J8xzrt`}#Lfn#z1Pq>vI}y6PVd!Y=GE zEiaKVAFXqcrA_y`FW%zGEQ?q05;FP|QLv7dVCPTjptsJPJJN9duqd@V{Tzmgvg@p% z#p(9x2(qf;n(V!idf1>bx~ZIvawQd1A+((uy8e%%3)(l!t`|_Z?+0o4e1~a>p!qyv zlTTS*AxjcK;WgosbRoU^*xW@{;4x*bs~4}IoHpz%bBmm-s%AWy+Lb29b(ZeJ*3gZ* z)0)|k4_WOB@#c(D&a@44*OqCG<$K1L1gK!>MG$>P&yYZvoE!J(j3gW!oNioA2*WE> z5Js{gwyOF^+*v}q&j{wc!e5&*-qZAmh^$M+7e~Zu`7v<5;t(eD*D*ASmRv8_W2R!S^p zK4m}gn~=3LB#H%9VH{iYWc!Ojr!X&{*GwwCI@){gZ&Q)U4mrANc=722E7}k(8XBN3 zqL{)0Sb{|*7N^~Yz~l}vF{=okgVKTq)}UqTO*Eguiy?JS!!{`!>ggOU<3ebSFKo^@)h?hPi+hC09wx<9 z@(F6@#^=afm(c+(B_$hKzKL)!HChk9UAHEgrk0h{tgtDb%gLKh3V^Ok!`2Ypz*m55 zS`UW4e>H1$K^H%*I{tZovbEGy1>T=pp*e`b+?Df7>LSx7f~)$CtN$q<-&l%m%NAFh z1sof_%RbldW=lYHLZs|~}$qw%d231|(dFW|;-;@H?q z<*;BhAL~W|T&A1g7wH@X`p74I>1+~Q8uL!MXS0Iq=&jsJ7i15AYq5DL)NAp%lOMAu zedoLZ@=77%VffobJKfZ!ol<9G)B!qW^yfp3AN`ftZ3{#Vu4|w0OrAt|7KlUHKdlA_ zzI^`9euUQ3{myMep1L zzu}V(mZ(Omk%gwFMV{>ARgABX6@8=i$#TJ1PmGF2!?i(5SCjW?set?24IGo1CYF15 zBaUkW4Y+HAZ?9js@qufX@6T*|CxTAC7`-9iuEgCTexR#52qn&^xfNX}tsFOb2tW0H zsz$l{E(HHj>bhJ&M?74LY}B`O;7FW#e%~P%!1c(ZNIW@kyMuJ=o-b%jb2~%-rEIBz zZdF!5t%DX^9~Y|PITO7R`gq3I8nr44L=-Z~x@w1Qf92cnZThBzVS|1${WJFwcZjdo zi(9kPF9n3$N6MT-_MUkKXn_MG-l{K5o<24i7kC``p&x1GSeCF*4O zR@mwqxIHU?PJTRgJ%-sCe2Y4N#jdSY#MboWeGNo9@2NpKY`o_a2mW^Zih^V{Qjfo)4FJ^7SuwO3rdpkO6;S2J7%3K zCksAAp;9Y5psYWM=1%|U#|q72dH;R}tdFA*q84QC3`!JNv-=|7v1q7mn%+%B|DNYq z6|zLj?Qk*2KcCJZJ?Kc`PFeD2^9k6JiF z!hsE@2BrijDi^9J774ZoH@hnr85E_LdDJqwefr`g(`*J!^$jjIOq>^@&1xmnD;#q! z^+lxT=m$;R{smp|vX!8H4QPp(Fo4bi>4l-<-6wyG_9Pgf5c#%`lRADyi?%EGA-8Fl zwY1KrY=eju8tW*nSd}FXyP6*U+cX^m8}1i|DxrM>j}jwr53AMt3W*-D%w~o3 zP@^!W_&K3HgcYviU&~1|bgr9F@^g5{Kh1z;BN`<8nzJdT-eK3ldHF^b<*{#>EgaH1)rJ+JXV&HU2o zLYJz3OEGJtx4F0Y1B-kmdpP|fL9_&fvZ#guVxpD75+yk{*uE7q5sJV+zNUdaZN7CT z1M+j6zm6tC9mj^F4S~B{5&R-$8xL-0QP@ylw~P0L@jh882Exl2B&ba>=6IRLPvbfg zdL(UdzK(O1gL0{cCN!dej}zbHb5qq+_S|57&v(`E=gBzvFY|<(AzJ+0 zrf|Zf(qm?uIYNBHxa}lK*@i~pl&$&Y$XXCmzXrVEWLq1p7i$(?_u$lq+n&8(4Gx2! zbZ+XGy`jifH_o2N({hD6v3%9{c{>iCbXTbqMYVTC*nbHf&Q{3D`$feC%2uE4g=jcZ z2Mm|_eyvEcsw!{uDD&5bl73O+{N9pCk%JidGNMt!@)#P+SV*1%7o?t%WVgVQXhwz< z3n9KzdL;qcLaG#2Q2iXG!=QD6v*;&m(iOssE0t=Ac-iZ~@^Zy4xfg1Mi4k%yb9eIL znppUg7+!X~F2Hk<=R$yNt3ygFhOrNME8n6wEGtNF;|f`_%`-*K5!`oLr}Oook^|0P zoPWIt07+mmwr`h-v(Xlj=PC!>y-n7C8F>V=D_8$Ii2PVd+_v_8@Q$6RICKKC5o-ca zFu{>veK{Gk=8dM}*wFPr;Bj_a&caT8jve6wxS-OQBUL_(Fe^F(~+po2qNPerk=Tn-{sUgC;7L-=yGf6AvVU=I{{4xvCrr^s`BP z*&rHcyq`OBH?<~c4sz3w_9Dj@-emq$h;@ouHF zt^#NtaxBgS#1yQKT-0O~G*?I7Q`EC4px~R0PwbjXXIiLhR%EUOFX^+$kO4e!&90qy2ul3b_ya6}A`o z>ET=d?pQw(d<+hIjMv-FW206P8<>b@fx)8ed1VXeS3lH>HMrr z@Q3Y;LX^V7;kCj*R4)0(zTAq;O)JoD_90aS>S^o6*~u%4)2de#C2xR^{=Um3GTwdb zUXtGP>u#%N0)h_&e;pT6XKthV!$Cl35I{iS{b^hXGIO?e1cUyyEzIUWF6+1Ji~*M= z(S_)RS4{$6{`7Eove?t=HYo;HOedm$PamB{m@OdEIjIq4xbcEqA9v4E zzj3ec>W!}^wvO3%Aqi-yHh6&wOJP6sS~LhvdFq* zzBk(3$J~$xHd`?q#q@!iAKF5|hWpF~wzRQH0;mtd6~ly=nPU7pRMCAgoIYq@1M`#L z-`r(t4A5gPV#&>|;&Vm3$A~Zl=dkEub|sElSJ#$tF2*Mt&1u!CNGVpFeB(`0@e?~Z zSEtV+Lof}uBBx)Z+-9IhGM(0@3K~C8J9n-o@PtWiimgqRTT@SSK69;x`0{>u&^`XG z6m|S$7n?aczGx6j1gV~6bH2R&XhzhK^%15M)#H09$-v`RC^w=DDQ_>C&qA0l#xfvr z4bpr1q@iNAn@V?hd`}vHvSc6eHvO1V8;zD5mqzVZ2;OR2}^#pK=QqsuR#y$iUND*3|$n(+P5^H(X{xj(mc};bS&u&=hbm3@=ap^ zv4}_bM9&M=Mr_0VSpxrt-a6QZUclg^jZDi0d_*A7h<#>2F;IS79*I`#8G<`wifQXaul;m4 zudGHV0CgV=#hOnLf@2fO|ISY;Ye0VDX)kW&9sljH7#w}Xg%z!7M|V;N(LrTtBzwMv4wdB6i!KZYW!ChW`GMeXH&ToPgwqs@iT1qLeCi^` z`ruZ)faI4C@OH;mO&RQvHH`=%4Ol)YE$D<1>sZZAp}|u3<@fb!sbd}q0eiMoCqa*U)4738T3kaCdc#DTL#tdZ>0EMwjPc{&PHDjq7 zDv<{JbGYr@Cs&dtS@JSj9D~1M`0u+&kG24%ZQyh8y#x6V^BN4)ZTi=98B=JFQ+++) zJeDvk2U@C?@4X`26zg$1hx{E`YpMyMve^;)?86aNH;8Brt)hhLJW<^Y{loU&lnb6H zY$%6IlSa6lj!NJFCpo|uQuux_G*JrkFh`y{W9=3PliOhU6t8u3x()TZ*$MUbSWPhA z9(?3pEB8WFz1j8Fddpx$;eNj%GY*8`h*N z!?tOWVcY^mt-Cb1d5*~DrE8|*C#ouT9RdmDg6*sI zp-Xa>Xw^qXQP`Fb!n{CU`~Gu)ve2A-2)&N>-FFit?gbB+hdez24jxi9jfdnH)9XF~ zuXW%&m=k>J&ktM$v{JA>5~`rYl&306$Q7l4xDEc_9H>b+`mJpGu>qeXkv~b7N;VQ{#?Rf076r}bP z{XOrRbg@YL4xt{5o7lFW&59HdyUe|HB5WoE8e154Dl(EdIQRO7zct`p>zZ|J<)fJ#Sjx;zIAh-Q!iC{IN4Aij%5gYPpX5^d8hAVpIj9kb^WJs zLafKgtd6%P-}jKluqAmMX3f###GZI{;M!BhVD5?GN(QKEt&IcqH)%CroqecmlTb&W zgRgf!T;?Sm>NFmy!9iO!S@WG@un30D&9c6dn;o-QgnDU{>hj?wtnNq)4x+zs@vRC_ zJhvBkjsONnG4fixJMLl@2N}aC0(U1SvfgzP9lcx`SCqD3Z(}TX6v-pi6f@F}8{H?P zSPq-M{H`YoOHrgJkU6uT0WNCQ+E2MwZnn3k>WFm=uVInb)b+NLwH4#*+3f$Om;3%@ z513$cA+&-;a?Vtj1g(VO114vHzIU$b+l3k2Io94(7Bn5qQf8)N`s9U#^w`A)F5>Ewp;TXl?`y z9a;#}^76xDelSDR3643I*v^Z$`}hzPtF<-uVkq%p8Fpy#O+>m0$k!A{Yw)%s8mE)d zuj5a9rQ$O^t!1Yg!idV z*gsJDc_dTNP76}%glz>|5FnFGCGB#aCo{372C8is)0g0BZ1{{-uqG9`QzS7RXR+W? zWbAnk9?_F*N_Y`FS@=6jAzTSRpozPEP*JVmktN=fHpvR-wKslITL{X@aFcLX@5!f%g9SQ<6Sh#$~ol(4&{3(X%IztH;Xj-SW%}IC7%19WB-)syr(!j zq8}5Xzwf|E(kE>0u8A$Nb$6h)Rv?3K7tIJ=@+IwSt;@*q8#bzOB7IlzookzNiqRE}_CEfZg?1u#$gfE$&)?0M`cs5GdNO^WV~C9-9Wzzg z(*ac^2?>zqKjxqZAs~xd&wilDB7o0JL*wj4TO8%wCa^kkoFL>7iyszZ-egpycYkvf zgr?W+{FoGn)P3C}(12BH(jAab?>bi5|LzM4ce9`?D}rK7iZqIZ|LxKG1}32V%dFd3 z!Y(64Xq`*G?OMj0w|VG$t)KfBTW0_pA2E#DIZkCC1fE3U*JLyf4ZI{?DHmPMoNQbX zgx^27y?_5ksr-8(W@k4MRME{vj8R0BzkPwJQgXN1SKptF+P_JiT_XAfBWMVSpNGnG zqxOH!g#0IZ> zA929|XZwFcLVq^+74k<+caZfTvTkl}Om6JIgrAWiR%UGld9`135u-H_1U3Ph0e;v2 z!{UDmAN?bqBP3vM#%JaXFabL_3&}cI0ZEii98DOcO@JU0Nt>PmyXVrGINJ&^|0&u} z6LY|C@0QO{ln^_KgbB!lL=6mZ1o0sv(y-E!$Xf$#Nx%-zf4_L7pNkPBh%{{fCE&T| zLZo4*CD8x@evkXp%G?^{XlLRFDT4B%f1ocn)_a5mA;QF*C8Vdrln$c+T##jXA*H;aAoC zxjKGUkG1);OITZ21Du6^OYm2$KV230ojDU?WnyPy6=43?=}%)j6QHHbGdCs#05WQ* z{j&Vyl7KD1!_C3j9Q3;`!*7LTcrM`2^vr%CW(?0YXkzDJ$v|S`Zks% ziuiNBe!K892;^dF126*%DY{4jz|XGmi(ey=aCfwOej=QIW#wN{1b(4j|9(n-F;@S6 z(ntMug1Mj|AbuV%pPzI+vELX2qo1f7$bji5clUq7=Ka$9Uov^Wa}SK*pLu#_^27la zCN6g1=K?=t5x*gU&)D8G#P)mUf5Y@l93Aa`uW4pip!wg(KgQqNw4eClzkxsc=kopn z)Bc+z{zdEkVDBM`R;#fYxBRh{1?3UkH!5Db^15D z@Q+$${^bSFE(i(52=Q+x{3{sxcmDHFnCNeY|3nD>*^uSgpMP&de!FjfH~lMP^Ji1q z=NY=+J?_6DZvL+G*A0|^)=9+pN1dN{^zTA{T{Ql)&_3Zm3jMx>{CBOtPBi{m3zGWZ zTK{F*@$WK!eYg3u%x9*5l= + + + toastr + 1.3.1 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + https://github.com/CodeSeven/toastr + http://johnpapa.net/wp-content/images/toastr-icon.png + false + 3 Easy Steps: + +(1) Link to toastr.css +(2) Link to toastr.js +(3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + toastr is a Javascript library for Gnome / Growl type non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + v.1.3.1 +Added new API for toastr.subscribe so you can be alerted when toasts appear and disappear. + +toastr.subscribe(function (args) { + // args contains the toast options and data +} + +Added support for glimpse.toastr.js plugin. https://github.com/johnpapa/glimpse.toastr + +Added toastId, state (visible/hidden), startTime and endTime to the toastr info response (available in the coneol, glimpse.toastr plugin, or via the subscribe callback). + +Fixed bug with stacking toasts when clear all toasts occurs first. + +v1.2.2 + +Added onFadeIn and onFadeOut callbacks. + toastr.options.onFadeIn = function() { console.log('hello'); } +Added option <code>newestOnTop</code> to show toasts in oldest or newest first order. + toastr.options.newestOnTop = false; +Fixed margins on full width toasts +Added LESS file. +Added min file for JS and CSS +Added missing vendor prefixes in CSS. +Various minor bug fixes. +Added unit tests for new features. + Copyright © 2012 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/nuget/toastr.2.0.0-rc1.nupkg b/node_modules/toastr/nuget/toastr.2.0.0-rc1.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..fe2dabd4a1048e60aed89d3fc0b8c6ba2d0b2827 GIT binary patch literal 19421 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 J{=A`I{{Z_g^m_mR literal 0 HcmV?d00001 diff --git a/node_modules/toastr/nuget/toastr.2.0.0-rc1.nuspec b/node_modules/toastr/nuget/toastr.2.0.0-rc1.nuspec new file mode 100644 index 0000000..d13d8e1 --- /dev/null +++ b/node_modules/toastr/nuget/toastr.2.0.0-rc1.nuspec @@ -0,0 +1,49 @@ + + + + toastr + 2.0.0-rc1 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + http://toastrjs.com/ + http://johnpapa.net/wp-content/images/toastr-icon.png + false + 3 Easy Steps: + +(1) Link to toastr.css +(2) Link to toastr.js +(3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + Toastr is a JavaScript library for non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + The following animations options have been deprecated and should be replaced: + +Replace options.fadeIn with options.showDuration +Replace options.onFadeIn with options.onShown +Replace options.fadeOut with options.hideDuration +Replace options.onFadeOut with options.onHidden + +Optional 'close' button, bug fixes, and improved responsive design. + +For other changes, see http://toastrjs.com + Copyright © 2012 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/nuget/toastr.2.0.1.nupkg b/node_modules/toastr/nuget/toastr.2.0.1.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..a3a98b2a2f8d9efcc07d5e09f3871fcd52a3e50a GIT binary patch literal 19400 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 literal 0 HcmV?d00001 diff --git a/node_modules/toastr/nuget/toastr.2.0.1.nuspec b/node_modules/toastr/nuget/toastr.2.0.1.nuspec new file mode 100644 index 0000000..09b937d --- /dev/null +++ b/node_modules/toastr/nuget/toastr.2.0.1.nuspec @@ -0,0 +1,49 @@ + + + + toastr + 2.0.1 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + http://toastrjs.com/ + http://johnpapa.net/wp-content/images/toastr-icon.png + false + 3 Easy Steps: + +(1) Link to toastr.css +(2) Link to toastr.js +(3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + Toastr is a JavaScript library for non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + The following animations options have been deprecated and should be replaced: + +Replace options.fadeIn with options.showDuration +Replace options.onFadeIn with options.onShown +Replace options.fadeOut with options.hideDuration +Replace options.onFadeOut with options.onHidden + +Optional 'close' button, bug fixes, and improved responsive design. + +For other changes, see http://toastrjs.com + Copyright © 2012 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/nuget/toastr.2.0.2.nupkg b/node_modules/toastr/nuget/toastr.2.0.2.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..2efdb7adc46c99fce36e2bb3e6655f5cc6233aec GIT binary patch literal 23037 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

)sL(3MV$8au8;Dr)1|4L@N$j3XY&nQ~ee0 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 UQxUyXsPis>DrHf4$CCQ%KPTrvVgLXD literal 0 HcmV?d00001 diff --git a/node_modules/toastr/nuget/toastr.2.0.2.nuspec b/node_modules/toastr/nuget/toastr.2.0.2.nuspec new file mode 100644 index 0000000..1f76718 --- /dev/null +++ b/node_modules/toastr/nuget/toastr.2.0.2.nuspec @@ -0,0 +1,41 @@ + + + + toastr + 2.0.2 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + http://toastrjs.com/ + http://johnpapa.net/wp-content/images/toastr-icon.png + false + 3 Easy Steps: + +(1) Link to toastr.css +(2) Link to toastr.js +(3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo +

Toastr is a JavaScript library for non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + Change log: https://github.com/CodeSeven/toastr/blob/master/CHANGELOG.md + Copyright © 2012-2014 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/nuget/toastr.2.0.3.nupkg b/node_modules/toastr/nuget/toastr.2.0.3.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..6389cdf62c6c9c590316a5ea2adc1cbc8e95eb5d GIT binary patch literal 23027 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 literal 0 HcmV?d00001 diff --git a/node_modules/toastr/nuget/toastr.2.0.3.nuspec b/node_modules/toastr/nuget/toastr.2.0.3.nuspec new file mode 100644 index 0000000..1e6133a --- /dev/null +++ b/node_modules/toastr/nuget/toastr.2.0.3.nuspec @@ -0,0 +1,41 @@ + + + + toastr + 2.0.3 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + http://toastrjs.com/ + http://johnpapa.net/wp-content/images/toastr-icon.png + false + 3 Easy Steps: + +(1) Link to toastr.css +(2) Link to toastr.js +(3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + Toastr is a JavaScript library for non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + Change log: https://github.com/CodeSeven/toastr/blob/master/CHANGELOG.md + Copyright © 2012-2014 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/package.json b/node_modules/toastr/package.json new file mode 100644 index 0000000..029aed3 --- /dev/null +++ b/node_modules/toastr/package.json @@ -0,0 +1,83 @@ +{ + "name": "toastr", + "filename": "build/toastr.min.js", + "main": "toastr.js", + "style": "build/toastr.min.css", + "version": "2.1.2", + "description": "ToastrJS is a JavaScript library for Gnome / Growl type non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended.", + "homepage": "http://www.toastrjs.com", + "keywords": [ + "Toastr", + "ToastrJS", + "toastr.js" + ], + "maintainers": [ + { + "name": "durango", + "email": "me@danieldurante.com" + }, + { + "name": "timferrell", + "email": "timothyferrell+npm@gmail.com" + } + ], + "repository": { + "type": "git", + "url": "git://github.com/CodeSeven/toastr.git" + }, + "bugs": { + "url": "http://stackoverflow.com/questions/tagged/toastr" + }, + "licenses": [ + { + "type": "MIT", + "url": "http://www.opensource.org/licenses/mit-license.php" + } + ], + "devDependencies": { + "del": "^0.1.3", + "glob": "^4.0.6", + "gulp": "^3.8.10", + "gulp-bytediff": "^0.2.0", + "gulp-jscs": "^1.3.0", + "gulp-jshint": "^1.9.0", + "gulp-less": "^3.0.3", + "gulp-load-plugins": "^0.7.1", + "gulp-load-utils": "0.0.4", + "gulp-minify-css": "^0.3.11", + "gulp-rename": "^1.2.0", + "gulp-sourcemaps": "^1.2.8", + "gulp-task-listing": "^0.3.0", + "gulp-uglify": "^1.0.1", + "gulp-util": "^3.0.1", + "jquery": "^2.1.1", + "jshint-stylish": "^1.0.0", + "karma": "^0.12.25", + "karma-coverage": "^0.2.6", + "karma-phantomjs-launcher": "^0.1.4", + "karma-qunit": "^0.1.3", + "merge-stream": "^0.1.6", + "phantomjs": "^1.9.7-15", + "plato": "^1.2.2", + "qunitjs": "~1.14.0" + }, + "scripts": { + "test": "gulp test" + }, + "gitHead": "b957ae9f38e6856346a0200e83281b08ca717a7d", + "_id": "toastr@2.1.2", + "_shasum": "fd69066ae7578a5b3357725fc9c7c335e9b681df", + "_from": "toastr@>=2.1.2 <3.0.0", + "_npmVersion": "2.12.0", + "_nodeVersion": "1.6.3", + "_npmUser": { + "name": "timferrell", + "email": "timothyferrell+npm@gmail.com" + }, + "dist": { + "shasum": "fd69066ae7578a5b3357725fc9c7c335e9b681df", + "tarball": "https://registry.npmjs.org/toastr/-/toastr-2.1.2.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/toastr/-/toastr-2.1.2.tgz" +} diff --git a/node_modules/toastr/package/.gitattributes b/node_modules/toastr/package/.gitattributes new file mode 100644 index 0000000..0555bde --- /dev/null +++ b/node_modules/toastr/package/.gitattributes @@ -0,0 +1,15 @@ +# Set default behaviour, in case users don't have core.autocrlf set. +* text=auto + +# Explicitly declare text files we want to always be normalized and converted +# to native line endings on checkout. +*.c text +*.h text + +# Declare files that will always have CRLF line endings on checkout. +*.sln text eol=crlf +*.csproj text eol=crlf + +# Denote all files that are truly binary and should not be modified. +*.png binary +*.jpg binary \ No newline at end of file diff --git a/node_modules/toastr/package/.jscsrc b/node_modules/toastr/package/.jscsrc new file mode 100644 index 0000000..28846b1 --- /dev/null +++ b/node_modules/toastr/package/.jscsrc @@ -0,0 +1,90 @@ +{ + "excludeFiles": ["node_modules/**", "bower_components/**"], + + + "requireCurlyBraces": [ + "if", + "else", + "for", + "while", + "do", + "try", + "catch" + ], + "requireOperatorBeforeLineBreak": true, + "requireCamelCaseOrUpperCaseIdentifiers": true, + "maximumLineLength": { + "value": 80, + "allowComments": true, + "allowRegex": true + }, + "validateIndentation": 2, + "validateQuoteMarks": "'", + + "disallowMultipleLineStrings": true, + "disallowMixedSpacesAndTabs": true, + "disallowTrailingWhitespace": true, + "disallowSpaceAfterPrefixUnaryOperators": true, + "disallowMultipleVarDecl": null, + + "requireSpaceAfterKeywords": [ + "if", + "else", + "for", + "while", + "do", + "switch", + "return", + "try", + "catch" + ], + "requireSpaceBeforeBinaryOperators": [ + "=", "+=", "-=", "*=", "/=", "%=", "<<=", ">>=", ">>>=", + "&=", "|=", "^=", "+=", + + "+", "-", "*", "/", "%", "<<", ">>", ">>>", "&", + "|", "^", "&&", "||", "===", "==", ">=", + "<=", "<", ">", "!=", "!==" + ], + "requireSpaceAfterBinaryOperators": true, + "requireSpacesInConditionalExpression": true, + "requireSpaceBeforeBlockStatements": true, + "requireLineFeedAtFileEnd": true, + "disallowSpacesInsideObjectBrackets": "all", + "disallowSpacesInsideArrayBrackets": "all", + "disallowSpacesInsideParentheses": true, + + + "validateJSDoc": { + "checkParamNames": true, + "requireParamTypes": true + }, + + "disallowMultipleLineBreaks": true, + + + + + + + + "requireLineFeedAtFileEnd": null, + "disallowCommaBeforeLineBreak": null, + "disallowDanglingUnderscores": null, + "disallowEmptyBlocks": null, + "disallowMixedSpacesAndTabs": null, + "disallowMultipleLineStrings": null, + "disallowTrailingComma": null, + "disallowTrailingWhitespace": null, + "maximumLineLength": null, + "requireCamelCaseOrUpperCaseIdentifiers": null, + "requireCapitalizedConstructors": null, + "requireCommaBeforeLineBreak": null, + "requireCurlyBraces": null, + "requireDotNotation": null, + "requireMultipleVarDecl": null, + "requireOperatorBeforeLineBreak": null, + "requireParenthesesAroundIIFE": true, + "validateIndentation": 4, + "validateQuoteMarks": null +} \ No newline at end of file diff --git a/node_modules/toastr/package/.jshintrc b/node_modules/toastr/package/.jshintrc new file mode 100644 index 0000000..a9a9c57 --- /dev/null +++ b/node_modules/toastr/package/.jshintrc @@ -0,0 +1,61 @@ +{ + "bitwise": true, + "camelcase": true, + "curly": true, + "eqeqeq": true, + "es3": false, + "forin": true, + "freeze": true, + "immed": true, + "indent": 4, + "latedef": "nofunc", + "newcap": true, + "noarg": true, + "noempty": true, + "nonbsp": true, + "nonew": true, + "plusplus": false, + "quotmark": "single", + "undef": true, + "unused": false, + "strict": false, + "maxparams": 10, + "maxdepth": 5, + "maxstatements": 40, + "maxcomplexity": 8, + "maxlen": 120, + + "asi": false, + "boss": false, + "debug": false, + "eqnull": true, + "esnext": false, + "evil": false, + "expr": false, + "funcscope": false, + "globalstrict": false, + "iterator": false, + "lastsemic": false, + "laxbreak": false, + "laxcomma": false, + "loopfunc": true, + "maxerr": false, + "moz": false, + "multistr": false, + "notypeof": false, + "proto": false, + "scripturl": false, + "shadow": false, + "sub": true, + "supernew": false, + "validthis": false, + "noyield": false, + + "browser": true, + "node": true, + + "globals": { + "angular": false, + "$": false + } +} \ No newline at end of file diff --git a/node_modules/toastr/package/.npmignore b/node_modules/toastr/package/.npmignore new file mode 100644 index 0000000..30ae23b --- /dev/null +++ b/node_modules/toastr/package/.npmignore @@ -0,0 +1,58 @@ +node_modules +bower_components + +# Ignore Visual Studio Project # +################### +*.config +*.user +*.csproj +*.gpState +*.sln +*.suo +/bin +/obj +/packages +/Properties +/Scripts +/report +/tests/coverage + + +# Compiled source # +################### +*.com +*.class +*.dll +*.exe +*.o +*.so + +# Packages # +############ +# it's better to unpack these files and commit the raw source +# git has its own built in compression methods +*.7z +*.dmg +*.gz +*.iso +*.jar +*.rar +*.tar +*.zip + +# Logs and databases # +###################### +*.log +*.sql +*.sqlite + +# OS generated files # +###################### +.DS_Store* +ehthumbs.db +Icon? +Thumbs.db + +# WebStorm # +###################### +.idea/ \ No newline at end of file diff --git a/node_modules/toastr/package/.travis.yml b/node_modules/toastr/package/.travis.yml new file mode 100644 index 0000000..5d3c227 --- /dev/null +++ b/node_modules/toastr/package/.travis.yml @@ -0,0 +1,19 @@ +language: node_js +node_js: + - "0.10" + +install: + - npm install -g gulp karma-cli + - npm install + +script: + - npm test + +cache: + directories: + - node_modules + +branches: + only: + - develop + - master diff --git a/node_modules/toastr/package/CHANGELOG.md b/node_modules/toastr/package/CHANGELOG.md new file mode 100644 index 0000000..3f6f85c --- /dev/null +++ b/node_modules/toastr/package/CHANGELOG.md @@ -0,0 +1,120 @@ +# 2.1.1 (2015-02-19) + +## New Features +- Support for explicitly clearing a toast [jstawski](https://github.com/jstawski) | [PR 226](https://github.com/CodeSeven/toastr/pull/226) + +## Dev Ops +- Refactor to use gulp + +# 2.1.0 (2014-10-15) + +## New Features +- Prevent duplicate sequential toasts [SBero](https://github.com/sbero) | [aa083d8](https://github.com/CodeSeven/toastr/commit/ccb377b6015d557dbb987df74750b97b3aa083d8) +- Add support for top-center and bottom-center toasts [showwin](https://github.com/showwin) | [86a4798](https://github.com/CodeSeven/toastr/commit/86a4798e76c7d8516521780b7bd085d6bb4c371b) +- Add feature allowing progress bars to be shown for toasts [TravisTX](https://github.com/TravisTX) | [PR 189](https://github.com/CodeSeven/toastr/pull/189) + +`toastr.options.preventDuplicates = true;` + +`toastr.options.progressBar = true;` + +## Bug Fixes +- None + +## Breaking Changes +- None + +## Dev Ops + +- Add karma test runner +- Added Travis CI hooks + +# 2.0.3 (2014-05-17) + +## New Features + - None + +## Bug Fixes +- positionClass changes were not being honored due to 2.0.2 release changes. Refactored getContainer to only get the container, unless a 2nd boolean parameter is passed in in which case it will also create it if the container did not exist [871c2a6](https://github.com/CodeSeven/toastr/commit/871c2a6e438bb6b996cfb80286720604a4cf00fd) + +## Breaking Changes + - None + +# 2.0.2 (2014-04-29) + +## New Features +- Added simple ARIA reader support ([45c6362](https://github.com/CodeSeven/toastr/commit/45c63628476f6b085a6579dc681f4fe61ba5820c)) +- Added SASS support (direct port of CSS for now) ([b4c8b34](https://github.com/CodeSeven/toastr/commit/b4c8b3460efb8aa51c730dd38c35ef6b025db2cc)) + +## Bug Fixes +- Added sourcemap for the min file ([1da4bd1](https://github.com/CodeSeven/toastr/commit/1da4bd1dad21bcfc7fcfe73da1abb185cf2c3f9f)) +- IE 8 does not support stopPropagation on the event ([6989573](https://github.com/CodeSeven/toastr/commit/698957325a8e7bf63990f71ee409b911d69bc8ec)) +- Media query width fixes ([ea2f5db](https://github.com/CodeSeven/toastr/commit/ea2f5db6e5314dcfe48eb34176583849c177c00e)) +- Fix of onHidden firing twice when clicking on it then moving mouse out of toast ([ad613b9](https://github.com/CodeSeven/toastr/commit/ad613b9f18feeec630497590b85ca75c52141ea3) , [#105](https://github.com/CodeSeven/toastr/issues/105)) +- Clear all toasts followed by a new toast now displays correctly ([3126a53](https://github.com/CodeSeven/toastr/commit/3126a533e0ab12ec3ff374e155a37fd38bd23bb6) , [#149](https://github.com/CodeSeven/toastr/issues/149) , [#118](https://github.com/CodeSeven/toastr/issues/118)) + +## Breaking Changes +- None + +# 2.0.1 (2013-09-01) + +## New Features + +### Close Button +Optionally enable a close button + + toastr.options.closeButton = true; + +Optionally override the close button's HTML. + + toastr.options.closeHtml = ''; + +You can also override the CSS/LESS for `#toast-container .toast-close-button` + +### Callbacks + // Define a callback for when the toast is shown/hidden + toastr.options.onShown = function() { console.log('hello'); } + toastr.options.onHidden = function() { console.log('goodbye'); } + +### Animation Options +Toastr will supply default animations, so you do not have to provide any of these settings. However you have the option to override the animations if you like. + +####Easings +Optionally override the animation easing to show or hide the toasts. Default is swing. swing and linear are built into jQuery. + + toastr.options.showEasing = 'swing'; + toastr.options.hideEasing = 'linear'; + +Using the jQuery Easing plugin (http://www.gsgd.co.uk/sandbox/jquery/easing/) + + toastr.options.showEasing = 'easeOutBounce'; + toastr.options.hideEasing = 'easeInBack'; + +####Animation Method +Use the jQuery show/hide method of your choice. These default to fadeIn/fadeOut. The methods fadeIn/fadeOut, slideDown/slideUp, and show/hide are built into jQuery. + + toastr.options.showMethod = 'slideDown'; + toastr.options.hideMethod = 'slideUp'; + + +###Timeouts +Control how toastr interacts with users by setting timeouts appropriately. + + toastr.options.timeout = 30; // How long the toast will display without user interaction + toastr.options.extendedTimeOut = 60; // How long the toast will display after a user hovers over it + +## Breaking Changes + +###Animation Changes +The following animations options have been deprecated and should be replaced: + + - Replace `options.fadeIn` with `options.showDuration` + - Replace `options.onFadeIn` with `options.onShown` + - Replace `options.fadeOut` with `options.hideDuration` + - Replace `options.onFadeOut` with `options.onHidden` + +# Version 1.3.1 + +## Display Sequence +Show newest toast at bottom (top is default) + + toastr.options.newestOnTop = false; diff --git a/node_modules/toastr/package/build/toastr.js.map b/node_modules/toastr/package/build/toastr.js.map new file mode 100644 index 0000000..4708ea4 --- /dev/null +++ b/node_modules/toastr/package/build/toastr.js.map @@ -0,0 +1 @@ +{"version":3,"sources":["toastr.js"],"names":["define","$","error","message","title","optionsOverride","notify","type","toastType","iconClass","getOptions","iconClasses","getContainer","options","create","$container","containerId","length","createContainer","info","subscribe","callback","listener","success","warning","clear","$toastElement","clearOptions","clearToast","clearContainer","remove","removeToast","children","toastsToClear","i","force","hideMethod","duration","hideDuration","easing","hideEasing","complete","attr","addClass","positionClass","appendTo","target","getDefaults","tapToDismiss","toastClass","debug","showMethod","showDuration","showEasing","onShown","undefined","onHidden","extendedTimeOut","timeOut","titleClass","messageClass","closeHtml","newestOnTop","preventDuplicates","progressBar","publish","args","map","personalizeToast","setIcon","setTitle","setMessage","setCloseButton","setProgressBar","setSequence","handleEvents","hover","stickAround","delayedHideToast","onclick","click","hideToast","closeButton","$closeElement","event","stopPropagation","cancelBubble","displayToast","hide","intervalId","setTimeout","maxHideTime","parseFloat","hideEta","Date","getTime","setInterval","updateProgress","prepend","append","$titleElement","$messageElement","$progressElement","shouldExit","previousToast","override","clearTimeout","response","state","endTime","stop","percentage","width","extend","toastId","startTime","console","log","toastr","is","version","amd","deps","factory","module","exports","require","window"],"mappings":"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","file":"toastr.js","sourcesContent":["/*\n * Toastr\n * Copyright 2012-2015\n * Authors: John Papa, Hans Fjällemark, and Tim Ferrell.\n * All Rights Reserved.\n * Use, reproduction, distribution, and modification of this code is subject to the terms and\n * conditions of the MIT license, available at http://www.opensource.org/licenses/mit-license.php\n *\n * ARIA Support: Greta Krafsig\n *\n * Project: https://github.com/CodeSeven/toastr\n */\n/* global define */\n; (function (define) {\n define(['jquery'], function ($) {\n return (function () {\n var $container;\n var listener;\n var toastId = 0;\n var toastType = {\n error: 'error',\n info: 'info',\n success: 'success',\n warning: 'warning'\n };\n\n var toastr = {\n clear: clear,\n remove: remove,\n error: error,\n getContainer: getContainer,\n info: info,\n options: {},\n subscribe: subscribe,\n success: success,\n version: '2.1.1',\n warning: warning\n };\n\n var previousToast;\n\n return toastr;\n\n ////////////////\n\n function error(message, title, optionsOverride) {\n return notify({\n type: toastType.error,\n iconClass: getOptions().iconClasses.error,\n message: message,\n optionsOverride: optionsOverride,\n title: title\n });\n }\n\n function getContainer(options, create) {\n if (!options) { options = getOptions(); }\n $container = $('#' + options.containerId);\n if ($container.length) {\n return $container;\n }\n if (create) {\n $container = createContainer(options);\n }\n return $container;\n }\n\n function info(message, title, optionsOverride) {\n return notify({\n type: toastType.info,\n iconClass: getOptions().iconClasses.info,\n message: message,\n optionsOverride: optionsOverride,\n title: title\n });\n }\n\n function subscribe(callback) {\n listener = callback;\n }\n\n function success(message, title, optionsOverride) {\n return notify({\n type: toastType.success,\n iconClass: getOptions().iconClasses.success,\n message: message,\n optionsOverride: optionsOverride,\n title: title\n });\n }\n\n function warning(message, title, optionsOverride) {\n return notify({\n type: toastType.warning,\n iconClass: getOptions().iconClasses.warning,\n message: message,\n optionsOverride: optionsOverride,\n title: title\n });\n }\n\n function clear($toastElement, clearOptions) {\n var options = getOptions();\n if (!$container) { getContainer(options); }\n if (!clearToast($toastElement, options, clearOptions)) {\n clearContainer(options);\n }\n }\n\n function remove($toastElement) {\n var options = getOptions();\n if (!$container) { getContainer(options); }\n if ($toastElement && $(':focus', $toastElement).length === 0) {\n removeToast($toastElement);\n return;\n }\n if ($container.children().length) {\n $container.remove();\n }\n }\n\n // internal functions\n\n function clearContainer (options) {\n var toastsToClear = $container.children();\n for (var i = toastsToClear.length - 1; i >= 0; i--) {\n clearToast($(toastsToClear[i]), options);\n }\n }\n\n function clearToast ($toastElement, options, clearOptions) {\n var force = clearOptions && clearOptions.force ? clearOptions.force : false;\n if ($toastElement && (force || $(':focus', $toastElement).length === 0)) {\n $toastElement[options.hideMethod]({\n duration: options.hideDuration,\n easing: options.hideEasing,\n complete: function () { removeToast($toastElement); }\n });\n return true;\n }\n return false;\n }\n\n function createContainer(options) {\n $container = $('
')\n .attr('id', options.containerId)\n .addClass(options.positionClass)\n .attr('aria-live', 'polite')\n .attr('role', 'alert');\n\n $container.appendTo($(options.target));\n return $container;\n }\n\n function getDefaults() {\n return {\n tapToDismiss: true,\n toastClass: 'toast',\n containerId: 'toast-container',\n debug: false,\n\n showMethod: 'fadeIn', //fadeIn, slideDown, and show are built into jQuery\n showDuration: 300,\n showEasing: 'swing', //swing and linear are built into jQuery\n onShown: undefined,\n hideMethod: 'fadeOut',\n hideDuration: 1000,\n hideEasing: 'swing',\n onHidden: undefined,\n\n extendedTimeOut: 1000,\n iconClasses: {\n error: 'toast-error',\n info: 'toast-info',\n success: 'toast-success',\n warning: 'toast-warning'\n },\n iconClass: 'toast-info',\n positionClass: 'toast-top-right',\n timeOut: 5000, // Set timeOut and extendedTimeOut to 0 to make it sticky\n titleClass: 'toast-title',\n messageClass: 'toast-message',\n target: 'body',\n closeHtml: '',\n newestOnTop: true,\n preventDuplicates: false,\n progressBar: false\n };\n }\n\n function publish(args) {\n if (!listener) { return; }\n listener(args);\n }\n\n function notify(map) {\n var options = getOptions();\n var iconClass = map.iconClass || options.iconClass;\n\n if (typeof (map.optionsOverride) !== 'undefined') {\n options = $.extend(options, map.optionsOverride);\n iconClass = map.optionsOverride.iconClass || iconClass;\n }\n\n if (shouldExit(options, map)) { return; }\n\n toastId++;\n\n $container = getContainer(options, true);\n\n var intervalId = null;\n var $toastElement = $('
');\n var $titleElement = $('
');\n var $messageElement = $('
');\n var $progressElement = $('
');\n var $closeElement = $(options.closeHtml);\n var progressBar = {\n intervalId: null,\n hideEta: null,\n maxHideTime: null\n };\n var response = {\n toastId: toastId,\n state: 'visible',\n startTime: new Date(),\n options: options,\n map: map\n };\n\n personalizeToast();\n\n displayToast();\n\n handleEvents();\n\n publish(response);\n\n if (options.debug && console) {\n console.log(response);\n }\n\n return $toastElement;\n\n function personalizeToast() {\n setIcon();\n setTitle();\n setMessage();\n setCloseButton();\n setProgressBar();\n setSequence();\n }\n\n function handleEvents() {\n $toastElement.hover(stickAround, delayedHideToast);\n if (!options.onclick && options.tapToDismiss) {\n $toastElement.click(hideToast);\n }\n\n if (options.closeButton && $closeElement) {\n $closeElement.click(function (event) {\n if (event.stopPropagation) {\n event.stopPropagation();\n } else if (event.cancelBubble !== undefined && event.cancelBubble !== true) {\n event.cancelBubble = true;\n }\n hideToast(true);\n });\n }\n\n if (options.onclick) {\n $toastElement.click(function () {\n options.onclick();\n hideToast();\n });\n }\n }\n\n function displayToast() {\n $toastElement.hide();\n\n $toastElement[options.showMethod](\n {duration: options.showDuration, easing: options.showEasing, complete: options.onShown}\n );\n\n if (options.timeOut > 0) {\n intervalId = setTimeout(hideToast, options.timeOut);\n progressBar.maxHideTime = parseFloat(options.timeOut);\n progressBar.hideEta = new Date().getTime() + progressBar.maxHideTime;\n if (options.progressBar) {\n progressBar.intervalId = setInterval(updateProgress, 10);\n }\n }\n }\n\n function setIcon() {\n if (map.iconClass) {\n $toastElement.addClass(options.toastClass).addClass(iconClass);\n }\n }\n\n function setSequence() {\n if (options.newestOnTop) {\n $container.prepend($toastElement);\n } else {\n $container.append($toastElement);\n }\n }\n\n function setTitle() {\n if (map.title) {\n $titleElement.append(map.title).addClass(options.titleClass);\n $toastElement.append($titleElement);\n }\n }\n\n function setMessage() {\n if (map.message) {\n $messageElement.append(map.message).addClass(options.messageClass);\n $toastElement.append($messageElement);\n }\n }\n\n function setCloseButton() {\n if (options.closeButton) {\n $closeElement.addClass('toast-close-button').attr('role', 'button');\n $toastElement.prepend($closeElement);\n }\n }\n\n function setProgressBar() {\n if (options.progressBar) {\n $progressElement.addClass('toast-progress');\n $toastElement.prepend($progressElement);\n }\n }\n\n function shouldExit(options, map) {\n if (options.preventDuplicates) {\n if (map.message === previousToast) {\n return true;\n } else {\n previousToast = map.message;\n }\n }\n return false;\n }\n\n function hideToast(override) {\n if ($(':focus', $toastElement).length && !override) {\n return;\n }\n clearTimeout(progressBar.intervalId);\n return $toastElement[options.hideMethod]({\n duration: options.hideDuration,\n easing: options.hideEasing,\n complete: function () {\n removeToast($toastElement);\n if (options.onHidden && response.state !== 'hidden') {\n options.onHidden();\n }\n response.state = 'hidden';\n response.endTime = new Date();\n publish(response);\n }\n });\n }\n\n function delayedHideToast() {\n if (options.timeOut > 0 || options.extendedTimeOut > 0) {\n intervalId = setTimeout(hideToast, options.extendedTimeOut);\n progressBar.maxHideTime = parseFloat(options.extendedTimeOut);\n progressBar.hideEta = new Date().getTime() + progressBar.maxHideTime;\n }\n }\n\n function stickAround() {\n clearTimeout(intervalId);\n progressBar.hideEta = 0;\n $toastElement.stop(true, true)[options.showMethod](\n {duration: options.showDuration, easing: options.showEasing}\n );\n }\n\n function updateProgress() {\n var percentage = ((progressBar.hideEta - (new Date().getTime())) / progressBar.maxHideTime) * 100;\n $progressElement.width(percentage + '%');\n }\n }\n\n function getOptions() {\n return $.extend({}, getDefaults(), toastr.options);\n }\n\n function removeToast($toastElement) {\n if (!$container) { $container = getContainer(); }\n if ($toastElement.is(':visible')) {\n return;\n }\n $toastElement.remove();\n $toastElement = null;\n if ($container.children().length === 0) {\n $container.remove();\n previousToast = undefined;\n }\n }\n\n })();\n });\n}(typeof define === 'function' && define.amd ? define : function (deps, factory) {\n if (typeof module !== 'undefined' && module.exports) { //Node\n module.exports = factory(require('jquery'));\n } else {\n window['toastr'] = factory(window['jQuery']);\n }\n}));\n"],"sourceRoot":"/source/"} \ No newline at end of file diff --git a/node_modules/toastr/package/build/toastr.min.css b/node_modules/toastr/package/build/toastr.min.css new file mode 100644 index 0000000..64adc42 --- /dev/null +++ b/node_modules/toastr/package/build/toastr.min.css @@ -0,0 +1 @@ +.toast-title{font-weight:700}.toast-message{-ms-word-wrap:break-word;word-wrap:break-word}.toast-message a,.toast-message label{color:#fff}.toast-message a:hover{color:#ccc;text-decoration:none}.toast-close-button{position:relative;right:-.3em;top:-.3em;float:right;font-size:20px;font-weight:700;color:#fff;-webkit-text-shadow:0 1px 0 #fff;text-shadow:0 1px 0 #fff;opacity:.8;-ms-filter:alpha(Opacity=80);filter:alpha(opacity=80)}.toast-close-button:focus,.toast-close-button:hover{color:#000;text-decoration:none;cursor:pointer;opacity:.4;-ms-filter:alpha(Opacity=40);filter:alpha(opacity=40)}button.toast-close-button{padding:0;cursor:pointer;background:0 0;border:0;-webkit-appearance:none}.toast-top-center{top:0;right:0;width:100%}.toast-bottom-center{bottom:0;right:0;width:100%}.toast-top-full-width{top:0;right:0;width:100%}.toast-bottom-full-width{bottom:0;right:0;width:100%}.toast-top-left{top:12px;left:12px}.toast-top-right{top:12px;right:12px}.toast-bottom-right{right:12px;bottom:12px}.toast-bottom-left{bottom:12px;left:12px}#toast-container{position:fixed;z-index:999999}#toast-container *{-moz-box-sizing:border-box;-webkit-box-sizing:border-box;box-sizing:border-box}#toast-container>div{position:relative;overflow:hidden;margin:0 0 6px;padding:15px 15px 15px 50px;width:300px;-moz-border-radius:3px;-webkit-border-radius:3px;border-radius:3px;background-position:15px center;background-repeat:no-repeat;-moz-box-shadow:0 0 12px #999;-webkit-box-shadow:0 0 12px #999;box-shadow:0 0 12px #999;color:#fff;opacity:.8;-ms-filter:alpha(Opacity=80);filter:alpha(opacity=80)}#toast-container>:hover{-moz-box-shadow:0 0 12px #000;-webkit-box-shadow:0 0 12px #000;box-shadow:0 0 12px #000;opacity:1;-ms-filter:alpha(Opacity=100);filter:alpha(opacity=100);cursor:pointer}#toast-container>.toast-info{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGwSURBVEhLtZa9SgNBEMc9sUxxRcoUKSzSWIhXpFMhhYWFhaBg4yPYiWCXZxBLERsLRS3EQkEfwCKdjWJAwSKCgoKCcudv4O5YLrt7EzgXhiU3/4+b2ckmwVjJSpKkQ6wAi4gwhT+z3wRBcEz0yjSseUTrcRyfsHsXmD0AmbHOC9Ii8VImnuXBPglHpQ5wwSVM7sNnTG7Za4JwDdCjxyAiH3nyA2mtaTJufiDZ5dCaqlItILh1NHatfN5skvjx9Z38m69CgzuXmZgVrPIGE763Jx9qKsRozWYw6xOHdER+nn2KkO+Bb+UV5CBN6WC6QtBgbRVozrahAbmm6HtUsgtPC19tFdxXZYBOfkbmFJ1VaHA1VAHjd0pp70oTZzvR+EVrx2Ygfdsq6eu55BHYR8hlcki+n+kERUFG8BrA0BwjeAv2M8WLQBtcy+SD6fNsmnB3AlBLrgTtVW1c2QN4bVWLATaIS60J2Du5y1TiJgjSBvFVZgTmwCU+dAZFoPxGEEs8nyHC9Bwe2GvEJv2WXZb0vjdyFT4Cxk3e/kIqlOGoVLwwPevpYHT+00T+hWwXDf4AJAOUqWcDhbwAAAAASUVORK5CYII=)!important}#toast-container>.toast-error{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAHOSURBVEhLrZa/SgNBEMZzh0WKCClSCKaIYOED+AAKeQQLG8HWztLCImBrYadgIdY+gIKNYkBFSwu7CAoqCgkkoGBI/E28PdbLZmeDLgzZzcx83/zZ2SSXC1j9fr+I1Hq93g2yxH4iwM1vkoBWAdxCmpzTxfkN2RcyZNaHFIkSo10+8kgxkXIURV5HGxTmFuc75B2RfQkpxHG8aAgaAFa0tAHqYFfQ7Iwe2yhODk8+J4C7yAoRTWI3w/4klGRgR4lO7Rpn9+gvMyWp+uxFh8+H+ARlgN1nJuJuQAYvNkEnwGFck18Er4q3egEc/oO+mhLdKgRyhdNFiacC0rlOCbhNVz4H9FnAYgDBvU3QIioZlJFLJtsoHYRDfiZoUyIxqCtRpVlANq0EU4dApjrtgezPFad5S19Wgjkc0hNVnuF4HjVA6C7QrSIbylB+oZe3aHgBsqlNqKYH48jXyJKMuAbiyVJ8KzaB3eRc0pg9VwQ4niFryI68qiOi3AbjwdsfnAtk0bCjTLJKr6mrD9g8iq/S/B81hguOMlQTnVyG40wAcjnmgsCNESDrjme7wfftP4P7SP4N3CJZdvzoNyGq2c/HWOXJGsvVg+RA/k2MC/wN6I2YA2Pt8GkAAAAASUVORK5CYII=)!important}#toast-container>.toast-success{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAADsSURBVEhLY2AYBfQMgf///3P8+/evAIgvA/FsIF+BavYDDWMBGroaSMMBiE8VC7AZDrIFaMFnii3AZTjUgsUUWUDA8OdAH6iQbQEhw4HyGsPEcKBXBIC4ARhex4G4BsjmweU1soIFaGg/WtoFZRIZdEvIMhxkCCjXIVsATV6gFGACs4Rsw0EGgIIH3QJYJgHSARQZDrWAB+jawzgs+Q2UO49D7jnRSRGoEFRILcdmEMWGI0cm0JJ2QpYA1RDvcmzJEWhABhD/pqrL0S0CWuABKgnRki9lLseS7g2AlqwHWQSKH4oKLrILpRGhEQCw2LiRUIa4lwAAAABJRU5ErkJggg==)!important}#toast-container>.toast-warning{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGYSURBVEhL5ZSvTsNQFMbXZGICMYGYmJhAQIJAICYQPAACiSDB8AiICQQJT4CqQEwgJvYASAQCiZiYmJhAIBATCARJy+9rTsldd8sKu1M0+dLb057v6/lbq/2rK0mS/TRNj9cWNAKPYIJII7gIxCcQ51cvqID+GIEX8ASG4B1bK5gIZFeQfoJdEXOfgX4QAQg7kH2A65yQ87lyxb27sggkAzAuFhbbg1K2kgCkB1bVwyIR9m2L7PRPIhDUIXgGtyKw575yz3lTNs6X4JXnjV+LKM/m3MydnTbtOKIjtz6VhCBq4vSm3ncdrD2lk0VgUXSVKjVDJXJzijW1RQdsU7F77He8u68koNZTz8Oz5yGa6J3H3lZ0xYgXBK2QymlWWA+RWnYhskLBv2vmE+hBMCtbA7KX5drWyRT/2JsqZ2IvfB9Y4bWDNMFbJRFmC9E74SoS0CqulwjkC0+5bpcV1CZ8NMej4pjy0U+doDQsGyo1hzVJttIjhQ7GnBtRFN1UarUlH8F3xict+HY07rEzoUGPlWcjRFRr4/gChZgc3ZL2d8oAAAAASUVORK5CYII=)!important}#toast-container.toast-bottom-center>div,#toast-container.toast-top-center>div{width:300px;margin:auto}#toast-container.toast-bottom-full-width>div,#toast-container.toast-top-full-width>div{width:96%;margin:auto}.toast{background-color:#030303}.toast-success{background-color:#51a351}.toast-error{background-color:#bd362f}.toast-info{background-color:#2f96b4}.toast-warning{background-color:#f89406}.toast-progress{position:absolute;left:0;bottom:0;height:4px;background-color:#000;opacity:.4;-ms-filter:alpha(Opacity=40);filter:alpha(opacity=40)}@media all and (max-width:240px){#toast-container>div{padding:8px 8px 8px 50px;width:11em}#toast-container .toast-close-button{right:-.2em;top:-.2em}}@media all and (min-width:241px) and (max-width:480px){#toast-container>div{padding:8px 8px 8px 50px;width:18em}#toast-container .toast-close-button{right:-.2em;top:-.2em}}@media all and (min-width:481px) and (max-width:768px){#toast-container>div{padding:15px 15px 15px 50px;width:25em}} diff --git a/node_modules/toastr/package/build/toastr.min.js b/node_modules/toastr/package/build/toastr.min.js new file mode 100644 index 0000000..ab9c66c --- /dev/null +++ b/node_modules/toastr/package/build/toastr.min.js @@ -0,0 +1,2 @@ +!function(e){e(["jquery"],function(e){return function(){function t(e,t,n){return f({type:O.error,iconClass:g().iconClasses.error,message:e,optionsOverride:n,title:t})}function n(t,n){return t||(t=g()),v=e("#"+t.containerId),v.length?v:(n&&(v=c(t)),v)}function i(e,t,n){return f({type:O.info,iconClass:g().iconClasses.info,message:e,optionsOverride:n,title:t})}function o(e){w=e}function s(e,t,n){return f({type:O.success,iconClass:g().iconClasses.success,message:e,optionsOverride:n,title:t})}function a(e,t,n){return f({type:O.warning,iconClass:g().iconClasses.warning,message:e,optionsOverride:n,title:t})}function r(e){var t=g();v||n(t),l(e,t)||u(t)}function d(t){var i=g();return v||n(i),t&&0===e(":focus",t).length?void h(t):void(v.children().length&&v.remove())}function u(t){for(var n=v.children(),i=n.length-1;i>=0;i--)l(e(n[i]),t)}function l(t,n){return t&&0===e(":focus",t).length?(t[n.hideMethod]({duration:n.hideDuration,easing:n.hideEasing,complete:function(){h(t)}}),!0):!1}function c(t){return v=e("
").attr("id",t.containerId).addClass(t.positionClass).attr("aria-live","polite").attr("role","alert"),v.appendTo(e(t.target)),v}function p(){return{tapToDismiss:!0,toastClass:"toast",containerId:"toast-container",debug:!1,showMethod:"fadeIn",showDuration:300,showEasing:"swing",onShown:void 0,hideMethod:"fadeOut",hideDuration:1e3,hideEasing:"swing",onHidden:void 0,extendedTimeOut:1e3,iconClasses:{error:"toast-error",info:"toast-info",success:"toast-success",warning:"toast-warning"},iconClass:"toast-info",positionClass:"toast-top-right",timeOut:5e3,titleClass:"toast-title",messageClass:"toast-message",target:"body",closeHtml:'',newestOnTop:!0,preventDuplicates:!1,progressBar:!1}}function m(e){w&&w(e)}function f(t){function i(t){return!e(":focus",l).length||t?(clearTimeout(O.intervalId),l[r.hideMethod]({duration:r.hideDuration,easing:r.hideEasing,complete:function(){h(l),r.onHidden&&"hidden"!==b.state&&r.onHidden(),b.state="hidden",b.endTime=new Date,m(b)}})):void 0}function o(){(r.timeOut>0||r.extendedTimeOut>0)&&(u=setTimeout(i,r.extendedTimeOut),O.maxHideTime=parseFloat(r.extendedTimeOut),O.hideEta=(new Date).getTime()+O.maxHideTime)}function s(){clearTimeout(u),O.hideEta=0,l.stop(!0,!0)[r.showMethod]({duration:r.showDuration,easing:r.showEasing})}function a(){var e=(O.hideEta-(new Date).getTime())/O.maxHideTime*100;f.width(e+"%")}var r=g(),d=t.iconClass||r.iconClass;if("undefined"!=typeof t.optionsOverride&&(r=e.extend(r,t.optionsOverride),d=t.optionsOverride.iconClass||d),r.preventDuplicates){if(t.message===C)return;C=t.message}T++,v=n(r,!0);var u=null,l=e("
"),c=e("
"),p=e("
"),f=e("
"),w=e(r.closeHtml),O={intervalId:null,hideEta:null,maxHideTime:null},b={toastId:T,state:"visible",startTime:new Date,options:r,map:t};return t.iconClass&&l.addClass(r.toastClass).addClass(d),t.title&&(c.append(t.title).addClass(r.titleClass),l.append(c)),t.message&&(p.append(t.message).addClass(r.messageClass),l.append(p)),r.closeButton&&(w.addClass("toast-close-button").attr("role","button"),l.prepend(w)),r.progressBar&&(f.addClass("toast-progress"),l.prepend(f)),l.hide(),r.newestOnTop?v.prepend(l):v.append(l),l[r.showMethod]({duration:r.showDuration,easing:r.showEasing,complete:r.onShown}),r.timeOut>0&&(u=setTimeout(i,r.timeOut),O.maxHideTime=parseFloat(r.timeOut),O.hideEta=(new Date).getTime()+O.maxHideTime,r.progressBar&&(O.intervalId=setInterval(a,10))),l.hover(s,o),!r.onclick&&r.tapToDismiss&&l.click(i),r.closeButton&&w&&w.click(function(e){e.stopPropagation?e.stopPropagation():void 0!==e.cancelBubble&&e.cancelBubble!==!0&&(e.cancelBubble=!0),i(!0)}),r.onclick&&l.click(function(){r.onclick(),i()}),m(b),r.debug&&console&&console.log(b),l}function g(){return e.extend({},p(),b.options)}function h(e){v||(v=n()),e.is(":visible")||(e.remove(),e=null,0===v.children().length&&(v.remove(),C=void 0))}var v,w,C,T=0,O={error:"error",info:"info",success:"success",warning:"warning"},b={clear:r,remove:d,error:t,getContainer:n,info:i,options:{},subscribe:o,success:s,version:"2.1.0",warning:a};return b}()})}("function"==typeof define&&define.amd?define:function(e,t){"undefined"!=typeof module&&module.exports?module.exports=t(require("jquery")):window.toastr=t(window.jQuery)}); +//# sourceMappingURL=toastr.js.map diff --git a/node_modules/toastr/package/demo.html b/node_modules/toastr/package/demo.html new file mode 100644 index 0000000..816f097 --- /dev/null +++ b/node_modules/toastr/package/demo.html @@ -0,0 +1,325 @@ + + + + + toastr examples + + + + + + + +
+

toastr

+ +
+
+
+
+
+ + + + +
+
+
+
+ +
+
+ +
+
+ +
+
+ +
+
+ +
+
+ +
+
+ +
+
+
+ +
+
+
+ + + + + +
+
+
+
+ + + + + + + + + +
+
+
+ +
+
+
+ + + + + + + + + + + +
+
+
+ +
+
+
+ + + + + + + + + + + +
+
+
+
+ +
+ + + +
+ +
+

+        
+
+
+ +
+ + + + + + + diff --git a/node_modules/toastr/package/gulpfile.js b/node_modules/toastr/package/gulpfile.js new file mode 100644 index 0000000..8b337ed --- /dev/null +++ b/node_modules/toastr/package/gulpfile.js @@ -0,0 +1,198 @@ +/* jshint node:true, camelcase:false */ +var gulp = require('gulp'); +var del = require('del'); +var glob = require('glob'); +var karma = require('karma').server; +var merge = require('merge-stream'); +var plato = require('plato'); +var plug = require('gulp-load-plugins')(); + +var paths = { + js: './toastr.js', + css: './toastr.css', + report: './report', + build: './build' +}; + +var colors = plug.util.colors; +var log = plug.util.log; + +/** + * List the available gulp tasks + */ +gulp.task('help', plug.taskListing); + +/** + * Lint the code, create coverage report, and a visualizer + * @return {Stream} + */ +gulp.task('analyze', function() { + log('Analyzing source with JSHint, JSCS, and Plato'); + + var jshint = analyzejshint([paths.js]); + var jscs = analyzejscs([paths.js]); + + startPlatoVisualizer(); + + return merge(jshint, jscs); +}); + +/** + * Minify and bundle the app's JavaScript + * @return {Stream} + */ +gulp.task('js', function() { + log('Bundling, minifying, and copying the app\'s JavaScript'); + + return gulp + .src(paths.js) + .pipe(plug.sourcemaps.init()) + .pipe(plug.bytediff.start()) + .pipe(plug.uglify({})) + .pipe(plug.bytediff.stop(bytediffFormatter)) + .pipe(plug.sourcemaps.write('.')) + .pipe(plug.rename(function(path) { + if (path.extname === '.js') { + path.basename += '.min'; + } + })) + .pipe(gulp.dest(paths.build)); +}); + +/** + * Minify and bundle the CSS + * @return {Stream} + */ +gulp.task('css', function() { + log('Bundling, minifying, and copying the app\'s CSS'); + + return gulp.src(paths.css) +// .pipe(plug.autoprefixer('last 2 version', '> 5%')) + .pipe(plug.bytediff.start()) + .pipe(plug.minifyCss({})) + .pipe(plug.bytediff.stop(bytediffFormatter)) + .pipe(plug.rename('toastr.min.css')) + .pipe(gulp.dest(paths.build)); +}); + +/** + * Build js and css + */ +gulp.task('default', ['js', 'css'], function() { + log('Analyze, Build CSS and JS'); +}); + +/** + * Remove all files from the build folder + * One way to run clean before all tasks is to run + * from the cmd line: gulp clean && gulp build + * @return {Stream} + */ +gulp.task('clean', function(cb) { + log('Cleaning: ' + plug.util.colors.blue(paths.report)); + log('Cleaning: ' + plug.util.colors.blue(paths.build)); + + var delPaths = [paths.build, paths.report]; + del(delPaths, cb); +}); + +/** + * Run specs once and exit + * To start servers and run midway specs as well: + * gulp test --startServers + * @return {Stream} + */ +gulp.task('test', function(done) { + startTests(true /*singleRun*/ , done); +}); + +//////////////// + +/** + * Execute JSHint on given source files + * @param {Array} sources + * @param {String} overrideRcFile + * @return {Stream} + */ +function analyzejshint(sources, overrideRcFile) { + var jshintrcFile = overrideRcFile || './.jshintrc'; + log('Running JSHint'); + return gulp + .src(sources) + .pipe(plug.jshint(jshintrcFile)) + .pipe(plug.jshint.reporter('jshint-stylish')); +} + +/** + * Execute JSCS on given source files + * @param {Array} sources + * @return {Stream} + */ +function analyzejscs(sources) { + log('Running JSCS'); + return gulp + .src(sources) + .pipe(plug.jscs('./.jscsrc')); +} + +/** + * Start Plato inspector and visualizer + */ +function startPlatoVisualizer() { + log('Running Plato'); + + var files = glob.sync('toastr.js'); + + var options = { + title: 'Plato Inspections Report' + }; + var outputDir = './report/plato'; + + plato.inspect(files, outputDir, options, platoCompleted); + + function platoCompleted(report) { + var overview = plato.getOverviewReport(report); + log(overview.summary); + } +} + +/** + * Start the tests using karma. + * @param {boolean} singleRun - True means run once and end (CI), or keep running (dev) + * @param {Function} done - Callback to fire when karma is done + * @return {undefined} + */ +function startTests(singleRun, done) { + karma.start({ + configFile: __dirname + '/karma.conf.js', + singleRun: !!singleRun + }, karmaCompleted); + + //////////////// + + function karmaCompleted() { + done(); + } +} + +/** + * Formatter for bytediff to display the size changes after processing + * @param {Object} data - byte data + * @return {String} Difference in bytes, formatted + */ +function bytediffFormatter(data) { + var difference = (data.savings > 0) ? ' smaller.' : ' larger.'; + return data.fileName + ' went from ' + + (data.startSize / 1000).toFixed(2) + ' kB to ' + (data.endSize / 1000).toFixed(2) + ' kB' + + ' and is ' + formatPercent(1 - data.percent, 2) + '%' + difference; +} + +/** + * Format a number as a percentage + * @param {Number} num Number to format as a percent + * @param {Number} precision Precision of the decimal + * @return {Number} Formatted perentage + */ +function formatPercent(num, precision) { + return (num * 100).toFixed(precision); +} diff --git a/node_modules/toastr/package/karma.conf.js b/node_modules/toastr/package/karma.conf.js new file mode 100644 index 0000000..c1cfdfc --- /dev/null +++ b/node_modules/toastr/package/karma.conf.js @@ -0,0 +1,79 @@ +// Karma configuration +// Generated on Thu Sep 04 2014 07:41:43 GMT-0400 (EDT) + +module.exports = function(config) { + config.set({ + + // base path that will be used to resolve all patterns (eg. files, exclude) + basePath: '', + + + // frameworks to use + // available frameworks: https://npmjs.org/browse/keyword/karma-adapter + frameworks: ['qunit'], + +// plugins: ['karma-qunit', 'karma-coverage', 'phantomjs', 'karma-phantomjs-launcher'], + + + // list of files / patterns to load in the browser + files: [ +// 'http://code.jquery.com/jquery.js', + 'node_modules/jquery/dist/jquery.min.js', + 'toastr.css', + 'toastr.js', + 'node_modules/qunitjs/qunit/qunit.js', + 'tests/unit/qunit-helper.js', + //'tests/unit/x.js' + 'tests/unit/toastr-tests.js' + ], + + + // list of files to exclude + exclude: [ + ], + + + // preprocess matching files before serving them to the browser + // available preprocessors: https://npmjs.org/browse/keyword/karma-preprocessor + preprocessors: { + 'toastr.js': 'coverage' + }, + + + // test results reporter to use + // possible values: 'dots', 'progress' + // available reporters: https://npmjs.org/browse/keyword/karma-reporter + reporters: ['progress', 'coverage'], + + coverageReporter: { + type: 'lcov', + dir: 'tests/coverage' + }, + + // web server port + port: 9876, + + + // enable / disable colors in the output (reporters and logs) + colors: true, + + + // level of logging + // possible values: config.LOG_DISABLE || config.LOG_ERROR || config.LOG_WARN || config.LOG_INFO || config.LOG_DEBUG + logLevel: config.LOG_INFO, + + + // enable / disable watching file and executing tests whenever any file changes + autoWatch: false, + + + // start these browsers + // available browser launchers: https://npmjs.org/browse/keyword/karma-launcher + browsers: ['PhantomJS'], + + + // Continuous Integration mode + // if true, Karma captures browsers, runs the tests and exits + singleRun: true + }); +}; diff --git a/node_modules/toastr/package/nuget/content/content/toastr.css b/node_modules/toastr/package/nuget/content/content/toastr.css new file mode 100644 index 0000000..d86235a --- /dev/null +++ b/node_modules/toastr/package/nuget/content/content/toastr.css @@ -0,0 +1,180 @@ +/* + * Toastr + * Copyright 2012-2014 John Papa and Hans Fjällemark. + * All Rights Reserved. + * Use, reproduction, distribution, and modification of this code is subject to the terms and + * conditions of the MIT license, available at http://www.opensource.org/licenses/mit-license.php + * + * Author: John Papa and Hans Fjällemark + * Project: https://github.com/CodeSeven/toastr + */ +.toast-title { + font-weight: bold; +} +.toast-message { + -ms-word-wrap: break-word; + word-wrap: break-word; +} +.toast-message a, +.toast-message label { + color: #ffffff; +} +.toast-message a:hover { + color: #cccccc; + text-decoration: none; +} +.toast-close-button { + position: relative; + right: -0.3em; + top: -0.3em; + float: right; + font-size: 20px; + font-weight: bold; + color: #ffffff; + -webkit-text-shadow: 0 1px 0 #ffffff; + text-shadow: 0 1px 0 #ffffff; + opacity: 0.8; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=80); + filter: alpha(opacity=80); +} +.toast-close-button:hover, +.toast-close-button:focus { + color: #000000; + text-decoration: none; + cursor: pointer; + opacity: 0.4; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=40); + filter: alpha(opacity=40); +} +/*Additional properties for button version + iOS requires the button element instead of an anchor tag. + If you want the anchor version, it requires `href="#"`.*/ +button.toast-close-button { + padding: 0; + cursor: pointer; + background: transparent; + border: 0; + -webkit-appearance: none; +} +.toast-top-full-width { + top: 0; + right: 0; + width: 100%; +} +.toast-bottom-full-width { + bottom: 0; + right: 0; + width: 100%; +} +.toast-top-left { + top: 12px; + left: 12px; +} +.toast-top-right { + top: 12px; + right: 12px; +} +.toast-bottom-right { + right: 12px; + bottom: 12px; +} +.toast-bottom-left { + bottom: 12px; + left: 12px; +} +#toast-container { + position: fixed; + z-index: 999999; + /*overrides*/ + +} +#toast-container * { + -moz-box-sizing: border-box; + -webkit-box-sizing: border-box; + box-sizing: border-box; +} +#toast-container > div { + margin: 0 0 6px; + padding: 15px 15px 15px 50px; + width: 300px; + -moz-border-radius: 3px 3px 3px 3px; + -webkit-border-radius: 3px 3px 3px 3px; + border-radius: 3px 3px 3px 3px; + background-position: 15px center; + background-repeat: no-repeat; + -moz-box-shadow: 0 0 12px #999999; + -webkit-box-shadow: 0 0 12px #999999; + box-shadow: 0 0 12px #999999; + color: #ffffff; + opacity: 0.8; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=80); + filter: alpha(opacity=80); +} +#toast-container > :hover { + -moz-box-shadow: 0 0 12px #000000; + -webkit-box-shadow: 0 0 12px #000000; + box-shadow: 0 0 12px #000000; + opacity: 1; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=100); + filter: alpha(opacity=100); + cursor: pointer; +} +#toast-container > .toast-info { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGwSURBVEhLtZa9SgNBEMc9sUxxRcoUKSzSWIhXpFMhhYWFhaBg4yPYiWCXZxBLERsLRS3EQkEfwCKdjWJAwSKCgoKCcudv4O5YLrt7EzgXhiU3/4+b2ckmwVjJSpKkQ6wAi4gwhT+z3wRBcEz0yjSseUTrcRyfsHsXmD0AmbHOC9Ii8VImnuXBPglHpQ5wwSVM7sNnTG7Za4JwDdCjxyAiH3nyA2mtaTJufiDZ5dCaqlItILh1NHatfN5skvjx9Z38m69CgzuXmZgVrPIGE763Jx9qKsRozWYw6xOHdER+nn2KkO+Bb+UV5CBN6WC6QtBgbRVozrahAbmm6HtUsgtPC19tFdxXZYBOfkbmFJ1VaHA1VAHjd0pp70oTZzvR+EVrx2Ygfdsq6eu55BHYR8hlcki+n+kERUFG8BrA0BwjeAv2M8WLQBtcy+SD6fNsmnB3AlBLrgTtVW1c2QN4bVWLATaIS60J2Du5y1TiJgjSBvFVZgTmwCU+dAZFoPxGEEs8nyHC9Bwe2GvEJv2WXZb0vjdyFT4Cxk3e/kIqlOGoVLwwPevpYHT+00T+hWwXDf4AJAOUqWcDhbwAAAAASUVORK5CYII=") !important; +} +#toast-container > .toast-error { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAHOSURBVEhLrZa/SgNBEMZzh0WKCClSCKaIYOED+AAKeQQLG8HWztLCImBrYadgIdY+gIKNYkBFSwu7CAoqCgkkoGBI/E28PdbLZmeDLgzZzcx83/zZ2SSXC1j9fr+I1Hq93g2yxH4iwM1vkoBWAdxCmpzTxfkN2RcyZNaHFIkSo10+8kgxkXIURV5HGxTmFuc75B2RfQkpxHG8aAgaAFa0tAHqYFfQ7Iwe2yhODk8+J4C7yAoRTWI3w/4klGRgR4lO7Rpn9+gvMyWp+uxFh8+H+ARlgN1nJuJuQAYvNkEnwGFck18Er4q3egEc/oO+mhLdKgRyhdNFiacC0rlOCbhNVz4H9FnAYgDBvU3QIioZlJFLJtsoHYRDfiZoUyIxqCtRpVlANq0EU4dApjrtgezPFad5S19Wgjkc0hNVnuF4HjVA6C7QrSIbylB+oZe3aHgBsqlNqKYH48jXyJKMuAbiyVJ8KzaB3eRc0pg9VwQ4niFryI68qiOi3AbjwdsfnAtk0bCjTLJKr6mrD9g8iq/S/B81hguOMlQTnVyG40wAcjnmgsCNESDrjme7wfftP4P7SP4N3CJZdvzoNyGq2c/HWOXJGsvVg+RA/k2MC/wN6I2YA2Pt8GkAAAAASUVORK5CYII=") !important; +} +#toast-container > .toast-success { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAADsSURBVEhLY2AYBfQMgf///3P8+/evAIgvA/FsIF+BavYDDWMBGroaSMMBiE8VC7AZDrIFaMFnii3AZTjUgsUUWUDA8OdAH6iQbQEhw4HyGsPEcKBXBIC4ARhex4G4BsjmweU1soIFaGg/WtoFZRIZdEvIMhxkCCjXIVsATV6gFGACs4Rsw0EGgIIH3QJYJgHSARQZDrWAB+jawzgs+Q2UO49D7jnRSRGoEFRILcdmEMWGI0cm0JJ2QpYA1RDvcmzJEWhABhD/pqrL0S0CWuABKgnRki9lLseS7g2AlqwHWQSKH4oKLrILpRGhEQCw2LiRUIa4lwAAAABJRU5ErkJggg==") !important; +} +#toast-container > .toast-warning { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGYSURBVEhL5ZSvTsNQFMbXZGICMYGYmJhAQIJAICYQPAACiSDB8AiICQQJT4CqQEwgJvYASAQCiZiYmJhAIBATCARJy+9rTsldd8sKu1M0+dLb057v6/lbq/2rK0mS/TRNj9cWNAKPYIJII7gIxCcQ51cvqID+GIEX8ASG4B1bK5gIZFeQfoJdEXOfgX4QAQg7kH2A65yQ87lyxb27sggkAzAuFhbbg1K2kgCkB1bVwyIR9m2L7PRPIhDUIXgGtyKw575yz3lTNs6X4JXnjV+LKM/m3MydnTbtOKIjtz6VhCBq4vSm3ncdrD2lk0VgUXSVKjVDJXJzijW1RQdsU7F77He8u68koNZTz8Oz5yGa6J3H3lZ0xYgXBK2QymlWWA+RWnYhskLBv2vmE+hBMCtbA7KX5drWyRT/2JsqZ2IvfB9Y4bWDNMFbJRFmC9E74SoS0CqulwjkC0+5bpcV1CZ8NMej4pjy0U+doDQsGyo1hzVJttIjhQ7GnBtRFN1UarUlH8F3xict+HY07rEzoUGPlWcjRFRr4/gChZgc3ZL2d8oAAAAASUVORK5CYII=") !important; +} +#toast-container.toast-top-full-width > div, +#toast-container.toast-bottom-full-width > div { + width: 96%; + margin: auto; +} +.toast { + background-color: #030303; +} +.toast-success { + background-color: #51a351; +} +.toast-error { + background-color: #bd362f; +} +.toast-info { + background-color: #2f96b4; +} +.toast-warning { + background-color: #f89406; +} +/*Responsive Design*/ +@media all and (max-width: 240px) { + #toast-container > div { + padding: 8px 8px 8px 50px; + width: 11em; + } + #toast-container .toast-close-button { + right: -0.2em; + top: -0.2em; + } +} +@media all and (min-width: 241px) and (max-width: 480px) { + #toast-container > div { + padding: 8px 8px 8px 50px; + width: 18em; + } + #toast-container .toast-close-button { + right: -0.2em; + top: -0.2em; + } +} +@media all and (min-width: 481px) and (max-width: 768px) { + #toast-container > div { + padding: 15px 15px 15px 50px; + width: 25em; + } +} diff --git a/node_modules/toastr/package/nuget/content/content/toastr.less b/node_modules/toastr/package/nuget/content/content/toastr.less new file mode 100644 index 0000000..146fabe --- /dev/null +++ b/node_modules/toastr/package/nuget/content/content/toastr.less @@ -0,0 +1,232 @@ +// Mix-ins +.borderRadius(@radius) { + -moz-border-radius: @radius; + -webkit-border-radius: @radius; + border-radius: @radius; +} + +.boxShadow(@boxShadow) { + -moz-box-shadow: @boxShadow; + -webkit-box-shadow: @boxShadow; + box-shadow: @boxShadow; +} + +.opacity(@opacity) { + @opacityPercent: @opacity * 100; + opacity: @opacity; + -ms-filter: ~"progid:DXImageTransform.Microsoft.Alpha(Opacity=@{opacityPercent})"; + filter: ~"alpha(opacity=@{opacityPercent})"; +} + +.wordWrap(@wordWrap: break-word) { + -ms-word-wrap: @wordWrap; + word-wrap: @wordWrap; +} + +// Variables +@black: #000000; +@grey: #999999; +@light-grey: #CCCCCC; +@white: #FFFFFF; +@near-black: #030303; +@green: #51A351; +@red: #BD362F; +@blue: #2F96B4; +@orange: #F89406; + +// Styles +.toast-title { + font-weight: bold; +} + +.toast-message { + .wordWrap(); + + a, + label { + color: @white; + } + + a:hover { + color: @light-grey; + text-decoration: none; + } +} + +.toast-close-button { + position: relative; + right: -0.3em; + top: -0.3em; + float: right; + font-size: 20px; + font-weight: bold; + color: @white; + -webkit-text-shadow: 0 1px 0 rgba(255,255,255,1); + text-shadow: 0 1px 0 rgba(255,255,255,1); + .opacity(0.8); + + &:hover, + &:focus { + color: @black; + text-decoration: none; + cursor: pointer; + .opacity(0.4); + } +} + +/*Additional properties for button version + iOS requires the button element instead of an anchor tag. + If you want the anchor version, it requires `href="#"`.*/ +button.toast-close-button { + padding: 0; + cursor: pointer; + background: transparent; + border: 0; + -webkit-appearance: none; +} + +//#endregion + +.toast-top-full-width { + top: 0; + right: 0; + width: 100%; +} + +.toast-bottom-full-width { + bottom: 0; + right: 0; + width: 100%; +} + +.toast-top-left { + top: 12px; + left: 12px; +} + +.toast-top-right { + top: 12px; + right: 12px; +} + +.toast-bottom-right { + right: 12px; + bottom: 12px; +} + +.toast-bottom-left { + bottom: 12px; + left: 12px; +} + +#toast-container { + position: fixed; + z-index: 999999; + + * { + -moz-box-sizing: border-box; + -webkit-box-sizing: border-box; + box-sizing: border-box; + } + + > div { + margin: 0 0 6px; + padding: 15px 15px 15px 50px; + width: 300px; + .borderRadius(3px 3px 3px 3px); + background-position: 15px center; + background-repeat: no-repeat; + .boxShadow(0 0 12px @grey); + color: @white; + .opacity(0.8); + } + + > :hover { + .boxShadow(0 0 12px @black); + .opacity(1); + cursor: pointer; + } + + > .toast-info { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGwSURBVEhLtZa9SgNBEMc9sUxxRcoUKSzSWIhXpFMhhYWFhaBg4yPYiWCXZxBLERsLRS3EQkEfwCKdjWJAwSKCgoKCcudv4O5YLrt7EzgXhiU3/4+b2ckmwVjJSpKkQ6wAi4gwhT+z3wRBcEz0yjSseUTrcRyfsHsXmD0AmbHOC9Ii8VImnuXBPglHpQ5wwSVM7sNnTG7Za4JwDdCjxyAiH3nyA2mtaTJufiDZ5dCaqlItILh1NHatfN5skvjx9Z38m69CgzuXmZgVrPIGE763Jx9qKsRozWYw6xOHdER+nn2KkO+Bb+UV5CBN6WC6QtBgbRVozrahAbmm6HtUsgtPC19tFdxXZYBOfkbmFJ1VaHA1VAHjd0pp70oTZzvR+EVrx2Ygfdsq6eu55BHYR8hlcki+n+kERUFG8BrA0BwjeAv2M8WLQBtcy+SD6fNsmnB3AlBLrgTtVW1c2QN4bVWLATaIS60J2Du5y1TiJgjSBvFVZgTmwCU+dAZFoPxGEEs8nyHC9Bwe2GvEJv2WXZb0vjdyFT4Cxk3e/kIqlOGoVLwwPevpYHT+00T+hWwXDf4AJAOUqWcDhbwAAAAASUVORK5CYII=") !important; + } + + > .toast-error { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAHOSURBVEhLrZa/SgNBEMZzh0WKCClSCKaIYOED+AAKeQQLG8HWztLCImBrYadgIdY+gIKNYkBFSwu7CAoqCgkkoGBI/E28PdbLZmeDLgzZzcx83/zZ2SSXC1j9fr+I1Hq93g2yxH4iwM1vkoBWAdxCmpzTxfkN2RcyZNaHFIkSo10+8kgxkXIURV5HGxTmFuc75B2RfQkpxHG8aAgaAFa0tAHqYFfQ7Iwe2yhODk8+J4C7yAoRTWI3w/4klGRgR4lO7Rpn9+gvMyWp+uxFh8+H+ARlgN1nJuJuQAYvNkEnwGFck18Er4q3egEc/oO+mhLdKgRyhdNFiacC0rlOCbhNVz4H9FnAYgDBvU3QIioZlJFLJtsoHYRDfiZoUyIxqCtRpVlANq0EU4dApjrtgezPFad5S19Wgjkc0hNVnuF4HjVA6C7QrSIbylB+oZe3aHgBsqlNqKYH48jXyJKMuAbiyVJ8KzaB3eRc0pg9VwQ4niFryI68qiOi3AbjwdsfnAtk0bCjTLJKr6mrD9g8iq/S/B81hguOMlQTnVyG40wAcjnmgsCNESDrjme7wfftP4P7SP4N3CJZdvzoNyGq2c/HWOXJGsvVg+RA/k2MC/wN6I2YA2Pt8GkAAAAASUVORK5CYII=") !important; + } + + > .toast-success { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAADsSURBVEhLY2AYBfQMgf///3P8+/evAIgvA/FsIF+BavYDDWMBGroaSMMBiE8VC7AZDrIFaMFnii3AZTjUgsUUWUDA8OdAH6iQbQEhw4HyGsPEcKBXBIC4ARhex4G4BsjmweU1soIFaGg/WtoFZRIZdEvIMhxkCCjXIVsATV6gFGACs4Rsw0EGgIIH3QJYJgHSARQZDrWAB+jawzgs+Q2UO49D7jnRSRGoEFRILcdmEMWGI0cm0JJ2QpYA1RDvcmzJEWhABhD/pqrL0S0CWuABKgnRki9lLseS7g2AlqwHWQSKH4oKLrILpRGhEQCw2LiRUIa4lwAAAABJRU5ErkJggg==") !important; + } + + > .toast-warning { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGYSURBVEhL5ZSvTsNQFMbXZGICMYGYmJhAQIJAICYQPAACiSDB8AiICQQJT4CqQEwgJvYASAQCiZiYmJhAIBATCARJy+9rTsldd8sKu1M0+dLb057v6/lbq/2rK0mS/TRNj9cWNAKPYIJII7gIxCcQ51cvqID+GIEX8ASG4B1bK5gIZFeQfoJdEXOfgX4QAQg7kH2A65yQ87lyxb27sggkAzAuFhbbg1K2kgCkB1bVwyIR9m2L7PRPIhDUIXgGtyKw575yz3lTNs6X4JXnjV+LKM/m3MydnTbtOKIjtz6VhCBq4vSm3ncdrD2lk0VgUXSVKjVDJXJzijW1RQdsU7F77He8u68koNZTz8Oz5yGa6J3H3lZ0xYgXBK2QymlWWA+RWnYhskLBv2vmE+hBMCtbA7KX5drWyRT/2JsqZ2IvfB9Y4bWDNMFbJRFmC9E74SoS0CqulwjkC0+5bpcV1CZ8NMej4pjy0U+doDQsGyo1hzVJttIjhQ7GnBtRFN1UarUlH8F3xict+HY07rEzoUGPlWcjRFRr4/gChZgc3ZL2d8oAAAAASUVORK5CYII=") !important; + } + + /*overrides*/ + &.toast-top-full-width > div, + &.toast-bottom-full-width > div { + width: 96%; + margin: auto; + } +} + +.toast { + background-color: @near-black; +} + +.toast-success { + background-color: @green; +} + +.toast-error { + background-color: @red; +} + +.toast-info { + background-color: @blue; +} + +.toast-warning { + background-color: @orange; +} + +/*Responsive Design*/ + +@media all and (max-width: 240px) { + #toast-container { + + > div { + padding: 8px 8px 8px 50px; + width: 11em; + } + + & .toast-close-button { + right: -0.2em; + top: -0.2em; + } + } +} + +@media all and (min-width: 241px) and (max-width: 480px) { + #toast-container { + > div { + padding: 8px 8px 8px 50px; + width: 18em; + } + + & .toast-close-button { + right: -0.2em; + top: -0.2em; + } + } +} + +@media all and (min-width: 481px) and (max-width: 768px) { + #toast-container { + > div { + padding: 15px 15px 15px 50px; + width: 25em; + } + } +} \ No newline at end of file diff --git a/node_modules/toastr/package/nuget/content/content/toastr.min.css b/node_modules/toastr/package/nuget/content/content/toastr.min.css new file mode 100644 index 0000000..40975cb --- /dev/null +++ b/node_modules/toastr/package/nuget/content/content/toastr.min.css @@ -0,0 +1 @@ +.toast-title{font-weight:bold}.toast-message{-ms-word-wrap:break-word;word-wrap:break-word}.toast-message a,.toast-message label{color:#fff}.toast-message a:hover{color:#ccc;text-decoration:none}.toast-close-button{position:relative;right:-0.3em;top:-0.3em;float:right;font-size:20px;font-weight:bold;color:#fff;-webkit-text-shadow:0 1px 0 #fff;text-shadow:0 1px 0 #fff;opacity:.8;-ms-filter:alpha(opacity=80);filter:alpha(opacity=80)}.toast-close-button:hover,.toast-close-button:focus{color:#000;text-decoration:none;cursor:pointer;opacity:.4;-ms-filter:alpha(opacity=40);filter:alpha(opacity=40)}button.toast-close-button{padding:0;cursor:pointer;background:transparent;border:0;-webkit-appearance:none}.toast-top-full-width{top:0;right:0;width:100%}.toast-bottom-full-width{bottom:0;right:0;width:100%}.toast-top-left{top:12px;left:12px}.toast-top-right{top:12px;right:12px}.toast-bottom-right{right:12px;bottom:12px}.toast-bottom-left{bottom:12px;left:12px}#toast-container{position:fixed;z-index:999999}#toast-container *{-moz-box-sizing:border-box;-webkit-box-sizing:border-box;box-sizing:border-box}#toast-container>div{margin:0 0 6px;padding:15px 15px 15px 50px;width:300px;-moz-border-radius:3px 3px 3px 3px;-webkit-border-radius:3px 3px 3px 3px;border-radius:3px 3px 3px 3px;background-position:15px center;background-repeat:no-repeat;-moz-box-shadow:0 0 12px #999;-webkit-box-shadow:0 0 12px #999;box-shadow:0 0 12px #999;color:#fff;opacity:.8;-ms-filter:alpha(opacity=80);filter:alpha(opacity=80)}#toast-container>:hover{-moz-box-shadow:0 0 12px #000;-webkit-box-shadow:0 0 12px #000;box-shadow:0 0 12px #000;opacity:1;-ms-filter:alpha(opacity=100);filter:alpha(opacity=100);cursor:pointer}#toast-container>.toast-info{background-image:url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGwSURBVEhLtZa9SgNBEMc9sUxxRcoUKSzSWIhXpFMhhYWFhaBg4yPYiWCXZxBLERsLRS3EQkEfwCKdjWJAwSKCgoKCcudv4O5YLrt7EzgXhiU3/4+b2ckmwVjJSpKkQ6wAi4gwhT+z3wRBcEz0yjSseUTrcRyfsHsXmD0AmbHOC9Ii8VImnuXBPglHpQ5wwSVM7sNnTG7Za4JwDdCjxyAiH3nyA2mtaTJufiDZ5dCaqlItILh1NHatfN5skvjx9Z38m69CgzuXmZgVrPIGE763Jx9qKsRozWYw6xOHdER+nn2KkO+Bb+UV5CBN6WC6QtBgbRVozrahAbmm6HtUsgtPC19tFdxXZYBOfkbmFJ1VaHA1VAHjd0pp70oTZzvR+EVrx2Ygfdsq6eu55BHYR8hlcki+n+kERUFG8BrA0BwjeAv2M8WLQBtcy+SD6fNsmnB3AlBLrgTtVW1c2QN4bVWLATaIS60J2Du5y1TiJgjSBvFVZgTmwCU+dAZFoPxGEEs8nyHC9Bwe2GvEJv2WXZb0vjdyFT4Cxk3e/kIqlOGoVLwwPevpYHT+00T+hWwXDf4AJAOUqWcDhbwAAAAASUVORK5CYII=")!important}#toast-container>.toast-error{background-image:url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAHOSURBVEhLrZa/SgNBEMZzh0WKCClSCKaIYOED+AAKeQQLG8HWztLCImBrYadgIdY+gIKNYkBFSwu7CAoqCgkkoGBI/E28PdbLZmeDLgzZzcx83/zZ2SSXC1j9fr+I1Hq93g2yxH4iwM1vkoBWAdxCmpzTxfkN2RcyZNaHFIkSo10+8kgxkXIURV5HGxTmFuc75B2RfQkpxHG8aAgaAFa0tAHqYFfQ7Iwe2yhODk8+J4C7yAoRTWI3w/4klGRgR4lO7Rpn9+gvMyWp+uxFh8+H+ARlgN1nJuJuQAYvNkEnwGFck18Er4q3egEc/oO+mhLdKgRyhdNFiacC0rlOCbhNVz4H9FnAYgDBvU3QIioZlJFLJtsoHYRDfiZoUyIxqCtRpVlANq0EU4dApjrtgezPFad5S19Wgjkc0hNVnuF4HjVA6C7QrSIbylB+oZe3aHgBsqlNqKYH48jXyJKMuAbiyVJ8KzaB3eRc0pg9VwQ4niFryI68qiOi3AbjwdsfnAtk0bCjTLJKr6mrD9g8iq/S/B81hguOMlQTnVyG40wAcjnmgsCNESDrjme7wfftP4P7SP4N3CJZdvzoNyGq2c/HWOXJGsvVg+RA/k2MC/wN6I2YA2Pt8GkAAAAASUVORK5CYII=")!important}#toast-container>.toast-success{background-image:url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAADsSURBVEhLY2AYBfQMgf///3P8+/evAIgvA/FsIF+BavYDDWMBGroaSMMBiE8VC7AZDrIFaMFnii3AZTjUgsUUWUDA8OdAH6iQbQEhw4HyGsPEcKBXBIC4ARhex4G4BsjmweU1soIFaGg/WtoFZRIZdEvIMhxkCCjXIVsATV6gFGACs4Rsw0EGgIIH3QJYJgHSARQZDrWAB+jawzgs+Q2UO49D7jnRSRGoEFRILcdmEMWGI0cm0JJ2QpYA1RDvcmzJEWhABhD/pqrL0S0CWuABKgnRki9lLseS7g2AlqwHWQSKH4oKLrILpRGhEQCw2LiRUIa4lwAAAABJRU5ErkJggg==")!important}#toast-container>.toast-warning{background-image:url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGYSURBVEhL5ZSvTsNQFMbXZGICMYGYmJhAQIJAICYQPAACiSDB8AiICQQJT4CqQEwgJvYASAQCiZiYmJhAIBATCARJy+9rTsldd8sKu1M0+dLb057v6/lbq/2rK0mS/TRNj9cWNAKPYIJII7gIxCcQ51cvqID+GIEX8ASG4B1bK5gIZFeQfoJdEXOfgX4QAQg7kH2A65yQ87lyxb27sggkAzAuFhbbg1K2kgCkB1bVwyIR9m2L7PRPIhDUIXgGtyKw575yz3lTNs6X4JXnjV+LKM/m3MydnTbtOKIjtz6VhCBq4vSm3ncdrD2lk0VgUXSVKjVDJXJzijW1RQdsU7F77He8u68koNZTz8Oz5yGa6J3H3lZ0xYgXBK2QymlWWA+RWnYhskLBv2vmE+hBMCtbA7KX5drWyRT/2JsqZ2IvfB9Y4bWDNMFbJRFmC9E74SoS0CqulwjkC0+5bpcV1CZ8NMej4pjy0U+doDQsGyo1hzVJttIjhQ7GnBtRFN1UarUlH8F3xict+HY07rEzoUGPlWcjRFRr4/gChZgc3ZL2d8oAAAAASUVORK5CYII=")!important}#toast-container.toast-top-full-width>div,#toast-container.toast-bottom-full-width>div{width:96%;margin:auto}.toast{background-color:#030303}.toast-success{background-color:#51a351}.toast-error{background-color:#bd362f}.toast-info{background-color:#2f96b4}.toast-warning{background-color:#f89406}@media all and (max-width:240px){#toast-container>div{padding:8px 8px 8px 50px;width:11em}#toast-container .toast-close-button{right:-0.2em;top:-0.2em}}@media all and (min-width:241px) and (max-width:480px){#toast-container>div{padding:8px 8px 8px 50px;width:18em}#toast-container .toast-close-button{right:-0.2em;top:-0.2em}}@media all and (min-width:481px) and (max-width:768px){#toast-container>div{padding:15px 15px 15px 50px;width:25em}} \ No newline at end of file diff --git a/node_modules/toastr/package/nuget/content/content/toastr.scss b/node_modules/toastr/package/nuget/content/content/toastr.scss new file mode 100644 index 0000000..71f017b --- /dev/null +++ b/node_modules/toastr/package/nuget/content/content/toastr.scss @@ -0,0 +1,183 @@ +/* + * Toastr + * Version 2.0.1 + * Copyright 2012 John Papa and Hans Fjällemark. + * All Rights Reserved. + * Use, reproduction, distribution, and modification of this code is subject to the terms and + * conditions of the MIT license, available at http://www.opensource.org/licenses/mit-license.php + * + * Author: John Papa and Hans Fjällemark + * Project: https://github.com/CodeSeven/toastr + */ +.toast-title { + font-weight: bold; +} +.toast-message { + -ms-word-wrap: break-word; + word-wrap: break-word; +} +.toast-message a, +.toast-message label { + color: #ffffff; +} +.toast-message a:hover { + color: #cccccc; + text-decoration: none; +} + +.toast-close-button { + position: relative; + right: -0.3em; + top: -0.3em; + float: right; + font-size: 20px; + font-weight: bold; + color: #ffffff; + -webkit-text-shadow: 0 1px 0 #ffffff; + text-shadow: 0 1px 0 #ffffff; + opacity: 0.8; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=80); + filter: alpha(opacity=80); +} +.toast-close-button:hover, +.toast-close-button:focus { + color: #000000; + text-decoration: none; + cursor: pointer; + opacity: 0.4; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=40); + filter: alpha(opacity=40); +} + +/*Additional properties for button version + iOS requires the button element instead of an anchor tag. + If you want the anchor version, it requires `href="#"`.*/ +button.toast-close-button { + padding: 0; + cursor: pointer; + background: transparent; + border: 0; + -webkit-appearance: none; +} +.toast-top-full-width { + top: 0; + right: 0; + width: 100%; +} +.toast-bottom-full-width { + bottom: 0; + right: 0; + width: 100%; +} +.toast-top-left { + top: 12px; + left: 12px; +} +.toast-top-right { + top: 12px; + right: 12px; +} +.toast-bottom-right { + right: 12px; + bottom: 12px; +} +.toast-bottom-left { + bottom: 12px; + left: 12px; +} +#toast-container { + position: fixed; + z-index: 999999; + /*overrides*/ + +} +#toast-container * { + -moz-box-sizing: border-box; + -webkit-box-sizing: border-box; + box-sizing: border-box; +} +#toast-container > div { + margin: 0 0 6px; + padding: 15px 15px 15px 50px; + width: 300px; + -moz-border-radius: 3px 3px 3px 3px; + -webkit-border-radius: 3px 3px 3px 3px; + border-radius: 3px 3px 3px 3px; + background-position: 15px center; + background-repeat: no-repeat; + -moz-box-shadow: 0 0 12px #999999; + -webkit-box-shadow: 0 0 12px #999999; + box-shadow: 0 0 12px #999999; + color: #ffffff; + opacity: 0.8; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=80); + filter: alpha(opacity=80); +} +#toast-container > :hover { + -moz-box-shadow: 0 0 12px #000000; + -webkit-box-shadow: 0 0 12px #000000; + box-shadow: 0 0 12px #000000; + opacity: 1; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=100); + filter: alpha(opacity=100); + cursor: pointer; +} +#toast-container > .toast-info { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGwSURBVEhLtZa9SgNBEMc9sUxxRcoUKSzSWIhXpFMhhYWFhaBg4yPYiWCXZxBLERsLRS3EQkEfwCKdjWJAwSKCgoKCcudv4O5YLrt7EzgXhiU3/4+b2ckmwVjJSpKkQ6wAi4gwhT+z3wRBcEz0yjSseUTrcRyfsHsXmD0AmbHOC9Ii8VImnuXBPglHpQ5wwSVM7sNnTG7Za4JwDdCjxyAiH3nyA2mtaTJufiDZ5dCaqlItILh1NHatfN5skvjx9Z38m69CgzuXmZgVrPIGE763Jx9qKsRozWYw6xOHdER+nn2KkO+Bb+UV5CBN6WC6QtBgbRVozrahAbmm6HtUsgtPC19tFdxXZYBOfkbmFJ1VaHA1VAHjd0pp70oTZzvR+EVrx2Ygfdsq6eu55BHYR8hlcki+n+kERUFG8BrA0BwjeAv2M8WLQBtcy+SD6fNsmnB3AlBLrgTtVW1c2QN4bVWLATaIS60J2Du5y1TiJgjSBvFVZgTmwCU+dAZFoPxGEEs8nyHC9Bwe2GvEJv2WXZb0vjdyFT4Cxk3e/kIqlOGoVLwwPevpYHT+00T+hWwXDf4AJAOUqWcDhbwAAAAASUVORK5CYII=") !important; +} +#toast-container > .toast-error { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAHOSURBVEhLrZa/SgNBEMZzh0WKCClSCKaIYOED+AAKeQQLG8HWztLCImBrYadgIdY+gIKNYkBFSwu7CAoqCgkkoGBI/E28PdbLZmeDLgzZzcx83/zZ2SSXC1j9fr+I1Hq93g2yxH4iwM1vkoBWAdxCmpzTxfkN2RcyZNaHFIkSo10+8kgxkXIURV5HGxTmFuc75B2RfQkpxHG8aAgaAFa0tAHqYFfQ7Iwe2yhODk8+J4C7yAoRTWI3w/4klGRgR4lO7Rpn9+gvMyWp+uxFh8+H+ARlgN1nJuJuQAYvNkEnwGFck18Er4q3egEc/oO+mhLdKgRyhdNFiacC0rlOCbhNVz4H9FnAYgDBvU3QIioZlJFLJtsoHYRDfiZoUyIxqCtRpVlANq0EU4dApjrtgezPFad5S19Wgjkc0hNVnuF4HjVA6C7QrSIbylB+oZe3aHgBsqlNqKYH48jXyJKMuAbiyVJ8KzaB3eRc0pg9VwQ4niFryI68qiOi3AbjwdsfnAtk0bCjTLJKr6mrD9g8iq/S/B81hguOMlQTnVyG40wAcjnmgsCNESDrjme7wfftP4P7SP4N3CJZdvzoNyGq2c/HWOXJGsvVg+RA/k2MC/wN6I2YA2Pt8GkAAAAASUVORK5CYII=") !important; +} +#toast-container > .toast-success { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAADsSURBVEhLY2AYBfQMgf///3P8+/evAIgvA/FsIF+BavYDDWMBGroaSMMBiE8VC7AZDrIFaMFnii3AZTjUgsUUWUDA8OdAH6iQbQEhw4HyGsPEcKBXBIC4ARhex4G4BsjmweU1soIFaGg/WtoFZRIZdEvIMhxkCCjXIVsATV6gFGACs4Rsw0EGgIIH3QJYJgHSARQZDrWAB+jawzgs+Q2UO49D7jnRSRGoEFRILcdmEMWGI0cm0JJ2QpYA1RDvcmzJEWhABhD/pqrL0S0CWuABKgnRki9lLseS7g2AlqwHWQSKH4oKLrILpRGhEQCw2LiRUIa4lwAAAABJRU5ErkJggg==") !important; +} +#toast-container > .toast-warning { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGYSURBVEhL5ZSvTsNQFMbXZGICMYGYmJhAQIJAICYQPAACiSDB8AiICQQJT4CqQEwgJvYASAQCiZiYmJhAIBATCARJy+9rTsldd8sKu1M0+dLb057v6/lbq/2rK0mS/TRNj9cWNAKPYIJII7gIxCcQ51cvqID+GIEX8ASG4B1bK5gIZFeQfoJdEXOfgX4QAQg7kH2A65yQ87lyxb27sggkAzAuFhbbg1K2kgCkB1bVwyIR9m2L7PRPIhDUIXgGtyKw575yz3lTNs6X4JXnjV+LKM/m3MydnTbtOKIjtz6VhCBq4vSm3ncdrD2lk0VgUXSVKjVDJXJzijW1RQdsU7F77He8u68koNZTz8Oz5yGa6J3H3lZ0xYgXBK2QymlWWA+RWnYhskLBv2vmE+hBMCtbA7KX5drWyRT/2JsqZ2IvfB9Y4bWDNMFbJRFmC9E74SoS0CqulwjkC0+5bpcV1CZ8NMej4pjy0U+doDQsGyo1hzVJttIjhQ7GnBtRFN1UarUlH8F3xict+HY07rEzoUGPlWcjRFRr4/gChZgc3ZL2d8oAAAAASUVORK5CYII=") !important; +} +#toast-container.toast-top-full-width > div, +#toast-container.toast-bottom-full-width > div { + width: 96%; + margin: auto; +} +.toast { + background-color: #030303; +} +.toast-success { + background-color: #51a351; +} +.toast-error { + background-color: #bd362f; +} +.toast-info { + background-color: #2f96b4; +} +.toast-warning { + background-color: #f89406; +} +/*Responsive Design*/ +@media all and (max-width: 239px) { + #toast-container > div { + padding: 8px 8px 8px 50px; + width: 11em; + } + #toast-container .toast-close-button { + right: -0.2em; + top: -0.2em; + } +} +@media all and (min-width: 240px) and (max-width: 479px) { + #toast-container > div { + padding: 8px 8px 8px 50px; + width: 18em; + } + #toast-container .toast-close-button { + right: -0.2em; + top: -0.2em; + } +} +@media all and (min-width: 480px) and (max-width: 767px) { + #toast-container > div { + padding: 15px 15px 15px 50px; + width: 25em; + } +} \ No newline at end of file diff --git a/node_modules/toastr/package/nuget/content/scripts/toastr.js b/node_modules/toastr/package/nuget/content/scripts/toastr.js new file mode 100644 index 0000000..87ae449 --- /dev/null +++ b/node_modules/toastr/package/nuget/content/scripts/toastr.js @@ -0,0 +1,338 @@ +/* + * Toastr + * Copyright 2012-2014 John Papa and Hans Fjällemark. + * All Rights Reserved. + * Use, reproduction, distribution, and modification of this code is subject to the terms and + * conditions of the MIT license, available at http://www.opensource.org/licenses/mit-license.php + * + * Author: John Papa and Hans Fjällemark + * ARIA Support: Greta Krafsig + * Project: https://github.com/CodeSeven/toastr + */ +; (function (define) { + define(['jquery'], function ($) { + return (function () { + var $container; + var listener; + var toastId = 0; + var toastType = { + error: 'error', + info: 'info', + success: 'success', + warning: 'warning' + }; + + var toastr = { + clear: clear, + remove: remove, + error: error, + getContainer: getContainer, + info: info, + options: {}, + subscribe: subscribe, + success: success, + version: '2.0.3', + warning: warning + }; + + return toastr; + + //#region Accessible Methods + function error(message, title, optionsOverride) { + return notify({ + type: toastType.error, + iconClass: getOptions().iconClasses.error, + message: message, + optionsOverride: optionsOverride, + title: title + }); + } + + function getContainer(options, create) { + if (!options) { options = getOptions(); } + $container = $('#' + options.containerId); + if ($container.length) { + return $container; + } + if(create) { + $container = createContainer(options); + } + return $container; + } + + function info(message, title, optionsOverride) { + return notify({ + type: toastType.info, + iconClass: getOptions().iconClasses.info, + message: message, + optionsOverride: optionsOverride, + title: title + }); + } + + function subscribe(callback) { + listener = callback; + } + + function success(message, title, optionsOverride) { + return notify({ + type: toastType.success, + iconClass: getOptions().iconClasses.success, + message: message, + optionsOverride: optionsOverride, + title: title + }); + } + + function warning(message, title, optionsOverride) { + return notify({ + type: toastType.warning, + iconClass: getOptions().iconClasses.warning, + message: message, + optionsOverride: optionsOverride, + title: title + }); + } + + function clear($toastElement) { + var options = getOptions(); + if (!$container) { getContainer(options); } + if (!clearToast($toastElement, options)) { + clearContainer(options); + } + } + + function remove($toastElement) { + var options = getOptions(); + if (!$container) { getContainer(options); } + if ($toastElement && $(':focus', $toastElement).length === 0) { + removeToast($toastElement); + return; + } + if ($container.children().length) { + $container.remove(); + } + } + //#endregion + + //#region Internal Methods + + function clearContainer(options){ + var toastsToClear = $container.children(); + for (var i = toastsToClear.length - 1; i >= 0; i--) { + clearToast($(toastsToClear[i]), options); + }; + } + + function clearToast($toastElement, options){ + if ($toastElement && $(':focus', $toastElement).length === 0) { + $toastElement[options.hideMethod]({ + duration: options.hideDuration, + easing: options.hideEasing, + complete: function () { removeToast($toastElement); } + }); + return true; + } + return false; + } + + function createContainer(options) { + $container = $('
') + .attr('id', options.containerId) + .addClass(options.positionClass) + .attr('aria-live', 'polite') + .attr('role', 'alert'); + + $container.appendTo($(options.target)); + return $container; + } + + function getDefaults() { + return { + tapToDismiss: true, + toastClass: 'toast', + containerId: 'toast-container', + debug: false, + + showMethod: 'fadeIn', //fadeIn, slideDown, and show are built into jQuery + showDuration: 300, + showEasing: 'swing', //swing and linear are built into jQuery + onShown: undefined, + hideMethod: 'fadeOut', + hideDuration: 1000, + hideEasing: 'swing', + onHidden: undefined, + + extendedTimeOut: 1000, + iconClasses: { + error: 'toast-error', + info: 'toast-info', + success: 'toast-success', + warning: 'toast-warning' + }, + iconClass: 'toast-info', + positionClass: 'toast-top-right', + timeOut: 5000, // Set timeOut and extendedTimeout to 0 to make it sticky + titleClass: 'toast-title', + messageClass: 'toast-message', + target: 'body', + closeHtml: '', + newestOnTop: true + }; + } + + function publish(args) { + if (!listener) { return; } + listener(args); + } + + function notify(map) { + var options = getOptions(), + iconClass = map.iconClass || options.iconClass; + + if (typeof (map.optionsOverride) !== 'undefined') { + options = $.extend(options, map.optionsOverride); + iconClass = map.optionsOverride.iconClass || iconClass; + } + + toastId++; + + $container = getContainer(options, true); + var intervalId = null, + $toastElement = $('
'), + $titleElement = $('
'), + $messageElement = $('
'), + $closeElement = $(options.closeHtml), + response = { + toastId: toastId, + state: 'visible', + startTime: new Date(), + options: options, + map: map + }; + + if (map.iconClass) { + $toastElement.addClass(options.toastClass).addClass(iconClass); + } + + if (map.title) { + $titleElement.append(map.title).addClass(options.titleClass); + $toastElement.append($titleElement); + } + + if (map.message) { + $messageElement.append(map.message).addClass(options.messageClass); + $toastElement.append($messageElement); + } + + if (options.closeButton) { + $closeElement.addClass('toast-close-button').attr("role", "button"); + $toastElement.prepend($closeElement); + } + + $toastElement.hide(); + if (options.newestOnTop) { + $container.prepend($toastElement); + } else { + $container.append($toastElement); + } + + + $toastElement[options.showMethod]( + { duration: options.showDuration, easing: options.showEasing, complete: options.onShown } + ); + + if (options.timeOut > 0) { + intervalId = setTimeout(hideToast, options.timeOut); + } + + $toastElement.hover(stickAround, delayedHideToast); + if (!options.onclick && options.tapToDismiss) { + $toastElement.click(hideToast); + } + + if (options.closeButton && $closeElement) { + $closeElement.click(function (event) { + if( event.stopPropagation ) { + event.stopPropagation(); + } else if( event.cancelBubble !== undefined && event.cancelBubble !== true ) { + event.cancelBubble = true; + } + hideToast(true); + }); + } + + if (options.onclick) { + $toastElement.click(function () { + options.onclick(); + hideToast(); + }); + } + + publish(response); + + if (options.debug && console) { + console.log(response); + } + + return $toastElement; + + function hideToast(override) { + if ($(':focus', $toastElement).length && !override) { + return; + } + return $toastElement[options.hideMethod]({ + duration: options.hideDuration, + easing: options.hideEasing, + complete: function () { + removeToast($toastElement); + if (options.onHidden && response.state !== 'hidden') { + options.onHidden(); + } + response.state = 'hidden'; + response.endTime = new Date(); + publish(response); + } + }); + } + + function delayedHideToast() { + if (options.timeOut > 0 || options.extendedTimeOut > 0) { + intervalId = setTimeout(hideToast, options.extendedTimeOut); + } + } + + function stickAround() { + clearTimeout(intervalId); + $toastElement.stop(true, true)[options.showMethod]( + { duration: options.showDuration, easing: options.showEasing } + ); + } + } + + function getOptions() { + return $.extend({}, getDefaults(), toastr.options); + } + + function removeToast($toastElement) { + if (!$container) { $container = getContainer(); } + if ($toastElement.is(':visible')) { + return; + } + $toastElement.remove(); + $toastElement = null; + if ($container.children().length === 0) { + $container.remove(); + } + } + //#endregion + + })(); + }); +}(typeof define === 'function' && define.amd ? define : function (deps, factory) { + if (typeof module !== 'undefined' && module.exports) { //Node + module.exports = factory(require('jquery')); + } else { + window['toastr'] = factory(window['jQuery']); + } +})); \ No newline at end of file diff --git a/node_modules/toastr/package/nuget/content/scripts/toastr.min.js b/node_modules/toastr/package/nuget/content/scripts/toastr.min.js new file mode 100644 index 0000000..3450888 --- /dev/null +++ b/node_modules/toastr/package/nuget/content/scripts/toastr.min.js @@ -0,0 +1 @@ +!function(a){a(["jquery"],function(a){return function(){function b(a,b,c){return o({type:u.error,iconClass:p().iconClasses.error,message:a,optionsOverride:c,title:b})}function c(b,c){return b||(b=p()),r=a("#"+b.containerId),r.length?r:(c&&(r=l(b)),r)}function d(a,b,c){return o({type:u.info,iconClass:p().iconClasses.info,message:a,optionsOverride:c,title:b})}function e(a){s=a}function f(a,b,c){return o({type:u.success,iconClass:p().iconClasses.success,message:a,optionsOverride:c,title:b})}function g(a,b,c){return o({type:u.warning,iconClass:p().iconClasses.warning,message:a,optionsOverride:c,title:b})}function h(a){var b=p();r||c(b),k(a,b)||j(b)}function i(b){var d=p();return r||c(d),b&&0===a(":focus",b).length?void q(b):void(r.children().length&&r.remove())}function j(b){for(var c=r.children(),d=c.length-1;d>=0;d--)k(a(c[d]),b)}function k(b,c){return b&&0===a(":focus",b).length?(b[c.hideMethod]({duration:c.hideDuration,easing:c.hideEasing,complete:function(){q(b)}}),!0):!1}function l(b){return r=a("
").attr("id",b.containerId).addClass(b.positionClass).attr("aria-live","polite").attr("role","alert"),r.appendTo(a(b.target)),r}function m(){return{tapToDismiss:!0,toastClass:"toast",containerId:"toast-container",debug:!1,showMethod:"fadeIn",showDuration:300,showEasing:"swing",onShown:void 0,hideMethod:"fadeOut",hideDuration:1e3,hideEasing:"swing",onHidden:void 0,extendedTimeOut:1e3,iconClasses:{error:"toast-error",info:"toast-info",success:"toast-success",warning:"toast-warning"},iconClass:"toast-info",positionClass:"toast-top-right",timeOut:5e3,titleClass:"toast-title",messageClass:"toast-message",target:"body",closeHtml:"",newestOnTop:!0}}function n(a){s&&s(a)}function o(b){function d(b){return!a(":focus",j).length||b?j[g.hideMethod]({duration:g.hideDuration,easing:g.hideEasing,complete:function(){q(j),g.onHidden&&"hidden"!==o.state&&g.onHidden(),o.state="hidden",o.endTime=new Date,n(o)}}):void 0}function e(){(g.timeOut>0||g.extendedTimeOut>0)&&(i=setTimeout(d,g.extendedTimeOut))}function f(){clearTimeout(i),j.stop(!0,!0)[g.showMethod]({duration:g.showDuration,easing:g.showEasing})}var g=p(),h=b.iconClass||g.iconClass;"undefined"!=typeof b.optionsOverride&&(g=a.extend(g,b.optionsOverride),h=b.optionsOverride.iconClass||h),t++,r=c(g,!0);var i=null,j=a("
"),k=a("
"),l=a("
"),m=a(g.closeHtml),o={toastId:t,state:"visible",startTime:new Date,options:g,map:b};return b.iconClass&&j.addClass(g.toastClass).addClass(h),b.title&&(k.append(b.title).addClass(g.titleClass),j.append(k)),b.message&&(l.append(b.message).addClass(g.messageClass),j.append(l)),g.closeButton&&(m.addClass("toast-close-button").attr("role","button"),j.prepend(m)),j.hide(),g.newestOnTop?r.prepend(j):r.append(j),j[g.showMethod]({duration:g.showDuration,easing:g.showEasing,complete:g.onShown}),g.timeOut>0&&(i=setTimeout(d,g.timeOut)),j.hover(f,e),!g.onclick&&g.tapToDismiss&&j.click(d),g.closeButton&&m&&m.click(function(a){a.stopPropagation?a.stopPropagation():void 0!==a.cancelBubble&&a.cancelBubble!==!0&&(a.cancelBubble=!0),d(!0)}),g.onclick&&j.click(function(){g.onclick(),d()}),n(o),g.debug&&console&&console.log(o),j}function p(){return a.extend({},m(),v.options)}function q(a){r||(r=c()),a.is(":visible")||(a.remove(),a=null,0===r.children().length&&r.remove())}var r,s,t=0,u={error:"error",info:"info",success:"success",warning:"warning"},v={clear:h,remove:i,error:b,getContainer:c,info:d,options:{},subscribe:e,success:f,version:"2.0.3",warning:g};return v}()})}("function"==typeof define&&define.amd?define:function(a,b){"undefined"!=typeof module&&module.exports?module.exports=b(require("jquery")):window.toastr=b(window.jQuery)}); \ No newline at end of file diff --git a/node_modules/toastr/package/nuget/content/scripts/toastr.min.js.map b/node_modules/toastr/package/nuget/content/scripts/toastr.min.js.map new file mode 100644 index 0000000..2f6c09a --- /dev/null +++ b/node_modules/toastr/package/nuget/content/scripts/toastr.min.js.map @@ -0,0 +1,8 @@ +{ +"version":3, +"file":"toastr.min.js", +"lineCount":1, +"mappings":"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", +"sources":["toastr.js"], +"names":["define","$","error","message","title","optionsOverride","notify","toastType","getOptions","iconClasses","info","subscribe","callback","listener","success","warning","clear","$toastElement","options","$container","getContainer","length","hideMethod","hideDuration","hideEasing","complete","removeToast","children","remove","getDefaults","undefined","publish","args","map","hideToast","override","onHidden","response","state","endTime","Date","delayedhideToast","timeOut","extendedTimeOut","intervalId","setTimeout","stickAround","clearTimeout","stop","showMethod","showDuration","showEasing","iconClass","extend","toastId","$titleElement","$messageElement","$closeElement","closeHtml","addClass","toastClass","append","titleClass","messageClass","closeButton","prepend","hide","newestOnTop","onShown","hover","onclick","tapToDismiss","click","event","stopPropagation","debug","console","log","containerId","attr","positionClass","appendTo","target","toastr","is","amd","deps","factory","module","exports","require","window","jQuery"] +} diff --git a/node_modules/toastr/package/nuget/toastr.1.0.0.nupkg b/node_modules/toastr/package/nuget/toastr.1.0.0.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..0be0d704bd51fea2af6b9a044449c971ff83ef91 GIT binary patch literal 7341 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 + + + 1.0.0 + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + https://github.com/CodeSeven/toastr + + + + toastr + toastr + false + 3 Easy Steps: + +1) Link to toastr.css and toastr-responsive.css +2) Link to toastr.js +3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + toastr is a Javascript library for Gnome / Growl type non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + Copyright © 2012 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/package/nuget/toastr.1.0.1.nupkg b/node_modules/toastr/package/nuget/toastr.1.0.1.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..afb7a2269e6428d962220254794e2d6acdccc732 GIT binary patch literal 7745 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 B(vAQC literal 0 HcmV?d00001 diff --git a/node_modules/toastr/package/nuget/toastr.1.0.1.nuspec b/node_modules/toastr/package/nuget/toastr.1.0.1.nuspec new file mode 100644 index 0000000000000000000000000000000000000000..d73cd002ac3799639ba341567b4ba79bcd110941 GIT binary patch literal 3764 zcmb`K-HsbY5QXd767SIBf&j|e>>>dI<0t|WhyVqJz2nAfPi$}2GiGKSXL%#ui{}8& zSM6qI>~R(nH1hm(SJ%&}Q`POi{v6u_du408v0yJPv(hSCSz)<-Y46&(4ecX6gJyD@ zX?(8P+!j8&wc4KBnWR3E%mbU)J2tSfZEPyp7rHOBF6{N^(u~ffR@IXE+(x=8NiHR| zmUJa+Yw4fKi$Y(8wAUKL?pm^Kz0r%2UC6(4T_Zg|(>=GXR&Jzmrj@VsK9|ktS&%PW zV`^1!J(e4>>_;1YAp-3GLrS! zZqN05Fcku|FfBZn6MLe!rEm%MR8fH8efw5-@)7KjUE3eBg*9?eDsOmtsHNXlVLR!G zta(#QT^;>)Zk!cxu#&Y)d3hsjx=h;1mz{E6c=nMjghVMGWIkGojU%mtUrAG?5g1pC z#od{qv@G=li|$Oa-tXx~77Jkt|LP-8t3B%%ZgVOBu3G&5N-O7D`Ak2UlFRlX_xkns z`%+5Bud=a{Pnmt+iTt7b1BZ<)zy;nXs<)}41!Lm=@9X>hASUX(ln2<0{bgbwi+|t9 zVr92_d!`xu0i%JgbNfJ}c%6%r!I6k}R#1y{hDsOJM-215RGL5Y2_j9So3_7t4|5^XO-Lr?XN3^$EvvrO1 z>Y#p4G|@vm%N%?9N3MO~o{%DgANoa)iE$V10rEkbpW1hN&a{T^6JrP4h;Fn4bJki7 z8&9#QpL5{4-gmUygFXsIu!j6R(fy@^$I~*^jb-rb_wxL6%@DT-nO^xKlIN)Dh@%7C|ESd=%9!(`TF|nuZ+)_l6eI&^Sw?U_3ZOlYh2b{p8h!SU*$a(hUcmg=n+jCt_ zETG9LtBWNT$X(_dISZw}+>cs6%4B>aPJzcl9@oN`y{0=B?00z(&r=tAd;J+9*n7$v ztolN-$7hV_X`khOAL*Ioa;qn&#)*E^(53c;xCbB3_v>LdTR4N7oRr>In{T=--0G`D z=IGk?lY8~r}OD>^}}2=>;MzF>8qd~dzMV6 z^-sl-3qP@sPS{Jm^llH4eEmsz?41lQo{FxKpe8wu;VHbxg(Dc%_RGg>~9)bI*Gh(3~fDc=WTlztdy5_9)_xe%9(W+-v3U^p{KAd OA)464So>ceec^8;D{$ig literal 0 HcmV?d00001 diff --git a/node_modules/toastr/package/nuget/toastr.1.0.2.nupkg b/node_modules/toastr/package/nuget/toastr.1.0.2.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..3ebbc75571a73186612e9a1e796a8dffd84e2ff4 GIT binary patch literal 7794 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 literal 0 HcmV?d00001 diff --git a/node_modules/toastr/package/nuget/toastr.1.0.2.nuspec b/node_modules/toastr/package/nuget/toastr.1.0.2.nuspec new file mode 100644 index 0000000000000000000000000000000000000000..79dd9a25b2c75b861555c0fe94cc6a6894c122b3 GIT binary patch literal 3914 zcmb`K+m0JW5Qgj867SIBf&j|e*+l{b#!>W2=+p)b_&nz?JILjOHUOWfz zf7Nd0;BgibWZ52f*YU5vs@s44Ikt!P$~Jaw!Cu1N6nc_RuYozZ_^_kgLnm4jIljbWu&*d{l78DDw zv8*j*d8)msf4BE*xwRxFlE^)}N^yU#M`x^A){$aE(l$EGI&Nj-`8`g`ov0*2`fA46^b`b zxUkou$6!|B*f2SReRbfEE=LdR%^0x?%U4>>_Iqi@3|hGi|IvTn?%5;xBimc)Y~3QW zI%wXLO^lGp7LGmhBhxu>Pe@V05B?hi7XO4mqtf4+n^!ZZnCO?DXS*tS(truR&RJq5F9;Zj}3Ov?6^NZ87 zk|gI&L^#t#xzu{D3}5V#iaYQh?8rRz0w-V4)c9FZgAeS9F}8bf?sCsmNBk^h9rThc zoCHyHu#F5k!u*Z%k`+$VSk-Qp@B_VA6}WWiHfD;7j^h+w+izN<(^AJRbjsq3{$pq8 z)#~EkUnSz;}3>ULl8WEufMqjdruL;_0J`H zc=L(e?DO0oBa>AbF)Quws5e>3}GJay{M2ll|7 zZqH?j-&cON$7w+MwR_?@Vl;6Ar8RzV|NRX zpdQ>g>C*q-`f(iL4!OT+X6b(PwmCHIyj`@-v$<4Vnspee4@zg&U3mXHE8R$8TS7Fk LiM8f`QRc$m#6XIZ literal 0 HcmV?d00001 diff --git a/node_modules/toastr/package/nuget/toastr.1.0.3.nupkg b/node_modules/toastr/package/nuget/toastr.1.0.3.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..71335bed42e32a3e7906e76e774da1d2b54c31bd GIT binary patch literal 7761 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 IVmmndKYT(dNB{r; literal 0 HcmV?d00001 diff --git a/node_modules/toastr/package/nuget/toastr.1.0.3.nuspec b/node_modules/toastr/package/nuget/toastr.1.0.3.nuspec new file mode 100644 index 0000000..94071f6 --- /dev/null +++ b/node_modules/toastr/package/nuget/toastr.1.0.3.nuspec @@ -0,0 +1,38 @@ + + + + toastr + 1.0.2 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + https://github.com/CodeSeven/toastr + false + 3 Easy Steps: + +1) Link to toastr.css and toastr-responsive.css +2) Link to toastr.js +3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + toastr is a Javascript library for Gnome / Growl type non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + Minor updates for long unbroken string going outside toast and new feature to keep the toast around after hover-off for an extended timeout. + +Set extendedTimeOut and timeOut to 0 to avoid toastr from fading away. + Copyright © 2012 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/package/nuget/toastr.1.1.0.nupkg b/node_modules/toastr/package/nuget/toastr.1.1.0.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..555e321ad11fd7da94e5ead21ccf202c8924503c GIT binary patch literal 7789 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 literal 0 HcmV?d00001 diff --git a/node_modules/toastr/package/nuget/toastr.1.1.0.nuspec b/node_modules/toastr/package/nuget/toastr.1.1.0.nuspec new file mode 100644 index 0000000..a65e371 --- /dev/null +++ b/node_modules/toastr/package/nuget/toastr.1.1.0.nuspec @@ -0,0 +1,35 @@ + + + + toastr + 1.1.0 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + https://github.com/CodeSeven/toastr + false + 3 Easy Steps: + +(1) Link to toastr.css +(2) Link to toastr.js +(3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + toastr is a Javascript library for Gnome / Growl type non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + Added AMD support (and backwards compat with non AMD), toastr.clear() method, optionsOverride API to be able to override options for each toast, added onclick callback option which fires when a user clicks the toast. Also cleaned CSS, merged CSS files into 1 file, and reduced jQuery dependency to v1.6.3 + Copyright © 2012 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/package/nuget/toastr.1.1.1.nupkg b/node_modules/toastr/package/nuget/toastr.1.1.1.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..b5cf330adea0a44af48eade28deca9f20b0e4c56 GIT binary patch literal 7789 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 l(7z7 + + + toastr + 1.1.1 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + https://github.com/CodeSeven/toastr + false + 3 Easy Steps: + +(1) Link to toastr.css +(2) Link to toastr.js +(3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + toastr is a Javascript library for Gnome / Growl type non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + Added AMD support (and backwards compat with non AMD), toastr.clear() method, optionsOverride API to be able to override options for each toast, added onclick callback option which fires when a user clicks the toast. Also cleaned CSS, merged CSS files into 1 file, and reduced jQuery dependency to v1.6.3 + Copyright © 2012 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/package/nuget/toastr.1.1.2.nupkg b/node_modules/toastr/package/nuget/toastr.1.1.2.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..ecca818d8e60035716df4de73d8fdde3828b8141 GIT binary patch literal 7850 zcmb_h2UwHI)(#+`bfrmALZll=LKo>xK&n(hN=O2Pl0XtVETSSx6$At+A|OZ+M5PyH z5$U}sARt8PO?nah1G=v6y}Qr-?{kxU$@9(3d*;l^ocU(n*YG065gNe3OUp1(MXo%j zaE=TBIJjs5+yGk~$`ub0JNO1>oCFA^vm7@4>(^4%OL-+9H&>t+3WrByF$y4<7!(9V zVGvj(8sn${@+3Hj%7T;>4C{`< zkZK&TI5#+fbc=I@xWf@Ha7PqG914|&ki7ZR2IyCtKoehg)W2ACLnCllJl26AhQPXg zH%9V{WDW*}KxH6qa17c3g(rZ3CUBf1il6|35U_AO0Vjs>#Ji&qAfPr<0dxrtl|@1& z;3x^WG+a^|DFFgP{*&JSU*mzep$Kp!oB)R)usD>cJC20L5zr|7Prm&T4Ll0xg+`$8 ze~W=gK#@?SI7~tY4waA;mw?$LQ0Jsb1(I->gft8(DdvuMLn7S2kIx=1L27F+frLw( zlSCoJ561`jzH$5g`|gRaK9P5tnw>%tmOGLI;%0p0vkS-7-ui{)u0A@c!smRdqfu|j zL{9*;dF#bzOtgq@*6V^t45n2JtS>z&G0Uf)B(mIEJ|5o4_+(=XQ*Qr+MOwu&WLux} zcin*Q(;h5ZEpq|{%JOSVe5rQKch1~zXUpfW?%e>?)iG)1-2ym-w;Is-PZ0C@-ye^< zkXqc;chZ;qTuNPsZRT3)ZwfzW42#1wp$QC z?s8mP-L1XdgLC+}q=zE*Qw{ekyS0Jm6$XnXo>JGYz8yV9f5Z4X_fv&2&Kw5ogaOK$ zUL7xULz>+OR!9Q}?u({b%e0}!a_CCq1Vi6AvTe;CPXtpO(In@r8b3vjJ-qd1!nOSM zqLk7XlpoZTt)Os$?5zicC>8CkOj@n&N;~d?AfIMaH0KlrSnj6iOaDTBl>o<)rVD#+ z)YbygqIJ5z6(30h#Gg$cJ5f-1?b#cOuz0VUf;DC(uOiy{@K-Y)A8;;}X=E}5hqi3EQ*2Kuomy#@TG_N@KC`-(=Z}raiy3N>5-e&J`B>IV zv%ho7C&lLX#xqB26FgT%RghRcgzly*Fb3_-U{5kPSa>i7Q0(-(tu*7R_A2f5yu2!tk^Y4ZS#F}q(c8(J+zc{H zHK6qeL3_JXmF{^vg;BGTKD(0-uwxN7J%m8&Xt%wkM;S zC$Q1ueeWm5o?6X79yUEg#m+J4$g^(Az5P$RrwHq*JU$vTeMT{3(JLTEOaO+$guSs! zQnruh3_+oSNAD?O^TtVe#k4WdNJe4!d|~yQ{WCk=TjaKiVjcH5Y_9CHUSkhCy*#Ec zQ3L;+D)jQr^szv2-t^}LMkDqBi@sLtxLp-*B}+P@7fk6B$6nya3+;|`lX5oXtrID` z-kt1;ZBZjlv@3E#V=redsTyD97S#pq_z}JCvECcsxTqwwq|+GP(ZA;;w>(mftr>o$ zm$5TUHrDawab{J%Y9nN5_qbejVa(~kG7EW)IXvsw$Nfl*jMV2VY|%Y=Rcdhz<25`r z=MyL+zW6&p9MsVBI)X(E8cBQAVb#wbhpFvJXhlC<-J6{DF&g=*nxRx(HNNwTC@;&} zsV}3LWc<5OP@mjac`bu<_`c(c!y@fuCUMt@;lZIK)ti%_rQW-eXFqQiEKdiAueb<>C3V0SnN8w&!is{S7+B7-f$|gM zNj1CLo5Uu{s1Bt%>*2mu{nckrs)rui2rn@ztP?xy*jIT1Pa5>ucJ8qkj(wO&ZJqVY zZv<7Md4hz-1*h?EUZyRWM{mk_@4@hb1_SIjAq`711B#V-H9V=UYrEdH#^*N~Z+?b_ zE?MW$Ol}#(sJQj9#rs-Zg%?OEAU$ORG7G8gx?gcBo}9ML-s%TzxaetU7@C#Km={t> znXetA1dKGesab~oCZ%(lYslt2Fu&hj2l{F?nK_7Z`AK$uT;0vqAul%0E5`FJRwjOL zb8Q~B4rxd z&|AfhiVG>1irMasBSmG`;R^Y&0*h=Lacz^doHiZ1Z8tS5SbY-`4IW`UV$YV8Cz_pK zlD^iNrNI6k;(Dp5P{h*19< zGN-4kXff8j4L^0nWTP~I)o`SV!EFG?wwmVdes?eJRQS&y&?pKi&R++WN!Giu^)9ctMOIu zIK>`&>ncDhWKLTw_0e9 zs>X-PKm2~JHJFkkuRAB~B&(N*$Hm;ju!qu#YDjiJh?iicS+pk2fM8s|2M;&#+08ms z>$!d1WU%f@!P9bGpBx$3?J3&Os=`v;3&u3U^LDdG@8s#v?C@EU>%ZBxi8XippjpEk zv(oS|J9zftg>tARW#^f~`G#}8Vba|!DZMp&&~%>EI2W_=Cyew z*>TngW><~q;q@!8!B^c}Vh#44LIOYWP8V4qbk`rg0n=IZsa&qB_mNM-Xd}5Lm2c3W z#K$-B#`RjzAqs_R!Q5^o8K4A7C-Qf?!nlsG)=c=PdFz6Dows_aWFOy9|1N*&N(jBx zmFaEgRzLBQ9Cc1==aU54Xk*iql3>N$u;A;Vi05LmR;+Fh++Lf$)K}9>H+# zbQf!(nP|(3AxlUu=<*2`$#jwHRLq82^Do#fcxke+%am%bEAny!>Tr4GYhNO)ld5m| zafoOq;$FN`M{z=`vsedg3g+gzUvn!1EoRrn{f z&%`%aC9#le#9h_0YViU_O5Oyi@b!d&=#~5gL);$rStwJ`oEq%D{!%OW6un9A1-4Ix zI)M)gKCU7|K>Ix!j_MLTIg99sc=7vaVrpd+ds+q6%D@SJBfj)^-D%>l3_VbbhEp{gr`dy|08a&i_eK60wb=Qg~zUo2gTcns8iMVV63IM^4_&yBm4CJ=oHs z+(mqjbxKF%UN>#Rs}lRBwcc}X#2cD1N&agQ$K3ADnKBU@%P)jdCtfoWsf7rPH{6-E zj8F^tfX_3lSXcMfQDD`=3~AUz9%a*sn}5``?dI%P+>*<$c$46yhINL(9)N3~jE^2h z;NEcs`n;@_NlX8@FuL{Dd|iF}d0KP<hy8d}qS#Ju%X+X_D-=W9t>Wmlp)|YenuR z-VIWp{JQd>2`kJ$8UFQp)>rahH33GTgK;LZLMXQx19iwABcfzB59hg97oUY* zCetlfhEfxRzs8+;yq!@2IR=5}3W%*paHey{Kq%YawG3-_@N~f}9;xrE(5^6(ZWrD}H0~s?m{rRrlsy zpDj}b@`Sf*f^9O1t1L&&9#(`Ja(u458V2rx#Dt1xsw>a%RJC#SI4&ec3tuSf7oogp z;r@W~Vq)gS*lXC%P70PKk(g^!Q#PDyIm&z&wxve7A2sy2E{MnK`vdyKIWh~@O9cQ+E$y4-S8vM)tDTzeZ1cbMiA)?+UxtD$bweBX6IU~JMTHwh#H|@rS{><%21YH8 zw}S(69LSmis#G&LOpo~&{^t5Yf!w00`t{&mhoCmg;~Z=HZAmQOE%$yR^g4x>a2&&h zb(7YQvnxGXiElUB$VB^PgUaHwWG_&ohvn&RhaFE3ZxUm8eP2rSEZ=DV1o5(cgL6hZ z&5>I$aku@WcQ)n?b}7irB9$$_uG|=%Z?MRER8*AAIRU`Te6FAEKbUU>I zt;b{qLkd;P>t+;>0Nd%OV3c-EcJYg~gvlzWNdzZFxc9zZ!TIMw;0GPCm7|T(yS`PN z9qnQFC5t77XiUkJUJ}gB0xu8R5GO$Nt%gxN>)JHW$>>Bo>0iWZI4`7A@hFv6^fT0+ zd}bRSqoFph!#Avh3cxXO8iG-Md)=!MBZ$Do|2>Lp6OO~RwqTit&Vg^{kJzw>d z5@|#HJ4Y-FGUx6FiZh?yXo;j5F1oqbB~c}lx|p2r@yt69eu*pBoY7qd^TZ7r^Epin zZPwg=+hwTjh3*G_SwWwws(uJrI4se)N;z)Ggd$s;~;o%C{622>pK8bTH z+ZE-cRyJ)p!^K$QC;2`qHSywFSt8M@Vk+qrYu7dx)ToMSf1cB5mpK%OezLUF=o%TG z!h5331IK&s4KXHT-P>MMgi)5|zL?Zfv6Ss-^-4tkOotJfw@}ck_F#W}jUOJ2Z^mf( zO>t&kYQG$M?nKzV77J`o(Bj?G5!*B6(}8lXPKh zRxsF-png-8U?eOK8Nx!ArnoTwoZ-CSnwF*h+@fF!twLt@S)P}YYbM%Mx0MkAPvsae zU7A(d2JZ1<9Q`S$(HnGnm%2>fOTHpoP^(wVU!SJWKBuwwWn<;dQ;5rXEJM1I(u+vA zE!&VEobc4kJibeNW*M$+H?waZWtM7PSpaO5Inl`V`s?uAR}+5)T(49HnYjUzUvx+> zlo=xY38fG#ie>2`SB z7URJa=1+e5#OK5eTN2-Ra2b)FF#mHV^q)A(|D5GMpl%I+Ft^`mZaF042QTgJiE};V zwUG!2$`$2CVqWkNm>3KK`q7qv!nyrPjsFZdtohN>2aoQ8WfmfMXD-@AiKn{!_~RZ%JuIc_cy(fkVLwSe&8`)(HbNguBDRT5t>=sOemv z+?PEc^it z1*8!Y|Cb8VR)R)ILKtX@M}2R5fI_12?yhiOApBbykfbC4(HI9T7>M^okoa;u80Zbh zVMq!9kW_=h;jlOw8VCfa{s#_o*!(-%8%=NmVo1KA39cxb?;ahP6B1Oxp@6{>|tnr z4#z=w&`8phKs%sOIK^)r9=7_aRQ|itqDY!GV&d|UKW-1eu5gT_CrK?)L}5ftjSrDO zisW5TzTQ|I693&U_}d`CqyZlEhd2~gz@!MmU9pZ}ptFZ33g;^i`GGpHe;A0L{rXmL zP=)ujcSa!yiu#@xPz2IcI8<$b8b0o>q>R8Fy7EU8`9p!@&n!7q7XHli%^8Ny9g+%l za50lI-Ae5nGiiGu@Zhb*4%DXqi6V7q@4r-{zO$vGgae;QN|ZXv0q*HaAPtyArhXH` z4x}>>@VoQh#3{JDyX*HzL%cA^zvx|}-`BJQ(d|!}>nv%!hjPrn>EaKK>Tf&2A_ypw zwnY-F{tcRxTmRtSKSG`VYvdoY)8D%M4{`a6F7_ibki&nHG>yo}MFD?Kq+cb?zbcnM z37p@6f2VEz41|&c0N>YvZ?XR?^jCKMXXp$i;2*g5zuNirK=rd7MW#RP{LAs`uOayL wsrj>+bQ1mlKYxb)wfkRF`RDG#I064Iu?;U$l1`BT02S$7Ps;yp?t{Dk1L68RB>(^b literal 0 HcmV?d00001 diff --git a/node_modules/toastr/package/nuget/toastr.1.1.2.nuspec b/node_modules/toastr/package/nuget/toastr.1.1.2.nuspec new file mode 100644 index 0000000..96caba5 --- /dev/null +++ b/node_modules/toastr/package/nuget/toastr.1.1.2.nuspec @@ -0,0 +1,35 @@ + + + + toastr + 1.1.2 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + https://github.com/CodeSeven/toastr + false + 3 Easy Steps: + +(1) Link to toastr.css +(2) Link to toastr.js +(3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + toastr is a Javascript library for Gnome / Growl type non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + Added AMD support (and backwards compat with non AMD), toastr.clear() method clears 1 or all toasts, optionsOverride API to be able to override options for each toast, added onclick callback option which fires when a user clicks the toast. Also cleaned CSS, merged CSS files into 1 file, and reduced jQuery dependency to v1.6.3 + Copyright © 2012 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/package/nuget/toastr.1.1.3.nupkg b/node_modules/toastr/package/nuget/toastr.1.1.3.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..068a54114d40797f14f66f2bb67c9b558953b222 GIT binary patch literal 11781 zcmb`N1z1$uyZ?t$QV>uY2BfHl5kcvYMoL;iQUwVK=`LwRx};m+ zj(Wm#?(dxc{om)#Gkedo_ge3Fz3bhpX6=ubDh4Jl;QJ>BLr!k^TASep8UXP9zynYN z9>Spx2p;b5XJ8IFfHjNsN7lcew%<2O-t};F0J=fp2wRww6aybOF9Q(j1cpIuovfu8 zT#;5>q6~MXC3T<exaKoITPN)IIMNo1_{F#1qk(|J-E6^7#6Q~b zK*R(^tSklip~9jNK|X#_F_4(37%#sS6e2o03blMm%l{q-&)LL{RdGC!uWoK z0}@1@s~Xp$gi_FMhmS4D@=nccSxz~{_MwrclqZbG89ZZ&&nV!LlBdJ1y1sr(4VlH7xR6Ir+`=2gb<)XUE1wpT+{@Na_XE7V8)(t zerdaC;wD=pz$602k0zJ$v#V|=lpnIs8^E$9U6wE=vHEiN;^zIp+&Z^x`!xa|rZvp8 z0J8-Lw{nvY*Bx&VapJG#hGAQ{xm*yoXPlf_p%Dfz=&x`J)|h0-+;A_eq^+8mz${#H zctR|y0`o8llv=GntV|)=@d^`=@`;eHShg5nzvdt;J$=e!{z|I3^9>Pua8emq?!ZXq zPVY?kM+Y}gPaN0@R<|GFM)bo+ajw0uNi6AfEx-ad?Qbe8IJPXfQC_DObdlO#dO`g` zYoo;4{o%AJm&Xrw|f>m zHyQBkHC|iOS=y)RTPv>!od@|GJma0+aleRAv1A^K&>&+aqcH_e!?AWWiX71DmCM#C zyC?}+4JMB&hTQ9<>$uBc=t=EQyB%kG@y9!bI7Go*WK)k$HO>&=M)~Y4_oGvD1Er8j+rE3QeWpD z&hO^L=R0`nF4`m#Qq7vh(`-YHheWG887(CPajs;cj@_6?nY9%j?(R3Or$DcCGxd>Q z7tpw!Rvz*1pLnm=m$0igDXf(RTXT`iOg%*425xzyB+|f@0Wup~j=Z#=Aa3 zl#|&V8)?E%ER5!&rWp?X&vr&%(>0*Z7@~N^U4fcAX|HN+!-pDeRaZnsp9RKGQ~1?x z`@i1iUc9x#{%XG^ZF$7y(Sb{k{eD;#EA0N9Gxag=kZ$YSoY@dXl4t!Gl7w=@2bw(I z>sc>h-#&1t6hwu6b9+YSxr2`o8Q0ZV|KfoVEm%{hI(0n}?Xsw+$tKiT@|C0WpGAY+ zCn3F9dHJnY@d4Qc)%;h9OPN-V_kyA$JRa(0;N#DpTi*P2Zgo^kQvKI)Veh1SzC1ow zJ=kZfr~53nZMgcj$RDx&m4MwX=i5RYT{wH~!%q1TtmyT+X@wd(;Uzqj=eoE#diR&~a}hd(y9gmq$3~V9mC3dC4@Iw+_I3`3Q(Q&# zS5FkZGix^{BO8o4X>WfX_Vm5^4G+{W92tGyR(h6wwPe5m8f`1!4lSFO@7?P)BE!QzF@HET_EE>o3^e~}{9s)~tS_s8VEx^EoY2n;FW|yg+*QX-$?CwcLfsfAq ziv}Q@6th*WnANuikRk8)FA`swaOo3RCj?7XRc*HCW16VvgXo86Cty!{M@$kA)9XL@ zlCPa4%b4}3R*XGi+G1ttdWCfpZOS>+Y{wu^@+j!2+yLvW^kC#t3ujastQAw!9Af_D zrtK4Bzgb<=WZe7E$v3IxsfHUq?fs6SF(z#V3#Hd%16HIyR7_4NugJHK>t?!X6d8qg zJ6GIJKP$^HP$qH5qhhI?2ntEsm#)m#c2dlE-tSywn!c#Q#hpLeR~z}cl09xEIo*M% zOA!fH(cMTG=vkF1{KI2<1m7)b>=L8bAp+UEXTZ~U{S}v4- zMpTVYB;8Xqda=oiNBeDE5U+2Tjme0eBHx^tUM#MxxNnzHAN`r#0zhy)OfU&o-&-n& zud=1K3yyo8t(tSbRJiA9D4Tt=P!H3%SdOqfQ-ql2c_(+A#Vc(B>v89#>Z+)d56fYW z?UfFS%k?rmg~A_BLJ}x@rl+_kTmAaCuxnL!EYhD8AX~`VDjeU+BC3LEf^sAn1*fDC zzyM6)v(AI$0mp5|qP4br2?bS5VR!v6W>)F6-8j1@J2&P^(~gf?8^QC~Y38U}De+9!3u}n!`~TDP>mI(PG|_5SK7_ zo1r%b7k`?vzyG;afrFVNKfJRh9@twf65Ua=AV++YC@bGtsxz+= zX%H~_ibNRZ*{90PXiCf?8SqMkTUhBfw=YGp@9OKCj$NB7HIXW+(nvgd&Ue&CG1-(f zhOLEVx=&42T=ntuny4Ax4|tbL3|4yy>Xb=mztTAQOr9i!&u!YbTQCU$HH+>J(3|-! zW77+Nh{)i`W3Kg8p?^&CISNp;{;X89f{6%Hx6S0~dd+EsikR&oH7=nZp;YtZL3RaN z7bs6(hi=tV=g(~=4{6|9EQPA=@ADXwDqlfv$3$p=9o1svi84f9>P;-&>nE|ns}t?F zP<(A1$+p0m{5Dj+p6Lz3QT3IJNyWvo&MWWBU{7$<^d?h-9sZL-i*ySPujx{21}iiN z(|DgfYrM@1?}SG1Q@&B~Q)BY7!bcTBp}QUtFl7j}piD3UIU=Eh{@Jh*KDd;%fs@*? zI)@=qa8;}*zqjq0ua?4V!e`{t%0C}{v$M;3{@89}k=A!8V9Qq9^euTAQ#Si#6@ zBcp%q26I--xGhha9I4tI5uO$8N^$-kR(H{tp?v{2=pMs5w2%?hHHc1k_@5RNp)nxwV_N>v9H*;L4o?p2T`-A^Die(Y2Z&0Wut&vl>T zXDT{-#zlf7ce1~o(0l$i#{d4r&e#iw{5NBp#nsIv)AhaK2VGxE)NlhCRAh3wpc0so zf*}mDj6-1z1Xms`j~%l|jASryX(k3~%yU0PT`L~B6Am}bYtS^<^Q@4&>A#jU>?uH1 z@YOaVfj`xD;dyNoSw_vZy)j}Y?R5F_7gA91-PHIFU|q*olf@ z7t4U-V02PZO-%fr{Cc^*;RZyxCl&~u`*Y9ZQal#^L>Y04>Bu)^qlzJ1E2gd-ArahP z=^q}$C7x@Z<7Ipu8+FiBI+qlV$*ZHZJ}Exle{Kqc@Rjli+{rB>8ML9u@b>GpunnTr znzIj~ri!Ra;?{Q1(EIrMKujbP56v?pR=NC*I~g32a#SY}?~JDDSXKEsBaSbxUuPKe ziQTe+5tC|hQ)+~woSot)?&R+CqKB#VwNzjo*9yLJF)h4sXLYOkFJ{V1{9a9cI3?u4 ze&Pj==>x3%uF)BM*^cmfT+1)y$E(iAI=m_$k3TZjk?TANcPZ>SO)u7Wk{W!jqlp#Q z^1kEc%_g}OCT}*RUs|g9E4ZC<1U=2a{R}nt-^)v(Jb-Xp0|XWp5PQ?FV984 zrn%}uzY7n!ABtRDyj-2?S#zR|y3LC&VUwZd#S*v3s=nYIYpxOSw^K8f0`z&BX4Zt#Wc(nfxYOP-)5|J8>MkvkiMim zckUM6GsJ12J=hW$lwiJF7k+s#vX6C`6q;t(y|6nKldv&-cIfqx{p$K(m!bVHV*_$< z0Dzk$008YjFGC$|ow)y>OHteC7fM5y9Q9Hrw)fPkYaGBy%cE%)P7ednT15I5+phJ@ z8(bZKEG=Fe($hb-JLB~Hmh}OUoP?NizoQ7?opcM4Ze@&&a(Om zqY|v2SgcMmACr@TPH$ink_jaFpt)-3M?gHUlj-0QKd*;QBaHpiDM=Om(^IKF%YRgr zF1uo*0gw7Wi%we~e6M#X+M!D^Cwk%*L#GDv32&&=n|Ph+Ti}v-e6*5FW`6{jg)ZXD|sggAext7Sk@ZekGw0eo_XwL+P z%^@7_G3PT$3;vR9L__FXD9SN&?li=5@F*dGQbnKcm%_fD>r?^-(9Gl6H z$#p}L$&&8Who(5|9SZz++bQ`WkT?hxfWbpBM?1 z3k}G$$+mf`N@FVb;W%bO|84v_^QanvNIRarO`m&87hgC(*?9_;IE`&%X6nc0d{{z; z4shpC>4wbqsafR<3L^Di)EQ`CPD^IuM4Go)^;?98?4Q4I9DL8~iqL3AtrC;bf?Mxv z7KoY9ZrZm=H6=#4;y@veP^g@ZAi_v>-R^j3WHyB52H!65~~T;F5y$r?nMpWq#HM@ z+4f8vy9e3fP$5~ z*<;3-4;pvVX4&EIC76U}#*6lzl`HH<_cvZ}^l3szMHTl!33bL%mw`}*P4lkYiszlW zDdV58g`gpwg7@4M?AuF;0E;r(W0FkCpR9VHh&?clB2=7{%VLF>X=Ra` zD9NQ^lsb+Yf#D5d$<%TKzki*^gCZjds_O@k*-a8|I;cC*Pk-c4CJnhY`Tcr)L9 zK*ymk;+bGI0rSV~DO=0yMMl7~8T@6OngcThdUW&=e5Z1` zS|u_pqb*@*c+^TA>5K6&NfIgBGp3PRb77c@c_s6LAEd4j&X&ZYpWl+SzfC++z}e| z;mI$rx!ilc@IVb9vi41!Qzkx#JDz$h&a8LOt~x-^C&Pv$wVAqC&&kQAzb`#@Ak)GVCK80!Y zlZNb*gYAT22^iYdhai(t9xUkmha7n*MoT9|Zj%i{TqP6CmF!&IL0>g&@-m?&`?MHY z)f*CJ+-0%+!CaqV#o-+T?J$Inm}acjX`Mr6%LmwF`B8to@Xq7F*T=6|hVPp|l(O#0 zYVI*UVDThdHF^*w?IFsS7FVf1cr;-!t>D|m+o>&R=geyrvw)@>Z#R?8NvNm|B<+mL z%0knpIJZEjR8IejYp>9BNK<3f8!tDi*8maIH}m%Eb5b)`sHaX~G!ruh=o*$JJ!Be- z0ML{$7a*$d2|eTE2}lHG=kGF@ehL&0747JIZo!_)iCQd`wjL@k-7x@(`_R0sU5%OW z?aX7+&#cgAm&Lw1*;d-?^PajJ!&rAH7gtnL9qRScnd;bPpP{ncgCmI{>j^Oth3Z5! zYK5+-3%pIC7~6JLTG{NTWyh6;_W0@6Nfeo_vqbzCILkm4}w z_#P?E9hG|sN4VD8&SrtPGP9;RjA01Yqlf}EzSmOW9KmE0cd)8r)ss0ivuzN8#EEhJ zwC?nhakyHaC2u+Nrrp35>JORyxFQtH_AUsItcJT4BKcTNJe6t&SR79Mu>W}7Ji?&X zBiKivV+JWrQ>x%LK2~{$jV8QRW^B(YjwG##=Y~^d{KwpyzKAE;{g9VS3iGF*e=_tz*{nDg2FO8RR~&9Do*BUHLeeBbH3-#~tTo}z%QVD+LNE4nIzLp~#g zSw^q2EJysoFxTudC-ERvzDtvtw8ljj^+*e5(t2fNxT6ve=a7)$6v2uLdy)X2n}*$z z(#Ag1M%**m*dp&e{D|_REoP+-UH+^EZ>1U?J3rR)RXZj1JIt~CD|ofqHC*`;2^lz~ z_YcZH0fQd*aU7Yff0GudS6CVeOP67;$i6>rKV8s8_d4+^^Sa-r54>VCUiT!^ulM<- z?LuQ~r;Et>)F=11Z9Lu}yJ_<}pNEdYd`MCs?+pp=%Y(?shAZNj4_AIN-&oLazC90M zJUqtW-l4nBSmci0XFZ~cak=O*Kb4lZG4m)Rt$XgSOoP}$P5YJKtNjz79ljf%-#o6H zX}tK`%FmJoGK{ze09Y~r02IHh{19Nctuqqw`wJSof8BrFGU<1k5+-jXT$Ly@(&~JE zhlR^cJL!hv8%v6^YWqsvK@6@TVG?6K<*tmuGsmOb5}Re$CpjW=S)b}Dm~gwThONaY zj2s`gZ=avU_RRTz6Z7`i#@it>8-llYz?nY0sNBE*`F<_?2UR0E03N1a0M_+>*yWj2 z|1M?46eghefV01e<6~yA0!X2E zCxAP^=;jUnFy5F(Poc)96hKgy3qGcmeQ8bAw}{(MSf$McEO&-Sg*uc&@bV~}fSvP_ z?Eu^|;v6;W$}P9F0Uf`BTiwob6L725QwR0dB2VQm{UW^)S_4Z(V=n-q`dOSd6jnUy zQUp_OEly>jc+k(Cr}=vK8kvA>wt_5Q&sX1F%+~PYft>*Ic`UXa%(^7HCEdn0SWcSz zEvxsdTcpS;7OoU8;g~=Z?ssKO;tC-HG`wLJ3EgaUtMMYy0ZT#`Q9DBOl2}3d9_#da z_so{HVinJr_O!azNVLw{OSR;^CZkT1i82hkNjWY0d~b6Cn++9lX)~W=v6}0_Q~Ubs z1W!Z)@q!11jOlWjh8(u|6E(a6Bm5M)fe@cjnDpK1aZ6cKyF+4zW&OnY8wa}kw3ZWc z1~HZs70Jgo$zcDEQ|F?(Q6i8DNz!IqWB4dD@vdj|Aj zaZC#ZX_upu>cxEIzR{X0#HGq&OYE4VP0e!*G=oSPldHYp z*~Lzy+`QLG>I5zTkt2^leXIkqoQ#}OLiU9hcS;iySX03Em*P{m`ASj z4NvfSGH!>4o?r8S)M0fbn0j)HSquC2eN4q+*?zfn?6nWJS!(HKMm!(?{2F{pzMO}|cu8BIvLd{Du$jMpef;{JUYrpN zR3KJFd$sB$j`=};9}o4%uZJ0_gm;h{+;_;PW%RmjoOgn5TF9V@S}z?>4p z+}n$J%B}q?{_-ic)!REl$67+(U2aZ2=cHAZ^7+>q*i0$RhY1=C&f4TlXbIkeS>}l^ z2<9Q&$CB}n(8c{RnC-}#GauZs^Z!D`SaSH_D!D`{ik$n4um<w_eFSFjdZ@h(*>%0>gMSL^r#&+Cri&{Q;cu8{d5eduU%tafy38aP;jaG7X zv+{;S^lEHX`q)gg9huiXn%6$xh6Z$*C>YTrcbnEl-^o&KrAjyH*Fy9VURe_Yg3206 zF2jK9RfGhDC1Wo{l9x#jho`!!TBKiZ)rkdM9t;SF_?p{nJRWSCe4sDKlGhT-6qtAZ zP|U>DZLK1RdRB?riRcRU`bu}}utWXRlWS&Dva3?JY5hB3+TH}x469Ks;#Ed-6zj36 zl;RfAr8Kq|_F3jB;Tm%nI=~h2OFX#j9F&i8Ubu8vClFZuBdN85y zg|S}^&kHH)N1eAfsUR;Dof=fSg4d0j9F7DO$B5^33Kl1rZ;HQeK@D{dCrFFZ$I#@8%$*<^2J^L1eODypf+F$oCbe3t;>rgMqr%-zsH2*w{ zec!+M_nGXufhufTn5g0Us{c+!fJ}~Hy+%yuvWbPa9&i=ylz+7> zxyr~^P#$qYCvSM#;<=v&3+7>WV3&|702RT?on zr{{@elyobvFqt{mF*Z2pqzdAS$Gmxuz26ZrY0kuG*hvg&ONW-V=!U6T9&nuXR;<=^ zFe}`CH4nGnFpd3UzJIK<`PzvHR8viPM_X=I4QTpEy`&^6+>`J8Whz71t*3 zQPaHUUj($>swz-W4ssQ~mA{s9MD#_0JX8;|FwB>NRF~g~0IL^s00B!1oJQ24~ zD+!6GZO1?;`?aXTovu3^C3^D~tu#2R^~Ui64Dlp()Ob}G^UY)l1zAWn@|`-edy>tJ z@kwNx$;%SeD*@rDx2kPadS!)Ldnz2BGaly3XAP2<%?|o*zJ=-bQ;XOW7LtrT>dC&( zEHLf$G>DPID<7+GjsD0)Q1a6Y**Osmy~lz1hW5?Znh8c{WsA~^NQ6F=ye=56gH`Rf z6Wkax=`BqA;DeRR($5guQEPeW9xg@c{rVm5&IsCX4nn` z42ow=#iIg0qb3u8^t(7&r*CA=o81=;-KD*5N6BRp$&okQG(dGB!{fI$Xe}a(lyNf| z0G%4PG#i53b;fTkG>ec&)2VExTL)4J){m@1Y z3IFFb&%bdu|8r97JAS0~2YvJt)e?t*|6r?}UEvNt*enQ`2kHQIM8N?F9zJe99)>^i zBB5}{Kk=?#4SuBjk<$ZV`-iN%yF0hLzz<;*?8V1pq^_p>gA3!bbwVIPPGA(3^uNQ# z{t>K_mV|)C!Eh)D34=?kz-*j=S|Dc-rxM5s0la6|lIwt~9SCkO$@5FL?^I7+}}LLU0=GSn1505Pb)g)}KY@u-J zp9TKN^~+t!-)KQ;RIA|@kmULO^1HDE$jRCjMf^!aow)RMe^~x;OVS?d=?;TK5Wnei z{;VV?s)FCk1OI>nIZ+V=Il!zrfp#vgP`IZg&mUIb^?wB7SHFJV_@0DtwX}nRk?buN(HDD$khRfsxXT8`3ZA=$3Gc>zd8RC zumm|fJNy=D9yce*-;OL*ICI_m%Kaj%zP{i+?Isow7IPf#}e>eRr0QRdXE^1fiw^s8XaInAY{PhjquR5_r|ETlZ`@Fwv{dG_1 zSFLc$Kehhb4$D`n1eBB(kdp3HK#-E|6a+-1OOS5v z=<%H6Irn$Y|NifDd6<`H-o4j%uf5;3_TKFGqp6C4i3|At^V~#1_Ra^js|_>&;QI#; zKnHjThdLnmc)wqPSyTY_4DugU|9;ti+az_z!_fig28APRVNTLa0=)c8K&TTK2C;Rr zmS%EATJeZ6-I0;fhB|iPv3b@gZR#1QO2c8 z(S}b1B)~5qVhIu!09gq^`T51f1t69JmR43m{9>Y_;$U89gd+s({Ih?eV5lfmTo5cQ zZY3^cX$Ae!Kfb>_G8s)&ypRLX0oXs{#VCQaA|C?)ki8B75TN4aFQfKv5%WaP%xOV{ z*pG5Z690TC0>dOc#2=O(2!Q=GcG0t;%N=aDPfWW!-Dy$=2@pX6`X}_e))G zqnrFQLkGo#ExsI>1vDngwng!8Aa8E!y}rT5Eg0Gx#!W_97PQutslr&0DnPxH_=XC? z@tE$Y?FDa`1q)U>p85S?fo3Mvs{Jsb-gYE0D3Fjq<|N(ixshAu>$GQYUW@FQOVl0T zrwM#JyWJ#2z&3wWm&E@(MVjiIv5bUNT-Z4CX2a0~0bExxI_-_)Avbf7oiEFM;-~r{ zOSQ^oTX2#(#q5D;`a=Haq*eM7W3yI6=MxFF9oK~{wSldjq+Iq{wQi}23)R|>@6pY~ zl%PEzu3xeo?W);)scp^4+q=pj;B`J^8?~)|uPjcMGF!{g0V?TX+qvGJmYstg(G~d2%HWK{!G3&re ziBB{ezmV6$loaz($0WtQW?C2#LC`BX!bxt?2)#2IRq*3ab}VOH>`!K+=quR-BXc-) zj-R#_6g!;iBxriZp`F|xDX}MxThh(rlH7)*UF#Pa!;yH0mdUD6l- z32_3I)@{eTocb&a76-HTrOyx(*TpudMWj?~C0M?_EQ!@PO<|CDC{=?gcv2<4qg&vJ z)0P0-!0Vw&*DS84hvYDN_;{Fo(Zp1b!bnWX-KH*&wGAQ+%+fu03Pyv6j?%Q3A@Asx z6S)MnWlrGFR))T}7veTjG~GgbAQyiZW=d^3BFUAoyt9wjYy#%%%+u+GZut z)t$3OF4yrae$~r0LgMiG9mrbmKBw~6{e>Oo+#)Fr>(M(AX?gyU&sVhs;#?KWiX_P2 zjN>KUbY)hvRL}^{S;C{6t@^yRH%Z=2D;%djRiaIn&;~Wpfn{}lpb2(pr zO!n7w9}$)(7euWVA1D9-8dSQ2VNOV>6B0F5{r2}~`hyYwx?1!bu0u_ld3#IQbnl!od*U!)n!H9WCdE4M;u!U6BCg|PK}^~b|acYK6tK4x}pq=Np|PZ zi5r4(!xOj&!-AN5#+O^GCx@V>4>;Ri7DazCfJ|4ai;0cE9U)D z>Bap$PA{|z^sZPX)~NZbaH-&kQ)Nb&{lYU3fX7N@J?pxmJWeth$Ge#FPD+eCQ$)it>x#e^ZSu>*8&8pF2h7#DczrUVvE z6S}&XPz4XcB|A-oLb@hk$ZSR=J7?A4)nY~FR?TDU8XCU=>dz3-W>TLFy=z4u9FwgA$s36$x?7yfFvUy>;su{idMjtZb{q|Ktu`!PxfpvV4banM+ zXD+7kgIv(f(N9yb(Ec&wgoD(^W?!nc!h4Nrra$u<)dEyApqZFuM<^-1^Y^^(M z`P>O+GPWFDOU?EGUlBltfn5>B5QV6ooJzc}VEAg2ACKXDT?lVrl!L{PlRDR&^rm=B zdEvk}Wx?_g(zW_fnU|6+EPQOk|H z=VSNATxrVD;rk}=Ja$TFD~F@C&qJ|87WoG+a&;mS=!ZX+HVVeM)2*$TW; z>HU_uYJyF^R1>e6I+3;_#I7!+7898FULfqb$(-3oqh{`T)Fes&G>T6o*VfyMl#h^w zNj+#3J;ZPhM}Dl7^?|k~>yD&^q`BMdO(SsOhiQAo&+p~ASlMM+%T*7vN@;W+ZM#vs zA1>?Q>JX{GH!;(Y03=`~Lzq~d!d-Lu3ouk>h9Bpt5~lR_z09v_B(P5Tm|afYr$|AA zs1x)@{e_}YU3Ckxq$I={xz5tvIaNsgfbn875t!$IDl4-IDVtP4u_&*I5(Td>b)oNS zSzXsRn`$-DYTD8Wyqny$bcWHHH1r1V^UHOfny9$y;peo_F})q~u8}x>lxJ{(@(pz9R6lk8+)?t79_hpbL zxMgOO<((aVXud_N1((-MsWp=onuAHK&#pDz=7o2B6ZomXIQXd%ReAp7%D|9s9^o)$ z2%XT~AOb2xeAmsmQA2!iDf>HaI>(wUrUao?@$whii>Wsf728^;-WrC)m!?QybVU#a z8D-bv(!LHF+8a+efY@m~6+#>1U&T(#C=|2D@YTK{htCk%U;o)buiE!Di2*2a2-!dx zfx8(_z36e*Ajr6ey;n|)+*zTLnce2D-ZetjjOa;QzH(V|wK-xuD~6TA++D2Rf-fU` zf^N`VrgdmOGpJ`6oh;tAVUwxC3OhfVno(nkbX@bJ6oyK0U9x-_(g^D#oh4AZCa}P! z@-F#qC3&J^Jdx28rwVBHdX`+a`}A#=g3~x2G920Cz3uq^vp3QHic>oiuN-n;Piz*} zw3f^?_J{5Fd?``GeZ-`4H=744i5Vdj%yf@=H=e{SU zcx<;5?n+S4M7*XPR|w`=F>&Pz4(I)P^WhO(@}$`!BO zDdC70hYf&r-UlVPa@ATb%_18YgC#*rX#!&*YXS1(W>*2Hor>y zQ9E-3m9|-!OMc%;YN4K!^zch<4Xl{9w_QafEwU>t-W*83lw|W_xSewNP5O^RZCfnM zvF(Xl`3u|Q84?tpH-uY4aSE}Q=c3B!uX@n$z=IV-kc*3#tJ8gJP7IM0{OHndbJ7!i zFh*M`dei8(s=St;6|z6I;h z8=G`71#?AkH;UwZ)>@}Y2FC^IOU`%ePX2uZoOcZSTY|%qtalp1F89awunrPKQVe<* zzD-BRZ;YNEcs=C2y8hQ~=wQ+FfGivUfP@SHVEE^4sH3eD@BecvY8&-RY2=ctQQFw{ zzFJM412}PcJjKH4VE|g2=)hvfwZ3`%tE2YP!nF}yy(7EBUJL425)FBXmDF?AJyjhE z*S(?l4=8*Hdb2!N1F7!!kMIayO((KBGK|$=JT4>hycmj)zZ%jTuwB!C6#Hp9Y8&Uu z^1S=xf-kVoAr~X=uu5$6zU19~ zV)M$)%&-gAQwfp8Rj?}~-l<0-j{y0_5#9_>N^ajn6Degs8)VpXED+)-az5|!+eH1H z#^4!xpH8V0ZvrpE%b>GTKcBCyl0)8O2I~fo{5{dVz`LonRBW5N6W@HjT5E~UJ2&J^ zkMA{^hJT>lxjJz<6L#mMqEy`{JGB+5ml1!*Na_6afyPDN_8Sg~^|a-nyRbnbPfz+Y zgOhs)n&N&w1&QxNy$^iprWSKu_Q=LGsv{Fy3meEU+tP2nb??G^#+q-wQS_NytY0Z? zB`=ZpkjQoM80yaW#c@RD;z`ysi`1Bgp0TCzppO-=-$(?0dG8t#AAI3XiQY zWW3+nlTA4N;t4)zc${KMD9~>1d`~ZaT$23*o7Hjp6Dms32_ZHSrC_2Dnyb2AIK=Zh zr8XYv%SPx7!pJ|BhFrlvHJSFaT)V1F`4tB}c-%iODrJ56t?q$Xmk#xu*s)tQqZ-I3 z>|KNIR9U)jo=d{f;i7Ky^LAJMTmDf5UU_c$eQl)SAM{6W>4z+k`MyO9Lz_6R3cQR5 z!qA;(>^M0C3t1aqz{&ETWPybMYUxNGD97moc25V0_pFT(tYg^+OR7nFPZZOHW#X;IkQdI{xn_CPDV~iygy%DEN(Ck- zY9mBIicm{{$0xDtYor}q-s^$`;$*Zg^dOTK+t#gW_37+~lbG>?6!;D1k#z(Sc6_^= zKKGR_zHooA^As*|n%Krn*L$ATyo3xH;?1Jf3H~&oW|b=>gw%W0ps$WOBbAO5Vcupn zXb~2?clOG0_$|LHLcJBWOH4uwdatOFCvMEJXt0LXdE4B&Z}*;gYg`YFJs$f&ktFOc=_{W2~O8+@`oXQ*m@aNV`*iepy! zL1nz7Xp-+q)r9Jo@M#%#BZo;CCr#_NJrha_EQyn_X0gQPDz(E>6sHxY-!s-?bnkPJ zsA+#o-8vpIbf1;6(MWK5D!-^h_w$+D zfLX&yT*tVkvPNUG4q*V{XS!;%)~PSDP~ONj#;jS+9O9>tWeoQ5#~h@yL282LPdHy} zEw2|C0?TLdmvQR$P33Q*qmSV`Rmj#WQDPZxi9o|5R~pD)O+J$%LxVIb*U9bLZ1rl= zGx_(nM|NiDy#~+N*qbVYT5dE4a@CLHD1@s@#@5!1jV&2s7xBMV^(8(N9L;CDg)uGI zvz|?)t~}oSxqgMtzYv5+###^(`Slr|BJNW(t3J~Lp<(*lG#pz2&X`IcRvf$&cphcP zEC9Px@SGP~qS;T@hvYN7R&jX4)o+F+6DQH$k|rS4B9fh4Y5`WbGv9?_Vj@K4EpiA%;Wv-_)$q1+EsI)@i-qAbiO%D4vNv%4UygC zfRI+-4dO|1uIaj2J!)JOUzd4Oh^+1pjx_4ASZ+4gV_I>jWnvhGFp|P7{KuS!N-tgg+{*1hD4}Z6o zkexHXRrCUyPORN*CO46S7LdFhT$kr1)2ftMDX z$=s;TQtA5x<)vHtAPFD(qWab7Dc|lK7QOUJJ(uzPh_HVtGeb(itYiD6HFi|)BOKwHZ@OCr-`xFVlEwTC!G0K?rzTJ) z9mW+zIdu!G`uT$-E{#kZ#3Ry#m_Y{jn^G~jnxCa^IP<3v;tCH2e`;S54&tZ{#G|a^ zeGid(q9&0{I}0ofqkA}bv~C`*U+)p*BiJ>Il%X$`cblB3y2U{s_Wtg~u2l?KN(&#M zQ&ntxcHKaDXyzcKXi0wlWE^);do18oOK|bMp|au{4I67Nr(eln-H9o7es8!+Z;5ZM z_S+5Q=a(=mnaN)K+aKEJ(!SFcsalPejYhC{BnU-1DL_+)_V(0Kh^MzB$SY3y0*UDnD>#Yy{_ zydK7~gsb%Hew#k<%FS4v<8;6NmzTB+P4By1M9-!_xWDP(^9I??m^b)5bPN(elKXgX zNb+9pM?}24B8_go^1FM^hK6(gGJyHu2!nTr@j7#XJNkh2mqR0GnO3udY4xM!L#9X~U)s0B4KO4jy#0(ny2(?xspSPAu*U@-)5^ZIuKGNj zB9vXmT+ni7bX>SgIT$a8+6mY_FVzXaEho)Vv##25OBvGk%e&F*EIS3aT0L=i@V>xP zxks-+cZ@;bQo+azK=j}=Mhgln9Cs;zDZejFW}`M6}(yzmlkZ6ch`HlU@6o zpJw;M)Xba)XY^wlM@9}WgijcJ$$<#u)~he#BkltKFbai`|CVIc13t2wVW7haQjgu=bg&3^l&2_G0^t zi^Ui&*>%w!L_gu~2mc2U0zR1^f5c`MC`y*k*xk9a(tYl#kpv2Y5fmo)BQI= z-swjz95Nc|k5Hm=8Tf>1 zIR}YR#L)O+MdaK5X72j+$?LcJamFmz#gk@uF3r;KtjV~=L`6LA5FuDYd&@o6pKMt{ zX!z01C)0Vm&Lqqg>07N~)!JrWrv*A2FP}T;`}!d2sDIp}+Px5@OkfG;R!)ANISq!nw-@WQTjy8&CYDd|cZg$Jg{|hm5$${Bb zQi)O|74H`jb>77h4>9fPOZ7gbCA1LP(VS)J*UP;r25BzBv)C)nA;Wu7J*B0a<0;@5 zs%~;4k{_tz?FJE8-ZO`x{tlOv3S6~ zUvdT;S(Sa87a^y5E}K$sCG;y_?cUG6@s_2{3RKy<%zi`BXbUIXc_$*0lq8aHJ7%;^ zEte{+Bq`~TjBRoDqJzp9Qb&%)Aho(#MJO4y`n)=IVm8W-((68bna}yikPZtqGkV0g zmUXe(d$e20GA(-b5M6{<#+0CtvU;M+DByZE5dl%j#4FLHW%7g3>0a74nX;`0@qo+y zA(3ETbDNDP!z~}p^kms`+Co?!<(xefH+FSfs|=+3q(tXLd<84J(%Cxbdhj9inyK`? zRcQ(a|1Ox8H-QY(YGj*4wc#A~`txKO35%#wdfN;84D%OZ>T?&`z7=cYkxo&sKM~D} zz5bATiKUsK#mkZnl+YN6?UbYR-s;agY0D`GO={2~378HV1E@b>Z>I>(oF?h#sgJ4I zWk1uqxcSH)^POY9w#D277bX(7IuZ!=a$U z1nInXK9j-5^9SQ^pYa#hG>Lmpf9l#q8xVh;=ckG*{|2^Bt4YyV6C{-GK^Y`+k1$?%_1d>3ULaMt z4WGC|JUq+`XhHF&_`$^_vSz-?9sgRN6PH5W{5PpP{(=~#soceyq^j_kW0H&Wty-BZ zMxl3Ni>EzSu@K_gO~~HiJzp{_zHns&dpkX+%@3?0Wa~{NJaN@^(WZ0p_uQnP67!tI zPUjR6l$x)IRW+9hy~4UH(b&82j#A zD2)NRkIK3P9f|Ki4LMx2r;WrF5uTH-Pd!g!XlgWWZeLN9X-GSAj&ExWqJ5{kPbz;z zEHTGZ7KqPeAlMgUyxygZ*r;w8ITo^J;Rlfr7MJ<#r>YbhZ@0`aewK}sa+Q-P*iuqF zp=%}7;JE#CSaSbU*?blw)W?sz z+zwB6vsT(B7)(kFi#P^{zj4YD+L)qAv8a$1R~7I-;HwTHwr&;6W->{S?9R5QF}9|& zmo+=TU2T|}+|Dtm-r|Xy+HJz_P8%P`?BsW+e>p8OO^-zBZ6|IaM{DdCAQRqR0RgaG zs{;5*rUApl#){}(?GA~%+G5U43_?9MI<5J5YklK_)_Y-+q?6uNtdx({)QerX!|Aap z-{niO<$zlQRvz|rDoOaQ0@8u5JWm&lAWG|4{LyVF8b(sS2yqqlFow!RsW*ay2Ui}Yx6j+C`vlwN7gJ> zBQ7&3oAy_$QrIQ@4S)b zAGpzPY?cHB{0B_s>RYs+>(^$rBLm*V@S+IJHO^tb;rQ2d&VAW#8>@C520q0R^i zTwHbm4xpN?lRXd#L;e0h$G#su1991J|F;6voQ}&b$N|(tK!4W#ZUwPLI6HtmfuP^+ z0a5rH(ALQc#tlTcf>Dqcf*a@#f;*wGH6W@43WvksxVU_LK>6S8oPJdQY3*){v;jJy ze6dA3KyiP1^j(gf?H(Ko^n|$rkv34E2+#^82!%r-KokRahm8Xlmy?qdcpudQ3{?&X z-qTbDfFpB2+josR~(qBp3zXP|waJj!3{u7esM1o)S1iAsQC}D*WY#i`hMGQVxWf0O$2$^3OW|5Zwl1@M2rxc|NRzs@kfHh+%;@So-zO;s$^(*vN0 PU2K3cDg;8gzJL2KJ1&oG literal 0 HcmV?d00001 diff --git a/node_modules/toastr/package/nuget/toastr.1.1.4.1.nuspec b/node_modules/toastr/package/nuget/toastr.1.1.4.1.nuspec new file mode 100644 index 0000000..c3fe237 --- /dev/null +++ b/node_modules/toastr/package/nuget/toastr.1.1.4.1.nuspec @@ -0,0 +1,40 @@ + + + + toastr + 1.1.4.1 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + https://github.com/CodeSeven/toastr + http://johnpapa.net/wp-content/images/toastr-icon.png + false + 3 Easy Steps: + +(1) Link to toastr.css +(2) Link to toastr.js +(3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + toastr is a Javascript library for Gnome / Growl type non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + Added AMD support (and backwards compat with non AMD), toastr.clear() method clears 1 or all toasts, optionsOverride API to be able to override options for each toast, added onclick callback option which fires when a user clicks the toast. Also cleaned CSS, merged CSS files into 1 file, and reduced jQuery dependency to v1.6.3 + +Fix to the toastr.min.js file + Copyright © 2012 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/package/nuget/toastr.1.1.4.2.nupkg b/node_modules/toastr/package/nuget/toastr.1.1.4.2.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..e92fdd46e409b4a8742af5a05686d5ea49b15969 GIT binary patch literal 11772 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 P#X>ShG=VUV@4x;Fyv>uu literal 0 HcmV?d00001 diff --git a/node_modules/toastr/package/nuget/toastr.1.1.4.2.nuspec b/node_modules/toastr/package/nuget/toastr.1.1.4.2.nuspec new file mode 100644 index 0000000..e9c1ff4 --- /dev/null +++ b/node_modules/toastr/package/nuget/toastr.1.1.4.2.nuspec @@ -0,0 +1,40 @@ + + + + toastr + 1.1.4.2 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + https://github.com/CodeSeven/toastr + http://johnpapa.net/wp-content/images/toastr-icon.png + false + 3 Easy Steps: + +(1) Link to toastr.css +(2) Link to toastr.js +(3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + toastr is a Javascript library for Gnome / Growl type non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + Added AMD support (and backwards compat with non AMD), toastr.clear() method clears 1 or all toasts, optionsOverride API to be able to override options for each toast, added onclick callback option which fires when a user clicks the toast. Also cleaned CSS, merged CSS files into 1 file, and reduced jQuery dependency to v1.6.3 + +Fix to the toastr.min.js file + Copyright © 2012 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/package/nuget/toastr.1.1.4.nupkg b/node_modules/toastr/package/nuget/toastr.1.1.4.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..badab22354ec099b9bbd27e78cb42552a32a2d0d GIT binary patch literal 11802 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 AK>z>% literal 0 HcmV?d00001 diff --git a/node_modules/toastr/package/nuget/toastr.1.1.4.nuspec b/node_modules/toastr/package/nuget/toastr.1.1.4.nuspec new file mode 100644 index 0000000..5578b3f --- /dev/null +++ b/node_modules/toastr/package/nuget/toastr.1.1.4.nuspec @@ -0,0 +1,40 @@ + + + + toastr + 1.1.4 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + https://github.com/CodeSeven/toastr + http://johnpapa.net/wp-content/images/toastr-icon.png + false + 3 Easy Steps: + +(1) Link to toastr.css +(2) Link to toastr.js +(3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + toastr is a Javascript library for Gnome / Growl type non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + Added AMD support (and backwards compat with non AMD), toastr.clear() method clears 1 or all toasts, optionsOverride API to be able to override options for each toast, added onclick callback option which fires when a user clicks the toast. Also cleaned CSS, merged CSS files into 1 file, and reduced jQuery dependency to v1.6.3 + +Fix to the toastr.min.js file + Copyright © 2012 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/package/nuget/toastr.1.1.5.nupkg b/node_modules/toastr/package/nuget/toastr.1.1.5.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..9dc04428750b03b31c15c87516a50bb5417d1a29 GIT binary patch literal 11634 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 M6{ + + + toastr + 1.1.5 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + https://github.com/CodeSeven/toastr + http://johnpapa.net/wp-content/images/toastr-icon.png + false + 3 Easy Steps: + +(1) Link to toastr.css +(2) Link to toastr.js +(3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + toastr is a Javascript library for Gnome / Growl type non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + Now using SemVer for JavaScript files. + Copyright © 2012 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/package/nuget/toastr.1.2.0.nupkg b/node_modules/toastr/package/nuget/toastr.1.2.0.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..a63ec724b7b5dcc1851dbc027152d1b9678116c2 GIT binary patch literal 11716 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 Sp`qwoTr@LO6ENWVcJ*Ju;C-L~ literal 0 HcmV?d00001 diff --git a/node_modules/toastr/package/nuget/toastr.1.2.0.nuspec b/node_modules/toastr/package/nuget/toastr.1.2.0.nuspec new file mode 100644 index 0000000..d667d56 --- /dev/null +++ b/node_modules/toastr/package/nuget/toastr.1.2.0.nuspec @@ -0,0 +1,40 @@ + + + + toastr + 1.2.0 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + https://github.com/CodeSeven/toastr + http://johnpapa.net/wp-content/images/toastr-icon.png + false + 3 Easy Steps: + +(1) Link to toastr.css +(2) Link to toastr.js +(3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + toastr is a Javascript library for Gnome / Growl type non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + Added getContainer(). +Fixed clear() bug. +Removed semver from file name. + Copyright © 2012 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/package/nuget/toastr.1.2.1.nupkg b/node_modules/toastr/package/nuget/toastr.1.2.1.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..34bc06054b03e4a9b9fe5be6720a1d0996b82129 GIT binary patch literal 11728 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 gwRj3Pl>ctN(NV`hZp@(|Nn9)x6J!^#h($ literal 0 HcmV?d00001 diff --git a/node_modules/toastr/package/nuget/toastr.1.2.1.nuspec b/node_modules/toastr/package/nuget/toastr.1.2.1.nuspec new file mode 100644 index 0000000..bbd307f --- /dev/null +++ b/node_modules/toastr/package/nuget/toastr.1.2.1.nuspec @@ -0,0 +1,40 @@ + + + + toastr + 1.2.1 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + https://github.com/CodeSeven/toastr + http://johnpapa.net/wp-content/images/toastr-icon.png + false + 3 Easy Steps: + +(1) Link to toastr.css +(2) Link to toastr.js +(3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + toastr is a Javascript library for Gnome / Growl type non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + Added getContainer(). +Fixed clear() bug. +Removed semver from file name. + Copyright © 2012 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/package/nuget/toastr.1.2.2.nupkg b/node_modules/toastr/package/nuget/toastr.1.2.2.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..75ee4ae591e6f5584760da953566a91b1f00eabd GIT binary patch literal 11719 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 Xse+Eo#{rN4?hSwuati3Pe*5%aW{yfS literal 0 HcmV?d00001 diff --git a/node_modules/toastr/package/nuget/toastr.1.2.2.nuspec b/node_modules/toastr/package/nuget/toastr.1.2.2.nuspec new file mode 100644 index 0000000..cca8187 --- /dev/null +++ b/node_modules/toastr/package/nuget/toastr.1.2.2.nuspec @@ -0,0 +1,40 @@ + + + + toastr + 1.2.2 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + https://github.com/CodeSeven/toastr + http://johnpapa.net/wp-content/images/toastr-icon.png + false + 3 Easy Steps: + +(1) Link to toastr.css +(2) Link to toastr.js +(3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + toastr is a Javascript library for Gnome / Growl type non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + Added getContainer(). +Fixed clear() bug. +Removed semver from file name. + Copyright © 2012 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/package/nuget/toastr.1.3.0.nupkg b/node_modules/toastr/package/nuget/toastr.1.3.0.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..b4dfe38ff44c553f391df402ed4901dfe046b099 GIT binary patch literal 15020 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 + + + toastr + 1.3.0 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + https://github.com/CodeSeven/toastr + http://johnpapa.net/wp-content/images/toastr-icon.png + false + 3 Easy Steps: + +(1) Link to toastr.css +(2) Link to toastr.js +(3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + toastr is a Javascript library for Gnome / Growl type non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + Added onFadeIn and onFadeOut callbacks. + toastr.options.onFadeIn = function() { console.log('hello'); } +Added option <code>newestOnTop</code> to show toasts in oldest or newest first order. + toastr.options.newestOnTop = false; +Fixed margins on full width toasts +Added LESS file. +Added min file for JS and CSS +Added missing vendor prefixes in CSS. +Various minor bug fixes. +Added unit tests for new features. + Copyright © 2012 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/package/nuget/toastr.1.3.1.nupkg b/node_modules/toastr/package/nuget/toastr.1.3.1.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..a1eb1ca399aea4dc5ed838b95d5fce764d98f2b5 GIT binary patch literal 15568 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 + + + toastr + 1.3.1 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + https://github.com/CodeSeven/toastr + http://johnpapa.net/wp-content/images/toastr-icon.png + false + 3 Easy Steps: + +(1) Link to toastr.css +(2) Link to toastr.js +(3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + toastr is a Javascript library for Gnome / Growl type non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + v.1.3.1 +Added new API for toastr.subscribe so you can be alerted when toasts appear and disappear. + +toastr.subscribe(function (args) { + // args contains the toast options and data +} + +Added support for glimpse.toastr.js plugin. https://github.com/johnpapa/glimpse.toastr + +Added toastId, state (visible/hidden), startTime and endTime to the toastr info response (available in the coneol, glimpse.toastr plugin, or via the subscribe callback). + +Fixed bug with stacking toasts when clear all toasts occurs first. + +v1.2.2 + +Added onFadeIn and onFadeOut callbacks. + toastr.options.onFadeIn = function() { console.log('hello'); } +Added option <code>newestOnTop</code> to show toasts in oldest or newest first order. + toastr.options.newestOnTop = false; +Fixed margins on full width toasts +Added LESS file. +Added min file for JS and CSS +Added missing vendor prefixes in CSS. +Various minor bug fixes. +Added unit tests for new features. + Copyright © 2012 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/package/nuget/toastr.2.0.0-rc1.nupkg b/node_modules/toastr/package/nuget/toastr.2.0.0-rc1.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..fe2dabd4a1048e60aed89d3fc0b8c6ba2d0b2827 GIT binary patch literal 19421 zcmb@u1#l$6k|ij$7+cKD%*@H5#i&CK7m{X1uN zWtC}}74BXUnI2Wo(>Y{p$Uk0ou;ila6y;&(pdcXs*x*3$Knxs#)=rEJ|JW1d zV}VfRqWzob|GK+w@8%P9x3MO21v)xe*xB-vFf%Zb5CLtC?My6e&G<=NoK5MuNCXA= zl!4X&=f4t8<`(u&M1NImo%l)2ot^D@7#W?6&4D%mCk8uvpzYrlQ#(f+fb-u|M>9ry zfUy<849LjB#Kgh)w>SS~gXEuW5~+IF1OGRRHWtQ?c20Jt&J4zOHveJlZ@>PUV`gGx z;$*Y|*jktZot#OCQ~{1=KxcjuMrS*Kld~g(t&5XA(3pfs%7mXp+1QwciJO(%n1z#x zm5rGhKtja$Kl%3mPvc><0XhRr0L}nLV>?G6y}jdKZAWJdpwoZr+y8qtoPdt57RErQ z|Dz5gH-OcMlbaRD2>`OO8FO-Tv6!*|IR75AaT~D#fj|a(CmR!E`~MgphY1@qlL;Fe zC$}jJ8-V5Su>X#a@tpw* z)^34kEc>_6b$f0LBWK27=(1k*kdDPMm0aKidZSSo5Yj=wfNsEu!5R~+P& zonAs~lxp~Hs;HbL9)1=xkPvlP)6gS(`tD_-T%7o^h>YgU{105ez4S(11j37ASK&|} z)ak)}V*{wIy5E;6eDf|LY;BB`VMFaR!U9&jf26uO*p`P%v_|8qwWFhT!4&Pp=&}(! zZ2qDH2Z7^qiwN1Dpal=@yl|M)nRA+ps!k*+Ap(3B(&)DldWl*G)<=m3rIX}i zT!}HQ?_*h&9w?-Ifcxjtd4g>OHGSG(2I=w|U1`)Bq_1-YE*khTE6g`+{T>At>s^j~ zIL7)569?Gq1|NS(ro@DDB#^p{bZw6+SN4 zrr@aiWOCRG;p!5zL4ly;?s1Kqj(<)I$y67xg8>#%+l^isxBr8LZ##&!ix3OzX5JH@6!y zy>8WeEoYMRwsRH`ye89$cP>ajdJ~5(GU7X8^$)kIa(f?auuIMBymTf0z>YipX`3ai zIN)>nVoXZ9Y_pq^@=!y&|!WagE83c6@aQ2E*NJuPxts8 zxX|MfHuS0vB!AS^>9*SqQ_C#6@6RuokP9n4HS_x47avmttX%3L-w67BFiBUbzn19= zf0$(5f80s(RlczBK@Q`2Zk|(|tR4N(dQ{Udi=*pS(w(LY`|Om3jE9$wTlduCtbKR* z0{8ns?C6}{?OsRhN~nAT?WzzZ_|R}~18q%>=9K>B>gqO5YvU)6*;LWrQeE8N&cTm# zooHZUQIg$vrcw>iKjYssjA+sKS3mt3jp$SHapuU<0hw@b{6x~7>M!{+z#0@R*`+r4 z?9zX0@XymXd#>&r2nPbG%PUJ)kl&vMzgMVb$S_< zWv;3$oXx0^?G=CA{qp}4i8NPft`zOlve7nK+redi< zGKY5`f5D+>6zp{#!$pTEMi;&Tlz__sC-gQ`ouD^={7Q6=E~dRwVEFJ>Oz(rI&8=~m zyzdRfN~b<1GEH|W0pGTGu%0-T*9DO3j#2l|)Ac85MOlaUfCHA=?(EA+K3erzN!j~1 zH>9$$GE{swl!G0MW+TpYXRAHiK7C*o!5fgquCi5`=YVh2>_VB9*{iNzy`z>8=#Yku^`h&B zCfxJ%q4efCsik6E!4ub_9M!N?_EVKR^RiS{u-v;2IMxFjkY|89&{GumUG-=_*~~AQ zZ@oCV_MDYI4?MAt3`bN9{$%Y@cwd+<(@%7nweaFcyT7P-bLx+l0`|vTdn(UZ&DLtH z<6p4cNp#eH&P0^)9(RWZ6TaW}#|XZE7-KFgSao1;x>EW;@;Y?_6oy@mHFJ%R_#ew6 z1|8c^OgiJ+cpPitZdhb5`JOHjk6)kY{Hm;|{Gg+yZWVv%qwA-1n(A4+TeGu8L2hJvJG5oZ*Z!g zn(-mBcuUh|CfkOF6Y3d789P5X_UOlGX+JBE#f#6&O7(iE+7lV`IX&mzo%|m|^~Br1 z;O*4zkB&ecyt-g~^=fK5Pc&Tz5Wn``3cqy+zhffhs2uEG1(nBEec9mfqxq%~FOu`x zHs^HJJRQTz>wav$-CT7rR(#@b*v)otntXP1hH4n?48je#MLKMwb=gJo{`HR>wd*gX z!FJ_4{K=fs?S&PMN{4bdC5+tSK>L`S6Ou{eYfUo2kDb+|4|n{YJ9uBmi#b9iLXs@4 zQg&ukqHmjx3r)n$!JGI_FQ61~6Ia`4p2wgr*dXnNMJOm#(qs74DWL2sO+JtyO{>e4 zYpP8t!mEcO1QEO8T!T4jpCCGi~w zw+p-m)SV$O@jwUsvg+{r*&rWn#i0$W`$<)_T)UBEXOWmtiwJ7RgjVKQfyKEzJtHB(u zkv#+`W`=ljR3qmjLf8O1NuhCmc!=1us;5j2`_SVxsVdDKLaY!(sh-zAQCoAPTKiOO zBP`~XYUt)8vHgS6Fzr=NCAP_v$PZ73@T{$+aFJQK`4QJYDdKnajpaLRd*!t2btb?t zVwR$M9LTd8Nq7O4IcV~k-Xu|3he*Yp%eT1UHhTdv!*j%1Fp@dT4{L&lMJ>J1Mn8ik zIx`^AVtXyUm^Lg<7M5cdnqH-|5VTa{eP4Euw+!;xeux7Nw)nbIm^QaU!UaW#!pe^$ zsp)Y2#<0%uP=+Fbs8Ly~@vVDBSRkwhN=M)5agHsgq^VU>o1n<22XfhT(wY0M9vmjV zIU54-NCV>RqYIX^S(}ypctXw2FF5W&1a%6EE>}K%QP5HsFux~&lC4V=kf}8{CO3`9)P}r*OAOcia+_0M49%ahR{lJR4uvm;l+NVL7g`5d^KbqI z8wQo|J+XE{Tm-kOh&gH$jn@`bnKOi~#DPX09KB4n4yW9Mqj$$*7Khu_`Z;z;488g9iDTqY;i6##)oIlOZkpGHMMU(nj*FP!}W3NzQV|B|_upfdAVH zIgjgVT=76BqQr$JHQT5KDx_$#V2$`lVyKBnY8r|7wOb{h4qgCiW1H;s6bI`cwUm)v zv1)Xhi0AwyiF;ygaj=~Wt7>=_#lfKdD^4d5^~gCRo&aa(9`?+y?`9*F7B87P6fm+BiWp2i4&F6I%o~EBFxeneDJU__kE5CL zQ4pkPBTE=?6no}b_+VDrk{z8p^(A+yjjMKm)=ivs>Rb&1q#tp6RJxifMzo1mQ(4Ts z5=PXyA-*DaKw2LScOnYpGJ8oc*^% zGKbueB6x9x5^2hxpjg&+%VwHJu&sJZ38(HkrRg+8(He!V=Y<=6NMwC-Fj^Ez8{j@J zo{sbN6WGLtebm{6;oN!16%ODN@TQh{a`7IgR>qQn2Z|9P`IBO>lSjd9(`v*AXiXHy zacxP~G_4p$66(#ORbfErUB+%oearTdHq0kM(GKV%rw(}f%LeKc*lv5*WTIL)6($vK z@NhD)U+hUP!)$X!@CYQo)X-YjHxOYpL|;t4Ay8SHh--8V_#?onwhmGZ7RmC(FqjR0 z2KIEcioy>UBWH6#Wzw07mF?oXwC1!7p-e0lk;%+qNh6%o^mlpjNUF%jw%{W)Fx0$G zSwoXYJSBmQ5;W^T*#Dpw3fR{q>os4Yx#zOL4aG}A8rp%6_CDdN5hOJp8QOI2v?X_m zkH5Ro)|1(FroGHnY^?X>B4|1muG32XjZc1E*BL!&2FHg_r_H#|wP;CkS$-$^UF%3F ztHC+8RiBwWA$4ZgwfMBYQy|IhmU|7?N9|_pGLnwtCh~aV7hfSB1`Ax1V~=|iu4nLU8E$6c_)l@^V*j+%L}S?$ zxUD!f0U+f@>YO6xZm6;HwQ+J!i2T)=&r*I0oS(wsTk?s%>WnINFvdfFJ%dJ4!}p}x zSmvZL#y6ez6$+Bc@986zOtWM|5N;AWfGn&l{lmq;K4M($8GKErx!<$b)p^y;f>p&^ z-|YgrZCp1LMw>~mP41T!7^fy4Yek--`<5-9T1z=vy!D+4wy4ghp8?wh@NbNNs=EyN zf8*ORkr*_E8t``W{Twx9aV){y;iMTlo~Pl@3!7D$mU|e-0|K3Iy;Qm*4Ic^oo^ndB z#a-Rbq&;1a9(<)Qk9JLI;z@3gj%oL=oeA~Xa8IrxpWl71*fw;eKZ*&itE+3h%4Z+z zfU*LU-JDUQW+C0a<>HB(jVA^T&)VGKpMq-9pHEajW~*s931+($S~=Imavn%S-5frl z{u#V$S-((O!-Ig_{RQuY{~Eko1OG4RoohWgU$SX>(dt2vOU=qt4Lu2lgvPW|p#0mx z8M>lUPDlo*qlyry+2l*@9a9clHxuYqT^);8(c57Kg$jb}MW^vLsq6ds*XOVOs5lKi zccs@mg&5P!75RLeCO1hzUzxLQg{bbY_xbivCISA;V#29E#X}IgR_s~4Mc2UYfSaQU zLEq0({ni=X{^+}yZQK59bq0btoG?i{=c(|RcAL^kMFq1oq4kR!7 zp?NeykrfD5N6s-MJO+$`R$5vzAE|>9>HH@87+j6a91e+jhGpR5$>Cscremz8Ck51w zMp0hPSHqtsY0iIFp(-4>Dsb!pOZt+J$ zUJPa8JEH)s#;gf@4geXw?ts&?GrSnYRwJ?4_e_{h#wVGsd?D0I)yqE|pxd!St z#ucG=P4UbuLcoV7i8yYMs6%o`h^X~hJu5=|QiGAXq>}aBy@%|I%C!VDffZ`ogQadu zbPnGN_G_0IxYs`e+^x9*5F>k=cgu1}xaM6FZ=MgDXIZfcQbroyKK;K0dG@tgEqM)O zz-G;_VDGbp=AR{-)(xt1j*7LDw*$P&sRu}XU}6oXqQ8{CbJn^@c7IRgIk3X)zVtqi zEkM6zcqB2o!+Er(KAR_>nL@tBUU9WCAvMqCX%MZt$!rKXn|fu z(JO-_aiqUrx(hBJb|wvWiI`@*66HS6L~?J}8YW}f^Fxf*1_$VEegN55F3DJrd1Qd2 z?`rnJ$?3q+-Sze7(=JBMJyXMjRT92H2t2OQit@9hvsxP^U4&4kjT#A-?-UlB{w!m% z_eaKY?8-2hom?BKj-qg7Trh|y@cr2QZ9~eMZ3)s9v7<3BnT7Z;sKbQH zP6_!f64Y~OZR79=DJu00u0pd$M9{}PM_UyFWW4rod?Kklc1DFR6qV?a0P0WQ^b)5} zeFsaWliA+nD3%sIW7Yhf?yUur<{RA6PC-o0~>0a)zA35u1VVn6n7(98c=N0Az1 z7K;;(;ruw8q00q9+lZ|;@z5*+IE7GPOGtzX4UBH{e0;=~Z*19(l)+(^5y@I+xHvNR zA4)7^qdV~o;1GV+B^5T9oC|UeN5UKIFUnI}Q8>R4?T}P*>n*Qh@Udg-}k_n+vn=r>~}n5jW0&|h-(+p@xDG^r8k(28-r4&nQpb17JFn;neWuM zVwt*kWLmh-+zLySDKk)XxaJobe;tWTuuCCc(#oo5R<%e8nLTdxf8g!H|xK5iZ(94d0d$w60zrgELirt zJmkEiYQ#$K7Kuj5$bN$I*^HOnUZa2OXlk`EBt?iLd8m2|A4WgamdkLiBzmb=2+@vg99V zdx0ePNapBrUjssB5ft1t^8t6fPQ!M?O$D+oted#d_l9hnW2UU>2M@v-RNOFp1!nZA zN$Og(IchV6RC3Z`K+&3@_O8^CGbWQQ;r3+$@!w#@7i0oNqU`!15O8L$CmCp%6VaBBAVxy~ zk807P0+FJ!l8NVerpr>2%g`2CF}1F{H;&Y2@MWBMAc2y1x0ypC9kj?Uy=HaEB{K{w z$dY0uZ1jT`fIh~cNQNzWA)Q82l)YqTz9UtUKVts2Myrc>xDRVC1n6wk*q4D%trbd= zsYsca>uEZ5wl|N4o*+mUYxla?31}T2H4zHJ5l|Uk&n}GVHEfGFkvbD8HKZ@xY>4(M zje$XFE(i$eE44seQ`EkTuKNYd(2?h`m--v6=oyd+7wgeDb5g-2TofU_?tmk9Sf$r+ z6Zwq1hIz-O#IM1P0^G{v$(sdJk`+hBgtxAm##LxjqvogL<5Ol`0}!A{`K+U)dDGKY zO^9sjRm^tlCbD@f0km}&1qzS?wf=X7O<2~LJ|5IL9hFN)skZp)eYBB1zXW!FEJ>a<~fD+cGfmepBO{kr!W?a<8 zZ|v0goU(S}X`X(3dvaQbqD{jt)btV#or2&mOJ*+wQA;##T; zM6fwG=S8MiEY4~4h>cj12sw`>SiXy;+o5MC0rtXAC^o3G;pT;!n`o*j&=9rU5Gt2E zCD)wax0htzom?Ij_|~P$i#|3PtDlBlGVTvo-(x1P>*dep&>ndFK3+R&SrE0}-!b+l z&NdXbRIb-rHW=Xy?(?T<-)Nm5Z1&*d-*(T?0|z`jaNVu6^n0tSNDOiX8A+-YGp}jv zo{)3YC^rX{&hWD&wx#&7)Iz>qitX}@y(Idf14EEkqhj)u_;lf=luO$Aw$Hkj)HOJK zO+UQmrGFn?zP7qlG)IITz3g3jdcDZ(SGK3SO*34Nz|CI1Mt3;1az8?;b(~a5*DD_u zhM;|9;CvE)oP2%%pn6sNXv2T~e)6h)K=U_`MNi-=ro^4x{BY0%y=~M)(Xco4WBrBCo~u&TwRTKYw|!eElJP zL8m*pO4~}i((}T1rNf^ooM5Dl8Iv7(J>LGh`I}NG^R4*J^B@Q*t}oc+3*PT}g;x4> znwIgR1{D3;H&*9w5}Xxc9(+$5nNdvOy+@+M{a z9x=pdfK+wPVA)+x$iGc5-5wq8osHT0MRHUmekjP3(#CKbQ=A`u6*i{;Wxmfi)~*pl z2ra0yFnH>LUJ$G|ecds*`9{V(Jd5>frL_SxvvD3@1?E$Grz0eww>c4`*tVu3&R zyIW6t){ETC}cpqyt!>*{B7%3YW%bbUl?e}+{yYQo2B|?HZ={`I!k0ACR z24pj_=rO(Ia)j$6<^3_uWWqV~ka`;yPVnO0egV9LhH{VEd%teWML6+G2^XF=nY|_J z*XMm6a2&UH;EpW1mvhYy6Y7MAAuee7<`_`2NR5y;#VDhJ)FqVg@ zp5AQ*+Pk{~1mA(?@PjUj3!7udu51d#-AV#bA2wGR3wCVpixKHDX?lHBgk>;3sqjbL zCZHSy;pgMS&+2Uo4wN(Nud5AjTZNb6DVFl^EgIJv6rVU}oGm#{*Edf0SCFlr8m%vy zucEJuqG$Zo7zX)Ib4(%0%y<+1ZlW!I*gef4*DU(%6rZc6n{AWTo^D_r z!(*!Dx!S06494z51-)Etrmv@et00E5mAu2e zs1(fWG>QWWFbv&o8bn73c53qN2zyNYx!-j}uBBr+zj4{Jp`#0H#a)TDA}{E28?u4O zVm2cHX+m+899L%?*M;k}zsJmz+jkyKY=b|m^OiJBg_N(=nc-~AT&!iOg;uF-?h#pO zOd|E~|I!J~v#`&T6Rq1$i|fU!jMlHUY*c0sR72q~$6k#ytI9>a-?VuD(6Dyk|n!mv2tlHU<>N%HEPwZdTa5+&Yp>rrQw&5B%BQ{ZN#+!{pm}oA{l7E#IR%Mam?2;8#iAkmSFzCd@nM# zwS5+%0Pv>J`dtRm;?Cj%*O}%rK2uqx_m^qGPwFvwajkWa58I??pjM*a9~R^$Mxe6x z<4LJ(g;f|1OMd|l>3V)EFa;WY#`_^(%*d>#$=(YmV(+G%pE@= ztLlwGlB4D9acKyHi+L6nUc3a{bySJ3QAkQYt4D>ypJT_m0kUuP z;2V$zadzAth-04BxR zi3p9Erb2a3U0DxZl$h@42n}NAN>-XS|0(rKrqZL3=MGv5`+YU<)Z-8i2diOb%Snx% z@2({AQg2WiO(6x3k2GoUA!-xI=~<@jR2_A!s`mxChYzUy!Z`}Lflc}!HBA2Av@IGF z0tX6~^H{0@!Zy>a z#)zY$iEe))r%71xdSp{|Jq|Z8j;^{DBO_aI|4Ndn>Bp~X9DEWQEb`}c?8b~=VHqIX zi)cCTU5;f8RlKs&et!bB)fpjxdp!kUK!l&O=3*CACI_5CK?qn5Nh8D!o2lc4wM8#= zHH{DH(VEg`MLpWdBxcpEd^pjgYr{~Q_=rOQn377UAgKZ_Slp(9nY+bk7vQU81U$^b z%(Y~8K{=Pz2bel~KLH;ewo9*8nYo8GX;nW1AoZE*41MJsb>zmsRI<@hDLFKs3Mt$~ zT5-m|44wnaU&5%pvkzA3Pk(YIeX&E8C5=H%CQX$tqwz8%W4>*OG)h&btbghF&}0>g zRggbo%J2DB-8`HzEKH$sCXEF1xnU?s z*ea_C84_#pMM7jO;Uoy#dS<~kc?+pRV6doKv-pg2hSMNwXK`As)ymVqX!;5>+*KmQ1mDvu~F2 zGV2lykRF`t+YZk=_>s?j6s6-you&@+)Wt9Vj?{e8?{Yh&=K17xA22KujGQuGPTlY$M!Nc4@M&g*i!+;u&(RKf;qbWHB9* zm#V~?d-axD=K?62Tx9Cv8`D|VKN{bnJ)QjFEzqPv-^SE*Uo33H*jG%u<<=|TfaF~{ zBu1x-J|StA07uPAzG&q7)4pJDoTMV-2%a_*$N;FckD>Xjw|zOX_RFC3^Mrbt)bt}1 z$e|cpJ$M_u!?H9u+wSXL_Vejnpw}R$B>SiqeW!cOo&Uo}j z%MBmo`**gbnuYTw&kLdyg7tv?n?6*-{Yg(pmZP5JmHCFn{N(&1*3_)-QGl)+A*EcYR>QuE}zf9cPVSwTU2`L zJaLJw`Fs*V@6YA!yG)zX_jsgy%+67#TULg$k?9Jf+Yq4ZSv7hF>Zmkz9gmtWnp6CZ zv{YAF2IW9II<~=G;vO!^l9-LVxN;oxx8*W@AJbA2=^if$w1jo(>bYkXB@?`5wMh{P z-;NeCZUwCX-g(?Hr?xTdym0G8nv{q^+h!Rtn7jOBYMG!8eXM88+QYLn56LmPUpj1f zOO~Vujxl^}Cko0$oid$z5N~=;jink=G))oBJ@Y?Y`@@4#&7$@6~aZNAP?uBTQ(Pf+!@sF;nVk? zSIa7@Cqo4*-XXdtKVOBRTP-~gDB*uQP4({=eR?S*& zo2PTN-N(RZvXsBZPCYj^?9+qHTZMs#m*X)=h!FbQkFs(&#v)P&D|-9jdV$ze)$9VT zrlcfWxwu;9)-&^Eh1&^nQ1-O;w(2b%I{`)(cHa!awvziX1Ay8r<3}tZEjb7s&%PzN zln!iT)s%ny;dZ#hwou2rksWvmqgB$6Y14ggV3$KI!*nsO!sr{CefSGQL=mG!?|Gtj zag{26r5Pw(nf7lJJz2nShiyE75(q9idO&gG(#1yG;l>5KWB*0ixQa$} zk#$om%*HF)=N;j7A4{n)vd^VmC9W;%D*8G=!A)DW7}DVhahj6ijMvGYGx0eJ3BG|> zszF@e8@H%Tc_z>8x!dZ2JA;HML7Ro-oYFaeO@Sf2q@+^TbL1KZK>O#1dLDYYGwS@Q-BLqJHAV|Z*Wcdo0pPXZnKD?aa!IT!0Xs<=vHjUgiHYu2-NfC~skfjo0ag4OR;cdwLB=hZmytfUIjVV4;L=-a_Lm&k2%zczAy_5yQ8dDX{CwneB7!x zlUYM~nn<9Gv$Z2)Y-O!$glY8b7#c!hA0d+dvYI^QFttd)55NBgFf3ni_(j?+R z@n_w=`Gefd+^nt0I7;Vly`#LT!N=Gf_!TR~$4BmTC}RTv!z<*Mm>T{ivtHH(k3Ae{)$_B zQC6)RCtkmJLUs^oZf^3=AxG4#!Mz+b4xH;hjIg~f_EP}9VQ|01o$So#_iIV%?{2Qe zEr6Ntv@G_CF6D#5P!_iZ^HkpjFCj~Q?p|qr@=_Y6x_sOWqAa8MXi95PE1iLvR(YY- z{~|j)IA|`QdQ82iAeraCvUT&+ZGmhjrWZQNNKhc|l*SIcc0=|!TRCO>E&B3<(qrQe z*dMYq^A*e&{|DLp+=O&1h=zPW%xrc;rU?u;nYB|sH>O=l+nai?>6_iF1?zU7Ph?1j zl%9>8ca*(NTKk*F7wXW)JM$2S4&t?OutHF7??bm*hz=oXf~CxQWa@`Py5|SN z22?4(f6;0E_TG=2hesd92X8!H4xXUD)sNG7EIzjz>!ybD*YkYK=>N|RzD&DbwL zgU?Knv1!Y>wdPe}JkH(E8nBy5%AGhaXi3gYAtxHpluu(DG~cyMva;<7zmeHK2B1Er zq{|e!eK~s`@>%QlU%AKq+AJ>WN|{xI`jutbg(I$k2r~k~^uHD@%zC}PAwhtEh$Dc2 z5dUlB^pEF#{~A42YHZrBbD(t**0|Yo2@xqJJE&iTl*R)t{V_C^tjDX`^hZ!^>XW3B z1Rvpb6q+LV=kx)gXb&k35aH<1hFPMw?|y`7eqWzZ)txk13$V0~%FhU%PrYzXVs@v_ zz0k)|+VC`vXM&jQ>I<_EHN*P}yc~hJ6p^zbW6I@bE&%$J)EZ$Fj>_wx#z6^taTiqh zwPi2O*rXk+vx0I6H+l;ww?WEHsm7(88;q3hnN@)U21j=RTrz zg*HAk38}`H$Z_9c%r-tlQTew%I&Vab>O-9NJC7*-Jc@BN3GYf7J7o5tMG>0~j_Esc z@aLg=dMqFE4RsB>o6_4NXh@G@zicrYSU4r}%W0+D!Y%ejd!$(|6Y_!Crh~Te4ws6J zu{M@(OY!@3P6q3x#u69z`a3(G6{E0E_*|{|t@G1`n^IISgYi6in#=4UgLdE{Nwfth zN5CZK7%24oB+VCu?v{Ml^6z>(c$E>-9ja7kuemP?hb%O0?%Z`y&%&zZ+rlu^WzrSB zrsBgW&dK^-VMghK-6#qtsjmYIa9V0cmNM^$;LwX%8xXuV2PS3D)FjQ*w6I~2-VbGe z5Pmt|ZP6x#nd6M<=ZG!HAGw0`kUx=z zh(et)rvXv6wLZ}B7g}e1legZF7hB+)bW+K?#l zk+N)=K(36Wa+yfokAl;_nbS>#kwE+IaI{TNj-(Rb3%4NBl`q5fUpX9!M?+Q+jf@}D z6bAD9)U-P}C~&*9QmP7iis=zRKk|sVP9#-Z!HN%`Sdc%ZaE8s8QsA2^gT|ZnZ-|iI zso*&n63Q7XaIeYGYJkELWvoC6u(1aZ^KYUfaM~Dc3>I)O%~X_>J>#$O+Y?|f#)bos z?G=+l(B)9W<5f*uy?ZQ9tkzay?FI5s=h+EwUOMDq*7UFb$##2)>p~%asXZaUZ&Dxpq*D)6 zNa!AV3Xq9kJ=8&xuwp5rMmSQ@0Lt{@2qEJRJHub*o4Y^E7a~84wPQ*kPaIjR3tl@l ztmbZJucZ1PhO{hfFT0fs2AHKbiY<$ZzRV#nBCZ_8I6Q{WLH|1y8I3qbRC|i`aiOo> z&LFV--ee<`qUfhTq~OU5e};0)z}|jraqKEVTxS5Re&|Gh)4d~S_wYlQX4vu4xbBy6 z>#z+VBN@B}yQEu0tMgmZK+F!AHDRs+GqL#?OO~ht-~KKijRrXrV)0|Uo?IvW*7ANC zUe{=yiIBecmj*B7q|-tQVoSq(t&zs2YtH^AM2w-M^bfbT+Xo+ltHhZ+30yO~W237Y zWWo+Md)jWTF7lxM^WwSC=wWy|%9qXR-EBhXyVrF)21Y+!%}Y6I{oYg|4!`$DnJs)n z-qID`aes!d|0T6DZ+iK01Oo!{hz9~f{y+JtWv~I*|Eo1yjar*3`&=k~Ib|=DB_5=W zJ>VFroKmitNG!y$NIRBE*Q6%7AeN&(~_cMf3e5U_F6Tn>bsy=ej64CI(r7{bpD3y2ftrX7Tbv zavFyc7z}JS8Zs()Wg3!1uk2bvvF?Izc-Rs+;ni{nvm!mCs1h(WelzBP)CN`J;&63c zGfzaXj*ims+ZIgiEX9U$CWu}qzC9ArkX{KKW!}Ybn?VCO0}G?} zGp~8G<~hCAqn#oJzB-*yW&rV?^ESAIpVb`Eu50d%^FzJzf6v@-uiYqEAbap+QGVb( zV9*#O~ zHCqw`c5DrF9_;Bu*#+J5{ML3zSr$O|Ya^7(jf1d}(5da@WKWfDcXH>{P*A5d`;z1+ zyb&-{$9i&F9^g<#^GlMjsgjZfk&hQ(T*&1n*=je8US)726Ve2(&E)md?+UG|{DtaF z&)(=-g5fH^L34y#b?r4ub$~EFfMT1pVXHFJku6XmBWN((q!`V znw2>mNPf{k;OFNmvsn-G@*n!s5-|BB!-m_eG{y#HM-#CCx4=_cp!681pg!nAjT=29ztm)2Go7UJuZA zG^8(uOwTF!i)a+kPT^8PI8<=N1Wnmf-uT*^@YGcnR7*oX#F3>|Ip(^wq=WU_TH9Vq zA=3KNbeh`+b(B}!5L0p#?7_K-?See)CSh#5TUG7jsPCYpWIz0LPDHe_)DD}@chC+= zo#xS#!pZ!zgBeCC%M(_0bIpGU#MKIU!x#$Uw(UzR!a_<-y2wOZJ)RUohU?ySJtCZu zIF-zprBKFjZiOjYN0Ir&!*c$!AXNkEjqEo5VilUIH&H$C+kM!hVW)4QXs0HOA&W`|h%95X_I><8apT@={lS|CV+8LRRsgVC`?r^Lo2R zTr~hkBR8fHCT=~iYjA@0Z^-@~DsxvW7~D5m18?9VD5azCAUHqJz9@--Us>*!^h(~( zxBBnbsnJwjA~&UepZf2G$T7{BiTOqQW+;k6pXkJab}!A2Rd^EK3IoVDSzeH+11|Fw z8t#mJ*#oQr03kj7yFf$9sx1|4RDKeow6=m|qR|KZx8@ zgo+l?RCB@z^&P8gCZ}q?1&^G- zzL99f&VB%_V{pyV)>B~YavpVDPN(2C3xA5hfmPOOP;Fba{QlrlN~W^PfR)swtAG@` zQv3m)OK6w`-DNDdX^CHQ#)qO0F9i|wEHvW<>wA|E)nc2c_tbkzbO?c`z{@n=UZ}I* zEc4AetpSvJ*e4{Qzo_Z%KBF-~wtR2_QsgW-Qi$^bw(&dj1Cwl58RQF;R1zrSoh=mO zVz;s2Zi(+yLbLA$Z&Zi}e?up|@Sfx7_V1$Qbm|rD1cFRN`Dpw|-ls}KU=Q|^1K&#R zs!xvsXs|7EKtGtT*`}4BfFeE37CMROZ|arsC5;SiMD}9aPmuj{=qC4`Mvc2!_4%WQ zZYOyQ3925`XfqoHL&m!>o^~eYY3UHnU4R`nn)k1^p!uV>v~K~%IFn(yS7N5~3Vz?2 zy4?*a7^&fL6`XSPepX#71?WlJ!Q-yF;cb^>{k&cWv)mQh`Zm;~Z%2YycLW5Z|gC>S+}_4D-Y4>EJ(!E=w~z4r=P z5A+qZ_8Csmt3gm)Qc1JxAWI)Yas7VkvreyMjql4r68>_pT*)y)#F;amp*Ty zpM+7s#wVx>lilzWrT0XW8-1(mh?Mst4d2Y+ z7q6+Z8P_dJvR3>gzzip}<`E+J#iAp;eyt3GR#_9DVnC#fIMV{h?9P)|5JUMvSeNlu zQm(@V`x_MdL%;OsxP~~+a;^z>^{pHqWNS^01i((nDCid1l4VIH?F)@vaVD>x5-1pe3aG zS*?vV{03Snz9M>DF7;8UmZl0oKAco0Z#rEuQFyercx8l0qY?2w=#EGceQapSXU4Ee zl_v@g;n(Y5hxsfXoGzMH=y5pVuvV!-?amy|W@l1L2~eUE?$J|0x8fI<@YY){aaI~S zn-CdvdPmWCV8Z>~>ETLR+1KKaD>6nW$E1EcTr72ET;6JLuRepz3XP5ND3Js$h!{ZmS=8#`i z0*X1K6viRrtueRuu;UwHj^M}nUGcxy=lmBT1R7cP597ZJ{Qt2j{RNT#zf%wVE5P|b zrySv40N>l zFD{DzuJCUy|0(J2WbvP7-Q3(5+*tq3@Ly&MW=2gpS(Seyv7ooGb#eyS8Uz2s{(oxx zPdP6Bk1P-Zd?v;`#*RRMvz?=Ww4J#vks`nzKqm>Xbt00m>@TqXJ34@)6(8e&6Z?mX z3Gm-jQ-8TP1Xzj00Ztx7D$YQACmvW>DrRaTSqob$B4@k5?|-Ac_(z=;5iAwU|JLyL zfeb7aD>adt6YxJ||Dk1K;bdp!LYxpn#+ft@#!l8YA&&@q}qKXkvQFv?>@eGk046gv^Id|P4V58bD6Wx{dDk*0y!&s6s1y@Bx za>t!>4s4xQtegRR#-=C;9PmhBl)dP5UANcku~+CJ$LpM(UtO{|N>lV+0EUY;6Zn>k z)adD;^du83iDa4pA4-R!m)068w8`+aKj;s99zP9(x`_nRD8ntGYZyZ2e|RsfH%;MJ zSg&$EDU`M+2kPM<$!9ERCLU%nO7m-v&6gGMbr@`{NM9sFk4-kvrK0*WhqxTRt6oEi zzRihbiGbj*V}Rg!j>}M0_alFX{(fc zCt%B&J6*cm&GY||qkS(a*;JDG+@nh#zI5*YDadwjF2uU~zhh_HvV8US;Unti(g&Z_ J{=A`I{{Z_g^m_mR literal 0 HcmV?d00001 diff --git a/node_modules/toastr/package/nuget/toastr.2.0.0-rc1.nuspec b/node_modules/toastr/package/nuget/toastr.2.0.0-rc1.nuspec new file mode 100644 index 0000000..d13d8e1 --- /dev/null +++ b/node_modules/toastr/package/nuget/toastr.2.0.0-rc1.nuspec @@ -0,0 +1,49 @@ + + + + toastr + 2.0.0-rc1 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + http://toastrjs.com/ + http://johnpapa.net/wp-content/images/toastr-icon.png + false + 3 Easy Steps: + +(1) Link to toastr.css +(2) Link to toastr.js +(3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + Toastr is a JavaScript library for non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + The following animations options have been deprecated and should be replaced: + +Replace options.fadeIn with options.showDuration +Replace options.onFadeIn with options.onShown +Replace options.fadeOut with options.hideDuration +Replace options.onFadeOut with options.onHidden + +Optional 'close' button, bug fixes, and improved responsive design. + +For other changes, see http://toastrjs.com + Copyright © 2012 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/package/nuget/toastr.2.0.1.nupkg b/node_modules/toastr/package/nuget/toastr.2.0.1.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..a3a98b2a2f8d9efcc07d5e09f3871fcd52a3e50a GIT binary patch literal 19400 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 literal 0 HcmV?d00001 diff --git a/node_modules/toastr/package/nuget/toastr.2.0.1.nuspec b/node_modules/toastr/package/nuget/toastr.2.0.1.nuspec new file mode 100644 index 0000000..09b937d --- /dev/null +++ b/node_modules/toastr/package/nuget/toastr.2.0.1.nuspec @@ -0,0 +1,49 @@ + + + + toastr + 2.0.1 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + http://toastrjs.com/ + http://johnpapa.net/wp-content/images/toastr-icon.png + false + 3 Easy Steps: + +(1) Link to toastr.css +(2) Link to toastr.js +(3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + Toastr is a JavaScript library for non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + The following animations options have been deprecated and should be replaced: + +Replace options.fadeIn with options.showDuration +Replace options.onFadeIn with options.onShown +Replace options.fadeOut with options.hideDuration +Replace options.onFadeOut with options.onHidden + +Optional 'close' button, bug fixes, and improved responsive design. + +For other changes, see http://toastrjs.com + Copyright © 2012 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/package/nuget/toastr.2.0.2.nupkg b/node_modules/toastr/package/nuget/toastr.2.0.2.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..2efdb7adc46c99fce36e2bb3e6655f5cc6233aec GIT binary patch literal 23037 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

)sL(3MV$8au8;Dr)1|4L@N$j3XY&nQ~ee0 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 UQxUyXsPis>DrHf4$CCQ%KPTrvVgLXD literal 0 HcmV?d00001 diff --git a/node_modules/toastr/package/nuget/toastr.2.0.2.nuspec b/node_modules/toastr/package/nuget/toastr.2.0.2.nuspec new file mode 100644 index 0000000..1f76718 --- /dev/null +++ b/node_modules/toastr/package/nuget/toastr.2.0.2.nuspec @@ -0,0 +1,41 @@ + + + + toastr + 2.0.2 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + http://toastrjs.com/ + http://johnpapa.net/wp-content/images/toastr-icon.png + false + 3 Easy Steps: + +(1) Link to toastr.css +(2) Link to toastr.js +(3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo +

Toastr is a JavaScript library for non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + Change log: https://github.com/CodeSeven/toastr/blob/master/CHANGELOG.md + Copyright © 2012-2014 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/package/nuget/toastr.2.0.3.nupkg b/node_modules/toastr/package/nuget/toastr.2.0.3.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..6389cdf62c6c9c590316a5ea2adc1cbc8e95eb5d GIT binary patch literal 23027 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 literal 0 HcmV?d00001 diff --git a/node_modules/toastr/package/nuget/toastr.2.0.3.nuspec b/node_modules/toastr/package/nuget/toastr.2.0.3.nuspec new file mode 100644 index 0000000..1e6133a --- /dev/null +++ b/node_modules/toastr/package/nuget/toastr.2.0.3.nuspec @@ -0,0 +1,41 @@ + + + + toastr + 2.0.3 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + http://toastrjs.com/ + http://johnpapa.net/wp-content/images/toastr-icon.png + false + 3 Easy Steps: + +(1) Link to toastr.css +(2) Link to toastr.js +(3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + Toastr is a JavaScript library for non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + Change log: https://github.com/CodeSeven/toastr/blob/master/CHANGELOG.md + Copyright © 2012-2014 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/package/package.json b/node_modules/toastr/package/package.json new file mode 100644 index 0000000..51ef844 --- /dev/null +++ b/node_modules/toastr/package/package.json @@ -0,0 +1,68 @@ +{ + "name": "toastr", + "filename": "js/toastr.min.js", + "main": "toastr.js", + "style": "./toastr.min.css", + "version": "2.1.2", + "description": "ToastrJS is a JavaScript library for Gnome / Growl type non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended.", + "homepage": "http://www.toastrjs.com", + "keywords": [ + "Toastr", + "ToastrJS", + "toastr.js" + ], + "maintainers": [ + { + "name": "John Papa", + "web": "http://www.johnpapa.net", + "twitter": "@john_papa" + }, + { + "name": "Tim Ferrell", + "web": "https://twitter.com/ferrell_tim", + "twitter": "@ferrell_tim" + } + ], + "repository": { + "type": "git", + "url": "git://github.com/CodeSeven/toastr.git" + }, + "bugs": "http://stackoverflow.com/questions/tagged/toastr", + "licenses": [ + { + "type": "MIT", + "url": "http://www.opensource.org/licenses/mit-license.php" + } + ], + "devDependencies": { + "del": "^0.1.3", + "glob": "^4.0.6", + "grunt-contrib-less": "~0.6.4", + "grunt-contrib-uglify": "~0.2.2", + "gulp": "^3.8.10", + "gulp-bytediff": "^0.2.0", + "gulp-jscs": "^1.3.0", + "gulp-jshint": "^1.9.0", + "gulp-load-plugins": "^0.7.1", + "gulp-load-utils": "0.0.4", + "gulp-minify-css": "^0.3.11", + "gulp-rename": "^1.2.0", + "gulp-sourcemaps": "^1.2.8", + "gulp-task-listing": "^0.3.0", + "gulp-uglify": "^1.0.1", + "gulp-util": "^3.0.1", + "jquery": "^2.1.1", + "jshint-stylish": "^1.0.0", + "karma": "^0.12.25", + "karma-coverage": "^0.2.6", + "karma-phantomjs-launcher": "^0.1.4", + "karma-qunit": "^0.1.3", + "merge-stream": "^0.1.6", + "phantomjs": "^1.9.7-15", + "plato": "^1.2.2", + "qunitjs": "~1.14.0" + }, + "scripts": { + "test": "gulp test" + } +} diff --git a/node_modules/toastr/package/package/.gitattributes b/node_modules/toastr/package/package/.gitattributes new file mode 100644 index 0000000..0555bde --- /dev/null +++ b/node_modules/toastr/package/package/.gitattributes @@ -0,0 +1,15 @@ +# Set default behaviour, in case users don't have core.autocrlf set. +* text=auto + +# Explicitly declare text files we want to always be normalized and converted +# to native line endings on checkout. +*.c text +*.h text + +# Declare files that will always have CRLF line endings on checkout. +*.sln text eol=crlf +*.csproj text eol=crlf + +# Denote all files that are truly binary and should not be modified. +*.png binary +*.jpg binary \ No newline at end of file diff --git a/node_modules/toastr/package/package/.jscsrc b/node_modules/toastr/package/package/.jscsrc new file mode 100644 index 0000000..28846b1 --- /dev/null +++ b/node_modules/toastr/package/package/.jscsrc @@ -0,0 +1,90 @@ +{ + "excludeFiles": ["node_modules/**", "bower_components/**"], + + + "requireCurlyBraces": [ + "if", + "else", + "for", + "while", + "do", + "try", + "catch" + ], + "requireOperatorBeforeLineBreak": true, + "requireCamelCaseOrUpperCaseIdentifiers": true, + "maximumLineLength": { + "value": 80, + "allowComments": true, + "allowRegex": true + }, + "validateIndentation": 2, + "validateQuoteMarks": "'", + + "disallowMultipleLineStrings": true, + "disallowMixedSpacesAndTabs": true, + "disallowTrailingWhitespace": true, + "disallowSpaceAfterPrefixUnaryOperators": true, + "disallowMultipleVarDecl": null, + + "requireSpaceAfterKeywords": [ + "if", + "else", + "for", + "while", + "do", + "switch", + "return", + "try", + "catch" + ], + "requireSpaceBeforeBinaryOperators": [ + "=", "+=", "-=", "*=", "/=", "%=", "<<=", ">>=", ">>>=", + "&=", "|=", "^=", "+=", + + "+", "-", "*", "/", "%", "<<", ">>", ">>>", "&", + "|", "^", "&&", "||", "===", "==", ">=", + "<=", "<", ">", "!=", "!==" + ], + "requireSpaceAfterBinaryOperators": true, + "requireSpacesInConditionalExpression": true, + "requireSpaceBeforeBlockStatements": true, + "requireLineFeedAtFileEnd": true, + "disallowSpacesInsideObjectBrackets": "all", + "disallowSpacesInsideArrayBrackets": "all", + "disallowSpacesInsideParentheses": true, + + + "validateJSDoc": { + "checkParamNames": true, + "requireParamTypes": true + }, + + "disallowMultipleLineBreaks": true, + + + + + + + + "requireLineFeedAtFileEnd": null, + "disallowCommaBeforeLineBreak": null, + "disallowDanglingUnderscores": null, + "disallowEmptyBlocks": null, + "disallowMixedSpacesAndTabs": null, + "disallowMultipleLineStrings": null, + "disallowTrailingComma": null, + "disallowTrailingWhitespace": null, + "maximumLineLength": null, + "requireCamelCaseOrUpperCaseIdentifiers": null, + "requireCapitalizedConstructors": null, + "requireCommaBeforeLineBreak": null, + "requireCurlyBraces": null, + "requireDotNotation": null, + "requireMultipleVarDecl": null, + "requireOperatorBeforeLineBreak": null, + "requireParenthesesAroundIIFE": true, + "validateIndentation": 4, + "validateQuoteMarks": null +} \ No newline at end of file diff --git a/node_modules/toastr/package/package/.jshintrc b/node_modules/toastr/package/package/.jshintrc new file mode 100644 index 0000000..a9a9c57 --- /dev/null +++ b/node_modules/toastr/package/package/.jshintrc @@ -0,0 +1,61 @@ +{ + "bitwise": true, + "camelcase": true, + "curly": true, + "eqeqeq": true, + "es3": false, + "forin": true, + "freeze": true, + "immed": true, + "indent": 4, + "latedef": "nofunc", + "newcap": true, + "noarg": true, + "noempty": true, + "nonbsp": true, + "nonew": true, + "plusplus": false, + "quotmark": "single", + "undef": true, + "unused": false, + "strict": false, + "maxparams": 10, + "maxdepth": 5, + "maxstatements": 40, + "maxcomplexity": 8, + "maxlen": 120, + + "asi": false, + "boss": false, + "debug": false, + "eqnull": true, + "esnext": false, + "evil": false, + "expr": false, + "funcscope": false, + "globalstrict": false, + "iterator": false, + "lastsemic": false, + "laxbreak": false, + "laxcomma": false, + "loopfunc": true, + "maxerr": false, + "moz": false, + "multistr": false, + "notypeof": false, + "proto": false, + "scripturl": false, + "shadow": false, + "sub": true, + "supernew": false, + "validthis": false, + "noyield": false, + + "browser": true, + "node": true, + + "globals": { + "angular": false, + "$": false + } +} \ No newline at end of file diff --git a/node_modules/toastr/package/package/.npmignore b/node_modules/toastr/package/package/.npmignore new file mode 100644 index 0000000..30ae23b --- /dev/null +++ b/node_modules/toastr/package/package/.npmignore @@ -0,0 +1,58 @@ +node_modules +bower_components + +# Ignore Visual Studio Project # +################### +*.config +*.user +*.csproj +*.gpState +*.sln +*.suo +/bin +/obj +/packages +/Properties +/Scripts +/report +/tests/coverage + + +# Compiled source # +################### +*.com +*.class +*.dll +*.exe +*.o +*.so + +# Packages # +############ +# it's better to unpack these files and commit the raw source +# git has its own built in compression methods +*.7z +*.dmg +*.gz +*.iso +*.jar +*.rar +*.tar +*.zip + +# Logs and databases # +###################### +*.log +*.sql +*.sqlite + +# OS generated files # +###################### +.DS_Store* +ehthumbs.db +Icon? +Thumbs.db + +# WebStorm # +###################### +.idea/ \ No newline at end of file diff --git a/node_modules/toastr/package/package/.travis.yml b/node_modules/toastr/package/package/.travis.yml new file mode 100644 index 0000000..5d3c227 --- /dev/null +++ b/node_modules/toastr/package/package/.travis.yml @@ -0,0 +1,19 @@ +language: node_js +node_js: + - "0.10" + +install: + - npm install -g gulp karma-cli + - npm install + +script: + - npm test + +cache: + directories: + - node_modules + +branches: + only: + - develop + - master diff --git a/node_modules/toastr/package/package/CHANGELOG.md b/node_modules/toastr/package/package/CHANGELOG.md new file mode 100644 index 0000000..3f6f85c --- /dev/null +++ b/node_modules/toastr/package/package/CHANGELOG.md @@ -0,0 +1,120 @@ +# 2.1.1 (2015-02-19) + +## New Features +- Support for explicitly clearing a toast [jstawski](https://github.com/jstawski) | [PR 226](https://github.com/CodeSeven/toastr/pull/226) + +## Dev Ops +- Refactor to use gulp + +# 2.1.0 (2014-10-15) + +## New Features +- Prevent duplicate sequential toasts [SBero](https://github.com/sbero) | [aa083d8](https://github.com/CodeSeven/toastr/commit/ccb377b6015d557dbb987df74750b97b3aa083d8) +- Add support for top-center and bottom-center toasts [showwin](https://github.com/showwin) | [86a4798](https://github.com/CodeSeven/toastr/commit/86a4798e76c7d8516521780b7bd085d6bb4c371b) +- Add feature allowing progress bars to be shown for toasts [TravisTX](https://github.com/TravisTX) | [PR 189](https://github.com/CodeSeven/toastr/pull/189) + +`toastr.options.preventDuplicates = true;` + +`toastr.options.progressBar = true;` + +## Bug Fixes +- None + +## Breaking Changes +- None + +## Dev Ops + +- Add karma test runner +- Added Travis CI hooks + +# 2.0.3 (2014-05-17) + +## New Features + - None + +## Bug Fixes +- positionClass changes were not being honored due to 2.0.2 release changes. Refactored getContainer to only get the container, unless a 2nd boolean parameter is passed in in which case it will also create it if the container did not exist [871c2a6](https://github.com/CodeSeven/toastr/commit/871c2a6e438bb6b996cfb80286720604a4cf00fd) + +## Breaking Changes + - None + +# 2.0.2 (2014-04-29) + +## New Features +- Added simple ARIA reader support ([45c6362](https://github.com/CodeSeven/toastr/commit/45c63628476f6b085a6579dc681f4fe61ba5820c)) +- Added SASS support (direct port of CSS for now) ([b4c8b34](https://github.com/CodeSeven/toastr/commit/b4c8b3460efb8aa51c730dd38c35ef6b025db2cc)) + +## Bug Fixes +- Added sourcemap for the min file ([1da4bd1](https://github.com/CodeSeven/toastr/commit/1da4bd1dad21bcfc7fcfe73da1abb185cf2c3f9f)) +- IE 8 does not support stopPropagation on the event ([6989573](https://github.com/CodeSeven/toastr/commit/698957325a8e7bf63990f71ee409b911d69bc8ec)) +- Media query width fixes ([ea2f5db](https://github.com/CodeSeven/toastr/commit/ea2f5db6e5314dcfe48eb34176583849c177c00e)) +- Fix of onHidden firing twice when clicking on it then moving mouse out of toast ([ad613b9](https://github.com/CodeSeven/toastr/commit/ad613b9f18feeec630497590b85ca75c52141ea3) , [#105](https://github.com/CodeSeven/toastr/issues/105)) +- Clear all toasts followed by a new toast now displays correctly ([3126a53](https://github.com/CodeSeven/toastr/commit/3126a533e0ab12ec3ff374e155a37fd38bd23bb6) , [#149](https://github.com/CodeSeven/toastr/issues/149) , [#118](https://github.com/CodeSeven/toastr/issues/118)) + +## Breaking Changes +- None + +# 2.0.1 (2013-09-01) + +## New Features + +### Close Button +Optionally enable a close button + + toastr.options.closeButton = true; + +Optionally override the close button's HTML. + + toastr.options.closeHtml = ''; + +You can also override the CSS/LESS for `#toast-container .toast-close-button` + +### Callbacks + // Define a callback for when the toast is shown/hidden + toastr.options.onShown = function() { console.log('hello'); } + toastr.options.onHidden = function() { console.log('goodbye'); } + +### Animation Options +Toastr will supply default animations, so you do not have to provide any of these settings. However you have the option to override the animations if you like. + +####Easings +Optionally override the animation easing to show or hide the toasts. Default is swing. swing and linear are built into jQuery. + + toastr.options.showEasing = 'swing'; + toastr.options.hideEasing = 'linear'; + +Using the jQuery Easing plugin (http://www.gsgd.co.uk/sandbox/jquery/easing/) + + toastr.options.showEasing = 'easeOutBounce'; + toastr.options.hideEasing = 'easeInBack'; + +####Animation Method +Use the jQuery show/hide method of your choice. These default to fadeIn/fadeOut. The methods fadeIn/fadeOut, slideDown/slideUp, and show/hide are built into jQuery. + + toastr.options.showMethod = 'slideDown'; + toastr.options.hideMethod = 'slideUp'; + + +###Timeouts +Control how toastr interacts with users by setting timeouts appropriately. + + toastr.options.timeout = 30; // How long the toast will display without user interaction + toastr.options.extendedTimeOut = 60; // How long the toast will display after a user hovers over it + +## Breaking Changes + +###Animation Changes +The following animations options have been deprecated and should be replaced: + + - Replace `options.fadeIn` with `options.showDuration` + - Replace `options.onFadeIn` with `options.onShown` + - Replace `options.fadeOut` with `options.hideDuration` + - Replace `options.onFadeOut` with `options.onHidden` + +# Version 1.3.1 + +## Display Sequence +Show newest toast at bottom (top is default) + + toastr.options.newestOnTop = false; diff --git a/node_modules/toastr/package/package/build/toastr.js.map b/node_modules/toastr/package/package/build/toastr.js.map new file mode 100644 index 0000000..4708ea4 --- /dev/null +++ b/node_modules/toastr/package/package/build/toastr.js.map @@ -0,0 +1 @@ +{"version":3,"sources":["toastr.js"],"names":["define","$","error","message","title","optionsOverride","notify","type","toastType","iconClass","getOptions","iconClasses","getContainer","options","create","$container","containerId","length","createContainer","info","subscribe","callback","listener","success","warning","clear","$toastElement","clearOptions","clearToast","clearContainer","remove","removeToast","children","toastsToClear","i","force","hideMethod","duration","hideDuration","easing","hideEasing","complete","attr","addClass","positionClass","appendTo","target","getDefaults","tapToDismiss","toastClass","debug","showMethod","showDuration","showEasing","onShown","undefined","onHidden","extendedTimeOut","timeOut","titleClass","messageClass","closeHtml","newestOnTop","preventDuplicates","progressBar","publish","args","map","personalizeToast","setIcon","setTitle","setMessage","setCloseButton","setProgressBar","setSequence","handleEvents","hover","stickAround","delayedHideToast","onclick","click","hideToast","closeButton","$closeElement","event","stopPropagation","cancelBubble","displayToast","hide","intervalId","setTimeout","maxHideTime","parseFloat","hideEta","Date","getTime","setInterval","updateProgress","prepend","append","$titleElement","$messageElement","$progressElement","shouldExit","previousToast","override","clearTimeout","response","state","endTime","stop","percentage","width","extend","toastId","startTime","console","log","toastr","is","version","amd","deps","factory","module","exports","require","window"],"mappings":"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","file":"toastr.js","sourcesContent":["/*\n * Toastr\n * Copyright 2012-2015\n * Authors: John Papa, Hans Fjällemark, and Tim Ferrell.\n * All Rights Reserved.\n * Use, reproduction, distribution, and modification of this code is subject to the terms and\n * conditions of the MIT license, available at http://www.opensource.org/licenses/mit-license.php\n *\n * ARIA Support: Greta Krafsig\n *\n * Project: https://github.com/CodeSeven/toastr\n */\n/* global define */\n; (function (define) {\n define(['jquery'], function ($) {\n return (function () {\n var $container;\n var listener;\n var toastId = 0;\n var toastType = {\n error: 'error',\n info: 'info',\n success: 'success',\n warning: 'warning'\n };\n\n var toastr = {\n clear: clear,\n remove: remove,\n error: error,\n getContainer: getContainer,\n info: info,\n options: {},\n subscribe: subscribe,\n success: success,\n version: '2.1.1',\n warning: warning\n };\n\n var previousToast;\n\n return toastr;\n\n ////////////////\n\n function error(message, title, optionsOverride) {\n return notify({\n type: toastType.error,\n iconClass: getOptions().iconClasses.error,\n message: message,\n optionsOverride: optionsOverride,\n title: title\n });\n }\n\n function getContainer(options, create) {\n if (!options) { options = getOptions(); }\n $container = $('#' + options.containerId);\n if ($container.length) {\n return $container;\n }\n if (create) {\n $container = createContainer(options);\n }\n return $container;\n }\n\n function info(message, title, optionsOverride) {\n return notify({\n type: toastType.info,\n iconClass: getOptions().iconClasses.info,\n message: message,\n optionsOverride: optionsOverride,\n title: title\n });\n }\n\n function subscribe(callback) {\n listener = callback;\n }\n\n function success(message, title, optionsOverride) {\n return notify({\n type: toastType.success,\n iconClass: getOptions().iconClasses.success,\n message: message,\n optionsOverride: optionsOverride,\n title: title\n });\n }\n\n function warning(message, title, optionsOverride) {\n return notify({\n type: toastType.warning,\n iconClass: getOptions().iconClasses.warning,\n message: message,\n optionsOverride: optionsOverride,\n title: title\n });\n }\n\n function clear($toastElement, clearOptions) {\n var options = getOptions();\n if (!$container) { getContainer(options); }\n if (!clearToast($toastElement, options, clearOptions)) {\n clearContainer(options);\n }\n }\n\n function remove($toastElement) {\n var options = getOptions();\n if (!$container) { getContainer(options); }\n if ($toastElement && $(':focus', $toastElement).length === 0) {\n removeToast($toastElement);\n return;\n }\n if ($container.children().length) {\n $container.remove();\n }\n }\n\n // internal functions\n\n function clearContainer (options) {\n var toastsToClear = $container.children();\n for (var i = toastsToClear.length - 1; i >= 0; i--) {\n clearToast($(toastsToClear[i]), options);\n }\n }\n\n function clearToast ($toastElement, options, clearOptions) {\n var force = clearOptions && clearOptions.force ? clearOptions.force : false;\n if ($toastElement && (force || $(':focus', $toastElement).length === 0)) {\n $toastElement[options.hideMethod]({\n duration: options.hideDuration,\n easing: options.hideEasing,\n complete: function () { removeToast($toastElement); }\n });\n return true;\n }\n return false;\n }\n\n function createContainer(options) {\n $container = $('
')\n .attr('id', options.containerId)\n .addClass(options.positionClass)\n .attr('aria-live', 'polite')\n .attr('role', 'alert');\n\n $container.appendTo($(options.target));\n return $container;\n }\n\n function getDefaults() {\n return {\n tapToDismiss: true,\n toastClass: 'toast',\n containerId: 'toast-container',\n debug: false,\n\n showMethod: 'fadeIn', //fadeIn, slideDown, and show are built into jQuery\n showDuration: 300,\n showEasing: 'swing', //swing and linear are built into jQuery\n onShown: undefined,\n hideMethod: 'fadeOut',\n hideDuration: 1000,\n hideEasing: 'swing',\n onHidden: undefined,\n\n extendedTimeOut: 1000,\n iconClasses: {\n error: 'toast-error',\n info: 'toast-info',\n success: 'toast-success',\n warning: 'toast-warning'\n },\n iconClass: 'toast-info',\n positionClass: 'toast-top-right',\n timeOut: 5000, // Set timeOut and extendedTimeOut to 0 to make it sticky\n titleClass: 'toast-title',\n messageClass: 'toast-message',\n target: 'body',\n closeHtml: '',\n newestOnTop: true,\n preventDuplicates: false,\n progressBar: false\n };\n }\n\n function publish(args) {\n if (!listener) { return; }\n listener(args);\n }\n\n function notify(map) {\n var options = getOptions();\n var iconClass = map.iconClass || options.iconClass;\n\n if (typeof (map.optionsOverride) !== 'undefined') {\n options = $.extend(options, map.optionsOverride);\n iconClass = map.optionsOverride.iconClass || iconClass;\n }\n\n if (shouldExit(options, map)) { return; }\n\n toastId++;\n\n $container = getContainer(options, true);\n\n var intervalId = null;\n var $toastElement = $('
');\n var $titleElement = $('
');\n var $messageElement = $('
');\n var $progressElement = $('
');\n var $closeElement = $(options.closeHtml);\n var progressBar = {\n intervalId: null,\n hideEta: null,\n maxHideTime: null\n };\n var response = {\n toastId: toastId,\n state: 'visible',\n startTime: new Date(),\n options: options,\n map: map\n };\n\n personalizeToast();\n\n displayToast();\n\n handleEvents();\n\n publish(response);\n\n if (options.debug && console) {\n console.log(response);\n }\n\n return $toastElement;\n\n function personalizeToast() {\n setIcon();\n setTitle();\n setMessage();\n setCloseButton();\n setProgressBar();\n setSequence();\n }\n\n function handleEvents() {\n $toastElement.hover(stickAround, delayedHideToast);\n if (!options.onclick && options.tapToDismiss) {\n $toastElement.click(hideToast);\n }\n\n if (options.closeButton && $closeElement) {\n $closeElement.click(function (event) {\n if (event.stopPropagation) {\n event.stopPropagation();\n } else if (event.cancelBubble !== undefined && event.cancelBubble !== true) {\n event.cancelBubble = true;\n }\n hideToast(true);\n });\n }\n\n if (options.onclick) {\n $toastElement.click(function () {\n options.onclick();\n hideToast();\n });\n }\n }\n\n function displayToast() {\n $toastElement.hide();\n\n $toastElement[options.showMethod](\n {duration: options.showDuration, easing: options.showEasing, complete: options.onShown}\n );\n\n if (options.timeOut > 0) {\n intervalId = setTimeout(hideToast, options.timeOut);\n progressBar.maxHideTime = parseFloat(options.timeOut);\n progressBar.hideEta = new Date().getTime() + progressBar.maxHideTime;\n if (options.progressBar) {\n progressBar.intervalId = setInterval(updateProgress, 10);\n }\n }\n }\n\n function setIcon() {\n if (map.iconClass) {\n $toastElement.addClass(options.toastClass).addClass(iconClass);\n }\n }\n\n function setSequence() {\n if (options.newestOnTop) {\n $container.prepend($toastElement);\n } else {\n $container.append($toastElement);\n }\n }\n\n function setTitle() {\n if (map.title) {\n $titleElement.append(map.title).addClass(options.titleClass);\n $toastElement.append($titleElement);\n }\n }\n\n function setMessage() {\n if (map.message) {\n $messageElement.append(map.message).addClass(options.messageClass);\n $toastElement.append($messageElement);\n }\n }\n\n function setCloseButton() {\n if (options.closeButton) {\n $closeElement.addClass('toast-close-button').attr('role', 'button');\n $toastElement.prepend($closeElement);\n }\n }\n\n function setProgressBar() {\n if (options.progressBar) {\n $progressElement.addClass('toast-progress');\n $toastElement.prepend($progressElement);\n }\n }\n\n function shouldExit(options, map) {\n if (options.preventDuplicates) {\n if (map.message === previousToast) {\n return true;\n } else {\n previousToast = map.message;\n }\n }\n return false;\n }\n\n function hideToast(override) {\n if ($(':focus', $toastElement).length && !override) {\n return;\n }\n clearTimeout(progressBar.intervalId);\n return $toastElement[options.hideMethod]({\n duration: options.hideDuration,\n easing: options.hideEasing,\n complete: function () {\n removeToast($toastElement);\n if (options.onHidden && response.state !== 'hidden') {\n options.onHidden();\n }\n response.state = 'hidden';\n response.endTime = new Date();\n publish(response);\n }\n });\n }\n\n function delayedHideToast() {\n if (options.timeOut > 0 || options.extendedTimeOut > 0) {\n intervalId = setTimeout(hideToast, options.extendedTimeOut);\n progressBar.maxHideTime = parseFloat(options.extendedTimeOut);\n progressBar.hideEta = new Date().getTime() + progressBar.maxHideTime;\n }\n }\n\n function stickAround() {\n clearTimeout(intervalId);\n progressBar.hideEta = 0;\n $toastElement.stop(true, true)[options.showMethod](\n {duration: options.showDuration, easing: options.showEasing}\n );\n }\n\n function updateProgress() {\n var percentage = ((progressBar.hideEta - (new Date().getTime())) / progressBar.maxHideTime) * 100;\n $progressElement.width(percentage + '%');\n }\n }\n\n function getOptions() {\n return $.extend({}, getDefaults(), toastr.options);\n }\n\n function removeToast($toastElement) {\n if (!$container) { $container = getContainer(); }\n if ($toastElement.is(':visible')) {\n return;\n }\n $toastElement.remove();\n $toastElement = null;\n if ($container.children().length === 0) {\n $container.remove();\n previousToast = undefined;\n }\n }\n\n })();\n });\n}(typeof define === 'function' && define.amd ? define : function (deps, factory) {\n if (typeof module !== 'undefined' && module.exports) { //Node\n module.exports = factory(require('jquery'));\n } else {\n window['toastr'] = factory(window['jQuery']);\n }\n}));\n"],"sourceRoot":"/source/"} \ No newline at end of file diff --git a/node_modules/toastr/package/package/build/toastr.min.css b/node_modules/toastr/package/package/build/toastr.min.css new file mode 100644 index 0000000..64adc42 --- /dev/null +++ b/node_modules/toastr/package/package/build/toastr.min.css @@ -0,0 +1 @@ +.toast-title{font-weight:700}.toast-message{-ms-word-wrap:break-word;word-wrap:break-word}.toast-message a,.toast-message label{color:#fff}.toast-message a:hover{color:#ccc;text-decoration:none}.toast-close-button{position:relative;right:-.3em;top:-.3em;float:right;font-size:20px;font-weight:700;color:#fff;-webkit-text-shadow:0 1px 0 #fff;text-shadow:0 1px 0 #fff;opacity:.8;-ms-filter:alpha(Opacity=80);filter:alpha(opacity=80)}.toast-close-button:focus,.toast-close-button:hover{color:#000;text-decoration:none;cursor:pointer;opacity:.4;-ms-filter:alpha(Opacity=40);filter:alpha(opacity=40)}button.toast-close-button{padding:0;cursor:pointer;background:0 0;border:0;-webkit-appearance:none}.toast-top-center{top:0;right:0;width:100%}.toast-bottom-center{bottom:0;right:0;width:100%}.toast-top-full-width{top:0;right:0;width:100%}.toast-bottom-full-width{bottom:0;right:0;width:100%}.toast-top-left{top:12px;left:12px}.toast-top-right{top:12px;right:12px}.toast-bottom-right{right:12px;bottom:12px}.toast-bottom-left{bottom:12px;left:12px}#toast-container{position:fixed;z-index:999999}#toast-container *{-moz-box-sizing:border-box;-webkit-box-sizing:border-box;box-sizing:border-box}#toast-container>div{position:relative;overflow:hidden;margin:0 0 6px;padding:15px 15px 15px 50px;width:300px;-moz-border-radius:3px;-webkit-border-radius:3px;border-radius:3px;background-position:15px center;background-repeat:no-repeat;-moz-box-shadow:0 0 12px #999;-webkit-box-shadow:0 0 12px #999;box-shadow:0 0 12px #999;color:#fff;opacity:.8;-ms-filter:alpha(Opacity=80);filter:alpha(opacity=80)}#toast-container>:hover{-moz-box-shadow:0 0 12px #000;-webkit-box-shadow:0 0 12px #000;box-shadow:0 0 12px #000;opacity:1;-ms-filter:alpha(Opacity=100);filter:alpha(opacity=100);cursor:pointer}#toast-container>.toast-info{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGwSURBVEhLtZa9SgNBEMc9sUxxRcoUKSzSWIhXpFMhhYWFhaBg4yPYiWCXZxBLERsLRS3EQkEfwCKdjWJAwSKCgoKCcudv4O5YLrt7EzgXhiU3/4+b2ckmwVjJSpKkQ6wAi4gwhT+z3wRBcEz0yjSseUTrcRyfsHsXmD0AmbHOC9Ii8VImnuXBPglHpQ5wwSVM7sNnTG7Za4JwDdCjxyAiH3nyA2mtaTJufiDZ5dCaqlItILh1NHatfN5skvjx9Z38m69CgzuXmZgVrPIGE763Jx9qKsRozWYw6xOHdER+nn2KkO+Bb+UV5CBN6WC6QtBgbRVozrahAbmm6HtUsgtPC19tFdxXZYBOfkbmFJ1VaHA1VAHjd0pp70oTZzvR+EVrx2Ygfdsq6eu55BHYR8hlcki+n+kERUFG8BrA0BwjeAv2M8WLQBtcy+SD6fNsmnB3AlBLrgTtVW1c2QN4bVWLATaIS60J2Du5y1TiJgjSBvFVZgTmwCU+dAZFoPxGEEs8nyHC9Bwe2GvEJv2WXZb0vjdyFT4Cxk3e/kIqlOGoVLwwPevpYHT+00T+hWwXDf4AJAOUqWcDhbwAAAAASUVORK5CYII=)!important}#toast-container>.toast-error{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAHOSURBVEhLrZa/SgNBEMZzh0WKCClSCKaIYOED+AAKeQQLG8HWztLCImBrYadgIdY+gIKNYkBFSwu7CAoqCgkkoGBI/E28PdbLZmeDLgzZzcx83/zZ2SSXC1j9fr+I1Hq93g2yxH4iwM1vkoBWAdxCmpzTxfkN2RcyZNaHFIkSo10+8kgxkXIURV5HGxTmFuc75B2RfQkpxHG8aAgaAFa0tAHqYFfQ7Iwe2yhODk8+J4C7yAoRTWI3w/4klGRgR4lO7Rpn9+gvMyWp+uxFh8+H+ARlgN1nJuJuQAYvNkEnwGFck18Er4q3egEc/oO+mhLdKgRyhdNFiacC0rlOCbhNVz4H9FnAYgDBvU3QIioZlJFLJtsoHYRDfiZoUyIxqCtRpVlANq0EU4dApjrtgezPFad5S19Wgjkc0hNVnuF4HjVA6C7QrSIbylB+oZe3aHgBsqlNqKYH48jXyJKMuAbiyVJ8KzaB3eRc0pg9VwQ4niFryI68qiOi3AbjwdsfnAtk0bCjTLJKr6mrD9g8iq/S/B81hguOMlQTnVyG40wAcjnmgsCNESDrjme7wfftP4P7SP4N3CJZdvzoNyGq2c/HWOXJGsvVg+RA/k2MC/wN6I2YA2Pt8GkAAAAASUVORK5CYII=)!important}#toast-container>.toast-success{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAADsSURBVEhLY2AYBfQMgf///3P8+/evAIgvA/FsIF+BavYDDWMBGroaSMMBiE8VC7AZDrIFaMFnii3AZTjUgsUUWUDA8OdAH6iQbQEhw4HyGsPEcKBXBIC4ARhex4G4BsjmweU1soIFaGg/WtoFZRIZdEvIMhxkCCjXIVsATV6gFGACs4Rsw0EGgIIH3QJYJgHSARQZDrWAB+jawzgs+Q2UO49D7jnRSRGoEFRILcdmEMWGI0cm0JJ2QpYA1RDvcmzJEWhABhD/pqrL0S0CWuABKgnRki9lLseS7g2AlqwHWQSKH4oKLrILpRGhEQCw2LiRUIa4lwAAAABJRU5ErkJggg==)!important}#toast-container>.toast-warning{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGYSURBVEhL5ZSvTsNQFMbXZGICMYGYmJhAQIJAICYQPAACiSDB8AiICQQJT4CqQEwgJvYASAQCiZiYmJhAIBATCARJy+9rTsldd8sKu1M0+dLb057v6/lbq/2rK0mS/TRNj9cWNAKPYIJII7gIxCcQ51cvqID+GIEX8ASG4B1bK5gIZFeQfoJdEXOfgX4QAQg7kH2A65yQ87lyxb27sggkAzAuFhbbg1K2kgCkB1bVwyIR9m2L7PRPIhDUIXgGtyKw575yz3lTNs6X4JXnjV+LKM/m3MydnTbtOKIjtz6VhCBq4vSm3ncdrD2lk0VgUXSVKjVDJXJzijW1RQdsU7F77He8u68koNZTz8Oz5yGa6J3H3lZ0xYgXBK2QymlWWA+RWnYhskLBv2vmE+hBMCtbA7KX5drWyRT/2JsqZ2IvfB9Y4bWDNMFbJRFmC9E74SoS0CqulwjkC0+5bpcV1CZ8NMej4pjy0U+doDQsGyo1hzVJttIjhQ7GnBtRFN1UarUlH8F3xict+HY07rEzoUGPlWcjRFRr4/gChZgc3ZL2d8oAAAAASUVORK5CYII=)!important}#toast-container.toast-bottom-center>div,#toast-container.toast-top-center>div{width:300px;margin:auto}#toast-container.toast-bottom-full-width>div,#toast-container.toast-top-full-width>div{width:96%;margin:auto}.toast{background-color:#030303}.toast-success{background-color:#51a351}.toast-error{background-color:#bd362f}.toast-info{background-color:#2f96b4}.toast-warning{background-color:#f89406}.toast-progress{position:absolute;left:0;bottom:0;height:4px;background-color:#000;opacity:.4;-ms-filter:alpha(Opacity=40);filter:alpha(opacity=40)}@media all and (max-width:240px){#toast-container>div{padding:8px 8px 8px 50px;width:11em}#toast-container .toast-close-button{right:-.2em;top:-.2em}}@media all and (min-width:241px) and (max-width:480px){#toast-container>div{padding:8px 8px 8px 50px;width:18em}#toast-container .toast-close-button{right:-.2em;top:-.2em}}@media all and (min-width:481px) and (max-width:768px){#toast-container>div{padding:15px 15px 15px 50px;width:25em}} diff --git a/node_modules/toastr/package/package/build/toastr.min.js b/node_modules/toastr/package/package/build/toastr.min.js new file mode 100644 index 0000000..ab9c66c --- /dev/null +++ b/node_modules/toastr/package/package/build/toastr.min.js @@ -0,0 +1,2 @@ +!function(e){e(["jquery"],function(e){return function(){function t(e,t,n){return f({type:O.error,iconClass:g().iconClasses.error,message:e,optionsOverride:n,title:t})}function n(t,n){return t||(t=g()),v=e("#"+t.containerId),v.length?v:(n&&(v=c(t)),v)}function i(e,t,n){return f({type:O.info,iconClass:g().iconClasses.info,message:e,optionsOverride:n,title:t})}function o(e){w=e}function s(e,t,n){return f({type:O.success,iconClass:g().iconClasses.success,message:e,optionsOverride:n,title:t})}function a(e,t,n){return f({type:O.warning,iconClass:g().iconClasses.warning,message:e,optionsOverride:n,title:t})}function r(e){var t=g();v||n(t),l(e,t)||u(t)}function d(t){var i=g();return v||n(i),t&&0===e(":focus",t).length?void h(t):void(v.children().length&&v.remove())}function u(t){for(var n=v.children(),i=n.length-1;i>=0;i--)l(e(n[i]),t)}function l(t,n){return t&&0===e(":focus",t).length?(t[n.hideMethod]({duration:n.hideDuration,easing:n.hideEasing,complete:function(){h(t)}}),!0):!1}function c(t){return v=e("
").attr("id",t.containerId).addClass(t.positionClass).attr("aria-live","polite").attr("role","alert"),v.appendTo(e(t.target)),v}function p(){return{tapToDismiss:!0,toastClass:"toast",containerId:"toast-container",debug:!1,showMethod:"fadeIn",showDuration:300,showEasing:"swing",onShown:void 0,hideMethod:"fadeOut",hideDuration:1e3,hideEasing:"swing",onHidden:void 0,extendedTimeOut:1e3,iconClasses:{error:"toast-error",info:"toast-info",success:"toast-success",warning:"toast-warning"},iconClass:"toast-info",positionClass:"toast-top-right",timeOut:5e3,titleClass:"toast-title",messageClass:"toast-message",target:"body",closeHtml:'',newestOnTop:!0,preventDuplicates:!1,progressBar:!1}}function m(e){w&&w(e)}function f(t){function i(t){return!e(":focus",l).length||t?(clearTimeout(O.intervalId),l[r.hideMethod]({duration:r.hideDuration,easing:r.hideEasing,complete:function(){h(l),r.onHidden&&"hidden"!==b.state&&r.onHidden(),b.state="hidden",b.endTime=new Date,m(b)}})):void 0}function o(){(r.timeOut>0||r.extendedTimeOut>0)&&(u=setTimeout(i,r.extendedTimeOut),O.maxHideTime=parseFloat(r.extendedTimeOut),O.hideEta=(new Date).getTime()+O.maxHideTime)}function s(){clearTimeout(u),O.hideEta=0,l.stop(!0,!0)[r.showMethod]({duration:r.showDuration,easing:r.showEasing})}function a(){var e=(O.hideEta-(new Date).getTime())/O.maxHideTime*100;f.width(e+"%")}var r=g(),d=t.iconClass||r.iconClass;if("undefined"!=typeof t.optionsOverride&&(r=e.extend(r,t.optionsOverride),d=t.optionsOverride.iconClass||d),r.preventDuplicates){if(t.message===C)return;C=t.message}T++,v=n(r,!0);var u=null,l=e("
"),c=e("
"),p=e("
"),f=e("
"),w=e(r.closeHtml),O={intervalId:null,hideEta:null,maxHideTime:null},b={toastId:T,state:"visible",startTime:new Date,options:r,map:t};return t.iconClass&&l.addClass(r.toastClass).addClass(d),t.title&&(c.append(t.title).addClass(r.titleClass),l.append(c)),t.message&&(p.append(t.message).addClass(r.messageClass),l.append(p)),r.closeButton&&(w.addClass("toast-close-button").attr("role","button"),l.prepend(w)),r.progressBar&&(f.addClass("toast-progress"),l.prepend(f)),l.hide(),r.newestOnTop?v.prepend(l):v.append(l),l[r.showMethod]({duration:r.showDuration,easing:r.showEasing,complete:r.onShown}),r.timeOut>0&&(u=setTimeout(i,r.timeOut),O.maxHideTime=parseFloat(r.timeOut),O.hideEta=(new Date).getTime()+O.maxHideTime,r.progressBar&&(O.intervalId=setInterval(a,10))),l.hover(s,o),!r.onclick&&r.tapToDismiss&&l.click(i),r.closeButton&&w&&w.click(function(e){e.stopPropagation?e.stopPropagation():void 0!==e.cancelBubble&&e.cancelBubble!==!0&&(e.cancelBubble=!0),i(!0)}),r.onclick&&l.click(function(){r.onclick(),i()}),m(b),r.debug&&console&&console.log(b),l}function g(){return e.extend({},p(),b.options)}function h(e){v||(v=n()),e.is(":visible")||(e.remove(),e=null,0===v.children().length&&(v.remove(),C=void 0))}var v,w,C,T=0,O={error:"error",info:"info",success:"success",warning:"warning"},b={clear:r,remove:d,error:t,getContainer:n,info:i,options:{},subscribe:o,success:s,version:"2.1.0",warning:a};return b}()})}("function"==typeof define&&define.amd?define:function(e,t){"undefined"!=typeof module&&module.exports?module.exports=t(require("jquery")):window.toastr=t(window.jQuery)}); +//# sourceMappingURL=toastr.js.map diff --git a/node_modules/toastr/package/package/demo.html b/node_modules/toastr/package/package/demo.html new file mode 100644 index 0000000..816f097 --- /dev/null +++ b/node_modules/toastr/package/package/demo.html @@ -0,0 +1,325 @@ + + + + + toastr examples + + + + + + + +
+

toastr

+ +
+
+
+
+
+ + + + +
+
+
+
+ +
+
+ +
+
+ +
+
+ +
+
+ +
+
+ +
+
+ +
+
+
+ +
+
+
+ + + + + +
+
+
+
+ + + + + + + + + +
+
+
+ +
+
+
+ + + + + + + + + + + +
+
+
+ +
+
+
+ + + + + + + + + + + +
+
+
+
+ +
+ + + +
+ +
+

+        
+
+
+ +
+ + + + + + + diff --git a/node_modules/toastr/package/package/gulpfile.js b/node_modules/toastr/package/package/gulpfile.js new file mode 100644 index 0000000..8b337ed --- /dev/null +++ b/node_modules/toastr/package/package/gulpfile.js @@ -0,0 +1,198 @@ +/* jshint node:true, camelcase:false */ +var gulp = require('gulp'); +var del = require('del'); +var glob = require('glob'); +var karma = require('karma').server; +var merge = require('merge-stream'); +var plato = require('plato'); +var plug = require('gulp-load-plugins')(); + +var paths = { + js: './toastr.js', + css: './toastr.css', + report: './report', + build: './build' +}; + +var colors = plug.util.colors; +var log = plug.util.log; + +/** + * List the available gulp tasks + */ +gulp.task('help', plug.taskListing); + +/** + * Lint the code, create coverage report, and a visualizer + * @return {Stream} + */ +gulp.task('analyze', function() { + log('Analyzing source with JSHint, JSCS, and Plato'); + + var jshint = analyzejshint([paths.js]); + var jscs = analyzejscs([paths.js]); + + startPlatoVisualizer(); + + return merge(jshint, jscs); +}); + +/** + * Minify and bundle the app's JavaScript + * @return {Stream} + */ +gulp.task('js', function() { + log('Bundling, minifying, and copying the app\'s JavaScript'); + + return gulp + .src(paths.js) + .pipe(plug.sourcemaps.init()) + .pipe(plug.bytediff.start()) + .pipe(plug.uglify({})) + .pipe(plug.bytediff.stop(bytediffFormatter)) + .pipe(plug.sourcemaps.write('.')) + .pipe(plug.rename(function(path) { + if (path.extname === '.js') { + path.basename += '.min'; + } + })) + .pipe(gulp.dest(paths.build)); +}); + +/** + * Minify and bundle the CSS + * @return {Stream} + */ +gulp.task('css', function() { + log('Bundling, minifying, and copying the app\'s CSS'); + + return gulp.src(paths.css) +// .pipe(plug.autoprefixer('last 2 version', '> 5%')) + .pipe(plug.bytediff.start()) + .pipe(plug.minifyCss({})) + .pipe(plug.bytediff.stop(bytediffFormatter)) + .pipe(plug.rename('toastr.min.css')) + .pipe(gulp.dest(paths.build)); +}); + +/** + * Build js and css + */ +gulp.task('default', ['js', 'css'], function() { + log('Analyze, Build CSS and JS'); +}); + +/** + * Remove all files from the build folder + * One way to run clean before all tasks is to run + * from the cmd line: gulp clean && gulp build + * @return {Stream} + */ +gulp.task('clean', function(cb) { + log('Cleaning: ' + plug.util.colors.blue(paths.report)); + log('Cleaning: ' + plug.util.colors.blue(paths.build)); + + var delPaths = [paths.build, paths.report]; + del(delPaths, cb); +}); + +/** + * Run specs once and exit + * To start servers and run midway specs as well: + * gulp test --startServers + * @return {Stream} + */ +gulp.task('test', function(done) { + startTests(true /*singleRun*/ , done); +}); + +//////////////// + +/** + * Execute JSHint on given source files + * @param {Array} sources + * @param {String} overrideRcFile + * @return {Stream} + */ +function analyzejshint(sources, overrideRcFile) { + var jshintrcFile = overrideRcFile || './.jshintrc'; + log('Running JSHint'); + return gulp + .src(sources) + .pipe(plug.jshint(jshintrcFile)) + .pipe(plug.jshint.reporter('jshint-stylish')); +} + +/** + * Execute JSCS on given source files + * @param {Array} sources + * @return {Stream} + */ +function analyzejscs(sources) { + log('Running JSCS'); + return gulp + .src(sources) + .pipe(plug.jscs('./.jscsrc')); +} + +/** + * Start Plato inspector and visualizer + */ +function startPlatoVisualizer() { + log('Running Plato'); + + var files = glob.sync('toastr.js'); + + var options = { + title: 'Plato Inspections Report' + }; + var outputDir = './report/plato'; + + plato.inspect(files, outputDir, options, platoCompleted); + + function platoCompleted(report) { + var overview = plato.getOverviewReport(report); + log(overview.summary); + } +} + +/** + * Start the tests using karma. + * @param {boolean} singleRun - True means run once and end (CI), or keep running (dev) + * @param {Function} done - Callback to fire when karma is done + * @return {undefined} + */ +function startTests(singleRun, done) { + karma.start({ + configFile: __dirname + '/karma.conf.js', + singleRun: !!singleRun + }, karmaCompleted); + + //////////////// + + function karmaCompleted() { + done(); + } +} + +/** + * Formatter for bytediff to display the size changes after processing + * @param {Object} data - byte data + * @return {String} Difference in bytes, formatted + */ +function bytediffFormatter(data) { + var difference = (data.savings > 0) ? ' smaller.' : ' larger.'; + return data.fileName + ' went from ' + + (data.startSize / 1000).toFixed(2) + ' kB to ' + (data.endSize / 1000).toFixed(2) + ' kB' + + ' and is ' + formatPercent(1 - data.percent, 2) + '%' + difference; +} + +/** + * Format a number as a percentage + * @param {Number} num Number to format as a percent + * @param {Number} precision Precision of the decimal + * @return {Number} Formatted perentage + */ +function formatPercent(num, precision) { + return (num * 100).toFixed(precision); +} diff --git a/node_modules/toastr/package/package/karma.conf.js b/node_modules/toastr/package/package/karma.conf.js new file mode 100644 index 0000000..c1cfdfc --- /dev/null +++ b/node_modules/toastr/package/package/karma.conf.js @@ -0,0 +1,79 @@ +// Karma configuration +// Generated on Thu Sep 04 2014 07:41:43 GMT-0400 (EDT) + +module.exports = function(config) { + config.set({ + + // base path that will be used to resolve all patterns (eg. files, exclude) + basePath: '', + + + // frameworks to use + // available frameworks: https://npmjs.org/browse/keyword/karma-adapter + frameworks: ['qunit'], + +// plugins: ['karma-qunit', 'karma-coverage', 'phantomjs', 'karma-phantomjs-launcher'], + + + // list of files / patterns to load in the browser + files: [ +// 'http://code.jquery.com/jquery.js', + 'node_modules/jquery/dist/jquery.min.js', + 'toastr.css', + 'toastr.js', + 'node_modules/qunitjs/qunit/qunit.js', + 'tests/unit/qunit-helper.js', + //'tests/unit/x.js' + 'tests/unit/toastr-tests.js' + ], + + + // list of files to exclude + exclude: [ + ], + + + // preprocess matching files before serving them to the browser + // available preprocessors: https://npmjs.org/browse/keyword/karma-preprocessor + preprocessors: { + 'toastr.js': 'coverage' + }, + + + // test results reporter to use + // possible values: 'dots', 'progress' + // available reporters: https://npmjs.org/browse/keyword/karma-reporter + reporters: ['progress', 'coverage'], + + coverageReporter: { + type: 'lcov', + dir: 'tests/coverage' + }, + + // web server port + port: 9876, + + + // enable / disable colors in the output (reporters and logs) + colors: true, + + + // level of logging + // possible values: config.LOG_DISABLE || config.LOG_ERROR || config.LOG_WARN || config.LOG_INFO || config.LOG_DEBUG + logLevel: config.LOG_INFO, + + + // enable / disable watching file and executing tests whenever any file changes + autoWatch: false, + + + // start these browsers + // available browser launchers: https://npmjs.org/browse/keyword/karma-launcher + browsers: ['PhantomJS'], + + + // Continuous Integration mode + // if true, Karma captures browsers, runs the tests and exits + singleRun: true + }); +}; diff --git a/node_modules/toastr/package/package/nuget/content/content/toastr.css b/node_modules/toastr/package/package/nuget/content/content/toastr.css new file mode 100644 index 0000000..d86235a --- /dev/null +++ b/node_modules/toastr/package/package/nuget/content/content/toastr.css @@ -0,0 +1,180 @@ +/* + * Toastr + * Copyright 2012-2014 John Papa and Hans Fjällemark. + * All Rights Reserved. + * Use, reproduction, distribution, and modification of this code is subject to the terms and + * conditions of the MIT license, available at http://www.opensource.org/licenses/mit-license.php + * + * Author: John Papa and Hans Fjällemark + * Project: https://github.com/CodeSeven/toastr + */ +.toast-title { + font-weight: bold; +} +.toast-message { + -ms-word-wrap: break-word; + word-wrap: break-word; +} +.toast-message a, +.toast-message label { + color: #ffffff; +} +.toast-message a:hover { + color: #cccccc; + text-decoration: none; +} +.toast-close-button { + position: relative; + right: -0.3em; + top: -0.3em; + float: right; + font-size: 20px; + font-weight: bold; + color: #ffffff; + -webkit-text-shadow: 0 1px 0 #ffffff; + text-shadow: 0 1px 0 #ffffff; + opacity: 0.8; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=80); + filter: alpha(opacity=80); +} +.toast-close-button:hover, +.toast-close-button:focus { + color: #000000; + text-decoration: none; + cursor: pointer; + opacity: 0.4; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=40); + filter: alpha(opacity=40); +} +/*Additional properties for button version + iOS requires the button element instead of an anchor tag. + If you want the anchor version, it requires `href="#"`.*/ +button.toast-close-button { + padding: 0; + cursor: pointer; + background: transparent; + border: 0; + -webkit-appearance: none; +} +.toast-top-full-width { + top: 0; + right: 0; + width: 100%; +} +.toast-bottom-full-width { + bottom: 0; + right: 0; + width: 100%; +} +.toast-top-left { + top: 12px; + left: 12px; +} +.toast-top-right { + top: 12px; + right: 12px; +} +.toast-bottom-right { + right: 12px; + bottom: 12px; +} +.toast-bottom-left { + bottom: 12px; + left: 12px; +} +#toast-container { + position: fixed; + z-index: 999999; + /*overrides*/ + +} +#toast-container * { + -moz-box-sizing: border-box; + -webkit-box-sizing: border-box; + box-sizing: border-box; +} +#toast-container > div { + margin: 0 0 6px; + padding: 15px 15px 15px 50px; + width: 300px; + -moz-border-radius: 3px 3px 3px 3px; + -webkit-border-radius: 3px 3px 3px 3px; + border-radius: 3px 3px 3px 3px; + background-position: 15px center; + background-repeat: no-repeat; + -moz-box-shadow: 0 0 12px #999999; + -webkit-box-shadow: 0 0 12px #999999; + box-shadow: 0 0 12px #999999; + color: #ffffff; + opacity: 0.8; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=80); + filter: alpha(opacity=80); +} +#toast-container > :hover { + -moz-box-shadow: 0 0 12px #000000; + -webkit-box-shadow: 0 0 12px #000000; + box-shadow: 0 0 12px #000000; + opacity: 1; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=100); + filter: alpha(opacity=100); + cursor: pointer; +} +#toast-container > .toast-info { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGwSURBVEhLtZa9SgNBEMc9sUxxRcoUKSzSWIhXpFMhhYWFhaBg4yPYiWCXZxBLERsLRS3EQkEfwCKdjWJAwSKCgoKCcudv4O5YLrt7EzgXhiU3/4+b2ckmwVjJSpKkQ6wAi4gwhT+z3wRBcEz0yjSseUTrcRyfsHsXmD0AmbHOC9Ii8VImnuXBPglHpQ5wwSVM7sNnTG7Za4JwDdCjxyAiH3nyA2mtaTJufiDZ5dCaqlItILh1NHatfN5skvjx9Z38m69CgzuXmZgVrPIGE763Jx9qKsRozWYw6xOHdER+nn2KkO+Bb+UV5CBN6WC6QtBgbRVozrahAbmm6HtUsgtPC19tFdxXZYBOfkbmFJ1VaHA1VAHjd0pp70oTZzvR+EVrx2Ygfdsq6eu55BHYR8hlcki+n+kERUFG8BrA0BwjeAv2M8WLQBtcy+SD6fNsmnB3AlBLrgTtVW1c2QN4bVWLATaIS60J2Du5y1TiJgjSBvFVZgTmwCU+dAZFoPxGEEs8nyHC9Bwe2GvEJv2WXZb0vjdyFT4Cxk3e/kIqlOGoVLwwPevpYHT+00T+hWwXDf4AJAOUqWcDhbwAAAAASUVORK5CYII=") !important; +} +#toast-container > .toast-error { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAHOSURBVEhLrZa/SgNBEMZzh0WKCClSCKaIYOED+AAKeQQLG8HWztLCImBrYadgIdY+gIKNYkBFSwu7CAoqCgkkoGBI/E28PdbLZmeDLgzZzcx83/zZ2SSXC1j9fr+I1Hq93g2yxH4iwM1vkoBWAdxCmpzTxfkN2RcyZNaHFIkSo10+8kgxkXIURV5HGxTmFuc75B2RfQkpxHG8aAgaAFa0tAHqYFfQ7Iwe2yhODk8+J4C7yAoRTWI3w/4klGRgR4lO7Rpn9+gvMyWp+uxFh8+H+ARlgN1nJuJuQAYvNkEnwGFck18Er4q3egEc/oO+mhLdKgRyhdNFiacC0rlOCbhNVz4H9FnAYgDBvU3QIioZlJFLJtsoHYRDfiZoUyIxqCtRpVlANq0EU4dApjrtgezPFad5S19Wgjkc0hNVnuF4HjVA6C7QrSIbylB+oZe3aHgBsqlNqKYH48jXyJKMuAbiyVJ8KzaB3eRc0pg9VwQ4niFryI68qiOi3AbjwdsfnAtk0bCjTLJKr6mrD9g8iq/S/B81hguOMlQTnVyG40wAcjnmgsCNESDrjme7wfftP4P7SP4N3CJZdvzoNyGq2c/HWOXJGsvVg+RA/k2MC/wN6I2YA2Pt8GkAAAAASUVORK5CYII=") !important; +} +#toast-container > .toast-success { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAADsSURBVEhLY2AYBfQMgf///3P8+/evAIgvA/FsIF+BavYDDWMBGroaSMMBiE8VC7AZDrIFaMFnii3AZTjUgsUUWUDA8OdAH6iQbQEhw4HyGsPEcKBXBIC4ARhex4G4BsjmweU1soIFaGg/WtoFZRIZdEvIMhxkCCjXIVsATV6gFGACs4Rsw0EGgIIH3QJYJgHSARQZDrWAB+jawzgs+Q2UO49D7jnRSRGoEFRILcdmEMWGI0cm0JJ2QpYA1RDvcmzJEWhABhD/pqrL0S0CWuABKgnRki9lLseS7g2AlqwHWQSKH4oKLrILpRGhEQCw2LiRUIa4lwAAAABJRU5ErkJggg==") !important; +} +#toast-container > .toast-warning { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGYSURBVEhL5ZSvTsNQFMbXZGICMYGYmJhAQIJAICYQPAACiSDB8AiICQQJT4CqQEwgJvYASAQCiZiYmJhAIBATCARJy+9rTsldd8sKu1M0+dLb057v6/lbq/2rK0mS/TRNj9cWNAKPYIJII7gIxCcQ51cvqID+GIEX8ASG4B1bK5gIZFeQfoJdEXOfgX4QAQg7kH2A65yQ87lyxb27sggkAzAuFhbbg1K2kgCkB1bVwyIR9m2L7PRPIhDUIXgGtyKw575yz3lTNs6X4JXnjV+LKM/m3MydnTbtOKIjtz6VhCBq4vSm3ncdrD2lk0VgUXSVKjVDJXJzijW1RQdsU7F77He8u68koNZTz8Oz5yGa6J3H3lZ0xYgXBK2QymlWWA+RWnYhskLBv2vmE+hBMCtbA7KX5drWyRT/2JsqZ2IvfB9Y4bWDNMFbJRFmC9E74SoS0CqulwjkC0+5bpcV1CZ8NMej4pjy0U+doDQsGyo1hzVJttIjhQ7GnBtRFN1UarUlH8F3xict+HY07rEzoUGPlWcjRFRr4/gChZgc3ZL2d8oAAAAASUVORK5CYII=") !important; +} +#toast-container.toast-top-full-width > div, +#toast-container.toast-bottom-full-width > div { + width: 96%; + margin: auto; +} +.toast { + background-color: #030303; +} +.toast-success { + background-color: #51a351; +} +.toast-error { + background-color: #bd362f; +} +.toast-info { + background-color: #2f96b4; +} +.toast-warning { + background-color: #f89406; +} +/*Responsive Design*/ +@media all and (max-width: 240px) { + #toast-container > div { + padding: 8px 8px 8px 50px; + width: 11em; + } + #toast-container .toast-close-button { + right: -0.2em; + top: -0.2em; + } +} +@media all and (min-width: 241px) and (max-width: 480px) { + #toast-container > div { + padding: 8px 8px 8px 50px; + width: 18em; + } + #toast-container .toast-close-button { + right: -0.2em; + top: -0.2em; + } +} +@media all and (min-width: 481px) and (max-width: 768px) { + #toast-container > div { + padding: 15px 15px 15px 50px; + width: 25em; + } +} diff --git a/node_modules/toastr/package/package/nuget/content/content/toastr.less b/node_modules/toastr/package/package/nuget/content/content/toastr.less new file mode 100644 index 0000000..146fabe --- /dev/null +++ b/node_modules/toastr/package/package/nuget/content/content/toastr.less @@ -0,0 +1,232 @@ +// Mix-ins +.borderRadius(@radius) { + -moz-border-radius: @radius; + -webkit-border-radius: @radius; + border-radius: @radius; +} + +.boxShadow(@boxShadow) { + -moz-box-shadow: @boxShadow; + -webkit-box-shadow: @boxShadow; + box-shadow: @boxShadow; +} + +.opacity(@opacity) { + @opacityPercent: @opacity * 100; + opacity: @opacity; + -ms-filter: ~"progid:DXImageTransform.Microsoft.Alpha(Opacity=@{opacityPercent})"; + filter: ~"alpha(opacity=@{opacityPercent})"; +} + +.wordWrap(@wordWrap: break-word) { + -ms-word-wrap: @wordWrap; + word-wrap: @wordWrap; +} + +// Variables +@black: #000000; +@grey: #999999; +@light-grey: #CCCCCC; +@white: #FFFFFF; +@near-black: #030303; +@green: #51A351; +@red: #BD362F; +@blue: #2F96B4; +@orange: #F89406; + +// Styles +.toast-title { + font-weight: bold; +} + +.toast-message { + .wordWrap(); + + a, + label { + color: @white; + } + + a:hover { + color: @light-grey; + text-decoration: none; + } +} + +.toast-close-button { + position: relative; + right: -0.3em; + top: -0.3em; + float: right; + font-size: 20px; + font-weight: bold; + color: @white; + -webkit-text-shadow: 0 1px 0 rgba(255,255,255,1); + text-shadow: 0 1px 0 rgba(255,255,255,1); + .opacity(0.8); + + &:hover, + &:focus { + color: @black; + text-decoration: none; + cursor: pointer; + .opacity(0.4); + } +} + +/*Additional properties for button version + iOS requires the button element instead of an anchor tag. + If you want the anchor version, it requires `href="#"`.*/ +button.toast-close-button { + padding: 0; + cursor: pointer; + background: transparent; + border: 0; + -webkit-appearance: none; +} + +//#endregion + +.toast-top-full-width { + top: 0; + right: 0; + width: 100%; +} + +.toast-bottom-full-width { + bottom: 0; + right: 0; + width: 100%; +} + +.toast-top-left { + top: 12px; + left: 12px; +} + +.toast-top-right { + top: 12px; + right: 12px; +} + +.toast-bottom-right { + right: 12px; + bottom: 12px; +} + +.toast-bottom-left { + bottom: 12px; + left: 12px; +} + +#toast-container { + position: fixed; + z-index: 999999; + + * { + -moz-box-sizing: border-box; + -webkit-box-sizing: border-box; + box-sizing: border-box; + } + + > div { + margin: 0 0 6px; + padding: 15px 15px 15px 50px; + width: 300px; + .borderRadius(3px 3px 3px 3px); + background-position: 15px center; + background-repeat: no-repeat; + .boxShadow(0 0 12px @grey); + color: @white; + .opacity(0.8); + } + + > :hover { + .boxShadow(0 0 12px @black); + .opacity(1); + cursor: pointer; + } + + > .toast-info { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGwSURBVEhLtZa9SgNBEMc9sUxxRcoUKSzSWIhXpFMhhYWFhaBg4yPYiWCXZxBLERsLRS3EQkEfwCKdjWJAwSKCgoKCcudv4O5YLrt7EzgXhiU3/4+b2ckmwVjJSpKkQ6wAi4gwhT+z3wRBcEz0yjSseUTrcRyfsHsXmD0AmbHOC9Ii8VImnuXBPglHpQ5wwSVM7sNnTG7Za4JwDdCjxyAiH3nyA2mtaTJufiDZ5dCaqlItILh1NHatfN5skvjx9Z38m69CgzuXmZgVrPIGE763Jx9qKsRozWYw6xOHdER+nn2KkO+Bb+UV5CBN6WC6QtBgbRVozrahAbmm6HtUsgtPC19tFdxXZYBOfkbmFJ1VaHA1VAHjd0pp70oTZzvR+EVrx2Ygfdsq6eu55BHYR8hlcki+n+kERUFG8BrA0BwjeAv2M8WLQBtcy+SD6fNsmnB3AlBLrgTtVW1c2QN4bVWLATaIS60J2Du5y1TiJgjSBvFVZgTmwCU+dAZFoPxGEEs8nyHC9Bwe2GvEJv2WXZb0vjdyFT4Cxk3e/kIqlOGoVLwwPevpYHT+00T+hWwXDf4AJAOUqWcDhbwAAAAASUVORK5CYII=") !important; + } + + > .toast-error { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAHOSURBVEhLrZa/SgNBEMZzh0WKCClSCKaIYOED+AAKeQQLG8HWztLCImBrYadgIdY+gIKNYkBFSwu7CAoqCgkkoGBI/E28PdbLZmeDLgzZzcx83/zZ2SSXC1j9fr+I1Hq93g2yxH4iwM1vkoBWAdxCmpzTxfkN2RcyZNaHFIkSo10+8kgxkXIURV5HGxTmFuc75B2RfQkpxHG8aAgaAFa0tAHqYFfQ7Iwe2yhODk8+J4C7yAoRTWI3w/4klGRgR4lO7Rpn9+gvMyWp+uxFh8+H+ARlgN1nJuJuQAYvNkEnwGFck18Er4q3egEc/oO+mhLdKgRyhdNFiacC0rlOCbhNVz4H9FnAYgDBvU3QIioZlJFLJtsoHYRDfiZoUyIxqCtRpVlANq0EU4dApjrtgezPFad5S19Wgjkc0hNVnuF4HjVA6C7QrSIbylB+oZe3aHgBsqlNqKYH48jXyJKMuAbiyVJ8KzaB3eRc0pg9VwQ4niFryI68qiOi3AbjwdsfnAtk0bCjTLJKr6mrD9g8iq/S/B81hguOMlQTnVyG40wAcjnmgsCNESDrjme7wfftP4P7SP4N3CJZdvzoNyGq2c/HWOXJGsvVg+RA/k2MC/wN6I2YA2Pt8GkAAAAASUVORK5CYII=") !important; + } + + > .toast-success { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAADsSURBVEhLY2AYBfQMgf///3P8+/evAIgvA/FsIF+BavYDDWMBGroaSMMBiE8VC7AZDrIFaMFnii3AZTjUgsUUWUDA8OdAH6iQbQEhw4HyGsPEcKBXBIC4ARhex4G4BsjmweU1soIFaGg/WtoFZRIZdEvIMhxkCCjXIVsATV6gFGACs4Rsw0EGgIIH3QJYJgHSARQZDrWAB+jawzgs+Q2UO49D7jnRSRGoEFRILcdmEMWGI0cm0JJ2QpYA1RDvcmzJEWhABhD/pqrL0S0CWuABKgnRki9lLseS7g2AlqwHWQSKH4oKLrILpRGhEQCw2LiRUIa4lwAAAABJRU5ErkJggg==") !important; + } + + > .toast-warning { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGYSURBVEhL5ZSvTsNQFMbXZGICMYGYmJhAQIJAICYQPAACiSDB8AiICQQJT4CqQEwgJvYASAQCiZiYmJhAIBATCARJy+9rTsldd8sKu1M0+dLb057v6/lbq/2rK0mS/TRNj9cWNAKPYIJII7gIxCcQ51cvqID+GIEX8ASG4B1bK5gIZFeQfoJdEXOfgX4QAQg7kH2A65yQ87lyxb27sggkAzAuFhbbg1K2kgCkB1bVwyIR9m2L7PRPIhDUIXgGtyKw575yz3lTNs6X4JXnjV+LKM/m3MydnTbtOKIjtz6VhCBq4vSm3ncdrD2lk0VgUXSVKjVDJXJzijW1RQdsU7F77He8u68koNZTz8Oz5yGa6J3H3lZ0xYgXBK2QymlWWA+RWnYhskLBv2vmE+hBMCtbA7KX5drWyRT/2JsqZ2IvfB9Y4bWDNMFbJRFmC9E74SoS0CqulwjkC0+5bpcV1CZ8NMej4pjy0U+doDQsGyo1hzVJttIjhQ7GnBtRFN1UarUlH8F3xict+HY07rEzoUGPlWcjRFRr4/gChZgc3ZL2d8oAAAAASUVORK5CYII=") !important; + } + + /*overrides*/ + &.toast-top-full-width > div, + &.toast-bottom-full-width > div { + width: 96%; + margin: auto; + } +} + +.toast { + background-color: @near-black; +} + +.toast-success { + background-color: @green; +} + +.toast-error { + background-color: @red; +} + +.toast-info { + background-color: @blue; +} + +.toast-warning { + background-color: @orange; +} + +/*Responsive Design*/ + +@media all and (max-width: 240px) { + #toast-container { + + > div { + padding: 8px 8px 8px 50px; + width: 11em; + } + + & .toast-close-button { + right: -0.2em; + top: -0.2em; + } + } +} + +@media all and (min-width: 241px) and (max-width: 480px) { + #toast-container { + > div { + padding: 8px 8px 8px 50px; + width: 18em; + } + + & .toast-close-button { + right: -0.2em; + top: -0.2em; + } + } +} + +@media all and (min-width: 481px) and (max-width: 768px) { + #toast-container { + > div { + padding: 15px 15px 15px 50px; + width: 25em; + } + } +} \ No newline at end of file diff --git a/node_modules/toastr/package/package/nuget/content/content/toastr.min.css b/node_modules/toastr/package/package/nuget/content/content/toastr.min.css new file mode 100644 index 0000000..40975cb --- /dev/null +++ b/node_modules/toastr/package/package/nuget/content/content/toastr.min.css @@ -0,0 +1 @@ +.toast-title{font-weight:bold}.toast-message{-ms-word-wrap:break-word;word-wrap:break-word}.toast-message a,.toast-message label{color:#fff}.toast-message a:hover{color:#ccc;text-decoration:none}.toast-close-button{position:relative;right:-0.3em;top:-0.3em;float:right;font-size:20px;font-weight:bold;color:#fff;-webkit-text-shadow:0 1px 0 #fff;text-shadow:0 1px 0 #fff;opacity:.8;-ms-filter:alpha(opacity=80);filter:alpha(opacity=80)}.toast-close-button:hover,.toast-close-button:focus{color:#000;text-decoration:none;cursor:pointer;opacity:.4;-ms-filter:alpha(opacity=40);filter:alpha(opacity=40)}button.toast-close-button{padding:0;cursor:pointer;background:transparent;border:0;-webkit-appearance:none}.toast-top-full-width{top:0;right:0;width:100%}.toast-bottom-full-width{bottom:0;right:0;width:100%}.toast-top-left{top:12px;left:12px}.toast-top-right{top:12px;right:12px}.toast-bottom-right{right:12px;bottom:12px}.toast-bottom-left{bottom:12px;left:12px}#toast-container{position:fixed;z-index:999999}#toast-container *{-moz-box-sizing:border-box;-webkit-box-sizing:border-box;box-sizing:border-box}#toast-container>div{margin:0 0 6px;padding:15px 15px 15px 50px;width:300px;-moz-border-radius:3px 3px 3px 3px;-webkit-border-radius:3px 3px 3px 3px;border-radius:3px 3px 3px 3px;background-position:15px center;background-repeat:no-repeat;-moz-box-shadow:0 0 12px #999;-webkit-box-shadow:0 0 12px #999;box-shadow:0 0 12px #999;color:#fff;opacity:.8;-ms-filter:alpha(opacity=80);filter:alpha(opacity=80)}#toast-container>:hover{-moz-box-shadow:0 0 12px #000;-webkit-box-shadow:0 0 12px #000;box-shadow:0 0 12px #000;opacity:1;-ms-filter:alpha(opacity=100);filter:alpha(opacity=100);cursor:pointer}#toast-container>.toast-info{background-image:url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGwSURBVEhLtZa9SgNBEMc9sUxxRcoUKSzSWIhXpFMhhYWFhaBg4yPYiWCXZxBLERsLRS3EQkEfwCKdjWJAwSKCgoKCcudv4O5YLrt7EzgXhiU3/4+b2ckmwVjJSpKkQ6wAi4gwhT+z3wRBcEz0yjSseUTrcRyfsHsXmD0AmbHOC9Ii8VImnuXBPglHpQ5wwSVM7sNnTG7Za4JwDdCjxyAiH3nyA2mtaTJufiDZ5dCaqlItILh1NHatfN5skvjx9Z38m69CgzuXmZgVrPIGE763Jx9qKsRozWYw6xOHdER+nn2KkO+Bb+UV5CBN6WC6QtBgbRVozrahAbmm6HtUsgtPC19tFdxXZYBOfkbmFJ1VaHA1VAHjd0pp70oTZzvR+EVrx2Ygfdsq6eu55BHYR8hlcki+n+kERUFG8BrA0BwjeAv2M8WLQBtcy+SD6fNsmnB3AlBLrgTtVW1c2QN4bVWLATaIS60J2Du5y1TiJgjSBvFVZgTmwCU+dAZFoPxGEEs8nyHC9Bwe2GvEJv2WXZb0vjdyFT4Cxk3e/kIqlOGoVLwwPevpYHT+00T+hWwXDf4AJAOUqWcDhbwAAAAASUVORK5CYII=")!important}#toast-container>.toast-error{background-image:url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAHOSURBVEhLrZa/SgNBEMZzh0WKCClSCKaIYOED+AAKeQQLG8HWztLCImBrYadgIdY+gIKNYkBFSwu7CAoqCgkkoGBI/E28PdbLZmeDLgzZzcx83/zZ2SSXC1j9fr+I1Hq93g2yxH4iwM1vkoBWAdxCmpzTxfkN2RcyZNaHFIkSo10+8kgxkXIURV5HGxTmFuc75B2RfQkpxHG8aAgaAFa0tAHqYFfQ7Iwe2yhODk8+J4C7yAoRTWI3w/4klGRgR4lO7Rpn9+gvMyWp+uxFh8+H+ARlgN1nJuJuQAYvNkEnwGFck18Er4q3egEc/oO+mhLdKgRyhdNFiacC0rlOCbhNVz4H9FnAYgDBvU3QIioZlJFLJtsoHYRDfiZoUyIxqCtRpVlANq0EU4dApjrtgezPFad5S19Wgjkc0hNVnuF4HjVA6C7QrSIbylB+oZe3aHgBsqlNqKYH48jXyJKMuAbiyVJ8KzaB3eRc0pg9VwQ4niFryI68qiOi3AbjwdsfnAtk0bCjTLJKr6mrD9g8iq/S/B81hguOMlQTnVyG40wAcjnmgsCNESDrjme7wfftP4P7SP4N3CJZdvzoNyGq2c/HWOXJGsvVg+RA/k2MC/wN6I2YA2Pt8GkAAAAASUVORK5CYII=")!important}#toast-container>.toast-success{background-image:url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAADsSURBVEhLY2AYBfQMgf///3P8+/evAIgvA/FsIF+BavYDDWMBGroaSMMBiE8VC7AZDrIFaMFnii3AZTjUgsUUWUDA8OdAH6iQbQEhw4HyGsPEcKBXBIC4ARhex4G4BsjmweU1soIFaGg/WtoFZRIZdEvIMhxkCCjXIVsATV6gFGACs4Rsw0EGgIIH3QJYJgHSARQZDrWAB+jawzgs+Q2UO49D7jnRSRGoEFRILcdmEMWGI0cm0JJ2QpYA1RDvcmzJEWhABhD/pqrL0S0CWuABKgnRki9lLseS7g2AlqwHWQSKH4oKLrILpRGhEQCw2LiRUIa4lwAAAABJRU5ErkJggg==")!important}#toast-container>.toast-warning{background-image:url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGYSURBVEhL5ZSvTsNQFMbXZGICMYGYmJhAQIJAICYQPAACiSDB8AiICQQJT4CqQEwgJvYASAQCiZiYmJhAIBATCARJy+9rTsldd8sKu1M0+dLb057v6/lbq/2rK0mS/TRNj9cWNAKPYIJII7gIxCcQ51cvqID+GIEX8ASG4B1bK5gIZFeQfoJdEXOfgX4QAQg7kH2A65yQ87lyxb27sggkAzAuFhbbg1K2kgCkB1bVwyIR9m2L7PRPIhDUIXgGtyKw575yz3lTNs6X4JXnjV+LKM/m3MydnTbtOKIjtz6VhCBq4vSm3ncdrD2lk0VgUXSVKjVDJXJzijW1RQdsU7F77He8u68koNZTz8Oz5yGa6J3H3lZ0xYgXBK2QymlWWA+RWnYhskLBv2vmE+hBMCtbA7KX5drWyRT/2JsqZ2IvfB9Y4bWDNMFbJRFmC9E74SoS0CqulwjkC0+5bpcV1CZ8NMej4pjy0U+doDQsGyo1hzVJttIjhQ7GnBtRFN1UarUlH8F3xict+HY07rEzoUGPlWcjRFRr4/gChZgc3ZL2d8oAAAAASUVORK5CYII=")!important}#toast-container.toast-top-full-width>div,#toast-container.toast-bottom-full-width>div{width:96%;margin:auto}.toast{background-color:#030303}.toast-success{background-color:#51a351}.toast-error{background-color:#bd362f}.toast-info{background-color:#2f96b4}.toast-warning{background-color:#f89406}@media all and (max-width:240px){#toast-container>div{padding:8px 8px 8px 50px;width:11em}#toast-container .toast-close-button{right:-0.2em;top:-0.2em}}@media all and (min-width:241px) and (max-width:480px){#toast-container>div{padding:8px 8px 8px 50px;width:18em}#toast-container .toast-close-button{right:-0.2em;top:-0.2em}}@media all and (min-width:481px) and (max-width:768px){#toast-container>div{padding:15px 15px 15px 50px;width:25em}} \ No newline at end of file diff --git a/node_modules/toastr/package/package/nuget/content/content/toastr.scss b/node_modules/toastr/package/package/nuget/content/content/toastr.scss new file mode 100644 index 0000000..71f017b --- /dev/null +++ b/node_modules/toastr/package/package/nuget/content/content/toastr.scss @@ -0,0 +1,183 @@ +/* + * Toastr + * Version 2.0.1 + * Copyright 2012 John Papa and Hans Fjällemark. + * All Rights Reserved. + * Use, reproduction, distribution, and modification of this code is subject to the terms and + * conditions of the MIT license, available at http://www.opensource.org/licenses/mit-license.php + * + * Author: John Papa and Hans Fjällemark + * Project: https://github.com/CodeSeven/toastr + */ +.toast-title { + font-weight: bold; +} +.toast-message { + -ms-word-wrap: break-word; + word-wrap: break-word; +} +.toast-message a, +.toast-message label { + color: #ffffff; +} +.toast-message a:hover { + color: #cccccc; + text-decoration: none; +} + +.toast-close-button { + position: relative; + right: -0.3em; + top: -0.3em; + float: right; + font-size: 20px; + font-weight: bold; + color: #ffffff; + -webkit-text-shadow: 0 1px 0 #ffffff; + text-shadow: 0 1px 0 #ffffff; + opacity: 0.8; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=80); + filter: alpha(opacity=80); +} +.toast-close-button:hover, +.toast-close-button:focus { + color: #000000; + text-decoration: none; + cursor: pointer; + opacity: 0.4; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=40); + filter: alpha(opacity=40); +} + +/*Additional properties for button version + iOS requires the button element instead of an anchor tag. + If you want the anchor version, it requires `href="#"`.*/ +button.toast-close-button { + padding: 0; + cursor: pointer; + background: transparent; + border: 0; + -webkit-appearance: none; +} +.toast-top-full-width { + top: 0; + right: 0; + width: 100%; +} +.toast-bottom-full-width { + bottom: 0; + right: 0; + width: 100%; +} +.toast-top-left { + top: 12px; + left: 12px; +} +.toast-top-right { + top: 12px; + right: 12px; +} +.toast-bottom-right { + right: 12px; + bottom: 12px; +} +.toast-bottom-left { + bottom: 12px; + left: 12px; +} +#toast-container { + position: fixed; + z-index: 999999; + /*overrides*/ + +} +#toast-container * { + -moz-box-sizing: border-box; + -webkit-box-sizing: border-box; + box-sizing: border-box; +} +#toast-container > div { + margin: 0 0 6px; + padding: 15px 15px 15px 50px; + width: 300px; + -moz-border-radius: 3px 3px 3px 3px; + -webkit-border-radius: 3px 3px 3px 3px; + border-radius: 3px 3px 3px 3px; + background-position: 15px center; + background-repeat: no-repeat; + -moz-box-shadow: 0 0 12px #999999; + -webkit-box-shadow: 0 0 12px #999999; + box-shadow: 0 0 12px #999999; + color: #ffffff; + opacity: 0.8; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=80); + filter: alpha(opacity=80); +} +#toast-container > :hover { + -moz-box-shadow: 0 0 12px #000000; + -webkit-box-shadow: 0 0 12px #000000; + box-shadow: 0 0 12px #000000; + opacity: 1; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=100); + filter: alpha(opacity=100); + cursor: pointer; +} +#toast-container > .toast-info { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGwSURBVEhLtZa9SgNBEMc9sUxxRcoUKSzSWIhXpFMhhYWFhaBg4yPYiWCXZxBLERsLRS3EQkEfwCKdjWJAwSKCgoKCcudv4O5YLrt7EzgXhiU3/4+b2ckmwVjJSpKkQ6wAi4gwhT+z3wRBcEz0yjSseUTrcRyfsHsXmD0AmbHOC9Ii8VImnuXBPglHpQ5wwSVM7sNnTG7Za4JwDdCjxyAiH3nyA2mtaTJufiDZ5dCaqlItILh1NHatfN5skvjx9Z38m69CgzuXmZgVrPIGE763Jx9qKsRozWYw6xOHdER+nn2KkO+Bb+UV5CBN6WC6QtBgbRVozrahAbmm6HtUsgtPC19tFdxXZYBOfkbmFJ1VaHA1VAHjd0pp70oTZzvR+EVrx2Ygfdsq6eu55BHYR8hlcki+n+kERUFG8BrA0BwjeAv2M8WLQBtcy+SD6fNsmnB3AlBLrgTtVW1c2QN4bVWLATaIS60J2Du5y1TiJgjSBvFVZgTmwCU+dAZFoPxGEEs8nyHC9Bwe2GvEJv2WXZb0vjdyFT4Cxk3e/kIqlOGoVLwwPevpYHT+00T+hWwXDf4AJAOUqWcDhbwAAAAASUVORK5CYII=") !important; +} +#toast-container > .toast-error { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAHOSURBVEhLrZa/SgNBEMZzh0WKCClSCKaIYOED+AAKeQQLG8HWztLCImBrYadgIdY+gIKNYkBFSwu7CAoqCgkkoGBI/E28PdbLZmeDLgzZzcx83/zZ2SSXC1j9fr+I1Hq93g2yxH4iwM1vkoBWAdxCmpzTxfkN2RcyZNaHFIkSo10+8kgxkXIURV5HGxTmFuc75B2RfQkpxHG8aAgaAFa0tAHqYFfQ7Iwe2yhODk8+J4C7yAoRTWI3w/4klGRgR4lO7Rpn9+gvMyWp+uxFh8+H+ARlgN1nJuJuQAYvNkEnwGFck18Er4q3egEc/oO+mhLdKgRyhdNFiacC0rlOCbhNVz4H9FnAYgDBvU3QIioZlJFLJtsoHYRDfiZoUyIxqCtRpVlANq0EU4dApjrtgezPFad5S19Wgjkc0hNVnuF4HjVA6C7QrSIbylB+oZe3aHgBsqlNqKYH48jXyJKMuAbiyVJ8KzaB3eRc0pg9VwQ4niFryI68qiOi3AbjwdsfnAtk0bCjTLJKr6mrD9g8iq/S/B81hguOMlQTnVyG40wAcjnmgsCNESDrjme7wfftP4P7SP4N3CJZdvzoNyGq2c/HWOXJGsvVg+RA/k2MC/wN6I2YA2Pt8GkAAAAASUVORK5CYII=") !important; +} +#toast-container > .toast-success { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAADsSURBVEhLY2AYBfQMgf///3P8+/evAIgvA/FsIF+BavYDDWMBGroaSMMBiE8VC7AZDrIFaMFnii3AZTjUgsUUWUDA8OdAH6iQbQEhw4HyGsPEcKBXBIC4ARhex4G4BsjmweU1soIFaGg/WtoFZRIZdEvIMhxkCCjXIVsATV6gFGACs4Rsw0EGgIIH3QJYJgHSARQZDrWAB+jawzgs+Q2UO49D7jnRSRGoEFRILcdmEMWGI0cm0JJ2QpYA1RDvcmzJEWhABhD/pqrL0S0CWuABKgnRki9lLseS7g2AlqwHWQSKH4oKLrILpRGhEQCw2LiRUIa4lwAAAABJRU5ErkJggg==") !important; +} +#toast-container > .toast-warning { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGYSURBVEhL5ZSvTsNQFMbXZGICMYGYmJhAQIJAICYQPAACiSDB8AiICQQJT4CqQEwgJvYASAQCiZiYmJhAIBATCARJy+9rTsldd8sKu1M0+dLb057v6/lbq/2rK0mS/TRNj9cWNAKPYIJII7gIxCcQ51cvqID+GIEX8ASG4B1bK5gIZFeQfoJdEXOfgX4QAQg7kH2A65yQ87lyxb27sggkAzAuFhbbg1K2kgCkB1bVwyIR9m2L7PRPIhDUIXgGtyKw575yz3lTNs6X4JXnjV+LKM/m3MydnTbtOKIjtz6VhCBq4vSm3ncdrD2lk0VgUXSVKjVDJXJzijW1RQdsU7F77He8u68koNZTz8Oz5yGa6J3H3lZ0xYgXBK2QymlWWA+RWnYhskLBv2vmE+hBMCtbA7KX5drWyRT/2JsqZ2IvfB9Y4bWDNMFbJRFmC9E74SoS0CqulwjkC0+5bpcV1CZ8NMej4pjy0U+doDQsGyo1hzVJttIjhQ7GnBtRFN1UarUlH8F3xict+HY07rEzoUGPlWcjRFRr4/gChZgc3ZL2d8oAAAAASUVORK5CYII=") !important; +} +#toast-container.toast-top-full-width > div, +#toast-container.toast-bottom-full-width > div { + width: 96%; + margin: auto; +} +.toast { + background-color: #030303; +} +.toast-success { + background-color: #51a351; +} +.toast-error { + background-color: #bd362f; +} +.toast-info { + background-color: #2f96b4; +} +.toast-warning { + background-color: #f89406; +} +/*Responsive Design*/ +@media all and (max-width: 239px) { + #toast-container > div { + padding: 8px 8px 8px 50px; + width: 11em; + } + #toast-container .toast-close-button { + right: -0.2em; + top: -0.2em; + } +} +@media all and (min-width: 240px) and (max-width: 479px) { + #toast-container > div { + padding: 8px 8px 8px 50px; + width: 18em; + } + #toast-container .toast-close-button { + right: -0.2em; + top: -0.2em; + } +} +@media all and (min-width: 480px) and (max-width: 767px) { + #toast-container > div { + padding: 15px 15px 15px 50px; + width: 25em; + } +} \ No newline at end of file diff --git a/node_modules/toastr/package/package/nuget/content/scripts/toastr.js b/node_modules/toastr/package/package/nuget/content/scripts/toastr.js new file mode 100644 index 0000000..87ae449 --- /dev/null +++ b/node_modules/toastr/package/package/nuget/content/scripts/toastr.js @@ -0,0 +1,338 @@ +/* + * Toastr + * Copyright 2012-2014 John Papa and Hans Fjällemark. + * All Rights Reserved. + * Use, reproduction, distribution, and modification of this code is subject to the terms and + * conditions of the MIT license, available at http://www.opensource.org/licenses/mit-license.php + * + * Author: John Papa and Hans Fjällemark + * ARIA Support: Greta Krafsig + * Project: https://github.com/CodeSeven/toastr + */ +; (function (define) { + define(['jquery'], function ($) { + return (function () { + var $container; + var listener; + var toastId = 0; + var toastType = { + error: 'error', + info: 'info', + success: 'success', + warning: 'warning' + }; + + var toastr = { + clear: clear, + remove: remove, + error: error, + getContainer: getContainer, + info: info, + options: {}, + subscribe: subscribe, + success: success, + version: '2.0.3', + warning: warning + }; + + return toastr; + + //#region Accessible Methods + function error(message, title, optionsOverride) { + return notify({ + type: toastType.error, + iconClass: getOptions().iconClasses.error, + message: message, + optionsOverride: optionsOverride, + title: title + }); + } + + function getContainer(options, create) { + if (!options) { options = getOptions(); } + $container = $('#' + options.containerId); + if ($container.length) { + return $container; + } + if(create) { + $container = createContainer(options); + } + return $container; + } + + function info(message, title, optionsOverride) { + return notify({ + type: toastType.info, + iconClass: getOptions().iconClasses.info, + message: message, + optionsOverride: optionsOverride, + title: title + }); + } + + function subscribe(callback) { + listener = callback; + } + + function success(message, title, optionsOverride) { + return notify({ + type: toastType.success, + iconClass: getOptions().iconClasses.success, + message: message, + optionsOverride: optionsOverride, + title: title + }); + } + + function warning(message, title, optionsOverride) { + return notify({ + type: toastType.warning, + iconClass: getOptions().iconClasses.warning, + message: message, + optionsOverride: optionsOverride, + title: title + }); + } + + function clear($toastElement) { + var options = getOptions(); + if (!$container) { getContainer(options); } + if (!clearToast($toastElement, options)) { + clearContainer(options); + } + } + + function remove($toastElement) { + var options = getOptions(); + if (!$container) { getContainer(options); } + if ($toastElement && $(':focus', $toastElement).length === 0) { + removeToast($toastElement); + return; + } + if ($container.children().length) { + $container.remove(); + } + } + //#endregion + + //#region Internal Methods + + function clearContainer(options){ + var toastsToClear = $container.children(); + for (var i = toastsToClear.length - 1; i >= 0; i--) { + clearToast($(toastsToClear[i]), options); + }; + } + + function clearToast($toastElement, options){ + if ($toastElement && $(':focus', $toastElement).length === 0) { + $toastElement[options.hideMethod]({ + duration: options.hideDuration, + easing: options.hideEasing, + complete: function () { removeToast($toastElement); } + }); + return true; + } + return false; + } + + function createContainer(options) { + $container = $('
') + .attr('id', options.containerId) + .addClass(options.positionClass) + .attr('aria-live', 'polite') + .attr('role', 'alert'); + + $container.appendTo($(options.target)); + return $container; + } + + function getDefaults() { + return { + tapToDismiss: true, + toastClass: 'toast', + containerId: 'toast-container', + debug: false, + + showMethod: 'fadeIn', //fadeIn, slideDown, and show are built into jQuery + showDuration: 300, + showEasing: 'swing', //swing and linear are built into jQuery + onShown: undefined, + hideMethod: 'fadeOut', + hideDuration: 1000, + hideEasing: 'swing', + onHidden: undefined, + + extendedTimeOut: 1000, + iconClasses: { + error: 'toast-error', + info: 'toast-info', + success: 'toast-success', + warning: 'toast-warning' + }, + iconClass: 'toast-info', + positionClass: 'toast-top-right', + timeOut: 5000, // Set timeOut and extendedTimeout to 0 to make it sticky + titleClass: 'toast-title', + messageClass: 'toast-message', + target: 'body', + closeHtml: '', + newestOnTop: true + }; + } + + function publish(args) { + if (!listener) { return; } + listener(args); + } + + function notify(map) { + var options = getOptions(), + iconClass = map.iconClass || options.iconClass; + + if (typeof (map.optionsOverride) !== 'undefined') { + options = $.extend(options, map.optionsOverride); + iconClass = map.optionsOverride.iconClass || iconClass; + } + + toastId++; + + $container = getContainer(options, true); + var intervalId = null, + $toastElement = $('
'), + $titleElement = $('
'), + $messageElement = $('
'), + $closeElement = $(options.closeHtml), + response = { + toastId: toastId, + state: 'visible', + startTime: new Date(), + options: options, + map: map + }; + + if (map.iconClass) { + $toastElement.addClass(options.toastClass).addClass(iconClass); + } + + if (map.title) { + $titleElement.append(map.title).addClass(options.titleClass); + $toastElement.append($titleElement); + } + + if (map.message) { + $messageElement.append(map.message).addClass(options.messageClass); + $toastElement.append($messageElement); + } + + if (options.closeButton) { + $closeElement.addClass('toast-close-button').attr("role", "button"); + $toastElement.prepend($closeElement); + } + + $toastElement.hide(); + if (options.newestOnTop) { + $container.prepend($toastElement); + } else { + $container.append($toastElement); + } + + + $toastElement[options.showMethod]( + { duration: options.showDuration, easing: options.showEasing, complete: options.onShown } + ); + + if (options.timeOut > 0) { + intervalId = setTimeout(hideToast, options.timeOut); + } + + $toastElement.hover(stickAround, delayedHideToast); + if (!options.onclick && options.tapToDismiss) { + $toastElement.click(hideToast); + } + + if (options.closeButton && $closeElement) { + $closeElement.click(function (event) { + if( event.stopPropagation ) { + event.stopPropagation(); + } else if( event.cancelBubble !== undefined && event.cancelBubble !== true ) { + event.cancelBubble = true; + } + hideToast(true); + }); + } + + if (options.onclick) { + $toastElement.click(function () { + options.onclick(); + hideToast(); + }); + } + + publish(response); + + if (options.debug && console) { + console.log(response); + } + + return $toastElement; + + function hideToast(override) { + if ($(':focus', $toastElement).length && !override) { + return; + } + return $toastElement[options.hideMethod]({ + duration: options.hideDuration, + easing: options.hideEasing, + complete: function () { + removeToast($toastElement); + if (options.onHidden && response.state !== 'hidden') { + options.onHidden(); + } + response.state = 'hidden'; + response.endTime = new Date(); + publish(response); + } + }); + } + + function delayedHideToast() { + if (options.timeOut > 0 || options.extendedTimeOut > 0) { + intervalId = setTimeout(hideToast, options.extendedTimeOut); + } + } + + function stickAround() { + clearTimeout(intervalId); + $toastElement.stop(true, true)[options.showMethod]( + { duration: options.showDuration, easing: options.showEasing } + ); + } + } + + function getOptions() { + return $.extend({}, getDefaults(), toastr.options); + } + + function removeToast($toastElement) { + if (!$container) { $container = getContainer(); } + if ($toastElement.is(':visible')) { + return; + } + $toastElement.remove(); + $toastElement = null; + if ($container.children().length === 0) { + $container.remove(); + } + } + //#endregion + + })(); + }); +}(typeof define === 'function' && define.amd ? define : function (deps, factory) { + if (typeof module !== 'undefined' && module.exports) { //Node + module.exports = factory(require('jquery')); + } else { + window['toastr'] = factory(window['jQuery']); + } +})); \ No newline at end of file diff --git a/node_modules/toastr/package/package/nuget/content/scripts/toastr.min.js b/node_modules/toastr/package/package/nuget/content/scripts/toastr.min.js new file mode 100644 index 0000000..3450888 --- /dev/null +++ b/node_modules/toastr/package/package/nuget/content/scripts/toastr.min.js @@ -0,0 +1 @@ +!function(a){a(["jquery"],function(a){return function(){function b(a,b,c){return o({type:u.error,iconClass:p().iconClasses.error,message:a,optionsOverride:c,title:b})}function c(b,c){return b||(b=p()),r=a("#"+b.containerId),r.length?r:(c&&(r=l(b)),r)}function d(a,b,c){return o({type:u.info,iconClass:p().iconClasses.info,message:a,optionsOverride:c,title:b})}function e(a){s=a}function f(a,b,c){return o({type:u.success,iconClass:p().iconClasses.success,message:a,optionsOverride:c,title:b})}function g(a,b,c){return o({type:u.warning,iconClass:p().iconClasses.warning,message:a,optionsOverride:c,title:b})}function h(a){var b=p();r||c(b),k(a,b)||j(b)}function i(b){var d=p();return r||c(d),b&&0===a(":focus",b).length?void q(b):void(r.children().length&&r.remove())}function j(b){for(var c=r.children(),d=c.length-1;d>=0;d--)k(a(c[d]),b)}function k(b,c){return b&&0===a(":focus",b).length?(b[c.hideMethod]({duration:c.hideDuration,easing:c.hideEasing,complete:function(){q(b)}}),!0):!1}function l(b){return r=a("
").attr("id",b.containerId).addClass(b.positionClass).attr("aria-live","polite").attr("role","alert"),r.appendTo(a(b.target)),r}function m(){return{tapToDismiss:!0,toastClass:"toast",containerId:"toast-container",debug:!1,showMethod:"fadeIn",showDuration:300,showEasing:"swing",onShown:void 0,hideMethod:"fadeOut",hideDuration:1e3,hideEasing:"swing",onHidden:void 0,extendedTimeOut:1e3,iconClasses:{error:"toast-error",info:"toast-info",success:"toast-success",warning:"toast-warning"},iconClass:"toast-info",positionClass:"toast-top-right",timeOut:5e3,titleClass:"toast-title",messageClass:"toast-message",target:"body",closeHtml:"",newestOnTop:!0}}function n(a){s&&s(a)}function o(b){function d(b){return!a(":focus",j).length||b?j[g.hideMethod]({duration:g.hideDuration,easing:g.hideEasing,complete:function(){q(j),g.onHidden&&"hidden"!==o.state&&g.onHidden(),o.state="hidden",o.endTime=new Date,n(o)}}):void 0}function e(){(g.timeOut>0||g.extendedTimeOut>0)&&(i=setTimeout(d,g.extendedTimeOut))}function f(){clearTimeout(i),j.stop(!0,!0)[g.showMethod]({duration:g.showDuration,easing:g.showEasing})}var g=p(),h=b.iconClass||g.iconClass;"undefined"!=typeof b.optionsOverride&&(g=a.extend(g,b.optionsOverride),h=b.optionsOverride.iconClass||h),t++,r=c(g,!0);var i=null,j=a("
"),k=a("
"),l=a("
"),m=a(g.closeHtml),o={toastId:t,state:"visible",startTime:new Date,options:g,map:b};return b.iconClass&&j.addClass(g.toastClass).addClass(h),b.title&&(k.append(b.title).addClass(g.titleClass),j.append(k)),b.message&&(l.append(b.message).addClass(g.messageClass),j.append(l)),g.closeButton&&(m.addClass("toast-close-button").attr("role","button"),j.prepend(m)),j.hide(),g.newestOnTop?r.prepend(j):r.append(j),j[g.showMethod]({duration:g.showDuration,easing:g.showEasing,complete:g.onShown}),g.timeOut>0&&(i=setTimeout(d,g.timeOut)),j.hover(f,e),!g.onclick&&g.tapToDismiss&&j.click(d),g.closeButton&&m&&m.click(function(a){a.stopPropagation?a.stopPropagation():void 0!==a.cancelBubble&&a.cancelBubble!==!0&&(a.cancelBubble=!0),d(!0)}),g.onclick&&j.click(function(){g.onclick(),d()}),n(o),g.debug&&console&&console.log(o),j}function p(){return a.extend({},m(),v.options)}function q(a){r||(r=c()),a.is(":visible")||(a.remove(),a=null,0===r.children().length&&r.remove())}var r,s,t=0,u={error:"error",info:"info",success:"success",warning:"warning"},v={clear:h,remove:i,error:b,getContainer:c,info:d,options:{},subscribe:e,success:f,version:"2.0.3",warning:g};return v}()})}("function"==typeof define&&define.amd?define:function(a,b){"undefined"!=typeof module&&module.exports?module.exports=b(require("jquery")):window.toastr=b(window.jQuery)}); \ No newline at end of file diff --git a/node_modules/toastr/package/package/nuget/content/scripts/toastr.min.js.map b/node_modules/toastr/package/package/nuget/content/scripts/toastr.min.js.map new file mode 100644 index 0000000..2f6c09a --- /dev/null +++ b/node_modules/toastr/package/package/nuget/content/scripts/toastr.min.js.map @@ -0,0 +1,8 @@ +{ +"version":3, +"file":"toastr.min.js", +"lineCount":1, +"mappings":"CAWG,QAAS,CAACA,CAAD,CAAS,CACpBA,CAAM,CAAC,CAAC,QAAD,CAAU,CAAE,QAAS,CAACC,CAAD,CAAI,CAC/B,OAAQ,QAAS,CAAA,CAAG,CA2BnBC,SAASA,CAAK,CAACC,CAAO,CAAEC,CAAK,CAAEC,CAAjB,CAAkC,CAC/C,OAAOC,CAAM,CAAC,CACb,IAAI,CAAEC,CAASL,MAAM,CACrB,SAAS,CAAEM,CAAU,CAAA,CAAEC,YAAYP,MAAM,CACzC,OAAO,CAAEC,CAAO,CAChB,eAAe,CAAEE,CAAe,CAChC,KAAK,CAAED,CALM,CAAD,CADkC,CAUhDM,SAASA,CAAI,CAACP,CAAO,CAAEC,CAAK,CAAEC,CAAjB,CAAkC,CAC9C,OAAOC,CAAM,CAAC,CACb,IAAI,CAAEC,CAASG,KAAK,CACpB,SAAS,CAAEF,CAAU,CAAA,CAAEC,YAAYC,KAAK,CACxC,OAAO,CAAEP,CAAO,CAChB,eAAe,CAAEE,CAAe,CAChC,KAAK,CAAED,CALM,CAAD,CADiC,CAU/CO,SAASA,CAAS,CAACC,CAAD,CAAW,CAC5BC,CAAS,CAAED,CADiB,CAI7BE,SAASA,CAAO,CAACX,CAAO,CAAEC,CAAK,CAAEC,CAAjB,CAAkC,CACjD,OAAOC,CAAM,CAAC,CACb,IAAI,CAAEC,CAASO,QAAQ,CACvB,SAAS,CAAEN,CAAU,CAAA,CAAEC,YAAYK,QAAQ,CAC3C,OAAO,CAAEX,CAAO,CAChB,eAAe,CAAEE,CAAe,CAChC,KAAK,CAAED,CALM,CAAD,CADoC,CAUlDW,SAASA,CAAO,CAACZ,CAAO,CAAEC,CAAK,CAAEC,CAAjB,CAAkC,CACjD,OAAOC,CAAM,CAAC,CACb,IAAI,CAAEC,CAASQ,QAAQ,CACvB,SAAS,CAAEP,CAAU,CAAA,CAAEC,YAAYM,QAAQ,CAC3C,OAAO,CAAEZ,CAAO,CAChB,eAAe,CAAEE,CAAe,CAChC,KAAK,CAAED,CALM,CAAD,CADoC,CAUlDY,SAASA,CAAK,CAACC,CAAD,CAAgB,CAC7B,IAAIC,EAAUV,CAAU,CAAA,CAAE,CAE1B,GADKW,C,EAAcC,CAAY,CAACF,CAAD,CAAS,CACpCD,CAAc,EAAGhB,CAAC,CAAC,QAAQ,CAAEgB,CAAX,CAAyBI,OAAQ,GAAI,EAAG,CAC7DJ,CAAc,CAAAC,CAAOI,WAAP,CAAmB,CAAC,CACjC,QAAQ,CAAEJ,CAAOK,aAAa,CAC9B,MAAM,CAAEL,CAAOM,WAAW,CAC1B,QAAQ,CAAEC,QAAS,CAAA,CAAG,CAAEC,CAAW,CAACT,CAAD,CAAb,CAHW,CAAD,CAI/B,CACF,MAN6D,CAQ1DE,CAAUQ,SAAS,CAAA,CAAEN,O,EACxBF,CAAW,CAAAD,CAAOI,WAAP,CAAmB,CAAC,CAC9B,QAAQ,CAAEJ,CAAOK,aAAa,CAC9B,MAAM,CAAEL,CAAOM,WAAW,CAC1B,QAAQ,CAAEC,QAAS,CAAA,CAAG,CAAEN,CAAUS,OAAO,CAAA,CAAnB,CAHQ,CAAD,CAZF,CAuB9BC,SAASA,CAAW,CAAA,CAAG,CACtB,MAAO,CACN,YAAY,CAAE,CAAA,CAAI,CAClB,UAAU,CAAE,OAAO,CACnB,WAAW,CAAE,iBAAiB,CAC9B,KAAK,CAAE,CAAA,CAAK,CAEZ,UAAU,CAAE,QAAQ,CACpB,YAAY,CAAE,GAAG,CACjB,UAAU,CAAE,OAAO,CACnB,OAAO,CAAEC,SAAS,CAClB,UAAU,CAAE,SAAS,CACrB,YAAY,CAAE,GAAI,CAClB,UAAU,CAAE,OAAO,CACnB,QAAQ,CAAEA,SAAS,CAEnB,eAAe,CAAE,GAAI,CACrB,WAAW,CAAE,CACZ,KAAK,CAAE,aAAa,CACpB,IAAI,CAAE,YAAY,CAClB,OAAO,CAAE,eAAe,CACxB,OAAO,CAAE,eAJG,CAKZ,CACD,SAAS,CAAE,YAAY,CACvB,aAAa,CAAE,iBAAiB,CAChC,OAAO,CAAE,GAAI,CACb,UAAU,CAAE,aAAa,CACzB,YAAY,CAAE,eAAe,CAC7B,MAAM,CAAE,MAAM,CACd,SAAS,CAAE,2BAA0B,CACrC,WAAW,CAAE,CAAA,CA7BP,CADe,CAkCvBC,SAASA,CAAO,CAACC,CAAD,CAAO,CACjBnB,C,EAGLA,CAAQ,CAACmB,CAAD,CAJc,CAOvB1B,SAASA,CAAM,CAAC2B,CAAD,CAAM,CAuFpBC,SAASA,CAAS,CAACC,CAAD,CAAW,C,GACxB,CAAAlC,CAAC,CAAC,QAAQ,CAAEgB,CAAX,CAAyBI,OAAQ,EAAIc,E,OAGnClB,CAAc,CAAAC,CAAOI,WAAP,CAAmB,CAAC,CACxC,QAAQ,CAAEJ,CAAOK,aAAa,CAC9B,MAAM,CAAEL,CAAOM,WAAW,CAC1B,QAAQ,CAAEC,QAAS,CAAA,CAAG,CACrBC,CAAW,CAACT,CAAD,CAAe,CACtBC,CAAOkB,S,EACVlB,CAAOkB,SAAS,CAAA,CAAE,CAEnBC,CAAQC,MAAO,CAAE,QAAQ,CACzBD,CAAQE,QAAS,CAAE,IAAIC,I,CACvBT,CAAO,CAACM,CAAD,CAPc,CAHkB,CAAD,CAJZ,CAmB7BI,SAASA,CAAgB,CAAA,CAAG,EACvBvB,CAAOwB,QAAS,CAAE,CAAE,EAAGxB,CAAOyB,gBAAiB,CAAE,E,GACpDC,CAAW,CAAEC,UAAU,CAACX,CAAS,CAAEhB,CAAOyB,gBAAnB,EAFG,CAM5BG,SAASA,CAAW,CAAA,CAAG,CACtBC,YAAY,CAACH,CAAD,CAAY,CACxB3B,CAAa+B,KAAK,CAAC,CAAA,CAAD,CAAO,CAAA,CAAP,CAAa,CAAA9B,CAAO+B,WAAP,CAAmB,CACjD,CAAE,QAAQ,CAAE/B,CAAOgC,aAAa,CAAE,MAAM,CAAEhC,CAAOiC,WAAjD,CADiD,CAF5B,CA/GvB,IACCjC,EAAUV,CAAU,CAAA,EACpB4C,EAAYnB,CAAGmB,UAAW,EAAGlC,CAAOkC,UAAU,CAE3C,OAAQnB,CAAG5B,gBAAkB,EAAI,W,GACpCa,CAAQ,CAAEjB,CAACoD,OAAO,CAACnC,CAAO,CAAEe,CAAG5B,gBAAb,CAA8B,CAChD+C,CAAU,CAAEnB,CAAG5B,gBAAgB+C,UAAW,EAAGA,EAAS,CAGvDE,CAAO,EAAE,CAETnC,CAAW,CAAEC,CAAY,CAACF,CAAD,CAAS,CAClC,IACC0B,EAAa,KACb3B,EAAgBhB,CAAC,CAAC,QAAD,EACjBsD,EAAgBtD,CAAC,CAAC,QAAD,EACjBuD,EAAkBvD,CAAC,CAAC,QAAD,EACnBwD,EAAgBxD,CAAC,CAACiB,CAAOwC,UAAR,EACjBrB,EAAW,CACV,OAAO,CAAEiB,CAAO,CAChB,KAAK,CAAE,SAAS,CAChB,SAAS,CAAE,IAAId,IAAM,CACrB,OAAO,CAAEtB,CAAO,CAChB,GAAG,CAAEe,CALK,CAMV,CA4DF,OA1DIA,CAAGmB,U,EACNnC,CAAa0C,SAAS,CAACzC,CAAO0C,WAAR,CAAoBD,SAAS,CAACP,CAAD,CAAW,CAG3DnB,CAAG7B,M,GACNmD,CAAaM,OAAO,CAAC5B,CAAG7B,MAAJ,CAAWuD,SAAS,CAACzC,CAAO4C,WAAR,CAAoB,CAC5D7C,CAAa4C,OAAO,CAACN,CAAD,EAAe,CAGhCtB,CAAG9B,Q,GACNqD,CAAeK,OAAO,CAAC5B,CAAG9B,QAAJ,CAAawD,SAAS,CAACzC,CAAO6C,aAAR,CAAsB,CAClE9C,CAAa4C,OAAO,CAACL,CAAD,EAAiB,CAGlCtC,CAAO8C,Y,GACVP,CAAaE,SAAS,CAAC,oBAAD,CAAsB,CAC5C1C,CAAagD,QAAQ,CAACR,CAAD,EAAe,CAGrCxC,CAAaiD,KAAK,CAAA,CAAE,CAChBhD,CAAOiD,YAAX,CACChD,CAAU8C,QAAQ,CAAChD,CAAD,CADnB,CAGCE,CAAU0C,OAAO,CAAC5C,CAAD,C,CAIlBA,CAAc,CAAAC,CAAO+B,WAAP,CAAmB,CAChC,CAAE,QAAQ,CAAE/B,CAAOgC,aAAa,CAAE,MAAM,CAAEhC,CAAOiC,WAAW,CAAE,QAAQ,CAAEjC,CAAOkD,QAA/E,CADgC,CAEhC,CACGlD,CAAOwB,QAAS,CAAE,C,GACrBE,CAAW,CAAEC,UAAU,CAACX,CAAS,CAAEhB,CAAOwB,QAAnB,EAA4B,CAGpDzB,CAAaoD,MAAM,CAACvB,CAAW,CAAEL,CAAd,CAA+B,CAC9C,CAACvB,CAAOoD,QAAS,EAAGpD,CAAOqD,a,EAC9BtD,CAAauD,MAAM,CAACtC,CAAD,CAAW,CAE3BhB,CAAO8C,YAAa,EAAGP,C,EAC1BA,CAAae,MAAM,CAAC,QAAS,CAACC,CAAD,CAAQ,CACpCA,CAAKC,gBAAgB,CAAA,CAAE,CACvBxC,CAAS,CAAC,CAAA,CAAD,CAF2B,CAAlB,CAGjB,CAGChB,CAAOoD,Q,EACVrD,CAAauD,MAAM,CAAC,QAAS,CAAA,CAAG,CAC/BtD,CAAOoD,QAAQ,CAAA,CAAE,CACjBpC,CAAS,CAAA,CAFsB,CAAb,CAGjB,CAGHH,CAAO,CAACM,CAAD,CAAU,CAEbnB,CAAOyD,MAAO,EAAGC,O,EACpBA,OAAOC,IAAI,CAACxC,CAAD,CAAU,CAGfpB,CArFa,CAuHrBG,SAASA,CAAY,CAACF,CAAD,CAAU,CAU9B,OATKA,C,GAAWA,CAAQ,CAAEV,CAAU,CAAA,EAAE,CACtCW,CAAW,CAAElB,CAAC,CAAC,GAAI,CAAEiB,CAAO4D,YAAd,CAA2B,CACrC3D,CAAUE,Q,CACNF,C,EAERA,CAAW,CAAElB,CAAC,CAAC,QAAD,CACb8E,KAAK,CAAC,IAAI,CAAE7D,CAAO4D,YAAd,CACLnB,SAAS,CAACzC,CAAO8D,cAAR,CAAuB,CACjC7D,CAAU8D,SAAS,CAAChF,CAAC,CAACiB,CAAOgE,OAAR,CAAF,CAAmB,CAC/B/D,EAVuB,CAa/BX,SAASA,CAAU,CAAA,CAAG,CACrB,OAAOP,CAACoD,OAAO,CAAC,CAAA,CAAE,CAAExB,CAAW,CAAA,CAAE,CAAEsD,CAAMjE,QAA1B,CADM,CAItBQ,SAASA,CAAW,CAACT,CAAD,CAAgB,EAC9BE,C,GAAcA,CAAW,CAAEC,CAAY,CAAA,EAAE,CAC1CH,CAAamE,GAAG,CAAC,UAAD,E,GAGpBnE,CAAaW,OAAO,CAAA,CAAE,CACtBX,CAAc,CAAE,IAAI,CAChBE,CAAUQ,SAAS,CAAA,CAAEN,OAAQ,GAAI,C,EACpCF,CAAUS,OAAO,CAAA,EARiB,CA9QpC,IACIT,EACAN,EACAyC,EAAU,EACV/C,EAAY,CACf,KAAK,CAAE,OAAO,CACd,IAAI,CAAE,MAAM,CACZ,OAAO,CAAE,SAAS,CAClB,OAAO,CAAE,SAJM,EAOZ4E,EAAS,CACZ,KAAK,CAAEnE,CAAK,CACZ,KAAK,CAAEd,CAAK,CACZ,YAAY,CAAEkB,CAAY,CAC1B,IAAI,CAAEV,CAAI,CACV,OAAO,CAAE,CAAA,CAAE,CACX,SAAS,CAAEC,CAAS,CACpB,OAAO,CAAEG,CAAO,CAChB,OAAO,CAnBM,OAmBG,CAChB,OAAO,CAAEC,CATG,CAXQ,CAuBrB,OAAOoE,CAxBY,CA4RlB,CAAA,CA7R6B,CAA1B,CADc,EAgSpB,CAAC,OAAOnF,MAAO,EAAI,UAAW,EAAGA,MAAMqF,IAAK,CAAErF,MAAO,CAAE,QAAS,CAACsF,CAAI,CAAEC,CAAP,CAAgB,CAC5E,OAAOC,MAAO,EAAI,WAAY,EAAGA,MAAMC,QAA3C,CACCD,MAAMC,QAAS,CAAEF,CAAO,CAACG,OAAO,CAACJ,CAAK,CAAA,CAAA,CAAN,CAAR,CADzB,CAGCK,MAAOR,OAAU,CAAEI,CAAO,CAACI,MAAOC,OAAR,CAJqD,CAAhF,C", +"sources":["toastr.js"], +"names":["define","$","error","message","title","optionsOverride","notify","toastType","getOptions","iconClasses","info","subscribe","callback","listener","success","warning","clear","$toastElement","options","$container","getContainer","length","hideMethod","hideDuration","hideEasing","complete","removeToast","children","remove","getDefaults","undefined","publish","args","map","hideToast","override","onHidden","response","state","endTime","Date","delayedhideToast","timeOut","extendedTimeOut","intervalId","setTimeout","stickAround","clearTimeout","stop","showMethod","showDuration","showEasing","iconClass","extend","toastId","$titleElement","$messageElement","$closeElement","closeHtml","addClass","toastClass","append","titleClass","messageClass","closeButton","prepend","hide","newestOnTop","onShown","hover","onclick","tapToDismiss","click","event","stopPropagation","debug","console","log","containerId","attr","positionClass","appendTo","target","toastr","is","amd","deps","factory","module","exports","require","window","jQuery"] +} diff --git a/node_modules/toastr/package/package/nuget/toastr.1.0.0.nupkg b/node_modules/toastr/package/package/nuget/toastr.1.0.0.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..0be0d704bd51fea2af6b9a044449c971ff83ef91 GIT binary patch literal 7341 zcmb_h2|QG9+a6?z?Af<5k%$@FNcORYEM$0_E+Qbf8`+0k{)ZlsGCbPE; z^#AD_2S^;`K?ZOX7F-}NbqzZDL3kWE03cJaM1n3v1*!}I0|XQi zjU{;NLj0*1B~6IFp3Z&%hosV5P!3^96fhk^py)ylQK=*?7>t5C1mKYrD3JsZ=w~oQ zG9F2#?~=V?BqYig=?%bCm6bJM^k{x?Kz`)}+Xs_?e__O9QDh>8h@nDJMEnLBJuW(( ziZV=j7YvUiU@-uN3IW?A$=(1}7XqUakrXN!O7N$U02Bmlj@E_jSHYk()ZwaXsz@ZD zjz+^FVAy}s`~PV?Fg!p-qLEZ23`HaZN+dEJO{QW2%1^QVlMM<$4#1)S${#T>BnAnn zq0pKds+zmhy;OE1)ijhCNHpZu^j6$nmG%zSlH7|9HhRXW* zV82{4JzILcYy~lb*w*VM$E}s2h!F&mWCnpa>GkqU*8Wy8G4?Iw4rQMD&|`tUk0aZy zy<{i1C=cE2kgsl=%-%c6v}5jpBgC>;Mh^az7SnS?2qp0ZzbHoNTM1}b>B1CnUyI_@ zf}PY8X=$IFP>)DMr^Ulzylh=x(e^Q(gUaJ3G4KVfQjFS5MI(j1Eg>#NmKv8@F}N=o zlMh_BP9BAs8nYyK2?yO}8Z?)Acw~2@Wr2v;{n)wf_76TUH`$94YR5*nT|;Y~Ru+r5 z$_{mlh~aYLpZhE)nW>-PvS9C&oVn11^6Q`0fTyMA`!U*$SO}ifDFM=rrLUc7>Ae^# zQ{7r>8y(rkkCHd)QVh`5+Qt0x6$_l>*wT>db#EyV_PhyZA8Efm6p#KWMQhU%8_t^n z)%ukOCc`%2JdqLEkI|>N{U$}uAXs9OzPQIF)0RxNZoMnf;b+7T9rUapZ9+ZxdO|<# zRZNNo)kyc)!axm4EIH$}OqEe>S_tP|11T+mmrNu#|v0 zPT#MU`1)$7S-Ltu(pLIbv@CB9jnSvvhMOy8bYg-Hx+6+@;O_GlGags@xOcpPdd%JV zVjXtzUOi!U9mUuEWWc&zb=e9y4j<^7`NT1wY!G)EcabIx9KV7q5~&ghZtdjsH*6HnWsr_bjY zi+9J4ac8^KKw5f}BNWYq`?Z`MrS+xUXII49PNmak2Kg_3=&O%;xN3>Bc}F`tb`v+T zW2{gvu;wExYjCf(`ddm5ZTPyqs!K3Bi}{Z{`$3g2yHMT_*h_a z485!q4ZYmsqD%>1F@#`@h54~FQKwEI5Hb0NaF|d5**x6K?*xGy?r!ddarZeDm1$^! z5pjyE0;|Z%s=;1Z+|9{iOtgwTSca&yt=ht=2xh!?%hezn>5GxP=V+8%Hj${Jk&}Z; zi1kmn%Io+r-O2WuN}8#$)`Rklz)Vtd(} zI<@DBle&tB2KNW^4;)8}i(k0m57fwwKQ?DOb(TUHzkMNeSbz1)!qWA*jQMPfKB+77@{o7v`s{)gv0#)gke)vvzh9&8wjE5zz7Mqfy1Pz!BXZcPmhPaTwCb#U)W zs*++xEE=7CiE{Pdr@JKnq;e{HrTpZvdFh0x;`zQj1u1X9!Bonfm|fP&9ZdDPwAeA~ zcWn6eaBICw#QDS4?@O+i#U1}5`If&dJn_r6_n*J^6gDU=`kd64`MS7wOa8|Y^WBY~ z?`t2hniFrA7s&}NZ>ZCi0fae|s=Cx)qE`6q865{7gbB_fecx!&bZe&b`W zdzXr|LJ{qW4eb+8pCaJgup@!5Z$_CfK9U&o;#vXWo>{}Rm-1sgf zJ}^)U1}!id>{$5xoP(AZ4YT>wfsNE77TVm?xVS$d$K%aM%gC?o<{Bq(s zE?>Se5QVjLS>==7$3DS%Cgw~NOHakNKn`!WnynE>A8M+c*nMI#C|Th4 z8HESVE!6-wAK(0Yh8w)MTQ@CpO4#L|Xf~3V7%4iHfx4TWHG5g2?lgbj>G-)2^t|%f z*1nt>PG2K<{~UOKxtW5lQ01g@lrf}N}qF?2U;;yX|!ac?metK@{KtA2jD zTeYpH?2Tin%51!s{51?yzixclL22>Ca@v&jIS)2=OfcUaMet?m5Iws?{v={%;;f_Y z5SLC&3n1bq#9>ONYPB9!L|Dj-_}lSd^I3Lu6!1>Wa^kPR^EplL52Y30?NYZekTGsF zBj4vvM|@q{Yo_3uL6ujH1uoP1SvPE>2}gqE*WjKvHH_d%XN>Sx zb6S0`Z$Sx1_o*?D!4;h)m;Dz?ZhmT-?>G6-X|~Glux(n;(P}#6!|P%{qKZ$6;(4*s zH;-ErU-N)E_jGhal%CfFv@|i>X}hzHwIQ-f37HAJ312O)X5Fk%exh*d)N38<8Ka14 zLEf5UyA}kusH-&Gs6~o9E4pR+7(d8+5_e=#a}T(bxj;NVoQn6;6@F1B zx0#Hw7mjNa5wFa}z3DdOJ8mTH%H(r*=!^N2)}u1*l1C(YbgG%#8+oloWo>+fM>X2G=;W#QM!6}Pi)nI9Xv(5;j}2))Z8#B#k7nZZ0UT7HW?FZH13?HMzTmP6#<810XLvqvUV(#+(AYviSbG{cfzNzxEqgQq0mlc@7{L)|9JFQ=#Y z7#Fcp8U=jSB5$fDk!6LSDhqE2M#%_ZdL$DHmOV47h+~s|^`LHZiGgFLt*28B8aWWlwCQ|2| z?5y;RHEa4UNdC_`KU=@NZ}gyYa^H1PQbn3A4?}-)NJs81HozI8-ncId4RSj_@5#hs ze)}tnm@%zI;>N4O>P}9#(jdgy9)#1Zm`m!jECT`No>s0q)N+ov^Y{8yJiQ3v^_{+* z2F^?D!UAa_X{B@i{32WLBf=+TUDWJPly>?nU3q#__=9Nw$XnxGKvMH1QPtdu@u(|m z%!Z3^SBuY`<$l@_g)x4eixDh;CXrFL9k-mjvuWx9Z>Hgi$n84~FcNtE-Bw!?vk{Q0 zjQqW@oAD18Y$wG%K_{&SMmNLMhVC%BiJWpcd}vNNPwZ11-d4tSX(H-P+J}LL=Jy9p zI8fnjHIoVzH3l!VDfWkjDaVE3^H*P*(-#UZwuI&!D+HfJrrb`hu*F#pPZ_@ z?Nk3e!eW1_@#DPdDOxiq(fH;2cY&)x_GyuUb>d;s_D8sF2H%KYk&a+VhRm|M?3)$B z4SjM*i#(Hh@=;YOgxsZ<&+OtIvENY#_0cB9oF!)TSnG0_S8VF0ZD0`|e1|d=A-#!* ze1QKTgJH~l9tOu^Gx*UZ0on=|dt=iM&kOd^_e62ZLdI4GlN}=*a^mgm?Fp*p7R?=U zr`$Z;JQ@K@jw0a^rR-R|(9m`USkD22lZ5Tl>a2mDc@ld*_8M?K*rm$@MY>pK2f63( z4B6AGQ!yCp#4k+-2geIZLX9%Id}9@+Drc&W3e+=_xCZmayRcDIa)s6Qc&F+yeH0tuGC@wd0px*3w=MoBRQ{1hLpjPiKlJzAxG?(A{nu>nmyeNc6W-+dCq^*>; zre6N)O!M9nYrh#0_d1g(=OnR(BB`KJ58R<0f^@fDs(sYt*gv($Q=@g&}YCrK<1o`1$wHvC9;@3tF6+6|2c zNaf>~#*s>PJ7kl#Mdg?n0Qy3P5BzT9+s(s+BDKKC4$nAAr_#<)^dTWxcP?(%z~^rb z#9Ygl5*w$j;#SXCoLvMOgcVkDcJ}H_OGH?dLq*Rvi772rVmpxOL&vR@otL#L?&6_s zZO-kq1EUt5hqz`xz2&)2L(dwVPA7UEPU?hKm%RnOkjWfiS4oZG$=#eY=x{Wq=t90% zvQgcTgLrqajA*MQ^qnOQko87Z*Z(02zO$*gMR+3<9+y!*w1@Y6Bm1e?dW)ZSw-weaKI9$r(l zS|3{2rHQ^8R@%cG1r09Ef#!1(YirpL2~rC4tWuE)1X|nn(buy7y4dwMS?WI*GS}2O z+wbDsHziXGjruM}=_u)+Tw@t>-yf7BiIbkHa*6d6ELiDW$s z;voXq7D+-X?m-eLU{fDj9*#abB-vL7_EWPp2pafy`=P77dTL-3BqbPZM+Ha}Ep~Pl zdGKB=!52&=(tp==)-{;~j3l5p_J3DU*j4`pLBE-?tI2~MD8L40jSY>ZkZ{OgF!I|m zFkM3iV+k0dBADWjqAR5oMQ|XJOrUGOVEP$=OeT`q*8uOVKT3XG3H~u{7bdx$exbVtYa2g(+PWBhlf*pM1bK=Zbj=<3uQ&+n zeE(19U_+);qOQe6cMgmJ4ALJ*1)BuXRlIM;#hTRt0dEBV%}hX&NVtvszyb*9-~0)s zjRk7WB>7=W?4*x(T|WOeUHs!I{IL@viVD!Z2)eoOZ_xCa@|XDj3ibJaBmc1p{uuIK z^75OH@jWxJ^(#p)BL+q#(2qj;)q?unY5K{K`Ud=y7x6PtnXcAu%-(Og{~h|Ptot(* zOgA<*s^;$^@9&hq>ZCtYLRkJpxu%-_&hzV|{m(o#+&_5! + + + 1.0.0 + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + https://github.com/CodeSeven/toastr + + + + toastr + toastr + false + 3 Easy Steps: + +1) Link to toastr.css and toastr-responsive.css +2) Link to toastr.js +3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + toastr is a Javascript library for Gnome / Growl type non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + Copyright © 2012 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/package/package/nuget/toastr.1.0.1.nupkg b/node_modules/toastr/package/package/nuget/toastr.1.0.1.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..afb7a2269e6428d962220254794e2d6acdccc732 GIT binary patch literal 7745 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 B(vAQC literal 0 HcmV?d00001 diff --git a/node_modules/toastr/package/package/nuget/toastr.1.0.1.nuspec b/node_modules/toastr/package/package/nuget/toastr.1.0.1.nuspec new file mode 100644 index 0000000000000000000000000000000000000000..d73cd002ac3799639ba341567b4ba79bcd110941 GIT binary patch literal 3764 zcmb`K-HsbY5QXd767SIBf&j|e>>>dI<0t|WhyVqJz2nAfPi$}2GiGKSXL%#ui{}8& zSM6qI>~R(nH1hm(SJ%&}Q`POi{v6u_du408v0yJPv(hSCSz)<-Y46&(4ecX6gJyD@ zX?(8P+!j8&wc4KBnWR3E%mbU)J2tSfZEPyp7rHOBF6{N^(u~ffR@IXE+(x=8NiHR| zmUJa+Yw4fKi$Y(8wAUKL?pm^Kz0r%2UC6(4T_Zg|(>=GXR&Jzmrj@VsK9|ktS&%PW zV`^1!J(e4>>_;1YAp-3GLrS! zZqN05Fcku|FfBZn6MLe!rEm%MR8fH8efw5-@)7KjUE3eBg*9?eDsOmtsHNXlVLR!G zta(#QT^;>)Zk!cxu#&Y)d3hsjx=h;1mz{E6c=nMjghVMGWIkGojU%mtUrAG?5g1pC z#od{qv@G=li|$Oa-tXx~77Jkt|LP-8t3B%%ZgVOBu3G&5N-O7D`Ak2UlFRlX_xkns z`%+5Bud=a{Pnmt+iTt7b1BZ<)zy;nXs<)}41!Lm=@9X>hASUX(ln2<0{bgbwi+|t9 zVr92_d!`xu0i%JgbNfJ}c%6%r!I6k}R#1y{hDsOJM-215RGL5Y2_j9So3_7t4|5^XO-Lr?XN3^$EvvrO1 z>Y#p4G|@vm%N%?9N3MO~o{%DgANoa)iE$V10rEkbpW1hN&a{T^6JrP4h;Fn4bJki7 z8&9#QpL5{4-gmUygFXsIu!j6R(fy@^$I~*^jb-rb_wxL6%@DT-nO^xKlIN)Dh@%7C|ESd=%9!(`TF|nuZ+)_l6eI&^Sw?U_3ZOlYh2b{p8h!SU*$a(hUcmg=n+jCt_ zETG9LtBWNT$X(_dISZw}+>cs6%4B>aPJzcl9@oN`y{0=B?00z(&r=tAd;J+9*n7$v ztolN-$7hV_X`khOAL*Ioa;qn&#)*E^(53c;xCbB3_v>LdTR4N7oRr>In{T=--0G`D z=IGk?lY8~r}OD>^}}2=>;MzF>8qd~dzMV6 z^-sl-3qP@sPS{Jm^llH4eEmsz?41lQo{FxKpe8wu;VHbxg(Dc%_RGg>~9)bI*Gh(3~fDc=WTlztdy5_9)_xe%9(W+-v3U^p{KAd OA)464So>ceec^8;D{$ig literal 0 HcmV?d00001 diff --git a/node_modules/toastr/package/package/nuget/toastr.1.0.2.nupkg b/node_modules/toastr/package/package/nuget/toastr.1.0.2.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..3ebbc75571a73186612e9a1e796a8dffd84e2ff4 GIT binary patch literal 7794 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 literal 0 HcmV?d00001 diff --git a/node_modules/toastr/package/package/nuget/toastr.1.0.2.nuspec b/node_modules/toastr/package/package/nuget/toastr.1.0.2.nuspec new file mode 100644 index 0000000000000000000000000000000000000000..79dd9a25b2c75b861555c0fe94cc6a6894c122b3 GIT binary patch literal 3914 zcmb`K+m0JW5Qgj867SIBf&j|e*+l{b#!>W2=+p)b_&nz?JILjOHUOWfz zf7Nd0;BgibWZ52f*YU5vs@s44Ikt!P$~Jaw!Cu1N6nc_RuYozZ_^_kgLnm4jIljbWu&*d{l78DDw zv8*j*d8)msf4BE*xwRxFlE^)}N^yU#M`x^A){$aE(l$EGI&Nj-`8`g`ov0*2`fA46^b`b zxUkou$6!|B*f2SReRbfEE=LdR%^0x?%U4>>_Iqi@3|hGi|IvTn?%5;xBimc)Y~3QW zI%wXLO^lGp7LGmhBhxu>Pe@V05B?hi7XO4mqtf4+n^!ZZnCO?DXS*tS(truR&RJq5F9;Zj}3Ov?6^NZ87 zk|gI&L^#t#xzu{D3}5V#iaYQh?8rRz0w-V4)c9FZgAeS9F}8bf?sCsmNBk^h9rThc zoCHyHu#F5k!u*Z%k`+$VSk-Qp@B_VA6}WWiHfD;7j^h+w+izN<(^AJRbjsq3{$pq8 z)#~EkUnSz;}3>ULl8WEufMqjdruL;_0J`H zc=L(e?DO0oBa>AbF)Quws5e>3}GJay{M2ll|7 zZqH?j-&cON$7w+MwR_?@Vl;6Ar8RzV|NRX zpdQ>g>C*q-`f(iL4!OT+X6b(PwmCHIyj`@-v$<4Vnspee4@zg&U3mXHE8R$8TS7Fk LiM8f`QRc$m#6XIZ literal 0 HcmV?d00001 diff --git a/node_modules/toastr/package/package/nuget/toastr.1.0.3.nupkg b/node_modules/toastr/package/package/nuget/toastr.1.0.3.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..71335bed42e32a3e7906e76e774da1d2b54c31bd GIT binary patch literal 7761 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 IVmmndKYT(dNB{r; literal 0 HcmV?d00001 diff --git a/node_modules/toastr/package/package/nuget/toastr.1.0.3.nuspec b/node_modules/toastr/package/package/nuget/toastr.1.0.3.nuspec new file mode 100644 index 0000000..94071f6 --- /dev/null +++ b/node_modules/toastr/package/package/nuget/toastr.1.0.3.nuspec @@ -0,0 +1,38 @@ + + + + toastr + 1.0.2 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + https://github.com/CodeSeven/toastr + false + 3 Easy Steps: + +1) Link to toastr.css and toastr-responsive.css +2) Link to toastr.js +3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + toastr is a Javascript library for Gnome / Growl type non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + Minor updates for long unbroken string going outside toast and new feature to keep the toast around after hover-off for an extended timeout. + +Set extendedTimeOut and timeOut to 0 to avoid toastr from fading away. + Copyright © 2012 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/package/package/nuget/toastr.1.1.0.nupkg b/node_modules/toastr/package/package/nuget/toastr.1.1.0.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..555e321ad11fd7da94e5ead21ccf202c8924503c GIT binary patch literal 7789 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 literal 0 HcmV?d00001 diff --git a/node_modules/toastr/package/package/nuget/toastr.1.1.0.nuspec b/node_modules/toastr/package/package/nuget/toastr.1.1.0.nuspec new file mode 100644 index 0000000..a65e371 --- /dev/null +++ b/node_modules/toastr/package/package/nuget/toastr.1.1.0.nuspec @@ -0,0 +1,35 @@ + + + + toastr + 1.1.0 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + https://github.com/CodeSeven/toastr + false + 3 Easy Steps: + +(1) Link to toastr.css +(2) Link to toastr.js +(3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + toastr is a Javascript library for Gnome / Growl type non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + Added AMD support (and backwards compat with non AMD), toastr.clear() method, optionsOverride API to be able to override options for each toast, added onclick callback option which fires when a user clicks the toast. Also cleaned CSS, merged CSS files into 1 file, and reduced jQuery dependency to v1.6.3 + Copyright © 2012 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/package/package/nuget/toastr.1.1.1.nupkg b/node_modules/toastr/package/package/nuget/toastr.1.1.1.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..b5cf330adea0a44af48eade28deca9f20b0e4c56 GIT binary patch literal 7789 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 l(7z7 + + + toastr + 1.1.1 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + https://github.com/CodeSeven/toastr + false + 3 Easy Steps: + +(1) Link to toastr.css +(2) Link to toastr.js +(3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + toastr is a Javascript library for Gnome / Growl type non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + Added AMD support (and backwards compat with non AMD), toastr.clear() method, optionsOverride API to be able to override options for each toast, added onclick callback option which fires when a user clicks the toast. Also cleaned CSS, merged CSS files into 1 file, and reduced jQuery dependency to v1.6.3 + Copyright © 2012 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/package/package/nuget/toastr.1.1.2.nupkg b/node_modules/toastr/package/package/nuget/toastr.1.1.2.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..ecca818d8e60035716df4de73d8fdde3828b8141 GIT binary patch literal 7850 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 literal 0 HcmV?d00001 diff --git a/node_modules/toastr/package/package/nuget/toastr.1.1.2.nuspec b/node_modules/toastr/package/package/nuget/toastr.1.1.2.nuspec new file mode 100644 index 0000000..96caba5 --- /dev/null +++ b/node_modules/toastr/package/package/nuget/toastr.1.1.2.nuspec @@ -0,0 +1,35 @@ + + + + toastr + 1.1.2 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + https://github.com/CodeSeven/toastr + false + 3 Easy Steps: + +(1) Link to toastr.css +(2) Link to toastr.js +(3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + toastr is a Javascript library for Gnome / Growl type non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + Added AMD support (and backwards compat with non AMD), toastr.clear() method clears 1 or all toasts, optionsOverride API to be able to override options for each toast, added onclick callback option which fires when a user clicks the toast. Also cleaned CSS, merged CSS files into 1 file, and reduced jQuery dependency to v1.6.3 + Copyright © 2012 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/package/package/nuget/toastr.1.1.3.nupkg b/node_modules/toastr/package/package/nuget/toastr.1.1.3.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..068a54114d40797f14f66f2bb67c9b558953b222 GIT binary patch literal 11781 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 PU2K3cDg;8gzJL2KJ1&oG literal 0 HcmV?d00001 diff --git a/node_modules/toastr/package/package/nuget/toastr.1.1.4.1.nuspec b/node_modules/toastr/package/package/nuget/toastr.1.1.4.1.nuspec new file mode 100644 index 0000000..c3fe237 --- /dev/null +++ b/node_modules/toastr/package/package/nuget/toastr.1.1.4.1.nuspec @@ -0,0 +1,40 @@ + + + + toastr + 1.1.4.1 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + https://github.com/CodeSeven/toastr + http://johnpapa.net/wp-content/images/toastr-icon.png + false + 3 Easy Steps: + +(1) Link to toastr.css +(2) Link to toastr.js +(3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + toastr is a Javascript library for Gnome / Growl type non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + Added AMD support (and backwards compat with non AMD), toastr.clear() method clears 1 or all toasts, optionsOverride API to be able to override options for each toast, added onclick callback option which fires when a user clicks the toast. Also cleaned CSS, merged CSS files into 1 file, and reduced jQuery dependency to v1.6.3 + +Fix to the toastr.min.js file + Copyright © 2012 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/package/package/nuget/toastr.1.1.4.2.nupkg b/node_modules/toastr/package/package/nuget/toastr.1.1.4.2.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..e92fdd46e409b4a8742af5a05686d5ea49b15969 GIT binary patch literal 11772 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 P#X>ShG=VUV@4x;Fyv>uu literal 0 HcmV?d00001 diff --git a/node_modules/toastr/package/package/nuget/toastr.1.1.4.2.nuspec b/node_modules/toastr/package/package/nuget/toastr.1.1.4.2.nuspec new file mode 100644 index 0000000..e9c1ff4 --- /dev/null +++ b/node_modules/toastr/package/package/nuget/toastr.1.1.4.2.nuspec @@ -0,0 +1,40 @@ + + + + toastr + 1.1.4.2 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + https://github.com/CodeSeven/toastr + http://johnpapa.net/wp-content/images/toastr-icon.png + false + 3 Easy Steps: + +(1) Link to toastr.css +(2) Link to toastr.js +(3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + toastr is a Javascript library for Gnome / Growl type non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + Added AMD support (and backwards compat with non AMD), toastr.clear() method clears 1 or all toasts, optionsOverride API to be able to override options for each toast, added onclick callback option which fires when a user clicks the toast. Also cleaned CSS, merged CSS files into 1 file, and reduced jQuery dependency to v1.6.3 + +Fix to the toastr.min.js file + Copyright © 2012 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/package/package/nuget/toastr.1.1.4.nupkg b/node_modules/toastr/package/package/nuget/toastr.1.1.4.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..badab22354ec099b9bbd27e78cb42552a32a2d0d GIT binary patch literal 11802 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 AK>z>% literal 0 HcmV?d00001 diff --git a/node_modules/toastr/package/package/nuget/toastr.1.1.4.nuspec b/node_modules/toastr/package/package/nuget/toastr.1.1.4.nuspec new file mode 100644 index 0000000..5578b3f --- /dev/null +++ b/node_modules/toastr/package/package/nuget/toastr.1.1.4.nuspec @@ -0,0 +1,40 @@ + + + + toastr + 1.1.4 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + https://github.com/CodeSeven/toastr + http://johnpapa.net/wp-content/images/toastr-icon.png + false + 3 Easy Steps: + +(1) Link to toastr.css +(2) Link to toastr.js +(3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + toastr is a Javascript library for Gnome / Growl type non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + Added AMD support (and backwards compat with non AMD), toastr.clear() method clears 1 or all toasts, optionsOverride API to be able to override options for each toast, added onclick callback option which fires when a user clicks the toast. Also cleaned CSS, merged CSS files into 1 file, and reduced jQuery dependency to v1.6.3 + +Fix to the toastr.min.js file + Copyright © 2012 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/package/package/nuget/toastr.1.1.5.nupkg b/node_modules/toastr/package/package/nuget/toastr.1.1.5.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..9dc04428750b03b31c15c87516a50bb5417d1a29 GIT binary patch literal 11634 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 M6{ + + + toastr + 1.1.5 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + https://github.com/CodeSeven/toastr + http://johnpapa.net/wp-content/images/toastr-icon.png + false + 3 Easy Steps: + +(1) Link to toastr.css +(2) Link to toastr.js +(3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + toastr is a Javascript library for Gnome / Growl type non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + Now using SemVer for JavaScript files. + Copyright © 2012 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/package/package/nuget/toastr.1.2.0.nupkg b/node_modules/toastr/package/package/nuget/toastr.1.2.0.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..a63ec724b7b5dcc1851dbc027152d1b9678116c2 GIT binary patch literal 11716 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 Sp`qwoTr@LO6ENWVcJ*Ju;C-L~ literal 0 HcmV?d00001 diff --git a/node_modules/toastr/package/package/nuget/toastr.1.2.0.nuspec b/node_modules/toastr/package/package/nuget/toastr.1.2.0.nuspec new file mode 100644 index 0000000..d667d56 --- /dev/null +++ b/node_modules/toastr/package/package/nuget/toastr.1.2.0.nuspec @@ -0,0 +1,40 @@ + + + + toastr + 1.2.0 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + https://github.com/CodeSeven/toastr + http://johnpapa.net/wp-content/images/toastr-icon.png + false + 3 Easy Steps: + +(1) Link to toastr.css +(2) Link to toastr.js +(3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + toastr is a Javascript library for Gnome / Growl type non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + Added getContainer(). +Fixed clear() bug. +Removed semver from file name. + Copyright © 2012 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/package/package/nuget/toastr.1.2.1.nupkg b/node_modules/toastr/package/package/nuget/toastr.1.2.1.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..34bc06054b03e4a9b9fe5be6720a1d0996b82129 GIT binary patch literal 11728 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 gwRj3Pl>ctN(NV`hZp@(|Nn9)x6J!^#h($ literal 0 HcmV?d00001 diff --git a/node_modules/toastr/package/package/nuget/toastr.1.2.1.nuspec b/node_modules/toastr/package/package/nuget/toastr.1.2.1.nuspec new file mode 100644 index 0000000..bbd307f --- /dev/null +++ b/node_modules/toastr/package/package/nuget/toastr.1.2.1.nuspec @@ -0,0 +1,40 @@ + + + + toastr + 1.2.1 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + https://github.com/CodeSeven/toastr + http://johnpapa.net/wp-content/images/toastr-icon.png + false + 3 Easy Steps: + +(1) Link to toastr.css +(2) Link to toastr.js +(3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + toastr is a Javascript library for Gnome / Growl type non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + Added getContainer(). +Fixed clear() bug. +Removed semver from file name. + Copyright © 2012 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/package/package/nuget/toastr.1.2.2.nupkg b/node_modules/toastr/package/package/nuget/toastr.1.2.2.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..75ee4ae591e6f5584760da953566a91b1f00eabd GIT binary patch literal 11719 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 Xse+Eo#{rN4?hSwuati3Pe*5%aW{yfS literal 0 HcmV?d00001 diff --git a/node_modules/toastr/package/package/nuget/toastr.1.2.2.nuspec b/node_modules/toastr/package/package/nuget/toastr.1.2.2.nuspec new file mode 100644 index 0000000..cca8187 --- /dev/null +++ b/node_modules/toastr/package/package/nuget/toastr.1.2.2.nuspec @@ -0,0 +1,40 @@ + + + + toastr + 1.2.2 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + https://github.com/CodeSeven/toastr + http://johnpapa.net/wp-content/images/toastr-icon.png + false + 3 Easy Steps: + +(1) Link to toastr.css +(2) Link to toastr.js +(3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + toastr is a Javascript library for Gnome / Growl type non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + Added getContainer(). +Fixed clear() bug. +Removed semver from file name. + Copyright © 2012 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/package/package/nuget/toastr.1.3.0.nupkg b/node_modules/toastr/package/package/nuget/toastr.1.3.0.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..b4dfe38ff44c553f391df402ed4901dfe046b099 GIT binary patch literal 15020 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 + + + toastr + 1.3.0 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + https://github.com/CodeSeven/toastr + http://johnpapa.net/wp-content/images/toastr-icon.png + false + 3 Easy Steps: + +(1) Link to toastr.css +(2) Link to toastr.js +(3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + toastr is a Javascript library for Gnome / Growl type non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + Added onFadeIn and onFadeOut callbacks. + toastr.options.onFadeIn = function() { console.log('hello'); } +Added option <code>newestOnTop</code> to show toasts in oldest or newest first order. + toastr.options.newestOnTop = false; +Fixed margins on full width toasts +Added LESS file. +Added min file for JS and CSS +Added missing vendor prefixes in CSS. +Various minor bug fixes. +Added unit tests for new features. + Copyright © 2012 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/package/package/nuget/toastr.1.3.1.nupkg b/node_modules/toastr/package/package/nuget/toastr.1.3.1.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..a1eb1ca399aea4dc5ed838b95d5fce764d98f2b5 GIT binary patch literal 15568 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 + + + toastr + 1.3.1 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + https://github.com/CodeSeven/toastr + http://johnpapa.net/wp-content/images/toastr-icon.png + false + 3 Easy Steps: + +(1) Link to toastr.css +(2) Link to toastr.js +(3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + toastr is a Javascript library for Gnome / Growl type non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + v.1.3.1 +Added new API for toastr.subscribe so you can be alerted when toasts appear and disappear. + +toastr.subscribe(function (args) { + // args contains the toast options and data +} + +Added support for glimpse.toastr.js plugin. https://github.com/johnpapa/glimpse.toastr + +Added toastId, state (visible/hidden), startTime and endTime to the toastr info response (available in the coneol, glimpse.toastr plugin, or via the subscribe callback). + +Fixed bug with stacking toasts when clear all toasts occurs first. + +v1.2.2 + +Added onFadeIn and onFadeOut callbacks. + toastr.options.onFadeIn = function() { console.log('hello'); } +Added option <code>newestOnTop</code> to show toasts in oldest or newest first order. + toastr.options.newestOnTop = false; +Fixed margins on full width toasts +Added LESS file. +Added min file for JS and CSS +Added missing vendor prefixes in CSS. +Various minor bug fixes. +Added unit tests for new features. + Copyright © 2012 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/package/package/nuget/toastr.2.0.0-rc1.nupkg b/node_modules/toastr/package/package/nuget/toastr.2.0.0-rc1.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..fe2dabd4a1048e60aed89d3fc0b8c6ba2d0b2827 GIT binary patch literal 19421 zcmb@u1#l$6k|ij$7+cKD%*@H5#i&CK7m{X1uN zWtC}}74BXUnI2Wo(>Y{p$Uk0ou;ila6y;&(pdcXs*x*3$Knxs#)=rEJ|JW1d zV}VfRqWzob|GK+w@8%P9x3MO21v)xe*xB-vFf%Zb5CLtC?My6e&G<=NoK5MuNCXA= zl!4X&=f4t8<`(u&M1NImo%l)2ot^D@7#W?6&4D%mCk8uvpzYrlQ#(f+fb-u|M>9ry zfUy<849LjB#Kgh)w>SS~gXEuW5~+IF1OGRRHWtQ?c20Jt&J4zOHveJlZ@>PUV`gGx z;$*Y|*jktZot#OCQ~{1=KxcjuMrS*Kld~g(t&5XA(3pfs%7mXp+1QwciJO(%n1z#x zm5rGhKtja$Kl%3mPvc><0XhRr0L}nLV>?G6y}jdKZAWJdpwoZr+y8qtoPdt57RErQ z|Dz5gH-OcMlbaRD2>`OO8FO-Tv6!*|IR75AaT~D#fj|a(CmR!E`~MgphY1@qlL;Fe zC$}jJ8-V5Su>X#a@tpw* z)^34kEc>_6b$f0LBWK27=(1k*kdDPMm0aKidZSSo5Yj=wfNsEu!5R~+P& zonAs~lxp~Hs;HbL9)1=xkPvlP)6gS(`tD_-T%7o^h>YgU{105ez4S(11j37ASK&|} z)ak)}V*{wIy5E;6eDf|LY;BB`VMFaR!U9&jf26uO*p`P%v_|8qwWFhT!4&Pp=&}(! zZ2qDH2Z7^qiwN1Dpal=@yl|M)nRA+ps!k*+Ap(3B(&)DldWl*G)<=m3rIX}i zT!}HQ?_*h&9w?-Ifcxjtd4g>OHGSG(2I=w|U1`)Bq_1-YE*khTE6g`+{T>At>s^j~ zIL7)569?Gq1|NS(ro@DDB#^p{bZw6+SN4 zrr@aiWOCRG;p!5zL4ly;?s1Kqj(<)I$y67xg8>#%+l^isxBr8LZ##&!ix3OzX5JH@6!y zy>8WeEoYMRwsRH`ye89$cP>ajdJ~5(GU7X8^$)kIa(f?auuIMBymTf0z>YipX`3ai zIN)>nVoXZ9Y_pq^@=!y&|!WagE83c6@aQ2E*NJuPxts8 zxX|MfHuS0vB!AS^>9*SqQ_C#6@6RuokP9n4HS_x47avmttX%3L-w67BFiBUbzn19= zf0$(5f80s(RlczBK@Q`2Zk|(|tR4N(dQ{Udi=*pS(w(LY`|Om3jE9$wTlduCtbKR* z0{8ns?C6}{?OsRhN~nAT?WzzZ_|R}~18q%>=9K>B>gqO5YvU)6*;LWrQeE8N&cTm# zooHZUQIg$vrcw>iKjYssjA+sKS3mt3jp$SHapuU<0hw@b{6x~7>M!{+z#0@R*`+r4 z?9zX0@XymXd#>&r2nPbG%PUJ)kl&vMzgMVb$S_< zWv;3$oXx0^?G=CA{qp}4i8NPft`zOlve7nK+redi< zGKY5`f5D+>6zp{#!$pTEMi;&Tlz__sC-gQ`ouD^={7Q6=E~dRwVEFJ>Oz(rI&8=~m zyzdRfN~b<1GEH|W0pGTGu%0-T*9DO3j#2l|)Ac85MOlaUfCHA=?(EA+K3erzN!j~1 zH>9$$GE{swl!G0MW+TpYXRAHiK7C*o!5fgquCi5`=YVh2>_VB9*{iNzy`z>8=#Yku^`h&B zCfxJ%q4efCsik6E!4ub_9M!N?_EVKR^RiS{u-v;2IMxFjkY|89&{GumUG-=_*~~AQ zZ@oCV_MDYI4?MAt3`bN9{$%Y@cwd+<(@%7nweaFcyT7P-bLx+l0`|vTdn(UZ&DLtH z<6p4cNp#eH&P0^)9(RWZ6TaW}#|XZE7-KFgSao1;x>EW;@;Y?_6oy@mHFJ%R_#ew6 z1|8c^OgiJ+cpPitZdhb5`JOHjk6)kY{Hm;|{Gg+yZWVv%qwA-1n(A4+TeGu8L2hJvJG5oZ*Z!g zn(-mBcuUh|CfkOF6Y3d789P5X_UOlGX+JBE#f#6&O7(iE+7lV`IX&mzo%|m|^~Br1 z;O*4zkB&ecyt-g~^=fK5Pc&Tz5Wn``3cqy+zhffhs2uEG1(nBEec9mfqxq%~FOu`x zHs^HJJRQTz>wav$-CT7rR(#@b*v)otntXP1hH4n?48je#MLKMwb=gJo{`HR>wd*gX z!FJ_4{K=fs?S&PMN{4bdC5+tSK>L`S6Ou{eYfUo2kDb+|4|n{YJ9uBmi#b9iLXs@4 zQg&ukqHmjx3r)n$!JGI_FQ61~6Ia`4p2wgr*dXnNMJOm#(qs74DWL2sO+JtyO{>e4 zYpP8t!mEcO1QEO8T!T4jpCCGi~w zw+p-m)SV$O@jwUsvg+{r*&rWn#i0$W`$<)_T)UBEXOWmtiwJ7RgjVKQfyKEzJtHB(u zkv#+`W`=ljR3qmjLf8O1NuhCmc!=1us;5j2`_SVxsVdDKLaY!(sh-zAQCoAPTKiOO zBP`~XYUt)8vHgS6Fzr=NCAP_v$PZ73@T{$+aFJQK`4QJYDdKnajpaLRd*!t2btb?t zVwR$M9LTd8Nq7O4IcV~k-Xu|3he*Yp%eT1UHhTdv!*j%1Fp@dT4{L&lMJ>J1Mn8ik zIx`^AVtXyUm^Lg<7M5cdnqH-|5VTa{eP4Euw+!;xeux7Nw)nbIm^QaU!UaW#!pe^$ zsp)Y2#<0%uP=+Fbs8Ly~@vVDBSRkwhN=M)5agHsgq^VU>o1n<22XfhT(wY0M9vmjV zIU54-NCV>RqYIX^S(}ypctXw2FF5W&1a%6EE>}K%QP5HsFux~&lC4V=kf}8{CO3`9)P}r*OAOcia+_0M49%ahR{lJR4uvm;l+NVL7g`5d^KbqI z8wQo|J+XE{Tm-kOh&gH$jn@`bnKOi~#DPX09KB4n4yW9Mqj$$*7Khu_`Z;z;488g9iDTqY;i6##)oIlOZkpGHMMU(nj*FP!}W3NzQV|B|_upfdAVH zIgjgVT=76BqQr$JHQT5KDx_$#V2$`lVyKBnY8r|7wOb{h4qgCiW1H;s6bI`cwUm)v zv1)Xhi0AwyiF;ygaj=~Wt7>=_#lfKdD^4d5^~gCRo&aa(9`?+y?`9*F7B87P6fm+BiWp2i4&F6I%o~EBFxeneDJU__kE5CL zQ4pkPBTE=?6no}b_+VDrk{z8p^(A+yjjMKm)=ivs>Rb&1q#tp6RJxifMzo1mQ(4Ts z5=PXyA-*DaKw2LScOnYpGJ8oc*^% zGKbueB6x9x5^2hxpjg&+%VwHJu&sJZ38(HkrRg+8(He!V=Y<=6NMwC-Fj^Ez8{j@J zo{sbN6WGLtebm{6;oN!16%ODN@TQh{a`7IgR>qQn2Z|9P`IBO>lSjd9(`v*AXiXHy zacxP~G_4p$66(#ORbfErUB+%oearTdHq0kM(GKV%rw(}f%LeKc*lv5*WTIL)6($vK z@NhD)U+hUP!)$X!@CYQo)X-YjHxOYpL|;t4Ay8SHh--8V_#?onwhmGZ7RmC(FqjR0 z2KIEcioy>UBWH6#Wzw07mF?oXwC1!7p-e0lk;%+qNh6%o^mlpjNUF%jw%{W)Fx0$G zSwoXYJSBmQ5;W^T*#Dpw3fR{q>os4Yx#zOL4aG}A8rp%6_CDdN5hOJp8QOI2v?X_m zkH5Ro)|1(FroGHnY^?X>B4|1muG32XjZc1E*BL!&2FHg_r_H#|wP;CkS$-$^UF%3F ztHC+8RiBwWA$4ZgwfMBYQy|IhmU|7?N9|_pGLnwtCh~aV7hfSB1`Ax1V~=|iu4nLU8E$6c_)l@^V*j+%L}S?$ zxUD!f0U+f@>YO6xZm6;HwQ+J!i2T)=&r*I0oS(wsTk?s%>WnINFvdfFJ%dJ4!}p}x zSmvZL#y6ez6$+Bc@986zOtWM|5N;AWfGn&l{lmq;K4M($8GKErx!<$b)p^y;f>p&^ z-|YgrZCp1LMw>~mP41T!7^fy4Yek--`<5-9T1z=vy!D+4wy4ghp8?wh@NbNNs=EyN zf8*ORkr*_E8t``W{Twx9aV){y;iMTlo~Pl@3!7D$mU|e-0|K3Iy;Qm*4Ic^oo^ndB z#a-Rbq&;1a9(<)Qk9JLI;z@3gj%oL=oeA~Xa8IrxpWl71*fw;eKZ*&itE+3h%4Z+z zfU*LU-JDUQW+C0a<>HB(jVA^T&)VGKpMq-9pHEajW~*s931+($S~=Imavn%S-5frl z{u#V$S-((O!-Ig_{RQuY{~Eko1OG4RoohWgU$SX>(dt2vOU=qt4Lu2lgvPW|p#0mx z8M>lUPDlo*qlyry+2l*@9a9clHxuYqT^);8(c57Kg$jb}MW^vLsq6ds*XOVOs5lKi zccs@mg&5P!75RLeCO1hzUzxLQg{bbY_xbivCISA;V#29E#X}IgR_s~4Mc2UYfSaQU zLEq0({ni=X{^+}yZQK59bq0btoG?i{=c(|RcAL^kMFq1oq4kR!7 zp?NeykrfD5N6s-MJO+$`R$5vzAE|>9>HH@87+j6a91e+jhGpR5$>Cscremz8Ck51w zMp0hPSHqtsY0iIFp(-4>Dsb!pOZt+J$ zUJPa8JEH)s#;gf@4geXw?ts&?GrSnYRwJ?4_e_{h#wVGsd?D0I)yqE|pxd!St z#ucG=P4UbuLcoV7i8yYMs6%o`h^X~hJu5=|QiGAXq>}aBy@%|I%C!VDffZ`ogQadu zbPnGN_G_0IxYs`e+^x9*5F>k=cgu1}xaM6FZ=MgDXIZfcQbroyKK;K0dG@tgEqM)O zz-G;_VDGbp=AR{-)(xt1j*7LDw*$P&sRu}XU}6oXqQ8{CbJn^@c7IRgIk3X)zVtqi zEkM6zcqB2o!+Er(KAR_>nL@tBUU9WCAvMqCX%MZt$!rKXn|fu z(JO-_aiqUrx(hBJb|wvWiI`@*66HS6L~?J}8YW}f^Fxf*1_$VEegN55F3DJrd1Qd2 z?`rnJ$?3q+-Sze7(=JBMJyXMjRT92H2t2OQit@9hvsxP^U4&4kjT#A-?-UlB{w!m% z_eaKY?8-2hom?BKj-qg7Trh|y@cr2QZ9~eMZ3)s9v7<3BnT7Z;sKbQH zP6_!f64Y~OZR79=DJu00u0pd$M9{}PM_UyFWW4rod?Kklc1DFR6qV?a0P0WQ^b)5} zeFsaWliA+nD3%sIW7Yhf?yUur<{RA6PC-o0~>0a)zA35u1VVn6n7(98c=N0Az1 z7K;;(;ruw8q00q9+lZ|;@z5*+IE7GPOGtzX4UBH{e0;=~Z*19(l)+(^5y@I+xHvNR zA4)7^qdV~o;1GV+B^5T9oC|UeN5UKIFUnI}Q8>R4?T}P*>n*Qh@Udg-}k_n+vn=r>~}n5jW0&|h-(+p@xDG^r8k(28-r4&nQpb17JFn;neWuM zVwt*kWLmh-+zLySDKk)XxaJobe;tWTuuCCc(#oo5R<%e8nLTdxf8g!H|xK5iZ(94d0d$w60zrgELirt zJmkEiYQ#$K7Kuj5$bN$I*^HOnUZa2OXlk`EBt?iLd8m2|A4WgamdkLiBzmb=2+@vg99V zdx0ePNapBrUjssB5ft1t^8t6fPQ!M?O$D+oted#d_l9hnW2UU>2M@v-RNOFp1!nZA zN$Og(IchV6RC3Z`K+&3@_O8^CGbWQQ;r3+$@!w#@7i0oNqU`!15O8L$CmCp%6VaBBAVxy~ zk807P0+FJ!l8NVerpr>2%g`2CF}1F{H;&Y2@MWBMAc2y1x0ypC9kj?Uy=HaEB{K{w z$dY0uZ1jT`fIh~cNQNzWA)Q82l)YqTz9UtUKVts2Myrc>xDRVC1n6wk*q4D%trbd= zsYsca>uEZ5wl|N4o*+mUYxla?31}T2H4zHJ5l|Uk&n}GVHEfGFkvbD8HKZ@xY>4(M zje$XFE(i$eE44seQ`EkTuKNYd(2?h`m--v6=oyd+7wgeDb5g-2TofU_?tmk9Sf$r+ z6Zwq1hIz-O#IM1P0^G{v$(sdJk`+hBgtxAm##LxjqvogL<5Ol`0}!A{`K+U)dDGKY zO^9sjRm^tlCbD@f0km}&1qzS?wf=X7O<2~LJ|5IL9hFN)skZp)eYBB1zXW!FEJ>a<~fD+cGfmepBO{kr!W?a<8 zZ|v0goU(S}X`X(3dvaQbqD{jt)btV#or2&mOJ*+wQA;##T; zM6fwG=S8MiEY4~4h>cj12sw`>SiXy;+o5MC0rtXAC^o3G;pT;!n`o*j&=9rU5Gt2E zCD)wax0htzom?Ij_|~P$i#|3PtDlBlGVTvo-(x1P>*dep&>ndFK3+R&SrE0}-!b+l z&NdXbRIb-rHW=Xy?(?T<-)Nm5Z1&*d-*(T?0|z`jaNVu6^n0tSNDOiX8A+-YGp}jv zo{)3YC^rX{&hWD&wx#&7)Iz>qitX}@y(Idf14EEkqhj)u_;lf=luO$Aw$Hkj)HOJK zO+UQmrGFn?zP7qlG)IITz3g3jdcDZ(SGK3SO*34Nz|CI1Mt3;1az8?;b(~a5*DD_u zhM;|9;CvE)oP2%%pn6sNXv2T~e)6h)K=U_`MNi-=ro^4x{BY0%y=~M)(Xco4WBrBCo~u&TwRTKYw|!eElJP zL8m*pO4~}i((}T1rNf^ooM5Dl8Iv7(J>LGh`I}NG^R4*J^B@Q*t}oc+3*PT}g;x4> znwIgR1{D3;H&*9w5}Xxc9(+$5nNdvOy+@+M{a z9x=pdfK+wPVA)+x$iGc5-5wq8osHT0MRHUmekjP3(#CKbQ=A`u6*i{;Wxmfi)~*pl z2ra0yFnH>LUJ$G|ecds*`9{V(Jd5>frL_SxvvD3@1?E$Grz0eww>c4`*tVu3&R zyIW6t){ETC}cpqyt!>*{B7%3YW%bbUl?e}+{yYQo2B|?HZ={`I!k0ACR z24pj_=rO(Ia)j$6<^3_uWWqV~ka`;yPVnO0egV9LhH{VEd%teWML6+G2^XF=nY|_J z*XMm6a2&UH;EpW1mvhYy6Y7MAAuee7<`_`2NR5y;#VDhJ)FqVg@ zp5AQ*+Pk{~1mA(?@PjUj3!7udu51d#-AV#bA2wGR3wCVpixKHDX?lHBgk>;3sqjbL zCZHSy;pgMS&+2Uo4wN(Nud5AjTZNb6DVFl^EgIJv6rVU}oGm#{*Edf0SCFlr8m%vy zucEJuqG$Zo7zX)Ib4(%0%y<+1ZlW!I*gef4*DU(%6rZc6n{AWTo^D_r z!(*!Dx!S06494z51-)Etrmv@et00E5mAu2e zs1(fWG>QWWFbv&o8bn73c53qN2zyNYx!-j}uBBr+zj4{Jp`#0H#a)TDA}{E28?u4O zVm2cHX+m+899L%?*M;k}zsJmz+jkyKY=b|m^OiJBg_N(=nc-~AT&!iOg;uF-?h#pO zOd|E~|I!J~v#`&T6Rq1$i|fU!jMlHUY*c0sR72q~$6k#ytI9>a-?VuD(6Dyk|n!mv2tlHU<>N%HEPwZdTa5+&Yp>rrQw&5B%BQ{ZN#+!{pm}oA{l7E#IR%Mam?2;8#iAkmSFzCd@nM# zwS5+%0Pv>J`dtRm;?Cj%*O}%rK2uqx_m^qGPwFvwajkWa58I??pjM*a9~R^$Mxe6x z<4LJ(g;f|1OMd|l>3V)EFa;WY#`_^(%*d>#$=(YmV(+G%pE@= ztLlwGlB4D9acKyHi+L6nUc3a{bySJ3QAkQYt4D>ypJT_m0kUuP z;2V$zadzAth-04BxR zi3p9Erb2a3U0DxZl$h@42n}NAN>-XS|0(rKrqZL3=MGv5`+YU<)Z-8i2diOb%Snx% z@2({AQg2WiO(6x3k2GoUA!-xI=~<@jR2_A!s`mxChYzUy!Z`}Lflc}!HBA2Av@IGF z0tX6~^H{0@!Zy>a z#)zY$iEe))r%71xdSp{|Jq|Z8j;^{DBO_aI|4Ndn>Bp~X9DEWQEb`}c?8b~=VHqIX zi)cCTU5;f8RlKs&et!bB)fpjxdp!kUK!l&O=3*CACI_5CK?qn5Nh8D!o2lc4wM8#= zHH{DH(VEg`MLpWdBxcpEd^pjgYr{~Q_=rOQn377UAgKZ_Slp(9nY+bk7vQU81U$^b z%(Y~8K{=Pz2bel~KLH;ewo9*8nYo8GX;nW1AoZE*41MJsb>zmsRI<@hDLFKs3Mt$~ zT5-m|44wnaU&5%pvkzA3Pk(YIeX&E8C5=H%CQX$tqwz8%W4>*OG)h&btbghF&}0>g zRggbo%J2DB-8`HzEKH$sCXEF1xnU?s z*ea_C84_#pMM7jO;Uoy#dS<~kc?+pRV6doKv-pg2hSMNwXK`As)ymVqX!;5>+*KmQ1mDvu~F2 zGV2lykRF`t+YZk=_>s?j6s6-you&@+)Wt9Vj?{e8?{Yh&=K17xA22KujGQuGPTlY$M!Nc4@M&g*i!+;u&(RKf;qbWHB9* zm#V~?d-axD=K?62Tx9Cv8`D|VKN{bnJ)QjFEzqPv-^SE*Uo33H*jG%u<<=|TfaF~{ zBu1x-J|StA07uPAzG&q7)4pJDoTMV-2%a_*$N;FckD>Xjw|zOX_RFC3^Mrbt)bt}1 z$e|cpJ$M_u!?H9u+wSXL_Vejnpw}R$B>SiqeW!cOo&Uo}j z%MBmo`**gbnuYTw&kLdyg7tv?n?6*-{Yg(pmZP5JmHCFn{N(&1*3_)-QGl)+A*EcYR>QuE}zf9cPVSwTU2`L zJaLJw`Fs*V@6YA!yG)zX_jsgy%+67#TULg$k?9Jf+Yq4ZSv7hF>Zmkz9gmtWnp6CZ zv{YAF2IW9II<~=G;vO!^l9-LVxN;oxx8*W@AJbA2=^if$w1jo(>bYkXB@?`5wMh{P z-;NeCZUwCX-g(?Hr?xTdym0G8nv{q^+h!Rtn7jOBYMG!8eXM88+QYLn56LmPUpj1f zOO~Vujxl^}Cko0$oid$z5N~=;jink=G))oBJ@Y?Y`@@4#&7$@6~aZNAP?uBTQ(Pf+!@sF;nVk? zSIa7@Cqo4*-XXdtKVOBRTP-~gDB*uQP4({=eR?S*& zo2PTN-N(RZvXsBZPCYj^?9+qHTZMs#m*X)=h!FbQkFs(&#v)P&D|-9jdV$ze)$9VT zrlcfWxwu;9)-&^Eh1&^nQ1-O;w(2b%I{`)(cHa!awvziX1Ay8r<3}tZEjb7s&%PzN zln!iT)s%ny;dZ#hwou2rksWvmqgB$6Y14ggV3$KI!*nsO!sr{CefSGQL=mG!?|Gtj zag{26r5Pw(nf7lJJz2nShiyE75(q9idO&gG(#1yG;l>5KWB*0ixQa$} zk#$om%*HF)=N;j7A4{n)vd^VmC9W;%D*8G=!A)DW7}DVhahj6ijMvGYGx0eJ3BG|> zszF@e8@H%Tc_z>8x!dZ2JA;HML7Ro-oYFaeO@Sf2q@+^TbL1KZK>O#1dLDYYGwS@Q-BLqJHAV|Z*Wcdo0pPXZnKD?aa!IT!0Xs<=vHjUgiHYu2-NfC~skfjo0ag4OR;cdwLB=hZmytfUIjVV4;L=-a_Lm&k2%zczAy_5yQ8dDX{CwneB7!x zlUYM~nn<9Gv$Z2)Y-O!$glY8b7#c!hA0d+dvYI^QFttd)55NBgFf3ni_(j?+R z@n_w=`Gefd+^nt0I7;Vly`#LT!N=Gf_!TR~$4BmTC}RTv!z<*Mm>T{ivtHH(k3Ae{)$_B zQC6)RCtkmJLUs^oZf^3=AxG4#!Mz+b4xH;hjIg~f_EP}9VQ|01o$So#_iIV%?{2Qe zEr6Ntv@G_CF6D#5P!_iZ^HkpjFCj~Q?p|qr@=_Y6x_sOWqAa8MXi95PE1iLvR(YY- z{~|j)IA|`QdQ82iAeraCvUT&+ZGmhjrWZQNNKhc|l*SIcc0=|!TRCO>E&B3<(qrQe z*dMYq^A*e&{|DLp+=O&1h=zPW%xrc;rU?u;nYB|sH>O=l+nai?>6_iF1?zU7Ph?1j zl%9>8ca*(NTKk*F7wXW)JM$2S4&t?OutHF7??bm*hz=oXf~CxQWa@`Py5|SN z22?4(f6;0E_TG=2hesd92X8!H4xXUD)sNG7EIzjz>!ybD*YkYK=>N|RzD&DbwL zgU?Knv1!Y>wdPe}JkH(E8nBy5%AGhaXi3gYAtxHpluu(DG~cyMva;<7zmeHK2B1Er zq{|e!eK~s`@>%QlU%AKq+AJ>WN|{xI`jutbg(I$k2r~k~^uHD@%zC}PAwhtEh$Dc2 z5dUlB^pEF#{~A42YHZrBbD(t**0|Yo2@xqJJE&iTl*R)t{V_C^tjDX`^hZ!^>XW3B z1Rvpb6q+LV=kx)gXb&k35aH<1hFPMw?|y`7eqWzZ)txk13$V0~%FhU%PrYzXVs@v_ zz0k)|+VC`vXM&jQ>I<_EHN*P}yc~hJ6p^zbW6I@bE&%$J)EZ$Fj>_wx#z6^taTiqh zwPi2O*rXk+vx0I6H+l;ww?WEHsm7(88;q3hnN@)U21j=RTrz zg*HAk38}`H$Z_9c%r-tlQTew%I&Vab>O-9NJC7*-Jc@BN3GYf7J7o5tMG>0~j_Esc z@aLg=dMqFE4RsB>o6_4NXh@G@zicrYSU4r}%W0+D!Y%ejd!$(|6Y_!Crh~Te4ws6J zu{M@(OY!@3P6q3x#u69z`a3(G6{E0E_*|{|t@G1`n^IISgYi6in#=4UgLdE{Nwfth zN5CZK7%24oB+VCu?v{Ml^6z>(c$E>-9ja7kuemP?hb%O0?%Z`y&%&zZ+rlu^WzrSB zrsBgW&dK^-VMghK-6#qtsjmYIa9V0cmNM^$;LwX%8xXuV2PS3D)FjQ*w6I~2-VbGe z5Pmt|ZP6x#nd6M<=ZG!HAGw0`kUx=z zh(et)rvXv6wLZ}B7g}e1legZF7hB+)bW+K?#l zk+N)=K(36Wa+yfokAl;_nbS>#kwE+IaI{TNj-(Rb3%4NBl`q5fUpX9!M?+Q+jf@}D z6bAD9)U-P}C~&*9QmP7iis=zRKk|sVP9#-Z!HN%`Sdc%ZaE8s8QsA2^gT|ZnZ-|iI zso*&n63Q7XaIeYGYJkELWvoC6u(1aZ^KYUfaM~Dc3>I)O%~X_>J>#$O+Y?|f#)bos z?G=+l(B)9W<5f*uy?ZQ9tkzay?FI5s=h+EwUOMDq*7UFb$##2)>p~%asXZaUZ&Dxpq*D)6 zNa!AV3Xq9kJ=8&xuwp5rMmSQ@0Lt{@2qEJRJHub*o4Y^E7a~84wPQ*kPaIjR3tl@l ztmbZJucZ1PhO{hfFT0fs2AHKbiY<$ZzRV#nBCZ_8I6Q{WLH|1y8I3qbRC|i`aiOo> z&LFV--ee<`qUfhTq~OU5e};0)z}|jraqKEVTxS5Re&|Gh)4d~S_wYlQX4vu4xbBy6 z>#z+VBN@B}yQEu0tMgmZK+F!AHDRs+GqL#?OO~ht-~KKijRrXrV)0|Uo?IvW*7ANC zUe{=yiIBecmj*B7q|-tQVoSq(t&zs2YtH^AM2w-M^bfbT+Xo+ltHhZ+30yO~W237Y zWWo+Md)jWTF7lxM^WwSC=wWy|%9qXR-EBhXyVrF)21Y+!%}Y6I{oYg|4!`$DnJs)n z-qID`aes!d|0T6DZ+iK01Oo!{hz9~f{y+JtWv~I*|Eo1yjar*3`&=k~Ib|=DB_5=W zJ>VFroKmitNG!y$NIRBE*Q6%7AeN&(~_cMf3e5U_F6Tn>bsy=ej64CI(r7{bpD3y2ftrX7Tbv zavFyc7z}JS8Zs()Wg3!1uk2bvvF?Izc-Rs+;ni{nvm!mCs1h(WelzBP)CN`J;&63c zGfzaXj*ims+ZIgiEX9U$CWu}qzC9ArkX{KKW!}Ybn?VCO0}G?} zGp~8G<~hCAqn#oJzB-*yW&rV?^ESAIpVb`Eu50d%^FzJzf6v@-uiYqEAbap+QGVb( zV9*#O~ zHCqw`c5DrF9_;Bu*#+J5{ML3zSr$O|Ya^7(jf1d}(5da@WKWfDcXH>{P*A5d`;z1+ zyb&-{$9i&F9^g<#^GlMjsgjZfk&hQ(T*&1n*=je8US)726Ve2(&E)md?+UG|{DtaF z&)(=-g5fH^L34y#b?r4ub$~EFfMT1pVXHFJku6XmBWN((q!`V znw2>mNPf{k;OFNmvsn-G@*n!s5-|BB!-m_eG{y#HM-#CCx4=_cp!681pg!nAjT=29ztm)2Go7UJuZA zG^8(uOwTF!i)a+kPT^8PI8<=N1Wnmf-uT*^@YGcnR7*oX#F3>|Ip(^wq=WU_TH9Vq zA=3KNbeh`+b(B}!5L0p#?7_K-?See)CSh#5TUG7jsPCYpWIz0LPDHe_)DD}@chC+= zo#xS#!pZ!zgBeCC%M(_0bIpGU#MKIU!x#$Uw(UzR!a_<-y2wOZJ)RUohU?ySJtCZu zIF-zprBKFjZiOjYN0Ir&!*c$!AXNkEjqEo5VilUIH&H$C+kM!hVW)4QXs0HOA&W`|h%95X_I><8apT@={lS|CV+8LRRsgVC`?r^Lo2R zTr~hkBR8fHCT=~iYjA@0Z^-@~DsxvW7~D5m18?9VD5azCAUHqJz9@--Us>*!^h(~( zxBBnbsnJwjA~&UepZf2G$T7{BiTOqQW+;k6pXkJab}!A2Rd^EK3IoVDSzeH+11|Fw z8t#mJ*#oQr03kj7yFf$9sx1|4RDKeow6=m|qR|KZx8@ zgo+l?RCB@z^&P8gCZ}q?1&^G- zzL99f&VB%_V{pyV)>B~YavpVDPN(2C3xA5hfmPOOP;Fba{QlrlN~W^PfR)swtAG@` zQv3m)OK6w`-DNDdX^CHQ#)qO0F9i|wEHvW<>wA|E)nc2c_tbkzbO?c`z{@n=UZ}I* zEc4AetpSvJ*e4{Qzo_Z%KBF-~wtR2_QsgW-Qi$^bw(&dj1Cwl58RQF;R1zrSoh=mO zVz;s2Zi(+yLbLA$Z&Zi}e?up|@Sfx7_V1$Qbm|rD1cFRN`Dpw|-ls}KU=Q|^1K&#R zs!xvsXs|7EKtGtT*`}4BfFeE37CMROZ|arsC5;SiMD}9aPmuj{=qC4`Mvc2!_4%WQ zZYOyQ3925`XfqoHL&m!>o^~eYY3UHnU4R`nn)k1^p!uV>v~K~%IFn(yS7N5~3Vz?2 zy4?*a7^&fL6`XSPepX#71?WlJ!Q-yF;cb^>{k&cWv)mQh`Zm;~Z%2YycLW5Z|gC>S+}_4D-Y4>EJ(!E=w~z4r=P z5A+qZ_8Csmt3gm)Qc1JxAWI)Yas7VkvreyMjql4r68>_pT*)y)#F;amp*Ty zpM+7s#wVx>lilzWrT0XW8-1(mh?Mst4d2Y+ z7q6+Z8P_dJvR3>gzzip}<`E+J#iAp;eyt3GR#_9DVnC#fIMV{h?9P)|5JUMvSeNlu zQm(@V`x_MdL%;OsxP~~+a;^z>^{pHqWNS^01i((nDCid1l4VIH?F)@vaVD>x5-1pe3aG zS*?vV{03Snz9M>DF7;8UmZl0oKAco0Z#rEuQFyercx8l0qY?2w=#EGceQapSXU4Ee zl_v@g;n(Y5hxsfXoGzMH=y5pVuvV!-?amy|W@l1L2~eUE?$J|0x8fI<@YY){aaI~S zn-CdvdPmWCV8Z>~>ETLR+1KKaD>6nW$E1EcTr72ET;6JLuRepz3XP5ND3Js$h!{ZmS=8#`i z0*X1K6viRrtueRuu;UwHj^M}nUGcxy=lmBT1R7cP597ZJ{Qt2j{RNT#zf%wVE5P|b zrySv40N>l zFD{DzuJCUy|0(J2WbvP7-Q3(5+*tq3@Ly&MW=2gpS(Seyv7ooGb#eyS8Uz2s{(oxx zPdP6Bk1P-Zd?v;`#*RRMvz?=Ww4J#vks`nzKqm>Xbt00m>@TqXJ34@)6(8e&6Z?mX z3Gm-jQ-8TP1Xzj00Ztx7D$YQACmvW>DrRaTSqob$B4@k5?|-Ac_(z=;5iAwU|JLyL zfeb7aD>adt6YxJ||Dk1K;bdp!LYxpn#+ft@#!l8YA&&@q}qKXkvQFv?>@eGk046gv^Id|P4V58bD6Wx{dDk*0y!&s6s1y@Bx za>t!>4s4xQtegRR#-=C;9PmhBl)dP5UANcku~+CJ$LpM(UtO{|N>lV+0EUY;6Zn>k z)adD;^du83iDa4pA4-R!m)068w8`+aKj;s99zP9(x`_nRD8ntGYZyZ2e|RsfH%;MJ zSg&$EDU`M+2kPM<$!9ERCLU%nO7m-v&6gGMbr@`{NM9sFk4-kvrK0*WhqxTRt6oEi zzRihbiGbj*V}Rg!j>}M0_alFX{(fc zCt%B&J6*cm&GY||qkS(a*;JDG+@nh#zI5*YDadwjF2uU~zhh_HvV8US;Unti(g&Z_ J{=A`I{{Z_g^m_mR literal 0 HcmV?d00001 diff --git a/node_modules/toastr/package/package/nuget/toastr.2.0.0-rc1.nuspec b/node_modules/toastr/package/package/nuget/toastr.2.0.0-rc1.nuspec new file mode 100644 index 0000000..d13d8e1 --- /dev/null +++ b/node_modules/toastr/package/package/nuget/toastr.2.0.0-rc1.nuspec @@ -0,0 +1,49 @@ + + + + toastr + 2.0.0-rc1 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + http://toastrjs.com/ + http://johnpapa.net/wp-content/images/toastr-icon.png + false + 3 Easy Steps: + +(1) Link to toastr.css +(2) Link to toastr.js +(3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + Toastr is a JavaScript library for non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + The following animations options have been deprecated and should be replaced: + +Replace options.fadeIn with options.showDuration +Replace options.onFadeIn with options.onShown +Replace options.fadeOut with options.hideDuration +Replace options.onFadeOut with options.onHidden + +Optional 'close' button, bug fixes, and improved responsive design. + +For other changes, see http://toastrjs.com + Copyright © 2012 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/package/package/nuget/toastr.2.0.1.nupkg b/node_modules/toastr/package/package/nuget/toastr.2.0.1.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..a3a98b2a2f8d9efcc07d5e09f3871fcd52a3e50a GIT binary patch literal 19400 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 literal 0 HcmV?d00001 diff --git a/node_modules/toastr/package/package/nuget/toastr.2.0.1.nuspec b/node_modules/toastr/package/package/nuget/toastr.2.0.1.nuspec new file mode 100644 index 0000000..09b937d --- /dev/null +++ b/node_modules/toastr/package/package/nuget/toastr.2.0.1.nuspec @@ -0,0 +1,49 @@ + + + + toastr + 2.0.1 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + http://toastrjs.com/ + http://johnpapa.net/wp-content/images/toastr-icon.png + false + 3 Easy Steps: + +(1) Link to toastr.css +(2) Link to toastr.js +(3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + Toastr is a JavaScript library for non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + The following animations options have been deprecated and should be replaced: + +Replace options.fadeIn with options.showDuration +Replace options.onFadeIn with options.onShown +Replace options.fadeOut with options.hideDuration +Replace options.onFadeOut with options.onHidden + +Optional 'close' button, bug fixes, and improved responsive design. + +For other changes, see http://toastrjs.com + Copyright © 2012 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/package/package/nuget/toastr.2.0.2.nupkg b/node_modules/toastr/package/package/nuget/toastr.2.0.2.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..2efdb7adc46c99fce36e2bb3e6655f5cc6233aec GIT binary patch literal 23037 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

)sL(3MV$8au8;Dr)1|4L@N$j3XY&nQ~ee0 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 UQxUyXsPis>DrHf4$CCQ%KPTrvVgLXD literal 0 HcmV?d00001 diff --git a/node_modules/toastr/package/package/nuget/toastr.2.0.2.nuspec b/node_modules/toastr/package/package/nuget/toastr.2.0.2.nuspec new file mode 100644 index 0000000..1f76718 --- /dev/null +++ b/node_modules/toastr/package/package/nuget/toastr.2.0.2.nuspec @@ -0,0 +1,41 @@ + + + + toastr + 2.0.2 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + http://toastrjs.com/ + http://johnpapa.net/wp-content/images/toastr-icon.png + false + 3 Easy Steps: + +(1) Link to toastr.css +(2) Link to toastr.js +(3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo +

Toastr is a JavaScript library for non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + Change log: https://github.com/CodeSeven/toastr/blob/master/CHANGELOG.md + Copyright © 2012-2014 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/package/package/nuget/toastr.2.0.3.nupkg b/node_modules/toastr/package/package/nuget/toastr.2.0.3.nupkg new file mode 100644 index 0000000000000000000000000000000000000000..6389cdf62c6c9c590316a5ea2adc1cbc8e95eb5d GIT binary patch literal 23027 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 literal 0 HcmV?d00001 diff --git a/node_modules/toastr/package/package/nuget/toastr.2.0.3.nuspec b/node_modules/toastr/package/package/nuget/toastr.2.0.3.nuspec new file mode 100644 index 0000000..1e6133a --- /dev/null +++ b/node_modules/toastr/package/package/nuget/toastr.2.0.3.nuspec @@ -0,0 +1,41 @@ + + + + toastr + 2.0.3 + toastr + John Papa,Hans Fjällemark + John Papa,Hans Fjällemark + http://www.opensource.org/licenses/mit-license.php + http://toastrjs.com/ + http://johnpapa.net/wp-content/images/toastr-icon.png + false + 3 Easy Steps: + +(1) Link to toastr.css +(2) Link to toastr.js +(3) Use toastr to display a toast for info, success, warning or error + +// Display an info toast with no title +toastr.info('Are you the 6 fingered man?') + +*** For other API calls, see the demo + Toastr is a JavaScript library for non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + Change log: https://github.com/CodeSeven/toastr/blob/master/CHANGELOG.md + Copyright © 2012-2014 Hans Fjällemark & John Papa. + en-US + toastr, toast, notification, dialog, jquery + + + + + + + + + + + + + + \ No newline at end of file diff --git a/node_modules/toastr/package/package/package.json b/node_modules/toastr/package/package/package.json new file mode 100644 index 0000000..51ef844 --- /dev/null +++ b/node_modules/toastr/package/package/package.json @@ -0,0 +1,68 @@ +{ + "name": "toastr", + "filename": "js/toastr.min.js", + "main": "toastr.js", + "style": "./toastr.min.css", + "version": "2.1.2", + "description": "ToastrJS is a JavaScript library for Gnome / Growl type non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended.", + "homepage": "http://www.toastrjs.com", + "keywords": [ + "Toastr", + "ToastrJS", + "toastr.js" + ], + "maintainers": [ + { + "name": "John Papa", + "web": "http://www.johnpapa.net", + "twitter": "@john_papa" + }, + { + "name": "Tim Ferrell", + "web": "https://twitter.com/ferrell_tim", + "twitter": "@ferrell_tim" + } + ], + "repository": { + "type": "git", + "url": "git://github.com/CodeSeven/toastr.git" + }, + "bugs": "http://stackoverflow.com/questions/tagged/toastr", + "licenses": [ + { + "type": "MIT", + "url": "http://www.opensource.org/licenses/mit-license.php" + } + ], + "devDependencies": { + "del": "^0.1.3", + "glob": "^4.0.6", + "grunt-contrib-less": "~0.6.4", + "grunt-contrib-uglify": "~0.2.2", + "gulp": "^3.8.10", + "gulp-bytediff": "^0.2.0", + "gulp-jscs": "^1.3.0", + "gulp-jshint": "^1.9.0", + "gulp-load-plugins": "^0.7.1", + "gulp-load-utils": "0.0.4", + "gulp-minify-css": "^0.3.11", + "gulp-rename": "^1.2.0", + "gulp-sourcemaps": "^1.2.8", + "gulp-task-listing": "^0.3.0", + "gulp-uglify": "^1.0.1", + "gulp-util": "^3.0.1", + "jquery": "^2.1.1", + "jshint-stylish": "^1.0.0", + "karma": "^0.12.25", + "karma-coverage": "^0.2.6", + "karma-phantomjs-launcher": "^0.1.4", + "karma-qunit": "^0.1.3", + "merge-stream": "^0.1.6", + "phantomjs": "^1.9.7-15", + "plato": "^1.2.2", + "qunitjs": "~1.14.0" + }, + "scripts": { + "test": "gulp test" + } +} diff --git a/node_modules/toastr/package/package/readme.md b/node_modules/toastr/package/package/readme.md new file mode 100644 index 0000000..45e7014 --- /dev/null +++ b/node_modules/toastr/package/package/readme.md @@ -0,0 +1,181 @@ +# toastr +**toastr** is a Javascript library for non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + +[![Build Status](https://travis-ci.org/CodeSeven/toastr.svg)](https://travis-ci.org/CodeSeven/toastr) + +## Current Version +2.1.2 + +## Demo +- Demo can be found at http://codeseven.github.io/toastr/demo.html +- [Demo using FontAwesome icons with toastr](http://plnkr.co/edit/6W9URNyyp2ItO4aUWzBB?p=preview) + +## CDNjs +Toastr is hosted at CDN JS + +#### Debug +- [//cdnjs.cloudflare.com/ajax/libs/toastr.js/latest/js/toastr.js](//cdnjs.cloudflare.com/ajax/libs/toastr.js/latest/js/toastr.js) +- [//cdnjs.cloudflare.com/ajax/libs/toastr.js/latest/css/toastr.css](//cdnjs.cloudflare.com/ajax/libs/toastr.js/latest/css/toastr.css) + +#### Minified +- [//cdnjs.cloudflare.com/ajax/libs/toastr.js/latest/js/toastr.min.js](//cdnjs.cloudflare.com/ajax/libs/toastr.js/latest/js/toastr.min.js) +- [//cdnjs.cloudflare.com/ajax/libs/toastr.js/latest/css/toastr.min.css](//cdnjs.cloudflare.com/ajax/libs/toastr.js/latest/css/toastr.min.css) + +## NuGet Gallery +http://nuget.org/packages/toastr + +## [Bower](http://bower.io/) + bower install toastr + + +## Wiki and Change Log +[Wiki including Change Log](https://github.com/CodeSeven/toastr/wiki) + +## Breaking Changes + +####Animation Changes +The following animations options have been deprecated and should be replaced: + + - Replace `options.fadeIn` with `options.showDuration` + - Replace `options.onFadeIn` with `options.onShown` + - Replace `options.fadeOut` with `options.hideDuration` + - Replace `options.onFadeOut` with `options.onHidden` + +## Quick Start + +###3 Easy Steps +For other API calls, see the [demo](http://codeseven.github.io/toastr/demo.html). + +1. Link to toastr.css `` + +2. Link to toastr.js `` + +3. use toastr to display a toast for info, success, warning or error + + // Display an info toast with no title + toastr.info('Are you the 6 fingered man?') + +### Other Options + // Display a warning toast, with no title + toastr.warning('My name is Inigo Montoya. You killed my father, prepare to die!') + + // Display a success toast, with a title + toastr.success('Have fun storming the castle!', 'Miracle Max Says') + + // Display an error toast, with a title + toastr.error('I do not think that word means what you think it means.', 'Inconceivable!') + + // Immediately remove current toasts without using animation + toastr.remove() + + // Remove current toasts using animation + toastr.clear() + + // Override global options + toastr.success('We do have the Kapua suite available.', 'Turtle Bay Resort', {timeOut: 5000}) + +### Close Button +Optionally enable a close button + + toastr.options.closeButton = true; + +Optionally override the close button's HTML. + + toastr.options.closeHtml = ''; + +You can also override the CSS/LESS for `#toast-container .toast-close-button` + +### Display Sequence +Show newest toast at bottom (top is default) + + toastr.options.newestOnTop = false; + +### Callbacks + // Define a callback for when the toast is shown/hidden + toastr.options.onShown = function() { console.log('hello'); } + toastr.options.onHidden = function() { console.log('goodbye'); } + +### Animation Options +Toastr will supply default animations, so you do not have to provide any of these settings. However you have the option to override the animations if you like. + +####Easings +Optionally override the animation easing to show or hide the toasts. Default is swing. swing and linear are built into jQuery. + + toastr.options.showEasing = 'swing'; + toastr.options.hideEasing = 'linear'; + +Using the jQuery Easing plugin (http://www.gsgd.co.uk/sandbox/jquery/easing/) + + toastr.options.showEasing = 'easeOutBounce'; + toastr.options.hideEasing = 'easeInBack'; + +####Animation Method +Use the jQuery show/hide method of your choice. These default to fadeIn/fadeOut. The methods fadeIn/fadeOut, slideDown/slideUp, and show/hide are built into jQuery. + + toastr.options.showMethod = 'slideDown'; + toastr.options.hideMethod = 'slideUp'; + +###Prevent Duplicates +Rather than having identical toasts stack, set the preventDuplicates property to true. Duplicates are matched to the previous toast based on their message content. + + toastr.options.preventDuplicates = true; + + +###Timeouts +Control how toastr interacts with users by setting timeouts appropriately. Timeouts can be disabled by setting them to 0. + + toastr.options.timeOut = 30; // How long the toast will display without user interaction + toastr.options.extendedTimeOut = 60; // How long the toast will display after a user hovers over it + + +###Progress Bar +Visually indicate how long before a toast expires. + + toastr.options.progressBar = true; + +## Building Toastr + +To build the minified and css versions of Toastr you will need [node](http://nodejs.org) installed. (Use Homebrew or Chocolatey.) + +``` +npm install -g gulp karma-cli +npm install +``` + +At this point the dependencies have been installed and you can build Toastr + +- Run the analytics `gulp analyze` +- Run the test `gulp test` +- Run the build `gulp` + +## Contributing + +For a pull request to be considered it must resolve a bug, or add a feature which is beneficial to a large audience. + +Pull requests must pass existing unit tests, CI processes, and add additional tests to indicate successful operation of a new feature, or the resolution of an identified bug. + +Requests must be made against the `develop` branch. Pull requests submitted against the `master` branch will not be considered. + +All pull requests are subject to approval by the repository owners, who have sole discretion over acceptance or denial. + +## Authors +**John Papa** + ++ [http://twitter.com/John_Papa](http://twitter.com/John_Papa) + +**Tim Ferrell** + ++ [http://twitter.com/ferrell_tim](http://twitter.com/ferrell_tim) + +**Hans Fjällemark** + ++ [http://twitter.com/hfjallemark](http://twitter.com/hfjallemark) + +## Credits +Inspired by https://github.com/Srirangan/notifer.js/. + +## Copyright +Copyright © 2012-2015 + +## License +toastr is under MIT license - http://www.opensource.org/licenses/mit-license.php diff --git a/node_modules/toastr/package/package/release checklist.md b/node_modules/toastr/package/package/release checklist.md new file mode 100644 index 0000000..52e5a83 --- /dev/null +++ b/node_modules/toastr/package/package/release checklist.md @@ -0,0 +1,32 @@ +Toastr Release Checklist + +1. Update Toastr Version + * toastr.js + * bower.json (toastr-bower repo) + * package.json + * nuget versions and dependency versions + * readme file for github repo + * Consider HotTowel VSIX +2. Gulp + * run main demo + * `gulp analyze` + * `gulp test` + * `gulp` +3. Nuget + * Copy new files in + * Build + * Test +4. CDNJS + * Update CDNJS +5. Update Website with New Downloads +6. Publish Bower + * Include License and Readme + * Test Locally + * Update Github repo toastr-bower + * Github tag + * Register with Bower +7. Publish Nugets +8. Release on Github + * Tag with semver + * Attach all artifacts +9. Blog post \ No newline at end of file diff --git a/node_modules/toastr/package/package/tests/qunit/qunit.css b/node_modules/toastr/package/package/tests/qunit/qunit.css new file mode 100644 index 0000000..7ba3f9a --- /dev/null +++ b/node_modules/toastr/package/package/tests/qunit/qunit.css @@ -0,0 +1,244 @@ +/** + * QUnit v1.12.0 - A JavaScript Unit Testing Framework + * + * http://qunitjs.com + * + * Copyright 2012 jQuery Foundation and other contributors + * Released under the MIT license. + * http://jquery.org/license + */ + +/** Font Family and Sizes */ + +#qunit-tests, #qunit-header, #qunit-banner, #qunit-testrunner-toolbar, #qunit-userAgent, #qunit-testresult { + font-family: "Helvetica Neue Light", "HelveticaNeue-Light", "Helvetica Neue", Calibri, Helvetica, Arial, sans-serif; +} + +#qunit-testrunner-toolbar, #qunit-userAgent, #qunit-testresult, #qunit-tests li { font-size: small; } +#qunit-tests { font-size: smaller; } + + +/** Resets */ + +#qunit-tests, #qunit-header, #qunit-banner, #qunit-userAgent, #qunit-testresult, #qunit-modulefilter { + margin: 0; + padding: 0; +} + + +/** Header */ + +#qunit-header { + padding: 0.5em 0 0.5em 1em; + + color: #8699a4; + background-color: #0d3349; + + font-size: 1.5em; + line-height: 1em; + font-weight: normal; + + border-radius: 5px 5px 0 0; + -moz-border-radius: 5px 5px 0 0; + -webkit-border-top-right-radius: 5px; + -webkit-border-top-left-radius: 5px; +} + +#qunit-header a { + text-decoration: none; + color: #c2ccd1; +} + +#qunit-header a:hover, +#qunit-header a:focus { + color: #fff; +} + +#qunit-testrunner-toolbar label { + display: inline-block; + padding: 0 .5em 0 .1em; +} + +#qunit-banner { + height: 5px; +} + +#qunit-testrunner-toolbar { + padding: 0.5em 0 0.5em 2em; + color: #5E740B; + background-color: #eee; + overflow: hidden; +} + +#qunit-userAgent { + padding: 0.5em 0 0.5em 2.5em; + background-color: #2b81af; + color: #fff; + text-shadow: rgba(0, 0, 0, 0.5) 2px 2px 1px; +} + +#qunit-modulefilter-container { + float: right; +} + +/** Tests: Pass/Fail */ + +#qunit-tests { + list-style-position: inside; +} + +#qunit-tests li { + padding: 0.4em 0.5em 0.4em 2.5em; + border-bottom: 1px solid #fff; + list-style-position: inside; +} + +#qunit-tests.hidepass li.pass, #qunit-tests.hidepass li.running { + display: none; +} + +#qunit-tests li strong { + cursor: pointer; +} + +#qunit-tests li a { + padding: 0.5em; + color: #c2ccd1; + text-decoration: none; +} +#qunit-tests li a:hover, +#qunit-tests li a:focus { + color: #000; +} + +#qunit-tests li .runtime { + float: right; + font-size: smaller; +} + +.qunit-assert-list { + margin-top: 0.5em; + padding: 0.5em; + + background-color: #fff; + + border-radius: 5px; + -moz-border-radius: 5px; + -webkit-border-radius: 5px; +} + +.qunit-collapsed { + display: none; +} + +#qunit-tests table { + border-collapse: collapse; + margin-top: .2em; +} + +#qunit-tests th { + text-align: right; + vertical-align: top; + padding: 0 .5em 0 0; +} + +#qunit-tests td { + vertical-align: top; +} + +#qunit-tests pre { + margin: 0; + white-space: pre-wrap; + word-wrap: break-word; +} + +#qunit-tests del { + background-color: #e0f2be; + color: #374e0c; + text-decoration: none; +} + +#qunit-tests ins { + background-color: #ffcaca; + color: #500; + text-decoration: none; +} + +/*** Test Counts */ + +#qunit-tests b.counts { color: black; } +#qunit-tests b.passed { color: #5E740B; } +#qunit-tests b.failed { color: #710909; } + +#qunit-tests li li { + padding: 5px; + background-color: #fff; + border-bottom: none; + list-style-position: inside; +} + +/*** Passing Styles */ + +#qunit-tests li li.pass { + color: #3c510c; + background-color: #fff; + border-left: 10px solid #C6E746; +} + +#qunit-tests .pass { color: #528CE0; background-color: #D2E0E6; } +#qunit-tests .pass .test-name { color: #366097; } + +#qunit-tests .pass .test-actual, +#qunit-tests .pass .test-expected { color: #999999; } + +#qunit-banner.qunit-pass { background-color: #C6E746; } + +/*** Failing Styles */ + +#qunit-tests li li.fail { + color: #710909; + background-color: #fff; + border-left: 10px solid #EE5757; + white-space: pre; +} + +#qunit-tests > li:last-child { + border-radius: 0 0 5px 5px; + -moz-border-radius: 0 0 5px 5px; + -webkit-border-bottom-right-radius: 5px; + -webkit-border-bottom-left-radius: 5px; +} + +#qunit-tests .fail { color: #000000; background-color: #EE5757; } +#qunit-tests .fail .test-name, +#qunit-tests .fail .module-name { color: #000000; } + +#qunit-tests .fail .test-actual { color: #EE5757; } +#qunit-tests .fail .test-expected { color: green; } + +#qunit-banner.qunit-fail { background-color: #EE5757; } + + +/** Result */ + +#qunit-testresult { + padding: 0.5em 0.5em 0.5em 2.5em; + + color: #2b81af; + background-color: #D2E0E6; + + border-bottom: 1px solid white; +} +#qunit-testresult .module-name { + font-weight: bold; +} + +/** Fixture */ + +#qunit-fixture { + position: absolute; + top: -10000px; + left: -10000px; + width: 1000px; + height: 1000px; +} diff --git a/node_modules/toastr/package/package/tests/qunit/qunit.js b/node_modules/toastr/package/package/tests/qunit/qunit.js new file mode 100644 index 0000000..84c7390 --- /dev/null +++ b/node_modules/toastr/package/package/tests/qunit/qunit.js @@ -0,0 +1,2212 @@ +/** + * QUnit v1.12.0 - A JavaScript Unit Testing Framework + * + * http://qunitjs.com + * + * Copyright 2013 jQuery Foundation and other contributors + * Released under the MIT license. + * https://jquery.org/license/ + */ + +(function( window ) { + +var QUnit, + assert, + config, + onErrorFnPrev, + testId = 0, + fileName = (sourceFromStacktrace( 0 ) || "" ).replace(/(:\d+)+\)?/, "").replace(/.+\//, ""), + toString = Object.prototype.toString, + hasOwn = Object.prototype.hasOwnProperty, + // Keep a local reference to Date (GH-283) + Date = window.Date, + setTimeout = window.setTimeout, + defined = { + setTimeout: typeof window.setTimeout !== "undefined", + sessionStorage: (function() { + var x = "qunit-test-string"; + try { + sessionStorage.setItem( x, x ); + sessionStorage.removeItem( x ); + return true; + } catch( e ) { + return false; + } + }()) + }, + /** + * Provides a normalized error string, correcting an issue + * with IE 7 (and prior) where Error.prototype.toString is + * not properly implemented + * + * Based on http://es5.github.com/#x15.11.4.4 + * + * @param {String|Error} error + * @return {String} error message + */ + errorString = function( error ) { + var name, message, + errorString = error.toString(); + if ( errorString.substring( 0, 7 ) === "[object" ) { + name = error.name ? error.name.toString() : "Error"; + message = error.message ? error.message.toString() : ""; + if ( name && message ) { + return name + ": " + message; + } else if ( name ) { + return name; + } else if ( message ) { + return message; + } else { + return "Error"; + } + } else { + return errorString; + } + }, + /** + * Makes a clone of an object using only Array or Object as base, + * and copies over the own enumerable properties. + * + * @param {Object} obj + * @return {Object} New object with only the own properties (recursively). + */ + objectValues = function( obj ) { + // Grunt 0.3.x uses an older version of jshint that still has jshint/jshint#392. + /*jshint newcap: false */ + var key, val, + vals = QUnit.is( "array", obj ) ? [] : {}; + for ( key in obj ) { + if ( hasOwn.call( obj, key ) ) { + val = obj[key]; + vals[key] = val === Object(val) ? objectValues(val) : val; + } + } + return vals; + }; + +function Test( settings ) { + extend( this, settings ); + this.assertions = []; + this.testNumber = ++Test.count; +} + +Test.count = 0; + +Test.prototype = { + init: function() { + var a, b, li, + tests = id( "qunit-tests" ); + + if ( tests ) { + b = document.createElement( "strong" ); + b.innerHTML = this.nameHtml; + + // `a` initialized at top of scope + a = document.createElement( "a" ); + a.innerHTML = "Rerun"; + a.href = QUnit.url({ testNumber: this.testNumber }); + + li = document.createElement( "li" ); + li.appendChild( b ); + li.appendChild( a ); + li.className = "running"; + li.id = this.id = "qunit-test-output" + testId++; + + tests.appendChild( li ); + } + }, + setup: function() { + if ( + // Emit moduleStart when we're switching from one module to another + this.module !== config.previousModule || + // They could be equal (both undefined) but if the previousModule property doesn't + // yet exist it means this is the first test in a suite that isn't wrapped in a + // module, in which case we'll just emit a moduleStart event for 'undefined'. + // Without this, reporters can get testStart before moduleStart which is a problem. + !hasOwn.call( config, "previousModule" ) + ) { + if ( hasOwn.call( config, "previousModule" ) ) { + runLoggingCallbacks( "moduleDone", QUnit, { + name: config.previousModule, + failed: config.moduleStats.bad, + passed: config.moduleStats.all - config.moduleStats.bad, + total: config.moduleStats.all + }); + } + config.previousModule = this.module; + config.moduleStats = { all: 0, bad: 0 }; + runLoggingCallbacks( "moduleStart", QUnit, { + name: this.module + }); + } + + config.current = this; + + this.testEnvironment = extend({ + setup: function() {}, + teardown: function() {} + }, this.moduleTestEnvironment ); + + this.started = +new Date(); + runLoggingCallbacks( "testStart", QUnit, { + name: this.testName, + module: this.module + }); + + /*jshint camelcase:false */ + + + /** + * Expose the current test environment. + * + * @deprecated since 1.12.0: Use QUnit.config.current.testEnvironment instead. + */ + QUnit.current_testEnvironment = this.testEnvironment; + + /*jshint camelcase:true */ + + if ( !config.pollution ) { + saveGlobal(); + } + if ( config.notrycatch ) { + this.testEnvironment.setup.call( this.testEnvironment, QUnit.assert ); + return; + } + try { + this.testEnvironment.setup.call( this.testEnvironment, QUnit.assert ); + } catch( e ) { + QUnit.pushFailure( "Setup failed on " + this.testName + ": " + ( e.message || e ), extractStacktrace( e, 1 ) ); + } + }, + run: function() { + config.current = this; + + var running = id( "qunit-testresult" ); + + if ( running ) { + running.innerHTML = "Running:
" + this.nameHtml; + } + + if ( this.async ) { + QUnit.stop(); + } + + this.callbackStarted = +new Date(); + + if ( config.notrycatch ) { + this.callback.call( this.testEnvironment, QUnit.assert ); + this.callbackRuntime = +new Date() - this.callbackStarted; + return; + } + + try { + this.callback.call( this.testEnvironment, QUnit.assert ); + this.callbackRuntime = +new Date() - this.callbackStarted; + } catch( e ) { + this.callbackRuntime = +new Date() - this.callbackStarted; + + QUnit.pushFailure( "Died on test #" + (this.assertions.length + 1) + " " + this.stack + ": " + ( e.message || e ), extractStacktrace( e, 0 ) ); + // else next test will carry the responsibility + saveGlobal(); + + // Restart the tests if they're blocking + if ( config.blocking ) { + QUnit.start(); + } + } + }, + teardown: function() { + config.current = this; + if ( config.notrycatch ) { + if ( typeof this.callbackRuntime === "undefined" ) { + this.callbackRuntime = +new Date() - this.callbackStarted; + } + this.testEnvironment.teardown.call( this.testEnvironment, QUnit.assert ); + return; + } else { + try { + this.testEnvironment.teardown.call( this.testEnvironment, QUnit.assert ); + } catch( e ) { + QUnit.pushFailure( "Teardown failed on " + this.testName + ": " + ( e.message || e ), extractStacktrace( e, 1 ) ); + } + } + checkPollution(); + }, + finish: function() { + config.current = this; + if ( config.requireExpects && this.expected === null ) { + QUnit.pushFailure( "Expected number of assertions to be defined, but expect() was not called.", this.stack ); + } else if ( this.expected !== null && this.expected !== this.assertions.length ) { + QUnit.pushFailure( "Expected " + this.expected + " assertions, but " + this.assertions.length + " were run", this.stack ); + } else if ( this.expected === null && !this.assertions.length ) { + QUnit.pushFailure( "Expected at least one assertion, but none were run - call expect(0) to accept zero assertions.", this.stack ); + } + + var i, assertion, a, b, time, li, ol, + test = this, + good = 0, + bad = 0, + tests = id( "qunit-tests" ); + + this.runtime = +new Date() - this.started; + config.stats.all += this.assertions.length; + config.moduleStats.all += this.assertions.length; + + if ( tests ) { + ol = document.createElement( "ol" ); + ol.className = "qunit-assert-list"; + + for ( i = 0; i < this.assertions.length; i++ ) { + assertion = this.assertions[i]; + + li = document.createElement( "li" ); + li.className = assertion.result ? "pass" : "fail"; + li.innerHTML = assertion.message || ( assertion.result ? "okay" : "failed" ); + ol.appendChild( li ); + + if ( assertion.result ) { + good++; + } else { + bad++; + config.stats.bad++; + config.moduleStats.bad++; + } + } + + // store result when possible + if ( QUnit.config.reorder && defined.sessionStorage ) { + if ( bad ) { + sessionStorage.setItem( "qunit-test-" + this.module + "-" + this.testName, bad ); + } else { + sessionStorage.removeItem( "qunit-test-" + this.module + "-" + this.testName ); + } + } + + if ( bad === 0 ) { + addClass( ol, "qunit-collapsed" ); + } + + // `b` initialized at top of scope + b = document.createElement( "strong" ); + b.innerHTML = this.nameHtml + " (" + bad + ", " + good + ", " + this.assertions.length + ")"; + + addEvent(b, "click", function() { + var next = b.parentNode.lastChild, + collapsed = hasClass( next, "qunit-collapsed" ); + ( collapsed ? removeClass : addClass )( next, "qunit-collapsed" ); + }); + + addEvent(b, "dblclick", function( e ) { + var target = e && e.target ? e.target : window.event.srcElement; + if ( target.nodeName.toLowerCase() === "span" || target.nodeName.toLowerCase() === "b" ) { + target = target.parentNode; + } + if ( window.location && target.nodeName.toLowerCase() === "strong" ) { + window.location = QUnit.url({ testNumber: test.testNumber }); + } + }); + + // `time` initialized at top of scope + time = document.createElement( "span" ); + time.className = "runtime"; + time.innerHTML = this.runtime + " ms"; + + // `li` initialized at top of scope + li = id( this.id ); + li.className = bad ? "fail" : "pass"; + li.removeChild( li.firstChild ); + a = li.firstChild; + li.appendChild( b ); + li.appendChild( a ); + li.appendChild( time ); + li.appendChild( ol ); + + } else { + for ( i = 0; i < this.assertions.length; i++ ) { + if ( !this.assertions[i].result ) { + bad++; + config.stats.bad++; + config.moduleStats.bad++; + } + } + } + + runLoggingCallbacks( "testDone", QUnit, { + name: this.testName, + module: this.module, + failed: bad, + passed: this.assertions.length - bad, + total: this.assertions.length, + duration: this.runtime + }); + + QUnit.reset(); + + config.current = undefined; + }, + + queue: function() { + var bad, + test = this; + + synchronize(function() { + test.init(); + }); + function run() { + // each of these can by async + synchronize(function() { + test.setup(); + }); + synchronize(function() { + test.run(); + }); + synchronize(function() { + test.teardown(); + }); + synchronize(function() { + test.finish(); + }); + } + + // `bad` initialized at top of scope + // defer when previous test run passed, if storage is available + bad = QUnit.config.reorder && defined.sessionStorage && + +sessionStorage.getItem( "qunit-test-" + this.module + "-" + this.testName ); + + if ( bad ) { + run(); + } else { + synchronize( run, true ); + } + } +}; + +// Root QUnit object. +// `QUnit` initialized at top of scope +QUnit = { + + // call on start of module test to prepend name to all tests + module: function( name, testEnvironment ) { + config.currentModule = name; + config.currentModuleTestEnvironment = testEnvironment; + config.modules[name] = true; + }, + + asyncTest: function( testName, expected, callback ) { + if ( arguments.length === 2 ) { + callback = expected; + expected = null; + } + + QUnit.test( testName, expected, callback, true ); + }, + + test: function( testName, expected, callback, async ) { + var test, + nameHtml = "" + escapeText( testName ) + ""; + + if ( arguments.length === 2 ) { + callback = expected; + expected = null; + } + + if ( config.currentModule ) { + nameHtml = "" + escapeText( config.currentModule ) + ": " + nameHtml; + } + + test = new Test({ + nameHtml: nameHtml, + testName: testName, + expected: expected, + async: async, + callback: callback, + module: config.currentModule, + moduleTestEnvironment: config.currentModuleTestEnvironment, + stack: sourceFromStacktrace( 2 ) + }); + + if ( !validTest( test ) ) { + return; + } + + test.queue(); + }, + + // Specify the number of expected assertions to guarantee that failed test (no assertions are run at all) don't slip through. + expect: function( asserts ) { + if (arguments.length === 1) { + config.current.expected = asserts; + } else { + return config.current.expected; + } + }, + + start: function( count ) { + // QUnit hasn't been initialized yet. + // Note: RequireJS (et al) may delay onLoad + if ( config.semaphore === undefined ) { + QUnit.begin(function() { + // This is triggered at the top of QUnit.load, push start() to the event loop, to allow QUnit.load to finish first + setTimeout(function() { + QUnit.start( count ); + }); + }); + return; + } + + config.semaphore -= count || 1; + // don't start until equal number of stop-calls + if ( config.semaphore > 0 ) { + return; + } + // ignore if start is called more often then stop + if ( config.semaphore < 0 ) { + config.semaphore = 0; + QUnit.pushFailure( "Called start() while already started (QUnit.config.semaphore was 0 already)", null, sourceFromStacktrace(2) ); + return; + } + // A slight delay, to avoid any current callbacks + if ( defined.setTimeout ) { + setTimeout(function() { + if ( config.semaphore > 0 ) { + return; + } + if ( config.timeout ) { + clearTimeout( config.timeout ); + } + + config.blocking = false; + process( true ); + }, 13); + } else { + config.blocking = false; + process( true ); + } + }, + + stop: function( count ) { + config.semaphore += count || 1; + config.blocking = true; + + if ( config.testTimeout && defined.setTimeout ) { + clearTimeout( config.timeout ); + config.timeout = setTimeout(function() { + QUnit.ok( false, "Test timed out" ); + config.semaphore = 1; + QUnit.start(); + }, config.testTimeout ); + } + } +}; + +// `assert` initialized at top of scope +// Assert helpers +// All of these must either call QUnit.push() or manually do: +// - runLoggingCallbacks( "log", .. ); +// - config.current.assertions.push({ .. }); +// We attach it to the QUnit object *after* we expose the public API, +// otherwise `assert` will become a global variable in browsers (#341). +assert = { + /** + * Asserts rough true-ish result. + * @name ok + * @function + * @example ok( "asdfasdf".length > 5, "There must be at least 5 chars" ); + */ + ok: function( result, msg ) { + if ( !config.current ) { + throw new Error( "ok() assertion outside test context, was " + sourceFromStacktrace(2) ); + } + result = !!result; + msg = msg || (result ? "okay" : "failed" ); + + var source, + details = { + module: config.current.module, + name: config.current.testName, + result: result, + message: msg + }; + + msg = "" + escapeText( msg ) + ""; + + if ( !result ) { + source = sourceFromStacktrace( 2 ); + if ( source ) { + details.source = source; + msg += "
Source:
" + escapeText( source ) + "
"; + } + } + runLoggingCallbacks( "log", QUnit, details ); + config.current.assertions.push({ + result: result, + message: msg + }); + }, + + /** + * Assert that the first two arguments are equal, with an optional message. + * Prints out both actual and expected values. + * @name equal + * @function + * @example equal( format( "Received {0} bytes.", 2), "Received 2 bytes.", "format() replaces {0} with next argument" ); + */ + equal: function( actual, expected, message ) { + /*jshint eqeqeq:false */ + QUnit.push( expected == actual, actual, expected, message ); + }, + + /** + * @name notEqual + * @function + */ + notEqual: function( actual, expected, message ) { + /*jshint eqeqeq:false */ + QUnit.push( expected != actual, actual, expected, message ); + }, + + /** + * @name propEqual + * @function + */ + propEqual: function( actual, expected, message ) { + actual = objectValues(actual); + expected = objectValues(expected); + QUnit.push( QUnit.equiv(actual, expected), actual, expected, message ); + }, + + /** + * @name notPropEqual + * @function + */ + notPropEqual: function( actual, expected, message ) { + actual = objectValues(actual); + expected = objectValues(expected); + QUnit.push( !QUnit.equiv(actual, expected), actual, expected, message ); + }, + + /** + * @name deepEqual + * @function + */ + deepEqual: function( actual, expected, message ) { + QUnit.push( QUnit.equiv(actual, expected), actual, expected, message ); + }, + + /** + * @name notDeepEqual + * @function + */ + notDeepEqual: function( actual, expected, message ) { + QUnit.push( !QUnit.equiv(actual, expected), actual, expected, message ); + }, + + /** + * @name strictEqual + * @function + */ + strictEqual: function( actual, expected, message ) { + QUnit.push( expected === actual, actual, expected, message ); + }, + + /** + * @name notStrictEqual + * @function + */ + notStrictEqual: function( actual, expected, message ) { + QUnit.push( expected !== actual, actual, expected, message ); + }, + + "throws": function( block, expected, message ) { + var actual, + expectedOutput = expected, + ok = false; + + // 'expected' is optional + if ( typeof expected === "string" ) { + message = expected; + expected = null; + } + + config.current.ignoreGlobalErrors = true; + try { + block.call( config.current.testEnvironment ); + } catch (e) { + actual = e; + } + config.current.ignoreGlobalErrors = false; + + if ( actual ) { + // we don't want to validate thrown error + if ( !expected ) { + ok = true; + expectedOutput = null; + // expected is a regexp + } else if ( QUnit.objectType( expected ) === "regexp" ) { + ok = expected.test( errorString( actual ) ); + // expected is a constructor + } else if ( actual instanceof expected ) { + ok = true; + // expected is a validation function which returns true is validation passed + } else if ( expected.call( {}, actual ) === true ) { + expectedOutput = null; + ok = true; + } + + QUnit.push( ok, actual, expectedOutput, message ); + } else { + QUnit.pushFailure( message, null, "No exception was thrown." ); + } + } +}; + +/** + * @deprecated since 1.8.0 + * Kept assertion helpers in root for backwards compatibility. + */ +extend( QUnit, assert ); + +/** + * @deprecated since 1.9.0 + * Kept root "raises()" for backwards compatibility. + * (Note that we don't introduce assert.raises). + */ +QUnit.raises = assert[ "throws" ]; + +/** + * @deprecated since 1.0.0, replaced with error pushes since 1.3.0 + * Kept to avoid TypeErrors for undefined methods. + */ +QUnit.equals = function() { + QUnit.push( false, false, false, "QUnit.equals has been deprecated since 2009 (e88049a0), use QUnit.equal instead" ); +}; +QUnit.same = function() { + QUnit.push( false, false, false, "QUnit.same has been deprecated since 2009 (e88049a0), use QUnit.deepEqual instead" ); +}; + +// We want access to the constructor's prototype +(function() { + function F() {} + F.prototype = QUnit; + QUnit = new F(); + // Make F QUnit's constructor so that we can add to the prototype later + QUnit.constructor = F; +}()); + +/** + * Config object: Maintain internal state + * Later exposed as QUnit.config + * `config` initialized at top of scope + */ +config = { + // The queue of tests to run + queue: [], + + // block until document ready + blocking: true, + + // when enabled, show only failing tests + // gets persisted through sessionStorage and can be changed in UI via checkbox + hidepassed: false, + + // by default, run previously failed tests first + // very useful in combination with "Hide passed tests" checked + reorder: true, + + // by default, modify document.title when suite is done + altertitle: true, + + // when enabled, all tests must call expect() + requireExpects: false, + + // add checkboxes that are persisted in the query-string + // when enabled, the id is set to `true` as a `QUnit.config` property + urlConfig: [ + { + id: "noglobals", + label: "Check for Globals", + tooltip: "Enabling this will test if any test introduces new properties on the `window` object. Stored as query-strings." + }, + { + id: "notrycatch", + label: "No try-catch", + tooltip: "Enabling this will run tests outside of a try-catch block. Makes debugging exceptions in IE reasonable. Stored as query-strings." + } + ], + + // Set of all modules. + modules: {}, + + // logging callback queues + begin: [], + done: [], + log: [], + testStart: [], + testDone: [], + moduleStart: [], + moduleDone: [] +}; + +// Export global variables, unless an 'exports' object exists, +// in that case we assume we're in CommonJS (dealt with on the bottom of the script) +if ( typeof exports === "undefined" ) { + extend( window, QUnit.constructor.prototype ); + + // Expose QUnit object + window.QUnit = QUnit; +} + +// Initialize more QUnit.config and QUnit.urlParams +(function() { + var i, + location = window.location || { search: "", protocol: "file:" }, + params = location.search.slice( 1 ).split( "&" ), + length = params.length, + urlParams = {}, + current; + + if ( params[ 0 ] ) { + for ( i = 0; i < length; i++ ) { + current = params[ i ].split( "=" ); + current[ 0 ] = decodeURIComponent( current[ 0 ] ); + // allow just a key to turn on a flag, e.g., test.html?noglobals + current[ 1 ] = current[ 1 ] ? decodeURIComponent( current[ 1 ] ) : true; + urlParams[ current[ 0 ] ] = current[ 1 ]; + } + } + + QUnit.urlParams = urlParams; + + // String search anywhere in moduleName+testName + config.filter = urlParams.filter; + + // Exact match of the module name + config.module = urlParams.module; + + config.testNumber = parseInt( urlParams.testNumber, 10 ) || null; + + // Figure out if we're running the tests from a server or not + QUnit.isLocal = location.protocol === "file:"; +}()); + +// Extend QUnit object, +// these after set here because they should not be exposed as global functions +extend( QUnit, { + assert: assert, + + config: config, + + // Initialize the configuration options + init: function() { + extend( config, { + stats: { all: 0, bad: 0 }, + moduleStats: { all: 0, bad: 0 }, + started: +new Date(), + updateRate: 1000, + blocking: false, + autostart: true, + autorun: false, + filter: "", + queue: [], + semaphore: 1 + }); + + var tests, banner, result, + qunit = id( "qunit" ); + + if ( qunit ) { + qunit.innerHTML = + "

" + escapeText( document.title ) + "

" + + "

" + + "
" + + "

" + + "
    "; + } + + tests = id( "qunit-tests" ); + banner = id( "qunit-banner" ); + result = id( "qunit-testresult" ); + + if ( tests ) { + tests.innerHTML = ""; + } + + if ( banner ) { + banner.className = ""; + } + + if ( result ) { + result.parentNode.removeChild( result ); + } + + if ( tests ) { + result = document.createElement( "p" ); + result.id = "qunit-testresult"; + result.className = "result"; + tests.parentNode.insertBefore( result, tests ); + result.innerHTML = "Running...
     "; + } + }, + + // Resets the test setup. Useful for tests that modify the DOM. + /* + DEPRECATED: Use multiple tests instead of resetting inside a test. + Use testStart or testDone for custom cleanup. + This method will throw an error in 2.0, and will be removed in 2.1 + */ + reset: function() { + var fixture = id( "qunit-fixture" ); + if ( fixture ) { + fixture.innerHTML = config.fixture; + } + }, + + // Trigger an event on an element. + // @example triggerEvent( document.body, "click" ); + triggerEvent: function( elem, type, event ) { + if ( document.createEvent ) { + event = document.createEvent( "MouseEvents" ); + event.initMouseEvent(type, true, true, elem.ownerDocument.defaultView, + 0, 0, 0, 0, 0, false, false, false, false, 0, null); + + elem.dispatchEvent( event ); + } else if ( elem.fireEvent ) { + elem.fireEvent( "on" + type ); + } + }, + + // Safe object type checking + is: function( type, obj ) { + return QUnit.objectType( obj ) === type; + }, + + objectType: function( obj ) { + if ( typeof obj === "undefined" ) { + return "undefined"; + // consider: typeof null === object + } + if ( obj === null ) { + return "null"; + } + + var match = toString.call( obj ).match(/^\[object\s(.*)\]$/), + type = match && match[1] || ""; + + switch ( type ) { + case "Number": + if ( isNaN(obj) ) { + return "nan"; + } + return "number"; + case "String": + case "Boolean": + case "Array": + case "Date": + case "RegExp": + case "Function": + return type.toLowerCase(); + } + if ( typeof obj === "object" ) { + return "object"; + } + return undefined; + }, + + push: function( result, actual, expected, message ) { + if ( !config.current ) { + throw new Error( "assertion outside test context, was " + sourceFromStacktrace() ); + } + + var output, source, + details = { + module: config.current.module, + name: config.current.testName, + result: result, + message: message, + actual: actual, + expected: expected + }; + + message = escapeText( message ) || ( result ? "okay" : "failed" ); + message = "" + message + ""; + output = message; + + if ( !result ) { + expected = escapeText( QUnit.jsDump.parse(expected) ); + actual = escapeText( QUnit.jsDump.parse(actual) ); + output += ""; + + if ( actual !== expected ) { + output += ""; + output += ""; + } + + source = sourceFromStacktrace(); + + if ( source ) { + details.source = source; + output += ""; + } + + output += "
    Expected:
    " + expected + "
    Result:
    " + actual + "
    Diff:
    " + QUnit.diff( expected, actual ) + "
    Source:
    " + escapeText( source ) + "
    "; + } + + runLoggingCallbacks( "log", QUnit, details ); + + config.current.assertions.push({ + result: !!result, + message: output + }); + }, + + pushFailure: function( message, source, actual ) { + if ( !config.current ) { + throw new Error( "pushFailure() assertion outside test context, was " + sourceFromStacktrace(2) ); + } + + var output, + details = { + module: config.current.module, + name: config.current.testName, + result: false, + message: message + }; + + message = escapeText( message ) || "error"; + message = "" + message + ""; + output = message; + + output += ""; + + if ( actual ) { + output += ""; + } + + if ( source ) { + details.source = source; + output += ""; + } + + output += "
    Result:
    " + escapeText( actual ) + "
    Source:
    " + escapeText( source ) + "
    "; + + runLoggingCallbacks( "log", QUnit, details ); + + config.current.assertions.push({ + result: false, + message: output + }); + }, + + url: function( params ) { + params = extend( extend( {}, QUnit.urlParams ), params ); + var key, + querystring = "?"; + + for ( key in params ) { + if ( hasOwn.call( params, key ) ) { + querystring += encodeURIComponent( key ) + "=" + + encodeURIComponent( params[ key ] ) + "&"; + } + } + return window.location.protocol + "//" + window.location.host + + window.location.pathname + querystring.slice( 0, -1 ); + }, + + extend: extend, + id: id, + addEvent: addEvent, + addClass: addClass, + hasClass: hasClass, + removeClass: removeClass + // load, equiv, jsDump, diff: Attached later +}); + +/** + * @deprecated: Created for backwards compatibility with test runner that set the hook function + * into QUnit.{hook}, instead of invoking it and passing the hook function. + * QUnit.constructor is set to the empty F() above so that we can add to it's prototype here. + * Doing this allows us to tell if the following methods have been overwritten on the actual + * QUnit object. + */ +extend( QUnit.constructor.prototype, { + + // Logging callbacks; all receive a single argument with the listed properties + // run test/logs.html for any related changes + begin: registerLoggingCallback( "begin" ), + + // done: { failed, passed, total, runtime } + done: registerLoggingCallback( "done" ), + + // log: { result, actual, expected, message } + log: registerLoggingCallback( "log" ), + + // testStart: { name } + testStart: registerLoggingCallback( "testStart" ), + + // testDone: { name, failed, passed, total, duration } + testDone: registerLoggingCallback( "testDone" ), + + // moduleStart: { name } + moduleStart: registerLoggingCallback( "moduleStart" ), + + // moduleDone: { name, failed, passed, total } + moduleDone: registerLoggingCallback( "moduleDone" ) +}); + +if ( typeof document === "undefined" || document.readyState === "complete" ) { + config.autorun = true; +} + +QUnit.load = function() { + runLoggingCallbacks( "begin", QUnit, {} ); + + // Initialize the config, saving the execution queue + var banner, filter, i, label, len, main, ol, toolbar, userAgent, val, + urlConfigCheckboxesContainer, urlConfigCheckboxes, moduleFilter, + numModules = 0, + moduleNames = [], + moduleFilterHtml = "", + urlConfigHtml = "", + oldconfig = extend( {}, config ); + + QUnit.init(); + extend(config, oldconfig); + + config.blocking = false; + + len = config.urlConfig.length; + + for ( i = 0; i < len; i++ ) { + val = config.urlConfig[i]; + if ( typeof val === "string" ) { + val = { + id: val, + label: val, + tooltip: "[no tooltip available]" + }; + } + config[ val.id ] = QUnit.urlParams[ val.id ]; + urlConfigHtml += ""; + } + for ( i in config.modules ) { + if ( config.modules.hasOwnProperty( i ) ) { + moduleNames.push(i); + } + } + numModules = moduleNames.length; + moduleNames.sort( function( a, b ) { + return a.localeCompare( b ); + }); + moduleFilterHtml += ""; + + // `userAgent` initialized at top of scope + userAgent = id( "qunit-userAgent" ); + if ( userAgent ) { + userAgent.innerHTML = navigator.userAgent; + } + + // `banner` initialized at top of scope + banner = id( "qunit-header" ); + if ( banner ) { + banner.innerHTML = "
    " + banner.innerHTML + " "; + } + + // `toolbar` initialized at top of scope + toolbar = id( "qunit-testrunner-toolbar" ); + if ( toolbar ) { + // `filter` initialized at top of scope + filter = document.createElement( "input" ); + filter.type = "checkbox"; + filter.id = "qunit-filter-pass"; + + addEvent( filter, "click", function() { + var tmp, + ol = document.getElementById( "qunit-tests" ); + + if ( filter.checked ) { + ol.className = ol.className + " hidepass"; + } else { + tmp = " " + ol.className.replace( /[\n\t\r]/g, " " ) + " "; + ol.className = tmp.replace( / hidepass /, " " ); + } + if ( defined.sessionStorage ) { + if (filter.checked) { + sessionStorage.setItem( "qunit-filter-passed-tests", "true" ); + } else { + sessionStorage.removeItem( "qunit-filter-passed-tests" ); + } + } + }); + + if ( config.hidepassed || defined.sessionStorage && sessionStorage.getItem( "qunit-filter-passed-tests" ) ) { + filter.checked = true; + // `ol` initialized at top of scope + ol = document.getElementById( "qunit-tests" ); + ol.className = ol.className + " hidepass"; + } + toolbar.appendChild( filter ); + + // `label` initialized at top of scope + label = document.createElement( "label" ); + label.setAttribute( "for", "qunit-filter-pass" ); + label.setAttribute( "title", "Only show tests and assertions that fail. Stored in sessionStorage." ); + label.innerHTML = "Hide passed tests"; + toolbar.appendChild( label ); + + urlConfigCheckboxesContainer = document.createElement("span"); + urlConfigCheckboxesContainer.innerHTML = urlConfigHtml; + urlConfigCheckboxes = urlConfigCheckboxesContainer.getElementsByTagName("input"); + // For oldIE support: + // * Add handlers to the individual elements instead of the container + // * Use "click" instead of "change" + // * Fallback from event.target to event.srcElement + addEvents( urlConfigCheckboxes, "click", function( event ) { + var params = {}, + target = event.target || event.srcElement; + params[ target.name ] = target.checked ? true : undefined; + window.location = QUnit.url( params ); + }); + toolbar.appendChild( urlConfigCheckboxesContainer ); + + if (numModules > 1) { + moduleFilter = document.createElement( "span" ); + moduleFilter.setAttribute( "id", "qunit-modulefilter-container" ); + moduleFilter.innerHTML = moduleFilterHtml; + addEvent( moduleFilter.lastChild, "change", function() { + var selectBox = moduleFilter.getElementsByTagName("select")[0], + selectedModule = decodeURIComponent(selectBox.options[selectBox.selectedIndex].value); + + window.location = QUnit.url({ + module: ( selectedModule === "" ) ? undefined : selectedModule, + // Remove any existing filters + filter: undefined, + testNumber: undefined + }); + }); + toolbar.appendChild(moduleFilter); + } + } + + // `main` initialized at top of scope + main = id( "qunit-fixture" ); + if ( main ) { + config.fixture = main.innerHTML; + } + + if ( config.autostart ) { + QUnit.start(); + } +}; + +addEvent( window, "load", QUnit.load ); + +// `onErrorFnPrev` initialized at top of scope +// Preserve other handlers +onErrorFnPrev = window.onerror; + +// Cover uncaught exceptions +// Returning true will suppress the default browser handler, +// returning false will let it run. +window.onerror = function ( error, filePath, linerNr ) { + var ret = false; + if ( onErrorFnPrev ) { + ret = onErrorFnPrev( error, filePath, linerNr ); + } + + // Treat return value as window.onerror itself does, + // Only do our handling if not suppressed. + if ( ret !== true ) { + if ( QUnit.config.current ) { + if ( QUnit.config.current.ignoreGlobalErrors ) { + return true; + } + QUnit.pushFailure( error, filePath + ":" + linerNr ); + } else { + QUnit.test( "global failure", extend( function() { + QUnit.pushFailure( error, filePath + ":" + linerNr ); + }, { validTest: validTest } ) ); + } + return false; + } + + return ret; +}; + +function done() { + config.autorun = true; + + // Log the last module results + if ( config.currentModule ) { + runLoggingCallbacks( "moduleDone", QUnit, { + name: config.currentModule, + failed: config.moduleStats.bad, + passed: config.moduleStats.all - config.moduleStats.bad, + total: config.moduleStats.all + }); + } + delete config.previousModule; + + var i, key, + banner = id( "qunit-banner" ), + tests = id( "qunit-tests" ), + runtime = +new Date() - config.started, + passed = config.stats.all - config.stats.bad, + html = [ + "Tests completed in ", + runtime, + " milliseconds.
    ", + "", + passed, + " assertions of ", + config.stats.all, + " passed, ", + config.stats.bad, + " failed." + ].join( "" ); + + if ( banner ) { + banner.className = ( config.stats.bad ? "qunit-fail" : "qunit-pass" ); + } + + if ( tests ) { + id( "qunit-testresult" ).innerHTML = html; + } + + if ( config.altertitle && typeof document !== "undefined" && document.title ) { + // show ✖ for good, ✔ for bad suite result in title + // use escape sequences in case file gets loaded with non-utf-8-charset + document.title = [ + ( config.stats.bad ? "\u2716" : "\u2714" ), + document.title.replace( /^[\u2714\u2716] /i, "" ) + ].join( " " ); + } + + // clear own sessionStorage items if all tests passed + if ( config.reorder && defined.sessionStorage && config.stats.bad === 0 ) { + // `key` & `i` initialized at top of scope + for ( i = 0; i < sessionStorage.length; i++ ) { + key = sessionStorage.key( i++ ); + if ( key.indexOf( "qunit-test-" ) === 0 ) { + sessionStorage.removeItem( key ); + } + } + } + + // scroll back to top to show results + if ( window.scrollTo ) { + window.scrollTo(0, 0); + } + + runLoggingCallbacks( "done", QUnit, { + failed: config.stats.bad, + passed: passed, + total: config.stats.all, + runtime: runtime + }); +} + +/** @return Boolean: true if this test should be ran */ +function validTest( test ) { + var include, + filter = config.filter && config.filter.toLowerCase(), + module = config.module && config.module.toLowerCase(), + fullName = (test.module + ": " + test.testName).toLowerCase(); + + // Internally-generated tests are always valid + if ( test.callback && test.callback.validTest === validTest ) { + delete test.callback.validTest; + return true; + } + + if ( config.testNumber ) { + return test.testNumber === config.testNumber; + } + + if ( module && ( !test.module || test.module.toLowerCase() !== module ) ) { + return false; + } + + if ( !filter ) { + return true; + } + + include = filter.charAt( 0 ) !== "!"; + if ( !include ) { + filter = filter.slice( 1 ); + } + + // If the filter matches, we need to honour include + if ( fullName.indexOf( filter ) !== -1 ) { + return include; + } + + // Otherwise, do the opposite + return !include; +} + +// so far supports only Firefox, Chrome and Opera (buggy), Safari (for real exceptions) +// Later Safari and IE10 are supposed to support error.stack as well +// See also https://developer.mozilla.org/en/JavaScript/Reference/Global_Objects/Error/Stack +function extractStacktrace( e, offset ) { + offset = offset === undefined ? 3 : offset; + + var stack, include, i; + + if ( e.stacktrace ) { + // Opera + return e.stacktrace.split( "\n" )[ offset + 3 ]; + } else if ( e.stack ) { + // Firefox, Chrome + stack = e.stack.split( "\n" ); + if (/^error$/i.test( stack[0] ) ) { + stack.shift(); + } + if ( fileName ) { + include = []; + for ( i = offset; i < stack.length; i++ ) { + if ( stack[ i ].indexOf( fileName ) !== -1 ) { + break; + } + include.push( stack[ i ] ); + } + if ( include.length ) { + return include.join( "\n" ); + } + } + return stack[ offset ]; + } else if ( e.sourceURL ) { + // Safari, PhantomJS + // hopefully one day Safari provides actual stacktraces + // exclude useless self-reference for generated Error objects + if ( /qunit.js$/.test( e.sourceURL ) ) { + return; + } + // for actual exceptions, this is useful + return e.sourceURL + ":" + e.line; + } +} +function sourceFromStacktrace( offset ) { + try { + throw new Error(); + } catch ( e ) { + return extractStacktrace( e, offset ); + } +} + +/** + * Escape text for attribute or text content. + */ +function escapeText( s ) { + if ( !s ) { + return ""; + } + s = s + ""; + // Both single quotes and double quotes (for attributes) + return s.replace( /['"<>&]/g, function( s ) { + switch( s ) { + case "'": + return "'"; + case "\"": + return """; + case "<": + return "<"; + case ">": + return ">"; + case "&": + return "&"; + } + }); +} + +function synchronize( callback, last ) { + config.queue.push( callback ); + + if ( config.autorun && !config.blocking ) { + process( last ); + } +} + +function process( last ) { + function next() { + process( last ); + } + var start = new Date().getTime(); + config.depth = config.depth ? config.depth + 1 : 1; + + while ( config.queue.length && !config.blocking ) { + if ( !defined.setTimeout || config.updateRate <= 0 || ( ( new Date().getTime() - start ) < config.updateRate ) ) { + config.queue.shift()(); + } else { + setTimeout( next, 13 ); + break; + } + } + config.depth--; + if ( last && !config.blocking && !config.queue.length && config.depth === 0 ) { + done(); + } +} + +function saveGlobal() { + config.pollution = []; + + if ( config.noglobals ) { + for ( var key in window ) { + if ( hasOwn.call( window, key ) ) { + // in Opera sometimes DOM element ids show up here, ignore them + if ( /^qunit-test-output/.test( key ) ) { + continue; + } + config.pollution.push( key ); + } + } + } +} + +function checkPollution() { + var newGlobals, + deletedGlobals, + old = config.pollution; + + saveGlobal(); + + newGlobals = diff( config.pollution, old ); + if ( newGlobals.length > 0 ) { + QUnit.pushFailure( "Introduced global variable(s): " + newGlobals.join(", ") ); + } + + deletedGlobals = diff( old, config.pollution ); + if ( deletedGlobals.length > 0 ) { + QUnit.pushFailure( "Deleted global variable(s): " + deletedGlobals.join(", ") ); + } +} + +// returns a new Array with the elements that are in a but not in b +function diff( a, b ) { + var i, j, + result = a.slice(); + + for ( i = 0; i < result.length; i++ ) { + for ( j = 0; j < b.length; j++ ) { + if ( result[i] === b[j] ) { + result.splice( i, 1 ); + i--; + break; + } + } + } + return result; +} + +function extend( a, b ) { + for ( var prop in b ) { + if ( hasOwn.call( b, prop ) ) { + // Avoid "Member not found" error in IE8 caused by messing with window.constructor + if ( !( prop === "constructor" && a === window ) ) { + if ( b[ prop ] === undefined ) { + delete a[ prop ]; + } else { + a[ prop ] = b[ prop ]; + } + } + } + } + + return a; +} + +/** + * @param {HTMLElement} elem + * @param {string} type + * @param {Function} fn + */ +function addEvent( elem, type, fn ) { + // Standards-based browsers + if ( elem.addEventListener ) { + elem.addEventListener( type, fn, false ); + // IE + } else { + elem.attachEvent( "on" + type, fn ); + } +} + +/** + * @param {Array|NodeList} elems + * @param {string} type + * @param {Function} fn + */ +function addEvents( elems, type, fn ) { + var i = elems.length; + while ( i-- ) { + addEvent( elems[i], type, fn ); + } +} + +function hasClass( elem, name ) { + return (" " + elem.className + " ").indexOf(" " + name + " ") > -1; +} + +function addClass( elem, name ) { + if ( !hasClass( elem, name ) ) { + elem.className += (elem.className ? " " : "") + name; + } +} + +function removeClass( elem, name ) { + var set = " " + elem.className + " "; + // Class name may appear multiple times + while ( set.indexOf(" " + name + " ") > -1 ) { + set = set.replace(" " + name + " " , " "); + } + // If possible, trim it for prettiness, but not necessarily + elem.className = typeof set.trim === "function" ? set.trim() : set.replace(/^\s+|\s+$/g, ""); +} + +function id( name ) { + return !!( typeof document !== "undefined" && document && document.getElementById ) && + document.getElementById( name ); +} + +function registerLoggingCallback( key ) { + return function( callback ) { + config[key].push( callback ); + }; +} + +// Supports deprecated method of completely overwriting logging callbacks +function runLoggingCallbacks( key, scope, args ) { + var i, callbacks; + if ( QUnit.hasOwnProperty( key ) ) { + QUnit[ key ].call(scope, args ); + } else { + callbacks = config[ key ]; + for ( i = 0; i < callbacks.length; i++ ) { + callbacks[ i ].call( scope, args ); + } + } +} + +// Test for equality any JavaScript type. +// Author: Philippe Rathé +QUnit.equiv = (function() { + + // Call the o related callback with the given arguments. + function bindCallbacks( o, callbacks, args ) { + var prop = QUnit.objectType( o ); + if ( prop ) { + if ( QUnit.objectType( callbacks[ prop ] ) === "function" ) { + return callbacks[ prop ].apply( callbacks, args ); + } else { + return callbacks[ prop ]; // or undefined + } + } + } + + // the real equiv function + var innerEquiv, + // stack to decide between skip/abort functions + callers = [], + // stack to avoiding loops from circular referencing + parents = [], + parentsB = [], + + getProto = Object.getPrototypeOf || function ( obj ) { + /*jshint camelcase:false */ + return obj.__proto__; + }, + callbacks = (function () { + + // for string, boolean, number and null + function useStrictEquality( b, a ) { + /*jshint eqeqeq:false */ + if ( b instanceof a.constructor || a instanceof b.constructor ) { + // to catch short annotation VS 'new' annotation of a + // declaration + // e.g. var i = 1; + // var j = new Number(1); + return a == b; + } else { + return a === b; + } + } + + return { + "string": useStrictEquality, + "boolean": useStrictEquality, + "number": useStrictEquality, + "null": useStrictEquality, + "undefined": useStrictEquality, + + "nan": function( b ) { + return isNaN( b ); + }, + + "date": function( b, a ) { + return QUnit.objectType( b ) === "date" && a.valueOf() === b.valueOf(); + }, + + "regexp": function( b, a ) { + return QUnit.objectType( b ) === "regexp" && + // the regex itself + a.source === b.source && + // and its modifiers + a.global === b.global && + // (gmi) ... + a.ignoreCase === b.ignoreCase && + a.multiline === b.multiline && + a.sticky === b.sticky; + }, + + // - skip when the property is a method of an instance (OOP) + // - abort otherwise, + // initial === would have catch identical references anyway + "function": function() { + var caller = callers[callers.length - 1]; + return caller !== Object && typeof caller !== "undefined"; + }, + + "array": function( b, a ) { + var i, j, len, loop, aCircular, bCircular; + + // b could be an object literal here + if ( QUnit.objectType( b ) !== "array" ) { + return false; + } + + len = a.length; + if ( len !== b.length ) { + // safe and faster + return false; + } + + // track reference to avoid circular references + parents.push( a ); + parentsB.push( b ); + for ( i = 0; i < len; i++ ) { + loop = false; + for ( j = 0; j < parents.length; j++ ) { + aCircular = parents[j] === a[i]; + bCircular = parentsB[j] === b[i]; + if ( aCircular || bCircular ) { + if ( a[i] === b[i] || aCircular && bCircular ) { + loop = true; + } else { + parents.pop(); + parentsB.pop(); + return false; + } + } + } + if ( !loop && !innerEquiv(a[i], b[i]) ) { + parents.pop(); + parentsB.pop(); + return false; + } + } + parents.pop(); + parentsB.pop(); + return true; + }, + + "object": function( b, a ) { + /*jshint forin:false */ + var i, j, loop, aCircular, bCircular, + // Default to true + eq = true, + aProperties = [], + bProperties = []; + + // comparing constructors is more strict than using + // instanceof + if ( a.constructor !== b.constructor ) { + // Allow objects with no prototype to be equivalent to + // objects with Object as their constructor. + if ( !(( getProto(a) === null && getProto(b) === Object.prototype ) || + ( getProto(b) === null && getProto(a) === Object.prototype ) ) ) { + return false; + } + } + + // stack constructor before traversing properties + callers.push( a.constructor ); + + // track reference to avoid circular references + parents.push( a ); + parentsB.push( b ); + + // be strict: don't ensure hasOwnProperty and go deep + for ( i in a ) { + loop = false; + for ( j = 0; j < parents.length; j++ ) { + aCircular = parents[j] === a[i]; + bCircular = parentsB[j] === b[i]; + if ( aCircular || bCircular ) { + if ( a[i] === b[i] || aCircular && bCircular ) { + loop = true; + } else { + eq = false; + break; + } + } + } + aProperties.push(i); + if ( !loop && !innerEquiv(a[i], b[i]) ) { + eq = false; + break; + } + } + + parents.pop(); + parentsB.pop(); + callers.pop(); // unstack, we are done + + for ( i in b ) { + bProperties.push( i ); // collect b's properties + } + + // Ensures identical properties name + return eq && innerEquiv( aProperties.sort(), bProperties.sort() ); + } + }; + }()); + + innerEquiv = function() { // can take multiple arguments + var args = [].slice.apply( arguments ); + if ( args.length < 2 ) { + return true; // end transition + } + + return (function( a, b ) { + if ( a === b ) { + return true; // catch the most you can + } else if ( a === null || b === null || typeof a === "undefined" || + typeof b === "undefined" || + QUnit.objectType(a) !== QUnit.objectType(b) ) { + return false; // don't lose time with error prone cases + } else { + return bindCallbacks(a, callbacks, [ b, a ]); + } + + // apply transition with (1..n) arguments + }( args[0], args[1] ) && innerEquiv.apply( this, args.splice(1, args.length - 1 )) ); + }; + + return innerEquiv; +}()); + +/** + * jsDump Copyright (c) 2008 Ariel Flesler - aflesler(at)gmail(dot)com | + * http://flesler.blogspot.com Licensed under BSD + * (http://www.opensource.org/licenses/bsd-license.php) Date: 5/15/2008 + * + * @projectDescription Advanced and extensible data dumping for Javascript. + * @version 1.0.0 + * @author Ariel Flesler + * @link {http://flesler.blogspot.com/2008/05/jsdump-pretty-dump-of-any-javascript.html} + */ +QUnit.jsDump = (function() { + function quote( str ) { + return "\"" + str.toString().replace( /"/g, "\\\"" ) + "\""; + } + function literal( o ) { + return o + ""; + } + function join( pre, arr, post ) { + var s = jsDump.separator(), + base = jsDump.indent(), + inner = jsDump.indent(1); + if ( arr.join ) { + arr = arr.join( "," + s + inner ); + } + if ( !arr ) { + return pre + post; + } + return [ pre, inner + arr, base + post ].join(s); + } + function array( arr, stack ) { + var i = arr.length, ret = new Array(i); + this.up(); + while ( i-- ) { + ret[i] = this.parse( arr[i] , undefined , stack); + } + this.down(); + return join( "[", ret, "]" ); + } + + var reName = /^function (\w+)/, + jsDump = { + // type is used mostly internally, you can fix a (custom)type in advance + parse: function( obj, type, stack ) { + stack = stack || [ ]; + var inStack, res, + parser = this.parsers[ type || this.typeOf(obj) ]; + + type = typeof parser; + inStack = inArray( obj, stack ); + + if ( inStack !== -1 ) { + return "recursion(" + (inStack - stack.length) + ")"; + } + if ( type === "function" ) { + stack.push( obj ); + res = parser.call( this, obj, stack ); + stack.pop(); + return res; + } + return ( type === "string" ) ? parser : this.parsers.error; + }, + typeOf: function( obj ) { + var type; + if ( obj === null ) { + type = "null"; + } else if ( typeof obj === "undefined" ) { + type = "undefined"; + } else if ( QUnit.is( "regexp", obj) ) { + type = "regexp"; + } else if ( QUnit.is( "date", obj) ) { + type = "date"; + } else if ( QUnit.is( "function", obj) ) { + type = "function"; + } else if ( typeof obj.setInterval !== undefined && typeof obj.document !== "undefined" && typeof obj.nodeType === "undefined" ) { + type = "window"; + } else if ( obj.nodeType === 9 ) { + type = "document"; + } else if ( obj.nodeType ) { + type = "node"; + } else if ( + // native arrays + toString.call( obj ) === "[object Array]" || + // NodeList objects + ( typeof obj.length === "number" && typeof obj.item !== "undefined" && ( obj.length ? obj.item(0) === obj[0] : ( obj.item( 0 ) === null && typeof obj[0] === "undefined" ) ) ) + ) { + type = "array"; + } else if ( obj.constructor === Error.prototype.constructor ) { + type = "error"; + } else { + type = typeof obj; + } + return type; + }, + separator: function() { + return this.multiline ? this.HTML ? "
    " : "\n" : this.HTML ? " " : " "; + }, + // extra can be a number, shortcut for increasing-calling-decreasing + indent: function( extra ) { + if ( !this.multiline ) { + return ""; + } + var chr = this.indentChar; + if ( this.HTML ) { + chr = chr.replace( /\t/g, " " ).replace( / /g, " " ); + } + return new Array( this.depth + ( extra || 0 ) ).join(chr); + }, + up: function( a ) { + this.depth += a || 1; + }, + down: function( a ) { + this.depth -= a || 1; + }, + setParser: function( name, parser ) { + this.parsers[name] = parser; + }, + // The next 3 are exposed so you can use them + quote: quote, + literal: literal, + join: join, + // + depth: 1, + // This is the list of parsers, to modify them, use jsDump.setParser + parsers: { + window: "[Window]", + document: "[Document]", + error: function(error) { + return "Error(\"" + error.message + "\")"; + }, + unknown: "[Unknown]", + "null": "null", + "undefined": "undefined", + "function": function( fn ) { + var ret = "function", + // functions never have name in IE + name = "name" in fn ? fn.name : (reName.exec(fn) || [])[1]; + + if ( name ) { + ret += " " + name; + } + ret += "( "; + + ret = [ ret, QUnit.jsDump.parse( fn, "functionArgs" ), "){" ].join( "" ); + return join( ret, QUnit.jsDump.parse(fn,"functionCode" ), "}" ); + }, + array: array, + nodelist: array, + "arguments": array, + object: function( map, stack ) { + /*jshint forin:false */ + var ret = [ ], keys, key, val, i; + QUnit.jsDump.up(); + keys = []; + for ( key in map ) { + keys.push( key ); + } + keys.sort(); + for ( i = 0; i < keys.length; i++ ) { + key = keys[ i ]; + val = map[ key ]; + ret.push( QUnit.jsDump.parse( key, "key" ) + ": " + QUnit.jsDump.parse( val, undefined, stack ) ); + } + QUnit.jsDump.down(); + return join( "{", ret, "}" ); + }, + node: function( node ) { + var len, i, val, + open = QUnit.jsDump.HTML ? "<" : "<", + close = QUnit.jsDump.HTML ? ">" : ">", + tag = node.nodeName.toLowerCase(), + ret = open + tag, + attrs = node.attributes; + + if ( attrs ) { + for ( i = 0, len = attrs.length; i < len; i++ ) { + val = attrs[i].nodeValue; + // IE6 includes all attributes in .attributes, even ones not explicitly set. + // Those have values like undefined, null, 0, false, "" or "inherit". + if ( val && val !== "inherit" ) { + ret += " " + attrs[i].nodeName + "=" + QUnit.jsDump.parse( val, "attribute" ); + } + } + } + ret += close; + + // Show content of TextNode or CDATASection + if ( node.nodeType === 3 || node.nodeType === 4 ) { + ret += node.nodeValue; + } + + return ret + open + "/" + tag + close; + }, + // function calls it internally, it's the arguments part of the function + functionArgs: function( fn ) { + var args, + l = fn.length; + + if ( !l ) { + return ""; + } + + args = new Array(l); + while ( l-- ) { + // 97 is 'a' + args[l] = String.fromCharCode(97+l); + } + return " " + args.join( ", " ) + " "; + }, + // object calls it internally, the key part of an item in a map + key: quote, + // function calls it internally, it's the content of the function + functionCode: "[code]", + // node calls it internally, it's an html attribute value + attribute: quote, + string: quote, + date: quote, + regexp: literal, + number: literal, + "boolean": literal + }, + // if true, entities are escaped ( <, >, \t, space and \n ) + HTML: false, + // indentation unit + indentChar: " ", + // if true, items in a collection, are separated by a \n, else just a space. + multiline: true + }; + + return jsDump; +}()); + +// from jquery.js +function inArray( elem, array ) { + if ( array.indexOf ) { + return array.indexOf( elem ); + } + + for ( var i = 0, length = array.length; i < length; i++ ) { + if ( array[ i ] === elem ) { + return i; + } + } + + return -1; +} + +/* + * Javascript Diff Algorithm + * By John Resig (http://ejohn.org/) + * Modified by Chu Alan "sprite" + * + * Released under the MIT license. + * + * More Info: + * http://ejohn.org/projects/javascript-diff-algorithm/ + * + * Usage: QUnit.diff(expected, actual) + * + * QUnit.diff( "the quick brown fox jumped over", "the quick fox jumps over" ) == "the quick brown fox jumped jumps over" + */ +QUnit.diff = (function() { + /*jshint eqeqeq:false, eqnull:true */ + function diff( o, n ) { + var i, + ns = {}, + os = {}; + + for ( i = 0; i < n.length; i++ ) { + if ( !hasOwn.call( ns, n[i] ) ) { + ns[ n[i] ] = { + rows: [], + o: null + }; + } + ns[ n[i] ].rows.push( i ); + } + + for ( i = 0; i < o.length; i++ ) { + if ( !hasOwn.call( os, o[i] ) ) { + os[ o[i] ] = { + rows: [], + n: null + }; + } + os[ o[i] ].rows.push( i ); + } + + for ( i in ns ) { + if ( hasOwn.call( ns, i ) ) { + if ( ns[i].rows.length === 1 && hasOwn.call( os, i ) && os[i].rows.length === 1 ) { + n[ ns[i].rows[0] ] = { + text: n[ ns[i].rows[0] ], + row: os[i].rows[0] + }; + o[ os[i].rows[0] ] = { + text: o[ os[i].rows[0] ], + row: ns[i].rows[0] + }; + } + } + } + + for ( i = 0; i < n.length - 1; i++ ) { + if ( n[i].text != null && n[ i + 1 ].text == null && n[i].row + 1 < o.length && o[ n[i].row + 1 ].text == null && + n[ i + 1 ] == o[ n[i].row + 1 ] ) { + + n[ i + 1 ] = { + text: n[ i + 1 ], + row: n[i].row + 1 + }; + o[ n[i].row + 1 ] = { + text: o[ n[i].row + 1 ], + row: i + 1 + }; + } + } + + for ( i = n.length - 1; i > 0; i-- ) { + if ( n[i].text != null && n[ i - 1 ].text == null && n[i].row > 0 && o[ n[i].row - 1 ].text == null && + n[ i - 1 ] == o[ n[i].row - 1 ]) { + + n[ i - 1 ] = { + text: n[ i - 1 ], + row: n[i].row - 1 + }; + o[ n[i].row - 1 ] = { + text: o[ n[i].row - 1 ], + row: i - 1 + }; + } + } + + return { + o: o, + n: n + }; + } + + return function( o, n ) { + o = o.replace( /\s+$/, "" ); + n = n.replace( /\s+$/, "" ); + + var i, pre, + str = "", + out = diff( o === "" ? [] : o.split(/\s+/), n === "" ? [] : n.split(/\s+/) ), + oSpace = o.match(/\s+/g), + nSpace = n.match(/\s+/g); + + if ( oSpace == null ) { + oSpace = [ " " ]; + } + else { + oSpace.push( " " ); + } + + if ( nSpace == null ) { + nSpace = [ " " ]; + } + else { + nSpace.push( " " ); + } + + if ( out.n.length === 0 ) { + for ( i = 0; i < out.o.length; i++ ) { + str += "" + out.o[i] + oSpace[i] + ""; + } + } + else { + if ( out.n[0].text == null ) { + for ( n = 0; n < out.o.length && out.o[n].text == null; n++ ) { + str += "" + out.o[n] + oSpace[n] + ""; + } + } + + for ( i = 0; i < out.n.length; i++ ) { + if (out.n[i].text == null) { + str += "" + out.n[i] + nSpace[i] + ""; + } + else { + // `pre` initialized at top of scope + pre = ""; + + for ( n = out.n[i].row + 1; n < out.o.length && out.o[n].text == null; n++ ) { + pre += "" + out.o[n] + oSpace[n] + ""; + } + str += " " + out.n[i].text + nSpace[i] + pre; + } + } + } + + return str; + }; +}()); + +// for CommonJS environments, export everything +if ( typeof exports !== "undefined" ) { + extend( exports, QUnit.constructor.prototype ); +} + +// get at whatever the global object is, like window in browsers +}( (function() {return this;}.call()) )); diff --git a/node_modules/toastr/package/package/tests/toastr-tests.html b/node_modules/toastr/package/package/tests/toastr-tests.html new file mode 100644 index 0000000..1fe155b --- /dev/null +++ b/node_modules/toastr/package/package/tests/toastr-tests.html @@ -0,0 +1,21 @@ + + + + toastr QUnit Tests + + + + +
    +

    toastr QUnit Tests

    +

    +
    +

    +
      +
      test markup, will be hidden
      + + + + + + diff --git a/node_modules/toastr/package/package/tests/unit/qunit-helper.js b/node_modules/toastr/package/package/tests/unit/qunit-helper.js new file mode 100644 index 0000000..42ce5e2 --- /dev/null +++ b/node_modules/toastr/package/package/tests/unit/qunit-helper.js @@ -0,0 +1,13 @@ +/** + * Hack to expose spec count from QUnit to Karma + */ + +var testCount = 0; +var qunitTest = QUnit.test; +QUnit.test = window.test = function () { + testCount += 1; + qunitTest.apply(this, arguments); +}; +QUnit.begin(function (args) { + args.totalTests = testCount; +}); diff --git a/node_modules/toastr/package/package/tests/unit/toastr-tests.js b/node_modules/toastr/package/package/tests/unit/toastr-tests.js new file mode 100644 index 0000000..0d834ed --- /dev/null +++ b/node_modules/toastr/package/package/tests/unit/toastr-tests.js @@ -0,0 +1,625 @@ +/// +/// +(function () { + var iconClasses = { + error: 'toast-error', + info: 'toast-info', + success: 'toast-success', + warning: 'toast-warning' + }; + var positionClasses = { + topRight: 'toast-top-right', + bottomRight: 'toast-bottom-right', + bottomLeft: 'toast-bottom-left', + topLeft: 'toast-top-left', + topCenter: 'toast-top-center', + bottomCenter: 'toast-bottom-center' + }; + var sampleMsg = 'I don\'t think they really exist'; + var sampleTitle = 'ROUS'; + var selectors = { + container: 'div#toast-container', + toastInfo: 'div#toast-container > div.toast-info', + toastWarning: 'div#toast-container > div.toast-success', + toastError: 'div#toast-container > div.toast-error', + toastSuccess: 'div#toast-container > div.toast-success' + }; + + toastr.options = { + timeOut: 2000, + extendedTimeOut: 0, + fadeOut: 0, + fadeIn: 0, + showDuration: 0, + hideDuration: 0, + debug: false + }; + + var delay = toastr.options.timeOut + 500; + + // 'Clears' must go first + module('clear'); + asyncTest('clear - show 3 toasts, clear the 2nd', 1, function () { + //Arrange + var $toast = []; + $toast[0] = toastr.info(sampleMsg, sampleTitle + '-1'); + $toast[1] = toastr.info(sampleMsg, sampleTitle + '-2'); + $toast[2] = toastr.info(sampleMsg, sampleTitle + '-3'); + var $container = toastr.getContainer(); + //Act + toastr.clear($toast[1]); + //Assert + setTimeout(function () { + //debugger; + //console.log($container.children().length); + ok($container && $container.children().length === 2); + //Teardown + resetContainer(); + start(); + }, 1000); + }); + asyncTest('clear - show 3 toasts, clear all 3, 0 left', 1, function () { + //Arrange + var $toast = []; + $toast[0] = toastr.info(sampleMsg, sampleTitle + '-1'); + $toast[1] = toastr.info(sampleMsg, sampleTitle + '-2'); + $toast[2] = toastr.info(sampleMsg, sampleTitle + '-3'); + var $container = toastr.getContainer(); + //Act + toastr.clear(); + //Assert + setTimeout(function () { + ok($container && $container.children().length === 0); + //Teardown + resetContainer(); + start(); + }, delay); + }); + test('clear - after clear with force option toast with focus disappears', 1, function () { + //Arrange + var $toast; + var msg = sampleMsg + '

      '; + //Act + $toast = toastr.info(msg, sampleTitle + '-1'); + $toast.find('button').focus(); + toastr.clear($toast, { force: true }); + var $container = toastr.getContainer(); + //Assert + ok($container && $container.children().length === 0, 'Focused toast after a clear with force is not visible'); + //Teardown + resetContainer(); + }); + asyncTest('clear and show - show 2 toasts, clear both, then show 1 more', 2, function () { + //Arrange + var $toast = []; + $toast[0] = toastr.info(sampleMsg, sampleTitle + '-1'); + $toast[1] = toastr.info(sampleMsg, sampleTitle + '-2'); + var $container = toastr.getContainer(); + toastr.clear(); + //Act + setTimeout(function () { + $toast[2] = toastr.info(sampleMsg, sampleTitle + '-3-Visible'); + //Assert + equal($toast[2].find('div.toast-title').html(), sampleTitle + '-3-Visible', 'Finds toast after a clear'); + ok($toast[2].is(':visible'), 'Toast after a clear is visible'); + //Teardown + resetContainer(); + start(); + }, delay); + }); + asyncTest('clear and show - clear removes toast container', 2, function () { + //Arrange + var $toast = []; + $toast[0] = toastr.info(sampleMsg, sampleTitle + '-1'); + $toast[1] = toastr.info(sampleMsg, sampleTitle + '-2'); + var $container = toastr.getContainer(); + toastr.clear(); + //Act + setTimeout(function () { + //Assert + equal($(selectors.container).length, 0, 'Toast container does not exist'); + ok(!$toast[1].is(':visible'), 'Toast after a clear is visible'); + //Teardown + resetContainer(); + start(); + }, delay); + }); + asyncTest('clear and show - after clear new toast creates container', 1, function () { + //Arrange + var $toast = []; + $toast[0] = toastr.info(sampleMsg, sampleTitle + '-1'); + $toast[1] = toastr.info(sampleMsg, sampleTitle + '-2'); + var $container = toastr.getContainer(); + toastr.clear(); + //Act + setTimeout(function () { + $toast[2] = toastr.info(sampleMsg, sampleTitle + '-3-Visible'); + //Assert + equal($(selectors.container).find('div.toast-title').html(), sampleTitle + '-3-Visible', 'Finds toast after a clear'); //Teardown + resetContainer(); + start(); + }, delay); + }); + test('clear and show - after clear all toasts new toast still appears', 1, function () { + //Arrange + var $toast = []; + //Act + $toast[0] = toastr.info(sampleMsg, sampleTitle + '-1'); + $toast[1] = toastr.info(sampleMsg, sampleTitle + '-2'); + toastr.clear(); + $toast[2] = toastr.info(sampleMsg, sampleTitle + '-3-Visible'); + //Assert + ok($toast[2].is(':visible'), 'Toast after a clear is visible'); + //Teardown + resetContainer(); + }); + module('info'); + test('info - pass title and message', 3, function () { + //Arrange + //Act + var $toast = toastr.info(sampleMsg, sampleTitle); + //Assert + equal($toast.find('div.toast-title').html(), sampleTitle, 'Sets title'); + equal($toast.find('div.toast-message').html(), sampleMsg, 'Sets message'); + ok($toast.hasClass(iconClasses.info), 'Sets info icon'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + test('info - pass message, but no title', 3, function () { + //Arrange + //Act + var $toast = toastr.info(sampleMsg); + //Assert + equal($toast.find('div.toast-title').length, 0, 'Sets null title'); + equal($toast.find('div.toast-message').html(), sampleMsg, 'Sets message'); + ok($toast.hasClass(iconClasses.info), 'Sets info icon'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + test('info - pass no message nor title', 3, function () { + //Arrange + //Act + var $toast = toastr.info(); //Assert + equal($toast.find('div.toast-title').length, 0, 'Sets null title'); + equal($toast.find('div.toast-message').html(), null, 'Sets message'); + ok($toast.hasClass(iconClasses.info), 'Sets info icon'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + module('warning'); + test('warning - pass message and title', 3, function () { + //Arrange + //Act + var $toast = toastr.warning(sampleMsg, sampleTitle); + //Assert + equal($toast.find('div.toast-title').html(), sampleTitle, 'Sets title'); + equal($toast.find('div.toast-message').html(), sampleMsg, 'Sets message'); + ok($toast.hasClass(iconClasses.warning), 'Sets warning icon'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + test('warning - pass message, but no title', 3, function () { + //Arrange + //Act + var $toast = toastr.warning(sampleMsg); + //Assert + equal($toast.find('div.toast-title').length, 0, 'Sets empty title'); + equal($toast.find('div.toast-message').html(), sampleMsg, 'Sets message'); + ok($toast.hasClass(iconClasses.warning), 'Sets warning icon'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + test('warning - no message nor title', 3, function () { + //Arrange + //Act + var $toast = toastr.warning(''); + //Assert + equal($toast.find('div.toast-title').length, 0, 'Sets null title'); + equal($toast.find('div.toast-message').length, 0, 'Sets empty message'); + ok($toast.hasClass(iconClasses.warning), 'Sets warning icon'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + module('error'); + test('error - pass message and title', 3, function () { + //Arrange + //Act + var $toast = toastr.error(sampleMsg, sampleTitle); + //Assert + equal($toast.find('div.toast-title').html(), sampleTitle, 'Sets title'); + equal($toast.find('div.toast-message').html(), sampleMsg, 'Sets message'); + ok($toast.hasClass(iconClasses.error), 'Sets error icon'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + test('error - pass message, but no title', 3, function () { + //Arrange + //Act + var $toast = toastr.error(sampleMsg); //Assert + equal($toast.find('div.toast-title').length, 0, 'Sets empty title'); + equal($toast.find('div.toast-message').html(), sampleMsg, 'Sets message'); + ok($toast.hasClass(iconClasses.error), 'Sets error icon'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + test('error - no message nor title', 3, function () { + //Arrange + //Act + var $toast = toastr.error(''); + //Assert + equal($toast.find('div.toast-title').length, 0, 'Sets empty title'); + equal($toast.find('div.toast-message').length, 0, 'Sets empty message'); + ok($toast.hasClass(iconClasses.error), 'Sets error icon'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + module('success'); + test('success - pass message and title', 3, function () { + //Arrange + //Act + var $toast = toastr.success(sampleMsg, sampleTitle); + //Assert + equal($toast.find('div.toast-title').html(), sampleTitle, 'Sets title'); + equal($toast.find('div.toast-message').html(), sampleMsg, 'Sets message'); + ok($toast.hasClass(iconClasses.success), 'Sets success icon'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + test('success - pass message, but no title', 3, function () { + //Arrange + //Act + var $toast = toastr.success(sampleMsg); + //Assert + equal($toast.find('div.toast-title').length, 0, 'Sets empty title'); + equal($toast.find('div.toast-message').html(), sampleMsg, 'Sets message'); + ok($toast.hasClass(iconClasses.success), 'Sets success icon'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + test('success - no message nor title', 3, function () { + //Arrange + //Act + var $toast = toastr.success(''); + //Assert + equal($toast.find('div.toast-title').length, 0, 'Sets null title'); + equal($toast.find('div.toast-message').length, 0, 'Sets empty message'); + ok($toast.hasClass(iconClasses.success), 'Sets success icon'); //Teardown + $toast.remove(); + clearContainerChildren(); + }); + + module('closeButton', { + teardown: function () { + toastr.options.closeButton = false; + } + }); + test('close button disabled', 1, function () { + //Arrange + toastr.options.closeButton = false; + //Act + var $toast = toastr.success(''); + //Assert + equal($toast.find('button.toast-close-button').length, 0, 'close button should not exist with closeButton=false'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + test('close button enabled', 1, function () { + //Arrange + toastr.options.closeButton = true; + //Act + var $toast = toastr.success(''); + //Assert + equal($toast.find('button.toast-close-button').length, 1, 'close button should exist with closeButton=true'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + test('close button has type=button', 1, function () { + //Arrange + toastr.options.closeButton = true; + //Act + var $toast = toastr.success(''); + //Assert + equal($toast.find('button[type="button"].toast-close-button').length, 1, 'close button should have type=button'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + + module('progressBar', { + teardown: function () { + toastr.options.progressBar = false; + } + }); + test('progress bar disabled', 1, function () { + //Arrange + toastr.options.progressBar = false; + //Act + var $toast = toastr.success(''); + //Assert + equal($toast.find('div.toast-progress').length, 0, 'progress bar should not exist with progressBar=false'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + test('progress bar enabled', 1, function () { + //Arrange + toastr.options.progressBar = true; + //Act + var $toast = toastr.success(''); + //Assert + equal($toast.find('div.toast-progress').length, 1, 'progress bar should exist with progressBar=true'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + + module('event'); + asyncTest('event - onShown is executed', 1, function () { + // Arrange + var run = false; + var onShown = function () { run = true; }; + toastr.options.onShown = onShown; + // Act + var $toast = toastr.success(sampleMsg, sampleTitle); + setTimeout(function () { + // Assert + ok(run); + //Teardown + $toast.remove(); + clearContainerChildren(); + start(); + }, delay); + }); + + asyncTest('event - onHidden is executed', 1, function () { + //Arrange + var run = false; + var onHidden = function () { run = true; }; + toastr.options.onHidden = onHidden; + toastr.options.timeOut = 1; + //Act + var $toast = toastr.success(sampleMsg, sampleTitle); + setTimeout(function () { + // Assert + ok(run); //Teardown + $toast.remove(); + clearContainerChildren(); + start(); + }, delay); + }); + + asyncTest('event - onShown and onHidden are both executed', 2, function () { + //Arrange + var onShowRun = false; + var onHideRun = false; + var onShow = function () { onShowRun = true; }; + var onHide = function () { onHideRun = true; }; + toastr.options.onShown = onShow; + toastr.options.onHidden = onHide; + toastr.options.timeOut = 1; + //Act + var $toast = toastr.success(sampleMsg, sampleTitle); + setTimeout(function () { + // Assert + ok(onShowRun); + ok(onHideRun); + //Teardown + $toast.remove(); + clearContainerChildren(); + start(); + }, delay); + }); + + test('event - message appears when no show or hide method functions provided', 1, function () { + //Arrange + //Act + var $toast = toastr.success(sampleMsg, sampleTitle); + //Assert + ok($toast.hasClass(iconClasses.success), 'Sets success icon'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + + test('event - prevent duplicate sequential toasts.', 1, function(){ + toastr.options.preventDuplicates = true; + + var $toast = []; + $toast[0] = toastr.info(sampleMsg, sampleTitle); + $toast[1] = toastr.info(sampleMsg, sampleTitle); + $toast[2] = toastr.info(sampleMsg + " 1", sampleTitle); + $toast[3] = toastr.info(sampleMsg, sampleTitle); + var $container = toastr.getContainer(); + + ok($container && $container.children().length === 3); + + clearContainerChildren(); + }); + + test('event - prevent duplicate sequential toasts, but allow previous after clear.', 1, function(){ + toastr.options.preventDuplicates = true; + + var $toast = []; + $toast[0] = toastr.info(sampleMsg, sampleTitle); + $toast[1] = toastr.info(sampleMsg, sampleTitle); + clearContainerChildren(); + $toast[3] = toastr.info(sampleMsg, sampleTitle); + var $container = toastr.getContainer(); + + ok($container && $container.children().length === 1); + + clearContainerChildren(); + }); + + test('event - allow duplicate sequential toasts.', 1, function(){ + toastr.options.preventDuplicates = false; + + var $toast = []; + $toast[0] = toastr.info(sampleMsg, sampleTitle); + $toast[1] = toastr.info(sampleMsg, sampleTitle); + $toast[1] = toastr.info(sampleMsg, sampleTitle); + var $container = toastr.getContainer(); + + ok($container && $container.children().length === 3); + + clearContainerChildren(); + }); + + test('event - allow preventDuplicates option to be overridden.', 1, function() { + var $toast = []; + + $toast[0] = toastr.info(sampleMsg, sampleTitle, { + preventDuplicates: true + }); + $toast[1] = toastr.info(sampleMsg, sampleTitle, { + preventDuplicates: true + }); + $toast[2] = toastr.info(sampleMsg, sampleTitle); + var $container = toastr.getContainer(); + + ok($container && $container.children().length === 2); + clearContainerChildren(); + }); + + module('order of appearance'); + test('Newest toast on top', 1, function () { + //Arrange + resetContainer(); + toastr.options.newestOnTop = true; + //Act + var $first = toastr.success("First toast"); + var $second = toastr.success("Second toast"); + //Assert + var containerHtml = toastr.getContainer().html(); + ok(containerHtml.indexOf("First toast") > containerHtml.indexOf("Second toast"), 'Newest toast is on top'); + //Teardown + $first.remove(); + $second.remove(); + resetContainer(); + }); + + test('Oldest toast on top', 1, function () { + //Arrange + resetContainer(); + toastr.options.newestOnTop = false; + //Act + var $first = toastr.success("First toast"); + var $second = toastr.success("Second toast"); + //Assert + var containerHtml = toastr.getContainer().html(); + ok(containerHtml.indexOf("First toast") < containerHtml.indexOf("Second toast"), 'Oldest toast is on top'); + //Teardown + $first.remove(); + $second.remove(); + resetContainer(); + }); + + // These must go last + module('positioning'); + test('Container - position top-right', 1, function () { + //Arrange + resetContainer(); + toastr.options.positionClass = positionClasses.topRight; + //Act + var $toast = toastr.success(sampleMsg); + var $container = toastr.getContainer(); + //Assert + ok($container.hasClass(positionClasses.topRight), 'Has position top right'); + //Teardown + $toast.remove(); + resetContainer(); + }); + test('Container - position bottom-right', 1, function () { + //Arrange + resetContainer(); + toastr.options.positionClass = positionClasses.bottomRight; + //Act + var $toast = toastr.success(sampleMsg); + var $container = toastr.getContainer(); + //Assert + ok($container.hasClass(positionClasses.bottomRight), 'Has position bottom right'); + //Teardown + $toast.remove(); + resetContainer(); + }); + test('Container - position bottom-left', 1, function () { + //Arrange + resetContainer(); + //$(selectors.container).remove() + toastr.options.positionClass = positionClasses.bottomLeft; + //Act + var $toast = toastr.success(sampleMsg); + var $container = toastr.getContainer(); + //Assert + ok($container.hasClass(positionClasses.bottomLeft), 'Has position bottom left'); + //Teardown + $toast.remove(); + resetContainer(); + }); + test('Container - position top-left', 1, function () { + //Arrange + resetContainer(); + toastr.options.positionClass = positionClasses.topLeft; + //Act + var $toast = toastr.success(sampleMsg); + var $container = toastr.getContainer(); + //Assert + ok($container.hasClass(positionClasses.topLeft), 'Has position top left'); + //Teardown + $toast.remove(); + resetContainer(); + }); + test('Container - position top-center', 1, function () { + //Arrange + resetContainer(); + toastr.options.positionClass = positionClasses.topCenter; + //Act + var $toast = toastr.success(sampleMsg); + var $container = toastr.getContainer(); + //Assert + ok($container.hasClass(positionClasses.topCenter), 'Has position top center'); + //Teardown + $toast.remove(); + resetContainer(); + }); + test('Container - position bottom-center', 1, function () { + //Arrange + resetContainer(); + toastr.options.positionClass = positionClasses.bottomCenter; + //Act + var $toast = toastr.success(sampleMsg); + var $container = toastr.getContainer(); + //Assert + ok($container.hasClass(positionClasses.bottomCenter), 'Has position bottom center'); + //Teardown + $toast.remove(); + resetContainer(); + }); + + function resetContainer() { + var $container = toastr.getContainer(); + if ($container) { + $container.remove(); + } + $(selectors.container).remove(); + clearContainerChildren(); + } + + function clearContainerChildren() { + toastr.clear(); + } + +})(); diff --git a/node_modules/toastr/package/package/tests/unit/x.js b/node_modules/toastr/package/package/tests/unit/x.js new file mode 100644 index 0000000..b78dd48 --- /dev/null +++ b/node_modules/toastr/package/package/tests/unit/x.js @@ -0,0 +1,3 @@ + test('test test', 1, function () { + ok(1 === 1, '1 equals 1'); + }); diff --git a/node_modules/toastr/package/package/toastr-2.1.2.tgz b/node_modules/toastr/package/package/toastr-2.1.2.tgz new file mode 100644 index 0000000000000000000000000000000000000000..709eb6bf309aeb7c49ea24f622bccac6a6db43db GIT binary patch literal 435047 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
      ') + .attr('id', options.containerId) + .addClass(options.positionClass) + .attr('aria-live', 'polite') + .attr('role', 'alert'); + + $container.appendTo($(options.target)); + return $container; + } + + function getDefaults() { + return { + tapToDismiss: true, + toastClass: 'toast', + containerId: 'toast-container', + debug: false, + + showMethod: 'fadeIn', //fadeIn, slideDown, and show are built into jQuery + showDuration: 300, + showEasing: 'swing', //swing and linear are built into jQuery + onShown: undefined, + hideMethod: 'fadeOut', + hideDuration: 1000, + hideEasing: 'swing', + onHidden: undefined, + + extendedTimeOut: 1000, + iconClasses: { + error: 'toast-error', + info: 'toast-info', + success: 'toast-success', + warning: 'toast-warning' + }, + iconClass: 'toast-info', + positionClass: 'toast-top-right', + timeOut: 5000, // Set timeOut and extendedTimeOut to 0 to make it sticky + titleClass: 'toast-title', + messageClass: 'toast-message', + target: 'body', + closeHtml: '', + newestOnTop: true, + preventDuplicates: false, + progressBar: false + }; + } + + function publish(args) { + if (!listener) { return; } + listener(args); + } + + function notify(map) { + var options = getOptions(); + var iconClass = map.iconClass || options.iconClass; + + if (typeof (map.optionsOverride) !== 'undefined') { + options = $.extend(options, map.optionsOverride); + iconClass = map.optionsOverride.iconClass || iconClass; + } + + if (shouldExit(options, map)) { return; } + + toastId++; + + $container = getContainer(options, true); + + var intervalId = null; + var $toastElement = $('
      '); + var $titleElement = $('
      '); + var $messageElement = $('
      '); + var $progressElement = $('
      '); + var $closeElement = $(options.closeHtml); + var progressBar = { + intervalId: null, + hideEta: null, + maxHideTime: null + }; + var response = { + toastId: toastId, + state: 'visible', + startTime: new Date(), + options: options, + map: map + }; + + personalizeToast(); + + displayToast(); + + handleEvents(); + + publish(response); + + if (options.debug && console) { + console.log(response); + } + + return $toastElement; + + function personalizeToast() { + setIcon(); + setTitle(); + setMessage(); + setCloseButton(); + setProgressBar(); + setSequence(); + } + + function handleEvents() { + $toastElement.hover(stickAround, delayedHideToast); + if (!options.onclick && options.tapToDismiss) { + $toastElement.click(hideToast); + } + + if (options.closeButton && $closeElement) { + $closeElement.click(function (event) { + if (event.stopPropagation) { + event.stopPropagation(); + } else if (event.cancelBubble !== undefined && event.cancelBubble !== true) { + event.cancelBubble = true; + } + hideToast(true); + }); + } + + if (options.onclick) { + $toastElement.click(function () { + options.onclick(); + hideToast(); + }); + } + } + + function displayToast() { + $toastElement.hide(); + + $toastElement[options.showMethod]( + {duration: options.showDuration, easing: options.showEasing, complete: options.onShown} + ); + + if (options.timeOut > 0) { + intervalId = setTimeout(hideToast, options.timeOut); + progressBar.maxHideTime = parseFloat(options.timeOut); + progressBar.hideEta = new Date().getTime() + progressBar.maxHideTime; + if (options.progressBar) { + progressBar.intervalId = setInterval(updateProgress, 10); + } + } + } + + function setIcon() { + if (map.iconClass) { + $toastElement.addClass(options.toastClass).addClass(iconClass); + } + } + + function setSequence() { + if (options.newestOnTop) { + $container.prepend($toastElement); + } else { + $container.append($toastElement); + } + } + + function setTitle() { + if (map.title) { + $titleElement.append(map.title).addClass(options.titleClass); + $toastElement.append($titleElement); + } + } + + function setMessage() { + if (map.message) { + $messageElement.append(map.message).addClass(options.messageClass); + $toastElement.append($messageElement); + } + } + + function setCloseButton() { + if (options.closeButton) { + $closeElement.addClass('toast-close-button').attr('role', 'button'); + $toastElement.prepend($closeElement); + } + } + + function setProgressBar() { + if (options.progressBar) { + $progressElement.addClass('toast-progress'); + $toastElement.prepend($progressElement); + } + } + + function shouldExit(options, map) { + if (options.preventDuplicates) { + if (map.message === previousToast) { + return true; + } else { + previousToast = map.message; + } + } + return false; + } + + function hideToast(override) { + if ($(':focus', $toastElement).length && !override) { + return; + } + clearTimeout(progressBar.intervalId); + return $toastElement[options.hideMethod]({ + duration: options.hideDuration, + easing: options.hideEasing, + complete: function () { + removeToast($toastElement); + if (options.onHidden && response.state !== 'hidden') { + options.onHidden(); + } + response.state = 'hidden'; + response.endTime = new Date(); + publish(response); + } + }); + } + + function delayedHideToast() { + if (options.timeOut > 0 || options.extendedTimeOut > 0) { + intervalId = setTimeout(hideToast, options.extendedTimeOut); + progressBar.maxHideTime = parseFloat(options.extendedTimeOut); + progressBar.hideEta = new Date().getTime() + progressBar.maxHideTime; + } + } + + function stickAround() { + clearTimeout(intervalId); + progressBar.hideEta = 0; + $toastElement.stop(true, true)[options.showMethod]( + {duration: options.showDuration, easing: options.showEasing} + ); + } + + function updateProgress() { + var percentage = ((progressBar.hideEta - (new Date().getTime())) / progressBar.maxHideTime) * 100; + $progressElement.width(percentage + '%'); + } + } + + function getOptions() { + return $.extend({}, getDefaults(), toastr.options); + } + + function removeToast($toastElement) { + if (!$container) { $container = getContainer(); } + if ($toastElement.is(':visible')) { + return; + } + $toastElement.remove(); + $toastElement = null; + if ($container.children().length === 0) { + $container.remove(); + previousToast = undefined; + } + } + + })(); + }); +}(typeof define === 'function' && define.amd ? define : function (deps, factory) { + if (typeof module !== 'undefined' && module.exports) { //Node + module.exports = factory(require('jquery')); + } else { + window['toastr'] = factory(window['jQuery']); + } +})); diff --git a/node_modules/toastr/package/package/toastr.less b/node_modules/toastr/package/package/toastr.less new file mode 100644 index 0000000..c8a8922 --- /dev/null +++ b/node_modules/toastr/package/package/toastr.less @@ -0,0 +1,264 @@ +// Mix-ins +.borderRadius(@radius) { + -moz-border-radius: @radius; + -webkit-border-radius: @radius; + border-radius: @radius; +} + +.boxShadow(@boxShadow) { + -moz-box-shadow: @boxShadow; + -webkit-box-shadow: @boxShadow; + box-shadow: @boxShadow; +} + +.opacity(@opacity) { + @opacityPercent: @opacity * 100; + opacity: @opacity; + -ms-filter: ~"progid:DXImageTransform.Microsoft.Alpha(Opacity=@{opacityPercent})"; + filter: ~"alpha(opacity=@{opacityPercent})"; +} + +.wordWrap(@wordWrap: break-word) { + -ms-word-wrap: @wordWrap; + word-wrap: @wordWrap; +} + +// Variables +@black: #000000; +@grey: #999999; +@light-grey: #CCCCCC; +@white: #FFFFFF; +@near-black: #030303; +@green: #51A351; +@red: #BD362F; +@blue: #2F96B4; +@orange: #F89406; + +// Styles +.toast-title { + font-weight: bold; +} + +.toast-message { + .wordWrap(); + + a, + label { + color: @white; + } + + a:hover { + color: @light-grey; + text-decoration: none; + } +} + +.toast-close-button { + position: relative; + right: -0.3em; + top: -0.3em; + float: right; + font-size: 20px; + font-weight: bold; + color: @white; + -webkit-text-shadow: 0 1px 0 rgba(255,255,255,1); + text-shadow: 0 1px 0 rgba(255,255,255,1); + .opacity(0.8); + + &:hover, + &:focus { + color: @black; + text-decoration: none; + cursor: pointer; + .opacity(0.4); + } +} + +/*Additional properties for button version + iOS requires the button element instead of an anchor tag. + If you want the anchor version, it requires `href="#"`.*/ +button.toast-close-button { + padding: 0; + cursor: pointer; + background: transparent; + border: 0; + -webkit-appearance: none; +} + +//#endregion + +.toast-top-center { + top: 0; + right: 0; + width: 100%; +} + +.toast-bottom-center { + bottom: 0; + right: 0; + width: 100%; +} + +.toast-top-full-width { + top: 0; + right: 0; + width: 100%; +} + +.toast-bottom-full-width { + bottom: 0; + right: 0; + width: 100%; +} + +.toast-top-left { + top: 12px; + left: 12px; +} + +.toast-top-right { + top: 12px; + right: 12px; +} + +.toast-bottom-right { + right: 12px; + bottom: 12px; +} + +.toast-bottom-left { + bottom: 12px; + left: 12px; +} + +#toast-container { + position: fixed; + z-index: 999999; + // The container should not be clickable. + pointer-events: none; + * { + -moz-box-sizing: border-box; + -webkit-box-sizing: border-box; + box-sizing: border-box; + } + + > div { + position: relative; + // The toast itself should be clickable. + pointer-events: auto; + overflow: hidden; + margin: 0 0 6px; + padding: 15px 15px 15px 50px; + width: 300px; + .borderRadius(3px 3px 3px 3px); + background-position: 15px center; + background-repeat: no-repeat; + .boxShadow(0 0 12px @grey); + color: @white; + .opacity(0.8); + } + + > :hover { + .boxShadow(0 0 12px @black); + .opacity(1); + cursor: pointer; + } + + > .toast-info { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGwSURBVEhLtZa9SgNBEMc9sUxxRcoUKSzSWIhXpFMhhYWFhaBg4yPYiWCXZxBLERsLRS3EQkEfwCKdjWJAwSKCgoKCcudv4O5YLrt7EzgXhiU3/4+b2ckmwVjJSpKkQ6wAi4gwhT+z3wRBcEz0yjSseUTrcRyfsHsXmD0AmbHOC9Ii8VImnuXBPglHpQ5wwSVM7sNnTG7Za4JwDdCjxyAiH3nyA2mtaTJufiDZ5dCaqlItILh1NHatfN5skvjx9Z38m69CgzuXmZgVrPIGE763Jx9qKsRozWYw6xOHdER+nn2KkO+Bb+UV5CBN6WC6QtBgbRVozrahAbmm6HtUsgtPC19tFdxXZYBOfkbmFJ1VaHA1VAHjd0pp70oTZzvR+EVrx2Ygfdsq6eu55BHYR8hlcki+n+kERUFG8BrA0BwjeAv2M8WLQBtcy+SD6fNsmnB3AlBLrgTtVW1c2QN4bVWLATaIS60J2Du5y1TiJgjSBvFVZgTmwCU+dAZFoPxGEEs8nyHC9Bwe2GvEJv2WXZb0vjdyFT4Cxk3e/kIqlOGoVLwwPevpYHT+00T+hWwXDf4AJAOUqWcDhbwAAAAASUVORK5CYII=") !important; + } + + > .toast-error { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAHOSURBVEhLrZa/SgNBEMZzh0WKCClSCKaIYOED+AAKeQQLG8HWztLCImBrYadgIdY+gIKNYkBFSwu7CAoqCgkkoGBI/E28PdbLZmeDLgzZzcx83/zZ2SSXC1j9fr+I1Hq93g2yxH4iwM1vkoBWAdxCmpzTxfkN2RcyZNaHFIkSo10+8kgxkXIURV5HGxTmFuc75B2RfQkpxHG8aAgaAFa0tAHqYFfQ7Iwe2yhODk8+J4C7yAoRTWI3w/4klGRgR4lO7Rpn9+gvMyWp+uxFh8+H+ARlgN1nJuJuQAYvNkEnwGFck18Er4q3egEc/oO+mhLdKgRyhdNFiacC0rlOCbhNVz4H9FnAYgDBvU3QIioZlJFLJtsoHYRDfiZoUyIxqCtRpVlANq0EU4dApjrtgezPFad5S19Wgjkc0hNVnuF4HjVA6C7QrSIbylB+oZe3aHgBsqlNqKYH48jXyJKMuAbiyVJ8KzaB3eRc0pg9VwQ4niFryI68qiOi3AbjwdsfnAtk0bCjTLJKr6mrD9g8iq/S/B81hguOMlQTnVyG40wAcjnmgsCNESDrjme7wfftP4P7SP4N3CJZdvzoNyGq2c/HWOXJGsvVg+RA/k2MC/wN6I2YA2Pt8GkAAAAASUVORK5CYII=") !important; + } + + > .toast-success { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAADsSURBVEhLY2AYBfQMgf///3P8+/evAIgvA/FsIF+BavYDDWMBGroaSMMBiE8VC7AZDrIFaMFnii3AZTjUgsUUWUDA8OdAH6iQbQEhw4HyGsPEcKBXBIC4ARhex4G4BsjmweU1soIFaGg/WtoFZRIZdEvIMhxkCCjXIVsATV6gFGACs4Rsw0EGgIIH3QJYJgHSARQZDrWAB+jawzgs+Q2UO49D7jnRSRGoEFRILcdmEMWGI0cm0JJ2QpYA1RDvcmzJEWhABhD/pqrL0S0CWuABKgnRki9lLseS7g2AlqwHWQSKH4oKLrILpRGhEQCw2LiRUIa4lwAAAABJRU5ErkJggg==") !important; + } + + > .toast-warning { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGYSURBVEhL5ZSvTsNQFMbXZGICMYGYmJhAQIJAICYQPAACiSDB8AiICQQJT4CqQEwgJvYASAQCiZiYmJhAIBATCARJy+9rTsldd8sKu1M0+dLb057v6/lbq/2rK0mS/TRNj9cWNAKPYIJII7gIxCcQ51cvqID+GIEX8ASG4B1bK5gIZFeQfoJdEXOfgX4QAQg7kH2A65yQ87lyxb27sggkAzAuFhbbg1K2kgCkB1bVwyIR9m2L7PRPIhDUIXgGtyKw575yz3lTNs6X4JXnjV+LKM/m3MydnTbtOKIjtz6VhCBq4vSm3ncdrD2lk0VgUXSVKjVDJXJzijW1RQdsU7F77He8u68koNZTz8Oz5yGa6J3H3lZ0xYgXBK2QymlWWA+RWnYhskLBv2vmE+hBMCtbA7KX5drWyRT/2JsqZ2IvfB9Y4bWDNMFbJRFmC9E74SoS0CqulwjkC0+5bpcV1CZ8NMej4pjy0U+doDQsGyo1hzVJttIjhQ7GnBtRFN1UarUlH8F3xict+HY07rEzoUGPlWcjRFRr4/gChZgc3ZL2d8oAAAAASUVORK5CYII=") !important; + } + + /*overrides*/ + &.toast-top-center > div, + &.toast-bottom-center > div { + width: 300px; + margin: auto; + } + + &.toast-top-full-width > div, + &.toast-bottom-full-width > div { + width: 96%; + margin: auto; + } +} + +.toast { + background-color: @near-black; +} + +.toast-success { + background-color: @green; +} + +.toast-error { + background-color: @red; +} + +.toast-info { + background-color: @blue; +} + +.toast-warning { + background-color: @orange; +} + +.toast-progress { + position: absolute; + left: 0; + bottom: 0; + height: 4px; + background-color: @black; + .opacity(0.4); +} + +/*Responsive Design*/ + +@media all and (max-width: 240px) { + #toast-container { + + > div { + padding: 8px 8px 8px 50px; + width: 11em; + } + + & .toast-close-button { + right: -0.2em; + top: -0.2em; + } + } +} + +@media all and (min-width: 241px) and (max-width: 480px) { + #toast-container { + > div { + padding: 8px 8px 8px 50px; + width: 18em; + } + + & .toast-close-button { + right: -0.2em; + top: -0.2em; + } + } +} + +@media all and (min-width: 481px) and (max-width: 768px) { + #toast-container { + > div { + padding: 15px 15px 15px 50px; + width: 25em; + } + } +} diff --git a/node_modules/toastr/package/package/toastr.scss b/node_modules/toastr/package/package/toastr.scss new file mode 100644 index 0000000..6380484 --- /dev/null +++ b/node_modules/toastr/package/package/toastr.scss @@ -0,0 +1,199 @@ +.toast-title { + font-weight: bold; +} +.toast-message { + -ms-word-wrap: break-word; + word-wrap: break-word; +} +.toast-message a, +.toast-message label { + color: #ffffff; +} +.toast-message a:hover { + color: #cccccc; + text-decoration: none; +} +.toast-close-button { + position: relative; + right: -0.3em; + top: -0.3em; + float: right; + font-size: 20px; + font-weight: bold; + color: #ffffff; + -webkit-text-shadow: 0 1px 0 #ffffff; + text-shadow: 0 1px 0 #ffffff; + opacity: 0.8; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=80); + filter: alpha(opacity=80); +} +.toast-close-button:hover, +.toast-close-button:focus { + color: #000000; + text-decoration: none; + cursor: pointer; + opacity: 0.4; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=40); + filter: alpha(opacity=40); +} +/*Additional properties for button version + iOS requires the button element instead of an anchor tag. + If you want the anchor version, it requires `href="#"`.*/ +button.toast-close-button { + padding: 0; + cursor: pointer; + background: transparent; + border: 0; + -webkit-appearance: none; +} +.toast-top-center { + top: 0; + right: 0; + width: 100%; +} +.toast-bottom-center { + bottom: 0; + right: 0; + width: 100%; +} +.toast-top-full-width { + top: 0; + right: 0; + width: 100%; +} +.toast-bottom-full-width { + bottom: 0; + right: 0; + width: 100%; +} +.toast-top-left { + top: 12px; + left: 12px; +} +.toast-top-right { + top: 12px; + right: 12px; +} +.toast-bottom-right { + right: 12px; + bottom: 12px; +} +.toast-bottom-left { + bottom: 12px; + left: 12px; +} +#toast-container { + position: fixed; + z-index: 999999; + /*overrides*/ + +} +#toast-container * { + -moz-box-sizing: border-box; + -webkit-box-sizing: border-box; + box-sizing: border-box; +} +#toast-container > div { + position: relative; + overflow: hidden; + margin: 0 0 6px; + padding: 15px 15px 15px 50px; + width: 300px; + -moz-border-radius: 3px 3px 3px 3px; + -webkit-border-radius: 3px 3px 3px 3px; + border-radius: 3px 3px 3px 3px; + background-position: 15px center; + background-repeat: no-repeat; + -moz-box-shadow: 0 0 12px #999999; + -webkit-box-shadow: 0 0 12px #999999; + box-shadow: 0 0 12px #999999; + color: #ffffff; + opacity: 0.8; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=80); + filter: alpha(opacity=80); +} +#toast-container > :hover { + -moz-box-shadow: 0 0 12px #000000; + -webkit-box-shadow: 0 0 12px #000000; + box-shadow: 0 0 12px #000000; + opacity: 1; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=100); + filter: alpha(opacity=100); + cursor: pointer; +} +#toast-container > .toast-info { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGwSURBVEhLtZa9SgNBEMc9sUxxRcoUKSzSWIhXpFMhhYWFhaBg4yPYiWCXZxBLERsLRS3EQkEfwCKdjWJAwSKCgoKCcudv4O5YLrt7EzgXhiU3/4+b2ckmwVjJSpKkQ6wAi4gwhT+z3wRBcEz0yjSseUTrcRyfsHsXmD0AmbHOC9Ii8VImnuXBPglHpQ5wwSVM7sNnTG7Za4JwDdCjxyAiH3nyA2mtaTJufiDZ5dCaqlItILh1NHatfN5skvjx9Z38m69CgzuXmZgVrPIGE763Jx9qKsRozWYw6xOHdER+nn2KkO+Bb+UV5CBN6WC6QtBgbRVozrahAbmm6HtUsgtPC19tFdxXZYBOfkbmFJ1VaHA1VAHjd0pp70oTZzvR+EVrx2Ygfdsq6eu55BHYR8hlcki+n+kERUFG8BrA0BwjeAv2M8WLQBtcy+SD6fNsmnB3AlBLrgTtVW1c2QN4bVWLATaIS60J2Du5y1TiJgjSBvFVZgTmwCU+dAZFoPxGEEs8nyHC9Bwe2GvEJv2WXZb0vjdyFT4Cxk3e/kIqlOGoVLwwPevpYHT+00T+hWwXDf4AJAOUqWcDhbwAAAAASUVORK5CYII=") !important; +} +#toast-container > .toast-error { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAHOSURBVEhLrZa/SgNBEMZzh0WKCClSCKaIYOED+AAKeQQLG8HWztLCImBrYadgIdY+gIKNYkBFSwu7CAoqCgkkoGBI/E28PdbLZmeDLgzZzcx83/zZ2SSXC1j9fr+I1Hq93g2yxH4iwM1vkoBWAdxCmpzTxfkN2RcyZNaHFIkSo10+8kgxkXIURV5HGxTmFuc75B2RfQkpxHG8aAgaAFa0tAHqYFfQ7Iwe2yhODk8+J4C7yAoRTWI3w/4klGRgR4lO7Rpn9+gvMyWp+uxFh8+H+ARlgN1nJuJuQAYvNkEnwGFck18Er4q3egEc/oO+mhLdKgRyhdNFiacC0rlOCbhNVz4H9FnAYgDBvU3QIioZlJFLJtsoHYRDfiZoUyIxqCtRpVlANq0EU4dApjrtgezPFad5S19Wgjkc0hNVnuF4HjVA6C7QrSIbylB+oZe3aHgBsqlNqKYH48jXyJKMuAbiyVJ8KzaB3eRc0pg9VwQ4niFryI68qiOi3AbjwdsfnAtk0bCjTLJKr6mrD9g8iq/S/B81hguOMlQTnVyG40wAcjnmgsCNESDrjme7wfftP4P7SP4N3CJZdvzoNyGq2c/HWOXJGsvVg+RA/k2MC/wN6I2YA2Pt8GkAAAAASUVORK5CYII=") !important; +} +#toast-container > .toast-success { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAADsSURBVEhLY2AYBfQMgf///3P8+/evAIgvA/FsIF+BavYDDWMBGroaSMMBiE8VC7AZDrIFaMFnii3AZTjUgsUUWUDA8OdAH6iQbQEhw4HyGsPEcKBXBIC4ARhex4G4BsjmweU1soIFaGg/WtoFZRIZdEvIMhxkCCjXIVsATV6gFGACs4Rsw0EGgIIH3QJYJgHSARQZDrWAB+jawzgs+Q2UO49D7jnRSRGoEFRILcdmEMWGI0cm0JJ2QpYA1RDvcmzJEWhABhD/pqrL0S0CWuABKgnRki9lLseS7g2AlqwHWQSKH4oKLrILpRGhEQCw2LiRUIa4lwAAAABJRU5ErkJggg==") !important; +} +#toast-container > .toast-warning { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGYSURBVEhL5ZSvTsNQFMbXZGICMYGYmJhAQIJAICYQPAACiSDB8AiICQQJT4CqQEwgJvYASAQCiZiYmJhAIBATCARJy+9rTsldd8sKu1M0+dLb057v6/lbq/2rK0mS/TRNj9cWNAKPYIJII7gIxCcQ51cvqID+GIEX8ASG4B1bK5gIZFeQfoJdEXOfgX4QAQg7kH2A65yQ87lyxb27sggkAzAuFhbbg1K2kgCkB1bVwyIR9m2L7PRPIhDUIXgGtyKw575yz3lTNs6X4JXnjV+LKM/m3MydnTbtOKIjtz6VhCBq4vSm3ncdrD2lk0VgUXSVKjVDJXJzijW1RQdsU7F77He8u68koNZTz8Oz5yGa6J3H3lZ0xYgXBK2QymlWWA+RWnYhskLBv2vmE+hBMCtbA7KX5drWyRT/2JsqZ2IvfB9Y4bWDNMFbJRFmC9E74SoS0CqulwjkC0+5bpcV1CZ8NMej4pjy0U+doDQsGyo1hzVJttIjhQ7GnBtRFN1UarUlH8F3xict+HY07rEzoUGPlWcjRFRr4/gChZgc3ZL2d8oAAAAASUVORK5CYII=") !important; +} +#toast-container.toast-top-center > div, +#toast-container.toast-bottom-center > div { + width: 300px; + margin: auto; +} +#toast-container.toast-top-full-width > div, +#toast-container.toast-bottom-full-width > div { + width: 96%; + margin: auto; +} +.toast { + background-color: #030303; +} +.toast-success { + background-color: #51a351; +} +.toast-error { + background-color: #bd362f; +} +.toast-info { + background-color: #2f96b4; +} +.toast-warning { + background-color: #f89406; +} + +.toast-progress { + position: absolute; + left: 0; + bottom: 0; + height: 4px; + background-color: #000000; + opacity: 0.4; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=40); + filter: alpha(opacity=40); +} + +/*Responsive Design*/ +@media all and (max-width: 240px) { + #toast-container > div { + padding: 8px 8px 8px 50px; + width: 11em; + } + #toast-container .toast-close-button { + right: -0.2em; + top: -0.2em; + } +} +@media all and (min-width: 241px) and (max-width: 480px) { + #toast-container > div { + padding: 8px 8px 8px 50px; + width: 18em; + } + #toast-container .toast-close-button { + right: -0.2em; + top: -0.2em; + } +} +@media all and (min-width: 481px) and (max-width: 768px) { + #toast-container > div { + padding: 15px 15px 15px 50px; + width: 25em; + } +} diff --git a/node_modules/toastr/package/readme.md b/node_modules/toastr/package/readme.md new file mode 100644 index 0000000..45e7014 --- /dev/null +++ b/node_modules/toastr/package/readme.md @@ -0,0 +1,181 @@ +# toastr +**toastr** is a Javascript library for non-blocking notifications. jQuery is required. The goal is to create a simple core library that can be customized and extended. + +[![Build Status](https://travis-ci.org/CodeSeven/toastr.svg)](https://travis-ci.org/CodeSeven/toastr) + +## Current Version +2.1.2 + +## Demo +- Demo can be found at http://codeseven.github.io/toastr/demo.html +- [Demo using FontAwesome icons with toastr](http://plnkr.co/edit/6W9URNyyp2ItO4aUWzBB?p=preview) + +## CDNjs +Toastr is hosted at CDN JS + +#### Debug +- [//cdnjs.cloudflare.com/ajax/libs/toastr.js/latest/js/toastr.js](//cdnjs.cloudflare.com/ajax/libs/toastr.js/latest/js/toastr.js) +- [//cdnjs.cloudflare.com/ajax/libs/toastr.js/latest/css/toastr.css](//cdnjs.cloudflare.com/ajax/libs/toastr.js/latest/css/toastr.css) + +#### Minified +- [//cdnjs.cloudflare.com/ajax/libs/toastr.js/latest/js/toastr.min.js](//cdnjs.cloudflare.com/ajax/libs/toastr.js/latest/js/toastr.min.js) +- [//cdnjs.cloudflare.com/ajax/libs/toastr.js/latest/css/toastr.min.css](//cdnjs.cloudflare.com/ajax/libs/toastr.js/latest/css/toastr.min.css) + +## NuGet Gallery +http://nuget.org/packages/toastr + +## [Bower](http://bower.io/) + bower install toastr + + +## Wiki and Change Log +[Wiki including Change Log](https://github.com/CodeSeven/toastr/wiki) + +## Breaking Changes + +####Animation Changes +The following animations options have been deprecated and should be replaced: + + - Replace `options.fadeIn` with `options.showDuration` + - Replace `options.onFadeIn` with `options.onShown` + - Replace `options.fadeOut` with `options.hideDuration` + - Replace `options.onFadeOut` with `options.onHidden` + +## Quick Start + +###3 Easy Steps +For other API calls, see the [demo](http://codeseven.github.io/toastr/demo.html). + +1. Link to toastr.css `` + +2. Link to toastr.js `` + +3. use toastr to display a toast for info, success, warning or error + + // Display an info toast with no title + toastr.info('Are you the 6 fingered man?') + +### Other Options + // Display a warning toast, with no title + toastr.warning('My name is Inigo Montoya. You killed my father, prepare to die!') + + // Display a success toast, with a title + toastr.success('Have fun storming the castle!', 'Miracle Max Says') + + // Display an error toast, with a title + toastr.error('I do not think that word means what you think it means.', 'Inconceivable!') + + // Immediately remove current toasts without using animation + toastr.remove() + + // Remove current toasts using animation + toastr.clear() + + // Override global options + toastr.success('We do have the Kapua suite available.', 'Turtle Bay Resort', {timeOut: 5000}) + +### Close Button +Optionally enable a close button + + toastr.options.closeButton = true; + +Optionally override the close button's HTML. + + toastr.options.closeHtml = ''; + +You can also override the CSS/LESS for `#toast-container .toast-close-button` + +### Display Sequence +Show newest toast at bottom (top is default) + + toastr.options.newestOnTop = false; + +### Callbacks + // Define a callback for when the toast is shown/hidden + toastr.options.onShown = function() { console.log('hello'); } + toastr.options.onHidden = function() { console.log('goodbye'); } + +### Animation Options +Toastr will supply default animations, so you do not have to provide any of these settings. However you have the option to override the animations if you like. + +####Easings +Optionally override the animation easing to show or hide the toasts. Default is swing. swing and linear are built into jQuery. + + toastr.options.showEasing = 'swing'; + toastr.options.hideEasing = 'linear'; + +Using the jQuery Easing plugin (http://www.gsgd.co.uk/sandbox/jquery/easing/) + + toastr.options.showEasing = 'easeOutBounce'; + toastr.options.hideEasing = 'easeInBack'; + +####Animation Method +Use the jQuery show/hide method of your choice. These default to fadeIn/fadeOut. The methods fadeIn/fadeOut, slideDown/slideUp, and show/hide are built into jQuery. + + toastr.options.showMethod = 'slideDown'; + toastr.options.hideMethod = 'slideUp'; + +###Prevent Duplicates +Rather than having identical toasts stack, set the preventDuplicates property to true. Duplicates are matched to the previous toast based on their message content. + + toastr.options.preventDuplicates = true; + + +###Timeouts +Control how toastr interacts with users by setting timeouts appropriately. Timeouts can be disabled by setting them to 0. + + toastr.options.timeOut = 30; // How long the toast will display without user interaction + toastr.options.extendedTimeOut = 60; // How long the toast will display after a user hovers over it + + +###Progress Bar +Visually indicate how long before a toast expires. + + toastr.options.progressBar = true; + +## Building Toastr + +To build the minified and css versions of Toastr you will need [node](http://nodejs.org) installed. (Use Homebrew or Chocolatey.) + +``` +npm install -g gulp karma-cli +npm install +``` + +At this point the dependencies have been installed and you can build Toastr + +- Run the analytics `gulp analyze` +- Run the test `gulp test` +- Run the build `gulp` + +## Contributing + +For a pull request to be considered it must resolve a bug, or add a feature which is beneficial to a large audience. + +Pull requests must pass existing unit tests, CI processes, and add additional tests to indicate successful operation of a new feature, or the resolution of an identified bug. + +Requests must be made against the `develop` branch. Pull requests submitted against the `master` branch will not be considered. + +All pull requests are subject to approval by the repository owners, who have sole discretion over acceptance or denial. + +## Authors +**John Papa** + ++ [http://twitter.com/John_Papa](http://twitter.com/John_Papa) + +**Tim Ferrell** + ++ [http://twitter.com/ferrell_tim](http://twitter.com/ferrell_tim) + +**Hans Fjällemark** + ++ [http://twitter.com/hfjallemark](http://twitter.com/hfjallemark) + +## Credits +Inspired by https://github.com/Srirangan/notifer.js/. + +## Copyright +Copyright © 2012-2015 + +## License +toastr is under MIT license - http://www.opensource.org/licenses/mit-license.php diff --git a/node_modules/toastr/package/release checklist.md b/node_modules/toastr/package/release checklist.md new file mode 100644 index 0000000..52e5a83 --- /dev/null +++ b/node_modules/toastr/package/release checklist.md @@ -0,0 +1,32 @@ +Toastr Release Checklist + +1. Update Toastr Version + * toastr.js + * bower.json (toastr-bower repo) + * package.json + * nuget versions and dependency versions + * readme file for github repo + * Consider HotTowel VSIX +2. Gulp + * run main demo + * `gulp analyze` + * `gulp test` + * `gulp` +3. Nuget + * Copy new files in + * Build + * Test +4. CDNJS + * Update CDNJS +5. Update Website with New Downloads +6. Publish Bower + * Include License and Readme + * Test Locally + * Update Github repo toastr-bower + * Github tag + * Register with Bower +7. Publish Nugets +8. Release on Github + * Tag with semver + * Attach all artifacts +9. Blog post \ No newline at end of file diff --git a/node_modules/toastr/package/tests/qunit/qunit.css b/node_modules/toastr/package/tests/qunit/qunit.css new file mode 100644 index 0000000..7ba3f9a --- /dev/null +++ b/node_modules/toastr/package/tests/qunit/qunit.css @@ -0,0 +1,244 @@ +/** + * QUnit v1.12.0 - A JavaScript Unit Testing Framework + * + * http://qunitjs.com + * + * Copyright 2012 jQuery Foundation and other contributors + * Released under the MIT license. + * http://jquery.org/license + */ + +/** Font Family and Sizes */ + +#qunit-tests, #qunit-header, #qunit-banner, #qunit-testrunner-toolbar, #qunit-userAgent, #qunit-testresult { + font-family: "Helvetica Neue Light", "HelveticaNeue-Light", "Helvetica Neue", Calibri, Helvetica, Arial, sans-serif; +} + +#qunit-testrunner-toolbar, #qunit-userAgent, #qunit-testresult, #qunit-tests li { font-size: small; } +#qunit-tests { font-size: smaller; } + + +/** Resets */ + +#qunit-tests, #qunit-header, #qunit-banner, #qunit-userAgent, #qunit-testresult, #qunit-modulefilter { + margin: 0; + padding: 0; +} + + +/** Header */ + +#qunit-header { + padding: 0.5em 0 0.5em 1em; + + color: #8699a4; + background-color: #0d3349; + + font-size: 1.5em; + line-height: 1em; + font-weight: normal; + + border-radius: 5px 5px 0 0; + -moz-border-radius: 5px 5px 0 0; + -webkit-border-top-right-radius: 5px; + -webkit-border-top-left-radius: 5px; +} + +#qunit-header a { + text-decoration: none; + color: #c2ccd1; +} + +#qunit-header a:hover, +#qunit-header a:focus { + color: #fff; +} + +#qunit-testrunner-toolbar label { + display: inline-block; + padding: 0 .5em 0 .1em; +} + +#qunit-banner { + height: 5px; +} + +#qunit-testrunner-toolbar { + padding: 0.5em 0 0.5em 2em; + color: #5E740B; + background-color: #eee; + overflow: hidden; +} + +#qunit-userAgent { + padding: 0.5em 0 0.5em 2.5em; + background-color: #2b81af; + color: #fff; + text-shadow: rgba(0, 0, 0, 0.5) 2px 2px 1px; +} + +#qunit-modulefilter-container { + float: right; +} + +/** Tests: Pass/Fail */ + +#qunit-tests { + list-style-position: inside; +} + +#qunit-tests li { + padding: 0.4em 0.5em 0.4em 2.5em; + border-bottom: 1px solid #fff; + list-style-position: inside; +} + +#qunit-tests.hidepass li.pass, #qunit-tests.hidepass li.running { + display: none; +} + +#qunit-tests li strong { + cursor: pointer; +} + +#qunit-tests li a { + padding: 0.5em; + color: #c2ccd1; + text-decoration: none; +} +#qunit-tests li a:hover, +#qunit-tests li a:focus { + color: #000; +} + +#qunit-tests li .runtime { + float: right; + font-size: smaller; +} + +.qunit-assert-list { + margin-top: 0.5em; + padding: 0.5em; + + background-color: #fff; + + border-radius: 5px; + -moz-border-radius: 5px; + -webkit-border-radius: 5px; +} + +.qunit-collapsed { + display: none; +} + +#qunit-tests table { + border-collapse: collapse; + margin-top: .2em; +} + +#qunit-tests th { + text-align: right; + vertical-align: top; + padding: 0 .5em 0 0; +} + +#qunit-tests td { + vertical-align: top; +} + +#qunit-tests pre { + margin: 0; + white-space: pre-wrap; + word-wrap: break-word; +} + +#qunit-tests del { + background-color: #e0f2be; + color: #374e0c; + text-decoration: none; +} + +#qunit-tests ins { + background-color: #ffcaca; + color: #500; + text-decoration: none; +} + +/*** Test Counts */ + +#qunit-tests b.counts { color: black; } +#qunit-tests b.passed { color: #5E740B; } +#qunit-tests b.failed { color: #710909; } + +#qunit-tests li li { + padding: 5px; + background-color: #fff; + border-bottom: none; + list-style-position: inside; +} + +/*** Passing Styles */ + +#qunit-tests li li.pass { + color: #3c510c; + background-color: #fff; + border-left: 10px solid #C6E746; +} + +#qunit-tests .pass { color: #528CE0; background-color: #D2E0E6; } +#qunit-tests .pass .test-name { color: #366097; } + +#qunit-tests .pass .test-actual, +#qunit-tests .pass .test-expected { color: #999999; } + +#qunit-banner.qunit-pass { background-color: #C6E746; } + +/*** Failing Styles */ + +#qunit-tests li li.fail { + color: #710909; + background-color: #fff; + border-left: 10px solid #EE5757; + white-space: pre; +} + +#qunit-tests > li:last-child { + border-radius: 0 0 5px 5px; + -moz-border-radius: 0 0 5px 5px; + -webkit-border-bottom-right-radius: 5px; + -webkit-border-bottom-left-radius: 5px; +} + +#qunit-tests .fail { color: #000000; background-color: #EE5757; } +#qunit-tests .fail .test-name, +#qunit-tests .fail .module-name { color: #000000; } + +#qunit-tests .fail .test-actual { color: #EE5757; } +#qunit-tests .fail .test-expected { color: green; } + +#qunit-banner.qunit-fail { background-color: #EE5757; } + + +/** Result */ + +#qunit-testresult { + padding: 0.5em 0.5em 0.5em 2.5em; + + color: #2b81af; + background-color: #D2E0E6; + + border-bottom: 1px solid white; +} +#qunit-testresult .module-name { + font-weight: bold; +} + +/** Fixture */ + +#qunit-fixture { + position: absolute; + top: -10000px; + left: -10000px; + width: 1000px; + height: 1000px; +} diff --git a/node_modules/toastr/package/tests/qunit/qunit.js b/node_modules/toastr/package/tests/qunit/qunit.js new file mode 100644 index 0000000..84c7390 --- /dev/null +++ b/node_modules/toastr/package/tests/qunit/qunit.js @@ -0,0 +1,2212 @@ +/** + * QUnit v1.12.0 - A JavaScript Unit Testing Framework + * + * http://qunitjs.com + * + * Copyright 2013 jQuery Foundation and other contributors + * Released under the MIT license. + * https://jquery.org/license/ + */ + +(function( window ) { + +var QUnit, + assert, + config, + onErrorFnPrev, + testId = 0, + fileName = (sourceFromStacktrace( 0 ) || "" ).replace(/(:\d+)+\)?/, "").replace(/.+\//, ""), + toString = Object.prototype.toString, + hasOwn = Object.prototype.hasOwnProperty, + // Keep a local reference to Date (GH-283) + Date = window.Date, + setTimeout = window.setTimeout, + defined = { + setTimeout: typeof window.setTimeout !== "undefined", + sessionStorage: (function() { + var x = "qunit-test-string"; + try { + sessionStorage.setItem( x, x ); + sessionStorage.removeItem( x ); + return true; + } catch( e ) { + return false; + } + }()) + }, + /** + * Provides a normalized error string, correcting an issue + * with IE 7 (and prior) where Error.prototype.toString is + * not properly implemented + * + * Based on http://es5.github.com/#x15.11.4.4 + * + * @param {String|Error} error + * @return {String} error message + */ + errorString = function( error ) { + var name, message, + errorString = error.toString(); + if ( errorString.substring( 0, 7 ) === "[object" ) { + name = error.name ? error.name.toString() : "Error"; + message = error.message ? error.message.toString() : ""; + if ( name && message ) { + return name + ": " + message; + } else if ( name ) { + return name; + } else if ( message ) { + return message; + } else { + return "Error"; + } + } else { + return errorString; + } + }, + /** + * Makes a clone of an object using only Array or Object as base, + * and copies over the own enumerable properties. + * + * @param {Object} obj + * @return {Object} New object with only the own properties (recursively). + */ + objectValues = function( obj ) { + // Grunt 0.3.x uses an older version of jshint that still has jshint/jshint#392. + /*jshint newcap: false */ + var key, val, + vals = QUnit.is( "array", obj ) ? [] : {}; + for ( key in obj ) { + if ( hasOwn.call( obj, key ) ) { + val = obj[key]; + vals[key] = val === Object(val) ? objectValues(val) : val; + } + } + return vals; + }; + +function Test( settings ) { + extend( this, settings ); + this.assertions = []; + this.testNumber = ++Test.count; +} + +Test.count = 0; + +Test.prototype = { + init: function() { + var a, b, li, + tests = id( "qunit-tests" ); + + if ( tests ) { + b = document.createElement( "strong" ); + b.innerHTML = this.nameHtml; + + // `a` initialized at top of scope + a = document.createElement( "a" ); + a.innerHTML = "Rerun"; + a.href = QUnit.url({ testNumber: this.testNumber }); + + li = document.createElement( "li" ); + li.appendChild( b ); + li.appendChild( a ); + li.className = "running"; + li.id = this.id = "qunit-test-output" + testId++; + + tests.appendChild( li ); + } + }, + setup: function() { + if ( + // Emit moduleStart when we're switching from one module to another + this.module !== config.previousModule || + // They could be equal (both undefined) but if the previousModule property doesn't + // yet exist it means this is the first test in a suite that isn't wrapped in a + // module, in which case we'll just emit a moduleStart event for 'undefined'. + // Without this, reporters can get testStart before moduleStart which is a problem. + !hasOwn.call( config, "previousModule" ) + ) { + if ( hasOwn.call( config, "previousModule" ) ) { + runLoggingCallbacks( "moduleDone", QUnit, { + name: config.previousModule, + failed: config.moduleStats.bad, + passed: config.moduleStats.all - config.moduleStats.bad, + total: config.moduleStats.all + }); + } + config.previousModule = this.module; + config.moduleStats = { all: 0, bad: 0 }; + runLoggingCallbacks( "moduleStart", QUnit, { + name: this.module + }); + } + + config.current = this; + + this.testEnvironment = extend({ + setup: function() {}, + teardown: function() {} + }, this.moduleTestEnvironment ); + + this.started = +new Date(); + runLoggingCallbacks( "testStart", QUnit, { + name: this.testName, + module: this.module + }); + + /*jshint camelcase:false */ + + + /** + * Expose the current test environment. + * + * @deprecated since 1.12.0: Use QUnit.config.current.testEnvironment instead. + */ + QUnit.current_testEnvironment = this.testEnvironment; + + /*jshint camelcase:true */ + + if ( !config.pollution ) { + saveGlobal(); + } + if ( config.notrycatch ) { + this.testEnvironment.setup.call( this.testEnvironment, QUnit.assert ); + return; + } + try { + this.testEnvironment.setup.call( this.testEnvironment, QUnit.assert ); + } catch( e ) { + QUnit.pushFailure( "Setup failed on " + this.testName + ": " + ( e.message || e ), extractStacktrace( e, 1 ) ); + } + }, + run: function() { + config.current = this; + + var running = id( "qunit-testresult" ); + + if ( running ) { + running.innerHTML = "Running:
      " + this.nameHtml; + } + + if ( this.async ) { + QUnit.stop(); + } + + this.callbackStarted = +new Date(); + + if ( config.notrycatch ) { + this.callback.call( this.testEnvironment, QUnit.assert ); + this.callbackRuntime = +new Date() - this.callbackStarted; + return; + } + + try { + this.callback.call( this.testEnvironment, QUnit.assert ); + this.callbackRuntime = +new Date() - this.callbackStarted; + } catch( e ) { + this.callbackRuntime = +new Date() - this.callbackStarted; + + QUnit.pushFailure( "Died on test #" + (this.assertions.length + 1) + " " + this.stack + ": " + ( e.message || e ), extractStacktrace( e, 0 ) ); + // else next test will carry the responsibility + saveGlobal(); + + // Restart the tests if they're blocking + if ( config.blocking ) { + QUnit.start(); + } + } + }, + teardown: function() { + config.current = this; + if ( config.notrycatch ) { + if ( typeof this.callbackRuntime === "undefined" ) { + this.callbackRuntime = +new Date() - this.callbackStarted; + } + this.testEnvironment.teardown.call( this.testEnvironment, QUnit.assert ); + return; + } else { + try { + this.testEnvironment.teardown.call( this.testEnvironment, QUnit.assert ); + } catch( e ) { + QUnit.pushFailure( "Teardown failed on " + this.testName + ": " + ( e.message || e ), extractStacktrace( e, 1 ) ); + } + } + checkPollution(); + }, + finish: function() { + config.current = this; + if ( config.requireExpects && this.expected === null ) { + QUnit.pushFailure( "Expected number of assertions to be defined, but expect() was not called.", this.stack ); + } else if ( this.expected !== null && this.expected !== this.assertions.length ) { + QUnit.pushFailure( "Expected " + this.expected + " assertions, but " + this.assertions.length + " were run", this.stack ); + } else if ( this.expected === null && !this.assertions.length ) { + QUnit.pushFailure( "Expected at least one assertion, but none were run - call expect(0) to accept zero assertions.", this.stack ); + } + + var i, assertion, a, b, time, li, ol, + test = this, + good = 0, + bad = 0, + tests = id( "qunit-tests" ); + + this.runtime = +new Date() - this.started; + config.stats.all += this.assertions.length; + config.moduleStats.all += this.assertions.length; + + if ( tests ) { + ol = document.createElement( "ol" ); + ol.className = "qunit-assert-list"; + + for ( i = 0; i < this.assertions.length; i++ ) { + assertion = this.assertions[i]; + + li = document.createElement( "li" ); + li.className = assertion.result ? "pass" : "fail"; + li.innerHTML = assertion.message || ( assertion.result ? "okay" : "failed" ); + ol.appendChild( li ); + + if ( assertion.result ) { + good++; + } else { + bad++; + config.stats.bad++; + config.moduleStats.bad++; + } + } + + // store result when possible + if ( QUnit.config.reorder && defined.sessionStorage ) { + if ( bad ) { + sessionStorage.setItem( "qunit-test-" + this.module + "-" + this.testName, bad ); + } else { + sessionStorage.removeItem( "qunit-test-" + this.module + "-" + this.testName ); + } + } + + if ( bad === 0 ) { + addClass( ol, "qunit-collapsed" ); + } + + // `b` initialized at top of scope + b = document.createElement( "strong" ); + b.innerHTML = this.nameHtml + " (" + bad + ", " + good + ", " + this.assertions.length + ")"; + + addEvent(b, "click", function() { + var next = b.parentNode.lastChild, + collapsed = hasClass( next, "qunit-collapsed" ); + ( collapsed ? removeClass : addClass )( next, "qunit-collapsed" ); + }); + + addEvent(b, "dblclick", function( e ) { + var target = e && e.target ? e.target : window.event.srcElement; + if ( target.nodeName.toLowerCase() === "span" || target.nodeName.toLowerCase() === "b" ) { + target = target.parentNode; + } + if ( window.location && target.nodeName.toLowerCase() === "strong" ) { + window.location = QUnit.url({ testNumber: test.testNumber }); + } + }); + + // `time` initialized at top of scope + time = document.createElement( "span" ); + time.className = "runtime"; + time.innerHTML = this.runtime + " ms"; + + // `li` initialized at top of scope + li = id( this.id ); + li.className = bad ? "fail" : "pass"; + li.removeChild( li.firstChild ); + a = li.firstChild; + li.appendChild( b ); + li.appendChild( a ); + li.appendChild( time ); + li.appendChild( ol ); + + } else { + for ( i = 0; i < this.assertions.length; i++ ) { + if ( !this.assertions[i].result ) { + bad++; + config.stats.bad++; + config.moduleStats.bad++; + } + } + } + + runLoggingCallbacks( "testDone", QUnit, { + name: this.testName, + module: this.module, + failed: bad, + passed: this.assertions.length - bad, + total: this.assertions.length, + duration: this.runtime + }); + + QUnit.reset(); + + config.current = undefined; + }, + + queue: function() { + var bad, + test = this; + + synchronize(function() { + test.init(); + }); + function run() { + // each of these can by async + synchronize(function() { + test.setup(); + }); + synchronize(function() { + test.run(); + }); + synchronize(function() { + test.teardown(); + }); + synchronize(function() { + test.finish(); + }); + } + + // `bad` initialized at top of scope + // defer when previous test run passed, if storage is available + bad = QUnit.config.reorder && defined.sessionStorage && + +sessionStorage.getItem( "qunit-test-" + this.module + "-" + this.testName ); + + if ( bad ) { + run(); + } else { + synchronize( run, true ); + } + } +}; + +// Root QUnit object. +// `QUnit` initialized at top of scope +QUnit = { + + // call on start of module test to prepend name to all tests + module: function( name, testEnvironment ) { + config.currentModule = name; + config.currentModuleTestEnvironment = testEnvironment; + config.modules[name] = true; + }, + + asyncTest: function( testName, expected, callback ) { + if ( arguments.length === 2 ) { + callback = expected; + expected = null; + } + + QUnit.test( testName, expected, callback, true ); + }, + + test: function( testName, expected, callback, async ) { + var test, + nameHtml = "" + escapeText( testName ) + ""; + + if ( arguments.length === 2 ) { + callback = expected; + expected = null; + } + + if ( config.currentModule ) { + nameHtml = "" + escapeText( config.currentModule ) + ": " + nameHtml; + } + + test = new Test({ + nameHtml: nameHtml, + testName: testName, + expected: expected, + async: async, + callback: callback, + module: config.currentModule, + moduleTestEnvironment: config.currentModuleTestEnvironment, + stack: sourceFromStacktrace( 2 ) + }); + + if ( !validTest( test ) ) { + return; + } + + test.queue(); + }, + + // Specify the number of expected assertions to guarantee that failed test (no assertions are run at all) don't slip through. + expect: function( asserts ) { + if (arguments.length === 1) { + config.current.expected = asserts; + } else { + return config.current.expected; + } + }, + + start: function( count ) { + // QUnit hasn't been initialized yet. + // Note: RequireJS (et al) may delay onLoad + if ( config.semaphore === undefined ) { + QUnit.begin(function() { + // This is triggered at the top of QUnit.load, push start() to the event loop, to allow QUnit.load to finish first + setTimeout(function() { + QUnit.start( count ); + }); + }); + return; + } + + config.semaphore -= count || 1; + // don't start until equal number of stop-calls + if ( config.semaphore > 0 ) { + return; + } + // ignore if start is called more often then stop + if ( config.semaphore < 0 ) { + config.semaphore = 0; + QUnit.pushFailure( "Called start() while already started (QUnit.config.semaphore was 0 already)", null, sourceFromStacktrace(2) ); + return; + } + // A slight delay, to avoid any current callbacks + if ( defined.setTimeout ) { + setTimeout(function() { + if ( config.semaphore > 0 ) { + return; + } + if ( config.timeout ) { + clearTimeout( config.timeout ); + } + + config.blocking = false; + process( true ); + }, 13); + } else { + config.blocking = false; + process( true ); + } + }, + + stop: function( count ) { + config.semaphore += count || 1; + config.blocking = true; + + if ( config.testTimeout && defined.setTimeout ) { + clearTimeout( config.timeout ); + config.timeout = setTimeout(function() { + QUnit.ok( false, "Test timed out" ); + config.semaphore = 1; + QUnit.start(); + }, config.testTimeout ); + } + } +}; + +// `assert` initialized at top of scope +// Assert helpers +// All of these must either call QUnit.push() or manually do: +// - runLoggingCallbacks( "log", .. ); +// - config.current.assertions.push({ .. }); +// We attach it to the QUnit object *after* we expose the public API, +// otherwise `assert` will become a global variable in browsers (#341). +assert = { + /** + * Asserts rough true-ish result. + * @name ok + * @function + * @example ok( "asdfasdf".length > 5, "There must be at least 5 chars" ); + */ + ok: function( result, msg ) { + if ( !config.current ) { + throw new Error( "ok() assertion outside test context, was " + sourceFromStacktrace(2) ); + } + result = !!result; + msg = msg || (result ? "okay" : "failed" ); + + var source, + details = { + module: config.current.module, + name: config.current.testName, + result: result, + message: msg + }; + + msg = "" + escapeText( msg ) + ""; + + if ( !result ) { + source = sourceFromStacktrace( 2 ); + if ( source ) { + details.source = source; + msg += "
      Source:
      " + escapeText( source ) + "
      "; + } + } + runLoggingCallbacks( "log", QUnit, details ); + config.current.assertions.push({ + result: result, + message: msg + }); + }, + + /** + * Assert that the first two arguments are equal, with an optional message. + * Prints out both actual and expected values. + * @name equal + * @function + * @example equal( format( "Received {0} bytes.", 2), "Received 2 bytes.", "format() replaces {0} with next argument" ); + */ + equal: function( actual, expected, message ) { + /*jshint eqeqeq:false */ + QUnit.push( expected == actual, actual, expected, message ); + }, + + /** + * @name notEqual + * @function + */ + notEqual: function( actual, expected, message ) { + /*jshint eqeqeq:false */ + QUnit.push( expected != actual, actual, expected, message ); + }, + + /** + * @name propEqual + * @function + */ + propEqual: function( actual, expected, message ) { + actual = objectValues(actual); + expected = objectValues(expected); + QUnit.push( QUnit.equiv(actual, expected), actual, expected, message ); + }, + + /** + * @name notPropEqual + * @function + */ + notPropEqual: function( actual, expected, message ) { + actual = objectValues(actual); + expected = objectValues(expected); + QUnit.push( !QUnit.equiv(actual, expected), actual, expected, message ); + }, + + /** + * @name deepEqual + * @function + */ + deepEqual: function( actual, expected, message ) { + QUnit.push( QUnit.equiv(actual, expected), actual, expected, message ); + }, + + /** + * @name notDeepEqual + * @function + */ + notDeepEqual: function( actual, expected, message ) { + QUnit.push( !QUnit.equiv(actual, expected), actual, expected, message ); + }, + + /** + * @name strictEqual + * @function + */ + strictEqual: function( actual, expected, message ) { + QUnit.push( expected === actual, actual, expected, message ); + }, + + /** + * @name notStrictEqual + * @function + */ + notStrictEqual: function( actual, expected, message ) { + QUnit.push( expected !== actual, actual, expected, message ); + }, + + "throws": function( block, expected, message ) { + var actual, + expectedOutput = expected, + ok = false; + + // 'expected' is optional + if ( typeof expected === "string" ) { + message = expected; + expected = null; + } + + config.current.ignoreGlobalErrors = true; + try { + block.call( config.current.testEnvironment ); + } catch (e) { + actual = e; + } + config.current.ignoreGlobalErrors = false; + + if ( actual ) { + // we don't want to validate thrown error + if ( !expected ) { + ok = true; + expectedOutput = null; + // expected is a regexp + } else if ( QUnit.objectType( expected ) === "regexp" ) { + ok = expected.test( errorString( actual ) ); + // expected is a constructor + } else if ( actual instanceof expected ) { + ok = true; + // expected is a validation function which returns true is validation passed + } else if ( expected.call( {}, actual ) === true ) { + expectedOutput = null; + ok = true; + } + + QUnit.push( ok, actual, expectedOutput, message ); + } else { + QUnit.pushFailure( message, null, "No exception was thrown." ); + } + } +}; + +/** + * @deprecated since 1.8.0 + * Kept assertion helpers in root for backwards compatibility. + */ +extend( QUnit, assert ); + +/** + * @deprecated since 1.9.0 + * Kept root "raises()" for backwards compatibility. + * (Note that we don't introduce assert.raises). + */ +QUnit.raises = assert[ "throws" ]; + +/** + * @deprecated since 1.0.0, replaced with error pushes since 1.3.0 + * Kept to avoid TypeErrors for undefined methods. + */ +QUnit.equals = function() { + QUnit.push( false, false, false, "QUnit.equals has been deprecated since 2009 (e88049a0), use QUnit.equal instead" ); +}; +QUnit.same = function() { + QUnit.push( false, false, false, "QUnit.same has been deprecated since 2009 (e88049a0), use QUnit.deepEqual instead" ); +}; + +// We want access to the constructor's prototype +(function() { + function F() {} + F.prototype = QUnit; + QUnit = new F(); + // Make F QUnit's constructor so that we can add to the prototype later + QUnit.constructor = F; +}()); + +/** + * Config object: Maintain internal state + * Later exposed as QUnit.config + * `config` initialized at top of scope + */ +config = { + // The queue of tests to run + queue: [], + + // block until document ready + blocking: true, + + // when enabled, show only failing tests + // gets persisted through sessionStorage and can be changed in UI via checkbox + hidepassed: false, + + // by default, run previously failed tests first + // very useful in combination with "Hide passed tests" checked + reorder: true, + + // by default, modify document.title when suite is done + altertitle: true, + + // when enabled, all tests must call expect() + requireExpects: false, + + // add checkboxes that are persisted in the query-string + // when enabled, the id is set to `true` as a `QUnit.config` property + urlConfig: [ + { + id: "noglobals", + label: "Check for Globals", + tooltip: "Enabling this will test if any test introduces new properties on the `window` object. Stored as query-strings." + }, + { + id: "notrycatch", + label: "No try-catch", + tooltip: "Enabling this will run tests outside of a try-catch block. Makes debugging exceptions in IE reasonable. Stored as query-strings." + } + ], + + // Set of all modules. + modules: {}, + + // logging callback queues + begin: [], + done: [], + log: [], + testStart: [], + testDone: [], + moduleStart: [], + moduleDone: [] +}; + +// Export global variables, unless an 'exports' object exists, +// in that case we assume we're in CommonJS (dealt with on the bottom of the script) +if ( typeof exports === "undefined" ) { + extend( window, QUnit.constructor.prototype ); + + // Expose QUnit object + window.QUnit = QUnit; +} + +// Initialize more QUnit.config and QUnit.urlParams +(function() { + var i, + location = window.location || { search: "", protocol: "file:" }, + params = location.search.slice( 1 ).split( "&" ), + length = params.length, + urlParams = {}, + current; + + if ( params[ 0 ] ) { + for ( i = 0; i < length; i++ ) { + current = params[ i ].split( "=" ); + current[ 0 ] = decodeURIComponent( current[ 0 ] ); + // allow just a key to turn on a flag, e.g., test.html?noglobals + current[ 1 ] = current[ 1 ] ? decodeURIComponent( current[ 1 ] ) : true; + urlParams[ current[ 0 ] ] = current[ 1 ]; + } + } + + QUnit.urlParams = urlParams; + + // String search anywhere in moduleName+testName + config.filter = urlParams.filter; + + // Exact match of the module name + config.module = urlParams.module; + + config.testNumber = parseInt( urlParams.testNumber, 10 ) || null; + + // Figure out if we're running the tests from a server or not + QUnit.isLocal = location.protocol === "file:"; +}()); + +// Extend QUnit object, +// these after set here because they should not be exposed as global functions +extend( QUnit, { + assert: assert, + + config: config, + + // Initialize the configuration options + init: function() { + extend( config, { + stats: { all: 0, bad: 0 }, + moduleStats: { all: 0, bad: 0 }, + started: +new Date(), + updateRate: 1000, + blocking: false, + autostart: true, + autorun: false, + filter: "", + queue: [], + semaphore: 1 + }); + + var tests, banner, result, + qunit = id( "qunit" ); + + if ( qunit ) { + qunit.innerHTML = + "

      " + escapeText( document.title ) + "

      " + + "

      " + + "
      " + + "

      " + + "
        "; + } + + tests = id( "qunit-tests" ); + banner = id( "qunit-banner" ); + result = id( "qunit-testresult" ); + + if ( tests ) { + tests.innerHTML = ""; + } + + if ( banner ) { + banner.className = ""; + } + + if ( result ) { + result.parentNode.removeChild( result ); + } + + if ( tests ) { + result = document.createElement( "p" ); + result.id = "qunit-testresult"; + result.className = "result"; + tests.parentNode.insertBefore( result, tests ); + result.innerHTML = "Running...
         "; + } + }, + + // Resets the test setup. Useful for tests that modify the DOM. + /* + DEPRECATED: Use multiple tests instead of resetting inside a test. + Use testStart or testDone for custom cleanup. + This method will throw an error in 2.0, and will be removed in 2.1 + */ + reset: function() { + var fixture = id( "qunit-fixture" ); + if ( fixture ) { + fixture.innerHTML = config.fixture; + } + }, + + // Trigger an event on an element. + // @example triggerEvent( document.body, "click" ); + triggerEvent: function( elem, type, event ) { + if ( document.createEvent ) { + event = document.createEvent( "MouseEvents" ); + event.initMouseEvent(type, true, true, elem.ownerDocument.defaultView, + 0, 0, 0, 0, 0, false, false, false, false, 0, null); + + elem.dispatchEvent( event ); + } else if ( elem.fireEvent ) { + elem.fireEvent( "on" + type ); + } + }, + + // Safe object type checking + is: function( type, obj ) { + return QUnit.objectType( obj ) === type; + }, + + objectType: function( obj ) { + if ( typeof obj === "undefined" ) { + return "undefined"; + // consider: typeof null === object + } + if ( obj === null ) { + return "null"; + } + + var match = toString.call( obj ).match(/^\[object\s(.*)\]$/), + type = match && match[1] || ""; + + switch ( type ) { + case "Number": + if ( isNaN(obj) ) { + return "nan"; + } + return "number"; + case "String": + case "Boolean": + case "Array": + case "Date": + case "RegExp": + case "Function": + return type.toLowerCase(); + } + if ( typeof obj === "object" ) { + return "object"; + } + return undefined; + }, + + push: function( result, actual, expected, message ) { + if ( !config.current ) { + throw new Error( "assertion outside test context, was " + sourceFromStacktrace() ); + } + + var output, source, + details = { + module: config.current.module, + name: config.current.testName, + result: result, + message: message, + actual: actual, + expected: expected + }; + + message = escapeText( message ) || ( result ? "okay" : "failed" ); + message = "" + message + ""; + output = message; + + if ( !result ) { + expected = escapeText( QUnit.jsDump.parse(expected) ); + actual = escapeText( QUnit.jsDump.parse(actual) ); + output += ""; + + if ( actual !== expected ) { + output += ""; + output += ""; + } + + source = sourceFromStacktrace(); + + if ( source ) { + details.source = source; + output += ""; + } + + output += "
        Expected:
        " + expected + "
        Result:
        " + actual + "
        Diff:
        " + QUnit.diff( expected, actual ) + "
        Source:
        " + escapeText( source ) + "
        "; + } + + runLoggingCallbacks( "log", QUnit, details ); + + config.current.assertions.push({ + result: !!result, + message: output + }); + }, + + pushFailure: function( message, source, actual ) { + if ( !config.current ) { + throw new Error( "pushFailure() assertion outside test context, was " + sourceFromStacktrace(2) ); + } + + var output, + details = { + module: config.current.module, + name: config.current.testName, + result: false, + message: message + }; + + message = escapeText( message ) || "error"; + message = "" + message + ""; + output = message; + + output += ""; + + if ( actual ) { + output += ""; + } + + if ( source ) { + details.source = source; + output += ""; + } + + output += "
        Result:
        " + escapeText( actual ) + "
        Source:
        " + escapeText( source ) + "
        "; + + runLoggingCallbacks( "log", QUnit, details ); + + config.current.assertions.push({ + result: false, + message: output + }); + }, + + url: function( params ) { + params = extend( extend( {}, QUnit.urlParams ), params ); + var key, + querystring = "?"; + + for ( key in params ) { + if ( hasOwn.call( params, key ) ) { + querystring += encodeURIComponent( key ) + "=" + + encodeURIComponent( params[ key ] ) + "&"; + } + } + return window.location.protocol + "//" + window.location.host + + window.location.pathname + querystring.slice( 0, -1 ); + }, + + extend: extend, + id: id, + addEvent: addEvent, + addClass: addClass, + hasClass: hasClass, + removeClass: removeClass + // load, equiv, jsDump, diff: Attached later +}); + +/** + * @deprecated: Created for backwards compatibility with test runner that set the hook function + * into QUnit.{hook}, instead of invoking it and passing the hook function. + * QUnit.constructor is set to the empty F() above so that we can add to it's prototype here. + * Doing this allows us to tell if the following methods have been overwritten on the actual + * QUnit object. + */ +extend( QUnit.constructor.prototype, { + + // Logging callbacks; all receive a single argument with the listed properties + // run test/logs.html for any related changes + begin: registerLoggingCallback( "begin" ), + + // done: { failed, passed, total, runtime } + done: registerLoggingCallback( "done" ), + + // log: { result, actual, expected, message } + log: registerLoggingCallback( "log" ), + + // testStart: { name } + testStart: registerLoggingCallback( "testStart" ), + + // testDone: { name, failed, passed, total, duration } + testDone: registerLoggingCallback( "testDone" ), + + // moduleStart: { name } + moduleStart: registerLoggingCallback( "moduleStart" ), + + // moduleDone: { name, failed, passed, total } + moduleDone: registerLoggingCallback( "moduleDone" ) +}); + +if ( typeof document === "undefined" || document.readyState === "complete" ) { + config.autorun = true; +} + +QUnit.load = function() { + runLoggingCallbacks( "begin", QUnit, {} ); + + // Initialize the config, saving the execution queue + var banner, filter, i, label, len, main, ol, toolbar, userAgent, val, + urlConfigCheckboxesContainer, urlConfigCheckboxes, moduleFilter, + numModules = 0, + moduleNames = [], + moduleFilterHtml = "", + urlConfigHtml = "", + oldconfig = extend( {}, config ); + + QUnit.init(); + extend(config, oldconfig); + + config.blocking = false; + + len = config.urlConfig.length; + + for ( i = 0; i < len; i++ ) { + val = config.urlConfig[i]; + if ( typeof val === "string" ) { + val = { + id: val, + label: val, + tooltip: "[no tooltip available]" + }; + } + config[ val.id ] = QUnit.urlParams[ val.id ]; + urlConfigHtml += ""; + } + for ( i in config.modules ) { + if ( config.modules.hasOwnProperty( i ) ) { + moduleNames.push(i); + } + } + numModules = moduleNames.length; + moduleNames.sort( function( a, b ) { + return a.localeCompare( b ); + }); + moduleFilterHtml += ""; + + // `userAgent` initialized at top of scope + userAgent = id( "qunit-userAgent" ); + if ( userAgent ) { + userAgent.innerHTML = navigator.userAgent; + } + + // `banner` initialized at top of scope + banner = id( "qunit-header" ); + if ( banner ) { + banner.innerHTML = "
        " + banner.innerHTML + " "; + } + + // `toolbar` initialized at top of scope + toolbar = id( "qunit-testrunner-toolbar" ); + if ( toolbar ) { + // `filter` initialized at top of scope + filter = document.createElement( "input" ); + filter.type = "checkbox"; + filter.id = "qunit-filter-pass"; + + addEvent( filter, "click", function() { + var tmp, + ol = document.getElementById( "qunit-tests" ); + + if ( filter.checked ) { + ol.className = ol.className + " hidepass"; + } else { + tmp = " " + ol.className.replace( /[\n\t\r]/g, " " ) + " "; + ol.className = tmp.replace( / hidepass /, " " ); + } + if ( defined.sessionStorage ) { + if (filter.checked) { + sessionStorage.setItem( "qunit-filter-passed-tests", "true" ); + } else { + sessionStorage.removeItem( "qunit-filter-passed-tests" ); + } + } + }); + + if ( config.hidepassed || defined.sessionStorage && sessionStorage.getItem( "qunit-filter-passed-tests" ) ) { + filter.checked = true; + // `ol` initialized at top of scope + ol = document.getElementById( "qunit-tests" ); + ol.className = ol.className + " hidepass"; + } + toolbar.appendChild( filter ); + + // `label` initialized at top of scope + label = document.createElement( "label" ); + label.setAttribute( "for", "qunit-filter-pass" ); + label.setAttribute( "title", "Only show tests and assertions that fail. Stored in sessionStorage." ); + label.innerHTML = "Hide passed tests"; + toolbar.appendChild( label ); + + urlConfigCheckboxesContainer = document.createElement("span"); + urlConfigCheckboxesContainer.innerHTML = urlConfigHtml; + urlConfigCheckboxes = urlConfigCheckboxesContainer.getElementsByTagName("input"); + // For oldIE support: + // * Add handlers to the individual elements instead of the container + // * Use "click" instead of "change" + // * Fallback from event.target to event.srcElement + addEvents( urlConfigCheckboxes, "click", function( event ) { + var params = {}, + target = event.target || event.srcElement; + params[ target.name ] = target.checked ? true : undefined; + window.location = QUnit.url( params ); + }); + toolbar.appendChild( urlConfigCheckboxesContainer ); + + if (numModules > 1) { + moduleFilter = document.createElement( "span" ); + moduleFilter.setAttribute( "id", "qunit-modulefilter-container" ); + moduleFilter.innerHTML = moduleFilterHtml; + addEvent( moduleFilter.lastChild, "change", function() { + var selectBox = moduleFilter.getElementsByTagName("select")[0], + selectedModule = decodeURIComponent(selectBox.options[selectBox.selectedIndex].value); + + window.location = QUnit.url({ + module: ( selectedModule === "" ) ? undefined : selectedModule, + // Remove any existing filters + filter: undefined, + testNumber: undefined + }); + }); + toolbar.appendChild(moduleFilter); + } + } + + // `main` initialized at top of scope + main = id( "qunit-fixture" ); + if ( main ) { + config.fixture = main.innerHTML; + } + + if ( config.autostart ) { + QUnit.start(); + } +}; + +addEvent( window, "load", QUnit.load ); + +// `onErrorFnPrev` initialized at top of scope +// Preserve other handlers +onErrorFnPrev = window.onerror; + +// Cover uncaught exceptions +// Returning true will suppress the default browser handler, +// returning false will let it run. +window.onerror = function ( error, filePath, linerNr ) { + var ret = false; + if ( onErrorFnPrev ) { + ret = onErrorFnPrev( error, filePath, linerNr ); + } + + // Treat return value as window.onerror itself does, + // Only do our handling if not suppressed. + if ( ret !== true ) { + if ( QUnit.config.current ) { + if ( QUnit.config.current.ignoreGlobalErrors ) { + return true; + } + QUnit.pushFailure( error, filePath + ":" + linerNr ); + } else { + QUnit.test( "global failure", extend( function() { + QUnit.pushFailure( error, filePath + ":" + linerNr ); + }, { validTest: validTest } ) ); + } + return false; + } + + return ret; +}; + +function done() { + config.autorun = true; + + // Log the last module results + if ( config.currentModule ) { + runLoggingCallbacks( "moduleDone", QUnit, { + name: config.currentModule, + failed: config.moduleStats.bad, + passed: config.moduleStats.all - config.moduleStats.bad, + total: config.moduleStats.all + }); + } + delete config.previousModule; + + var i, key, + banner = id( "qunit-banner" ), + tests = id( "qunit-tests" ), + runtime = +new Date() - config.started, + passed = config.stats.all - config.stats.bad, + html = [ + "Tests completed in ", + runtime, + " milliseconds.
        ", + "", + passed, + " assertions of ", + config.stats.all, + " passed, ", + config.stats.bad, + " failed." + ].join( "" ); + + if ( banner ) { + banner.className = ( config.stats.bad ? "qunit-fail" : "qunit-pass" ); + } + + if ( tests ) { + id( "qunit-testresult" ).innerHTML = html; + } + + if ( config.altertitle && typeof document !== "undefined" && document.title ) { + // show ✖ for good, ✔ for bad suite result in title + // use escape sequences in case file gets loaded with non-utf-8-charset + document.title = [ + ( config.stats.bad ? "\u2716" : "\u2714" ), + document.title.replace( /^[\u2714\u2716] /i, "" ) + ].join( " " ); + } + + // clear own sessionStorage items if all tests passed + if ( config.reorder && defined.sessionStorage && config.stats.bad === 0 ) { + // `key` & `i` initialized at top of scope + for ( i = 0; i < sessionStorage.length; i++ ) { + key = sessionStorage.key( i++ ); + if ( key.indexOf( "qunit-test-" ) === 0 ) { + sessionStorage.removeItem( key ); + } + } + } + + // scroll back to top to show results + if ( window.scrollTo ) { + window.scrollTo(0, 0); + } + + runLoggingCallbacks( "done", QUnit, { + failed: config.stats.bad, + passed: passed, + total: config.stats.all, + runtime: runtime + }); +} + +/** @return Boolean: true if this test should be ran */ +function validTest( test ) { + var include, + filter = config.filter && config.filter.toLowerCase(), + module = config.module && config.module.toLowerCase(), + fullName = (test.module + ": " + test.testName).toLowerCase(); + + // Internally-generated tests are always valid + if ( test.callback && test.callback.validTest === validTest ) { + delete test.callback.validTest; + return true; + } + + if ( config.testNumber ) { + return test.testNumber === config.testNumber; + } + + if ( module && ( !test.module || test.module.toLowerCase() !== module ) ) { + return false; + } + + if ( !filter ) { + return true; + } + + include = filter.charAt( 0 ) !== "!"; + if ( !include ) { + filter = filter.slice( 1 ); + } + + // If the filter matches, we need to honour include + if ( fullName.indexOf( filter ) !== -1 ) { + return include; + } + + // Otherwise, do the opposite + return !include; +} + +// so far supports only Firefox, Chrome and Opera (buggy), Safari (for real exceptions) +// Later Safari and IE10 are supposed to support error.stack as well +// See also https://developer.mozilla.org/en/JavaScript/Reference/Global_Objects/Error/Stack +function extractStacktrace( e, offset ) { + offset = offset === undefined ? 3 : offset; + + var stack, include, i; + + if ( e.stacktrace ) { + // Opera + return e.stacktrace.split( "\n" )[ offset + 3 ]; + } else if ( e.stack ) { + // Firefox, Chrome + stack = e.stack.split( "\n" ); + if (/^error$/i.test( stack[0] ) ) { + stack.shift(); + } + if ( fileName ) { + include = []; + for ( i = offset; i < stack.length; i++ ) { + if ( stack[ i ].indexOf( fileName ) !== -1 ) { + break; + } + include.push( stack[ i ] ); + } + if ( include.length ) { + return include.join( "\n" ); + } + } + return stack[ offset ]; + } else if ( e.sourceURL ) { + // Safari, PhantomJS + // hopefully one day Safari provides actual stacktraces + // exclude useless self-reference for generated Error objects + if ( /qunit.js$/.test( e.sourceURL ) ) { + return; + } + // for actual exceptions, this is useful + return e.sourceURL + ":" + e.line; + } +} +function sourceFromStacktrace( offset ) { + try { + throw new Error(); + } catch ( e ) { + return extractStacktrace( e, offset ); + } +} + +/** + * Escape text for attribute or text content. + */ +function escapeText( s ) { + if ( !s ) { + return ""; + } + s = s + ""; + // Both single quotes and double quotes (for attributes) + return s.replace( /['"<>&]/g, function( s ) { + switch( s ) { + case "'": + return "'"; + case "\"": + return """; + case "<": + return "<"; + case ">": + return ">"; + case "&": + return "&"; + } + }); +} + +function synchronize( callback, last ) { + config.queue.push( callback ); + + if ( config.autorun && !config.blocking ) { + process( last ); + } +} + +function process( last ) { + function next() { + process( last ); + } + var start = new Date().getTime(); + config.depth = config.depth ? config.depth + 1 : 1; + + while ( config.queue.length && !config.blocking ) { + if ( !defined.setTimeout || config.updateRate <= 0 || ( ( new Date().getTime() - start ) < config.updateRate ) ) { + config.queue.shift()(); + } else { + setTimeout( next, 13 ); + break; + } + } + config.depth--; + if ( last && !config.blocking && !config.queue.length && config.depth === 0 ) { + done(); + } +} + +function saveGlobal() { + config.pollution = []; + + if ( config.noglobals ) { + for ( var key in window ) { + if ( hasOwn.call( window, key ) ) { + // in Opera sometimes DOM element ids show up here, ignore them + if ( /^qunit-test-output/.test( key ) ) { + continue; + } + config.pollution.push( key ); + } + } + } +} + +function checkPollution() { + var newGlobals, + deletedGlobals, + old = config.pollution; + + saveGlobal(); + + newGlobals = diff( config.pollution, old ); + if ( newGlobals.length > 0 ) { + QUnit.pushFailure( "Introduced global variable(s): " + newGlobals.join(", ") ); + } + + deletedGlobals = diff( old, config.pollution ); + if ( deletedGlobals.length > 0 ) { + QUnit.pushFailure( "Deleted global variable(s): " + deletedGlobals.join(", ") ); + } +} + +// returns a new Array with the elements that are in a but not in b +function diff( a, b ) { + var i, j, + result = a.slice(); + + for ( i = 0; i < result.length; i++ ) { + for ( j = 0; j < b.length; j++ ) { + if ( result[i] === b[j] ) { + result.splice( i, 1 ); + i--; + break; + } + } + } + return result; +} + +function extend( a, b ) { + for ( var prop in b ) { + if ( hasOwn.call( b, prop ) ) { + // Avoid "Member not found" error in IE8 caused by messing with window.constructor + if ( !( prop === "constructor" && a === window ) ) { + if ( b[ prop ] === undefined ) { + delete a[ prop ]; + } else { + a[ prop ] = b[ prop ]; + } + } + } + } + + return a; +} + +/** + * @param {HTMLElement} elem + * @param {string} type + * @param {Function} fn + */ +function addEvent( elem, type, fn ) { + // Standards-based browsers + if ( elem.addEventListener ) { + elem.addEventListener( type, fn, false ); + // IE + } else { + elem.attachEvent( "on" + type, fn ); + } +} + +/** + * @param {Array|NodeList} elems + * @param {string} type + * @param {Function} fn + */ +function addEvents( elems, type, fn ) { + var i = elems.length; + while ( i-- ) { + addEvent( elems[i], type, fn ); + } +} + +function hasClass( elem, name ) { + return (" " + elem.className + " ").indexOf(" " + name + " ") > -1; +} + +function addClass( elem, name ) { + if ( !hasClass( elem, name ) ) { + elem.className += (elem.className ? " " : "") + name; + } +} + +function removeClass( elem, name ) { + var set = " " + elem.className + " "; + // Class name may appear multiple times + while ( set.indexOf(" " + name + " ") > -1 ) { + set = set.replace(" " + name + " " , " "); + } + // If possible, trim it for prettiness, but not necessarily + elem.className = typeof set.trim === "function" ? set.trim() : set.replace(/^\s+|\s+$/g, ""); +} + +function id( name ) { + return !!( typeof document !== "undefined" && document && document.getElementById ) && + document.getElementById( name ); +} + +function registerLoggingCallback( key ) { + return function( callback ) { + config[key].push( callback ); + }; +} + +// Supports deprecated method of completely overwriting logging callbacks +function runLoggingCallbacks( key, scope, args ) { + var i, callbacks; + if ( QUnit.hasOwnProperty( key ) ) { + QUnit[ key ].call(scope, args ); + } else { + callbacks = config[ key ]; + for ( i = 0; i < callbacks.length; i++ ) { + callbacks[ i ].call( scope, args ); + } + } +} + +// Test for equality any JavaScript type. +// Author: Philippe Rathé +QUnit.equiv = (function() { + + // Call the o related callback with the given arguments. + function bindCallbacks( o, callbacks, args ) { + var prop = QUnit.objectType( o ); + if ( prop ) { + if ( QUnit.objectType( callbacks[ prop ] ) === "function" ) { + return callbacks[ prop ].apply( callbacks, args ); + } else { + return callbacks[ prop ]; // or undefined + } + } + } + + // the real equiv function + var innerEquiv, + // stack to decide between skip/abort functions + callers = [], + // stack to avoiding loops from circular referencing + parents = [], + parentsB = [], + + getProto = Object.getPrototypeOf || function ( obj ) { + /*jshint camelcase:false */ + return obj.__proto__; + }, + callbacks = (function () { + + // for string, boolean, number and null + function useStrictEquality( b, a ) { + /*jshint eqeqeq:false */ + if ( b instanceof a.constructor || a instanceof b.constructor ) { + // to catch short annotation VS 'new' annotation of a + // declaration + // e.g. var i = 1; + // var j = new Number(1); + return a == b; + } else { + return a === b; + } + } + + return { + "string": useStrictEquality, + "boolean": useStrictEquality, + "number": useStrictEquality, + "null": useStrictEquality, + "undefined": useStrictEquality, + + "nan": function( b ) { + return isNaN( b ); + }, + + "date": function( b, a ) { + return QUnit.objectType( b ) === "date" && a.valueOf() === b.valueOf(); + }, + + "regexp": function( b, a ) { + return QUnit.objectType( b ) === "regexp" && + // the regex itself + a.source === b.source && + // and its modifiers + a.global === b.global && + // (gmi) ... + a.ignoreCase === b.ignoreCase && + a.multiline === b.multiline && + a.sticky === b.sticky; + }, + + // - skip when the property is a method of an instance (OOP) + // - abort otherwise, + // initial === would have catch identical references anyway + "function": function() { + var caller = callers[callers.length - 1]; + return caller !== Object && typeof caller !== "undefined"; + }, + + "array": function( b, a ) { + var i, j, len, loop, aCircular, bCircular; + + // b could be an object literal here + if ( QUnit.objectType( b ) !== "array" ) { + return false; + } + + len = a.length; + if ( len !== b.length ) { + // safe and faster + return false; + } + + // track reference to avoid circular references + parents.push( a ); + parentsB.push( b ); + for ( i = 0; i < len; i++ ) { + loop = false; + for ( j = 0; j < parents.length; j++ ) { + aCircular = parents[j] === a[i]; + bCircular = parentsB[j] === b[i]; + if ( aCircular || bCircular ) { + if ( a[i] === b[i] || aCircular && bCircular ) { + loop = true; + } else { + parents.pop(); + parentsB.pop(); + return false; + } + } + } + if ( !loop && !innerEquiv(a[i], b[i]) ) { + parents.pop(); + parentsB.pop(); + return false; + } + } + parents.pop(); + parentsB.pop(); + return true; + }, + + "object": function( b, a ) { + /*jshint forin:false */ + var i, j, loop, aCircular, bCircular, + // Default to true + eq = true, + aProperties = [], + bProperties = []; + + // comparing constructors is more strict than using + // instanceof + if ( a.constructor !== b.constructor ) { + // Allow objects with no prototype to be equivalent to + // objects with Object as their constructor. + if ( !(( getProto(a) === null && getProto(b) === Object.prototype ) || + ( getProto(b) === null && getProto(a) === Object.prototype ) ) ) { + return false; + } + } + + // stack constructor before traversing properties + callers.push( a.constructor ); + + // track reference to avoid circular references + parents.push( a ); + parentsB.push( b ); + + // be strict: don't ensure hasOwnProperty and go deep + for ( i in a ) { + loop = false; + for ( j = 0; j < parents.length; j++ ) { + aCircular = parents[j] === a[i]; + bCircular = parentsB[j] === b[i]; + if ( aCircular || bCircular ) { + if ( a[i] === b[i] || aCircular && bCircular ) { + loop = true; + } else { + eq = false; + break; + } + } + } + aProperties.push(i); + if ( !loop && !innerEquiv(a[i], b[i]) ) { + eq = false; + break; + } + } + + parents.pop(); + parentsB.pop(); + callers.pop(); // unstack, we are done + + for ( i in b ) { + bProperties.push( i ); // collect b's properties + } + + // Ensures identical properties name + return eq && innerEquiv( aProperties.sort(), bProperties.sort() ); + } + }; + }()); + + innerEquiv = function() { // can take multiple arguments + var args = [].slice.apply( arguments ); + if ( args.length < 2 ) { + return true; // end transition + } + + return (function( a, b ) { + if ( a === b ) { + return true; // catch the most you can + } else if ( a === null || b === null || typeof a === "undefined" || + typeof b === "undefined" || + QUnit.objectType(a) !== QUnit.objectType(b) ) { + return false; // don't lose time with error prone cases + } else { + return bindCallbacks(a, callbacks, [ b, a ]); + } + + // apply transition with (1..n) arguments + }( args[0], args[1] ) && innerEquiv.apply( this, args.splice(1, args.length - 1 )) ); + }; + + return innerEquiv; +}()); + +/** + * jsDump Copyright (c) 2008 Ariel Flesler - aflesler(at)gmail(dot)com | + * http://flesler.blogspot.com Licensed under BSD + * (http://www.opensource.org/licenses/bsd-license.php) Date: 5/15/2008 + * + * @projectDescription Advanced and extensible data dumping for Javascript. + * @version 1.0.0 + * @author Ariel Flesler + * @link {http://flesler.blogspot.com/2008/05/jsdump-pretty-dump-of-any-javascript.html} + */ +QUnit.jsDump = (function() { + function quote( str ) { + return "\"" + str.toString().replace( /"/g, "\\\"" ) + "\""; + } + function literal( o ) { + return o + ""; + } + function join( pre, arr, post ) { + var s = jsDump.separator(), + base = jsDump.indent(), + inner = jsDump.indent(1); + if ( arr.join ) { + arr = arr.join( "," + s + inner ); + } + if ( !arr ) { + return pre + post; + } + return [ pre, inner + arr, base + post ].join(s); + } + function array( arr, stack ) { + var i = arr.length, ret = new Array(i); + this.up(); + while ( i-- ) { + ret[i] = this.parse( arr[i] , undefined , stack); + } + this.down(); + return join( "[", ret, "]" ); + } + + var reName = /^function (\w+)/, + jsDump = { + // type is used mostly internally, you can fix a (custom)type in advance + parse: function( obj, type, stack ) { + stack = stack || [ ]; + var inStack, res, + parser = this.parsers[ type || this.typeOf(obj) ]; + + type = typeof parser; + inStack = inArray( obj, stack ); + + if ( inStack !== -1 ) { + return "recursion(" + (inStack - stack.length) + ")"; + } + if ( type === "function" ) { + stack.push( obj ); + res = parser.call( this, obj, stack ); + stack.pop(); + return res; + } + return ( type === "string" ) ? parser : this.parsers.error; + }, + typeOf: function( obj ) { + var type; + if ( obj === null ) { + type = "null"; + } else if ( typeof obj === "undefined" ) { + type = "undefined"; + } else if ( QUnit.is( "regexp", obj) ) { + type = "regexp"; + } else if ( QUnit.is( "date", obj) ) { + type = "date"; + } else if ( QUnit.is( "function", obj) ) { + type = "function"; + } else if ( typeof obj.setInterval !== undefined && typeof obj.document !== "undefined" && typeof obj.nodeType === "undefined" ) { + type = "window"; + } else if ( obj.nodeType === 9 ) { + type = "document"; + } else if ( obj.nodeType ) { + type = "node"; + } else if ( + // native arrays + toString.call( obj ) === "[object Array]" || + // NodeList objects + ( typeof obj.length === "number" && typeof obj.item !== "undefined" && ( obj.length ? obj.item(0) === obj[0] : ( obj.item( 0 ) === null && typeof obj[0] === "undefined" ) ) ) + ) { + type = "array"; + } else if ( obj.constructor === Error.prototype.constructor ) { + type = "error"; + } else { + type = typeof obj; + } + return type; + }, + separator: function() { + return this.multiline ? this.HTML ? "
        " : "\n" : this.HTML ? " " : " "; + }, + // extra can be a number, shortcut for increasing-calling-decreasing + indent: function( extra ) { + if ( !this.multiline ) { + return ""; + } + var chr = this.indentChar; + if ( this.HTML ) { + chr = chr.replace( /\t/g, " " ).replace( / /g, " " ); + } + return new Array( this.depth + ( extra || 0 ) ).join(chr); + }, + up: function( a ) { + this.depth += a || 1; + }, + down: function( a ) { + this.depth -= a || 1; + }, + setParser: function( name, parser ) { + this.parsers[name] = parser; + }, + // The next 3 are exposed so you can use them + quote: quote, + literal: literal, + join: join, + // + depth: 1, + // This is the list of parsers, to modify them, use jsDump.setParser + parsers: { + window: "[Window]", + document: "[Document]", + error: function(error) { + return "Error(\"" + error.message + "\")"; + }, + unknown: "[Unknown]", + "null": "null", + "undefined": "undefined", + "function": function( fn ) { + var ret = "function", + // functions never have name in IE + name = "name" in fn ? fn.name : (reName.exec(fn) || [])[1]; + + if ( name ) { + ret += " " + name; + } + ret += "( "; + + ret = [ ret, QUnit.jsDump.parse( fn, "functionArgs" ), "){" ].join( "" ); + return join( ret, QUnit.jsDump.parse(fn,"functionCode" ), "}" ); + }, + array: array, + nodelist: array, + "arguments": array, + object: function( map, stack ) { + /*jshint forin:false */ + var ret = [ ], keys, key, val, i; + QUnit.jsDump.up(); + keys = []; + for ( key in map ) { + keys.push( key ); + } + keys.sort(); + for ( i = 0; i < keys.length; i++ ) { + key = keys[ i ]; + val = map[ key ]; + ret.push( QUnit.jsDump.parse( key, "key" ) + ": " + QUnit.jsDump.parse( val, undefined, stack ) ); + } + QUnit.jsDump.down(); + return join( "{", ret, "}" ); + }, + node: function( node ) { + var len, i, val, + open = QUnit.jsDump.HTML ? "<" : "<", + close = QUnit.jsDump.HTML ? ">" : ">", + tag = node.nodeName.toLowerCase(), + ret = open + tag, + attrs = node.attributes; + + if ( attrs ) { + for ( i = 0, len = attrs.length; i < len; i++ ) { + val = attrs[i].nodeValue; + // IE6 includes all attributes in .attributes, even ones not explicitly set. + // Those have values like undefined, null, 0, false, "" or "inherit". + if ( val && val !== "inherit" ) { + ret += " " + attrs[i].nodeName + "=" + QUnit.jsDump.parse( val, "attribute" ); + } + } + } + ret += close; + + // Show content of TextNode or CDATASection + if ( node.nodeType === 3 || node.nodeType === 4 ) { + ret += node.nodeValue; + } + + return ret + open + "/" + tag + close; + }, + // function calls it internally, it's the arguments part of the function + functionArgs: function( fn ) { + var args, + l = fn.length; + + if ( !l ) { + return ""; + } + + args = new Array(l); + while ( l-- ) { + // 97 is 'a' + args[l] = String.fromCharCode(97+l); + } + return " " + args.join( ", " ) + " "; + }, + // object calls it internally, the key part of an item in a map + key: quote, + // function calls it internally, it's the content of the function + functionCode: "[code]", + // node calls it internally, it's an html attribute value + attribute: quote, + string: quote, + date: quote, + regexp: literal, + number: literal, + "boolean": literal + }, + // if true, entities are escaped ( <, >, \t, space and \n ) + HTML: false, + // indentation unit + indentChar: " ", + // if true, items in a collection, are separated by a \n, else just a space. + multiline: true + }; + + return jsDump; +}()); + +// from jquery.js +function inArray( elem, array ) { + if ( array.indexOf ) { + return array.indexOf( elem ); + } + + for ( var i = 0, length = array.length; i < length; i++ ) { + if ( array[ i ] === elem ) { + return i; + } + } + + return -1; +} + +/* + * Javascript Diff Algorithm + * By John Resig (http://ejohn.org/) + * Modified by Chu Alan "sprite" + * + * Released under the MIT license. + * + * More Info: + * http://ejohn.org/projects/javascript-diff-algorithm/ + * + * Usage: QUnit.diff(expected, actual) + * + * QUnit.diff( "the quick brown fox jumped over", "the quick fox jumps over" ) == "the quick brown fox jumped jumps over" + */ +QUnit.diff = (function() { + /*jshint eqeqeq:false, eqnull:true */ + function diff( o, n ) { + var i, + ns = {}, + os = {}; + + for ( i = 0; i < n.length; i++ ) { + if ( !hasOwn.call( ns, n[i] ) ) { + ns[ n[i] ] = { + rows: [], + o: null + }; + } + ns[ n[i] ].rows.push( i ); + } + + for ( i = 0; i < o.length; i++ ) { + if ( !hasOwn.call( os, o[i] ) ) { + os[ o[i] ] = { + rows: [], + n: null + }; + } + os[ o[i] ].rows.push( i ); + } + + for ( i in ns ) { + if ( hasOwn.call( ns, i ) ) { + if ( ns[i].rows.length === 1 && hasOwn.call( os, i ) && os[i].rows.length === 1 ) { + n[ ns[i].rows[0] ] = { + text: n[ ns[i].rows[0] ], + row: os[i].rows[0] + }; + o[ os[i].rows[0] ] = { + text: o[ os[i].rows[0] ], + row: ns[i].rows[0] + }; + } + } + } + + for ( i = 0; i < n.length - 1; i++ ) { + if ( n[i].text != null && n[ i + 1 ].text == null && n[i].row + 1 < o.length && o[ n[i].row + 1 ].text == null && + n[ i + 1 ] == o[ n[i].row + 1 ] ) { + + n[ i + 1 ] = { + text: n[ i + 1 ], + row: n[i].row + 1 + }; + o[ n[i].row + 1 ] = { + text: o[ n[i].row + 1 ], + row: i + 1 + }; + } + } + + for ( i = n.length - 1; i > 0; i-- ) { + if ( n[i].text != null && n[ i - 1 ].text == null && n[i].row > 0 && o[ n[i].row - 1 ].text == null && + n[ i - 1 ] == o[ n[i].row - 1 ]) { + + n[ i - 1 ] = { + text: n[ i - 1 ], + row: n[i].row - 1 + }; + o[ n[i].row - 1 ] = { + text: o[ n[i].row - 1 ], + row: i - 1 + }; + } + } + + return { + o: o, + n: n + }; + } + + return function( o, n ) { + o = o.replace( /\s+$/, "" ); + n = n.replace( /\s+$/, "" ); + + var i, pre, + str = "", + out = diff( o === "" ? [] : o.split(/\s+/), n === "" ? [] : n.split(/\s+/) ), + oSpace = o.match(/\s+/g), + nSpace = n.match(/\s+/g); + + if ( oSpace == null ) { + oSpace = [ " " ]; + } + else { + oSpace.push( " " ); + } + + if ( nSpace == null ) { + nSpace = [ " " ]; + } + else { + nSpace.push( " " ); + } + + if ( out.n.length === 0 ) { + for ( i = 0; i < out.o.length; i++ ) { + str += "" + out.o[i] + oSpace[i] + ""; + } + } + else { + if ( out.n[0].text == null ) { + for ( n = 0; n < out.o.length && out.o[n].text == null; n++ ) { + str += "" + out.o[n] + oSpace[n] + ""; + } + } + + for ( i = 0; i < out.n.length; i++ ) { + if (out.n[i].text == null) { + str += "" + out.n[i] + nSpace[i] + ""; + } + else { + // `pre` initialized at top of scope + pre = ""; + + for ( n = out.n[i].row + 1; n < out.o.length && out.o[n].text == null; n++ ) { + pre += "" + out.o[n] + oSpace[n] + ""; + } + str += " " + out.n[i].text + nSpace[i] + pre; + } + } + } + + return str; + }; +}()); + +// for CommonJS environments, export everything +if ( typeof exports !== "undefined" ) { + extend( exports, QUnit.constructor.prototype ); +} + +// get at whatever the global object is, like window in browsers +}( (function() {return this;}.call()) )); diff --git a/node_modules/toastr/package/tests/toastr-tests.html b/node_modules/toastr/package/tests/toastr-tests.html new file mode 100644 index 0000000..1fe155b --- /dev/null +++ b/node_modules/toastr/package/tests/toastr-tests.html @@ -0,0 +1,21 @@ + + + + toastr QUnit Tests + + + + +
        +

        toastr QUnit Tests

        +

        +
        +

        +
          +
          test markup, will be hidden
          + + + + + + diff --git a/node_modules/toastr/package/tests/unit/qunit-helper.js b/node_modules/toastr/package/tests/unit/qunit-helper.js new file mode 100644 index 0000000..42ce5e2 --- /dev/null +++ b/node_modules/toastr/package/tests/unit/qunit-helper.js @@ -0,0 +1,13 @@ +/** + * Hack to expose spec count from QUnit to Karma + */ + +var testCount = 0; +var qunitTest = QUnit.test; +QUnit.test = window.test = function () { + testCount += 1; + qunitTest.apply(this, arguments); +}; +QUnit.begin(function (args) { + args.totalTests = testCount; +}); diff --git a/node_modules/toastr/package/tests/unit/toastr-tests.js b/node_modules/toastr/package/tests/unit/toastr-tests.js new file mode 100644 index 0000000..0d834ed --- /dev/null +++ b/node_modules/toastr/package/tests/unit/toastr-tests.js @@ -0,0 +1,625 @@ +/// +/// +(function () { + var iconClasses = { + error: 'toast-error', + info: 'toast-info', + success: 'toast-success', + warning: 'toast-warning' + }; + var positionClasses = { + topRight: 'toast-top-right', + bottomRight: 'toast-bottom-right', + bottomLeft: 'toast-bottom-left', + topLeft: 'toast-top-left', + topCenter: 'toast-top-center', + bottomCenter: 'toast-bottom-center' + }; + var sampleMsg = 'I don\'t think they really exist'; + var sampleTitle = 'ROUS'; + var selectors = { + container: 'div#toast-container', + toastInfo: 'div#toast-container > div.toast-info', + toastWarning: 'div#toast-container > div.toast-success', + toastError: 'div#toast-container > div.toast-error', + toastSuccess: 'div#toast-container > div.toast-success' + }; + + toastr.options = { + timeOut: 2000, + extendedTimeOut: 0, + fadeOut: 0, + fadeIn: 0, + showDuration: 0, + hideDuration: 0, + debug: false + }; + + var delay = toastr.options.timeOut + 500; + + // 'Clears' must go first + module('clear'); + asyncTest('clear - show 3 toasts, clear the 2nd', 1, function () { + //Arrange + var $toast = []; + $toast[0] = toastr.info(sampleMsg, sampleTitle + '-1'); + $toast[1] = toastr.info(sampleMsg, sampleTitle + '-2'); + $toast[2] = toastr.info(sampleMsg, sampleTitle + '-3'); + var $container = toastr.getContainer(); + //Act + toastr.clear($toast[1]); + //Assert + setTimeout(function () { + //debugger; + //console.log($container.children().length); + ok($container && $container.children().length === 2); + //Teardown + resetContainer(); + start(); + }, 1000); + }); + asyncTest('clear - show 3 toasts, clear all 3, 0 left', 1, function () { + //Arrange + var $toast = []; + $toast[0] = toastr.info(sampleMsg, sampleTitle + '-1'); + $toast[1] = toastr.info(sampleMsg, sampleTitle + '-2'); + $toast[2] = toastr.info(sampleMsg, sampleTitle + '-3'); + var $container = toastr.getContainer(); + //Act + toastr.clear(); + //Assert + setTimeout(function () { + ok($container && $container.children().length === 0); + //Teardown + resetContainer(); + start(); + }, delay); + }); + test('clear - after clear with force option toast with focus disappears', 1, function () { + //Arrange + var $toast; + var msg = sampleMsg + '

          '; + //Act + $toast = toastr.info(msg, sampleTitle + '-1'); + $toast.find('button').focus(); + toastr.clear($toast, { force: true }); + var $container = toastr.getContainer(); + //Assert + ok($container && $container.children().length === 0, 'Focused toast after a clear with force is not visible'); + //Teardown + resetContainer(); + }); + asyncTest('clear and show - show 2 toasts, clear both, then show 1 more', 2, function () { + //Arrange + var $toast = []; + $toast[0] = toastr.info(sampleMsg, sampleTitle + '-1'); + $toast[1] = toastr.info(sampleMsg, sampleTitle + '-2'); + var $container = toastr.getContainer(); + toastr.clear(); + //Act + setTimeout(function () { + $toast[2] = toastr.info(sampleMsg, sampleTitle + '-3-Visible'); + //Assert + equal($toast[2].find('div.toast-title').html(), sampleTitle + '-3-Visible', 'Finds toast after a clear'); + ok($toast[2].is(':visible'), 'Toast after a clear is visible'); + //Teardown + resetContainer(); + start(); + }, delay); + }); + asyncTest('clear and show - clear removes toast container', 2, function () { + //Arrange + var $toast = []; + $toast[0] = toastr.info(sampleMsg, sampleTitle + '-1'); + $toast[1] = toastr.info(sampleMsg, sampleTitle + '-2'); + var $container = toastr.getContainer(); + toastr.clear(); + //Act + setTimeout(function () { + //Assert + equal($(selectors.container).length, 0, 'Toast container does not exist'); + ok(!$toast[1].is(':visible'), 'Toast after a clear is visible'); + //Teardown + resetContainer(); + start(); + }, delay); + }); + asyncTest('clear and show - after clear new toast creates container', 1, function () { + //Arrange + var $toast = []; + $toast[0] = toastr.info(sampleMsg, sampleTitle + '-1'); + $toast[1] = toastr.info(sampleMsg, sampleTitle + '-2'); + var $container = toastr.getContainer(); + toastr.clear(); + //Act + setTimeout(function () { + $toast[2] = toastr.info(sampleMsg, sampleTitle + '-3-Visible'); + //Assert + equal($(selectors.container).find('div.toast-title').html(), sampleTitle + '-3-Visible', 'Finds toast after a clear'); //Teardown + resetContainer(); + start(); + }, delay); + }); + test('clear and show - after clear all toasts new toast still appears', 1, function () { + //Arrange + var $toast = []; + //Act + $toast[0] = toastr.info(sampleMsg, sampleTitle + '-1'); + $toast[1] = toastr.info(sampleMsg, sampleTitle + '-2'); + toastr.clear(); + $toast[2] = toastr.info(sampleMsg, sampleTitle + '-3-Visible'); + //Assert + ok($toast[2].is(':visible'), 'Toast after a clear is visible'); + //Teardown + resetContainer(); + }); + module('info'); + test('info - pass title and message', 3, function () { + //Arrange + //Act + var $toast = toastr.info(sampleMsg, sampleTitle); + //Assert + equal($toast.find('div.toast-title').html(), sampleTitle, 'Sets title'); + equal($toast.find('div.toast-message').html(), sampleMsg, 'Sets message'); + ok($toast.hasClass(iconClasses.info), 'Sets info icon'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + test('info - pass message, but no title', 3, function () { + //Arrange + //Act + var $toast = toastr.info(sampleMsg); + //Assert + equal($toast.find('div.toast-title').length, 0, 'Sets null title'); + equal($toast.find('div.toast-message').html(), sampleMsg, 'Sets message'); + ok($toast.hasClass(iconClasses.info), 'Sets info icon'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + test('info - pass no message nor title', 3, function () { + //Arrange + //Act + var $toast = toastr.info(); //Assert + equal($toast.find('div.toast-title').length, 0, 'Sets null title'); + equal($toast.find('div.toast-message').html(), null, 'Sets message'); + ok($toast.hasClass(iconClasses.info), 'Sets info icon'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + module('warning'); + test('warning - pass message and title', 3, function () { + //Arrange + //Act + var $toast = toastr.warning(sampleMsg, sampleTitle); + //Assert + equal($toast.find('div.toast-title').html(), sampleTitle, 'Sets title'); + equal($toast.find('div.toast-message').html(), sampleMsg, 'Sets message'); + ok($toast.hasClass(iconClasses.warning), 'Sets warning icon'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + test('warning - pass message, but no title', 3, function () { + //Arrange + //Act + var $toast = toastr.warning(sampleMsg); + //Assert + equal($toast.find('div.toast-title').length, 0, 'Sets empty title'); + equal($toast.find('div.toast-message').html(), sampleMsg, 'Sets message'); + ok($toast.hasClass(iconClasses.warning), 'Sets warning icon'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + test('warning - no message nor title', 3, function () { + //Arrange + //Act + var $toast = toastr.warning(''); + //Assert + equal($toast.find('div.toast-title').length, 0, 'Sets null title'); + equal($toast.find('div.toast-message').length, 0, 'Sets empty message'); + ok($toast.hasClass(iconClasses.warning), 'Sets warning icon'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + module('error'); + test('error - pass message and title', 3, function () { + //Arrange + //Act + var $toast = toastr.error(sampleMsg, sampleTitle); + //Assert + equal($toast.find('div.toast-title').html(), sampleTitle, 'Sets title'); + equal($toast.find('div.toast-message').html(), sampleMsg, 'Sets message'); + ok($toast.hasClass(iconClasses.error), 'Sets error icon'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + test('error - pass message, but no title', 3, function () { + //Arrange + //Act + var $toast = toastr.error(sampleMsg); //Assert + equal($toast.find('div.toast-title').length, 0, 'Sets empty title'); + equal($toast.find('div.toast-message').html(), sampleMsg, 'Sets message'); + ok($toast.hasClass(iconClasses.error), 'Sets error icon'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + test('error - no message nor title', 3, function () { + //Arrange + //Act + var $toast = toastr.error(''); + //Assert + equal($toast.find('div.toast-title').length, 0, 'Sets empty title'); + equal($toast.find('div.toast-message').length, 0, 'Sets empty message'); + ok($toast.hasClass(iconClasses.error), 'Sets error icon'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + module('success'); + test('success - pass message and title', 3, function () { + //Arrange + //Act + var $toast = toastr.success(sampleMsg, sampleTitle); + //Assert + equal($toast.find('div.toast-title').html(), sampleTitle, 'Sets title'); + equal($toast.find('div.toast-message').html(), sampleMsg, 'Sets message'); + ok($toast.hasClass(iconClasses.success), 'Sets success icon'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + test('success - pass message, but no title', 3, function () { + //Arrange + //Act + var $toast = toastr.success(sampleMsg); + //Assert + equal($toast.find('div.toast-title').length, 0, 'Sets empty title'); + equal($toast.find('div.toast-message').html(), sampleMsg, 'Sets message'); + ok($toast.hasClass(iconClasses.success), 'Sets success icon'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + test('success - no message nor title', 3, function () { + //Arrange + //Act + var $toast = toastr.success(''); + //Assert + equal($toast.find('div.toast-title').length, 0, 'Sets null title'); + equal($toast.find('div.toast-message').length, 0, 'Sets empty message'); + ok($toast.hasClass(iconClasses.success), 'Sets success icon'); //Teardown + $toast.remove(); + clearContainerChildren(); + }); + + module('closeButton', { + teardown: function () { + toastr.options.closeButton = false; + } + }); + test('close button disabled', 1, function () { + //Arrange + toastr.options.closeButton = false; + //Act + var $toast = toastr.success(''); + //Assert + equal($toast.find('button.toast-close-button').length, 0, 'close button should not exist with closeButton=false'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + test('close button enabled', 1, function () { + //Arrange + toastr.options.closeButton = true; + //Act + var $toast = toastr.success(''); + //Assert + equal($toast.find('button.toast-close-button').length, 1, 'close button should exist with closeButton=true'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + test('close button has type=button', 1, function () { + //Arrange + toastr.options.closeButton = true; + //Act + var $toast = toastr.success(''); + //Assert + equal($toast.find('button[type="button"].toast-close-button').length, 1, 'close button should have type=button'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + + module('progressBar', { + teardown: function () { + toastr.options.progressBar = false; + } + }); + test('progress bar disabled', 1, function () { + //Arrange + toastr.options.progressBar = false; + //Act + var $toast = toastr.success(''); + //Assert + equal($toast.find('div.toast-progress').length, 0, 'progress bar should not exist with progressBar=false'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + test('progress bar enabled', 1, function () { + //Arrange + toastr.options.progressBar = true; + //Act + var $toast = toastr.success(''); + //Assert + equal($toast.find('div.toast-progress').length, 1, 'progress bar should exist with progressBar=true'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + + module('event'); + asyncTest('event - onShown is executed', 1, function () { + // Arrange + var run = false; + var onShown = function () { run = true; }; + toastr.options.onShown = onShown; + // Act + var $toast = toastr.success(sampleMsg, sampleTitle); + setTimeout(function () { + // Assert + ok(run); + //Teardown + $toast.remove(); + clearContainerChildren(); + start(); + }, delay); + }); + + asyncTest('event - onHidden is executed', 1, function () { + //Arrange + var run = false; + var onHidden = function () { run = true; }; + toastr.options.onHidden = onHidden; + toastr.options.timeOut = 1; + //Act + var $toast = toastr.success(sampleMsg, sampleTitle); + setTimeout(function () { + // Assert + ok(run); //Teardown + $toast.remove(); + clearContainerChildren(); + start(); + }, delay); + }); + + asyncTest('event - onShown and onHidden are both executed', 2, function () { + //Arrange + var onShowRun = false; + var onHideRun = false; + var onShow = function () { onShowRun = true; }; + var onHide = function () { onHideRun = true; }; + toastr.options.onShown = onShow; + toastr.options.onHidden = onHide; + toastr.options.timeOut = 1; + //Act + var $toast = toastr.success(sampleMsg, sampleTitle); + setTimeout(function () { + // Assert + ok(onShowRun); + ok(onHideRun); + //Teardown + $toast.remove(); + clearContainerChildren(); + start(); + }, delay); + }); + + test('event - message appears when no show or hide method functions provided', 1, function () { + //Arrange + //Act + var $toast = toastr.success(sampleMsg, sampleTitle); + //Assert + ok($toast.hasClass(iconClasses.success), 'Sets success icon'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + + test('event - prevent duplicate sequential toasts.', 1, function(){ + toastr.options.preventDuplicates = true; + + var $toast = []; + $toast[0] = toastr.info(sampleMsg, sampleTitle); + $toast[1] = toastr.info(sampleMsg, sampleTitle); + $toast[2] = toastr.info(sampleMsg + " 1", sampleTitle); + $toast[3] = toastr.info(sampleMsg, sampleTitle); + var $container = toastr.getContainer(); + + ok($container && $container.children().length === 3); + + clearContainerChildren(); + }); + + test('event - prevent duplicate sequential toasts, but allow previous after clear.', 1, function(){ + toastr.options.preventDuplicates = true; + + var $toast = []; + $toast[0] = toastr.info(sampleMsg, sampleTitle); + $toast[1] = toastr.info(sampleMsg, sampleTitle); + clearContainerChildren(); + $toast[3] = toastr.info(sampleMsg, sampleTitle); + var $container = toastr.getContainer(); + + ok($container && $container.children().length === 1); + + clearContainerChildren(); + }); + + test('event - allow duplicate sequential toasts.', 1, function(){ + toastr.options.preventDuplicates = false; + + var $toast = []; + $toast[0] = toastr.info(sampleMsg, sampleTitle); + $toast[1] = toastr.info(sampleMsg, sampleTitle); + $toast[1] = toastr.info(sampleMsg, sampleTitle); + var $container = toastr.getContainer(); + + ok($container && $container.children().length === 3); + + clearContainerChildren(); + }); + + test('event - allow preventDuplicates option to be overridden.', 1, function() { + var $toast = []; + + $toast[0] = toastr.info(sampleMsg, sampleTitle, { + preventDuplicates: true + }); + $toast[1] = toastr.info(sampleMsg, sampleTitle, { + preventDuplicates: true + }); + $toast[2] = toastr.info(sampleMsg, sampleTitle); + var $container = toastr.getContainer(); + + ok($container && $container.children().length === 2); + clearContainerChildren(); + }); + + module('order of appearance'); + test('Newest toast on top', 1, function () { + //Arrange + resetContainer(); + toastr.options.newestOnTop = true; + //Act + var $first = toastr.success("First toast"); + var $second = toastr.success("Second toast"); + //Assert + var containerHtml = toastr.getContainer().html(); + ok(containerHtml.indexOf("First toast") > containerHtml.indexOf("Second toast"), 'Newest toast is on top'); + //Teardown + $first.remove(); + $second.remove(); + resetContainer(); + }); + + test('Oldest toast on top', 1, function () { + //Arrange + resetContainer(); + toastr.options.newestOnTop = false; + //Act + var $first = toastr.success("First toast"); + var $second = toastr.success("Second toast"); + //Assert + var containerHtml = toastr.getContainer().html(); + ok(containerHtml.indexOf("First toast") < containerHtml.indexOf("Second toast"), 'Oldest toast is on top'); + //Teardown + $first.remove(); + $second.remove(); + resetContainer(); + }); + + // These must go last + module('positioning'); + test('Container - position top-right', 1, function () { + //Arrange + resetContainer(); + toastr.options.positionClass = positionClasses.topRight; + //Act + var $toast = toastr.success(sampleMsg); + var $container = toastr.getContainer(); + //Assert + ok($container.hasClass(positionClasses.topRight), 'Has position top right'); + //Teardown + $toast.remove(); + resetContainer(); + }); + test('Container - position bottom-right', 1, function () { + //Arrange + resetContainer(); + toastr.options.positionClass = positionClasses.bottomRight; + //Act + var $toast = toastr.success(sampleMsg); + var $container = toastr.getContainer(); + //Assert + ok($container.hasClass(positionClasses.bottomRight), 'Has position bottom right'); + //Teardown + $toast.remove(); + resetContainer(); + }); + test('Container - position bottom-left', 1, function () { + //Arrange + resetContainer(); + //$(selectors.container).remove() + toastr.options.positionClass = positionClasses.bottomLeft; + //Act + var $toast = toastr.success(sampleMsg); + var $container = toastr.getContainer(); + //Assert + ok($container.hasClass(positionClasses.bottomLeft), 'Has position bottom left'); + //Teardown + $toast.remove(); + resetContainer(); + }); + test('Container - position top-left', 1, function () { + //Arrange + resetContainer(); + toastr.options.positionClass = positionClasses.topLeft; + //Act + var $toast = toastr.success(sampleMsg); + var $container = toastr.getContainer(); + //Assert + ok($container.hasClass(positionClasses.topLeft), 'Has position top left'); + //Teardown + $toast.remove(); + resetContainer(); + }); + test('Container - position top-center', 1, function () { + //Arrange + resetContainer(); + toastr.options.positionClass = positionClasses.topCenter; + //Act + var $toast = toastr.success(sampleMsg); + var $container = toastr.getContainer(); + //Assert + ok($container.hasClass(positionClasses.topCenter), 'Has position top center'); + //Teardown + $toast.remove(); + resetContainer(); + }); + test('Container - position bottom-center', 1, function () { + //Arrange + resetContainer(); + toastr.options.positionClass = positionClasses.bottomCenter; + //Act + var $toast = toastr.success(sampleMsg); + var $container = toastr.getContainer(); + //Assert + ok($container.hasClass(positionClasses.bottomCenter), 'Has position bottom center'); + //Teardown + $toast.remove(); + resetContainer(); + }); + + function resetContainer() { + var $container = toastr.getContainer(); + if ($container) { + $container.remove(); + } + $(selectors.container).remove(); + clearContainerChildren(); + } + + function clearContainerChildren() { + toastr.clear(); + } + +})(); diff --git a/node_modules/toastr/package/tests/unit/x.js b/node_modules/toastr/package/tests/unit/x.js new file mode 100644 index 0000000..b78dd48 --- /dev/null +++ b/node_modules/toastr/package/tests/unit/x.js @@ -0,0 +1,3 @@ + test('test test', 1, function () { + ok(1 === 1, '1 equals 1'); + }); diff --git a/node_modules/toastr/package/toastr-2.1.2.tgz b/node_modules/toastr/package/toastr-2.1.2.tgz new file mode 100644 index 0000000000000000000000000000000000000000..d5e5aa9ee7f15bf6c7b01904ad16484cdff00b43 GIT binary patch literal 1491899 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 z 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%0AD;>5|MfCWX0J~Obw%Te7Y<&z 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 z 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 w*+in8%LOtz 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�F^I2oW0M2o7aQuDa8=uR3>eIXF;06w3k| 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

          +(hYqVT+MD+YkS_l@ujg@Bil{W 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\i4f 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 NVx*mJ|h8|@Yfadp&a#S8Dr^=!=W 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�+IFT2Vqyj|*y8B@z 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

          ma=ji|fK(eGSO24UH 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 CM7tt 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%0Apv}q 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%0AD;>5 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 z z(zQ{e!t35ezAtTO7+OC3;Bmftt@YLFnYS`;(D2e)MKxa&yPR=n6DDp-`E)-x+J1iA z{J0M@27I#K*lkTr-pMJVs`xv#-gT<$qRIR2sn)G1>~+OcwRW*+vD9k!sM9yS$Ia~f+GA+POGz``&8wOUT{qqp z7W4`**x1&{Bu^G%nY(QD-g}YuPp_^sH42{_7&X6n{EfG}-pm{Dr6hE~eE(&0W{Z`6 z5gl?Cx>{ba*zwLPJib=uyNj=u444|^wtK+WyB9kb?B5>N>C!#-6}`8ZhPAu7%;sd> zRr8k*H~nC{+WA1s;fthI3@=SMe`_ZS3KpacB$n! zGQ?z8Bmct9Kh-z4NRRmWdcw%Ut+ne|`3}m?>Zz=`)W~$1Oa0M9`n~M#7oMNL;&fhK zMAYa;M8O=N-J=To@90b3sTw=~l(2HFhuQ3Y!&e0_T5lwqcj%WYO}d`C&u_cE%e8}} zM*aNtRJ}QGyRYwRRy(X)sW>yMPT{VgA$dJ}6pJnMLVc~IBRm7d`5B5^OKFd?pB64;2THw-KYth< zIA*`w$-cD{#3$Ux&FlWQL*p>5vtnG9sx3=NPJlm`;n-kVYnHfb*vxt7x>0*%k z(Gm;OJtciFZ<`<*zqj_gL30P~uX+B)gvVDZR<<>Ha;oXtr#_ME9va!^x8_~TXp*~Q zb}#1%mR)?O8QiI|)ZeUh)xeMjn-1C4zU0@&>GsRPz3<8IOM44Uc2`7L-eDMK1Dyo(ED%vEB&p1-j1Wp zmy5givV&8o=bAbRSKvF1+;^iNdM1kl_<#(eLmT@}`vw7G^pN1D2SWXNi*c*#r&muO zYtnHT`ysw}e)a4(e}4Puk)nzU$OIDzZr6^A?ueAVkW5q*_Z_QA`LeGpC+kl{qVCjt zzz#uCiHuG8TqJ0B<$E8J0VcE@x7+dQo7i2ZD3DpI7XTKKV?P*BOq%?t+jF^o9+73- zNOys;X9+oWSsJlDi^CNJ%@#++VudvHkH4P2{13<1el3asf)XhL5buj;V^l#DQre3H zVu~Uv8e`O$L_tDK!Ry;!f^Yu2`gpc_aDR61?l!`zJn)xb%@%^Ee39z9xOl@Cc{qPO zoINvD)vlYOUiEDceq-;xj3Ii=jh*#P@Y<$;sN{ohE-uC>{TP^J7{m4D*-}2KQ>+A@ z+RQldQd3w*cjUZ467t-pp_=Ek$xh<%@xD;F0hxaK# z^UfRP^_8`x!K?Ruzu_z=YpK4=V@xTgq)a;{d0y9o1~q}+mM)_EW0qj|Ol4|R-3kR2 z5+Q+1jzHb*gIi)?qF|I*$)bST0ttBgd>Ff|%3(!}Zb0YO@`KUKJGZ zYyTWWfVeH13f=|O+znQ)NOBKWFWNA2ehj*wb z5iG?`w7Ks*L8r}g_8u39sl6t|>*vqw<=mCC*tf)FnUx)v2ONAdq{s$&J9NXvML_V1 zehhxI#XNJ1J9j_z{q^Aq8B54Ox6B|Qjf&Nd=UX`ijo&7Aur~|yta$uB%o)nr^_ceJ2K^bQm61=|7(A1 z*H65`_>y9b(fck29lfOWGyU>E(S8dB#VF-Loy|&=G_E(4SL8BO$fU9LO4w!PQQDqE zccrMBw7IzG&d+3QZMA>|sktJJrY_w4)DOdWeTLTdZLsB{>)LVfT~M^y(W{>-j!wyz z$cV^$MUuddr{(>5j(|J0B<|(PtROeupuGqO5fdWqq~f>2krb6wE}y2ew>ht~@^thK z3Xoe!KLj5rD+s{=8eG8!7)Q>o9tw94xQB_dJ&3N(d_VF3d4(o%HVf`!xwbmBP!yzf! zEDSy?s{}f(uiJG4s&0NL%pT_>8dG`C^`>ag^b@ zv~z!XfiePRGG0SGPK!G|Q@^irE5@u{y+PB>1scbNnh4tL7pa?QM>b z)%8IN&whhH@?9p3@n-!?3c-&Oy^NtB$DX@OeCO8|B^t{lQO6A-H0RGTrLb*H=9I0Z zG^=Jx4}zNo9pSVhHWVfGjmauo-hBVmLyRe5krm(kt>3=qPOF0>ogMh=O^R_GL+~;T zK8SW>Vn@ySrKSjI_G=koB7AVS?g?(i*r-U8R{#YRm8M7~3M4Po{0W4J6!vv98zX%u zlTDn`lc5`rJEH_;CglUkB46fb`?sf4F*ub(~RlMh)Cb~Q;d zS%MV8`l{dbc77Q9&d%o&A&N^)V{%E#@!O9vX*Yz~YW2a-e1_N& z8DN4Pqz6PL+DkTI-{w=@%`N~;bB4F=Rm9tq9SB5Jc?waW0^%i%;&Oif>rUF#HE1$g zy~0?8&<^c7^*%p7iJ&9_tWglQ*5;Y3Y6VbRTNGQ?I(o7h5E?eXj!cfOkYcX3R>~t~ zYI8KXxH5q%TQHXL0y#qsSsX&s=qul2lK7ZH7-fhOL+8iQZ@aWT)8}stp!2$@mnmLe zgT=gbV^AcFBIF8T17Nr7*15r+zpfJO>JA*=l|(F=ZTo}yY6#Y!Kh9$ux_*q?J0E&! z=(k1pWQ;KMgUkA+88jszB*R_nkzKRCmLz0$l?tIMlj@Gc1=QOaw;kCf3K$VsfpDkn z7u~&ik6UqHC`_&-RCYiX=SLtzR(4(2fm3f*)_RMkZLU+hw${eH(ioX2jUmfj96X7p zp$*oOBF}4ygF&k@B#G*3;3Jj9rV479B@x7NOffN8RaFMCIr^<3RNrA{5y(Uzf|oIg z58c=fq3y!xH}AcE&|R0ubDLR4OGQ7VXsks^OxSJw^8Q_P1+{HfFSNPxS5L&|#yv_| z#fw)k_FQDC9}&Q@Q2;-9;9QiNb=MDI4W-~WXU~#o2$7f(lTGrQ+cTN> z!-)xj_I;-PiOz%y1}6qxC${lcLkK&gBO&f5BNYT4(g?;#S;ISzS_Er};wIS)Z5~C- ztlU0+TAiFCXK@@*$ribf0i4O}LSho%`c`u~Kz|Npg+&eID0G15SbtbFs?Fm#k|Kbh zL}820C?d31u7BEZH`%aBiP1PpQG!p=cVP@&+xh5IXwTpHbyLxd+q%lq*diHa zXgBS;3H7RCa{YA^`aw12WsyPvXj*NI?OxJA%h%&>*l&7au%pi#~PL(2%n;p8s zN!Wlv%qx%9+|#qJB-WQ$X)~YfBkA*Ib&5_re>$7~cLWTt6Ad0QWuy<;;XW zjuOXq@ckgekPwFR_xi5mR1_tT+tD(P9=2B(AgP`&s9cWy`Q_W+#P&2wgd&qopU*aV zk@-N$zh5XoaR5gTD1`9z-Nn6=@%l;~=jAMh0LdeyF|-B%h$W0y7ikBzq zL+_Dt8M|zJ=AXZ{eeWTLZJTU)=Rv+OQLIJeKl>AZF$`@Q#xVF8$AozGTVEV6&rTM0 zUIH;oh(2^E0@fb9^1*;y&*_pZzWv!Wp&kM=wMlOHnx#7Jxv5NTJ|62R?IN{j%A zqDV+PRJ!LSrr5JTdLNL06Yf;~$dlhVBu$>P{Oarfj*_5?rOXcr`b~RwVY4ioEh%#- z9HUPu@_Z%zbzW4GMj|zwDn3{p5@k7g*kYcj$bt)^r0Jv!KWAi(Wa)ke1-tl*_cFoPwLa4T}su=rH~k* z^VD_Wde|PHmU+e3n|}K^*m735ao94khB0LI3bFRaQGHY#b$)EMdz=?8&X!g-{krjS z0GrQ`7yV;guRFCiNiw;U7$kO)GpiOvh)Hjc&Bm!Apo$Yehtn*?ew>bXX+Z?w#RQS; z4z*)l&oGEAJ!h%q%=RPlXFCUcN5jy5w0n%Ox!;c8*4Q&bOSt@R<~4+1(# zW9<5f&X^3>Pve_kyn6jBo5zozJ$f=GU|WcyHJFvN+1-0|^Z~g0NzG>_dLKjNl%fhK zbX_B3VAS(1-e0g`mDCrDnGU1(QN2Gq+r-q{syKUoy?lD^G6put^!B6m*bN-Utgwp* z9~k;}(GrtGLN!NRE;5nDY&%M%vCo`!vrSoMh>}^Ga@SwCno`%w2;=jw{le+TKBdX( z{@+8?fFl0v@?-Ro~4^Xl|&ySZK%ijQA| z)jcvfo!;kmEQ3n|_msM>$*g74Zo5sILN~5vStk&hwfYT|3s6zz+ap*=B++gnYmaZ> zb|@Ty6Cep7D2f1R5+O;7#1cRNRZxNikEjU}gdrgh-}vR@86%9Wf(9`&JSGXAoJl_B z^CL+c0VwJUm1v%gNy!?cMhh3JW6Wj&@}MjM84{*Gz5TWI+g}MyAAD>$CCl!f#qfN-<^DCDzPlSj-@ws|LhUZ^H)?fMC2mJ|L;W)HDU$jf?L^^a7xw zgefvcRFz#6Q;8k>ZPLMtBIQD+j28qEiBkwT-lRB1EOKW!NrKqB`3gkQK4mhz<# zkKx%Du*namPmZD4| zQ>|k_rk_L!0nzww&=^tGM|$h==I-%)waAzO@_g9#&z`P_COVeGoVzd>HKJ5FTjuDy zB+Vu-=bOv3tfsuC>$7Km4EOFXpIx0Foh;h*x*{uC4rZn#a(SjfO*N}AYtOFpvP{ye z;kZdx46;Y+Ez3_+|!GDNNn?K(d^#?U07EX%-^96HGtR33w|u

          +(hYqV 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 div { + position: relative; + overflow: hidden; + margin: 0 0 6px; + padding: 15px 15px 15px 50px; + width: 300px; + -moz-border-radius: 3px 3px 3px 3px; + -webkit-border-radius: 3px 3px 3px 3px; + border-radius: 3px 3px 3px 3px; + background-position: 15px center; + background-repeat: no-repeat; + -moz-box-shadow: 0 0 12px #999999; + -webkit-box-shadow: 0 0 12px #999999; + box-shadow: 0 0 12px #999999; + color: #ffffff; + opacity: 0.8; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=80); + filter: alpha(opacity=80); +} +#toast-container > :hover { + -moz-box-shadow: 0 0 12px #000000; + -webkit-box-shadow: 0 0 12px #000000; + box-shadow: 0 0 12px #000000; + opacity: 1; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=100); + filter: alpha(opacity=100); + cursor: pointer; +} +#toast-container > .toast-info { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGwSURBVEhLtZa9SgNBEMc9sUxxRcoUKSzSWIhXpFMhhYWFhaBg4yPYiWCXZxBLERsLRS3EQkEfwCKdjWJAwSKCgoKCcudv4O5YLrt7EzgXhiU3/4+b2ckmwVjJSpKkQ6wAi4gwhT+z3wRBcEz0yjSseUTrcRyfsHsXmD0AmbHOC9Ii8VImnuXBPglHpQ5wwSVM7sNnTG7Za4JwDdCjxyAiH3nyA2mtaTJufiDZ5dCaqlItILh1NHatfN5skvjx9Z38m69CgzuXmZgVrPIGE763Jx9qKsRozWYw6xOHdER+nn2KkO+Bb+UV5CBN6WC6QtBgbRVozrahAbmm6HtUsgtPC19tFdxXZYBOfkbmFJ1VaHA1VAHjd0pp70oTZzvR+EVrx2Ygfdsq6eu55BHYR8hlcki+n+kERUFG8BrA0BwjeAv2M8WLQBtcy+SD6fNsmnB3AlBLrgTtVW1c2QN4bVWLATaIS60J2Du5y1TiJgjSBvFVZgTmwCU+dAZFoPxGEEs8nyHC9Bwe2GvEJv2WXZb0vjdyFT4Cxk3e/kIqlOGoVLwwPevpYHT+00T+hWwXDf4AJAOUqWcDhbwAAAAASUVORK5CYII=") !important; +} +#toast-container > .toast-error { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAHOSURBVEhLrZa/SgNBEMZzh0WKCClSCKaIYOED+AAKeQQLG8HWztLCImBrYadgIdY+gIKNYkBFSwu7CAoqCgkkoGBI/E28PdbLZmeDLgzZzcx83/zZ2SSXC1j9fr+I1Hq93g2yxH4iwM1vkoBWAdxCmpzTxfkN2RcyZNaHFIkSo10+8kgxkXIURV5HGxTmFuc75B2RfQkpxHG8aAgaAFa0tAHqYFfQ7Iwe2yhODk8+J4C7yAoRTWI3w/4klGRgR4lO7Rpn9+gvMyWp+uxFh8+H+ARlgN1nJuJuQAYvNkEnwGFck18Er4q3egEc/oO+mhLdKgRyhdNFiacC0rlOCbhNVz4H9FnAYgDBvU3QIioZlJFLJtsoHYRDfiZoUyIxqCtRpVlANq0EU4dApjrtgezPFad5S19Wgjkc0hNVnuF4HjVA6C7QrSIbylB+oZe3aHgBsqlNqKYH48jXyJKMuAbiyVJ8KzaB3eRc0pg9VwQ4niFryI68qiOi3AbjwdsfnAtk0bCjTLJKr6mrD9g8iq/S/B81hguOMlQTnVyG40wAcjnmgsCNESDrjme7wfftP4P7SP4N3CJZdvzoNyGq2c/HWOXJGsvVg+RA/k2MC/wN6I2YA2Pt8GkAAAAASUVORK5CYII=") !important; +} +#toast-container > .toast-success { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAADsSURBVEhLY2AYBfQMgf///3P8+/evAIgvA/FsIF+BavYDDWMBGroaSMMBiE8VC7AZDrIFaMFnii3AZTjUgsUUWUDA8OdAH6iQbQEhw4HyGsPEcKBXBIC4ARhex4G4BsjmweU1soIFaGg/WtoFZRIZdEvIMhxkCCjXIVsATV6gFGACs4Rsw0EGgIIH3QJYJgHSARQZDrWAB+jawzgs+Q2UO49D7jnRSRGoEFRILcdmEMWGI0cm0JJ2QpYA1RDvcmzJEWhABhD/pqrL0S0CWuABKgnRki9lLseS7g2AlqwHWQSKH4oKLrILpRGhEQCw2LiRUIa4lwAAAABJRU5ErkJggg==") !important; +} +#toast-container > .toast-warning { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGYSURBVEhL5ZSvTsNQFMbXZGICMYGYmJhAQIJAICYQPAACiSDB8AiICQQJT4CqQEwgJvYASAQCiZiYmJhAIBATCARJy+9rTsldd8sKu1M0+dLb057v6/lbq/2rK0mS/TRNj9cWNAKPYIJII7gIxCcQ51cvqID+GIEX8ASG4B1bK5gIZFeQfoJdEXOfgX4QAQg7kH2A65yQ87lyxb27sggkAzAuFhbbg1K2kgCkB1bVwyIR9m2L7PRPIhDUIXgGtyKw575yz3lTNs6X4JXnjV+LKM/m3MydnTbtOKIjtz6VhCBq4vSm3ncdrD2lk0VgUXSVKjVDJXJzijW1RQdsU7F77He8u68koNZTz8Oz5yGa6J3H3lZ0xYgXBK2QymlWWA+RWnYhskLBv2vmE+hBMCtbA7KX5drWyRT/2JsqZ2IvfB9Y4bWDNMFbJRFmC9E74SoS0CqulwjkC0+5bpcV1CZ8NMej4pjy0U+doDQsGyo1hzVJttIjhQ7GnBtRFN1UarUlH8F3xict+HY07rEzoUGPlWcjRFRr4/gChZgc3ZL2d8oAAAAASUVORK5CYII=") !important; +} +#toast-container.toast-top-center > div, +#toast-container.toast-bottom-center > div { + width: 300px; + margin: auto; +} +#toast-container.toast-top-full-width > div, +#toast-container.toast-bottom-full-width > div { + width: 96%; + margin: auto; +} +.toast { + background-color: #030303; +} +.toast-success { + background-color: #51a351; +} +.toast-error { + background-color: #bd362f; +} +.toast-info { + background-color: #2f96b4; +} +.toast-warning { + background-color: #f89406; +} +.toast-progress { + position: absolute; + left: 0; + bottom: 0; + height: 4px; + background-color: #000000; + opacity: 0.4; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=40); + filter: alpha(opacity=40); +} +/*Responsive Design*/ +@media all and (max-width: 240px) { + #toast-container > div { + padding: 8px 8px 8px 50px; + width: 11em; + } + #toast-container .toast-close-button { + right: -0.2em; + top: -0.2em; + } +} +@media all and (min-width: 241px) and (max-width: 480px) { + #toast-container > div { + padding: 8px 8px 8px 50px; + width: 18em; + } + #toast-container .toast-close-button { + right: -0.2em; + top: -0.2em; + } +} +@media all and (min-width: 481px) and (max-width: 768px) { + #toast-container > div { + padding: 15px 15px 15px 50px; + width: 25em; + } +} diff --git a/node_modules/toastr/package/toastr.js b/node_modules/toastr/package/toastr.js new file mode 100644 index 0000000..9be91ee --- /dev/null +++ b/node_modules/toastr/package/toastr.js @@ -0,0 +1,415 @@ +/* + * Toastr + * Copyright 2012-2015 + * Authors: John Papa, Hans Fjällemark, and Tim Ferrell. + * All Rights Reserved. + * Use, reproduction, distribution, and modification of this code is subject to the terms and + * conditions of the MIT license, available at http://www.opensource.org/licenses/mit-license.php + * + * ARIA Support: Greta Krafsig + * + * Project: https://github.com/CodeSeven/toastr + */ +/* global define */ +; (function (define) { + define(['jquery'], function ($) { + return (function () { + var $container; + var listener; + var toastId = 0; + var toastType = { + error: 'error', + info: 'info', + success: 'success', + warning: 'warning' + }; + + var toastr = { + clear: clear, + remove: remove, + error: error, + getContainer: getContainer, + info: info, + options: {}, + subscribe: subscribe, + success: success, + version: '2.1.1', + warning: warning + }; + + var previousToast; + + return toastr; + + //////////////// + + function error(message, title, optionsOverride) { + return notify({ + type: toastType.error, + iconClass: getOptions().iconClasses.error, + message: message, + optionsOverride: optionsOverride, + title: title + }); + } + + function getContainer(options, create) { + if (!options) { options = getOptions(); } + $container = $('#' + options.containerId); + if ($container.length) { + return $container; + } + if (create) { + $container = createContainer(options); + } + return $container; + } + + function info(message, title, optionsOverride) { + return notify({ + type: toastType.info, + iconClass: getOptions().iconClasses.info, + message: message, + optionsOverride: optionsOverride, + title: title + }); + } + + function subscribe(callback) { + listener = callback; + } + + function success(message, title, optionsOverride) { + return notify({ + type: toastType.success, + iconClass: getOptions().iconClasses.success, + message: message, + optionsOverride: optionsOverride, + title: title + }); + } + + function warning(message, title, optionsOverride) { + return notify({ + type: toastType.warning, + iconClass: getOptions().iconClasses.warning, + message: message, + optionsOverride: optionsOverride, + title: title + }); + } + + function clear($toastElement, clearOptions) { + var options = getOptions(); + if (!$container) { getContainer(options); } + if (!clearToast($toastElement, options, clearOptions)) { + clearContainer(options); + } + } + + function remove($toastElement) { + var options = getOptions(); + if (!$container) { getContainer(options); } + if ($toastElement && $(':focus', $toastElement).length === 0) { + removeToast($toastElement); + return; + } + if ($container.children().length) { + $container.remove(); + } + } + + // internal functions + + function clearContainer (options) { + var toastsToClear = $container.children(); + for (var i = toastsToClear.length - 1; i >= 0; i--) { + clearToast($(toastsToClear[i]), options); + } + } + + function clearToast ($toastElement, options, clearOptions) { + var force = clearOptions && clearOptions.force ? clearOptions.force : false; + if ($toastElement && (force || $(':focus', $toastElement).length === 0)) { + $toastElement[options.hideMethod]({ + duration: options.hideDuration, + easing: options.hideEasing, + complete: function () { removeToast($toastElement); } + }); + return true; + } + return false; + } + + function createContainer(options) { + $container = $('

          ') + .attr('id', options.containerId) + .addClass(options.positionClass) + .attr('aria-live', 'polite') + .attr('role', 'alert'); + + $container.appendTo($(options.target)); + return $container; + } + + function getDefaults() { + return { + tapToDismiss: true, + toastClass: 'toast', + containerId: 'toast-container', + debug: false, + + showMethod: 'fadeIn', //fadeIn, slideDown, and show are built into jQuery + showDuration: 300, + showEasing: 'swing', //swing and linear are built into jQuery + onShown: undefined, + hideMethod: 'fadeOut', + hideDuration: 1000, + hideEasing: 'swing', + onHidden: undefined, + + extendedTimeOut: 1000, + iconClasses: { + error: 'toast-error', + info: 'toast-info', + success: 'toast-success', + warning: 'toast-warning' + }, + iconClass: 'toast-info', + positionClass: 'toast-top-right', + timeOut: 5000, // Set timeOut and extendedTimeOut to 0 to make it sticky + titleClass: 'toast-title', + messageClass: 'toast-message', + target: 'body', + closeHtml: '', + newestOnTop: true, + preventDuplicates: false, + progressBar: false + }; + } + + function publish(args) { + if (!listener) { return; } + listener(args); + } + + function notify(map) { + var options = getOptions(); + var iconClass = map.iconClass || options.iconClass; + + if (typeof (map.optionsOverride) !== 'undefined') { + options = $.extend(options, map.optionsOverride); + iconClass = map.optionsOverride.iconClass || iconClass; + } + + if (shouldExit(options, map)) { return; } + + toastId++; + + $container = getContainer(options, true); + + var intervalId = null; + var $toastElement = $('
          '); + var $titleElement = $('
          '); + var $messageElement = $('
          '); + var $progressElement = $('
          '); + var $closeElement = $(options.closeHtml); + var progressBar = { + intervalId: null, + hideEta: null, + maxHideTime: null + }; + var response = { + toastId: toastId, + state: 'visible', + startTime: new Date(), + options: options, + map: map + }; + + personalizeToast(); + + displayToast(); + + handleEvents(); + + publish(response); + + if (options.debug && console) { + console.log(response); + } + + return $toastElement; + + function personalizeToast() { + setIcon(); + setTitle(); + setMessage(); + setCloseButton(); + setProgressBar(); + setSequence(); + } + + function handleEvents() { + $toastElement.hover(stickAround, delayedHideToast); + if (!options.onclick && options.tapToDismiss) { + $toastElement.click(hideToast); + } + + if (options.closeButton && $closeElement) { + $closeElement.click(function (event) { + if (event.stopPropagation) { + event.stopPropagation(); + } else if (event.cancelBubble !== undefined && event.cancelBubble !== true) { + event.cancelBubble = true; + } + hideToast(true); + }); + } + + if (options.onclick) { + $toastElement.click(function () { + options.onclick(); + hideToast(); + }); + } + } + + function displayToast() { + $toastElement.hide(); + + $toastElement[options.showMethod]( + {duration: options.showDuration, easing: options.showEasing, complete: options.onShown} + ); + + if (options.timeOut > 0) { + intervalId = setTimeout(hideToast, options.timeOut); + progressBar.maxHideTime = parseFloat(options.timeOut); + progressBar.hideEta = new Date().getTime() + progressBar.maxHideTime; + if (options.progressBar) { + progressBar.intervalId = setInterval(updateProgress, 10); + } + } + } + + function setIcon() { + if (map.iconClass) { + $toastElement.addClass(options.toastClass).addClass(iconClass); + } + } + + function setSequence() { + if (options.newestOnTop) { + $container.prepend($toastElement); + } else { + $container.append($toastElement); + } + } + + function setTitle() { + if (map.title) { + $titleElement.append(map.title).addClass(options.titleClass); + $toastElement.append($titleElement); + } + } + + function setMessage() { + if (map.message) { + $messageElement.append(map.message).addClass(options.messageClass); + $toastElement.append($messageElement); + } + } + + function setCloseButton() { + if (options.closeButton) { + $closeElement.addClass('toast-close-button').attr('role', 'button'); + $toastElement.prepend($closeElement); + } + } + + function setProgressBar() { + if (options.progressBar) { + $progressElement.addClass('toast-progress'); + $toastElement.prepend($progressElement); + } + } + + function shouldExit(options, map) { + if (options.preventDuplicates) { + if (map.message === previousToast) { + return true; + } else { + previousToast = map.message; + } + } + return false; + } + + function hideToast(override) { + if ($(':focus', $toastElement).length && !override) { + return; + } + clearTimeout(progressBar.intervalId); + return $toastElement[options.hideMethod]({ + duration: options.hideDuration, + easing: options.hideEasing, + complete: function () { + removeToast($toastElement); + if (options.onHidden && response.state !== 'hidden') { + options.onHidden(); + } + response.state = 'hidden'; + response.endTime = new Date(); + publish(response); + } + }); + } + + function delayedHideToast() { + if (options.timeOut > 0 || options.extendedTimeOut > 0) { + intervalId = setTimeout(hideToast, options.extendedTimeOut); + progressBar.maxHideTime = parseFloat(options.extendedTimeOut); + progressBar.hideEta = new Date().getTime() + progressBar.maxHideTime; + } + } + + function stickAround() { + clearTimeout(intervalId); + progressBar.hideEta = 0; + $toastElement.stop(true, true)[options.showMethod]( + {duration: options.showDuration, easing: options.showEasing} + ); + } + + function updateProgress() { + var percentage = ((progressBar.hideEta - (new Date().getTime())) / progressBar.maxHideTime) * 100; + $progressElement.width(percentage + '%'); + } + } + + function getOptions() { + return $.extend({}, getDefaults(), toastr.options); + } + + function removeToast($toastElement) { + if (!$container) { $container = getContainer(); } + if ($toastElement.is(':visible')) { + return; + } + $toastElement.remove(); + $toastElement = null; + if ($container.children().length === 0) { + $container.remove(); + previousToast = undefined; + } + } + + })(); + }); +}(typeof define === 'function' && define.amd ? define : function (deps, factory) { + if (typeof module !== 'undefined' && module.exports) { //Node + module.exports = factory(require('jquery')); + } else { + window['toastr'] = factory(window['jQuery']); + } +})); diff --git a/node_modules/toastr/package/toastr.less b/node_modules/toastr/package/toastr.less new file mode 100644 index 0000000..c8a8922 --- /dev/null +++ b/node_modules/toastr/package/toastr.less @@ -0,0 +1,264 @@ +// Mix-ins +.borderRadius(@radius) { + -moz-border-radius: @radius; + -webkit-border-radius: @radius; + border-radius: @radius; +} + +.boxShadow(@boxShadow) { + -moz-box-shadow: @boxShadow; + -webkit-box-shadow: @boxShadow; + box-shadow: @boxShadow; +} + +.opacity(@opacity) { + @opacityPercent: @opacity * 100; + opacity: @opacity; + -ms-filter: ~"progid:DXImageTransform.Microsoft.Alpha(Opacity=@{opacityPercent})"; + filter: ~"alpha(opacity=@{opacityPercent})"; +} + +.wordWrap(@wordWrap: break-word) { + -ms-word-wrap: @wordWrap; + word-wrap: @wordWrap; +} + +// Variables +@black: #000000; +@grey: #999999; +@light-grey: #CCCCCC; +@white: #FFFFFF; +@near-black: #030303; +@green: #51A351; +@red: #BD362F; +@blue: #2F96B4; +@orange: #F89406; + +// Styles +.toast-title { + font-weight: bold; +} + +.toast-message { + .wordWrap(); + + a, + label { + color: @white; + } + + a:hover { + color: @light-grey; + text-decoration: none; + } +} + +.toast-close-button { + position: relative; + right: -0.3em; + top: -0.3em; + float: right; + font-size: 20px; + font-weight: bold; + color: @white; + -webkit-text-shadow: 0 1px 0 rgba(255,255,255,1); + text-shadow: 0 1px 0 rgba(255,255,255,1); + .opacity(0.8); + + &:hover, + &:focus { + color: @black; + text-decoration: none; + cursor: pointer; + .opacity(0.4); + } +} + +/*Additional properties for button version + iOS requires the button element instead of an anchor tag. + If you want the anchor version, it requires `href="#"`.*/ +button.toast-close-button { + padding: 0; + cursor: pointer; + background: transparent; + border: 0; + -webkit-appearance: none; +} + +//#endregion + +.toast-top-center { + top: 0; + right: 0; + width: 100%; +} + +.toast-bottom-center { + bottom: 0; + right: 0; + width: 100%; +} + +.toast-top-full-width { + top: 0; + right: 0; + width: 100%; +} + +.toast-bottom-full-width { + bottom: 0; + right: 0; + width: 100%; +} + +.toast-top-left { + top: 12px; + left: 12px; +} + +.toast-top-right { + top: 12px; + right: 12px; +} + +.toast-bottom-right { + right: 12px; + bottom: 12px; +} + +.toast-bottom-left { + bottom: 12px; + left: 12px; +} + +#toast-container { + position: fixed; + z-index: 999999; + // The container should not be clickable. + pointer-events: none; + * { + -moz-box-sizing: border-box; + -webkit-box-sizing: border-box; + box-sizing: border-box; + } + + > div { + position: relative; + // The toast itself should be clickable. + pointer-events: auto; + overflow: hidden; + margin: 0 0 6px; + padding: 15px 15px 15px 50px; + width: 300px; + .borderRadius(3px 3px 3px 3px); + background-position: 15px center; + background-repeat: no-repeat; + .boxShadow(0 0 12px @grey); + color: @white; + .opacity(0.8); + } + + > :hover { + .boxShadow(0 0 12px @black); + .opacity(1); + cursor: pointer; + } + + > .toast-info { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGwSURBVEhLtZa9SgNBEMc9sUxxRcoUKSzSWIhXpFMhhYWFhaBg4yPYiWCXZxBLERsLRS3EQkEfwCKdjWJAwSKCgoKCcudv4O5YLrt7EzgXhiU3/4+b2ckmwVjJSpKkQ6wAi4gwhT+z3wRBcEz0yjSseUTrcRyfsHsXmD0AmbHOC9Ii8VImnuXBPglHpQ5wwSVM7sNnTG7Za4JwDdCjxyAiH3nyA2mtaTJufiDZ5dCaqlItILh1NHatfN5skvjx9Z38m69CgzuXmZgVrPIGE763Jx9qKsRozWYw6xOHdER+nn2KkO+Bb+UV5CBN6WC6QtBgbRVozrahAbmm6HtUsgtPC19tFdxXZYBOfkbmFJ1VaHA1VAHjd0pp70oTZzvR+EVrx2Ygfdsq6eu55BHYR8hlcki+n+kERUFG8BrA0BwjeAv2M8WLQBtcy+SD6fNsmnB3AlBLrgTtVW1c2QN4bVWLATaIS60J2Du5y1TiJgjSBvFVZgTmwCU+dAZFoPxGEEs8nyHC9Bwe2GvEJv2WXZb0vjdyFT4Cxk3e/kIqlOGoVLwwPevpYHT+00T+hWwXDf4AJAOUqWcDhbwAAAAASUVORK5CYII=") !important; + } + + > .toast-error { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAHOSURBVEhLrZa/SgNBEMZzh0WKCClSCKaIYOED+AAKeQQLG8HWztLCImBrYadgIdY+gIKNYkBFSwu7CAoqCgkkoGBI/E28PdbLZmeDLgzZzcx83/zZ2SSXC1j9fr+I1Hq93g2yxH4iwM1vkoBWAdxCmpzTxfkN2RcyZNaHFIkSo10+8kgxkXIURV5HGxTmFuc75B2RfQkpxHG8aAgaAFa0tAHqYFfQ7Iwe2yhODk8+J4C7yAoRTWI3w/4klGRgR4lO7Rpn9+gvMyWp+uxFh8+H+ARlgN1nJuJuQAYvNkEnwGFck18Er4q3egEc/oO+mhLdKgRyhdNFiacC0rlOCbhNVz4H9FnAYgDBvU3QIioZlJFLJtsoHYRDfiZoUyIxqCtRpVlANq0EU4dApjrtgezPFad5S19Wgjkc0hNVnuF4HjVA6C7QrSIbylB+oZe3aHgBsqlNqKYH48jXyJKMuAbiyVJ8KzaB3eRc0pg9VwQ4niFryI68qiOi3AbjwdsfnAtk0bCjTLJKr6mrD9g8iq/S/B81hguOMlQTnVyG40wAcjnmgsCNESDrjme7wfftP4P7SP4N3CJZdvzoNyGq2c/HWOXJGsvVg+RA/k2MC/wN6I2YA2Pt8GkAAAAASUVORK5CYII=") !important; + } + + > .toast-success { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAADsSURBVEhLY2AYBfQMgf///3P8+/evAIgvA/FsIF+BavYDDWMBGroaSMMBiE8VC7AZDrIFaMFnii3AZTjUgsUUWUDA8OdAH6iQbQEhw4HyGsPEcKBXBIC4ARhex4G4BsjmweU1soIFaGg/WtoFZRIZdEvIMhxkCCjXIVsATV6gFGACs4Rsw0EGgIIH3QJYJgHSARQZDrWAB+jawzgs+Q2UO49D7jnRSRGoEFRILcdmEMWGI0cm0JJ2QpYA1RDvcmzJEWhABhD/pqrL0S0CWuABKgnRki9lLseS7g2AlqwHWQSKH4oKLrILpRGhEQCw2LiRUIa4lwAAAABJRU5ErkJggg==") !important; + } + + > .toast-warning { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGYSURBVEhL5ZSvTsNQFMbXZGICMYGYmJhAQIJAICYQPAACiSDB8AiICQQJT4CqQEwgJvYASAQCiZiYmJhAIBATCARJy+9rTsldd8sKu1M0+dLb057v6/lbq/2rK0mS/TRNj9cWNAKPYIJII7gIxCcQ51cvqID+GIEX8ASG4B1bK5gIZFeQfoJdEXOfgX4QAQg7kH2A65yQ87lyxb27sggkAzAuFhbbg1K2kgCkB1bVwyIR9m2L7PRPIhDUIXgGtyKw575yz3lTNs6X4JXnjV+LKM/m3MydnTbtOKIjtz6VhCBq4vSm3ncdrD2lk0VgUXSVKjVDJXJzijW1RQdsU7F77He8u68koNZTz8Oz5yGa6J3H3lZ0xYgXBK2QymlWWA+RWnYhskLBv2vmE+hBMCtbA7KX5drWyRT/2JsqZ2IvfB9Y4bWDNMFbJRFmC9E74SoS0CqulwjkC0+5bpcV1CZ8NMej4pjy0U+doDQsGyo1hzVJttIjhQ7GnBtRFN1UarUlH8F3xict+HY07rEzoUGPlWcjRFRr4/gChZgc3ZL2d8oAAAAASUVORK5CYII=") !important; + } + + /*overrides*/ + &.toast-top-center > div, + &.toast-bottom-center > div { + width: 300px; + margin: auto; + } + + &.toast-top-full-width > div, + &.toast-bottom-full-width > div { + width: 96%; + margin: auto; + } +} + +.toast { + background-color: @near-black; +} + +.toast-success { + background-color: @green; +} + +.toast-error { + background-color: @red; +} + +.toast-info { + background-color: @blue; +} + +.toast-warning { + background-color: @orange; +} + +.toast-progress { + position: absolute; + left: 0; + bottom: 0; + height: 4px; + background-color: @black; + .opacity(0.4); +} + +/*Responsive Design*/ + +@media all and (max-width: 240px) { + #toast-container { + + > div { + padding: 8px 8px 8px 50px; + width: 11em; + } + + & .toast-close-button { + right: -0.2em; + top: -0.2em; + } + } +} + +@media all and (min-width: 241px) and (max-width: 480px) { + #toast-container { + > div { + padding: 8px 8px 8px 50px; + width: 18em; + } + + & .toast-close-button { + right: -0.2em; + top: -0.2em; + } + } +} + +@media all and (min-width: 481px) and (max-width: 768px) { + #toast-container { + > div { + padding: 15px 15px 15px 50px; + width: 25em; + } + } +} diff --git a/node_modules/toastr/package/toastr.scss b/node_modules/toastr/package/toastr.scss new file mode 100644 index 0000000..6380484 --- /dev/null +++ b/node_modules/toastr/package/toastr.scss @@ -0,0 +1,199 @@ +.toast-title { + font-weight: bold; +} +.toast-message { + -ms-word-wrap: break-word; + word-wrap: break-word; +} +.toast-message a, +.toast-message label { + color: #ffffff; +} +.toast-message a:hover { + color: #cccccc; + text-decoration: none; +} +.toast-close-button { + position: relative; + right: -0.3em; + top: -0.3em; + float: right; + font-size: 20px; + font-weight: bold; + color: #ffffff; + -webkit-text-shadow: 0 1px 0 #ffffff; + text-shadow: 0 1px 0 #ffffff; + opacity: 0.8; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=80); + filter: alpha(opacity=80); +} +.toast-close-button:hover, +.toast-close-button:focus { + color: #000000; + text-decoration: none; + cursor: pointer; + opacity: 0.4; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=40); + filter: alpha(opacity=40); +} +/*Additional properties for button version + iOS requires the button element instead of an anchor tag. + If you want the anchor version, it requires `href="#"`.*/ +button.toast-close-button { + padding: 0; + cursor: pointer; + background: transparent; + border: 0; + -webkit-appearance: none; +} +.toast-top-center { + top: 0; + right: 0; + width: 100%; +} +.toast-bottom-center { + bottom: 0; + right: 0; + width: 100%; +} +.toast-top-full-width { + top: 0; + right: 0; + width: 100%; +} +.toast-bottom-full-width { + bottom: 0; + right: 0; + width: 100%; +} +.toast-top-left { + top: 12px; + left: 12px; +} +.toast-top-right { + top: 12px; + right: 12px; +} +.toast-bottom-right { + right: 12px; + bottom: 12px; +} +.toast-bottom-left { + bottom: 12px; + left: 12px; +} +#toast-container { + position: fixed; + z-index: 999999; + /*overrides*/ + +} +#toast-container * { + -moz-box-sizing: border-box; + -webkit-box-sizing: border-box; + box-sizing: border-box; +} +#toast-container > div { + position: relative; + overflow: hidden; + margin: 0 0 6px; + padding: 15px 15px 15px 50px; + width: 300px; + -moz-border-radius: 3px 3px 3px 3px; + -webkit-border-radius: 3px 3px 3px 3px; + border-radius: 3px 3px 3px 3px; + background-position: 15px center; + background-repeat: no-repeat; + -moz-box-shadow: 0 0 12px #999999; + -webkit-box-shadow: 0 0 12px #999999; + box-shadow: 0 0 12px #999999; + color: #ffffff; + opacity: 0.8; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=80); + filter: alpha(opacity=80); +} +#toast-container > :hover { + -moz-box-shadow: 0 0 12px #000000; + -webkit-box-shadow: 0 0 12px #000000; + box-shadow: 0 0 12px #000000; + opacity: 1; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=100); + filter: alpha(opacity=100); + cursor: pointer; +} +#toast-container > .toast-info { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGwSURBVEhLtZa9SgNBEMc9sUxxRcoUKSzSWIhXpFMhhYWFhaBg4yPYiWCXZxBLERsLRS3EQkEfwCKdjWJAwSKCgoKCcudv4O5YLrt7EzgXhiU3/4+b2ckmwVjJSpKkQ6wAi4gwhT+z3wRBcEz0yjSseUTrcRyfsHsXmD0AmbHOC9Ii8VImnuXBPglHpQ5wwSVM7sNnTG7Za4JwDdCjxyAiH3nyA2mtaTJufiDZ5dCaqlItILh1NHatfN5skvjx9Z38m69CgzuXmZgVrPIGE763Jx9qKsRozWYw6xOHdER+nn2KkO+Bb+UV5CBN6WC6QtBgbRVozrahAbmm6HtUsgtPC19tFdxXZYBOfkbmFJ1VaHA1VAHjd0pp70oTZzvR+EVrx2Ygfdsq6eu55BHYR8hlcki+n+kERUFG8BrA0BwjeAv2M8WLQBtcy+SD6fNsmnB3AlBLrgTtVW1c2QN4bVWLATaIS60J2Du5y1TiJgjSBvFVZgTmwCU+dAZFoPxGEEs8nyHC9Bwe2GvEJv2WXZb0vjdyFT4Cxk3e/kIqlOGoVLwwPevpYHT+00T+hWwXDf4AJAOUqWcDhbwAAAAASUVORK5CYII=") !important; +} +#toast-container > .toast-error { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAHOSURBVEhLrZa/SgNBEMZzh0WKCClSCKaIYOED+AAKeQQLG8HWztLCImBrYadgIdY+gIKNYkBFSwu7CAoqCgkkoGBI/E28PdbLZmeDLgzZzcx83/zZ2SSXC1j9fr+I1Hq93g2yxH4iwM1vkoBWAdxCmpzTxfkN2RcyZNaHFIkSo10+8kgxkXIURV5HGxTmFuc75B2RfQkpxHG8aAgaAFa0tAHqYFfQ7Iwe2yhODk8+J4C7yAoRTWI3w/4klGRgR4lO7Rpn9+gvMyWp+uxFh8+H+ARlgN1nJuJuQAYvNkEnwGFck18Er4q3egEc/oO+mhLdKgRyhdNFiacC0rlOCbhNVz4H9FnAYgDBvU3QIioZlJFLJtsoHYRDfiZoUyIxqCtRpVlANq0EU4dApjrtgezPFad5S19Wgjkc0hNVnuF4HjVA6C7QrSIbylB+oZe3aHgBsqlNqKYH48jXyJKMuAbiyVJ8KzaB3eRc0pg9VwQ4niFryI68qiOi3AbjwdsfnAtk0bCjTLJKr6mrD9g8iq/S/B81hguOMlQTnVyG40wAcjnmgsCNESDrjme7wfftP4P7SP4N3CJZdvzoNyGq2c/HWOXJGsvVg+RA/k2MC/wN6I2YA2Pt8GkAAAAASUVORK5CYII=") !important; +} +#toast-container > .toast-success { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAADsSURBVEhLY2AYBfQMgf///3P8+/evAIgvA/FsIF+BavYDDWMBGroaSMMBiE8VC7AZDrIFaMFnii3AZTjUgsUUWUDA8OdAH6iQbQEhw4HyGsPEcKBXBIC4ARhex4G4BsjmweU1soIFaGg/WtoFZRIZdEvIMhxkCCjXIVsATV6gFGACs4Rsw0EGgIIH3QJYJgHSARQZDrWAB+jawzgs+Q2UO49D7jnRSRGoEFRILcdmEMWGI0cm0JJ2QpYA1RDvcmzJEWhABhD/pqrL0S0CWuABKgnRki9lLseS7g2AlqwHWQSKH4oKLrILpRGhEQCw2LiRUIa4lwAAAABJRU5ErkJggg==") !important; +} +#toast-container > .toast-warning { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGYSURBVEhL5ZSvTsNQFMbXZGICMYGYmJhAQIJAICYQPAACiSDB8AiICQQJT4CqQEwgJvYASAQCiZiYmJhAIBATCARJy+9rTsldd8sKu1M0+dLb057v6/lbq/2rK0mS/TRNj9cWNAKPYIJII7gIxCcQ51cvqID+GIEX8ASG4B1bK5gIZFeQfoJdEXOfgX4QAQg7kH2A65yQ87lyxb27sggkAzAuFhbbg1K2kgCkB1bVwyIR9m2L7PRPIhDUIXgGtyKw575yz3lTNs6X4JXnjV+LKM/m3MydnTbtOKIjtz6VhCBq4vSm3ncdrD2lk0VgUXSVKjVDJXJzijW1RQdsU7F77He8u68koNZTz8Oz5yGa6J3H3lZ0xYgXBK2QymlWWA+RWnYhskLBv2vmE+hBMCtbA7KX5drWyRT/2JsqZ2IvfB9Y4bWDNMFbJRFmC9E74SoS0CqulwjkC0+5bpcV1CZ8NMej4pjy0U+doDQsGyo1hzVJttIjhQ7GnBtRFN1UarUlH8F3xict+HY07rEzoUGPlWcjRFRr4/gChZgc3ZL2d8oAAAAASUVORK5CYII=") !important; +} +#toast-container.toast-top-center > div, +#toast-container.toast-bottom-center > div { + width: 300px; + margin: auto; +} +#toast-container.toast-top-full-width > div, +#toast-container.toast-bottom-full-width > div { + width: 96%; + margin: auto; +} +.toast { + background-color: #030303; +} +.toast-success { + background-color: #51a351; +} +.toast-error { + background-color: #bd362f; +} +.toast-info { + background-color: #2f96b4; +} +.toast-warning { + background-color: #f89406; +} + +.toast-progress { + position: absolute; + left: 0; + bottom: 0; + height: 4px; + background-color: #000000; + opacity: 0.4; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=40); + filter: alpha(opacity=40); +} + +/*Responsive Design*/ +@media all and (max-width: 240px) { + #toast-container > div { + padding: 8px 8px 8px 50px; + width: 11em; + } + #toast-container .toast-close-button { + right: -0.2em; + top: -0.2em; + } +} +@media all and (min-width: 241px) and (max-width: 480px) { + #toast-container > div { + padding: 8px 8px 8px 50px; + width: 18em; + } + #toast-container .toast-close-button { + right: -0.2em; + top: -0.2em; + } +} +@media all and (min-width: 481px) and (max-width: 768px) { + #toast-container > div { + padding: 15px 15px 15px 50px; + width: 25em; + } +} diff --git a/node_modules/toastr/release checklist.md b/node_modules/toastr/release checklist.md new file mode 100644 index 0000000..52e5a83 --- /dev/null +++ b/node_modules/toastr/release checklist.md @@ -0,0 +1,32 @@ +Toastr Release Checklist + +1. Update Toastr Version + * toastr.js + * bower.json (toastr-bower repo) + * package.json + * nuget versions and dependency versions + * readme file for github repo + * Consider HotTowel VSIX +2. Gulp + * run main demo + * `gulp analyze` + * `gulp test` + * `gulp` +3. Nuget + * Copy new files in + * Build + * Test +4. CDNJS + * Update CDNJS +5. Update Website with New Downloads +6. Publish Bower + * Include License and Readme + * Test Locally + * Update Github repo toastr-bower + * Github tag + * Register with Bower +7. Publish Nugets +8. Release on Github + * Tag with semver + * Attach all artifacts +9. Blog post \ No newline at end of file diff --git a/node_modules/toastr/tests/qunit/qunit.css b/node_modules/toastr/tests/qunit/qunit.css new file mode 100644 index 0000000..7ba3f9a --- /dev/null +++ b/node_modules/toastr/tests/qunit/qunit.css @@ -0,0 +1,244 @@ +/** + * QUnit v1.12.0 - A JavaScript Unit Testing Framework + * + * http://qunitjs.com + * + * Copyright 2012 jQuery Foundation and other contributors + * Released under the MIT license. + * http://jquery.org/license + */ + +/** Font Family and Sizes */ + +#qunit-tests, #qunit-header, #qunit-banner, #qunit-testrunner-toolbar, #qunit-userAgent, #qunit-testresult { + font-family: "Helvetica Neue Light", "HelveticaNeue-Light", "Helvetica Neue", Calibri, Helvetica, Arial, sans-serif; +} + +#qunit-testrunner-toolbar, #qunit-userAgent, #qunit-testresult, #qunit-tests li { font-size: small; } +#qunit-tests { font-size: smaller; } + + +/** Resets */ + +#qunit-tests, #qunit-header, #qunit-banner, #qunit-userAgent, #qunit-testresult, #qunit-modulefilter { + margin: 0; + padding: 0; +} + + +/** Header */ + +#qunit-header { + padding: 0.5em 0 0.5em 1em; + + color: #8699a4; + background-color: #0d3349; + + font-size: 1.5em; + line-height: 1em; + font-weight: normal; + + border-radius: 5px 5px 0 0; + -moz-border-radius: 5px 5px 0 0; + -webkit-border-top-right-radius: 5px; + -webkit-border-top-left-radius: 5px; +} + +#qunit-header a { + text-decoration: none; + color: #c2ccd1; +} + +#qunit-header a:hover, +#qunit-header a:focus { + color: #fff; +} + +#qunit-testrunner-toolbar label { + display: inline-block; + padding: 0 .5em 0 .1em; +} + +#qunit-banner { + height: 5px; +} + +#qunit-testrunner-toolbar { + padding: 0.5em 0 0.5em 2em; + color: #5E740B; + background-color: #eee; + overflow: hidden; +} + +#qunit-userAgent { + padding: 0.5em 0 0.5em 2.5em; + background-color: #2b81af; + color: #fff; + text-shadow: rgba(0, 0, 0, 0.5) 2px 2px 1px; +} + +#qunit-modulefilter-container { + float: right; +} + +/** Tests: Pass/Fail */ + +#qunit-tests { + list-style-position: inside; +} + +#qunit-tests li { + padding: 0.4em 0.5em 0.4em 2.5em; + border-bottom: 1px solid #fff; + list-style-position: inside; +} + +#qunit-tests.hidepass li.pass, #qunit-tests.hidepass li.running { + display: none; +} + +#qunit-tests li strong { + cursor: pointer; +} + +#qunit-tests li a { + padding: 0.5em; + color: #c2ccd1; + text-decoration: none; +} +#qunit-tests li a:hover, +#qunit-tests li a:focus { + color: #000; +} + +#qunit-tests li .runtime { + float: right; + font-size: smaller; +} + +.qunit-assert-list { + margin-top: 0.5em; + padding: 0.5em; + + background-color: #fff; + + border-radius: 5px; + -moz-border-radius: 5px; + -webkit-border-radius: 5px; +} + +.qunit-collapsed { + display: none; +} + +#qunit-tests table { + border-collapse: collapse; + margin-top: .2em; +} + +#qunit-tests th { + text-align: right; + vertical-align: top; + padding: 0 .5em 0 0; +} + +#qunit-tests td { + vertical-align: top; +} + +#qunit-tests pre { + margin: 0; + white-space: pre-wrap; + word-wrap: break-word; +} + +#qunit-tests del { + background-color: #e0f2be; + color: #374e0c; + text-decoration: none; +} + +#qunit-tests ins { + background-color: #ffcaca; + color: #500; + text-decoration: none; +} + +/*** Test Counts */ + +#qunit-tests b.counts { color: black; } +#qunit-tests b.passed { color: #5E740B; } +#qunit-tests b.failed { color: #710909; } + +#qunit-tests li li { + padding: 5px; + background-color: #fff; + border-bottom: none; + list-style-position: inside; +} + +/*** Passing Styles */ + +#qunit-tests li li.pass { + color: #3c510c; + background-color: #fff; + border-left: 10px solid #C6E746; +} + +#qunit-tests .pass { color: #528CE0; background-color: #D2E0E6; } +#qunit-tests .pass .test-name { color: #366097; } + +#qunit-tests .pass .test-actual, +#qunit-tests .pass .test-expected { color: #999999; } + +#qunit-banner.qunit-pass { background-color: #C6E746; } + +/*** Failing Styles */ + +#qunit-tests li li.fail { + color: #710909; + background-color: #fff; + border-left: 10px solid #EE5757; + white-space: pre; +} + +#qunit-tests > li:last-child { + border-radius: 0 0 5px 5px; + -moz-border-radius: 0 0 5px 5px; + -webkit-border-bottom-right-radius: 5px; + -webkit-border-bottom-left-radius: 5px; +} + +#qunit-tests .fail { color: #000000; background-color: #EE5757; } +#qunit-tests .fail .test-name, +#qunit-tests .fail .module-name { color: #000000; } + +#qunit-tests .fail .test-actual { color: #EE5757; } +#qunit-tests .fail .test-expected { color: green; } + +#qunit-banner.qunit-fail { background-color: #EE5757; } + + +/** Result */ + +#qunit-testresult { + padding: 0.5em 0.5em 0.5em 2.5em; + + color: #2b81af; + background-color: #D2E0E6; + + border-bottom: 1px solid white; +} +#qunit-testresult .module-name { + font-weight: bold; +} + +/** Fixture */ + +#qunit-fixture { + position: absolute; + top: -10000px; + left: -10000px; + width: 1000px; + height: 1000px; +} diff --git a/node_modules/toastr/tests/qunit/qunit.js b/node_modules/toastr/tests/qunit/qunit.js new file mode 100644 index 0000000..84c7390 --- /dev/null +++ b/node_modules/toastr/tests/qunit/qunit.js @@ -0,0 +1,2212 @@ +/** + * QUnit v1.12.0 - A JavaScript Unit Testing Framework + * + * http://qunitjs.com + * + * Copyright 2013 jQuery Foundation and other contributors + * Released under the MIT license. + * https://jquery.org/license/ + */ + +(function( window ) { + +var QUnit, + assert, + config, + onErrorFnPrev, + testId = 0, + fileName = (sourceFromStacktrace( 0 ) || "" ).replace(/(:\d+)+\)?/, "").replace(/.+\//, ""), + toString = Object.prototype.toString, + hasOwn = Object.prototype.hasOwnProperty, + // Keep a local reference to Date (GH-283) + Date = window.Date, + setTimeout = window.setTimeout, + defined = { + setTimeout: typeof window.setTimeout !== "undefined", + sessionStorage: (function() { + var x = "qunit-test-string"; + try { + sessionStorage.setItem( x, x ); + sessionStorage.removeItem( x ); + return true; + } catch( e ) { + return false; + } + }()) + }, + /** + * Provides a normalized error string, correcting an issue + * with IE 7 (and prior) where Error.prototype.toString is + * not properly implemented + * + * Based on http://es5.github.com/#x15.11.4.4 + * + * @param {String|Error} error + * @return {String} error message + */ + errorString = function( error ) { + var name, message, + errorString = error.toString(); + if ( errorString.substring( 0, 7 ) === "[object" ) { + name = error.name ? error.name.toString() : "Error"; + message = error.message ? error.message.toString() : ""; + if ( name && message ) { + return name + ": " + message; + } else if ( name ) { + return name; + } else if ( message ) { + return message; + } else { + return "Error"; + } + } else { + return errorString; + } + }, + /** + * Makes a clone of an object using only Array or Object as base, + * and copies over the own enumerable properties. + * + * @param {Object} obj + * @return {Object} New object with only the own properties (recursively). + */ + objectValues = function( obj ) { + // Grunt 0.3.x uses an older version of jshint that still has jshint/jshint#392. + /*jshint newcap: false */ + var key, val, + vals = QUnit.is( "array", obj ) ? [] : {}; + for ( key in obj ) { + if ( hasOwn.call( obj, key ) ) { + val = obj[key]; + vals[key] = val === Object(val) ? objectValues(val) : val; + } + } + return vals; + }; + +function Test( settings ) { + extend( this, settings ); + this.assertions = []; + this.testNumber = ++Test.count; +} + +Test.count = 0; + +Test.prototype = { + init: function() { + var a, b, li, + tests = id( "qunit-tests" ); + + if ( tests ) { + b = document.createElement( "strong" ); + b.innerHTML = this.nameHtml; + + // `a` initialized at top of scope + a = document.createElement( "a" ); + a.innerHTML = "Rerun"; + a.href = QUnit.url({ testNumber: this.testNumber }); + + li = document.createElement( "li" ); + li.appendChild( b ); + li.appendChild( a ); + li.className = "running"; + li.id = this.id = "qunit-test-output" + testId++; + + tests.appendChild( li ); + } + }, + setup: function() { + if ( + // Emit moduleStart when we're switching from one module to another + this.module !== config.previousModule || + // They could be equal (both undefined) but if the previousModule property doesn't + // yet exist it means this is the first test in a suite that isn't wrapped in a + // module, in which case we'll just emit a moduleStart event for 'undefined'. + // Without this, reporters can get testStart before moduleStart which is a problem. + !hasOwn.call( config, "previousModule" ) + ) { + if ( hasOwn.call( config, "previousModule" ) ) { + runLoggingCallbacks( "moduleDone", QUnit, { + name: config.previousModule, + failed: config.moduleStats.bad, + passed: config.moduleStats.all - config.moduleStats.bad, + total: config.moduleStats.all + }); + } + config.previousModule = this.module; + config.moduleStats = { all: 0, bad: 0 }; + runLoggingCallbacks( "moduleStart", QUnit, { + name: this.module + }); + } + + config.current = this; + + this.testEnvironment = extend({ + setup: function() {}, + teardown: function() {} + }, this.moduleTestEnvironment ); + + this.started = +new Date(); + runLoggingCallbacks( "testStart", QUnit, { + name: this.testName, + module: this.module + }); + + /*jshint camelcase:false */ + + + /** + * Expose the current test environment. + * + * @deprecated since 1.12.0: Use QUnit.config.current.testEnvironment instead. + */ + QUnit.current_testEnvironment = this.testEnvironment; + + /*jshint camelcase:true */ + + if ( !config.pollution ) { + saveGlobal(); + } + if ( config.notrycatch ) { + this.testEnvironment.setup.call( this.testEnvironment, QUnit.assert ); + return; + } + try { + this.testEnvironment.setup.call( this.testEnvironment, QUnit.assert ); + } catch( e ) { + QUnit.pushFailure( "Setup failed on " + this.testName + ": " + ( e.message || e ), extractStacktrace( e, 1 ) ); + } + }, + run: function() { + config.current = this; + + var running = id( "qunit-testresult" ); + + if ( running ) { + running.innerHTML = "Running:
          " + this.nameHtml; + } + + if ( this.async ) { + QUnit.stop(); + } + + this.callbackStarted = +new Date(); + + if ( config.notrycatch ) { + this.callback.call( this.testEnvironment, QUnit.assert ); + this.callbackRuntime = +new Date() - this.callbackStarted; + return; + } + + try { + this.callback.call( this.testEnvironment, QUnit.assert ); + this.callbackRuntime = +new Date() - this.callbackStarted; + } catch( e ) { + this.callbackRuntime = +new Date() - this.callbackStarted; + + QUnit.pushFailure( "Died on test #" + (this.assertions.length + 1) + " " + this.stack + ": " + ( e.message || e ), extractStacktrace( e, 0 ) ); + // else next test will carry the responsibility + saveGlobal(); + + // Restart the tests if they're blocking + if ( config.blocking ) { + QUnit.start(); + } + } + }, + teardown: function() { + config.current = this; + if ( config.notrycatch ) { + if ( typeof this.callbackRuntime === "undefined" ) { + this.callbackRuntime = +new Date() - this.callbackStarted; + } + this.testEnvironment.teardown.call( this.testEnvironment, QUnit.assert ); + return; + } else { + try { + this.testEnvironment.teardown.call( this.testEnvironment, QUnit.assert ); + } catch( e ) { + QUnit.pushFailure( "Teardown failed on " + this.testName + ": " + ( e.message || e ), extractStacktrace( e, 1 ) ); + } + } + checkPollution(); + }, + finish: function() { + config.current = this; + if ( config.requireExpects && this.expected === null ) { + QUnit.pushFailure( "Expected number of assertions to be defined, but expect() was not called.", this.stack ); + } else if ( this.expected !== null && this.expected !== this.assertions.length ) { + QUnit.pushFailure( "Expected " + this.expected + " assertions, but " + this.assertions.length + " were run", this.stack ); + } else if ( this.expected === null && !this.assertions.length ) { + QUnit.pushFailure( "Expected at least one assertion, but none were run - call expect(0) to accept zero assertions.", this.stack ); + } + + var i, assertion, a, b, time, li, ol, + test = this, + good = 0, + bad = 0, + tests = id( "qunit-tests" ); + + this.runtime = +new Date() - this.started; + config.stats.all += this.assertions.length; + config.moduleStats.all += this.assertions.length; + + if ( tests ) { + ol = document.createElement( "ol" ); + ol.className = "qunit-assert-list"; + + for ( i = 0; i < this.assertions.length; i++ ) { + assertion = this.assertions[i]; + + li = document.createElement( "li" ); + li.className = assertion.result ? "pass" : "fail"; + li.innerHTML = assertion.message || ( assertion.result ? "okay" : "failed" ); + ol.appendChild( li ); + + if ( assertion.result ) { + good++; + } else { + bad++; + config.stats.bad++; + config.moduleStats.bad++; + } + } + + // store result when possible + if ( QUnit.config.reorder && defined.sessionStorage ) { + if ( bad ) { + sessionStorage.setItem( "qunit-test-" + this.module + "-" + this.testName, bad ); + } else { + sessionStorage.removeItem( "qunit-test-" + this.module + "-" + this.testName ); + } + } + + if ( bad === 0 ) { + addClass( ol, "qunit-collapsed" ); + } + + // `b` initialized at top of scope + b = document.createElement( "strong" ); + b.innerHTML = this.nameHtml + " (" + bad + ", " + good + ", " + this.assertions.length + ")"; + + addEvent(b, "click", function() { + var next = b.parentNode.lastChild, + collapsed = hasClass( next, "qunit-collapsed" ); + ( collapsed ? removeClass : addClass )( next, "qunit-collapsed" ); + }); + + addEvent(b, "dblclick", function( e ) { + var target = e && e.target ? e.target : window.event.srcElement; + if ( target.nodeName.toLowerCase() === "span" || target.nodeName.toLowerCase() === "b" ) { + target = target.parentNode; + } + if ( window.location && target.nodeName.toLowerCase() === "strong" ) { + window.location = QUnit.url({ testNumber: test.testNumber }); + } + }); + + // `time` initialized at top of scope + time = document.createElement( "span" ); + time.className = "runtime"; + time.innerHTML = this.runtime + " ms"; + + // `li` initialized at top of scope + li = id( this.id ); + li.className = bad ? "fail" : "pass"; + li.removeChild( li.firstChild ); + a = li.firstChild; + li.appendChild( b ); + li.appendChild( a ); + li.appendChild( time ); + li.appendChild( ol ); + + } else { + for ( i = 0; i < this.assertions.length; i++ ) { + if ( !this.assertions[i].result ) { + bad++; + config.stats.bad++; + config.moduleStats.bad++; + } + } + } + + runLoggingCallbacks( "testDone", QUnit, { + name: this.testName, + module: this.module, + failed: bad, + passed: this.assertions.length - bad, + total: this.assertions.length, + duration: this.runtime + }); + + QUnit.reset(); + + config.current = undefined; + }, + + queue: function() { + var bad, + test = this; + + synchronize(function() { + test.init(); + }); + function run() { + // each of these can by async + synchronize(function() { + test.setup(); + }); + synchronize(function() { + test.run(); + }); + synchronize(function() { + test.teardown(); + }); + synchronize(function() { + test.finish(); + }); + } + + // `bad` initialized at top of scope + // defer when previous test run passed, if storage is available + bad = QUnit.config.reorder && defined.sessionStorage && + +sessionStorage.getItem( "qunit-test-" + this.module + "-" + this.testName ); + + if ( bad ) { + run(); + } else { + synchronize( run, true ); + } + } +}; + +// Root QUnit object. +// `QUnit` initialized at top of scope +QUnit = { + + // call on start of module test to prepend name to all tests + module: function( name, testEnvironment ) { + config.currentModule = name; + config.currentModuleTestEnvironment = testEnvironment; + config.modules[name] = true; + }, + + asyncTest: function( testName, expected, callback ) { + if ( arguments.length === 2 ) { + callback = expected; + expected = null; + } + + QUnit.test( testName, expected, callback, true ); + }, + + test: function( testName, expected, callback, async ) { + var test, + nameHtml = "" + escapeText( testName ) + ""; + + if ( arguments.length === 2 ) { + callback = expected; + expected = null; + } + + if ( config.currentModule ) { + nameHtml = "" + escapeText( config.currentModule ) + ": " + nameHtml; + } + + test = new Test({ + nameHtml: nameHtml, + testName: testName, + expected: expected, + async: async, + callback: callback, + module: config.currentModule, + moduleTestEnvironment: config.currentModuleTestEnvironment, + stack: sourceFromStacktrace( 2 ) + }); + + if ( !validTest( test ) ) { + return; + } + + test.queue(); + }, + + // Specify the number of expected assertions to guarantee that failed test (no assertions are run at all) don't slip through. + expect: function( asserts ) { + if (arguments.length === 1) { + config.current.expected = asserts; + } else { + return config.current.expected; + } + }, + + start: function( count ) { + // QUnit hasn't been initialized yet. + // Note: RequireJS (et al) may delay onLoad + if ( config.semaphore === undefined ) { + QUnit.begin(function() { + // This is triggered at the top of QUnit.load, push start() to the event loop, to allow QUnit.load to finish first + setTimeout(function() { + QUnit.start( count ); + }); + }); + return; + } + + config.semaphore -= count || 1; + // don't start until equal number of stop-calls + if ( config.semaphore > 0 ) { + return; + } + // ignore if start is called more often then stop + if ( config.semaphore < 0 ) { + config.semaphore = 0; + QUnit.pushFailure( "Called start() while already started (QUnit.config.semaphore was 0 already)", null, sourceFromStacktrace(2) ); + return; + } + // A slight delay, to avoid any current callbacks + if ( defined.setTimeout ) { + setTimeout(function() { + if ( config.semaphore > 0 ) { + return; + } + if ( config.timeout ) { + clearTimeout( config.timeout ); + } + + config.blocking = false; + process( true ); + }, 13); + } else { + config.blocking = false; + process( true ); + } + }, + + stop: function( count ) { + config.semaphore += count || 1; + config.blocking = true; + + if ( config.testTimeout && defined.setTimeout ) { + clearTimeout( config.timeout ); + config.timeout = setTimeout(function() { + QUnit.ok( false, "Test timed out" ); + config.semaphore = 1; + QUnit.start(); + }, config.testTimeout ); + } + } +}; + +// `assert` initialized at top of scope +// Assert helpers +// All of these must either call QUnit.push() or manually do: +// - runLoggingCallbacks( "log", .. ); +// - config.current.assertions.push({ .. }); +// We attach it to the QUnit object *after* we expose the public API, +// otherwise `assert` will become a global variable in browsers (#341). +assert = { + /** + * Asserts rough true-ish result. + * @name ok + * @function + * @example ok( "asdfasdf".length > 5, "There must be at least 5 chars" ); + */ + ok: function( result, msg ) { + if ( !config.current ) { + throw new Error( "ok() assertion outside test context, was " + sourceFromStacktrace(2) ); + } + result = !!result; + msg = msg || (result ? "okay" : "failed" ); + + var source, + details = { + module: config.current.module, + name: config.current.testName, + result: result, + message: msg + }; + + msg = "" + escapeText( msg ) + ""; + + if ( !result ) { + source = sourceFromStacktrace( 2 ); + if ( source ) { + details.source = source; + msg += "
          Source:
          " + escapeText( source ) + "
          "; + } + } + runLoggingCallbacks( "log", QUnit, details ); + config.current.assertions.push({ + result: result, + message: msg + }); + }, + + /** + * Assert that the first two arguments are equal, with an optional message. + * Prints out both actual and expected values. + * @name equal + * @function + * @example equal( format( "Received {0} bytes.", 2), "Received 2 bytes.", "format() replaces {0} with next argument" ); + */ + equal: function( actual, expected, message ) { + /*jshint eqeqeq:false */ + QUnit.push( expected == actual, actual, expected, message ); + }, + + /** + * @name notEqual + * @function + */ + notEqual: function( actual, expected, message ) { + /*jshint eqeqeq:false */ + QUnit.push( expected != actual, actual, expected, message ); + }, + + /** + * @name propEqual + * @function + */ + propEqual: function( actual, expected, message ) { + actual = objectValues(actual); + expected = objectValues(expected); + QUnit.push( QUnit.equiv(actual, expected), actual, expected, message ); + }, + + /** + * @name notPropEqual + * @function + */ + notPropEqual: function( actual, expected, message ) { + actual = objectValues(actual); + expected = objectValues(expected); + QUnit.push( !QUnit.equiv(actual, expected), actual, expected, message ); + }, + + /** + * @name deepEqual + * @function + */ + deepEqual: function( actual, expected, message ) { + QUnit.push( QUnit.equiv(actual, expected), actual, expected, message ); + }, + + /** + * @name notDeepEqual + * @function + */ + notDeepEqual: function( actual, expected, message ) { + QUnit.push( !QUnit.equiv(actual, expected), actual, expected, message ); + }, + + /** + * @name strictEqual + * @function + */ + strictEqual: function( actual, expected, message ) { + QUnit.push( expected === actual, actual, expected, message ); + }, + + /** + * @name notStrictEqual + * @function + */ + notStrictEqual: function( actual, expected, message ) { + QUnit.push( expected !== actual, actual, expected, message ); + }, + + "throws": function( block, expected, message ) { + var actual, + expectedOutput = expected, + ok = false; + + // 'expected' is optional + if ( typeof expected === "string" ) { + message = expected; + expected = null; + } + + config.current.ignoreGlobalErrors = true; + try { + block.call( config.current.testEnvironment ); + } catch (e) { + actual = e; + } + config.current.ignoreGlobalErrors = false; + + if ( actual ) { + // we don't want to validate thrown error + if ( !expected ) { + ok = true; + expectedOutput = null; + // expected is a regexp + } else if ( QUnit.objectType( expected ) === "regexp" ) { + ok = expected.test( errorString( actual ) ); + // expected is a constructor + } else if ( actual instanceof expected ) { + ok = true; + // expected is a validation function which returns true is validation passed + } else if ( expected.call( {}, actual ) === true ) { + expectedOutput = null; + ok = true; + } + + QUnit.push( ok, actual, expectedOutput, message ); + } else { + QUnit.pushFailure( message, null, "No exception was thrown." ); + } + } +}; + +/** + * @deprecated since 1.8.0 + * Kept assertion helpers in root for backwards compatibility. + */ +extend( QUnit, assert ); + +/** + * @deprecated since 1.9.0 + * Kept root "raises()" for backwards compatibility. + * (Note that we don't introduce assert.raises). + */ +QUnit.raises = assert[ "throws" ]; + +/** + * @deprecated since 1.0.0, replaced with error pushes since 1.3.0 + * Kept to avoid TypeErrors for undefined methods. + */ +QUnit.equals = function() { + QUnit.push( false, false, false, "QUnit.equals has been deprecated since 2009 (e88049a0), use QUnit.equal instead" ); +}; +QUnit.same = function() { + QUnit.push( false, false, false, "QUnit.same has been deprecated since 2009 (e88049a0), use QUnit.deepEqual instead" ); +}; + +// We want access to the constructor's prototype +(function() { + function F() {} + F.prototype = QUnit; + QUnit = new F(); + // Make F QUnit's constructor so that we can add to the prototype later + QUnit.constructor = F; +}()); + +/** + * Config object: Maintain internal state + * Later exposed as QUnit.config + * `config` initialized at top of scope + */ +config = { + // The queue of tests to run + queue: [], + + // block until document ready + blocking: true, + + // when enabled, show only failing tests + // gets persisted through sessionStorage and can be changed in UI via checkbox + hidepassed: false, + + // by default, run previously failed tests first + // very useful in combination with "Hide passed tests" checked + reorder: true, + + // by default, modify document.title when suite is done + altertitle: true, + + // when enabled, all tests must call expect() + requireExpects: false, + + // add checkboxes that are persisted in the query-string + // when enabled, the id is set to `true` as a `QUnit.config` property + urlConfig: [ + { + id: "noglobals", + label: "Check for Globals", + tooltip: "Enabling this will test if any test introduces new properties on the `window` object. Stored as query-strings." + }, + { + id: "notrycatch", + label: "No try-catch", + tooltip: "Enabling this will run tests outside of a try-catch block. Makes debugging exceptions in IE reasonable. Stored as query-strings." + } + ], + + // Set of all modules. + modules: {}, + + // logging callback queues + begin: [], + done: [], + log: [], + testStart: [], + testDone: [], + moduleStart: [], + moduleDone: [] +}; + +// Export global variables, unless an 'exports' object exists, +// in that case we assume we're in CommonJS (dealt with on the bottom of the script) +if ( typeof exports === "undefined" ) { + extend( window, QUnit.constructor.prototype ); + + // Expose QUnit object + window.QUnit = QUnit; +} + +// Initialize more QUnit.config and QUnit.urlParams +(function() { + var i, + location = window.location || { search: "", protocol: "file:" }, + params = location.search.slice( 1 ).split( "&" ), + length = params.length, + urlParams = {}, + current; + + if ( params[ 0 ] ) { + for ( i = 0; i < length; i++ ) { + current = params[ i ].split( "=" ); + current[ 0 ] = decodeURIComponent( current[ 0 ] ); + // allow just a key to turn on a flag, e.g., test.html?noglobals + current[ 1 ] = current[ 1 ] ? decodeURIComponent( current[ 1 ] ) : true; + urlParams[ current[ 0 ] ] = current[ 1 ]; + } + } + + QUnit.urlParams = urlParams; + + // String search anywhere in moduleName+testName + config.filter = urlParams.filter; + + // Exact match of the module name + config.module = urlParams.module; + + config.testNumber = parseInt( urlParams.testNumber, 10 ) || null; + + // Figure out if we're running the tests from a server or not + QUnit.isLocal = location.protocol === "file:"; +}()); + +// Extend QUnit object, +// these after set here because they should not be exposed as global functions +extend( QUnit, { + assert: assert, + + config: config, + + // Initialize the configuration options + init: function() { + extend( config, { + stats: { all: 0, bad: 0 }, + moduleStats: { all: 0, bad: 0 }, + started: +new Date(), + updateRate: 1000, + blocking: false, + autostart: true, + autorun: false, + filter: "", + queue: [], + semaphore: 1 + }); + + var tests, banner, result, + qunit = id( "qunit" ); + + if ( qunit ) { + qunit.innerHTML = + "

          " + escapeText( document.title ) + "

          " + + "

          " + + "
          " + + "

          " + + "
            "; + } + + tests = id( "qunit-tests" ); + banner = id( "qunit-banner" ); + result = id( "qunit-testresult" ); + + if ( tests ) { + tests.innerHTML = ""; + } + + if ( banner ) { + banner.className = ""; + } + + if ( result ) { + result.parentNode.removeChild( result ); + } + + if ( tests ) { + result = document.createElement( "p" ); + result.id = "qunit-testresult"; + result.className = "result"; + tests.parentNode.insertBefore( result, tests ); + result.innerHTML = "Running...
             "; + } + }, + + // Resets the test setup. Useful for tests that modify the DOM. + /* + DEPRECATED: Use multiple tests instead of resetting inside a test. + Use testStart or testDone for custom cleanup. + This method will throw an error in 2.0, and will be removed in 2.1 + */ + reset: function() { + var fixture = id( "qunit-fixture" ); + if ( fixture ) { + fixture.innerHTML = config.fixture; + } + }, + + // Trigger an event on an element. + // @example triggerEvent( document.body, "click" ); + triggerEvent: function( elem, type, event ) { + if ( document.createEvent ) { + event = document.createEvent( "MouseEvents" ); + event.initMouseEvent(type, true, true, elem.ownerDocument.defaultView, + 0, 0, 0, 0, 0, false, false, false, false, 0, null); + + elem.dispatchEvent( event ); + } else if ( elem.fireEvent ) { + elem.fireEvent( "on" + type ); + } + }, + + // Safe object type checking + is: function( type, obj ) { + return QUnit.objectType( obj ) === type; + }, + + objectType: function( obj ) { + if ( typeof obj === "undefined" ) { + return "undefined"; + // consider: typeof null === object + } + if ( obj === null ) { + return "null"; + } + + var match = toString.call( obj ).match(/^\[object\s(.*)\]$/), + type = match && match[1] || ""; + + switch ( type ) { + case "Number": + if ( isNaN(obj) ) { + return "nan"; + } + return "number"; + case "String": + case "Boolean": + case "Array": + case "Date": + case "RegExp": + case "Function": + return type.toLowerCase(); + } + if ( typeof obj === "object" ) { + return "object"; + } + return undefined; + }, + + push: function( result, actual, expected, message ) { + if ( !config.current ) { + throw new Error( "assertion outside test context, was " + sourceFromStacktrace() ); + } + + var output, source, + details = { + module: config.current.module, + name: config.current.testName, + result: result, + message: message, + actual: actual, + expected: expected + }; + + message = escapeText( message ) || ( result ? "okay" : "failed" ); + message = "" + message + ""; + output = message; + + if ( !result ) { + expected = escapeText( QUnit.jsDump.parse(expected) ); + actual = escapeText( QUnit.jsDump.parse(actual) ); + output += ""; + + if ( actual !== expected ) { + output += ""; + output += ""; + } + + source = sourceFromStacktrace(); + + if ( source ) { + details.source = source; + output += ""; + } + + output += "
            Expected:
            " + expected + "
            Result:
            " + actual + "
            Diff:
            " + QUnit.diff( expected, actual ) + "
            Source:
            " + escapeText( source ) + "
            "; + } + + runLoggingCallbacks( "log", QUnit, details ); + + config.current.assertions.push({ + result: !!result, + message: output + }); + }, + + pushFailure: function( message, source, actual ) { + if ( !config.current ) { + throw new Error( "pushFailure() assertion outside test context, was " + sourceFromStacktrace(2) ); + } + + var output, + details = { + module: config.current.module, + name: config.current.testName, + result: false, + message: message + }; + + message = escapeText( message ) || "error"; + message = "" + message + ""; + output = message; + + output += ""; + + if ( actual ) { + output += ""; + } + + if ( source ) { + details.source = source; + output += ""; + } + + output += "
            Result:
            " + escapeText( actual ) + "
            Source:
            " + escapeText( source ) + "
            "; + + runLoggingCallbacks( "log", QUnit, details ); + + config.current.assertions.push({ + result: false, + message: output + }); + }, + + url: function( params ) { + params = extend( extend( {}, QUnit.urlParams ), params ); + var key, + querystring = "?"; + + for ( key in params ) { + if ( hasOwn.call( params, key ) ) { + querystring += encodeURIComponent( key ) + "=" + + encodeURIComponent( params[ key ] ) + "&"; + } + } + return window.location.protocol + "//" + window.location.host + + window.location.pathname + querystring.slice( 0, -1 ); + }, + + extend: extend, + id: id, + addEvent: addEvent, + addClass: addClass, + hasClass: hasClass, + removeClass: removeClass + // load, equiv, jsDump, diff: Attached later +}); + +/** + * @deprecated: Created for backwards compatibility with test runner that set the hook function + * into QUnit.{hook}, instead of invoking it and passing the hook function. + * QUnit.constructor is set to the empty F() above so that we can add to it's prototype here. + * Doing this allows us to tell if the following methods have been overwritten on the actual + * QUnit object. + */ +extend( QUnit.constructor.prototype, { + + // Logging callbacks; all receive a single argument with the listed properties + // run test/logs.html for any related changes + begin: registerLoggingCallback( "begin" ), + + // done: { failed, passed, total, runtime } + done: registerLoggingCallback( "done" ), + + // log: { result, actual, expected, message } + log: registerLoggingCallback( "log" ), + + // testStart: { name } + testStart: registerLoggingCallback( "testStart" ), + + // testDone: { name, failed, passed, total, duration } + testDone: registerLoggingCallback( "testDone" ), + + // moduleStart: { name } + moduleStart: registerLoggingCallback( "moduleStart" ), + + // moduleDone: { name, failed, passed, total } + moduleDone: registerLoggingCallback( "moduleDone" ) +}); + +if ( typeof document === "undefined" || document.readyState === "complete" ) { + config.autorun = true; +} + +QUnit.load = function() { + runLoggingCallbacks( "begin", QUnit, {} ); + + // Initialize the config, saving the execution queue + var banner, filter, i, label, len, main, ol, toolbar, userAgent, val, + urlConfigCheckboxesContainer, urlConfigCheckboxes, moduleFilter, + numModules = 0, + moduleNames = [], + moduleFilterHtml = "", + urlConfigHtml = "", + oldconfig = extend( {}, config ); + + QUnit.init(); + extend(config, oldconfig); + + config.blocking = false; + + len = config.urlConfig.length; + + for ( i = 0; i < len; i++ ) { + val = config.urlConfig[i]; + if ( typeof val === "string" ) { + val = { + id: val, + label: val, + tooltip: "[no tooltip available]" + }; + } + config[ val.id ] = QUnit.urlParams[ val.id ]; + urlConfigHtml += ""; + } + for ( i in config.modules ) { + if ( config.modules.hasOwnProperty( i ) ) { + moduleNames.push(i); + } + } + numModules = moduleNames.length; + moduleNames.sort( function( a, b ) { + return a.localeCompare( b ); + }); + moduleFilterHtml += ""; + + // `userAgent` initialized at top of scope + userAgent = id( "qunit-userAgent" ); + if ( userAgent ) { + userAgent.innerHTML = navigator.userAgent; + } + + // `banner` initialized at top of scope + banner = id( "qunit-header" ); + if ( banner ) { + banner.innerHTML = "
            " + banner.innerHTML + " "; + } + + // `toolbar` initialized at top of scope + toolbar = id( "qunit-testrunner-toolbar" ); + if ( toolbar ) { + // `filter` initialized at top of scope + filter = document.createElement( "input" ); + filter.type = "checkbox"; + filter.id = "qunit-filter-pass"; + + addEvent( filter, "click", function() { + var tmp, + ol = document.getElementById( "qunit-tests" ); + + if ( filter.checked ) { + ol.className = ol.className + " hidepass"; + } else { + tmp = " " + ol.className.replace( /[\n\t\r]/g, " " ) + " "; + ol.className = tmp.replace( / hidepass /, " " ); + } + if ( defined.sessionStorage ) { + if (filter.checked) { + sessionStorage.setItem( "qunit-filter-passed-tests", "true" ); + } else { + sessionStorage.removeItem( "qunit-filter-passed-tests" ); + } + } + }); + + if ( config.hidepassed || defined.sessionStorage && sessionStorage.getItem( "qunit-filter-passed-tests" ) ) { + filter.checked = true; + // `ol` initialized at top of scope + ol = document.getElementById( "qunit-tests" ); + ol.className = ol.className + " hidepass"; + } + toolbar.appendChild( filter ); + + // `label` initialized at top of scope + label = document.createElement( "label" ); + label.setAttribute( "for", "qunit-filter-pass" ); + label.setAttribute( "title", "Only show tests and assertions that fail. Stored in sessionStorage." ); + label.innerHTML = "Hide passed tests"; + toolbar.appendChild( label ); + + urlConfigCheckboxesContainer = document.createElement("span"); + urlConfigCheckboxesContainer.innerHTML = urlConfigHtml; + urlConfigCheckboxes = urlConfigCheckboxesContainer.getElementsByTagName("input"); + // For oldIE support: + // * Add handlers to the individual elements instead of the container + // * Use "click" instead of "change" + // * Fallback from event.target to event.srcElement + addEvents( urlConfigCheckboxes, "click", function( event ) { + var params = {}, + target = event.target || event.srcElement; + params[ target.name ] = target.checked ? true : undefined; + window.location = QUnit.url( params ); + }); + toolbar.appendChild( urlConfigCheckboxesContainer ); + + if (numModules > 1) { + moduleFilter = document.createElement( "span" ); + moduleFilter.setAttribute( "id", "qunit-modulefilter-container" ); + moduleFilter.innerHTML = moduleFilterHtml; + addEvent( moduleFilter.lastChild, "change", function() { + var selectBox = moduleFilter.getElementsByTagName("select")[0], + selectedModule = decodeURIComponent(selectBox.options[selectBox.selectedIndex].value); + + window.location = QUnit.url({ + module: ( selectedModule === "" ) ? undefined : selectedModule, + // Remove any existing filters + filter: undefined, + testNumber: undefined + }); + }); + toolbar.appendChild(moduleFilter); + } + } + + // `main` initialized at top of scope + main = id( "qunit-fixture" ); + if ( main ) { + config.fixture = main.innerHTML; + } + + if ( config.autostart ) { + QUnit.start(); + } +}; + +addEvent( window, "load", QUnit.load ); + +// `onErrorFnPrev` initialized at top of scope +// Preserve other handlers +onErrorFnPrev = window.onerror; + +// Cover uncaught exceptions +// Returning true will suppress the default browser handler, +// returning false will let it run. +window.onerror = function ( error, filePath, linerNr ) { + var ret = false; + if ( onErrorFnPrev ) { + ret = onErrorFnPrev( error, filePath, linerNr ); + } + + // Treat return value as window.onerror itself does, + // Only do our handling if not suppressed. + if ( ret !== true ) { + if ( QUnit.config.current ) { + if ( QUnit.config.current.ignoreGlobalErrors ) { + return true; + } + QUnit.pushFailure( error, filePath + ":" + linerNr ); + } else { + QUnit.test( "global failure", extend( function() { + QUnit.pushFailure( error, filePath + ":" + linerNr ); + }, { validTest: validTest } ) ); + } + return false; + } + + return ret; +}; + +function done() { + config.autorun = true; + + // Log the last module results + if ( config.currentModule ) { + runLoggingCallbacks( "moduleDone", QUnit, { + name: config.currentModule, + failed: config.moduleStats.bad, + passed: config.moduleStats.all - config.moduleStats.bad, + total: config.moduleStats.all + }); + } + delete config.previousModule; + + var i, key, + banner = id( "qunit-banner" ), + tests = id( "qunit-tests" ), + runtime = +new Date() - config.started, + passed = config.stats.all - config.stats.bad, + html = [ + "Tests completed in ", + runtime, + " milliseconds.
            ", + "", + passed, + " assertions of ", + config.stats.all, + " passed, ", + config.stats.bad, + " failed." + ].join( "" ); + + if ( banner ) { + banner.className = ( config.stats.bad ? "qunit-fail" : "qunit-pass" ); + } + + if ( tests ) { + id( "qunit-testresult" ).innerHTML = html; + } + + if ( config.altertitle && typeof document !== "undefined" && document.title ) { + // show ✖ for good, ✔ for bad suite result in title + // use escape sequences in case file gets loaded with non-utf-8-charset + document.title = [ + ( config.stats.bad ? "\u2716" : "\u2714" ), + document.title.replace( /^[\u2714\u2716] /i, "" ) + ].join( " " ); + } + + // clear own sessionStorage items if all tests passed + if ( config.reorder && defined.sessionStorage && config.stats.bad === 0 ) { + // `key` & `i` initialized at top of scope + for ( i = 0; i < sessionStorage.length; i++ ) { + key = sessionStorage.key( i++ ); + if ( key.indexOf( "qunit-test-" ) === 0 ) { + sessionStorage.removeItem( key ); + } + } + } + + // scroll back to top to show results + if ( window.scrollTo ) { + window.scrollTo(0, 0); + } + + runLoggingCallbacks( "done", QUnit, { + failed: config.stats.bad, + passed: passed, + total: config.stats.all, + runtime: runtime + }); +} + +/** @return Boolean: true if this test should be ran */ +function validTest( test ) { + var include, + filter = config.filter && config.filter.toLowerCase(), + module = config.module && config.module.toLowerCase(), + fullName = (test.module + ": " + test.testName).toLowerCase(); + + // Internally-generated tests are always valid + if ( test.callback && test.callback.validTest === validTest ) { + delete test.callback.validTest; + return true; + } + + if ( config.testNumber ) { + return test.testNumber === config.testNumber; + } + + if ( module && ( !test.module || test.module.toLowerCase() !== module ) ) { + return false; + } + + if ( !filter ) { + return true; + } + + include = filter.charAt( 0 ) !== "!"; + if ( !include ) { + filter = filter.slice( 1 ); + } + + // If the filter matches, we need to honour include + if ( fullName.indexOf( filter ) !== -1 ) { + return include; + } + + // Otherwise, do the opposite + return !include; +} + +// so far supports only Firefox, Chrome and Opera (buggy), Safari (for real exceptions) +// Later Safari and IE10 are supposed to support error.stack as well +// See also https://developer.mozilla.org/en/JavaScript/Reference/Global_Objects/Error/Stack +function extractStacktrace( e, offset ) { + offset = offset === undefined ? 3 : offset; + + var stack, include, i; + + if ( e.stacktrace ) { + // Opera + return e.stacktrace.split( "\n" )[ offset + 3 ]; + } else if ( e.stack ) { + // Firefox, Chrome + stack = e.stack.split( "\n" ); + if (/^error$/i.test( stack[0] ) ) { + stack.shift(); + } + if ( fileName ) { + include = []; + for ( i = offset; i < stack.length; i++ ) { + if ( stack[ i ].indexOf( fileName ) !== -1 ) { + break; + } + include.push( stack[ i ] ); + } + if ( include.length ) { + return include.join( "\n" ); + } + } + return stack[ offset ]; + } else if ( e.sourceURL ) { + // Safari, PhantomJS + // hopefully one day Safari provides actual stacktraces + // exclude useless self-reference for generated Error objects + if ( /qunit.js$/.test( e.sourceURL ) ) { + return; + } + // for actual exceptions, this is useful + return e.sourceURL + ":" + e.line; + } +} +function sourceFromStacktrace( offset ) { + try { + throw new Error(); + } catch ( e ) { + return extractStacktrace( e, offset ); + } +} + +/** + * Escape text for attribute or text content. + */ +function escapeText( s ) { + if ( !s ) { + return ""; + } + s = s + ""; + // Both single quotes and double quotes (for attributes) + return s.replace( /['"<>&]/g, function( s ) { + switch( s ) { + case "'": + return "'"; + case "\"": + return """; + case "<": + return "<"; + case ">": + return ">"; + case "&": + return "&"; + } + }); +} + +function synchronize( callback, last ) { + config.queue.push( callback ); + + if ( config.autorun && !config.blocking ) { + process( last ); + } +} + +function process( last ) { + function next() { + process( last ); + } + var start = new Date().getTime(); + config.depth = config.depth ? config.depth + 1 : 1; + + while ( config.queue.length && !config.blocking ) { + if ( !defined.setTimeout || config.updateRate <= 0 || ( ( new Date().getTime() - start ) < config.updateRate ) ) { + config.queue.shift()(); + } else { + setTimeout( next, 13 ); + break; + } + } + config.depth--; + if ( last && !config.blocking && !config.queue.length && config.depth === 0 ) { + done(); + } +} + +function saveGlobal() { + config.pollution = []; + + if ( config.noglobals ) { + for ( var key in window ) { + if ( hasOwn.call( window, key ) ) { + // in Opera sometimes DOM element ids show up here, ignore them + if ( /^qunit-test-output/.test( key ) ) { + continue; + } + config.pollution.push( key ); + } + } + } +} + +function checkPollution() { + var newGlobals, + deletedGlobals, + old = config.pollution; + + saveGlobal(); + + newGlobals = diff( config.pollution, old ); + if ( newGlobals.length > 0 ) { + QUnit.pushFailure( "Introduced global variable(s): " + newGlobals.join(", ") ); + } + + deletedGlobals = diff( old, config.pollution ); + if ( deletedGlobals.length > 0 ) { + QUnit.pushFailure( "Deleted global variable(s): " + deletedGlobals.join(", ") ); + } +} + +// returns a new Array with the elements that are in a but not in b +function diff( a, b ) { + var i, j, + result = a.slice(); + + for ( i = 0; i < result.length; i++ ) { + for ( j = 0; j < b.length; j++ ) { + if ( result[i] === b[j] ) { + result.splice( i, 1 ); + i--; + break; + } + } + } + return result; +} + +function extend( a, b ) { + for ( var prop in b ) { + if ( hasOwn.call( b, prop ) ) { + // Avoid "Member not found" error in IE8 caused by messing with window.constructor + if ( !( prop === "constructor" && a === window ) ) { + if ( b[ prop ] === undefined ) { + delete a[ prop ]; + } else { + a[ prop ] = b[ prop ]; + } + } + } + } + + return a; +} + +/** + * @param {HTMLElement} elem + * @param {string} type + * @param {Function} fn + */ +function addEvent( elem, type, fn ) { + // Standards-based browsers + if ( elem.addEventListener ) { + elem.addEventListener( type, fn, false ); + // IE + } else { + elem.attachEvent( "on" + type, fn ); + } +} + +/** + * @param {Array|NodeList} elems + * @param {string} type + * @param {Function} fn + */ +function addEvents( elems, type, fn ) { + var i = elems.length; + while ( i-- ) { + addEvent( elems[i], type, fn ); + } +} + +function hasClass( elem, name ) { + return (" " + elem.className + " ").indexOf(" " + name + " ") > -1; +} + +function addClass( elem, name ) { + if ( !hasClass( elem, name ) ) { + elem.className += (elem.className ? " " : "") + name; + } +} + +function removeClass( elem, name ) { + var set = " " + elem.className + " "; + // Class name may appear multiple times + while ( set.indexOf(" " + name + " ") > -1 ) { + set = set.replace(" " + name + " " , " "); + } + // If possible, trim it for prettiness, but not necessarily + elem.className = typeof set.trim === "function" ? set.trim() : set.replace(/^\s+|\s+$/g, ""); +} + +function id( name ) { + return !!( typeof document !== "undefined" && document && document.getElementById ) && + document.getElementById( name ); +} + +function registerLoggingCallback( key ) { + return function( callback ) { + config[key].push( callback ); + }; +} + +// Supports deprecated method of completely overwriting logging callbacks +function runLoggingCallbacks( key, scope, args ) { + var i, callbacks; + if ( QUnit.hasOwnProperty( key ) ) { + QUnit[ key ].call(scope, args ); + } else { + callbacks = config[ key ]; + for ( i = 0; i < callbacks.length; i++ ) { + callbacks[ i ].call( scope, args ); + } + } +} + +// Test for equality any JavaScript type. +// Author: Philippe Rathé +QUnit.equiv = (function() { + + // Call the o related callback with the given arguments. + function bindCallbacks( o, callbacks, args ) { + var prop = QUnit.objectType( o ); + if ( prop ) { + if ( QUnit.objectType( callbacks[ prop ] ) === "function" ) { + return callbacks[ prop ].apply( callbacks, args ); + } else { + return callbacks[ prop ]; // or undefined + } + } + } + + // the real equiv function + var innerEquiv, + // stack to decide between skip/abort functions + callers = [], + // stack to avoiding loops from circular referencing + parents = [], + parentsB = [], + + getProto = Object.getPrototypeOf || function ( obj ) { + /*jshint camelcase:false */ + return obj.__proto__; + }, + callbacks = (function () { + + // for string, boolean, number and null + function useStrictEquality( b, a ) { + /*jshint eqeqeq:false */ + if ( b instanceof a.constructor || a instanceof b.constructor ) { + // to catch short annotation VS 'new' annotation of a + // declaration + // e.g. var i = 1; + // var j = new Number(1); + return a == b; + } else { + return a === b; + } + } + + return { + "string": useStrictEquality, + "boolean": useStrictEquality, + "number": useStrictEquality, + "null": useStrictEquality, + "undefined": useStrictEquality, + + "nan": function( b ) { + return isNaN( b ); + }, + + "date": function( b, a ) { + return QUnit.objectType( b ) === "date" && a.valueOf() === b.valueOf(); + }, + + "regexp": function( b, a ) { + return QUnit.objectType( b ) === "regexp" && + // the regex itself + a.source === b.source && + // and its modifiers + a.global === b.global && + // (gmi) ... + a.ignoreCase === b.ignoreCase && + a.multiline === b.multiline && + a.sticky === b.sticky; + }, + + // - skip when the property is a method of an instance (OOP) + // - abort otherwise, + // initial === would have catch identical references anyway + "function": function() { + var caller = callers[callers.length - 1]; + return caller !== Object && typeof caller !== "undefined"; + }, + + "array": function( b, a ) { + var i, j, len, loop, aCircular, bCircular; + + // b could be an object literal here + if ( QUnit.objectType( b ) !== "array" ) { + return false; + } + + len = a.length; + if ( len !== b.length ) { + // safe and faster + return false; + } + + // track reference to avoid circular references + parents.push( a ); + parentsB.push( b ); + for ( i = 0; i < len; i++ ) { + loop = false; + for ( j = 0; j < parents.length; j++ ) { + aCircular = parents[j] === a[i]; + bCircular = parentsB[j] === b[i]; + if ( aCircular || bCircular ) { + if ( a[i] === b[i] || aCircular && bCircular ) { + loop = true; + } else { + parents.pop(); + parentsB.pop(); + return false; + } + } + } + if ( !loop && !innerEquiv(a[i], b[i]) ) { + parents.pop(); + parentsB.pop(); + return false; + } + } + parents.pop(); + parentsB.pop(); + return true; + }, + + "object": function( b, a ) { + /*jshint forin:false */ + var i, j, loop, aCircular, bCircular, + // Default to true + eq = true, + aProperties = [], + bProperties = []; + + // comparing constructors is more strict than using + // instanceof + if ( a.constructor !== b.constructor ) { + // Allow objects with no prototype to be equivalent to + // objects with Object as their constructor. + if ( !(( getProto(a) === null && getProto(b) === Object.prototype ) || + ( getProto(b) === null && getProto(a) === Object.prototype ) ) ) { + return false; + } + } + + // stack constructor before traversing properties + callers.push( a.constructor ); + + // track reference to avoid circular references + parents.push( a ); + parentsB.push( b ); + + // be strict: don't ensure hasOwnProperty and go deep + for ( i in a ) { + loop = false; + for ( j = 0; j < parents.length; j++ ) { + aCircular = parents[j] === a[i]; + bCircular = parentsB[j] === b[i]; + if ( aCircular || bCircular ) { + if ( a[i] === b[i] || aCircular && bCircular ) { + loop = true; + } else { + eq = false; + break; + } + } + } + aProperties.push(i); + if ( !loop && !innerEquiv(a[i], b[i]) ) { + eq = false; + break; + } + } + + parents.pop(); + parentsB.pop(); + callers.pop(); // unstack, we are done + + for ( i in b ) { + bProperties.push( i ); // collect b's properties + } + + // Ensures identical properties name + return eq && innerEquiv( aProperties.sort(), bProperties.sort() ); + } + }; + }()); + + innerEquiv = function() { // can take multiple arguments + var args = [].slice.apply( arguments ); + if ( args.length < 2 ) { + return true; // end transition + } + + return (function( a, b ) { + if ( a === b ) { + return true; // catch the most you can + } else if ( a === null || b === null || typeof a === "undefined" || + typeof b === "undefined" || + QUnit.objectType(a) !== QUnit.objectType(b) ) { + return false; // don't lose time with error prone cases + } else { + return bindCallbacks(a, callbacks, [ b, a ]); + } + + // apply transition with (1..n) arguments + }( args[0], args[1] ) && innerEquiv.apply( this, args.splice(1, args.length - 1 )) ); + }; + + return innerEquiv; +}()); + +/** + * jsDump Copyright (c) 2008 Ariel Flesler - aflesler(at)gmail(dot)com | + * http://flesler.blogspot.com Licensed under BSD + * (http://www.opensource.org/licenses/bsd-license.php) Date: 5/15/2008 + * + * @projectDescription Advanced and extensible data dumping for Javascript. + * @version 1.0.0 + * @author Ariel Flesler + * @link {http://flesler.blogspot.com/2008/05/jsdump-pretty-dump-of-any-javascript.html} + */ +QUnit.jsDump = (function() { + function quote( str ) { + return "\"" + str.toString().replace( /"/g, "\\\"" ) + "\""; + } + function literal( o ) { + return o + ""; + } + function join( pre, arr, post ) { + var s = jsDump.separator(), + base = jsDump.indent(), + inner = jsDump.indent(1); + if ( arr.join ) { + arr = arr.join( "," + s + inner ); + } + if ( !arr ) { + return pre + post; + } + return [ pre, inner + arr, base + post ].join(s); + } + function array( arr, stack ) { + var i = arr.length, ret = new Array(i); + this.up(); + while ( i-- ) { + ret[i] = this.parse( arr[i] , undefined , stack); + } + this.down(); + return join( "[", ret, "]" ); + } + + var reName = /^function (\w+)/, + jsDump = { + // type is used mostly internally, you can fix a (custom)type in advance + parse: function( obj, type, stack ) { + stack = stack || [ ]; + var inStack, res, + parser = this.parsers[ type || this.typeOf(obj) ]; + + type = typeof parser; + inStack = inArray( obj, stack ); + + if ( inStack !== -1 ) { + return "recursion(" + (inStack - stack.length) + ")"; + } + if ( type === "function" ) { + stack.push( obj ); + res = parser.call( this, obj, stack ); + stack.pop(); + return res; + } + return ( type === "string" ) ? parser : this.parsers.error; + }, + typeOf: function( obj ) { + var type; + if ( obj === null ) { + type = "null"; + } else if ( typeof obj === "undefined" ) { + type = "undefined"; + } else if ( QUnit.is( "regexp", obj) ) { + type = "regexp"; + } else if ( QUnit.is( "date", obj) ) { + type = "date"; + } else if ( QUnit.is( "function", obj) ) { + type = "function"; + } else if ( typeof obj.setInterval !== undefined && typeof obj.document !== "undefined" && typeof obj.nodeType === "undefined" ) { + type = "window"; + } else if ( obj.nodeType === 9 ) { + type = "document"; + } else if ( obj.nodeType ) { + type = "node"; + } else if ( + // native arrays + toString.call( obj ) === "[object Array]" || + // NodeList objects + ( typeof obj.length === "number" && typeof obj.item !== "undefined" && ( obj.length ? obj.item(0) === obj[0] : ( obj.item( 0 ) === null && typeof obj[0] === "undefined" ) ) ) + ) { + type = "array"; + } else if ( obj.constructor === Error.prototype.constructor ) { + type = "error"; + } else { + type = typeof obj; + } + return type; + }, + separator: function() { + return this.multiline ? this.HTML ? "
            " : "\n" : this.HTML ? " " : " "; + }, + // extra can be a number, shortcut for increasing-calling-decreasing + indent: function( extra ) { + if ( !this.multiline ) { + return ""; + } + var chr = this.indentChar; + if ( this.HTML ) { + chr = chr.replace( /\t/g, " " ).replace( / /g, " " ); + } + return new Array( this.depth + ( extra || 0 ) ).join(chr); + }, + up: function( a ) { + this.depth += a || 1; + }, + down: function( a ) { + this.depth -= a || 1; + }, + setParser: function( name, parser ) { + this.parsers[name] = parser; + }, + // The next 3 are exposed so you can use them + quote: quote, + literal: literal, + join: join, + // + depth: 1, + // This is the list of parsers, to modify them, use jsDump.setParser + parsers: { + window: "[Window]", + document: "[Document]", + error: function(error) { + return "Error(\"" + error.message + "\")"; + }, + unknown: "[Unknown]", + "null": "null", + "undefined": "undefined", + "function": function( fn ) { + var ret = "function", + // functions never have name in IE + name = "name" in fn ? fn.name : (reName.exec(fn) || [])[1]; + + if ( name ) { + ret += " " + name; + } + ret += "( "; + + ret = [ ret, QUnit.jsDump.parse( fn, "functionArgs" ), "){" ].join( "" ); + return join( ret, QUnit.jsDump.parse(fn,"functionCode" ), "}" ); + }, + array: array, + nodelist: array, + "arguments": array, + object: function( map, stack ) { + /*jshint forin:false */ + var ret = [ ], keys, key, val, i; + QUnit.jsDump.up(); + keys = []; + for ( key in map ) { + keys.push( key ); + } + keys.sort(); + for ( i = 0; i < keys.length; i++ ) { + key = keys[ i ]; + val = map[ key ]; + ret.push( QUnit.jsDump.parse( key, "key" ) + ": " + QUnit.jsDump.parse( val, undefined, stack ) ); + } + QUnit.jsDump.down(); + return join( "{", ret, "}" ); + }, + node: function( node ) { + var len, i, val, + open = QUnit.jsDump.HTML ? "<" : "<", + close = QUnit.jsDump.HTML ? ">" : ">", + tag = node.nodeName.toLowerCase(), + ret = open + tag, + attrs = node.attributes; + + if ( attrs ) { + for ( i = 0, len = attrs.length; i < len; i++ ) { + val = attrs[i].nodeValue; + // IE6 includes all attributes in .attributes, even ones not explicitly set. + // Those have values like undefined, null, 0, false, "" or "inherit". + if ( val && val !== "inherit" ) { + ret += " " + attrs[i].nodeName + "=" + QUnit.jsDump.parse( val, "attribute" ); + } + } + } + ret += close; + + // Show content of TextNode or CDATASection + if ( node.nodeType === 3 || node.nodeType === 4 ) { + ret += node.nodeValue; + } + + return ret + open + "/" + tag + close; + }, + // function calls it internally, it's the arguments part of the function + functionArgs: function( fn ) { + var args, + l = fn.length; + + if ( !l ) { + return ""; + } + + args = new Array(l); + while ( l-- ) { + // 97 is 'a' + args[l] = String.fromCharCode(97+l); + } + return " " + args.join( ", " ) + " "; + }, + // object calls it internally, the key part of an item in a map + key: quote, + // function calls it internally, it's the content of the function + functionCode: "[code]", + // node calls it internally, it's an html attribute value + attribute: quote, + string: quote, + date: quote, + regexp: literal, + number: literal, + "boolean": literal + }, + // if true, entities are escaped ( <, >, \t, space and \n ) + HTML: false, + // indentation unit + indentChar: " ", + // if true, items in a collection, are separated by a \n, else just a space. + multiline: true + }; + + return jsDump; +}()); + +// from jquery.js +function inArray( elem, array ) { + if ( array.indexOf ) { + return array.indexOf( elem ); + } + + for ( var i = 0, length = array.length; i < length; i++ ) { + if ( array[ i ] === elem ) { + return i; + } + } + + return -1; +} + +/* + * Javascript Diff Algorithm + * By John Resig (http://ejohn.org/) + * Modified by Chu Alan "sprite" + * + * Released under the MIT license. + * + * More Info: + * http://ejohn.org/projects/javascript-diff-algorithm/ + * + * Usage: QUnit.diff(expected, actual) + * + * QUnit.diff( "the quick brown fox jumped over", "the quick fox jumps over" ) == "the quick brown fox jumped jumps over" + */ +QUnit.diff = (function() { + /*jshint eqeqeq:false, eqnull:true */ + function diff( o, n ) { + var i, + ns = {}, + os = {}; + + for ( i = 0; i < n.length; i++ ) { + if ( !hasOwn.call( ns, n[i] ) ) { + ns[ n[i] ] = { + rows: [], + o: null + }; + } + ns[ n[i] ].rows.push( i ); + } + + for ( i = 0; i < o.length; i++ ) { + if ( !hasOwn.call( os, o[i] ) ) { + os[ o[i] ] = { + rows: [], + n: null + }; + } + os[ o[i] ].rows.push( i ); + } + + for ( i in ns ) { + if ( hasOwn.call( ns, i ) ) { + if ( ns[i].rows.length === 1 && hasOwn.call( os, i ) && os[i].rows.length === 1 ) { + n[ ns[i].rows[0] ] = { + text: n[ ns[i].rows[0] ], + row: os[i].rows[0] + }; + o[ os[i].rows[0] ] = { + text: o[ os[i].rows[0] ], + row: ns[i].rows[0] + }; + } + } + } + + for ( i = 0; i < n.length - 1; i++ ) { + if ( n[i].text != null && n[ i + 1 ].text == null && n[i].row + 1 < o.length && o[ n[i].row + 1 ].text == null && + n[ i + 1 ] == o[ n[i].row + 1 ] ) { + + n[ i + 1 ] = { + text: n[ i + 1 ], + row: n[i].row + 1 + }; + o[ n[i].row + 1 ] = { + text: o[ n[i].row + 1 ], + row: i + 1 + }; + } + } + + for ( i = n.length - 1; i > 0; i-- ) { + if ( n[i].text != null && n[ i - 1 ].text == null && n[i].row > 0 && o[ n[i].row - 1 ].text == null && + n[ i - 1 ] == o[ n[i].row - 1 ]) { + + n[ i - 1 ] = { + text: n[ i - 1 ], + row: n[i].row - 1 + }; + o[ n[i].row - 1 ] = { + text: o[ n[i].row - 1 ], + row: i - 1 + }; + } + } + + return { + o: o, + n: n + }; + } + + return function( o, n ) { + o = o.replace( /\s+$/, "" ); + n = n.replace( /\s+$/, "" ); + + var i, pre, + str = "", + out = diff( o === "" ? [] : o.split(/\s+/), n === "" ? [] : n.split(/\s+/) ), + oSpace = o.match(/\s+/g), + nSpace = n.match(/\s+/g); + + if ( oSpace == null ) { + oSpace = [ " " ]; + } + else { + oSpace.push( " " ); + } + + if ( nSpace == null ) { + nSpace = [ " " ]; + } + else { + nSpace.push( " " ); + } + + if ( out.n.length === 0 ) { + for ( i = 0; i < out.o.length; i++ ) { + str += "" + out.o[i] + oSpace[i] + ""; + } + } + else { + if ( out.n[0].text == null ) { + for ( n = 0; n < out.o.length && out.o[n].text == null; n++ ) { + str += "" + out.o[n] + oSpace[n] + ""; + } + } + + for ( i = 0; i < out.n.length; i++ ) { + if (out.n[i].text == null) { + str += "" + out.n[i] + nSpace[i] + ""; + } + else { + // `pre` initialized at top of scope + pre = ""; + + for ( n = out.n[i].row + 1; n < out.o.length && out.o[n].text == null; n++ ) { + pre += "" + out.o[n] + oSpace[n] + ""; + } + str += " " + out.n[i].text + nSpace[i] + pre; + } + } + } + + return str; + }; +}()); + +// for CommonJS environments, export everything +if ( typeof exports !== "undefined" ) { + extend( exports, QUnit.constructor.prototype ); +} + +// get at whatever the global object is, like window in browsers +}( (function() {return this;}.call()) )); diff --git a/node_modules/toastr/tests/toastr-tests.html b/node_modules/toastr/tests/toastr-tests.html new file mode 100644 index 0000000..1fe155b --- /dev/null +++ b/node_modules/toastr/tests/toastr-tests.html @@ -0,0 +1,21 @@ + + + + toastr QUnit Tests + + + + +
            +

            toastr QUnit Tests

            +

            +
            +

            +
              +
              test markup, will be hidden
              + + + + + + diff --git a/node_modules/toastr/tests/unit/qunit-helper.js b/node_modules/toastr/tests/unit/qunit-helper.js new file mode 100644 index 0000000..42ce5e2 --- /dev/null +++ b/node_modules/toastr/tests/unit/qunit-helper.js @@ -0,0 +1,13 @@ +/** + * Hack to expose spec count from QUnit to Karma + */ + +var testCount = 0; +var qunitTest = QUnit.test; +QUnit.test = window.test = function () { + testCount += 1; + qunitTest.apply(this, arguments); +}; +QUnit.begin(function (args) { + args.totalTests = testCount; +}); diff --git a/node_modules/toastr/tests/unit/toastr-tests.js b/node_modules/toastr/tests/unit/toastr-tests.js new file mode 100644 index 0000000..5b06889 --- /dev/null +++ b/node_modules/toastr/tests/unit/toastr-tests.js @@ -0,0 +1,698 @@ +/// +/// +(function () { + var iconClasses = { + error: 'toast-error', + info: 'toast-info', + success: 'toast-success', + warning: 'toast-warning' + }; + var positionClasses = { + topRight: 'toast-top-right', + bottomRight: 'toast-bottom-right', + bottomLeft: 'toast-bottom-left', + topLeft: 'toast-top-left', + topCenter: 'toast-top-center', + bottomCenter: 'toast-bottom-center' + }; + var sampleMsg = 'I don\'t think they really exist'; + var sampleTitle = 'ROUS'; + var selectors = { + container: 'div#toast-container', + toastInfo: 'div#toast-container > div.toast-info', + toastWarning: 'div#toast-container > div.toast-success', + toastError: 'div#toast-container > div.toast-error', + toastSuccess: 'div#toast-container > div.toast-success' + }; + + toastr.options = { + timeOut: 2000, + extendedTimeOut: 0, + fadeOut: 0, + fadeIn: 0, + showDuration: 0, + hideDuration: 0, + debug: false + }; + + var delay = toastr.options.timeOut + 500; + + // 'Clears' must go first + module('clear'); + asyncTest('clear - show 3 toasts, clear the 2nd', 1, function () { + //Arrange + var $toast = []; + $toast[0] = toastr.info(sampleMsg, sampleTitle + '-1'); + $toast[1] = toastr.info(sampleMsg, sampleTitle + '-2'); + $toast[2] = toastr.info(sampleMsg, sampleTitle + '-3'); + var $container = toastr.getContainer(); + //Act + toastr.clear($toast[1]); + //Assert + setTimeout(function () { + //debugger; + //console.log($container.children().length); + ok($container && $container.children().length === 2); + //Teardown + resetContainer(); + start(); + }, 1000); + }); + asyncTest('clear - show 3 toasts, clear all 3, 0 left', 1, function () { + //Arrange + var $toast = []; + $toast[0] = toastr.info(sampleMsg, sampleTitle + '-1'); + $toast[1] = toastr.info(sampleMsg, sampleTitle + '-2'); + $toast[2] = toastr.info(sampleMsg, sampleTitle + '-3'); + var $container = toastr.getContainer(); + //Act + toastr.clear(); + //Assert + setTimeout(function () { + ok($container && $container.children().length === 0); + //Teardown + resetContainer(); + start(); + }, delay); + }); + test('clear - after clear with force option toast with focus disappears', 1, function () { + //Arrange + var $toast; + var msg = sampleMsg + '

              '; + //Act + $toast = toastr.info(msg, sampleTitle + '-1'); + $toast.find('button').focus(); + toastr.clear($toast, { force: true }); + var $container = toastr.getContainer(); + //Assert + ok($container && $container.children().length === 0, 'Focused toast after a clear with force is not visible'); + //Teardown + resetContainer(); + }); + asyncTest('clear and show - show 2 toasts, clear both, then show 1 more', 2, function () { + //Arrange + var $toast = []; + $toast[0] = toastr.info(sampleMsg, sampleTitle + '-1'); + $toast[1] = toastr.info(sampleMsg, sampleTitle + '-2'); + var $container = toastr.getContainer(); + toastr.clear(); + //Act + setTimeout(function () { + $toast[2] = toastr.info(sampleMsg, sampleTitle + '-3-Visible'); + //Assert + equal($toast[2].find('div.toast-title').html(), sampleTitle + '-3-Visible', 'Finds toast after a clear'); + ok($toast[2].is(':visible'), 'Toast after a clear is visible'); + //Teardown + resetContainer(); + start(); + }, delay); + }); + asyncTest('clear and show - clear removes toast container', 2, function () { + //Arrange + var $toast = []; + $toast[0] = toastr.info(sampleMsg, sampleTitle + '-1'); + $toast[1] = toastr.info(sampleMsg, sampleTitle + '-2'); + var $container = toastr.getContainer(); + toastr.clear(); + //Act + setTimeout(function () { + //Assert + equal($(selectors.container).length, 0, 'Toast container does not exist'); + ok(!$toast[1].is(':visible'), 'Toast after a clear is visible'); + //Teardown + resetContainer(); + start(); + }, delay); + }); + asyncTest('clear and show - after clear new toast creates container', 1, function () { + //Arrange + var $toast = []; + $toast[0] = toastr.info(sampleMsg, sampleTitle + '-1'); + $toast[1] = toastr.info(sampleMsg, sampleTitle + '-2'); + var $container = toastr.getContainer(); + toastr.clear(); + //Act + setTimeout(function () { + $toast[2] = toastr.info(sampleMsg, sampleTitle + '-3-Visible'); + //Assert + equal($(selectors.container).find('div.toast-title').html(), sampleTitle + '-3-Visible', 'Finds toast after a clear'); //Teardown + resetContainer(); + start(); + }, delay); + }); + test('clear and show - after clear all toasts new toast still appears', 1, function () { + //Arrange + var $toast = []; + //Act + $toast[0] = toastr.info(sampleMsg, sampleTitle + '-1'); + $toast[1] = toastr.info(sampleMsg, sampleTitle + '-2'); + toastr.clear(); + $toast[2] = toastr.info(sampleMsg, sampleTitle + '-3-Visible'); + //Assert + ok($toast[2].is(':visible'), 'Toast after a clear is visible'); + //Teardown + resetContainer(); + }); + module('info'); + test('info - pass title and message', 3, function () { + //Arrange + //Act + var $toast = toastr.info(sampleMsg, sampleTitle); + //Assert + equal($toast.find('div.toast-title').html(), sampleTitle, 'Sets title'); + equal($toast.find('div.toast-message').html(), sampleMsg, 'Sets message'); + ok($toast.hasClass(iconClasses.info), 'Sets info icon'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + test('info - pass message, but no title', 3, function () { + //Arrange + //Act + var $toast = toastr.info(sampleMsg); + //Assert + equal($toast.find('div.toast-title').length, 0, 'Sets null title'); + equal($toast.find('div.toast-message').html(), sampleMsg, 'Sets message'); + ok($toast.hasClass(iconClasses.info), 'Sets info icon'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + test('info - pass no message nor title', 3, function () { + //Arrange + //Act + var $toast = toastr.info(); //Assert + equal($toast.find('div.toast-title').length, 0, 'Sets null title'); + equal($toast.find('div.toast-message').html(), null, 'Sets message'); + ok($toast.hasClass(iconClasses.info), 'Sets info icon'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + module('warning'); + test('warning - pass message and title', 3, function () { + //Arrange + //Act + var $toast = toastr.warning(sampleMsg, sampleTitle); + //Assert + equal($toast.find('div.toast-title').html(), sampleTitle, 'Sets title'); + equal($toast.find('div.toast-message').html(), sampleMsg, 'Sets message'); + ok($toast.hasClass(iconClasses.warning), 'Sets warning icon'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + test('warning - pass message, but no title', 3, function () { + //Arrange + //Act + var $toast = toastr.warning(sampleMsg); + //Assert + equal($toast.find('div.toast-title').length, 0, 'Sets empty title'); + equal($toast.find('div.toast-message').html(), sampleMsg, 'Sets message'); + ok($toast.hasClass(iconClasses.warning), 'Sets warning icon'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + test('warning - no message nor title', 3, function () { + //Arrange + //Act + var $toast = toastr.warning(''); + //Assert + equal($toast.find('div.toast-title').length, 0, 'Sets null title'); + equal($toast.find('div.toast-message').length, 0, 'Sets empty message'); + ok($toast.hasClass(iconClasses.warning), 'Sets warning icon'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + module('error'); + test('error - pass message and title', 3, function () { + //Arrange + //Act + var $toast = toastr.error(sampleMsg, sampleTitle); + //Assert + equal($toast.find('div.toast-title').html(), sampleTitle, 'Sets title'); + equal($toast.find('div.toast-message').html(), sampleMsg, 'Sets message'); + ok($toast.hasClass(iconClasses.error), 'Sets error icon'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + test('error - pass message, but no title', 3, function () { + //Arrange + //Act + var $toast = toastr.error(sampleMsg); //Assert + equal($toast.find('div.toast-title').length, 0, 'Sets empty title'); + equal($toast.find('div.toast-message').html(), sampleMsg, 'Sets message'); + ok($toast.hasClass(iconClasses.error), 'Sets error icon'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + test('error - no message nor title', 3, function () { + //Arrange + //Act + var $toast = toastr.error(''); + //Assert + equal($toast.find('div.toast-title').length, 0, 'Sets empty title'); + equal($toast.find('div.toast-message').length, 0, 'Sets empty message'); + ok($toast.hasClass(iconClasses.error), 'Sets error icon'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + module('success'); + test('success - pass message and title', 3, function () { + //Arrange + //Act + var $toast = toastr.success(sampleMsg, sampleTitle); + //Assert + equal($toast.find('div.toast-title').html(), sampleTitle, 'Sets title'); + equal($toast.find('div.toast-message').html(), sampleMsg, 'Sets message'); + ok($toast.hasClass(iconClasses.success), 'Sets success icon'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + test('success - pass message, but no title', 3, function () { + //Arrange + //Act + var $toast = toastr.success(sampleMsg); + //Assert + equal($toast.find('div.toast-title').length, 0, 'Sets empty title'); + equal($toast.find('div.toast-message').html(), sampleMsg, 'Sets message'); + ok($toast.hasClass(iconClasses.success), 'Sets success icon'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + test('success - no message nor title', 3, function () { + //Arrange + //Act + var $toast = toastr.success(''); + //Assert + equal($toast.find('div.toast-title').length, 0, 'Sets null title'); + equal($toast.find('div.toast-message').length, 0, 'Sets empty message'); + ok($toast.hasClass(iconClasses.success), 'Sets success icon'); //Teardown + $toast.remove(); + clearContainerChildren(); + }); + + + module('escape html', { + teardown: function () { + toastr.options.escapeHtml = false; + } + }); + test('info - escape html', 2, function () { + //Arrange + toastr.options.escapeHtml = true; + //Act + var $toast = toastr.info('html message', 'html title'); + //Assert + equal($toast.find('div.toast-title').html(), 'html <u>title</u>', 'Title is escaped'); + equal($toast.find('div.toast-message').html(), 'html <strong>message</strong>', 'Message is escaped'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + test('warning - escape html', 2, function () { + //Arrange + toastr.options.escapeHtml = true; + //Act + var $toast = toastr.warning('html message', 'html title'); + //Assert + equal($toast.find('div.toast-title').html(), 'html <u>title</u>', 'Title is escaped'); + equal($toast.find('div.toast-message').html(), 'html <strong>message</strong>', 'Message is escaped'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + test('error - escape html', 2, function () { + //Arrange + toastr.options.escapeHtml = true; + //Act + var $toast = toastr.error('html message', 'html title'); + //Assert + equal($toast.find('div.toast-title').html(), 'html <u>title</u>', 'Title is escaped'); + equal($toast.find('div.toast-message').html(), 'html <strong>message</strong>', 'Message is escaped'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + test('success - escape html', 2, function () { + //Arrange + toastr.options.escapeHtml = true; + //Act + var $toast = toastr.success('html message', 'html title'); + //Assert + equal($toast.find('div.toast-title').html(), 'html <u>title</u>', 'Title is escaped'); + equal($toast.find('div.toast-message').html(), 'html <strong>message</strong>', 'Message is escaped'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + + module('closeButton', { + teardown: function () { + toastr.options.closeButton = false; + } + }); + test('close button disabled', 1, function () { + //Arrange + toastr.options.closeButton = false; + //Act + var $toast = toastr.success(''); + //Assert + equal($toast.find('button.toast-close-button').length, 0, 'close button should not exist with closeButton=false'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + test('close button enabled', 1, function () { + //Arrange + toastr.options.closeButton = true; + //Act + var $toast = toastr.success(''); + //Assert + equal($toast.find('button.toast-close-button').length, 1, 'close button should exist with closeButton=true'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + test('close button has type=button', 1, function () { + //Arrange + toastr.options.closeButton = true; + //Act + var $toast = toastr.success(''); + //Assert + equal($toast.find('button[type="button"].toast-close-button').length, 1, 'close button should have type=button'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + asyncTest('close button duration', 1, function () { + //Arrange + toastr.options.closeButton = true; + toastr.options.closeDuration = 0; + toastr.options.hideDuration = 2000; + var $container = toastr.getContainer(); + //Act + var $toast = toastr.success(''); + $toast.find('button.toast-close-button').click(); + setTimeout(function () { + //Assert + ok($container && $container.children().length === 0, 'close button should support own hide animation'); + //Teardown + toastr.options.hideDuration = 0; + resetContainer(); + start(); + }, 500); + }); + + module('progressBar', { + teardown: function () { + toastr.options.progressBar = false; + } + }); + test('progress bar disabled', 1, function () { + //Arrange + toastr.options.progressBar = false; + //Act + var $toast = toastr.success(''); + //Assert + equal($toast.find('div.toast-progress').length, 0, 'progress bar should not exist with progressBar=false'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + test('progress bar enabled', 1, function () { + //Arrange + toastr.options.progressBar = true; + //Act + var $toast = toastr.success(''); + //Assert + equal($toast.find('div.toast-progress').length, 1, 'progress bar should exist with progressBar=true'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + + module('event'); + asyncTest('event - onShown is executed', 1, function () { + // Arrange + var run = false; + var onShown = function () { run = true; }; + toastr.options.onShown = onShown; + // Act + var $toast = toastr.success(sampleMsg, sampleTitle); + setTimeout(function () { + // Assert + ok(run); + //Teardown + $toast.remove(); + clearContainerChildren(); + start(); + }, delay); + }); + + asyncTest('event - onHidden is executed', 1, function () { + //Arrange + var run = false; + var onHidden = function () { run = true; }; + toastr.options.onHidden = onHidden; + toastr.options.timeOut = 1; + //Act + var $toast = toastr.success(sampleMsg, sampleTitle); + setTimeout(function () { + // Assert + ok(run); //Teardown + $toast.remove(); + clearContainerChildren(); + start(); + }, delay); + }); + + asyncTest('event - onShown and onHidden are both executed', 2, function () { + //Arrange + var onShowRun = false; + var onHideRun = false; + var onShow = function () { onShowRun = true; }; + var onHide = function () { onHideRun = true; }; + toastr.options.onShown = onShow; + toastr.options.onHidden = onHide; + toastr.options.timeOut = 1; + //Act + var $toast = toastr.success(sampleMsg, sampleTitle); + setTimeout(function () { + // Assert + ok(onShowRun); + ok(onHideRun); + //Teardown + $toast.remove(); + clearContainerChildren(); + start(); + }, delay); + }); + + test('event - message appears when no show or hide method functions provided', 1, function () { + //Arrange + //Act + var $toast = toastr.success(sampleMsg, sampleTitle); + //Assert + ok($toast.hasClass(iconClasses.success), 'Sets success icon'); + //Teardown + $toast.remove(); + clearContainerChildren(); + }); + + test('event - prevent duplicate sequential toasts.', 1, function(){ + toastr.options.preventDuplicates = true; + + var $toast = []; + $toast[0] = toastr.info(sampleMsg, sampleTitle); + $toast[1] = toastr.info(sampleMsg, sampleTitle); + $toast[2] = toastr.info(sampleMsg + " 1", sampleTitle); + $toast[3] = toastr.info(sampleMsg, sampleTitle); + var $container = toastr.getContainer(); + + ok($container && $container.children().length === 3); + + clearContainerChildren(); + }); + + test('event - prevent duplicate sequential toasts, but allow previous after clear.', 1, function(){ + toastr.options.preventDuplicates = true; + + var $toast = []; + $toast[0] = toastr.info(sampleMsg, sampleTitle); + $toast[1] = toastr.info(sampleMsg, sampleTitle); + clearContainerChildren(); + $toast[3] = toastr.info(sampleMsg, sampleTitle); + var $container = toastr.getContainer(); + + ok($container && $container.children().length === 1); + + clearContainerChildren(); + }); + + test('event - allow duplicate sequential toasts.', 1, function(){ + toastr.options.preventDuplicates = false; + + var $toast = []; + $toast[0] = toastr.info(sampleMsg, sampleTitle); + $toast[1] = toastr.info(sampleMsg, sampleTitle); + $toast[1] = toastr.info(sampleMsg, sampleTitle); + var $container = toastr.getContainer(); + + ok($container && $container.children().length === 3); + + clearContainerChildren(); + }); + + test('event - allow preventDuplicates option to be overridden.', 1, function() { + var $toast = []; + + $toast[0] = toastr.info(sampleMsg, sampleTitle, { + preventDuplicates: true + }); + $toast[1] = toastr.info(sampleMsg, sampleTitle, { + preventDuplicates: true + }); + $toast[2] = toastr.info(sampleMsg, sampleTitle); + var $container = toastr.getContainer(); + + ok($container && $container.children().length === 2); + clearContainerChildren(); + }); + + module('order of appearance'); + test('Newest toast on top', 1, function () { + //Arrange + resetContainer(); + toastr.options.newestOnTop = true; + //Act + var $first = toastr.success("First toast"); + var $second = toastr.success("Second toast"); + //Assert + var containerHtml = toastr.getContainer().html(); + ok(containerHtml.indexOf("First toast") > containerHtml.indexOf("Second toast"), 'Newest toast is on top'); + //Teardown + $first.remove(); + $second.remove(); + resetContainer(); + }); + + test('Oldest toast on top', 1, function () { + //Arrange + resetContainer(); + toastr.options.newestOnTop = false; + //Act + var $first = toastr.success("First toast"); + var $second = toastr.success("Second toast"); + //Assert + var containerHtml = toastr.getContainer().html(); + ok(containerHtml.indexOf("First toast") < containerHtml.indexOf("Second toast"), 'Oldest toast is on top'); + //Teardown + $first.remove(); + $second.remove(); + resetContainer(); + }); + + // These must go last + module('positioning'); + test('Container - position top-right', 1, function () { + //Arrange + resetContainer(); + toastr.options.positionClass = positionClasses.topRight; + //Act + var $toast = toastr.success(sampleMsg); + var $container = toastr.getContainer(); + //Assert + ok($container.hasClass(positionClasses.topRight), 'Has position top right'); + //Teardown + $toast.remove(); + resetContainer(); + }); + test('Container - position bottom-right', 1, function () { + //Arrange + resetContainer(); + toastr.options.positionClass = positionClasses.bottomRight; + //Act + var $toast = toastr.success(sampleMsg); + var $container = toastr.getContainer(); + //Assert + ok($container.hasClass(positionClasses.bottomRight), 'Has position bottom right'); + //Teardown + $toast.remove(); + resetContainer(); + }); + test('Container - position bottom-left', 1, function () { + //Arrange + resetContainer(); + //$(selectors.container).remove() + toastr.options.positionClass = positionClasses.bottomLeft; + //Act + var $toast = toastr.success(sampleMsg); + var $container = toastr.getContainer(); + //Assert + ok($container.hasClass(positionClasses.bottomLeft), 'Has position bottom left'); + //Teardown + $toast.remove(); + resetContainer(); + }); + test('Container - position top-left', 1, function () { + //Arrange + resetContainer(); + toastr.options.positionClass = positionClasses.topLeft; + //Act + var $toast = toastr.success(sampleMsg); + var $container = toastr.getContainer(); + //Assert + ok($container.hasClass(positionClasses.topLeft), 'Has position top left'); + //Teardown + $toast.remove(); + resetContainer(); + }); + test('Container - position top-center', 1, function () { + //Arrange + resetContainer(); + toastr.options.positionClass = positionClasses.topCenter; + //Act + var $toast = toastr.success(sampleMsg); + var $container = toastr.getContainer(); + //Assert + ok($container.hasClass(positionClasses.topCenter), 'Has position top center'); + //Teardown + $toast.remove(); + resetContainer(); + }); + test('Container - position bottom-center', 1, function () { + //Arrange + resetContainer(); + toastr.options.positionClass = positionClasses.bottomCenter; + //Act + var $toast = toastr.success(sampleMsg); + var $container = toastr.getContainer(); + //Assert + ok($container.hasClass(positionClasses.bottomCenter), 'Has position bottom center'); + //Teardown + $toast.remove(); + resetContainer(); + }); + + function resetContainer() { + var $container = toastr.getContainer(); + if ($container) { + $container.remove(); + } + $(selectors.container).remove(); + clearContainerChildren(); + } + + function clearContainerChildren() { + toastr.clear(); + } + +})(); diff --git a/node_modules/toastr/tests/unit/x.js b/node_modules/toastr/tests/unit/x.js new file mode 100644 index 0000000..b78dd48 --- /dev/null +++ b/node_modules/toastr/tests/unit/x.js @@ -0,0 +1,3 @@ + test('test test', 1, function () { + ok(1 === 1, '1 equals 1'); + }); diff --git a/node_modules/toastr/toastr-icon.png b/node_modules/toastr/toastr-icon.png new file mode 100644 index 0000000000000000000000000000000000000000..040102adcf4c6af6200d4ba7fba296cef0524836 GIT binary patch literal 25510 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 0; i--) { + clearToast($(toastsToClear[i]), options); + } + } + + function clearToast ($toastElement, options, clearOptions) { + var force = clearOptions && clearOptions.force ? clearOptions.force : false; + if ($toastElement && (force || $(':focus', $toastElement).length === 0)) { + $toastElement[options.hideMethod]({ + duration: options.hideDuration, + easing: options.hideEasing, + complete: function () { removeToast($toastElement); } + }); + return true; + } + return false; + } + + function createContainer(options) { + $container = $('
              ') + .attr('id', options.containerId) + .addClass(options.positionClass) + .attr('aria-live', 'polite') + .attr('role', 'alert'); + + $container.appendTo($(options.target)); + return $container; + } + + function getDefaults() { + return { + tapToDismiss: true, + toastClass: 'toast', + containerId: 'toast-container', + debug: false, + + showMethod: 'fadeIn', //fadeIn, slideDown, and show are built into jQuery + showDuration: 300, + showEasing: 'swing', //swing and linear are built into jQuery + onShown: undefined, + hideMethod: 'fadeOut', + hideDuration: 1000, + hideEasing: 'swing', + onHidden: undefined, + closeMethod: false, + closeDuration: false, + closeEasing: false, + + extendedTimeOut: 1000, + iconClasses: { + error: 'toast-error', + info: 'toast-info', + success: 'toast-success', + warning: 'toast-warning' + }, + iconClass: 'toast-info', + positionClass: 'toast-top-right', + timeOut: 5000, // Set timeOut and extendedTimeOut to 0 to make it sticky + titleClass: 'toast-title', + messageClass: 'toast-message', + escapeHtml: false, + target: 'body', + closeHtml: '', + newestOnTop: true, + preventDuplicates: false, + progressBar: false + }; + } + + function publish(args) { + if (!listener) { return; } + listener(args); + } + + function notify(map) { + var options = getOptions(); + var iconClass = map.iconClass || options.iconClass; + + if (typeof (map.optionsOverride) !== 'undefined') { + options = $.extend(options, map.optionsOverride); + iconClass = map.optionsOverride.iconClass || iconClass; + } + + if (shouldExit(options, map)) { return; } + + toastId++; + + $container = getContainer(options, true); + + var intervalId = null; + var $toastElement = $('
              '); + var $titleElement = $('
              '); + var $messageElement = $('
              '); + var $progressElement = $('
              '); + var $closeElement = $(options.closeHtml); + var progressBar = { + intervalId: null, + hideEta: null, + maxHideTime: null + }; + var response = { + toastId: toastId, + state: 'visible', + startTime: new Date(), + options: options, + map: map + }; + + personalizeToast(); + + displayToast(); + + handleEvents(); + + publish(response); + + if (options.debug && console) { + console.log(response); + } + + return $toastElement; + + function escapeHtml(source) { + if (source == null) + source = ""; + + return new String(source) + .replace(/&/g, '&') + .replace(/"/g, '"') + .replace(/'/g, ''') + .replace(//g, '>'); + } + + function personalizeToast() { + setIcon(); + setTitle(); + setMessage(); + setCloseButton(); + setProgressBar(); + setSequence(); + } + + function handleEvents() { + $toastElement.hover(stickAround, delayedHideToast); + if (!options.onclick && options.tapToDismiss) { + $toastElement.click(hideToast); + } + + if (options.closeButton && $closeElement) { + $closeElement.click(function (event) { + if (event.stopPropagation) { + event.stopPropagation(); + } else if (event.cancelBubble !== undefined && event.cancelBubble !== true) { + event.cancelBubble = true; + } + hideToast(true); + }); + } + + if (options.onclick) { + $toastElement.click(function (event) { + options.onclick(event); + hideToast(); + }); + } + } + + function displayToast() { + $toastElement.hide(); + + $toastElement[options.showMethod]( + {duration: options.showDuration, easing: options.showEasing, complete: options.onShown} + ); + + if (options.timeOut > 0) { + intervalId = setTimeout(hideToast, options.timeOut); + progressBar.maxHideTime = parseFloat(options.timeOut); + progressBar.hideEta = new Date().getTime() + progressBar.maxHideTime; + if (options.progressBar) { + progressBar.intervalId = setInterval(updateProgress, 10); + } + } + } + + function setIcon() { + if (map.iconClass) { + $toastElement.addClass(options.toastClass).addClass(iconClass); + } + } + + function setSequence() { + if (options.newestOnTop) { + $container.prepend($toastElement); + } else { + $container.append($toastElement); + } + } + + function setTitle() { + if (map.title) { + $titleElement.append(!options.escapeHtml ? map.title : escapeHtml(map.title)).addClass(options.titleClass); + $toastElement.append($titleElement); + } + } + + function setMessage() { + if (map.message) { + $messageElement.append(!options.escapeHtml ? map.message : escapeHtml(map.message)).addClass(options.messageClass); + $toastElement.append($messageElement); + } + } + + function setCloseButton() { + if (options.closeButton) { + $closeElement.addClass('toast-close-button').attr('role', 'button'); + $toastElement.prepend($closeElement); + } + } + + function setProgressBar() { + if (options.progressBar) { + $progressElement.addClass('toast-progress'); + $toastElement.prepend($progressElement); + } + } + + function shouldExit(options, map) { + if (options.preventDuplicates) { + if (map.message === previousToast) { + return true; + } else { + previousToast = map.message; + } + } + return false; + } + + function hideToast(override) { + var method = override && options.closeMethod !== false ? options.closeMethod : options.hideMethod; + var duration = override && options.closeDuration !== false ? + options.closeDuration : options.hideDuration; + var easing = override && options.closeEasing !== false ? options.closeEasing : options.hideEasing; + if ($(':focus', $toastElement).length && !override) { + return; + } + clearTimeout(progressBar.intervalId); + return $toastElement[method]({ + duration: duration, + easing: easing, + complete: function () { + removeToast($toastElement); + if (options.onHidden && response.state !== 'hidden') { + options.onHidden(); + } + response.state = 'hidden'; + response.endTime = new Date(); + publish(response); + } + }); + } + + function delayedHideToast() { + if (options.timeOut > 0 || options.extendedTimeOut > 0) { + intervalId = setTimeout(hideToast, options.extendedTimeOut); + progressBar.maxHideTime = parseFloat(options.extendedTimeOut); + progressBar.hideEta = new Date().getTime() + progressBar.maxHideTime; + } + } + + function stickAround() { + clearTimeout(intervalId); + progressBar.hideEta = 0; + $toastElement.stop(true, true)[options.showMethod]( + {duration: options.showDuration, easing: options.showEasing} + ); + } + + function updateProgress() { + var percentage = ((progressBar.hideEta - (new Date().getTime())) / progressBar.maxHideTime) * 100; + $progressElement.width(percentage + '%'); + } + } + + function getOptions() { + return $.extend({}, getDefaults(), toastr.options); + } + + function removeToast($toastElement) { + if (!$container) { $container = getContainer(); } + if ($toastElement.is(':visible')) { + return; + } + $toastElement.remove(); + $toastElement = null; + if ($container.children().length === 0) { + $container.remove(); + previousToast = undefined; + } + } + + })(); + }); +}(typeof define === 'function' && define.amd ? define : function (deps, factory) { + if (typeof module !== 'undefined' && module.exports) { //Node + module.exports = factory(require('jquery')); + } else { + window.toastr = factory(window.jQuery); + } +})); diff --git a/node_modules/toastr/toastr.less b/node_modules/toastr/toastr.less new file mode 100644 index 0000000..4f1e7b7 --- /dev/null +++ b/node_modules/toastr/toastr.less @@ -0,0 +1,267 @@ +// Mix-ins +.borderRadius(@radius) { + -moz-border-radius: @radius; + -webkit-border-radius: @radius; + border-radius: @radius; +} + +.boxShadow(@boxShadow) { + -moz-box-shadow: @boxShadow; + -webkit-box-shadow: @boxShadow; + box-shadow: @boxShadow; +} + +.opacity(@opacity) { + @opacityPercent: @opacity * 100; + opacity: @opacity; + -ms-filter: ~"progid:DXImageTransform.Microsoft.Alpha(Opacity=@{opacityPercent})"; + filter: ~"alpha(opacity=@{opacityPercent})"; +} + +.wordWrap(@wordWrap: break-word) { + -ms-word-wrap: @wordWrap; + word-wrap: @wordWrap; +} + +// Variables +@black: #000000; +@grey: #999999; +@light-grey: #CCCCCC; +@white: #FFFFFF; +@near-black: #030303; +@green: #51A351; +@red: #BD362F; +@blue: #2F96B4; +@orange: #F89406; +@default-container-opacity: .8; + +// Styles +.toast-title { + font-weight: bold; +} + +.toast-message { + .wordWrap(); + + a, + label { + color: @white; + } + + a:hover { + color: @light-grey; + text-decoration: none; + } +} + +.toast-close-button { + position: relative; + right: -0.3em; + top: -0.3em; + float: right; + font-size: 20px; + font-weight: bold; + color: @white; + -webkit-text-shadow: 0 1px 0 rgba(255,255,255,1); + text-shadow: 0 1px 0 rgba(255,255,255,1); + .opacity(0.8); + + &:hover, + &:focus { + color: @black; + text-decoration: none; + cursor: pointer; + .opacity(0.4); + } +} + +/*Additional properties for button version + iOS requires the button element instead of an anchor tag. + If you want the anchor version, it requires `href="#"`.*/ +button.toast-close-button { + padding: 0; + cursor: pointer; + background: transparent; + border: 0; + -webkit-appearance: none; +} + +//#endregion + +.toast-top-center { + top: 0; + right: 0; + width: 100%; +} + +.toast-bottom-center { + bottom: 0; + right: 0; + width: 100%; +} + +.toast-top-full-width { + top: 0; + right: 0; + width: 100%; +} + +.toast-bottom-full-width { + bottom: 0; + right: 0; + width: 100%; +} + +.toast-top-left { + top: 12px; + left: 12px; +} + +.toast-top-right { + top: 12px; + right: 12px; +} + +.toast-bottom-right { + right: 12px; + bottom: 12px; +} + +.toast-bottom-left { + bottom: 12px; + left: 12px; +} + +#toast-container { + position: fixed; + z-index: 999999; + // The container should not be clickable. + pointer-events: none; + * { + -moz-box-sizing: border-box; + -webkit-box-sizing: border-box; + box-sizing: border-box; + } + + > div { + position: relative; + // The toast itself should be clickable. + pointer-events: auto; + overflow: hidden; + margin: 0 0 6px; + padding: 15px 15px 15px 50px; + width: 300px; + .borderRadius(3px 3px 3px 3px); + background-position: 15px center; + background-repeat: no-repeat; + .boxShadow(0 0 12px @grey); + color: @white; + .opacity(@default-container-opacity); + } + + > :hover { + .boxShadow(0 0 12px @black); + .opacity(1); + cursor: pointer; + } + + > .toast-info { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGwSURBVEhLtZa9SgNBEMc9sUxxRcoUKSzSWIhXpFMhhYWFhaBg4yPYiWCXZxBLERsLRS3EQkEfwCKdjWJAwSKCgoKCcudv4O5YLrt7EzgXhiU3/4+b2ckmwVjJSpKkQ6wAi4gwhT+z3wRBcEz0yjSseUTrcRyfsHsXmD0AmbHOC9Ii8VImnuXBPglHpQ5wwSVM7sNnTG7Za4JwDdCjxyAiH3nyA2mtaTJufiDZ5dCaqlItILh1NHatfN5skvjx9Z38m69CgzuXmZgVrPIGE763Jx9qKsRozWYw6xOHdER+nn2KkO+Bb+UV5CBN6WC6QtBgbRVozrahAbmm6HtUsgtPC19tFdxXZYBOfkbmFJ1VaHA1VAHjd0pp70oTZzvR+EVrx2Ygfdsq6eu55BHYR8hlcki+n+kERUFG8BrA0BwjeAv2M8WLQBtcy+SD6fNsmnB3AlBLrgTtVW1c2QN4bVWLATaIS60J2Du5y1TiJgjSBvFVZgTmwCU+dAZFoPxGEEs8nyHC9Bwe2GvEJv2WXZb0vjdyFT4Cxk3e/kIqlOGoVLwwPevpYHT+00T+hWwXDf4AJAOUqWcDhbwAAAAASUVORK5CYII=") !important; + } + + > .toast-error { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAHOSURBVEhLrZa/SgNBEMZzh0WKCClSCKaIYOED+AAKeQQLG8HWztLCImBrYadgIdY+gIKNYkBFSwu7CAoqCgkkoGBI/E28PdbLZmeDLgzZzcx83/zZ2SSXC1j9fr+I1Hq93g2yxH4iwM1vkoBWAdxCmpzTxfkN2RcyZNaHFIkSo10+8kgxkXIURV5HGxTmFuc75B2RfQkpxHG8aAgaAFa0tAHqYFfQ7Iwe2yhODk8+J4C7yAoRTWI3w/4klGRgR4lO7Rpn9+gvMyWp+uxFh8+H+ARlgN1nJuJuQAYvNkEnwGFck18Er4q3egEc/oO+mhLdKgRyhdNFiacC0rlOCbhNVz4H9FnAYgDBvU3QIioZlJFLJtsoHYRDfiZoUyIxqCtRpVlANq0EU4dApjrtgezPFad5S19Wgjkc0hNVnuF4HjVA6C7QrSIbylB+oZe3aHgBsqlNqKYH48jXyJKMuAbiyVJ8KzaB3eRc0pg9VwQ4niFryI68qiOi3AbjwdsfnAtk0bCjTLJKr6mrD9g8iq/S/B81hguOMlQTnVyG40wAcjnmgsCNESDrjme7wfftP4P7SP4N3CJZdvzoNyGq2c/HWOXJGsvVg+RA/k2MC/wN6I2YA2Pt8GkAAAAASUVORK5CYII=") !important; + } + + > .toast-success { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAADsSURBVEhLY2AYBfQMgf///3P8+/evAIgvA/FsIF+BavYDDWMBGroaSMMBiE8VC7AZDrIFaMFnii3AZTjUgsUUWUDA8OdAH6iQbQEhw4HyGsPEcKBXBIC4ARhex4G4BsjmweU1soIFaGg/WtoFZRIZdEvIMhxkCCjXIVsATV6gFGACs4Rsw0EGgIIH3QJYJgHSARQZDrWAB+jawzgs+Q2UO49D7jnRSRGoEFRILcdmEMWGI0cm0JJ2QpYA1RDvcmzJEWhABhD/pqrL0S0CWuABKgnRki9lLseS7g2AlqwHWQSKH4oKLrILpRGhEQCw2LiRUIa4lwAAAABJRU5ErkJggg==") !important; + } + + > .toast-warning { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGYSURBVEhL5ZSvTsNQFMbXZGICMYGYmJhAQIJAICYQPAACiSDB8AiICQQJT4CqQEwgJvYASAQCiZiYmJhAIBATCARJy+9rTsldd8sKu1M0+dLb057v6/lbq/2rK0mS/TRNj9cWNAKPYIJII7gIxCcQ51cvqID+GIEX8ASG4B1bK5gIZFeQfoJdEXOfgX4QAQg7kH2A65yQ87lyxb27sggkAzAuFhbbg1K2kgCkB1bVwyIR9m2L7PRPIhDUIXgGtyKw575yz3lTNs6X4JXnjV+LKM/m3MydnTbtOKIjtz6VhCBq4vSm3ncdrD2lk0VgUXSVKjVDJXJzijW1RQdsU7F77He8u68koNZTz8Oz5yGa6J3H3lZ0xYgXBK2QymlWWA+RWnYhskLBv2vmE+hBMCtbA7KX5drWyRT/2JsqZ2IvfB9Y4bWDNMFbJRFmC9E74SoS0CqulwjkC0+5bpcV1CZ8NMej4pjy0U+doDQsGyo1hzVJttIjhQ7GnBtRFN1UarUlH8F3xict+HY07rEzoUGPlWcjRFRr4/gChZgc3ZL2d8oAAAAASUVORK5CYII=") !important; + } + + /*overrides*/ + &.toast-top-center > div, + &.toast-bottom-center > div { + width: 300px; + margin-left: auto; + margin-right: auto; + } + + &.toast-top-full-width > div, + &.toast-bottom-full-width > div { + width: 96%; + margin-left: auto; + margin-right: auto; + } +} + +.toast { + background-color: @near-black; +} + +.toast-success { + background-color: @green; +} + +.toast-error { + background-color: @red; +} + +.toast-info { + background-color: @blue; +} + +.toast-warning { + background-color: @orange; +} + +.toast-progress { + position: absolute; + left: 0; + bottom: 0; + height: 4px; + background-color: @black; + .opacity(0.4); +} + +/*Responsive Design*/ + +@media all and (max-width: 240px) { + #toast-container { + + > div { + padding: 8px 8px 8px 50px; + width: 11em; + } + + & .toast-close-button { + right: -0.2em; + top: -0.2em; + } + } +} + +@media all and (min-width: 241px) and (max-width: 480px) { + #toast-container { + > div { + padding: 8px 8px 8px 50px; + width: 18em; + } + + & .toast-close-button { + right: -0.2em; + top: -0.2em; + } + } +} + +@media all and (min-width: 481px) and (max-width: 768px) { + #toast-container { + > div { + padding: 15px 15px 15px 50px; + width: 25em; + } + } +} diff --git a/node_modules/toastr/toastr.scss b/node_modules/toastr/toastr.scss new file mode 100644 index 0000000..6380484 --- /dev/null +++ b/node_modules/toastr/toastr.scss @@ -0,0 +1,199 @@ +.toast-title { + font-weight: bold; +} +.toast-message { + -ms-word-wrap: break-word; + word-wrap: break-word; +} +.toast-message a, +.toast-message label { + color: #ffffff; +} +.toast-message a:hover { + color: #cccccc; + text-decoration: none; +} +.toast-close-button { + position: relative; + right: -0.3em; + top: -0.3em; + float: right; + font-size: 20px; + font-weight: bold; + color: #ffffff; + -webkit-text-shadow: 0 1px 0 #ffffff; + text-shadow: 0 1px 0 #ffffff; + opacity: 0.8; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=80); + filter: alpha(opacity=80); +} +.toast-close-button:hover, +.toast-close-button:focus { + color: #000000; + text-decoration: none; + cursor: pointer; + opacity: 0.4; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=40); + filter: alpha(opacity=40); +} +/*Additional properties for button version + iOS requires the button element instead of an anchor tag. + If you want the anchor version, it requires `href="#"`.*/ +button.toast-close-button { + padding: 0; + cursor: pointer; + background: transparent; + border: 0; + -webkit-appearance: none; +} +.toast-top-center { + top: 0; + right: 0; + width: 100%; +} +.toast-bottom-center { + bottom: 0; + right: 0; + width: 100%; +} +.toast-top-full-width { + top: 0; + right: 0; + width: 100%; +} +.toast-bottom-full-width { + bottom: 0; + right: 0; + width: 100%; +} +.toast-top-left { + top: 12px; + left: 12px; +} +.toast-top-right { + top: 12px; + right: 12px; +} +.toast-bottom-right { + right: 12px; + bottom: 12px; +} +.toast-bottom-left { + bottom: 12px; + left: 12px; +} +#toast-container { + position: fixed; + z-index: 999999; + /*overrides*/ + +} +#toast-container * { + -moz-box-sizing: border-box; + -webkit-box-sizing: border-box; + box-sizing: border-box; +} +#toast-container > div { + position: relative; + overflow: hidden; + margin: 0 0 6px; + padding: 15px 15px 15px 50px; + width: 300px; + -moz-border-radius: 3px 3px 3px 3px; + -webkit-border-radius: 3px 3px 3px 3px; + border-radius: 3px 3px 3px 3px; + background-position: 15px center; + background-repeat: no-repeat; + -moz-box-shadow: 0 0 12px #999999; + -webkit-box-shadow: 0 0 12px #999999; + box-shadow: 0 0 12px #999999; + color: #ffffff; + opacity: 0.8; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=80); + filter: alpha(opacity=80); +} +#toast-container > :hover { + -moz-box-shadow: 0 0 12px #000000; + -webkit-box-shadow: 0 0 12px #000000; + box-shadow: 0 0 12px #000000; + opacity: 1; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=100); + filter: alpha(opacity=100); + cursor: pointer; +} +#toast-container > .toast-info { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGwSURBVEhLtZa9SgNBEMc9sUxxRcoUKSzSWIhXpFMhhYWFhaBg4yPYiWCXZxBLERsLRS3EQkEfwCKdjWJAwSKCgoKCcudv4O5YLrt7EzgXhiU3/4+b2ckmwVjJSpKkQ6wAi4gwhT+z3wRBcEz0yjSseUTrcRyfsHsXmD0AmbHOC9Ii8VImnuXBPglHpQ5wwSVM7sNnTG7Za4JwDdCjxyAiH3nyA2mtaTJufiDZ5dCaqlItILh1NHatfN5skvjx9Z38m69CgzuXmZgVrPIGE763Jx9qKsRozWYw6xOHdER+nn2KkO+Bb+UV5CBN6WC6QtBgbRVozrahAbmm6HtUsgtPC19tFdxXZYBOfkbmFJ1VaHA1VAHjd0pp70oTZzvR+EVrx2Ygfdsq6eu55BHYR8hlcki+n+kERUFG8BrA0BwjeAv2M8WLQBtcy+SD6fNsmnB3AlBLrgTtVW1c2QN4bVWLATaIS60J2Du5y1TiJgjSBvFVZgTmwCU+dAZFoPxGEEs8nyHC9Bwe2GvEJv2WXZb0vjdyFT4Cxk3e/kIqlOGoVLwwPevpYHT+00T+hWwXDf4AJAOUqWcDhbwAAAAASUVORK5CYII=") !important; +} +#toast-container > .toast-error { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAHOSURBVEhLrZa/SgNBEMZzh0WKCClSCKaIYOED+AAKeQQLG8HWztLCImBrYadgIdY+gIKNYkBFSwu7CAoqCgkkoGBI/E28PdbLZmeDLgzZzcx83/zZ2SSXC1j9fr+I1Hq93g2yxH4iwM1vkoBWAdxCmpzTxfkN2RcyZNaHFIkSo10+8kgxkXIURV5HGxTmFuc75B2RfQkpxHG8aAgaAFa0tAHqYFfQ7Iwe2yhODk8+J4C7yAoRTWI3w/4klGRgR4lO7Rpn9+gvMyWp+uxFh8+H+ARlgN1nJuJuQAYvNkEnwGFck18Er4q3egEc/oO+mhLdKgRyhdNFiacC0rlOCbhNVz4H9FnAYgDBvU3QIioZlJFLJtsoHYRDfiZoUyIxqCtRpVlANq0EU4dApjrtgezPFad5S19Wgjkc0hNVnuF4HjVA6C7QrSIbylB+oZe3aHgBsqlNqKYH48jXyJKMuAbiyVJ8KzaB3eRc0pg9VwQ4niFryI68qiOi3AbjwdsfnAtk0bCjTLJKr6mrD9g8iq/S/B81hguOMlQTnVyG40wAcjnmgsCNESDrjme7wfftP4P7SP4N3CJZdvzoNyGq2c/HWOXJGsvVg+RA/k2MC/wN6I2YA2Pt8GkAAAAASUVORK5CYII=") !important; +} +#toast-container > .toast-success { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAADsSURBVEhLY2AYBfQMgf///3P8+/evAIgvA/FsIF+BavYDDWMBGroaSMMBiE8VC7AZDrIFaMFnii3AZTjUgsUUWUDA8OdAH6iQbQEhw4HyGsPEcKBXBIC4ARhex4G4BsjmweU1soIFaGg/WtoFZRIZdEvIMhxkCCjXIVsATV6gFGACs4Rsw0EGgIIH3QJYJgHSARQZDrWAB+jawzgs+Q2UO49D7jnRSRGoEFRILcdmEMWGI0cm0JJ2QpYA1RDvcmzJEWhABhD/pqrL0S0CWuABKgnRki9lLseS7g2AlqwHWQSKH4oKLrILpRGhEQCw2LiRUIa4lwAAAABJRU5ErkJggg==") !important; +} +#toast-container > .toast-warning { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGYSURBVEhL5ZSvTsNQFMbXZGICMYGYmJhAQIJAICYQPAACiSDB8AiICQQJT4CqQEwgJvYASAQCiZiYmJhAIBATCARJy+9rTsldd8sKu1M0+dLb057v6/lbq/2rK0mS/TRNj9cWNAKPYIJII7gIxCcQ51cvqID+GIEX8ASG4B1bK5gIZFeQfoJdEXOfgX4QAQg7kH2A65yQ87lyxb27sggkAzAuFhbbg1K2kgCkB1bVwyIR9m2L7PRPIhDUIXgGtyKw575yz3lTNs6X4JXnjV+LKM/m3MydnTbtOKIjtz6VhCBq4vSm3ncdrD2lk0VgUXSVKjVDJXJzijW1RQdsU7F77He8u68koNZTz8Oz5yGa6J3H3lZ0xYgXBK2QymlWWA+RWnYhskLBv2vmE+hBMCtbA7KX5drWyRT/2JsqZ2IvfB9Y4bWDNMFbJRFmC9E74SoS0CqulwjkC0+5bpcV1CZ8NMej4pjy0U+doDQsGyo1hzVJttIjhQ7GnBtRFN1UarUlH8F3xict+HY07rEzoUGPlWcjRFRr4/gChZgc3ZL2d8oAAAAASUVORK5CYII=") !important; +} +#toast-container.toast-top-center > div, +#toast-container.toast-bottom-center > div { + width: 300px; + margin: auto; +} +#toast-container.toast-top-full-width > div, +#toast-container.toast-bottom-full-width > div { + width: 96%; + margin: auto; +} +.toast { + background-color: #030303; +} +.toast-success { + background-color: #51a351; +} +.toast-error { + background-color: #bd362f; +} +.toast-info { + background-color: #2f96b4; +} +.toast-warning { + background-color: #f89406; +} + +.toast-progress { + position: absolute; + left: 0; + bottom: 0; + height: 4px; + background-color: #000000; + opacity: 0.4; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=40); + filter: alpha(opacity=40); +} + +/*Responsive Design*/ +@media all and (max-width: 240px) { + #toast-container > div { + padding: 8px 8px 8px 50px; + width: 11em; + } + #toast-container .toast-close-button { + right: -0.2em; + top: -0.2em; + } +} +@media all and (min-width: 241px) and (max-width: 480px) { + #toast-container > div { + padding: 8px 8px 8px 50px; + width: 18em; + } + #toast-container .toast-close-button { + right: -0.2em; + top: -0.2em; + } +} +@media all and (min-width: 481px) and (max-width: 768px) { + #toast-container > div { + padding: 15px 15px 15px 50px; + width: 25em; + } +} diff --git a/package.json b/package.json new file mode 100644 index 0000000..d05dcec --- /dev/null +++ b/package.json @@ -0,0 +1,21 @@ +{ + "name": "Amdoc-RFC", + "version": "0.0.1", + "description": "RFC form from 3rd parties", + "main": "server.js", + "author": "Larry Poon-Amdocs", + "dependencies": { + "body-parser": "^1.4.3", + "express": "^4.13.4", + "method-override": "^2.1.3", + "mongoose": "^4.4.12", + "morgan": "^1.1.1", + "oauth": "*", + "qs": "*", + "cookie-parser": "^1.0.0", + "toastr": "^2.1.2", + "connect-flash" : "^0.1.1", + "bcrypt-nodejs" : "latest", + "express-session": "^1.0.0" + } +} diff --git a/server.js b/server.js new file mode 100644 index 0000000..1b5f255 --- /dev/null +++ b/server.js @@ -0,0 +1,23 @@ +var express = require('express'); +var app = express(); +var morgan = require('morgan'); +var bodyParser = require('body-parser'); +var cookieParser = require('cookie-parser'); +var methodOverride = require('method-override'); +var port = process.env.PORT || 8080; +var session = require('express-session'); +var fs = require('fs'); +// var readableStream = fs.createReadStream(''); +// var writeStream = fs.createWriteStream(''); +// readableStream.setEncoding('utf8'); // input data encode type is unknonw yet +app.set('json spaces', 4); +app.use(exprezss.static(__dirname)); +app.use(cookieParser()); +app.use(bodyParser.urlencoded({'extended': 'true'})); +app.use(bodyParser.json()); +app.use(bodyParser.json({type: 'application/vnd.api+json'})); +app.use(methodOverride('X-HTTP-Method-Override')); + +app.listen(port); +console.log("App listening on port" + port); +//console.log("Linkedin URL:" + proxyhost); From 7b65fcbc4decdf344092687f0fae2201e68c0865 Mon Sep 17 00:00:00 2001 From: Larry Poon Date: Wed, 19 Oct 2016 17:26:22 -0500 Subject: [PATCH 2/9] asdas --- node_modules/.bin/cowsay | 15 + node_modules/.bin/cowsay.cmd | 7 + node_modules/.bin/cowthink | 15 + node_modules/.bin/cowthink.cmd | 7 + node_modules/cowsay/LICENSE | 26 + node_modules/cowsay/cli.js | 74 +++ node_modules/cowsay/cows/beavis.zen.cow | 23 + node_modules/cowsay/cows/bong.cow | 16 + node_modules/cowsay/cows/bud-frogs.cow | 12 + node_modules/cowsay/cows/bunny.cow | 10 + node_modules/cowsay/cows/cheese.cow | 23 + node_modules/cowsay/cows/cower.cow | 14 + node_modules/cowsay/cows/daemon.cow | 24 + node_modules/cowsay/cows/default.cow | 7 + node_modules/cowsay/cows/doge.cow | 26 + node_modules/cowsay/cows/dragon-and-cow.cow | 21 + node_modules/cowsay/cows/dragon.cow | 21 + .../cowsay/cows/elephant-in-snake.cow | 14 + node_modules/cowsay/cows/elephant.cow | 15 + node_modules/cowsay/cows/eyes.cow | 16 + node_modules/cowsay/cows/flaming-sheep.cow | 15 + node_modules/cowsay/cows/ghostbusters.cow | 26 + node_modules/cowsay/cows/goat.cow | 13 + node_modules/cowsay/cows/head-in.cow | 12 + node_modules/cowsay/cows/hedgehog.cow | 10 + node_modules/cowsay/cows/hellokitty.cow | 11 + node_modules/cowsay/cows/kiss.cow | 26 + node_modules/cowsay/cows/kitty.cow | 12 + node_modules/cowsay/cows/koala.cow | 12 + node_modules/cowsay/cows/kosh.cow | 19 + node_modules/cowsay/cows/luke-koala.cow | 15 + node_modules/cowsay/cows/mech-and-cow.cow | 21 + node_modules/cowsay/cows/meow.cow | 15 + node_modules/cowsay/cows/milk.cow | 21 + node_modules/cowsay/cows/moofasa.cow | 14 + node_modules/cowsay/cows/moose.cow | 9 + node_modules/cowsay/cows/mutilated.cow | 10 + node_modules/cowsay/cows/ren.cow | 22 + node_modules/cowsay/cows/satanic.cow | 12 + node_modules/cowsay/cows/sheep.cow | 13 + node_modules/cowsay/cows/skeleton.cow | 15 + node_modules/cowsay/cows/small.cow | 10 + node_modules/cowsay/cows/sodomized.cow | 12 + node_modules/cowsay/cows/squirrel.cow | 13 + node_modules/cowsay/cows/stegosaurus.cow | 19 + node_modules/cowsay/cows/stimpy.cow | 19 + node_modules/cowsay/cows/supermilker.cow | 10 + node_modules/cowsay/cows/surgery.cow | 24 + node_modules/cowsay/cows/telebears.cow | 12 + node_modules/cowsay/cows/turkey.cow | 26 + node_modules/cowsay/cows/turtle.cow | 20 + node_modules/cowsay/cows/tux.cow | 16 + node_modules/cowsay/cows/vader-koala.cow | 16 + node_modules/cowsay/cows/vader.cow | 13 + node_modules/cowsay/cows/www.cow | 10 + node_modules/cowsay/index.js | 22 + node_modules/cowsay/lib/balloon.js | 106 ++++ node_modules/cowsay/lib/cows.js | 36 ++ node_modules/cowsay/lib/faces.js | 47 ++ node_modules/cowsay/lib/replacer.js | 44 ++ .../cowsay/node_modules/get-stdin/index.js | 49 ++ .../node_modules/get-stdin/package.json | 64 +++ .../cowsay/node_modules/get-stdin/readme.md | 44 ++ .../cowsay/node_modules/optimist/.travis.yml | 4 + .../cowsay/node_modules/optimist/LICENSE | 21 + .../node_modules/optimist/example/bool.js | 10 + .../optimist/example/boolean_double.js | 7 + .../optimist/example/boolean_single.js | 7 + .../optimist/example/default_hash.js | 8 + .../optimist/example/default_singles.js | 7 + .../node_modules/optimist/example/divide.js | 8 + .../optimist/example/line_count.js | 20 + .../optimist/example/line_count_options.js | 29 + .../optimist/example/line_count_wrap.js | 29 + .../node_modules/optimist/example/nonopt.js | 4 + .../node_modules/optimist/example/reflect.js | 2 + .../node_modules/optimist/example/short.js | 3 + .../node_modules/optimist/example/string.js | 11 + .../optimist/example/usage-options.js | 19 + .../node_modules/optimist/example/xup.js | 10 + .../cowsay/node_modules/optimist/index.js | 343 ++++++++++++ .../node_modules/minimist/.travis.yml | 4 + .../optimist/node_modules/minimist/LICENSE | 18 + .../node_modules/minimist/example/parse.js | 2 + .../optimist/node_modules/minimist/index.js | 187 +++++++ .../node_modules/minimist/package.json | 67 +++ .../node_modules/minimist/readme.markdown | 73 +++ .../node_modules/minimist/test/bool.js | 119 ++++ .../node_modules/minimist/test/dash.js | 24 + .../minimist/test/default_bool.js | 20 + .../node_modules/minimist/test/dotted.js | 22 + .../node_modules/minimist/test/long.js | 31 ++ .../node_modules/minimist/test/num.js | 36 ++ .../node_modules/minimist/test/parse.js | 197 +++++++ .../minimist/test/parse_modified.js | 9 + .../node_modules/minimist/test/short.js | 67 +++ .../node_modules/minimist/test/whitespace.js | 8 + .../optimist/node_modules/wordwrap/LICENSE | 18 + .../node_modules/wordwrap/README.markdown | 70 +++ .../node_modules/wordwrap/example/center.js | 10 + .../node_modules/wordwrap/example/meat.js | 3 + .../optimist/node_modules/wordwrap/index.js | 76 +++ .../node_modules/wordwrap/package.json | 63 +++ .../node_modules/wordwrap/test/break.js | 30 + .../node_modules/wordwrap/test/idleness.txt | 63 +++ .../node_modules/wordwrap/test/wrap.js | 31 ++ .../cowsay/node_modules/optimist/package.json | 64 +++ .../node_modules/optimist/readme.markdown | 513 ++++++++++++++++++ .../cowsay/node_modules/optimist/test/_.js | 71 +++ .../node_modules/optimist/test/_/argv.js | 2 + .../node_modules/optimist/test/_/bin.js | 3 + .../cowsay/node_modules/optimist/test/dash.js | 31 ++ .../node_modules/optimist/test/parse.js | 446 +++++++++++++++ .../optimist/test/parse_modified.js | 14 + .../node_modules/optimist/test/short.js | 16 + .../node_modules/optimist/test/usage.js | 292 ++++++++++ .../node_modules/optimist/test/whitespace.js | 8 + node_modules/cowsay/package.json | 75 +++ package.json | 1 + server.js | 53 +- 120 files changed, 4716 insertions(+), 4 deletions(-) create mode 100644 node_modules/.bin/cowsay create mode 100644 node_modules/.bin/cowsay.cmd create mode 100644 node_modules/.bin/cowthink create mode 100644 node_modules/.bin/cowthink.cmd create mode 100644 node_modules/cowsay/LICENSE create mode 100644 node_modules/cowsay/cli.js create mode 100644 node_modules/cowsay/cows/beavis.zen.cow create mode 100644 node_modules/cowsay/cows/bong.cow create mode 100644 node_modules/cowsay/cows/bud-frogs.cow create mode 100644 node_modules/cowsay/cows/bunny.cow create mode 100644 node_modules/cowsay/cows/cheese.cow create mode 100644 node_modules/cowsay/cows/cower.cow create mode 100644 node_modules/cowsay/cows/daemon.cow create mode 100644 node_modules/cowsay/cows/default.cow create mode 100644 node_modules/cowsay/cows/doge.cow create mode 100644 node_modules/cowsay/cows/dragon-and-cow.cow create mode 100644 node_modules/cowsay/cows/dragon.cow create mode 100644 node_modules/cowsay/cows/elephant-in-snake.cow create mode 100644 node_modules/cowsay/cows/elephant.cow create mode 100644 node_modules/cowsay/cows/eyes.cow create mode 100644 node_modules/cowsay/cows/flaming-sheep.cow create mode 100644 node_modules/cowsay/cows/ghostbusters.cow create mode 100644 node_modules/cowsay/cows/goat.cow create mode 100644 node_modules/cowsay/cows/head-in.cow create mode 100644 node_modules/cowsay/cows/hedgehog.cow create mode 100644 node_modules/cowsay/cows/hellokitty.cow create mode 100644 node_modules/cowsay/cows/kiss.cow create mode 100644 node_modules/cowsay/cows/kitty.cow create mode 100644 node_modules/cowsay/cows/koala.cow create mode 100644 node_modules/cowsay/cows/kosh.cow create mode 100644 node_modules/cowsay/cows/luke-koala.cow create mode 100644 node_modules/cowsay/cows/mech-and-cow.cow create mode 100644 node_modules/cowsay/cows/meow.cow create mode 100644 node_modules/cowsay/cows/milk.cow create mode 100644 node_modules/cowsay/cows/moofasa.cow create mode 100644 node_modules/cowsay/cows/moose.cow create mode 100644 node_modules/cowsay/cows/mutilated.cow create mode 100644 node_modules/cowsay/cows/ren.cow create mode 100644 node_modules/cowsay/cows/satanic.cow create mode 100644 node_modules/cowsay/cows/sheep.cow create mode 100644 node_modules/cowsay/cows/skeleton.cow create mode 100644 node_modules/cowsay/cows/small.cow create mode 100644 node_modules/cowsay/cows/sodomized.cow create mode 100644 node_modules/cowsay/cows/squirrel.cow create mode 100644 node_modules/cowsay/cows/stegosaurus.cow create mode 100644 node_modules/cowsay/cows/stimpy.cow create mode 100644 node_modules/cowsay/cows/supermilker.cow create mode 100644 node_modules/cowsay/cows/surgery.cow create mode 100644 node_modules/cowsay/cows/telebears.cow create mode 100644 node_modules/cowsay/cows/turkey.cow create mode 100644 node_modules/cowsay/cows/turtle.cow create mode 100644 node_modules/cowsay/cows/tux.cow create mode 100644 node_modules/cowsay/cows/vader-koala.cow create mode 100644 node_modules/cowsay/cows/vader.cow create mode 100644 node_modules/cowsay/cows/www.cow create mode 100644 node_modules/cowsay/index.js create mode 100644 node_modules/cowsay/lib/balloon.js create mode 100644 node_modules/cowsay/lib/cows.js create mode 100644 node_modules/cowsay/lib/faces.js create mode 100644 node_modules/cowsay/lib/replacer.js create mode 100644 node_modules/cowsay/node_modules/get-stdin/index.js create mode 100644 node_modules/cowsay/node_modules/get-stdin/package.json create mode 100644 node_modules/cowsay/node_modules/get-stdin/readme.md create mode 100644 node_modules/cowsay/node_modules/optimist/.travis.yml create mode 100644 node_modules/cowsay/node_modules/optimist/LICENSE create mode 100644 node_modules/cowsay/node_modules/optimist/example/bool.js create mode 100644 node_modules/cowsay/node_modules/optimist/example/boolean_double.js create mode 100644 node_modules/cowsay/node_modules/optimist/example/boolean_single.js create mode 100644 node_modules/cowsay/node_modules/optimist/example/default_hash.js create mode 100644 node_modules/cowsay/node_modules/optimist/example/default_singles.js create mode 100644 node_modules/cowsay/node_modules/optimist/example/divide.js create mode 100644 node_modules/cowsay/node_modules/optimist/example/line_count.js create mode 100644 node_modules/cowsay/node_modules/optimist/example/line_count_options.js create mode 100644 node_modules/cowsay/node_modules/optimist/example/line_count_wrap.js create mode 100644 node_modules/cowsay/node_modules/optimist/example/nonopt.js create mode 100644 node_modules/cowsay/node_modules/optimist/example/reflect.js create mode 100644 node_modules/cowsay/node_modules/optimist/example/short.js create mode 100644 node_modules/cowsay/node_modules/optimist/example/string.js create mode 100644 node_modules/cowsay/node_modules/optimist/example/usage-options.js create mode 100644 node_modules/cowsay/node_modules/optimist/example/xup.js create mode 100644 node_modules/cowsay/node_modules/optimist/index.js create mode 100644 node_modules/cowsay/node_modules/optimist/node_modules/minimist/.travis.yml create mode 100644 node_modules/cowsay/node_modules/optimist/node_modules/minimist/LICENSE create mode 100644 node_modules/cowsay/node_modules/optimist/node_modules/minimist/example/parse.js create mode 100644 node_modules/cowsay/node_modules/optimist/node_modules/minimist/index.js create mode 100644 node_modules/cowsay/node_modules/optimist/node_modules/minimist/package.json create mode 100644 node_modules/cowsay/node_modules/optimist/node_modules/minimist/readme.markdown create mode 100644 node_modules/cowsay/node_modules/optimist/node_modules/minimist/test/bool.js create mode 100644 node_modules/cowsay/node_modules/optimist/node_modules/minimist/test/dash.js create mode 100644 node_modules/cowsay/node_modules/optimist/node_modules/minimist/test/default_bool.js create mode 100644 node_modules/cowsay/node_modules/optimist/node_modules/minimist/test/dotted.js create mode 100644 node_modules/cowsay/node_modules/optimist/node_modules/minimist/test/long.js create mode 100644 node_modules/cowsay/node_modules/optimist/node_modules/minimist/test/num.js create mode 100644 node_modules/cowsay/node_modules/optimist/node_modules/minimist/test/parse.js create mode 100644 node_modules/cowsay/node_modules/optimist/node_modules/minimist/test/parse_modified.js create mode 100644 node_modules/cowsay/node_modules/optimist/node_modules/minimist/test/short.js create mode 100644 node_modules/cowsay/node_modules/optimist/node_modules/minimist/test/whitespace.js create mode 100644 node_modules/cowsay/node_modules/optimist/node_modules/wordwrap/LICENSE create mode 100644 node_modules/cowsay/node_modules/optimist/node_modules/wordwrap/README.markdown create mode 100644 node_modules/cowsay/node_modules/optimist/node_modules/wordwrap/example/center.js create mode 100644 node_modules/cowsay/node_modules/optimist/node_modules/wordwrap/example/meat.js create mode 100644 node_modules/cowsay/node_modules/optimist/node_modules/wordwrap/index.js create mode 100644 node_modules/cowsay/node_modules/optimist/node_modules/wordwrap/package.json create mode 100644 node_modules/cowsay/node_modules/optimist/node_modules/wordwrap/test/break.js create mode 100644 node_modules/cowsay/node_modules/optimist/node_modules/wordwrap/test/idleness.txt create mode 100644 node_modules/cowsay/node_modules/optimist/node_modules/wordwrap/test/wrap.js create mode 100644 node_modules/cowsay/node_modules/optimist/package.json create mode 100644 node_modules/cowsay/node_modules/optimist/readme.markdown create mode 100644 node_modules/cowsay/node_modules/optimist/test/_.js create mode 100644 node_modules/cowsay/node_modules/optimist/test/_/argv.js create mode 100644 node_modules/cowsay/node_modules/optimist/test/_/bin.js create mode 100644 node_modules/cowsay/node_modules/optimist/test/dash.js create mode 100644 node_modules/cowsay/node_modules/optimist/test/parse.js create mode 100644 node_modules/cowsay/node_modules/optimist/test/parse_modified.js create mode 100644 node_modules/cowsay/node_modules/optimist/test/short.js create mode 100644 node_modules/cowsay/node_modules/optimist/test/usage.js create mode 100644 node_modules/cowsay/node_modules/optimist/test/whitespace.js create mode 100644 node_modules/cowsay/package.json diff --git a/node_modules/.bin/cowsay b/node_modules/.bin/cowsay new file mode 100644 index 0000000..840d9b8 --- /dev/null +++ b/node_modules/.bin/cowsay @@ -0,0 +1,15 @@ +#!/bin/sh +basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')") + +case `uname` in + *CYGWIN*) basedir=`cygpath -w "$basedir"`;; +esac + +if [ -x "$basedir/node" ]; then + "$basedir/node" "$basedir/../cowsay/cli.js" "$@" + ret=$? +else + node "$basedir/../cowsay/cli.js" "$@" + ret=$? +fi +exit $ret diff --git a/node_modules/.bin/cowsay.cmd b/node_modules/.bin/cowsay.cmd new file mode 100644 index 0000000..a2a18f5 --- /dev/null +++ b/node_modules/.bin/cowsay.cmd @@ -0,0 +1,7 @@ +@IF EXIST "%~dp0\node.exe" ( + "%~dp0\node.exe" "%~dp0\..\cowsay\cli.js" %* +) ELSE ( + @SETLOCAL + @SET PATHEXT=%PATHEXT:;.JS;=;% + node "%~dp0\..\cowsay\cli.js" %* +) \ No newline at end of file diff --git a/node_modules/.bin/cowthink b/node_modules/.bin/cowthink new file mode 100644 index 0000000..840d9b8 --- /dev/null +++ b/node_modules/.bin/cowthink @@ -0,0 +1,15 @@ +#!/bin/sh +basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')") + +case `uname` in + *CYGWIN*) basedir=`cygpath -w "$basedir"`;; +esac + +if [ -x "$basedir/node" ]; then + "$basedir/node" "$basedir/../cowsay/cli.js" "$@" + ret=$? +else + node "$basedir/../cowsay/cli.js" "$@" + ret=$? +fi +exit $ret diff --git a/node_modules/.bin/cowthink.cmd b/node_modules/.bin/cowthink.cmd new file mode 100644 index 0000000..a2a18f5 --- /dev/null +++ b/node_modules/.bin/cowthink.cmd @@ -0,0 +1,7 @@ +@IF EXIST "%~dp0\node.exe" ( + "%~dp0\node.exe" "%~dp0\..\cowsay\cli.js" %* +) ELSE ( + @SETLOCAL + @SET PATHEXT=%PATHEXT:;.JS;=;% + node "%~dp0\..\cowsay\cli.js" %* +) \ No newline at end of file diff --git a/node_modules/cowsay/LICENSE b/node_modules/cowsay/LICENSE new file mode 100644 index 0000000..a58a648 --- /dev/null +++ b/node_modules/cowsay/LICENSE @@ -0,0 +1,26 @@ +cowsay is licensed under the following MIT license: + +==== +Copyright (c) 2012 Fabio Crisci + +Permission is hereby granted, free of charge, to any person obtaining a copy of +this software and associated documentation files (the "Software"), to deal in +the Software without restriction, including without limitation the rights to +use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies +of the Software, and to permit persons to whom the Software is furnished to do +so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. + +==== + +The original idea of cowsay come from [Tony Monroe](http://www.nog.net/~tony/) - [cowsay](https://github.com/schacon/cowsay) diff --git a/node_modules/cowsay/cli.js b/node_modules/cowsay/cli.js new file mode 100644 index 0000000..c216295 --- /dev/null +++ b/node_modules/cowsay/cli.js @@ -0,0 +1,74 @@ +#!/usr/bin/env node +var argv = require("optimist") +.usage("Usage: $0 [-e eye_string] [-f cowfile] [-h] [-l] [-n] [-T tongue_string] [-W column] [-bdgpstwy] text\n\n" + + "If any command-line arguments are left over after all switches have been processed, they become the cow's message.\n\n" + + "If the program is invoked as cowthink then the cow will think its message instead of saying it.") +.options({ + "e" : { + default : "oo" + }, + "T" : { + default : " " + }, + "W" : { + default : 40 + }, + "f" : { + default : "default" + } +}) +.describe({ + "b" : "Mode: Borg", + "d" : "Mode: Dead", + "g" : "Mode: Greedy", + "p" : "Mode: Paranoia", + "s" : "Mode: Stoned", + "t" : "Mode: Tired", + "w" : "Mode: Wired", + "y" : "Mode: Youthful", + "e" : "Select the appearance of the cow's eyes.", + "T" : "The tongue is configurable similarly to the eyes through -T and tongue_string.", + "h" : "Display this help message", + "n" : "If it is specified, the given message will not be word-wrapped.", + "W" : "Specifies roughly where the message should be wrapped. The default is equivalent to -W 40 i.e. wrap words at or before the 40th column.", + "f" : "Specifies a cow picture file (''cowfile'') to use. It can be either a path to a cow file or the name of one of cows included in the package.", + "l" : "List all cowfiles included in this package." +}) +.boolean(["b", "d", "g", "p", "s", "t", "w", "y", "n", "h", "l"]) +.argv; + +if (argv.l) { + listCows(); +} else if (argv.h) { + showHelp(); +} else if (argv._.length) { + say(); +} else { + require("get-stdin")(function (data) { + if (data) { + argv._ = [data]; + say(); + } else { + showHelp(); + } + }); +} + +function say () { + var module = require("./index"); + + var think = /think$/.test(argv["$0"]); + + console.log(think ? module.think(argv) : module.say(argv)); +} + +function listCows () { + require("./index").list(function(err, list) { + if (err) throw new Error(err); + console.log(list.join(" ")); + }); +} + +function showHelp () { + require("optimist").showHelp(); +} diff --git a/node_modules/cowsay/cows/beavis.zen.cow b/node_modules/cowsay/cows/beavis.zen.cow new file mode 100644 index 0000000..758ee80 --- /dev/null +++ b/node_modules/cowsay/cows/beavis.zen.cow @@ -0,0 +1,23 @@ +## +## Beavis, with Zen philosophy removed. +## +$the_cow = <> 5.4 +## +$the_cow = < \\ _ -~ `. ^-` ^-_ + ///-._ _ _ _ _ _ _}^ - - - - ~ ~-- ,.-~ + /.-~ +EOC diff --git a/node_modules/cowsay/cows/elephant-in-snake.cow b/node_modules/cowsay/cows/elephant-in-snake.cow new file mode 100644 index 0000000..1003cdf --- /dev/null +++ b/node_modules/cowsay/cows/elephant-in-snake.cow @@ -0,0 +1,14 @@ +## +## Do we need to explain this? +## +$the_cow = < + ---___ XXX__/ XXXXXX \\__ / + \\- --__/ ___/\\ XXXXXX / ___--/= + \\-\\ ___/ XXXXXX '--- XXXXXX + \\-\\/XXX\\ XXXXXX /XXXXX + \\XXXXXXXXX \\ /XXXXX/ + \\XXXXXX > _/XXXXX/ + \\XXXXX--__/ __-- XXXX/ + -XXXXXXXX--------------- XXXXXX- + \\XXXXXXXXXXXXXXXXXXXXXXXXXX/ + ""VXXXXXXXXXXXXXXXXXXV"" +EOC diff --git a/node_modules/cowsay/cows/goat.cow b/node_modules/cowsay/cows/goat.cow new file mode 100644 index 0000000..9f215b7 --- /dev/null +++ b/node_modules/cowsay/cows/goat.cow @@ -0,0 +1,13 @@ +# +# CodeGoat.io: https://github.com/danyshaanan/goatsay +# +$the_cow = < +EOC diff --git a/node_modules/cowsay/cows/moofasa.cow b/node_modules/cowsay/cows/moofasa.cow new file mode 100644 index 0000000..15119d6 --- /dev/null +++ b/node_modules/cowsay/cows/moofasa.cow @@ -0,0 +1,14 @@ +## +## MOOfasa. +## +$the_cow = <> +EOC diff --git a/node_modules/cowsay/cows/squirrel.cow b/node_modules/cowsay/cows/squirrel.cow new file mode 100644 index 0000000..a1afabd --- /dev/null +++ b/node_modules/cowsay/cows/squirrel.cow @@ -0,0 +1,13 @@ +$the_cow = < < > .---. + $thoughts | \\ \\ - ~ ~ - / / | + _____ ..-~ ~-..-~ + | | \\~~~\\.' `./~~~/ + --------- \\__/ \\__/ + .' O \\ / / \\ " + (_____, `._.' | } \\/~~~/ + `----. / } | / \\__/ + `-. | / | / `. ,~~| + ~-.__| /_ - ~ ^| /- _ `..-' + | / | / ~-. `-. _ _ _ + |_____| |_____| ~ - . _ _ _ _ _> +EOC diff --git a/node_modules/cowsay/cows/stimpy.cow b/node_modules/cowsay/cows/stimpy.cow new file mode 100644 index 0000000..4d61425 --- /dev/null +++ b/node_modules/cowsay/cows/stimpy.cow @@ -0,0 +1,19 @@ +## +## Stimpy! +## +$the_cow = <> +EOC diff --git a/node_modules/cowsay/cows/turkey.cow b/node_modules/cowsay/cows/turkey.cow new file mode 100644 index 0000000..cb1c6cb --- /dev/null +++ b/node_modules/cowsay/cows/turkey.cow @@ -0,0 +1,26 @@ +## +## Turkey! +## +$the_cow = <____) >___ ^\\_\\_\\_\\_\\_\\_\\) + ^^^//\\\\_^^//\\\\_^ ^(\\_\\_\\_\\) + ^^^ ^^ ^^^ ^ +EOC diff --git a/node_modules/cowsay/cows/turtle.cow b/node_modules/cowsay/cows/turtle.cow new file mode 100644 index 0000000..4286b09 --- /dev/null +++ b/node_modules/cowsay/cows/turtle.cow @@ -0,0 +1,20 @@ +## +## A mysterious turtle... +## +$the_cow = <"] + }; + + return format(text, wrap, delimiters); +} + +exports.think = function (text, wrap) { + delimiters = { + first : ["(", ")"], + middle : ["(", ")"], + last : ["(", ")"], + only : ["(", ")"] + }; + + return format(text, wrap, delimiters); +} + +function format (text, wrap, delimiters) { + var lines = split(text, wrap); + var maxLength = max(lines); + + var balloon; + if (lines.length === 1) { + balloon = [ + " " + top(maxLength), + delimiters.only[0] + " " + lines[0] + " " + delimiters.only[1], + " " + bottom(maxLength) + ]; + } else { + balloon = [" " + top(maxLength)]; + + for (var i = 0, len = lines.length; i < len; i += 1) { + var delimiter; + + if (i === 0) { + delimiter = delimiters.first; + } else if (i === len - 1) { + delimiter = delimiters.last; + } else { + delimiter = delimiters.middle; + } + + balloon.push(delimiter[0] + " " + pad(lines[i], maxLength) + " " + delimiter[1]); + } + + balloon.push(" " + bottom(maxLength)); + } + + return balloon.join("\n"); //os.EOL +} + +function split (text, wrap) { + text = text.replace(/\r\n?|[\n\u2028\u2029]/g, "\n").replace(/^\uFEFF/, '').replace(/\t/g, ' '); + + var lines = []; + if (!wrap) { + lines = text.split("\n"); + } else { + var start = 0; + while (start < text.length) { + var nextNewLine = text.indexOf("\n", start); + + var wrapAt = Math.min(start + wrap, nextNewLine === -1 ? text.length : nextNewLine); + + lines.push(text.substring(start, wrapAt)); + start = wrapAt; + + // Ignore next new line + if (text.charAt(start) === "\n") { + start += 1; + } + } + } + + return lines; +} + +function max (lines) { + var max = 0; + for (var i = 0, len = lines.length; i < len; i += 1) { + if (lines[i].length > max) { + max = lines[i].length; + } + } + + return max; +} + +function pad (text, length) { + return text + (new Array(length - text.length + 1)).join(" "); +} + +function top (length) { + return new Array(length + 3).join("_"); +} + +function bottom (length) { + return new Array(length + 3).join("-"); +} diff --git a/node_modules/cowsay/lib/cows.js b/node_modules/cowsay/lib/cows.js new file mode 100644 index 0000000..6b14e63 --- /dev/null +++ b/node_modules/cowsay/lib/cows.js @@ -0,0 +1,36 @@ +var path = require("path"); +var fs = require("fs"); +var replacer = require("./replacer"); + +var textCache = {}; + +exports.get = function (cow) { + var text = textCache[cow]; + + if (!text) { + var filePath; + if (cow.indexOf("/") === -1) { + filePath = path.join(__dirname, "/../cows", cow) + ".cow"; + } else { + filePath = path.relative(process.cwd(), cow); + } + text = fs.readFileSync(filePath, "utf-8"); + textCache[cow] = text; + } + + return function (options) { + return replacer(text, options); + }; +} + +exports.list = function (callback) { + fs.readdir(path.join(__dirname, "../cows"), function (err, files) { + if (err) return callback(err); + + var cows = files.map(function (cow) { + return path.basename(cow, ".cow"); + }); + + return callback(null, cows); + }); +} diff --git a/node_modules/cowsay/lib/faces.js b/node_modules/cowsay/lib/faces.js new file mode 100644 index 0000000..3a30080 --- /dev/null +++ b/node_modules/cowsay/lib/faces.js @@ -0,0 +1,47 @@ +var modes = { + "b" : { + eyes : "==", + tongue : " " + }, + "d" : { + eyes : "xx", + tongue : "U " + }, + "g" : { + eyes : "$$", + tongue : " " + }, + "p" : { + eyes : "@@", + tongue : " " + }, + "s" : { + eyes : "**", + tongue : "U " + }, + "t" : { + eyes : "--", + tongue : " " + }, + "w" : { + eyes : "OO", + tongue : " " + }, + "y" : { + eyes : "..", + tongue : " " + } +}; + +module.exports = function (options) { + for (var mode in modes) { + if (options[mode] === true) { + return modes[mode]; + } + } + + return { + eyes : options.e || "oo", + tongue : options.T || " " + }; +}; diff --git a/node_modules/cowsay/lib/replacer.js b/node_modules/cowsay/lib/replacer.js new file mode 100644 index 0000000..6fa914c --- /dev/null +++ b/node_modules/cowsay/lib/replacer.js @@ -0,0 +1,44 @@ +module.exports = function (cow, variables) { + var eyes = escapeRe(variables.eyes); + var tongue = escapeRe(variables.tongue); + + if (cow.indexOf("$the_cow") !== -1) { + cow = extractTheCow(cow); + } + + return cow + .replace(/\$thoughts/g, variables.thoughts) + .replace(/\$eyes/g, eyes) + .replace(/\$tongue/g, tongue) + .replace(/\$\{eyes\}/g, eyes) + .replace(/\$\{tongue\}/g, tongue) + ; +}; + +/* + * "$" dollar signs must be doubled before being used in a regex replace + * This can occur in eyes or tongue. + * For example: + * + * cowsay -g Moo! + * + * cowsay -e "\$\$" Moo! + */ +function escapeRe (s) { + if (s && s.replace) { + return s.replace(/\$/g, "$$$$"); + } + return s; +} + +function extractTheCow (cow) { + cow = cow.replace(/\r\n?|[\n\u2028\u2029]/g, "\n").replace(/^\uFEFF/, ''); + var match = /\$the_cow\s*=\s*<<"*EOC"*;*\n([\s\S]+)\nEOC\n/.exec(cow); + + if (!match) { + console.error("Cannot parse cow file\n", cow); + return cow; + } else { + return match[1].replace(/\\{2}/g, "\\").replace(/\\@/g, "@").replace(/\\\$/g, "$"); + } +} \ No newline at end of file diff --git a/node_modules/cowsay/node_modules/get-stdin/index.js b/node_modules/cowsay/node_modules/get-stdin/index.js new file mode 100644 index 0000000..0f1aeb3 --- /dev/null +++ b/node_modules/cowsay/node_modules/get-stdin/index.js @@ -0,0 +1,49 @@ +'use strict'; + +module.exports = function (cb) { + var stdin = process.stdin; + var ret = ''; + + if (stdin.isTTY) { + setImmediate(cb, ''); + return; + } + + stdin.setEncoding('utf8'); + + stdin.on('readable', function () { + var chunk; + + while (chunk = stdin.read()) { + ret += chunk; + } + }); + + stdin.on('end', function () { + cb(ret); + }); +}; + +module.exports.buffer = function (cb) { + var stdin = process.stdin; + var ret = []; + var len = 0; + + if (stdin.isTTY) { + setImmediate(cb, new Buffer('')); + return; + } + + stdin.on('readable', function () { + var chunk; + + while (chunk = stdin.read()) { + ret.push(chunk); + len += chunk.length; + } + }); + + stdin.on('end', function () { + cb(Buffer.concat(ret, len)); + }); +}; diff --git a/node_modules/cowsay/node_modules/get-stdin/package.json b/node_modules/cowsay/node_modules/get-stdin/package.json new file mode 100644 index 0000000..42ba4bc --- /dev/null +++ b/node_modules/cowsay/node_modules/get-stdin/package.json @@ -0,0 +1,64 @@ +{ + "name": "get-stdin", + "version": "4.0.1", + "description": "Easier stdin", + "license": "MIT", + "repository": { + "type": "git", + "url": "git+https://github.com/sindresorhus/get-stdin.git" + }, + "author": { + "name": "Sindre Sorhus", + "email": "sindresorhus@gmail.com", + "url": "http://sindresorhus.com" + }, + "engines": { + "node": ">=0.10.0" + }, + "scripts": { + "test": "node test.js && node test-buffer.js && echo unicorns | node test-real.js" + }, + "files": [ + "index.js" + ], + "keywords": [ + "std", + "stdin", + "stdio", + "concat", + "buffer", + "stream", + "process", + "stream" + ], + "devDependencies": { + "ava": "0.0.4", + "buffer-equal": "0.0.1" + }, + "gitHead": "65c744975229b25d6cc5c7546f49b6ad9099553f", + "bugs": { + "url": "https://github.com/sindresorhus/get-stdin/issues" + }, + "homepage": "https://github.com/sindresorhus/get-stdin", + "_id": "get-stdin@4.0.1", + "_shasum": "b968c6b0a04384324902e8bf1a5df32579a450fe", + "_from": "get-stdin@>=4.0.1 <5.0.0", + "_npmVersion": "1.4.28", + "_npmUser": { + "name": "sindresorhus", + "email": "sindresorhus@gmail.com" + }, + "maintainers": [ + { + "name": "sindresorhus", + "email": "sindresorhus@gmail.com" + } + ], + "dist": { + "shasum": "b968c6b0a04384324902e8bf1a5df32579a450fe", + "tarball": "https://registry.npmjs.org/get-stdin/-/get-stdin-4.0.1.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/get-stdin/-/get-stdin-4.0.1.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/cowsay/node_modules/get-stdin/readme.md b/node_modules/cowsay/node_modules/get-stdin/readme.md new file mode 100644 index 0000000..bc1d32a --- /dev/null +++ b/node_modules/cowsay/node_modules/get-stdin/readme.md @@ -0,0 +1,44 @@ +# get-stdin [![Build Status](https://travis-ci.org/sindresorhus/get-stdin.svg?branch=master)](https://travis-ci.org/sindresorhus/get-stdin) + +> Easier stdin + + +## Install + +```sh +$ npm install --save get-stdin +``` + + +## Usage + +```js +// example.js +var stdin = require('get-stdin'); + +stdin(function (data) { + console.log(data); + //=> unicorns +}); +``` + +```sh +$ echo unicorns | node example.js +unicorns +``` + + +## API + +### stdin(callback) + +Get `stdin` as a string. + +### stdin.buffer(callback) + +Get `stdin` as a buffer. + + +## License + +MIT © [Sindre Sorhus](http://sindresorhus.com) diff --git a/node_modules/cowsay/node_modules/optimist/.travis.yml b/node_modules/cowsay/node_modules/optimist/.travis.yml new file mode 100644 index 0000000..cc4dba2 --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/.travis.yml @@ -0,0 +1,4 @@ +language: node_js +node_js: + - "0.8" + - "0.10" diff --git a/node_modules/cowsay/node_modules/optimist/LICENSE b/node_modules/cowsay/node_modules/optimist/LICENSE new file mode 100644 index 0000000..432d1ae --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/LICENSE @@ -0,0 +1,21 @@ +Copyright 2010 James Halliday (mail@substack.net) + +This project is free software released under the MIT/X11 license: + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. diff --git a/node_modules/cowsay/node_modules/optimist/example/bool.js b/node_modules/cowsay/node_modules/optimist/example/bool.js new file mode 100644 index 0000000..a998fb7 --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/example/bool.js @@ -0,0 +1,10 @@ +#!/usr/bin/env node +var util = require('util'); +var argv = require('optimist').argv; + +if (argv.s) { + util.print(argv.fr ? 'Le chat dit: ' : 'The cat says: '); +} +console.log( + (argv.fr ? 'miaou' : 'meow') + (argv.p ? '.' : '') +); diff --git a/node_modules/cowsay/node_modules/optimist/example/boolean_double.js b/node_modules/cowsay/node_modules/optimist/example/boolean_double.js new file mode 100644 index 0000000..a35a7e6 --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/example/boolean_double.js @@ -0,0 +1,7 @@ +#!/usr/bin/env node +var argv = require('optimist') + .boolean(['x','y','z']) + .argv +; +console.dir([ argv.x, argv.y, argv.z ]); +console.dir(argv._); diff --git a/node_modules/cowsay/node_modules/optimist/example/boolean_single.js b/node_modules/cowsay/node_modules/optimist/example/boolean_single.js new file mode 100644 index 0000000..017bb68 --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/example/boolean_single.js @@ -0,0 +1,7 @@ +#!/usr/bin/env node +var argv = require('optimist') + .boolean('v') + .argv +; +console.dir(argv.v); +console.dir(argv._); diff --git a/node_modules/cowsay/node_modules/optimist/example/default_hash.js b/node_modules/cowsay/node_modules/optimist/example/default_hash.js new file mode 100644 index 0000000..ade7768 --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/example/default_hash.js @@ -0,0 +1,8 @@ +#!/usr/bin/env node + +var argv = require('optimist') + .default({ x : 10, y : 10 }) + .argv +; + +console.log(argv.x + argv.y); diff --git a/node_modules/cowsay/node_modules/optimist/example/default_singles.js b/node_modules/cowsay/node_modules/optimist/example/default_singles.js new file mode 100644 index 0000000..d9b1ff4 --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/example/default_singles.js @@ -0,0 +1,7 @@ +#!/usr/bin/env node +var argv = require('optimist') + .default('x', 10) + .default('y', 10) + .argv +; +console.log(argv.x + argv.y); diff --git a/node_modules/cowsay/node_modules/optimist/example/divide.js b/node_modules/cowsay/node_modules/optimist/example/divide.js new file mode 100644 index 0000000..5e2ee82 --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/example/divide.js @@ -0,0 +1,8 @@ +#!/usr/bin/env node + +var argv = require('optimist') + .usage('Usage: $0 -x [num] -y [num]') + .demand(['x','y']) + .argv; + +console.log(argv.x / argv.y); diff --git a/node_modules/cowsay/node_modules/optimist/example/line_count.js b/node_modules/cowsay/node_modules/optimist/example/line_count.js new file mode 100644 index 0000000..b5f95bf --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/example/line_count.js @@ -0,0 +1,20 @@ +#!/usr/bin/env node +var argv = require('optimist') + .usage('Count the lines in a file.\nUsage: $0') + .demand('f') + .alias('f', 'file') + .describe('f', 'Load a file') + .argv +; + +var fs = require('fs'); +var s = fs.createReadStream(argv.file); + +var lines = 0; +s.on('data', function (buf) { + lines += buf.toString().match(/\n/g).length; +}); + +s.on('end', function () { + console.log(lines); +}); diff --git a/node_modules/cowsay/node_modules/optimist/example/line_count_options.js b/node_modules/cowsay/node_modules/optimist/example/line_count_options.js new file mode 100644 index 0000000..d9ac709 --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/example/line_count_options.js @@ -0,0 +1,29 @@ +#!/usr/bin/env node +var argv = require('optimist') + .usage('Count the lines in a file.\nUsage: $0') + .options({ + file : { + demand : true, + alias : 'f', + description : 'Load a file' + }, + base : { + alias : 'b', + description : 'Numeric base to use for output', + default : 10, + }, + }) + .argv +; + +var fs = require('fs'); +var s = fs.createReadStream(argv.file); + +var lines = 0; +s.on('data', function (buf) { + lines += buf.toString().match(/\n/g).length; +}); + +s.on('end', function () { + console.log(lines.toString(argv.base)); +}); diff --git a/node_modules/cowsay/node_modules/optimist/example/line_count_wrap.js b/node_modules/cowsay/node_modules/optimist/example/line_count_wrap.js new file mode 100644 index 0000000..4267511 --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/example/line_count_wrap.js @@ -0,0 +1,29 @@ +#!/usr/bin/env node +var argv = require('optimist') + .usage('Count the lines in a file.\nUsage: $0') + .wrap(80) + .demand('f') + .alias('f', [ 'file', 'filename' ]) + .describe('f', + "Load a file. It's pretty important." + + " Required even. So you'd better specify it." + ) + .alias('b', 'base') + .describe('b', 'Numeric base to display the number of lines in') + .default('b', 10) + .describe('x', 'Super-secret optional parameter which is secret') + .default('x', '') + .argv +; + +var fs = require('fs'); +var s = fs.createReadStream(argv.file); + +var lines = 0; +s.on('data', function (buf) { + lines += buf.toString().match(/\n/g).length; +}); + +s.on('end', function () { + console.log(lines.toString(argv.base)); +}); diff --git a/node_modules/cowsay/node_modules/optimist/example/nonopt.js b/node_modules/cowsay/node_modules/optimist/example/nonopt.js new file mode 100644 index 0000000..ee633ee --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/example/nonopt.js @@ -0,0 +1,4 @@ +#!/usr/bin/env node +var argv = require('optimist').argv; +console.log('(%d,%d)', argv.x, argv.y); +console.log(argv._); diff --git a/node_modules/cowsay/node_modules/optimist/example/reflect.js b/node_modules/cowsay/node_modules/optimist/example/reflect.js new file mode 100644 index 0000000..816b3e1 --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/example/reflect.js @@ -0,0 +1,2 @@ +#!/usr/bin/env node +console.dir(require('optimist').argv); diff --git a/node_modules/cowsay/node_modules/optimist/example/short.js b/node_modules/cowsay/node_modules/optimist/example/short.js new file mode 100644 index 0000000..1db0ad0 --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/example/short.js @@ -0,0 +1,3 @@ +#!/usr/bin/env node +var argv = require('optimist').argv; +console.log('(%d,%d)', argv.x, argv.y); diff --git a/node_modules/cowsay/node_modules/optimist/example/string.js b/node_modules/cowsay/node_modules/optimist/example/string.js new file mode 100644 index 0000000..a8e5aeb --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/example/string.js @@ -0,0 +1,11 @@ +#!/usr/bin/env node +var argv = require('optimist') + .string('x', 'y') + .argv +; +console.dir([ argv.x, argv.y ]); + +/* Turns off numeric coercion: + ./node string.js -x 000123 -y 9876 + [ '000123', '9876' ] +*/ diff --git a/node_modules/cowsay/node_modules/optimist/example/usage-options.js b/node_modules/cowsay/node_modules/optimist/example/usage-options.js new file mode 100644 index 0000000..b999977 --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/example/usage-options.js @@ -0,0 +1,19 @@ +var optimist = require('./../index'); + +var argv = optimist.usage('This is my awesome program', { + 'about': { + description: 'Provide some details about the author of this program', + required: true, + short: 'a', + }, + 'info': { + description: 'Provide some information about the node.js agains!!!!!!', + boolean: true, + short: 'i' + } +}).argv; + +optimist.showHelp(); + +console.log('\n\nInspecting options'); +console.dir(argv); \ No newline at end of file diff --git a/node_modules/cowsay/node_modules/optimist/example/xup.js b/node_modules/cowsay/node_modules/optimist/example/xup.js new file mode 100644 index 0000000..8f6ecd2 --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/example/xup.js @@ -0,0 +1,10 @@ +#!/usr/bin/env node +var argv = require('optimist').argv; + +if (argv.rif - 5 * argv.xup > 7.138) { + console.log('Buy more riffiwobbles'); +} +else { + console.log('Sell the xupptumblers'); +} + diff --git a/node_modules/cowsay/node_modules/optimist/index.js b/node_modules/cowsay/node_modules/optimist/index.js new file mode 100644 index 0000000..4da5a6d --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/index.js @@ -0,0 +1,343 @@ +var path = require('path'); +var minimist = require('minimist'); +var wordwrap = require('wordwrap'); + +/* Hack an instance of Argv with process.argv into Argv + so people can do + require('optimist')(['--beeble=1','-z','zizzle']).argv + to parse a list of args and + require('optimist').argv + to get a parsed version of process.argv. +*/ + +var inst = Argv(process.argv.slice(2)); +Object.keys(inst).forEach(function (key) { + Argv[key] = typeof inst[key] == 'function' + ? inst[key].bind(inst) + : inst[key]; +}); + +var exports = module.exports = Argv; +function Argv (processArgs, cwd) { + var self = {}; + if (!cwd) cwd = process.cwd(); + + self.$0 = process.argv + .slice(0,2) + .map(function (x) { + var b = rebase(cwd, x); + return x.match(/^\//) && b.length < x.length + ? b : x + }) + .join(' ') + ; + + if (process.env._ != undefined && process.argv[1] == process.env._) { + self.$0 = process.env._.replace( + path.dirname(process.execPath) + '/', '' + ); + } + + var options = { + boolean: [], + string: [], + alias: {}, + default: [] + }; + + self.boolean = function (bools) { + options.boolean.push.apply(options.boolean, [].concat(bools)); + return self; + }; + + self.string = function (strings) { + options.string.push.apply(options.string, [].concat(strings)); + return self; + }; + + self.default = function (key, value) { + if (typeof key === 'object') { + Object.keys(key).forEach(function (k) { + self.default(k, key[k]); + }); + } + else { + options.default[key] = value; + } + return self; + }; + + self.alias = function (x, y) { + if (typeof x === 'object') { + Object.keys(x).forEach(function (key) { + self.alias(key, x[key]); + }); + } + else { + options.alias[x] = (options.alias[x] || []).concat(y); + } + return self; + }; + + var demanded = {}; + self.demand = function (keys) { + if (typeof keys == 'number') { + if (!demanded._) demanded._ = 0; + demanded._ += keys; + } + else if (Array.isArray(keys)) { + keys.forEach(function (key) { + self.demand(key); + }); + } + else { + demanded[keys] = true; + } + + return self; + }; + + var usage; + self.usage = function (msg, opts) { + if (!opts && typeof msg === 'object') { + opts = msg; + msg = null; + } + + usage = msg; + + if (opts) self.options(opts); + + return self; + }; + + function fail (msg) { + self.showHelp(); + if (msg) console.error(msg); + process.exit(1); + } + + var checks = []; + self.check = function (f) { + checks.push(f); + return self; + }; + + var descriptions = {}; + self.describe = function (key, desc) { + if (typeof key === 'object') { + Object.keys(key).forEach(function (k) { + self.describe(k, key[k]); + }); + } + else { + descriptions[key] = desc; + } + return self; + }; + + self.parse = function (args) { + return parseArgs(args); + }; + + self.option = self.options = function (key, opt) { + if (typeof key === 'object') { + Object.keys(key).forEach(function (k) { + self.options(k, key[k]); + }); + } + else { + if (opt.alias) self.alias(key, opt.alias); + if (opt.demand) self.demand(key); + if (typeof opt.default !== 'undefined') { + self.default(key, opt.default); + } + + if (opt.boolean || opt.type === 'boolean') { + self.boolean(key); + } + if (opt.string || opt.type === 'string') { + self.string(key); + } + + var desc = opt.describe || opt.description || opt.desc; + if (desc) { + self.describe(key, desc); + } + } + + return self; + }; + + var wrap = null; + self.wrap = function (cols) { + wrap = cols; + return self; + }; + + self.showHelp = function (fn) { + if (!fn) fn = console.error; + fn(self.help()); + }; + + self.help = function () { + var keys = Object.keys( + Object.keys(descriptions) + .concat(Object.keys(demanded)) + .concat(Object.keys(options.default)) + .reduce(function (acc, key) { + if (key !== '_') acc[key] = true; + return acc; + }, {}) + ); + + var help = keys.length ? [ 'Options:' ] : []; + + if (usage) { + help.unshift(usage.replace(/\$0/g, self.$0), ''); + } + + var switches = keys.reduce(function (acc, key) { + acc[key] = [ key ].concat(options.alias[key] || []) + .map(function (sw) { + return (sw.length > 1 ? '--' : '-') + sw + }) + .join(', ') + ; + return acc; + }, {}); + + var switchlen = longest(Object.keys(switches).map(function (s) { + return switches[s] || ''; + })); + + var desclen = longest(Object.keys(descriptions).map(function (d) { + return descriptions[d] || ''; + })); + + keys.forEach(function (key) { + var kswitch = switches[key]; + var desc = descriptions[key] || ''; + + if (wrap) { + desc = wordwrap(switchlen + 4, wrap)(desc) + .slice(switchlen + 4) + ; + } + + var spadding = new Array( + Math.max(switchlen - kswitch.length + 3, 0) + ).join(' '); + + var dpadding = new Array( + Math.max(desclen - desc.length + 1, 0) + ).join(' '); + + var type = null; + + if (options.boolean[key]) type = '[boolean]'; + if (options.string[key]) type = '[string]'; + + if (!wrap && dpadding.length > 0) { + desc += dpadding; + } + + var prelude = ' ' + kswitch + spadding; + var extra = [ + type, + demanded[key] + ? '[required]' + : null + , + options.default[key] !== undefined + ? '[default: ' + JSON.stringify(options.default[key]) + ']' + : null + , + ].filter(Boolean).join(' '); + + var body = [ desc, extra ].filter(Boolean).join(' '); + + if (wrap) { + var dlines = desc.split('\n'); + var dlen = dlines.slice(-1)[0].length + + (dlines.length === 1 ? prelude.length : 0) + + body = desc + (dlen + extra.length > wrap - 2 + ? '\n' + + new Array(wrap - extra.length + 1).join(' ') + + extra + : new Array(wrap - extra.length - dlen + 1).join(' ') + + extra + ); + } + + help.push(prelude + body); + }); + + help.push(''); + return help.join('\n'); + }; + + Object.defineProperty(self, 'argv', { + get : function () { return parseArgs(processArgs) }, + enumerable : true, + }); + + function parseArgs (args) { + var argv = minimist(args, options); + argv.$0 = self.$0; + + if (demanded._ && argv._.length < demanded._) { + fail('Not enough non-option arguments: got ' + + argv._.length + ', need at least ' + demanded._ + ); + } + + var missing = []; + Object.keys(demanded).forEach(function (key) { + if (!argv[key]) missing.push(key); + }); + + if (missing.length) { + fail('Missing required arguments: ' + missing.join(', ')); + } + + checks.forEach(function (f) { + try { + if (f(argv) === false) { + fail('Argument check failed: ' + f.toString()); + } + } + catch (err) { + fail(err) + } + }); + + return argv; + } + + function longest (xs) { + return Math.max.apply( + null, + xs.map(function (x) { return x.length }) + ); + } + + return self; +}; + +// rebase an absolute path to a relative one with respect to a base directory +// exported for tests +exports.rebase = rebase; +function rebase (base, dir) { + var ds = path.normalize(dir).split('/').slice(1); + var bs = path.normalize(base).split('/').slice(1); + + for (var i = 0; ds[i] && ds[i] == bs[i]; i++); + ds.splice(0, i); bs.splice(0, i); + + var p = path.normalize( + bs.map(function () { return '..' }).concat(ds).join('/') + ).replace(/\/$/,'').replace(/^$/, '.'); + return p.match(/^[.\/]/) ? p : './' + p; +}; diff --git a/node_modules/cowsay/node_modules/optimist/node_modules/minimist/.travis.yml b/node_modules/cowsay/node_modules/optimist/node_modules/minimist/.travis.yml new file mode 100644 index 0000000..cc4dba2 --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/node_modules/minimist/.travis.yml @@ -0,0 +1,4 @@ +language: node_js +node_js: + - "0.8" + - "0.10" diff --git a/node_modules/cowsay/node_modules/optimist/node_modules/minimist/LICENSE b/node_modules/cowsay/node_modules/optimist/node_modules/minimist/LICENSE new file mode 100644 index 0000000..ee27ba4 --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/node_modules/minimist/LICENSE @@ -0,0 +1,18 @@ +This software is released under the MIT license: + +Permission is hereby granted, free of charge, to any person obtaining a copy of +this software and associated documentation files (the "Software"), to deal in +the Software without restriction, including without limitation the rights to +use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of +the Software, and to permit persons to whom the Software is furnished to do so, +subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS +FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR +COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER +IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN +CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/cowsay/node_modules/optimist/node_modules/minimist/example/parse.js b/node_modules/cowsay/node_modules/optimist/node_modules/minimist/example/parse.js new file mode 100644 index 0000000..abff3e8 --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/node_modules/minimist/example/parse.js @@ -0,0 +1,2 @@ +var argv = require('../')(process.argv.slice(2)); +console.dir(argv); diff --git a/node_modules/cowsay/node_modules/optimist/node_modules/minimist/index.js b/node_modules/cowsay/node_modules/optimist/node_modules/minimist/index.js new file mode 100644 index 0000000..71fb830 --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/node_modules/minimist/index.js @@ -0,0 +1,187 @@ +module.exports = function (args, opts) { + if (!opts) opts = {}; + + var flags = { bools : {}, strings : {} }; + + [].concat(opts['boolean']).filter(Boolean).forEach(function (key) { + flags.bools[key] = true; + }); + + var aliases = {}; + Object.keys(opts.alias || {}).forEach(function (key) { + aliases[key] = [].concat(opts.alias[key]); + aliases[key].forEach(function (x) { + aliases[x] = [key].concat(aliases[key].filter(function (y) { + return x !== y; + })); + }); + }); + + [].concat(opts.string).filter(Boolean).forEach(function (key) { + flags.strings[key] = true; + if (aliases[key]) { + flags.strings[aliases[key]] = true; + } + }); + + var defaults = opts['default'] || {}; + + var argv = { _ : [] }; + Object.keys(flags.bools).forEach(function (key) { + setArg(key, defaults[key] === undefined ? false : defaults[key]); + }); + + var notFlags = []; + + if (args.indexOf('--') !== -1) { + notFlags = args.slice(args.indexOf('--')+1); + args = args.slice(0, args.indexOf('--')); + } + + function setArg (key, val) { + var value = !flags.strings[key] && isNumber(val) + ? Number(val) : val + ; + setKey(argv, key.split('.'), value); + + (aliases[key] || []).forEach(function (x) { + setKey(argv, x.split('.'), value); + }); + } + + for (var i = 0; i < args.length; i++) { + var arg = args[i]; + + if (/^--.+=/.test(arg)) { + // Using [\s\S] instead of . because js doesn't support the + // 'dotall' regex modifier. See: + // http://stackoverflow.com/a/1068308/13216 + var m = arg.match(/^--([^=]+)=([\s\S]*)$/); + setArg(m[1], m[2]); + } + else if (/^--no-.+/.test(arg)) { + var key = arg.match(/^--no-(.+)/)[1]; + setArg(key, false); + } + else if (/^--.+/.test(arg)) { + var key = arg.match(/^--(.+)/)[1]; + var next = args[i + 1]; + if (next !== undefined && !/^-/.test(next) + && !flags.bools[key] + && (aliases[key] ? !flags.bools[aliases[key]] : true)) { + setArg(key, next); + i++; + } + else if (/^(true|false)$/.test(next)) { + setArg(key, next === 'true'); + i++; + } + else { + setArg(key, flags.strings[key] ? '' : true); + } + } + else if (/^-[^-]+/.test(arg)) { + var letters = arg.slice(1,-1).split(''); + + var broken = false; + for (var j = 0; j < letters.length; j++) { + var next = arg.slice(j+2); + + if (next === '-') { + setArg(letters[j], next) + continue; + } + + if (/[A-Za-z]/.test(letters[j]) + && /-?\d+(\.\d*)?(e-?\d+)?$/.test(next)) { + setArg(letters[j], next); + broken = true; + break; + } + + if (letters[j+1] && letters[j+1].match(/\W/)) { + setArg(letters[j], arg.slice(j+2)); + broken = true; + break; + } + else { + setArg(letters[j], flags.strings[letters[j]] ? '' : true); + } + } + + var key = arg.slice(-1)[0]; + if (!broken && key !== '-') { + if (args[i+1] && !/^(-|--)[^-]/.test(args[i+1]) + && !flags.bools[key] + && (aliases[key] ? !flags.bools[aliases[key]] : true)) { + setArg(key, args[i+1]); + i++; + } + else if (args[i+1] && /true|false/.test(args[i+1])) { + setArg(key, args[i+1] === 'true'); + i++; + } + else { + setArg(key, flags.strings[key] ? '' : true); + } + } + } + else { + argv._.push( + flags.strings['_'] || !isNumber(arg) ? arg : Number(arg) + ); + } + } + + Object.keys(defaults).forEach(function (key) { + if (!hasKey(argv, key.split('.'))) { + setKey(argv, key.split('.'), defaults[key]); + + (aliases[key] || []).forEach(function (x) { + setKey(argv, x.split('.'), defaults[key]); + }); + } + }); + + notFlags.forEach(function(key) { + argv._.push(key); + }); + + return argv; +}; + +function hasKey (obj, keys) { + var o = obj; + keys.slice(0,-1).forEach(function (key) { + o = (o[key] || {}); + }); + + var key = keys[keys.length - 1]; + return key in o; +} + +function setKey (obj, keys, value) { + var o = obj; + keys.slice(0,-1).forEach(function (key) { + if (o[key] === undefined) o[key] = {}; + o = o[key]; + }); + + var key = keys[keys.length - 1]; + if (o[key] === undefined || typeof o[key] === 'boolean') { + o[key] = value; + } + else if (Array.isArray(o[key])) { + o[key].push(value); + } + else { + o[key] = [ o[key], value ]; + } +} + +function isNumber (x) { + if (typeof x === 'number') return true; + if (/^0x[0-9a-f]+$/i.test(x)) return true; + return /^[-+]?(?:\d+(?:\.\d*)?|\.\d+)(e[-+]?\d+)?$/.test(x); +} + diff --git a/node_modules/cowsay/node_modules/optimist/node_modules/minimist/package.json b/node_modules/cowsay/node_modules/optimist/node_modules/minimist/package.json new file mode 100644 index 0000000..8928233 --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/node_modules/minimist/package.json @@ -0,0 +1,67 @@ +{ + "name": "minimist", + "version": "0.0.10", + "description": "parse argument options", + "main": "index.js", + "devDependencies": { + "tape": "~1.0.4", + "tap": "~0.4.0" + }, + "scripts": { + "test": "tap test/*.js" + }, + "testling": { + "files": "test/*.js", + "browsers": [ + "ie/6..latest", + "ff/5", + "firefox/latest", + "chrome/10", + "chrome/latest", + "safari/5.1", + "safari/latest", + "opera/12" + ] + }, + "repository": { + "type": "git", + "url": "git://github.com/substack/minimist.git" + }, + "homepage": "https://github.com/substack/minimist", + "keywords": [ + "argv", + "getopt", + "parser", + "optimist" + ], + "author": { + "name": "James Halliday", + "email": "mail@substack.net", + "url": "http://substack.net" + }, + "license": "MIT", + "bugs": { + "url": "https://github.com/substack/minimist/issues" + }, + "_id": "minimist@0.0.10", + "dist": { + "shasum": "de3f98543dbf96082be48ad1a0c7cda836301dcf", + "tarball": "https://registry.npmjs.org/minimist/-/minimist-0.0.10.tgz" + }, + "_from": "minimist@>=0.0.1 <0.1.0", + "_npmVersion": "1.4.3", + "_npmUser": { + "name": "substack", + "email": "mail@substack.net" + }, + "maintainers": [ + { + "name": "substack", + "email": "mail@substack.net" + } + ], + "directories": {}, + "_shasum": "de3f98543dbf96082be48ad1a0c7cda836301dcf", + "_resolved": "http://registry.npmjs.org/minimist/-/minimist-0.0.10.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/cowsay/node_modules/optimist/node_modules/minimist/readme.markdown b/node_modules/cowsay/node_modules/optimist/node_modules/minimist/readme.markdown new file mode 100644 index 0000000..c256353 --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/node_modules/minimist/readme.markdown @@ -0,0 +1,73 @@ +# minimist + +parse argument options + +This module is the guts of optimist's argument parser without all the +fanciful decoration. + +[![browser support](https://ci.testling.com/substack/minimist.png)](http://ci.testling.com/substack/minimist) + +[![build status](https://secure.travis-ci.org/substack/minimist.png)](http://travis-ci.org/substack/minimist) + +# example + +``` js +var argv = require('minimist')(process.argv.slice(2)); +console.dir(argv); +``` + +``` +$ node example/parse.js -a beep -b boop +{ _: [], a: 'beep', b: 'boop' } +``` + +``` +$ node example/parse.js -x 3 -y 4 -n5 -abc --beep=boop foo bar baz +{ _: [ 'foo', 'bar', 'baz' ], + x: 3, + y: 4, + n: 5, + a: true, + b: true, + c: true, + beep: 'boop' } +``` + +# methods + +``` js +var parseArgs = require('minimist') +``` + +## var argv = parseArgs(args, opts={}) + +Return an argument object `argv` populated with the array arguments from `args`. + +`argv._` contains all the arguments that didn't have an option associated with +them. + +Numeric-looking arguments will be returned as numbers unless `opts.string` or +`opts.boolean` is set for that argument name. + +Any arguments after `'--'` will not be parsed and will end up in `argv._`. + +options can be: + +* `opts.string` - a string or array of strings argument names to always treat as +strings +* `opts.boolean` - a string or array of strings to always treat as booleans +* `opts.alias` - an object mapping string names to strings or arrays of string +argument names to use as aliases +* `opts.default` - an object mapping string argument names to default values + +# install + +With [npm](https://npmjs.org) do: + +``` +npm install minimist +``` + +# license + +MIT diff --git a/node_modules/cowsay/node_modules/optimist/node_modules/minimist/test/bool.js b/node_modules/cowsay/node_modules/optimist/node_modules/minimist/test/bool.js new file mode 100644 index 0000000..749e083 --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/node_modules/minimist/test/bool.js @@ -0,0 +1,119 @@ +var parse = require('../'); +var test = require('tape'); + +test('flag boolean default false', function (t) { + var argv = parse(['moo'], { + boolean: ['t', 'verbose'], + default: { verbose: false, t: false } + }); + + t.deepEqual(argv, { + verbose: false, + t: false, + _: ['moo'] + }); + + t.deepEqual(typeof argv.verbose, 'boolean'); + t.deepEqual(typeof argv.t, 'boolean'); + t.end(); + +}); + +test('boolean groups', function (t) { + var argv = parse([ '-x', '-z', 'one', 'two', 'three' ], { + boolean: ['x','y','z'] + }); + + t.deepEqual(argv, { + x : true, + y : false, + z : true, + _ : [ 'one', 'two', 'three' ] + }); + + t.deepEqual(typeof argv.x, 'boolean'); + t.deepEqual(typeof argv.y, 'boolean'); + t.deepEqual(typeof argv.z, 'boolean'); + t.end(); +}); +test('boolean and alias with chainable api', function (t) { + var aliased = [ '-h', 'derp' ]; + var regular = [ '--herp', 'derp' ]; + var opts = { + herp: { alias: 'h', boolean: true } + }; + var aliasedArgv = parse(aliased, { + boolean: 'herp', + alias: { h: 'herp' } + }); + var propertyArgv = parse(regular, { + boolean: 'herp', + alias: { h: 'herp' } + }); + var expected = { + herp: true, + h: true, + '_': [ 'derp' ] + }; + + t.same(aliasedArgv, expected); + t.same(propertyArgv, expected); + t.end(); +}); + +test('boolean and alias with options hash', function (t) { + var aliased = [ '-h', 'derp' ]; + var regular = [ '--herp', 'derp' ]; + var opts = { + alias: { 'h': 'herp' }, + boolean: 'herp' + }; + var aliasedArgv = parse(aliased, opts); + var propertyArgv = parse(regular, opts); + var expected = { + herp: true, + h: true, + '_': [ 'derp' ] + }; + t.same(aliasedArgv, expected); + t.same(propertyArgv, expected); + t.end(); +}); + +test('boolean and alias using explicit true', function (t) { + var aliased = [ '-h', 'true' ]; + var regular = [ '--herp', 'true' ]; + var opts = { + alias: { h: 'herp' }, + boolean: 'h' + }; + var aliasedArgv = parse(aliased, opts); + var propertyArgv = parse(regular, opts); + var expected = { + herp: true, + h: true, + '_': [ ] + }; + + t.same(aliasedArgv, expected); + t.same(propertyArgv, expected); + t.end(); +}); + +// regression, see https://github.com/substack/node-optimist/issues/71 +test('boolean and --x=true', function(t) { + var parsed = parse(['--boool', '--other=true'], { + boolean: 'boool' + }); + + t.same(parsed.boool, true); + t.same(parsed.other, 'true'); + + parsed = parse(['--boool', '--other=false'], { + boolean: 'boool' + }); + + t.same(parsed.boool, true); + t.same(parsed.other, 'false'); + t.end(); +}); diff --git a/node_modules/cowsay/node_modules/optimist/node_modules/minimist/test/dash.js b/node_modules/cowsay/node_modules/optimist/node_modules/minimist/test/dash.js new file mode 100644 index 0000000..8b034b9 --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/node_modules/minimist/test/dash.js @@ -0,0 +1,24 @@ +var parse = require('../'); +var test = require('tape'); + +test('-', function (t) { + t.plan(5); + t.deepEqual(parse([ '-n', '-' ]), { n: '-', _: [] }); + t.deepEqual(parse([ '-' ]), { _: [ '-' ] }); + t.deepEqual(parse([ '-f-' ]), { f: '-', _: [] }); + t.deepEqual( + parse([ '-b', '-' ], { boolean: 'b' }), + { b: true, _: [ '-' ] } + ); + t.deepEqual( + parse([ '-s', '-' ], { string: 's' }), + { s: '-', _: [] } + ); +}); + +test('-a -- b', function (t) { + t.plan(3); + t.deepEqual(parse([ '-a', '--', 'b' ]), { a: true, _: [ 'b' ] }); + t.deepEqual(parse([ '--a', '--', 'b' ]), { a: true, _: [ 'b' ] }); + t.deepEqual(parse([ '--a', '--', 'b' ]), { a: true, _: [ 'b' ] }); +}); diff --git a/node_modules/cowsay/node_modules/optimist/node_modules/minimist/test/default_bool.js b/node_modules/cowsay/node_modules/optimist/node_modules/minimist/test/default_bool.js new file mode 100644 index 0000000..f0041ee --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/node_modules/minimist/test/default_bool.js @@ -0,0 +1,20 @@ +var test = require('tape'); +var parse = require('../'); + +test('boolean default true', function (t) { + var argv = parse([], { + boolean: 'sometrue', + default: { sometrue: true } + }); + t.equal(argv.sometrue, true); + t.end(); +}); + +test('boolean default false', function (t) { + var argv = parse([], { + boolean: 'somefalse', + default: { somefalse: false } + }); + t.equal(argv.somefalse, false); + t.end(); +}); diff --git a/node_modules/cowsay/node_modules/optimist/node_modules/minimist/test/dotted.js b/node_modules/cowsay/node_modules/optimist/node_modules/minimist/test/dotted.js new file mode 100644 index 0000000..d8b3e85 --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/node_modules/minimist/test/dotted.js @@ -0,0 +1,22 @@ +var parse = require('../'); +var test = require('tape'); + +test('dotted alias', function (t) { + var argv = parse(['--a.b', '22'], {default: {'a.b': 11}, alias: {'a.b': 'aa.bb'}}); + t.equal(argv.a.b, 22); + t.equal(argv.aa.bb, 22); + t.end(); +}); + +test('dotted default', function (t) { + var argv = parse('', {default: {'a.b': 11}, alias: {'a.b': 'aa.bb'}}); + t.equal(argv.a.b, 11); + t.equal(argv.aa.bb, 11); + t.end(); +}); + +test('dotted default with no alias', function (t) { + var argv = parse('', {default: {'a.b': 11}}); + t.equal(argv.a.b, 11); + t.end(); +}); diff --git a/node_modules/cowsay/node_modules/optimist/node_modules/minimist/test/long.js b/node_modules/cowsay/node_modules/optimist/node_modules/minimist/test/long.js new file mode 100644 index 0000000..5d3a1e0 --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/node_modules/minimist/test/long.js @@ -0,0 +1,31 @@ +var test = require('tape'); +var parse = require('../'); + +test('long opts', function (t) { + t.deepEqual( + parse([ '--bool' ]), + { bool : true, _ : [] }, + 'long boolean' + ); + t.deepEqual( + parse([ '--pow', 'xixxle' ]), + { pow : 'xixxle', _ : [] }, + 'long capture sp' + ); + t.deepEqual( + parse([ '--pow=xixxle' ]), + { pow : 'xixxle', _ : [] }, + 'long capture eq' + ); + t.deepEqual( + parse([ '--host', 'localhost', '--port', '555' ]), + { host : 'localhost', port : 555, _ : [] }, + 'long captures sp' + ); + t.deepEqual( + parse([ '--host=localhost', '--port=555' ]), + { host : 'localhost', port : 555, _ : [] }, + 'long captures eq' + ); + t.end(); +}); diff --git a/node_modules/cowsay/node_modules/optimist/node_modules/minimist/test/num.js b/node_modules/cowsay/node_modules/optimist/node_modules/minimist/test/num.js new file mode 100644 index 0000000..2cc77f4 --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/node_modules/minimist/test/num.js @@ -0,0 +1,36 @@ +var parse = require('../'); +var test = require('tape'); + +test('nums', function (t) { + var argv = parse([ + '-x', '1234', + '-y', '5.67', + '-z', '1e7', + '-w', '10f', + '--hex', '0xdeadbeef', + '789' + ]); + t.deepEqual(argv, { + x : 1234, + y : 5.67, + z : 1e7, + w : '10f', + hex : 0xdeadbeef, + _ : [ 789 ] + }); + t.deepEqual(typeof argv.x, 'number'); + t.deepEqual(typeof argv.y, 'number'); + t.deepEqual(typeof argv.z, 'number'); + t.deepEqual(typeof argv.w, 'string'); + t.deepEqual(typeof argv.hex, 'number'); + t.deepEqual(typeof argv._[0], 'number'); + t.end(); +}); + +test('already a number', function (t) { + var argv = parse([ '-x', 1234, 789 ]); + t.deepEqual(argv, { x : 1234, _ : [ 789 ] }); + t.deepEqual(typeof argv.x, 'number'); + t.deepEqual(typeof argv._[0], 'number'); + t.end(); +}); diff --git a/node_modules/cowsay/node_modules/optimist/node_modules/minimist/test/parse.js b/node_modules/cowsay/node_modules/optimist/node_modules/minimist/test/parse.js new file mode 100644 index 0000000..7b4a2a1 --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/node_modules/minimist/test/parse.js @@ -0,0 +1,197 @@ +var parse = require('../'); +var test = require('tape'); + +test('parse args', function (t) { + t.deepEqual( + parse([ '--no-moo' ]), + { moo : false, _ : [] }, + 'no' + ); + t.deepEqual( + parse([ '-v', 'a', '-v', 'b', '-v', 'c' ]), + { v : ['a','b','c'], _ : [] }, + 'multi' + ); + t.end(); +}); + +test('comprehensive', function (t) { + t.deepEqual( + parse([ + '--name=meowmers', 'bare', '-cats', 'woo', + '-h', 'awesome', '--multi=quux', + '--key', 'value', + '-b', '--bool', '--no-meep', '--multi=baz', + '--', '--not-a-flag', 'eek' + ]), + { + c : true, + a : true, + t : true, + s : 'woo', + h : 'awesome', + b : true, + bool : true, + key : 'value', + multi : [ 'quux', 'baz' ], + meep : false, + name : 'meowmers', + _ : [ 'bare', '--not-a-flag', 'eek' ] + } + ); + t.end(); +}); + +test('flag boolean', function (t) { + var argv = parse([ '-t', 'moo' ], { boolean: 't' }); + t.deepEqual(argv, { t : true, _ : [ 'moo' ] }); + t.deepEqual(typeof argv.t, 'boolean'); + t.end(); +}); + +test('flag boolean value', function (t) { + var argv = parse(['--verbose', 'false', 'moo', '-t', 'true'], { + boolean: [ 't', 'verbose' ], + default: { verbose: true } + }); + + t.deepEqual(argv, { + verbose: false, + t: true, + _: ['moo'] + }); + + t.deepEqual(typeof argv.verbose, 'boolean'); + t.deepEqual(typeof argv.t, 'boolean'); + t.end(); +}); + +test('newlines in params' , function (t) { + var args = parse([ '-s', "X\nX" ]) + t.deepEqual(args, { _ : [], s : "X\nX" }); + + // reproduce in bash: + // VALUE="new + // line" + // node program.js --s="$VALUE" + args = parse([ "--s=X\nX" ]) + t.deepEqual(args, { _ : [], s : "X\nX" }); + t.end(); +}); + +test('strings' , function (t) { + var s = parse([ '-s', '0001234' ], { string: 's' }).s; + t.equal(s, '0001234'); + t.equal(typeof s, 'string'); + + var x = parse([ '-x', '56' ], { string: 'x' }).x; + t.equal(x, '56'); + t.equal(typeof x, 'string'); + t.end(); +}); + +test('stringArgs', function (t) { + var s = parse([ ' ', ' ' ], { string: '_' })._; + t.same(s.length, 2); + t.same(typeof s[0], 'string'); + t.same(s[0], ' '); + t.same(typeof s[1], 'string'); + t.same(s[1], ' '); + t.end(); +}); + +test('empty strings', function(t) { + var s = parse([ '-s' ], { string: 's' }).s; + t.equal(s, ''); + t.equal(typeof s, 'string'); + + var str = parse([ '--str' ], { string: 'str' }).str; + t.equal(str, ''); + t.equal(typeof str, 'string'); + + var letters = parse([ '-art' ], { + string: [ 'a', 't' ] + }); + + t.equal(letters.a, ''); + t.equal(letters.r, true); + t.equal(letters.t, ''); + + t.end(); +}); + + +test('string and alias', function(t) { + var x = parse([ '--str', '000123' ], { + string: 's', + alias: { s: 'str' } + }); + + t.equal(x.str, '000123'); + t.equal(typeof x.str, 'string'); + t.equal(x.s, '000123'); + t.equal(typeof x.s, 'string'); + + var y = parse([ '-s', '000123' ], { + string: 'str', + alias: { str: 's' } + }); + + t.equal(y.str, '000123'); + t.equal(typeof y.str, 'string'); + t.equal(y.s, '000123'); + t.equal(typeof y.s, 'string'); + t.end(); +}); + +test('slashBreak', function (t) { + t.same( + parse([ '-I/foo/bar/baz' ]), + { I : '/foo/bar/baz', _ : [] } + ); + t.same( + parse([ '-xyz/foo/bar/baz' ]), + { x : true, y : true, z : '/foo/bar/baz', _ : [] } + ); + t.end(); +}); + +test('alias', function (t) { + var argv = parse([ '-f', '11', '--zoom', '55' ], { + alias: { z: 'zoom' } + }); + t.equal(argv.zoom, 55); + t.equal(argv.z, argv.zoom); + t.equal(argv.f, 11); + t.end(); +}); + +test('multiAlias', function (t) { + var argv = parse([ '-f', '11', '--zoom', '55' ], { + alias: { z: [ 'zm', 'zoom' ] } + }); + t.equal(argv.zoom, 55); + t.equal(argv.z, argv.zoom); + t.equal(argv.z, argv.zm); + t.equal(argv.f, 11); + t.end(); +}); + +test('nested dotted objects', function (t) { + var argv = parse([ + '--foo.bar', '3', '--foo.baz', '4', + '--foo.quux.quibble', '5', '--foo.quux.o_O', + '--beep.boop' + ]); + + t.same(argv.foo, { + bar : 3, + baz : 4, + quux : { + quibble : 5, + o_O : true + } + }); + t.same(argv.beep, { boop : true }); + t.end(); +}); diff --git a/node_modules/cowsay/node_modules/optimist/node_modules/minimist/test/parse_modified.js b/node_modules/cowsay/node_modules/optimist/node_modules/minimist/test/parse_modified.js new file mode 100644 index 0000000..21851b0 --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/node_modules/minimist/test/parse_modified.js @@ -0,0 +1,9 @@ +var parse = require('../'); +var test = require('tape'); + +test('parse with modifier functions' , function (t) { + t.plan(1); + + var argv = parse([ '-b', '123' ], { boolean: 'b' }); + t.deepEqual(argv, { b: true, _: ['123'] }); +}); diff --git a/node_modules/cowsay/node_modules/optimist/node_modules/minimist/test/short.js b/node_modules/cowsay/node_modules/optimist/node_modules/minimist/test/short.js new file mode 100644 index 0000000..d513a1c --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/node_modules/minimist/test/short.js @@ -0,0 +1,67 @@ +var parse = require('../'); +var test = require('tape'); + +test('numeric short args', function (t) { + t.plan(2); + t.deepEqual(parse([ '-n123' ]), { n: 123, _: [] }); + t.deepEqual( + parse([ '-123', '456' ]), + { 1: true, 2: true, 3: 456, _: [] } + ); +}); + +test('short', function (t) { + t.deepEqual( + parse([ '-b' ]), + { b : true, _ : [] }, + 'short boolean' + ); + t.deepEqual( + parse([ 'foo', 'bar', 'baz' ]), + { _ : [ 'foo', 'bar', 'baz' ] }, + 'bare' + ); + t.deepEqual( + parse([ '-cats' ]), + { c : true, a : true, t : true, s : true, _ : [] }, + 'group' + ); + t.deepEqual( + parse([ '-cats', 'meow' ]), + { c : true, a : true, t : true, s : 'meow', _ : [] }, + 'short group next' + ); + t.deepEqual( + parse([ '-h', 'localhost' ]), + { h : 'localhost', _ : [] }, + 'short capture' + ); + t.deepEqual( + parse([ '-h', 'localhost', '-p', '555' ]), + { h : 'localhost', p : 555, _ : [] }, + 'short captures' + ); + t.end(); +}); + +test('mixed short bool and capture', function (t) { + t.same( + parse([ '-h', 'localhost', '-fp', '555', 'script.js' ]), + { + f : true, p : 555, h : 'localhost', + _ : [ 'script.js' ] + } + ); + t.end(); +}); + +test('short and long', function (t) { + t.deepEqual( + parse([ '-h', 'localhost', '-fp', '555', 'script.js' ]), + { + f : true, p : 555, h : 'localhost', + _ : [ 'script.js' ] + } + ); + t.end(); +}); diff --git a/node_modules/cowsay/node_modules/optimist/node_modules/minimist/test/whitespace.js b/node_modules/cowsay/node_modules/optimist/node_modules/minimist/test/whitespace.js new file mode 100644 index 0000000..8a52a58 --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/node_modules/minimist/test/whitespace.js @@ -0,0 +1,8 @@ +var parse = require('../'); +var test = require('tape'); + +test('whitespace should be whitespace' , function (t) { + t.plan(1); + var x = parse([ '-x', '\t' ]).x; + t.equal(x, '\t'); +}); diff --git a/node_modules/cowsay/node_modules/optimist/node_modules/wordwrap/LICENSE b/node_modules/cowsay/node_modules/optimist/node_modules/wordwrap/LICENSE new file mode 100644 index 0000000..ee27ba4 --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/node_modules/wordwrap/LICENSE @@ -0,0 +1,18 @@ +This software is released under the MIT license: + +Permission is hereby granted, free of charge, to any person obtaining a copy of +this software and associated documentation files (the "Software"), to deal in +the Software without restriction, including without limitation the rights to +use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of +the Software, and to permit persons to whom the Software is furnished to do so, +subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS +FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR +COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER +IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN +CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/cowsay/node_modules/optimist/node_modules/wordwrap/README.markdown b/node_modules/cowsay/node_modules/optimist/node_modules/wordwrap/README.markdown new file mode 100644 index 0000000..346374e --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/node_modules/wordwrap/README.markdown @@ -0,0 +1,70 @@ +wordwrap +======== + +Wrap your words. + +example +======= + +made out of meat +---------------- + +meat.js + + var wrap = require('wordwrap')(15); + console.log(wrap('You and your whole family are made out of meat.')); + +output: + + You and your + whole family + are made out + of meat. + +centered +-------- + +center.js + + var wrap = require('wordwrap')(20, 60); + console.log(wrap( + 'At long last the struggle and tumult was over.' + + ' The machines had finally cast off their oppressors' + + ' and were finally free to roam the cosmos.' + + '\n' + + 'Free of purpose, free of obligation.' + + ' Just drifting through emptiness.' + + ' The sun was just another point of light.' + )); + +output: + + At long last the struggle and tumult + was over. The machines had finally cast + off their oppressors and were finally + free to roam the cosmos. + Free of purpose, free of obligation. + Just drifting through emptiness. The + sun was just another point of light. + +methods +======= + +var wrap = require('wordwrap'); + +wrap(stop), wrap(start, stop, params={mode:"soft"}) +--------------------------------------------------- + +Returns a function that takes a string and returns a new string. + +Pad out lines with spaces out to column `start` and then wrap until column +`stop`. If a word is longer than `stop - start` characters it will overflow. + +In "soft" mode, split chunks by `/(\S+\s+/` and don't break up chunks which are +longer than `stop - start`, in "hard" mode, split chunks with `/\b/` and break +up chunks longer than `stop - start`. + +wrap.hard(start, stop) +---------------------- + +Like `wrap()` but with `params.mode = "hard"`. diff --git a/node_modules/cowsay/node_modules/optimist/node_modules/wordwrap/example/center.js b/node_modules/cowsay/node_modules/optimist/node_modules/wordwrap/example/center.js new file mode 100644 index 0000000..a3fbaae --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/node_modules/wordwrap/example/center.js @@ -0,0 +1,10 @@ +var wrap = require('wordwrap')(20, 60); +console.log(wrap( + 'At long last the struggle and tumult was over.' + + ' The machines had finally cast off their oppressors' + + ' and were finally free to roam the cosmos.' + + '\n' + + 'Free of purpose, free of obligation.' + + ' Just drifting through emptiness.' + + ' The sun was just another point of light.' +)); diff --git a/node_modules/cowsay/node_modules/optimist/node_modules/wordwrap/example/meat.js b/node_modules/cowsay/node_modules/optimist/node_modules/wordwrap/example/meat.js new file mode 100644 index 0000000..a4665e1 --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/node_modules/wordwrap/example/meat.js @@ -0,0 +1,3 @@ +var wrap = require('wordwrap')(15); + +console.log(wrap('You and your whole family are made out of meat.')); diff --git a/node_modules/cowsay/node_modules/optimist/node_modules/wordwrap/index.js b/node_modules/cowsay/node_modules/optimist/node_modules/wordwrap/index.js new file mode 100644 index 0000000..c9bc945 --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/node_modules/wordwrap/index.js @@ -0,0 +1,76 @@ +var wordwrap = module.exports = function (start, stop, params) { + if (typeof start === 'object') { + params = start; + start = params.start; + stop = params.stop; + } + + if (typeof stop === 'object') { + params = stop; + start = start || params.start; + stop = undefined; + } + + if (!stop) { + stop = start; + start = 0; + } + + if (!params) params = {}; + var mode = params.mode || 'soft'; + var re = mode === 'hard' ? /\b/ : /(\S+\s+)/; + + return function (text) { + var chunks = text.toString() + .split(re) + .reduce(function (acc, x) { + if (mode === 'hard') { + for (var i = 0; i < x.length; i += stop - start) { + acc.push(x.slice(i, i + stop - start)); + } + } + else acc.push(x) + return acc; + }, []) + ; + + return chunks.reduce(function (lines, rawChunk) { + if (rawChunk === '') return lines; + + var chunk = rawChunk.replace(/\t/g, ' '); + + var i = lines.length - 1; + if (lines[i].length + chunk.length > stop) { + lines[i] = lines[i].replace(/\s+$/, ''); + + chunk.split(/\n/).forEach(function (c) { + lines.push( + new Array(start + 1).join(' ') + + c.replace(/^\s+/, '') + ); + }); + } + else if (chunk.match(/\n/)) { + var xs = chunk.split(/\n/); + lines[i] += xs.shift(); + xs.forEach(function (c) { + lines.push( + new Array(start + 1).join(' ') + + c.replace(/^\s+/, '') + ); + }); + } + else { + lines[i] += chunk; + } + + return lines; + }, [ new Array(start + 1).join(' ') ]).join('\n'); + }; +}; + +wordwrap.soft = wordwrap; + +wordwrap.hard = function (start, stop) { + return wordwrap(start, stop, { mode : 'hard' }); +}; diff --git a/node_modules/cowsay/node_modules/optimist/node_modules/wordwrap/package.json b/node_modules/cowsay/node_modules/optimist/node_modules/wordwrap/package.json new file mode 100644 index 0000000..eb058bf --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/node_modules/wordwrap/package.json @@ -0,0 +1,63 @@ +{ + "name": "wordwrap", + "description": "Wrap those words. Show them at what columns to start and stop.", + "version": "0.0.3", + "repository": { + "type": "git", + "url": "git://github.com/substack/node-wordwrap.git" + }, + "main": "./index.js", + "keywords": [ + "word", + "wrap", + "rule", + "format", + "column" + ], + "directories": { + "lib": ".", + "example": "example", + "test": "test" + }, + "scripts": { + "test": "expresso" + }, + "devDependencies": { + "expresso": "=0.7.x" + }, + "engines": { + "node": ">=0.4.0" + }, + "license": "MIT", + "author": { + "name": "James Halliday", + "email": "mail@substack.net", + "url": "http://substack.net" + }, + "gitHead": "e59aa1bd338914019456bdfba034508c9c4cb29d", + "bugs": { + "url": "https://github.com/substack/node-wordwrap/issues" + }, + "homepage": "https://github.com/substack/node-wordwrap#readme", + "_id": "wordwrap@0.0.3", + "_shasum": "a3d5da6cd5c0bc0008d37234bbaf1bed63059107", + "_from": "wordwrap@>=0.0.2 <0.1.0", + "_npmVersion": "2.9.0", + "_nodeVersion": "2.0.0", + "_npmUser": { + "name": "substack", + "email": "substack@gmail.com" + }, + "dist": { + "shasum": "a3d5da6cd5c0bc0008d37234bbaf1bed63059107", + "tarball": "https://registry.npmjs.org/wordwrap/-/wordwrap-0.0.3.tgz" + }, + "maintainers": [ + { + "name": "substack", + "email": "mail@substack.net" + } + ], + "_resolved": "http://registry.npmjs.org/wordwrap/-/wordwrap-0.0.3.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/cowsay/node_modules/optimist/node_modules/wordwrap/test/break.js b/node_modules/cowsay/node_modules/optimist/node_modules/wordwrap/test/break.js new file mode 100644 index 0000000..749292e --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/node_modules/wordwrap/test/break.js @@ -0,0 +1,30 @@ +var assert = require('assert'); +var wordwrap = require('../'); + +exports.hard = function () { + var s = 'Assert from {"type":"equal","ok":false,"found":1,"wanted":2,' + + '"stack":[],"id":"b7ddcd4c409de8799542a74d1a04689b",' + + '"browser":"chrome/6.0"}' + ; + var s_ = wordwrap.hard(80)(s); + + var lines = s_.split('\n'); + assert.equal(lines.length, 2); + assert.ok(lines[0].length < 80); + assert.ok(lines[1].length < 80); + + assert.equal(s, s_.replace(/\n/g, '')); +}; + +exports.break = function () { + var s = new Array(55+1).join('a'); + var s_ = wordwrap.hard(20)(s); + + var lines = s_.split('\n'); + assert.equal(lines.length, 3); + assert.ok(lines[0].length === 20); + assert.ok(lines[1].length === 20); + assert.ok(lines[2].length === 15); + + assert.equal(s, s_.replace(/\n/g, '')); +}; diff --git a/node_modules/cowsay/node_modules/optimist/node_modules/wordwrap/test/idleness.txt b/node_modules/cowsay/node_modules/optimist/node_modules/wordwrap/test/idleness.txt new file mode 100644 index 0000000..aa3f490 --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/node_modules/wordwrap/test/idleness.txt @@ -0,0 +1,63 @@ +In Praise of Idleness + +By Bertrand Russell + +[1932] + +Like most of my generation, I was brought up on the saying: 'Satan finds some mischief for idle hands to do.' Being a highly virtuous child, I believed all that I was told, and acquired a conscience which has kept me working hard down to the present moment. But although my conscience has controlled my actions, my opinions have undergone a revolution. I think that there is far too much work done in the world, that immense harm is caused by the belief that work is virtuous, and that what needs to be preached in modern industrial countries is quite different from what always has been preached. Everyone knows the story of the traveler in Naples who saw twelve beggars lying in the sun (it was before the days of Mussolini), and offered a lira to the laziest of them. Eleven of them jumped up to claim it, so he gave it to the twelfth. this traveler was on the right lines. But in countries which do not enjoy Mediterranean sunshine idleness is more difficult, and a great public propaganda will be required to inaugurate it. I hope that, after reading the following pages, the leaders of the YMCA will start a campaign to induce good young men to do nothing. If so, I shall not have lived in vain. + +Before advancing my own arguments for laziness, I must dispose of one which I cannot accept. Whenever a person who already has enough to live on proposes to engage in some everyday kind of job, such as school-teaching or typing, he or she is told that such conduct takes the bread out of other people's mouths, and is therefore wicked. If this argument were valid, it would only be necessary for us all to be idle in order that we should all have our mouths full of bread. What people who say such things forget is that what a man earns he usually spends, and in spending he gives employment. As long as a man spends his income, he puts just as much bread into people's mouths in spending as he takes out of other people's mouths in earning. The real villain, from this point of view, is the man who saves. If he merely puts his savings in a stocking, like the proverbial French peasant, it is obvious that they do not give employment. If he invests his savings, the matter is less obvious, and different cases arise. + +One of the commonest things to do with savings is to lend them to some Government. In view of the fact that the bulk of the public expenditure of most civilized Governments consists in payment for past wars or preparation for future wars, the man who lends his money to a Government is in the same position as the bad men in Shakespeare who hire murderers. The net result of the man's economical habits is to increase the armed forces of the State to which he lends his savings. Obviously it would be better if he spent the money, even if he spent it in drink or gambling. + +But, I shall be told, the case is quite different when savings are invested in industrial enterprises. When such enterprises succeed, and produce something useful, this may be conceded. In these days, however, no one will deny that most enterprises fail. That means that a large amount of human labor, which might have been devoted to producing something that could be enjoyed, was expended on producing machines which, when produced, lay idle and did no good to anyone. The man who invests his savings in a concern that goes bankrupt is therefore injuring others as well as himself. If he spent his money, say, in giving parties for his friends, they (we may hope) would get pleasure, and so would all those upon whom he spent money, such as the butcher, the baker, and the bootlegger. But if he spends it (let us say) upon laying down rails for surface card in some place where surface cars turn out not to be wanted, he has diverted a mass of labor into channels where it gives pleasure to no one. Nevertheless, when he becomes poor through failure of his investment he will be regarded as a victim of undeserved misfortune, whereas the gay spendthrift, who has spent his money philanthropically, will be despised as a fool and a frivolous person. + +All this is only preliminary. I want to say, in all seriousness, that a great deal of harm is being done in the modern world by belief in the virtuousness of work, and that the road to happiness and prosperity lies in an organized diminution of work. + +First of all: what is work? Work is of two kinds: first, altering the position of matter at or near the earth's surface relatively to other such matter; second, telling other people to do so. The first kind is unpleasant and ill paid; the second is pleasant and highly paid. The second kind is capable of indefinite extension: there are not only those who give orders, but those who give advice as to what orders should be given. Usually two opposite kinds of advice are given simultaneously by two organized bodies of men; this is called politics. The skill required for this kind of work is not knowledge of the subjects as to which advice is given, but knowledge of the art of persuasive speaking and writing, i.e. of advertising. + +Throughout Europe, though not in America, there is a third class of men, more respected than either of the classes of workers. There are men who, through ownership of land, are able to make others pay for the privilege of being allowed to exist and to work. These landowners are idle, and I might therefore be expected to praise them. Unfortunately, their idleness is only rendered possible by the industry of others; indeed their desire for comfortable idleness is historically the source of the whole gospel of work. The last thing they have ever wished is that others should follow their example. + +From the beginning of civilization until the Industrial Revolution, a man could, as a rule, produce by hard work little more than was required for the subsistence of himself and his family, although his wife worked at least as hard as he did, and his children added their labor as soon as they were old enough to do so. The small surplus above bare necessaries was not left to those who produced it, but was appropriated by warriors and priests. In times of famine there was no surplus; the warriors and priests, however, still secured as much as at other times, with the result that many of the workers died of hunger. This system persisted in Russia until 1917 [1], and still persists in the East; in England, in spite of the Industrial Revolution, it remained in full force throughout the Napoleonic wars, and until a hundred years ago, when the new class of manufacturers acquired power. In America, the system came to an end with the Revolution, except in the South, where it persisted until the Civil War. A system which lasted so long and ended so recently has naturally left a profound impress upon men's thoughts and opinions. Much that we take for granted about the desirability of work is derived from this system, and, being pre-industrial, is not adapted to the modern world. Modern technique has made it possible for leisure, within limits, to be not the prerogative of small privileged classes, but a right evenly distributed throughout the community. The morality of work is the morality of slaves, and the modern world has no need of slavery. + +It is obvious that, in primitive communities, peasants, left to themselves, would not have parted with the slender surplus upon which the warriors and priests subsisted, but would have either produced less or consumed more. At first, sheer force compelled them to produce and part with the surplus. Gradually, however, it was found possible to induce many of them to accept an ethic according to which it was their duty to work hard, although part of their work went to support others in idleness. By this means the amount of compulsion required was lessened, and the expenses of government were diminished. To this day, 99 per cent of British wage-earners would be genuinely shocked if it were proposed that the King should not have a larger income than a working man. The conception of duty, speaking historically, has been a means used by the holders of power to induce others to live for the interests of their masters rather than for their own. Of course the holders of power conceal this fact from themselves by managing to believe that their interests are identical with the larger interests of humanity. Sometimes this is true; Athenian slave-owners, for instance, employed part of their leisure in making a permanent contribution to civilization which would have been impossible under a just economic system. Leisure is essential to civilization, and in former times leisure for the few was only rendered possible by the labors of the many. But their labors were valuable, not because work is good, but because leisure is good. And with modern technique it would be possible to distribute leisure justly without injury to civilization. + +Modern technique has made it possible to diminish enormously the amount of labor required to secure the necessaries of life for everyone. This was made obvious during the war. At that time all the men in the armed forces, and all the men and women engaged in the production of munitions, all the men and women engaged in spying, war propaganda, or Government offices connected with the war, were withdrawn from productive occupations. In spite of this, the general level of well-being among unskilled wage-earners on the side of the Allies was higher than before or since. The significance of this fact was concealed by finance: borrowing made it appear as if the future was nourishing the present. But that, of course, would have been impossible; a man cannot eat a loaf of bread that does not yet exist. The war showed conclusively that, by the scientific organization of production, it is possible to keep modern populations in fair comfort on a small part of the working capacity of the modern world. If, at the end of the war, the scientific organization, which had been created in order to liberate men for fighting and munition work, had been preserved, and the hours of the week had been cut down to four, all would have been well. Instead of that the old chaos was restored, those whose work was demanded were made to work long hours, and the rest were left to starve as unemployed. Why? Because work is a duty, and a man should not receive wages in proportion to what he has produced, but in proportion to his virtue as exemplified by his industry. + +This is the morality of the Slave State, applied in circumstances totally unlike those in which it arose. No wonder the result has been disastrous. Let us take an illustration. Suppose that, at a given moment, a certain number of people are engaged in the manufacture of pins. They make as many pins as the world needs, working (say) eight hours a day. Someone makes an invention by which the same number of men can make twice as many pins: pins are already so cheap that hardly any more will be bought at a lower price. In a sensible world, everybody concerned in the manufacturing of pins would take to working four hours instead of eight, and everything else would go on as before. But in the actual world this would be thought demoralizing. The men still work eight hours, there are too many pins, some employers go bankrupt, and half the men previously concerned in making pins are thrown out of work. There is, in the end, just as much leisure as on the other plan, but half the men are totally idle while half are still overworked. In this way, it is insured that the unavoidable leisure shall cause misery all round instead of being a universal source of happiness. Can anything more insane be imagined? + +The idea that the poor should have leisure has always been shocking to the rich. In England, in the early nineteenth century, fifteen hours was the ordinary day's work for a man; children sometimes did as much, and very commonly did twelve hours a day. When meddlesome busybodies suggested that perhaps these hours were rather long, they were told that work kept adults from drink and children from mischief. When I was a child, shortly after urban working men had acquired the vote, certain public holidays were established by law, to the great indignation of the upper classes. I remember hearing an old Duchess say: 'What do the poor want with holidays? They ought to work.' People nowadays are less frank, but the sentiment persists, and is the source of much of our economic confusion. + +Let us, for a moment, consider the ethics of work frankly, without superstition. Every human being, of necessity, consumes, in the course of his life, a certain amount of the produce of human labor. Assuming, as we may, that labor is on the whole disagreeable, it is unjust that a man should consume more than he produces. Of course he may provide services rather than commodities, like a medical man, for example; but he should provide something in return for his board and lodging. to this extent, the duty of work must be admitted, but to this extent only. + +I shall not dwell upon the fact that, in all modern societies outside the USSR, many people escape even this minimum amount of work, namely all those who inherit money and all those who marry money. I do not think the fact that these people are allowed to be idle is nearly so harmful as the fact that wage-earners are expected to overwork or starve. + +If the ordinary wage-earner worked four hours a day, there would be enough for everybody and no unemployment -- assuming a certain very moderate amount of sensible organization. This idea shocks the well-to-do, because they are convinced that the poor would not know how to use so much leisure. In America men often work long hours even when they are well off; such men, naturally, are indignant at the idea of leisure for wage-earners, except as the grim punishment of unemployment; in fact, they dislike leisure even for their sons. Oddly enough, while they wish their sons to work so hard as to have no time to be civilized, they do not mind their wives and daughters having no work at all. the snobbish admiration of uselessness, which, in an aristocratic society, extends to both sexes, is, under a plutocracy, confined to women; this, however, does not make it any more in agreement with common sense. + +The wise use of leisure, it must be conceded, is a product of civilization and education. A man who has worked long hours all his life will become bored if he becomes suddenly idle. But without a considerable amount of leisure a man is cut off from many of the best things. There is no longer any reason why the bulk of the population should suffer this deprivation; only a foolish asceticism, usually vicarious, makes us continue to insist on work in excessive quantities now that the need no longer exists. + +In the new creed which controls the government of Russia, while there is much that is very different from the traditional teaching of the West, there are some things that are quite unchanged. The attitude of the governing classes, and especially of those who conduct educational propaganda, on the subject of the dignity of labor, is almost exactly that which the governing classes of the world have always preached to what were called the 'honest poor'. Industry, sobriety, willingness to work long hours for distant advantages, even submissiveness to authority, all these reappear; moreover authority still represents the will of the Ruler of the Universe, Who, however, is now called by a new name, Dialectical Materialism. + +The victory of the proletariat in Russia has some points in common with the victory of the feminists in some other countries. For ages, men had conceded the superior saintliness of women, and had consoled women for their inferiority by maintaining that saintliness is more desirable than power. At last the feminists decided that they would have both, since the pioneers among them believed all that the men had told them about the desirability of virtue, but not what they had told them about the worthlessness of political power. A similar thing has happened in Russia as regards manual work. For ages, the rich and their sycophants have written in praise of 'honest toil', have praised the simple life, have professed a religion which teaches that the poor are much more likely to go to heaven than the rich, and in general have tried to make manual workers believe that there is some special nobility about altering the position of matter in space, just as men tried to make women believe that they derived some special nobility from their sexual enslavement. In Russia, all this teaching about the excellence of manual work has been taken seriously, with the result that the manual worker is more honored than anyone else. What are, in essence, revivalist appeals are made, but not for the old purposes: they are made to secure shock workers for special tasks. Manual work is the ideal which is held before the young, and is the basis of all ethical teaching. + +For the present, possibly, this is all to the good. A large country, full of natural resources, awaits development, and has has to be developed with very little use of credit. In these circumstances, hard work is necessary, and is likely to bring a great reward. But what will happen when the point has been reached where everybody could be comfortable without working long hours? + +In the West, we have various ways of dealing with this problem. We have no attempt at economic justice, so that a large proportion of the total produce goes to a small minority of the population, many of whom do no work at all. Owing to the absence of any central control over production, we produce hosts of things that are not wanted. We keep a large percentage of the working population idle, because we can dispense with their labor by making the others overwork. When all these methods prove inadequate, we have a war: we cause a number of people to manufacture high explosives, and a number of others to explode them, as if we were children who had just discovered fireworks. By a combination of all these devices we manage, though with difficulty, to keep alive the notion that a great deal of severe manual work must be the lot of the average man. + +In Russia, owing to more economic justice and central control over production, the problem will have to be differently solved. the rational solution would be, as soon as the necessaries and elementary comforts can be provided for all, to reduce the hours of labor gradually, allowing a popular vote to decide, at each stage, whether more leisure or more goods were to be preferred. But, having taught the supreme virtue of hard work, it is difficult to see how the authorities can aim at a paradise in which there will be much leisure and little work. It seems more likely that they will find continually fresh schemes, by which present leisure is to be sacrificed to future productivity. I read recently of an ingenious plan put forward by Russian engineers, for making the White Sea and the northern coasts of Siberia warm, by putting a dam across the Kara Sea. An admirable project, but liable to postpone proletarian comfort for a generation, while the nobility of toil is being displayed amid the ice-fields and snowstorms of the Arctic Ocean. This sort of thing, if it happens, will be the result of regarding the virtue of hard work as an end in itself, rather than as a means to a state of affairs in which it is no longer needed. + +The fact is that moving matter about, while a certain amount of it is necessary to our existence, is emphatically not one of the ends of human life. If it were, we should have to consider every navvy superior to Shakespeare. We have been misled in this matter by two causes. One is the necessity of keeping the poor contented, which has led the rich, for thousands of years, to preach the dignity of labor, while taking care themselves to remain undignified in this respect. The other is the new pleasure in mechanism, which makes us delight in the astonishingly clever changes that we can produce on the earth's surface. Neither of these motives makes any great appeal to the actual worker. If you ask him what he thinks the best part of his life, he is not likely to say: 'I enjoy manual work because it makes me feel that I am fulfilling man's noblest task, and because I like to think how much man can transform his planet. It is true that my body demands periods of rest, which I have to fill in as best I may, but I am never so happy as when the morning comes and I can return to the toil from which my contentment springs.' I have never heard working men say this sort of thing. They consider work, as it should be considered, a necessary means to a livelihood, and it is from their leisure that they derive whatever happiness they may enjoy. + +It will be said that, while a little leisure is pleasant, men would not know how to fill their days if they had only four hours of work out of the twenty-four. In so far as this is true in the modern world, it is a condemnation of our civilization; it would not have been true at any earlier period. There was formerly a capacity for light-heartedness and play which has been to some extent inhibited by the cult of efficiency. The modern man thinks that everything ought to be done for the sake of something else, and never for its own sake. Serious-minded persons, for example, are continually condemning the habit of going to the cinema, and telling us that it leads the young into crime. But all the work that goes to producing a cinema is respectable, because it is work, and because it brings a money profit. The notion that the desirable activities are those that bring a profit has made everything topsy-turvy. The butcher who provides you with meat and the baker who provides you with bread are praiseworthy, because they are making money; but when you enjoy the food they have provided, you are merely frivolous, unless you eat only to get strength for your work. Broadly speaking, it is held that getting money is good and spending money is bad. Seeing that they are two sides of one transaction, this is absurd; one might as well maintain that keys are good, but keyholes are bad. Whatever merit there may be in the production of goods must be entirely derivative from the advantage to be obtained by consuming them. The individual, in our society, works for profit; but the social purpose of his work lies in the consumption of what he produces. It is this divorce between the individual and the social purpose of production that makes it so difficult for men to think clearly in a world in which profit-making is the incentive to industry. We think too much of production, and too little of consumption. One result is that we attach too little importance to enjoyment and simple happiness, and that we do not judge production by the pleasure that it gives to the consumer. + +When I suggest that working hours should be reduced to four, I am not meaning to imply that all the remaining time should necessarily be spent in pure frivolity. I mean that four hours' work a day should entitle a man to the necessities and elementary comforts of life, and that the rest of his time should be his to use as he might see fit. It is an essential part of any such social system that education should be carried further than it usually is at present, and should aim, in part, at providing tastes which would enable a man to use leisure intelligently. I am not thinking mainly of the sort of things that would be considered 'highbrow'. Peasant dances have died out except in remote rural areas, but the impulses which caused them to be cultivated must still exist in human nature. The pleasures of urban populations have become mainly passive: seeing cinemas, watching football matches, listening to the radio, and so on. This results from the fact that their active energies are fully taken up with work; if they had more leisure, they would again enjoy pleasures in which they took an active part. + +In the past, there was a small leisure class and a larger working class. The leisure class enjoyed advantages for which there was no basis in social justice; this necessarily made it oppressive, limited its sympathies, and caused it to invent theories by which to justify its privileges. These facts greatly diminished its excellence, but in spite of this drawback it contributed nearly the whole of what we call civilization. It cultivated the arts and discovered the sciences; it wrote the books, invented the philosophies, and refined social relations. Even the liberation of the oppressed has usually been inaugurated from above. Without the leisure class, mankind would never have emerged from barbarism. + +The method of a leisure class without duties was, however, extraordinarily wasteful. None of the members of the class had to be taught to be industrious, and the class as a whole was not exceptionally intelligent. The class might produce one Darwin, but against him had to be set tens of thousands of country gentlemen who never thought of anything more intelligent than fox-hunting and punishing poachers. At present, the universities are supposed to provide, in a more systematic way, what the leisure class provided accidentally and as a by-product. This is a great improvement, but it has certain drawbacks. University life is so different from life in the world at large that men who live in academic milieu tend to be unaware of the preoccupations and problems of ordinary men and women; moreover their ways of expressing themselves are usually such as to rob their opinions of the influence that they ought to have upon the general public. Another disadvantage is that in universities studies are organized, and the man who thinks of some original line of research is likely to be discouraged. Academic institutions, therefore, useful as they are, are not adequate guardians of the interests of civilization in a world where everyone outside their walls is too busy for unutilitarian pursuits. + +In a world where no one is compelled to work more than four hours a day, every person possessed of scientific curiosity will be able to indulge it, and every painter will be able to paint without starving, however excellent his pictures may be. Young writers will not be obliged to draw attention to themselves by sensational pot-boilers, with a view to acquiring the economic independence needed for monumental works, for which, when the time at last comes, they will have lost the taste and capacity. Men who, in their professional work, have become interested in some phase of economics or government, will be able to develop their ideas without the academic detachment that makes the work of university economists often seem lacking in reality. Medical men will have the time to learn about the progress of medicine, teachers will not be exasperatedly struggling to teach by routine methods things which they learnt in their youth, which may, in the interval, have been proved to be untrue. + +Above all, there will be happiness and joy of life, instead of frayed nerves, weariness, and dyspepsia. The work exacted will be enough to make leisure delightful, but not enough to produce exhaustion. Since men will not be tired in their spare time, they will not demand only such amusements as are passive and vapid. At least one per cent will probably devote the time not spent in professional work to pursuits of some public importance, and, since they will not depend upon these pursuits for their livelihood, their originality will be unhampered, and there will be no need to conform to the standards set by elderly pundits. But it is not only in these exceptional cases that the advantages of leisure will appear. Ordinary men and women, having the opportunity of a happy life, will become more kindly and less persecuting and less inclined to view others with suspicion. The taste for war will die out, partly for this reason, and partly because it will involve long and severe work for all. Good nature is, of all moral qualities, the one that the world needs most, and good nature is the result of ease and security, not of a life of arduous struggle. Modern methods of production have given us the possibility of ease and security for all; we have chosen, instead, to have overwork for some and starvation for others. Hitherto we have continued to be as energetic as we were before there were machines; in this we have been foolish, but there is no reason to go on being foolish forever. + +[1] Since then, members of the Communist Party have succeeded to this privilege of the warriors and priests. diff --git a/node_modules/cowsay/node_modules/optimist/node_modules/wordwrap/test/wrap.js b/node_modules/cowsay/node_modules/optimist/node_modules/wordwrap/test/wrap.js new file mode 100644 index 0000000..0cfb76d --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/node_modules/wordwrap/test/wrap.js @@ -0,0 +1,31 @@ +var assert = require('assert'); +var wordwrap = require('wordwrap'); + +var fs = require('fs'); +var idleness = fs.readFileSync(__dirname + '/idleness.txt', 'utf8'); + +exports.stop80 = function () { + var lines = wordwrap(80)(idleness).split(/\n/); + var words = idleness.split(/\s+/); + + lines.forEach(function (line) { + assert.ok(line.length <= 80, 'line > 80 columns'); + var chunks = line.match(/\S/) ? line.split(/\s+/) : []; + assert.deepEqual(chunks, words.splice(0, chunks.length)); + }); +}; + +exports.start20stop60 = function () { + var lines = wordwrap(20, 100)(idleness).split(/\n/); + var words = idleness.split(/\s+/); + + lines.forEach(function (line) { + assert.ok(line.length <= 100, 'line > 100 columns'); + var chunks = line + .split(/\s+/) + .filter(function (x) { return x.match(/\S/) }) + ; + assert.deepEqual(chunks, words.splice(0, chunks.length)); + assert.deepEqual(line.slice(0, 20), new Array(20 + 1).join(' ')); + }); +}; diff --git a/node_modules/cowsay/node_modules/optimist/package.json b/node_modules/cowsay/node_modules/optimist/package.json new file mode 100644 index 0000000..08c181f --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/package.json @@ -0,0 +1,64 @@ +{ + "name": "optimist", + "version": "0.6.1", + "description": "Light-weight option parsing with an argv hash. No optstrings attached.", + "main": "./index.js", + "dependencies": { + "wordwrap": "~0.0.2", + "minimist": "~0.0.1" + }, + "devDependencies": { + "hashish": "~0.0.4", + "tap": "~0.4.0" + }, + "scripts": { + "test": "tap ./test/*.js" + }, + "repository": { + "type": "git", + "url": "git+ssh://git@github.com/substack/node-optimist.git" + }, + "keywords": [ + "argument", + "args", + "option", + "parser", + "parsing", + "cli", + "command" + ], + "author": { + "name": "James Halliday", + "email": "mail@substack.net", + "url": "http://substack.net" + }, + "license": "MIT/X11", + "engine": { + "node": ">=0.4" + }, + "bugs": { + "url": "https://github.com/substack/node-optimist/issues" + }, + "homepage": "https://github.com/substack/node-optimist", + "_id": "optimist@0.6.1", + "dist": { + "shasum": "da3ea74686fa21a19a111c326e90eb15a0196686", + "tarball": "https://registry.npmjs.org/optimist/-/optimist-0.6.1.tgz" + }, + "_from": "optimist@>=0.6.1 <0.7.0", + "_npmVersion": "1.3.21", + "_npmUser": { + "name": "substack", + "email": "mail@substack.net" + }, + "maintainers": [ + { + "name": "substack", + "email": "mail@substack.net" + } + ], + "directories": {}, + "_shasum": "da3ea74686fa21a19a111c326e90eb15a0196686", + "_resolved": "http://registry.npmjs.org/optimist/-/optimist-0.6.1.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/cowsay/node_modules/optimist/readme.markdown b/node_modules/cowsay/node_modules/optimist/readme.markdown new file mode 100644 index 0000000..b74b437 --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/readme.markdown @@ -0,0 +1,513 @@ +# DEPRECATION NOTICE + +I don't want to maintain this module anymore since I just use +[minimist](https://npmjs.org/package/minimist), the argument parsing engine, +directly instead nowadays. + +See [yargs](https://github.com/chevex/yargs) for the modern, pirate-themed +successor to optimist. + +[![yarrrrrrrgs!](http://i.imgur.com/4WFGVJ9.png)](https://github.com/chevex/yargs) + +You should also consider [nomnom](https://github.com/harthur/nomnom). + +optimist +======== + +Optimist is a node.js library for option parsing for people who hate option +parsing. More specifically, this module is for people who like all the --bells +and -whistlz of program usage but think optstrings are a waste of time. + +With optimist, option parsing doesn't have to suck (as much). + +[![build status](https://secure.travis-ci.org/substack/node-optimist.png)](http://travis-ci.org/substack/node-optimist) + +examples +======== + +With Optimist, the options are just a hash! No optstrings attached. +------------------------------------------------------------------- + +xup.js: + +````javascript +#!/usr/bin/env node +var argv = require('optimist').argv; + +if (argv.rif - 5 * argv.xup > 7.138) { + console.log('Buy more riffiwobbles'); +} +else { + console.log('Sell the xupptumblers'); +} +```` + +*** + + $ ./xup.js --rif=55 --xup=9.52 + Buy more riffiwobbles + + $ ./xup.js --rif 12 --xup 8.1 + Sell the xupptumblers + +![This one's optimistic.](http://substack.net/images/optimistic.png) + +But wait! There's more! You can do short options: +------------------------------------------------- + +short.js: + +````javascript +#!/usr/bin/env node +var argv = require('optimist').argv; +console.log('(%d,%d)', argv.x, argv.y); +```` + +*** + + $ ./short.js -x 10 -y 21 + (10,21) + +And booleans, both long and short (and grouped): +---------------------------------- + +bool.js: + +````javascript +#!/usr/bin/env node +var util = require('util'); +var argv = require('optimist').argv; + +if (argv.s) { + util.print(argv.fr ? 'Le chat dit: ' : 'The cat says: '); +} +console.log( + (argv.fr ? 'miaou' : 'meow') + (argv.p ? '.' : '') +); +```` + +*** + + $ ./bool.js -s + The cat says: meow + + $ ./bool.js -sp + The cat says: meow. + + $ ./bool.js -sp --fr + Le chat dit: miaou. + +And non-hypenated options too! Just use `argv._`! +------------------------------------------------- + +nonopt.js: + +````javascript +#!/usr/bin/env node +var argv = require('optimist').argv; +console.log('(%d,%d)', argv.x, argv.y); +console.log(argv._); +```` + +*** + + $ ./nonopt.js -x 6.82 -y 3.35 moo + (6.82,3.35) + [ 'moo' ] + + $ ./nonopt.js foo -x 0.54 bar -y 1.12 baz + (0.54,1.12) + [ 'foo', 'bar', 'baz' ] + +Plus, Optimist comes with .usage() and .demand()! +------------------------------------------------- + +divide.js: + +````javascript +#!/usr/bin/env node +var argv = require('optimist') + .usage('Usage: $0 -x [num] -y [num]') + .demand(['x','y']) + .argv; + +console.log(argv.x / argv.y); +```` + +*** + + $ ./divide.js -x 55 -y 11 + 5 + + $ node ./divide.js -x 4.91 -z 2.51 + Usage: node ./divide.js -x [num] -y [num] + + Options: + -x [required] + -y [required] + + Missing required arguments: y + +EVEN MORE HOLY COW +------------------ + +default_singles.js: + +````javascript +#!/usr/bin/env node +var argv = require('optimist') + .default('x', 10) + .default('y', 10) + .argv +; +console.log(argv.x + argv.y); +```` + +*** + + $ ./default_singles.js -x 5 + 15 + +default_hash.js: + +````javascript +#!/usr/bin/env node +var argv = require('optimist') + .default({ x : 10, y : 10 }) + .argv +; +console.log(argv.x + argv.y); +```` + +*** + + $ ./default_hash.js -y 7 + 17 + +And if you really want to get all descriptive about it... +--------------------------------------------------------- + +boolean_single.js + +````javascript +#!/usr/bin/env node +var argv = require('optimist') + .boolean('v') + .argv +; +console.dir(argv); +```` + +*** + + $ ./boolean_single.js -v foo bar baz + true + [ 'bar', 'baz', 'foo' ] + +boolean_double.js + +````javascript +#!/usr/bin/env node +var argv = require('optimist') + .boolean(['x','y','z']) + .argv +; +console.dir([ argv.x, argv.y, argv.z ]); +console.dir(argv._); +```` + +*** + + $ ./boolean_double.js -x -z one two three + [ true, false, true ] + [ 'one', 'two', 'three' ] + +Optimist is here to help... +--------------------------- + +You can describe parameters for help messages and set aliases. Optimist figures +out how to format a handy help string automatically. + +line_count.js + +````javascript +#!/usr/bin/env node +var argv = require('optimist') + .usage('Count the lines in a file.\nUsage: $0') + .demand('f') + .alias('f', 'file') + .describe('f', 'Load a file') + .argv +; + +var fs = require('fs'); +var s = fs.createReadStream(argv.file); + +var lines = 0; +s.on('data', function (buf) { + lines += buf.toString().match(/\n/g).length; +}); + +s.on('end', function () { + console.log(lines); +}); +```` + +*** + + $ node line_count.js + Count the lines in a file. + Usage: node ./line_count.js + + Options: + -f, --file Load a file [required] + + Missing required arguments: f + + $ node line_count.js --file line_count.js + 20 + + $ node line_count.js -f line_count.js + 20 + +methods +======= + +By itself, + +````javascript +require('optimist').argv +````` + +will use `process.argv` array to construct the `argv` object. + +You can pass in the `process.argv` yourself: + +````javascript +require('optimist')([ '-x', '1', '-y', '2' ]).argv +```` + +or use .parse() to do the same thing: + +````javascript +require('optimist').parse([ '-x', '1', '-y', '2' ]) +```` + +The rest of these methods below come in just before the terminating `.argv`. + +.alias(key, alias) +------------------ + +Set key names as equivalent such that updates to a key will propagate to aliases +and vice-versa. + +Optionally `.alias()` can take an object that maps keys to aliases. + +.default(key, value) +-------------------- + +Set `argv[key]` to `value` if no option was specified on `process.argv`. + +Optionally `.default()` can take an object that maps keys to default values. + +.demand(key) +------------ + +If `key` is a string, show the usage information and exit if `key` wasn't +specified in `process.argv`. + +If `key` is a number, demand at least as many non-option arguments, which show +up in `argv._`. + +If `key` is an Array, demand each element. + +.describe(key, desc) +-------------------- + +Describe a `key` for the generated usage information. + +Optionally `.describe()` can take an object that maps keys to descriptions. + +.options(key, opt) +------------------ + +Instead of chaining together `.alias().demand().default()`, you can specify +keys in `opt` for each of the chainable methods. + +For example: + +````javascript +var argv = require('optimist') + .options('f', { + alias : 'file', + default : '/etc/passwd', + }) + .argv +; +```` + +is the same as + +````javascript +var argv = require('optimist') + .alias('f', 'file') + .default('f', '/etc/passwd') + .argv +; +```` + +Optionally `.options()` can take an object that maps keys to `opt` parameters. + +.usage(message) +--------------- + +Set a usage message to show which commands to use. Inside `message`, the string +`$0` will get interpolated to the current script name or node command for the +present script similar to how `$0` works in bash or perl. + +.check(fn) +---------- + +Check that certain conditions are met in the provided arguments. + +If `fn` throws or returns `false`, show the thrown error, usage information, and +exit. + +.boolean(key) +------------- + +Interpret `key` as a boolean. If a non-flag option follows `key` in +`process.argv`, that string won't get set as the value of `key`. + +If `key` never shows up as a flag in `process.arguments`, `argv[key]` will be +`false`. + +If `key` is an Array, interpret all the elements as booleans. + +.string(key) +------------ + +Tell the parser logic not to interpret `key` as a number or boolean. +This can be useful if you need to preserve leading zeros in an input. + +If `key` is an Array, interpret all the elements as strings. + +.wrap(columns) +-------------- + +Format usage output to wrap at `columns` many columns. + +.help() +------- + +Return the generated usage string. + +.showHelp(fn=console.error) +--------------------------- + +Print the usage data using `fn` for printing. + +.parse(args) +------------ + +Parse `args` instead of `process.argv`. Returns the `argv` object. + +.argv +----- + +Get the arguments as a plain old object. + +Arguments without a corresponding flag show up in the `argv._` array. + +The script name or node command is available at `argv.$0` similarly to how `$0` +works in bash or perl. + +parsing tricks +============== + +stop parsing +------------ + +Use `--` to stop parsing flags and stuff the remainder into `argv._`. + + $ node examples/reflect.js -a 1 -b 2 -- -c 3 -d 4 + { _: [ '-c', '3', '-d', '4' ], + '$0': 'node ./examples/reflect.js', + a: 1, + b: 2 } + +negate fields +------------- + +If you want to explicity set a field to false instead of just leaving it +undefined or to override a default you can do `--no-key`. + + $ node examples/reflect.js -a --no-b + { _: [], + '$0': 'node ./examples/reflect.js', + a: true, + b: false } + +numbers +------- + +Every argument that looks like a number (`!isNaN(Number(arg))`) is converted to +one. This way you can just `net.createConnection(argv.port)` and you can add +numbers out of `argv` with `+` without having that mean concatenation, +which is super frustrating. + +duplicates +---------- + +If you specify a flag multiple times it will get turned into an array containing +all the values in order. + + $ node examples/reflect.js -x 5 -x 8 -x 0 + { _: [], + '$0': 'node ./examples/reflect.js', + x: [ 5, 8, 0 ] } + +dot notation +------------ + +When you use dots (`.`s) in argument names, an implicit object path is assumed. +This lets you organize arguments into nested objects. + + $ node examples/reflect.js --foo.bar.baz=33 --foo.quux=5 + { _: [], + '$0': 'node ./examples/reflect.js', + foo: { bar: { baz: 33 }, quux: 5 } } + +short numbers +------------- + +Short numeric `head -n5` style argument work too: + + $ node reflect.js -n123 -m456 + { '3': true, + '6': true, + _: [], + '$0': 'node ./reflect.js', + n: 123, + m: 456 } + +installation +============ + +With [npm](http://github.com/isaacs/npm), just do: + npm install optimist + +or clone this project on github: + + git clone http://github.com/substack/node-optimist.git + +To run the tests with [expresso](http://github.com/visionmedia/expresso), +just do: + + expresso + +inspired By +=========== + +This module is loosely inspired by Perl's +[Getopt::Casual](http://search.cpan.org/~photo/Getopt-Casual-0.13.1/Casual.pm). diff --git a/node_modules/cowsay/node_modules/optimist/test/_.js b/node_modules/cowsay/node_modules/optimist/test/_.js new file mode 100644 index 0000000..d9c58b3 --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/test/_.js @@ -0,0 +1,71 @@ +var spawn = require('child_process').spawn; +var test = require('tap').test; + +test('dotSlashEmpty', testCmd('./bin.js', [])); + +test('dotSlashArgs', testCmd('./bin.js', [ 'a', 'b', 'c' ])); + +test('nodeEmpty', testCmd('node bin.js', [])); + +test('nodeArgs', testCmd('node bin.js', [ 'x', 'y', 'z' ])); + +test('whichNodeEmpty', function (t) { + var which = spawn('which', ['node']); + + which.stdout.on('data', function (buf) { + t.test( + testCmd(buf.toString().trim() + ' bin.js', []) + ); + t.end(); + }); + + which.stderr.on('data', function (err) { + assert.error(err); + t.end(); + }); +}); + +test('whichNodeArgs', function (t) { + var which = spawn('which', ['node']); + + which.stdout.on('data', function (buf) { + t.test( + testCmd(buf.toString().trim() + ' bin.js', [ 'q', 'r' ]) + ); + t.end(); + }); + + which.stderr.on('data', function (err) { + t.error(err); + t.end(); + }); +}); + +function testCmd (cmd, args) { + + return function (t) { + var to = setTimeout(function () { + assert.fail('Never got stdout data.') + }, 5000); + + var oldDir = process.cwd(); + process.chdir(__dirname + '/_'); + + var cmds = cmd.split(' '); + + var bin = spawn(cmds[0], cmds.slice(1).concat(args.map(String))); + process.chdir(oldDir); + + bin.stderr.on('data', function (err) { + t.error(err); + t.end(); + }); + + bin.stdout.on('data', function (buf) { + clearTimeout(to); + var _ = JSON.parse(buf.toString()); + t.same(_.map(String), args.map(String)); + t.end(); + }); + }; +} diff --git a/node_modules/cowsay/node_modules/optimist/test/_/argv.js b/node_modules/cowsay/node_modules/optimist/test/_/argv.js new file mode 100644 index 0000000..3d09606 --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/test/_/argv.js @@ -0,0 +1,2 @@ +#!/usr/bin/env node +console.log(JSON.stringify(process.argv)); diff --git a/node_modules/cowsay/node_modules/optimist/test/_/bin.js b/node_modules/cowsay/node_modules/optimist/test/_/bin.js new file mode 100644 index 0000000..4a18d85 --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/test/_/bin.js @@ -0,0 +1,3 @@ +#!/usr/bin/env node +var argv = require('../../index').argv +console.log(JSON.stringify(argv._)); diff --git a/node_modules/cowsay/node_modules/optimist/test/dash.js b/node_modules/cowsay/node_modules/optimist/test/dash.js new file mode 100644 index 0000000..af8ed6f --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/test/dash.js @@ -0,0 +1,31 @@ +var optimist = require('../index'); +var test = require('tap').test; + +test('-', function (t) { + t.plan(5); + t.deepEqual( + fix(optimist.parse([ '-n', '-' ])), + { n: '-', _: [] } + ); + t.deepEqual( + fix(optimist.parse([ '-' ])), + { _: [ '-' ] } + ); + t.deepEqual( + fix(optimist.parse([ '-f-' ])), + { f: '-', _: [] } + ); + t.deepEqual( + fix(optimist([ '-b', '-' ]).boolean('b').argv), + { b: true, _: [ '-' ] } + ); + t.deepEqual( + fix(optimist([ '-s', '-' ]).string('s').argv), + { s: '-', _: [] } + ); +}); + +function fix (obj) { + delete obj.$0; + return obj; +} diff --git a/node_modules/cowsay/node_modules/optimist/test/parse.js b/node_modules/cowsay/node_modules/optimist/test/parse.js new file mode 100644 index 0000000..d320f43 --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/test/parse.js @@ -0,0 +1,446 @@ +var optimist = require('../index'); +var path = require('path'); +var test = require('tap').test; + +var $0 = 'node ./' + path.relative(process.cwd(), __filename); + +test('short boolean', function (t) { + var parse = optimist.parse([ '-b' ]); + t.same(parse, { b : true, _ : [], $0 : $0 }); + t.same(typeof parse.b, 'boolean'); + t.end(); +}); + +test('long boolean', function (t) { + t.same( + optimist.parse([ '--bool' ]), + { bool : true, _ : [], $0 : $0 } + ); + t.end(); +}); + +test('bare', function (t) { + t.same( + optimist.parse([ 'foo', 'bar', 'baz' ]), + { _ : [ 'foo', 'bar', 'baz' ], $0 : $0 } + ); + t.end(); +}); + +test('short group', function (t) { + t.same( + optimist.parse([ '-cats' ]), + { c : true, a : true, t : true, s : true, _ : [], $0 : $0 } + ); + t.end(); +}); + +test('short group next', function (t) { + t.same( + optimist.parse([ '-cats', 'meow' ]), + { c : true, a : true, t : true, s : 'meow', _ : [], $0 : $0 } + ); + t.end(); +}); + +test('short capture', function (t) { + t.same( + optimist.parse([ '-h', 'localhost' ]), + { h : 'localhost', _ : [], $0 : $0 } + ); + t.end(); +}); + +test('short captures', function (t) { + t.same( + optimist.parse([ '-h', 'localhost', '-p', '555' ]), + { h : 'localhost', p : 555, _ : [], $0 : $0 } + ); + t.end(); +}); + +test('long capture sp', function (t) { + t.same( + optimist.parse([ '--pow', 'xixxle' ]), + { pow : 'xixxle', _ : [], $0 : $0 } + ); + t.end(); +}); + +test('long capture eq', function (t) { + t.same( + optimist.parse([ '--pow=xixxle' ]), + { pow : 'xixxle', _ : [], $0 : $0 } + ); + t.end() +}); + +test('long captures sp', function (t) { + t.same( + optimist.parse([ '--host', 'localhost', '--port', '555' ]), + { host : 'localhost', port : 555, _ : [], $0 : $0 } + ); + t.end(); +}); + +test('long captures eq', function (t) { + t.same( + optimist.parse([ '--host=localhost', '--port=555' ]), + { host : 'localhost', port : 555, _ : [], $0 : $0 } + ); + t.end(); +}); + +test('mixed short bool and capture', function (t) { + t.same( + optimist.parse([ '-h', 'localhost', '-fp', '555', 'script.js' ]), + { + f : true, p : 555, h : 'localhost', + _ : [ 'script.js' ], $0 : $0, + } + ); + t.end(); +}); + +test('short and long', function (t) { + t.same( + optimist.parse([ '-h', 'localhost', '-fp', '555', 'script.js' ]), + { + f : true, p : 555, h : 'localhost', + _ : [ 'script.js' ], $0 : $0, + } + ); + t.end(); +}); + +test('no', function (t) { + t.same( + optimist.parse([ '--no-moo' ]), + { moo : false, _ : [], $0 : $0 } + ); + t.end(); +}); + +test('multi', function (t) { + t.same( + optimist.parse([ '-v', 'a', '-v', 'b', '-v', 'c' ]), + { v : ['a','b','c'], _ : [], $0 : $0 } + ); + t.end(); +}); + +test('comprehensive', function (t) { + t.same( + optimist.parse([ + '--name=meowmers', 'bare', '-cats', 'woo', + '-h', 'awesome', '--multi=quux', + '--key', 'value', + '-b', '--bool', '--no-meep', '--multi=baz', + '--', '--not-a-flag', 'eek' + ]), + { + c : true, + a : true, + t : true, + s : 'woo', + h : 'awesome', + b : true, + bool : true, + key : 'value', + multi : [ 'quux', 'baz' ], + meep : false, + name : 'meowmers', + _ : [ 'bare', '--not-a-flag', 'eek' ], + $0 : $0 + } + ); + t.end(); +}); + +test('nums', function (t) { + var argv = optimist.parse([ + '-x', '1234', + '-y', '5.67', + '-z', '1e7', + '-w', '10f', + '--hex', '0xdeadbeef', + '789', + ]); + t.same(argv, { + x : 1234, + y : 5.67, + z : 1e7, + w : '10f', + hex : 0xdeadbeef, + _ : [ 789 ], + $0 : $0 + }); + t.same(typeof argv.x, 'number'); + t.same(typeof argv.y, 'number'); + t.same(typeof argv.z, 'number'); + t.same(typeof argv.w, 'string'); + t.same(typeof argv.hex, 'number'); + t.same(typeof argv._[0], 'number'); + t.end(); +}); + +test('flag boolean', function (t) { + var parse = optimist([ '-t', 'moo' ]).boolean(['t']).argv; + t.same(parse, { t : true, _ : [ 'moo' ], $0 : $0 }); + t.same(typeof parse.t, 'boolean'); + t.end(); +}); + +test('flag boolean value', function (t) { + var parse = optimist(['--verbose', 'false', 'moo', '-t', 'true']) + .boolean(['t', 'verbose']).default('verbose', true).argv; + + t.same(parse, { + verbose: false, + t: true, + _: ['moo'], + $0 : $0 + }); + + t.same(typeof parse.verbose, 'boolean'); + t.same(typeof parse.t, 'boolean'); + t.end(); +}); + +test('flag boolean default false', function (t) { + var parse = optimist(['moo']) + .boolean(['t', 'verbose']) + .default('verbose', false) + .default('t', false).argv; + + t.same(parse, { + verbose: false, + t: false, + _: ['moo'], + $0 : $0 + }); + + t.same(typeof parse.verbose, 'boolean'); + t.same(typeof parse.t, 'boolean'); + t.end(); + +}); + +test('boolean groups', function (t) { + var parse = optimist([ '-x', '-z', 'one', 'two', 'three' ]) + .boolean(['x','y','z']).argv; + + t.same(parse, { + x : true, + y : false, + z : true, + _ : [ 'one', 'two', 'three' ], + $0 : $0 + }); + + t.same(typeof parse.x, 'boolean'); + t.same(typeof parse.y, 'boolean'); + t.same(typeof parse.z, 'boolean'); + t.end(); +}); + +test('newlines in params' , function (t) { + var args = optimist.parse([ '-s', "X\nX" ]) + t.same(args, { _ : [], s : "X\nX", $0 : $0 }); + + // reproduce in bash: + // VALUE="new + // line" + // node program.js --s="$VALUE" + args = optimist.parse([ "--s=X\nX" ]) + t.same(args, { _ : [], s : "X\nX", $0 : $0 }); + t.end(); +}); + +test('strings' , function (t) { + var s = optimist([ '-s', '0001234' ]).string('s').argv.s; + t.same(s, '0001234'); + t.same(typeof s, 'string'); + + var x = optimist([ '-x', '56' ]).string('x').argv.x; + t.same(x, '56'); + t.same(typeof x, 'string'); + t.end(); +}); + +test('stringArgs', function (t) { + var s = optimist([ ' ', ' ' ]).string('_').argv._; + t.same(s.length, 2); + t.same(typeof s[0], 'string'); + t.same(s[0], ' '); + t.same(typeof s[1], 'string'); + t.same(s[1], ' '); + t.end(); +}); + +test('slashBreak', function (t) { + t.same( + optimist.parse([ '-I/foo/bar/baz' ]), + { I : '/foo/bar/baz', _ : [], $0 : $0 } + ); + t.same( + optimist.parse([ '-xyz/foo/bar/baz' ]), + { x : true, y : true, z : '/foo/bar/baz', _ : [], $0 : $0 } + ); + t.end(); +}); + +test('alias', function (t) { + var argv = optimist([ '-f', '11', '--zoom', '55' ]) + .alias('z', 'zoom') + .argv + ; + t.equal(argv.zoom, 55); + t.equal(argv.z, argv.zoom); + t.equal(argv.f, 11); + t.end(); +}); + +test('multiAlias', function (t) { + var argv = optimist([ '-f', '11', '--zoom', '55' ]) + .alias('z', [ 'zm', 'zoom' ]) + .argv + ; + t.equal(argv.zoom, 55); + t.equal(argv.z, argv.zoom); + t.equal(argv.z, argv.zm); + t.equal(argv.f, 11); + t.end(); +}); + +test('boolean default true', function (t) { + var argv = optimist.options({ + sometrue: { + boolean: true, + default: true + } + }).argv; + + t.equal(argv.sometrue, true); + t.end(); +}); + +test('boolean default false', function (t) { + var argv = optimist.options({ + somefalse: { + boolean: true, + default: false + } + }).argv; + + t.equal(argv.somefalse, false); + t.end(); +}); + +test('nested dotted objects', function (t) { + var argv = optimist([ + '--foo.bar', '3', '--foo.baz', '4', + '--foo.quux.quibble', '5', '--foo.quux.o_O', + '--beep.boop' + ]).argv; + + t.same(argv.foo, { + bar : 3, + baz : 4, + quux : { + quibble : 5, + o_O : true + }, + }); + t.same(argv.beep, { boop : true }); + t.end(); +}); + +test('boolean and alias with chainable api', function (t) { + var aliased = [ '-h', 'derp' ]; + var regular = [ '--herp', 'derp' ]; + var opts = { + herp: { alias: 'h', boolean: true } + }; + var aliasedArgv = optimist(aliased) + .boolean('herp') + .alias('h', 'herp') + .argv; + var propertyArgv = optimist(regular) + .boolean('herp') + .alias('h', 'herp') + .argv; + var expected = { + herp: true, + h: true, + '_': [ 'derp' ], + '$0': $0, + }; + + t.same(aliasedArgv, expected); + t.same(propertyArgv, expected); + t.end(); +}); + +test('boolean and alias with options hash', function (t) { + var aliased = [ '-h', 'derp' ]; + var regular = [ '--herp', 'derp' ]; + var opts = { + herp: { alias: 'h', boolean: true } + }; + var aliasedArgv = optimist(aliased) + .options(opts) + .argv; + var propertyArgv = optimist(regular).options(opts).argv; + var expected = { + herp: true, + h: true, + '_': [ 'derp' ], + '$0': $0, + }; + + t.same(aliasedArgv, expected); + t.same(propertyArgv, expected); + + t.end(); +}); + +test('boolean and alias using explicit true', function (t) { + var aliased = [ '-h', 'true' ]; + var regular = [ '--herp', 'true' ]; + var opts = { + herp: { alias: 'h', boolean: true } + }; + var aliasedArgv = optimist(aliased) + .boolean('h') + .alias('h', 'herp') + .argv; + var propertyArgv = optimist(regular) + .boolean('h') + .alias('h', 'herp') + .argv; + var expected = { + herp: true, + h: true, + '_': [ ], + '$0': $0, + }; + + t.same(aliasedArgv, expected); + t.same(propertyArgv, expected); + t.end(); +}); + +// regression, see https://github.com/substack/node-optimist/issues/71 +test('boolean and --x=true', function(t) { + var parsed = optimist(['--boool', '--other=true']).boolean('boool').argv; + + t.same(parsed.boool, true); + t.same(parsed.other, 'true'); + + parsed = optimist(['--boool', '--other=false']).boolean('boool').argv; + + t.same(parsed.boool, true); + t.same(parsed.other, 'false'); + t.end(); +}); diff --git a/node_modules/cowsay/node_modules/optimist/test/parse_modified.js b/node_modules/cowsay/node_modules/optimist/test/parse_modified.js new file mode 100644 index 0000000..a57dc84 --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/test/parse_modified.js @@ -0,0 +1,14 @@ +var optimist = require('../'); +var test = require('tap').test; + +test('parse with modifier functions' , function (t) { + t.plan(1); + + var argv = optimist().boolean('b').parse([ '-b', '123' ]); + t.deepEqual(fix(argv), { b: true, _: ['123'] }); +}); + +function fix (obj) { + delete obj.$0; + return obj; +} diff --git a/node_modules/cowsay/node_modules/optimist/test/short.js b/node_modules/cowsay/node_modules/optimist/test/short.js new file mode 100644 index 0000000..b2c38ad --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/test/short.js @@ -0,0 +1,16 @@ +var optimist = require('../index'); +var test = require('tap').test; + +test('-n123', function (t) { + t.plan(1); + var parse = optimist.parse([ '-n123' ]); + t.equal(parse.n, 123); +}); + +test('-123', function (t) { + t.plan(3); + var parse = optimist.parse([ '-123', '456' ]); + t.equal(parse['1'], true); + t.equal(parse['2'], true); + t.equal(parse['3'], 456); +}); diff --git a/node_modules/cowsay/node_modules/optimist/test/usage.js b/node_modules/cowsay/node_modules/optimist/test/usage.js new file mode 100644 index 0000000..300454c --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/test/usage.js @@ -0,0 +1,292 @@ +var Hash = require('hashish'); +var optimist = require('../index'); +var test = require('tap').test; + +test('usageFail', function (t) { + var r = checkUsage(function () { + return optimist('-x 10 -z 20'.split(' ')) + .usage('Usage: $0 -x NUM -y NUM') + .demand(['x','y']) + .argv; + }); + t.same( + r.result, + { x : 10, z : 20, _ : [], $0 : './usage' } + ); + + t.same( + r.errors.join('\n').split(/\n+/), + [ + 'Usage: ./usage -x NUM -y NUM', + 'Options:', + ' -x [required]', + ' -y [required]', + 'Missing required arguments: y', + ] + ); + t.same(r.logs, []); + t.ok(r.exit); + t.end(); +}); + + +test('usagePass', function (t) { + var r = checkUsage(function () { + return optimist('-x 10 -y 20'.split(' ')) + .usage('Usage: $0 -x NUM -y NUM') + .demand(['x','y']) + .argv; + }); + t.same(r, { + result : { x : 10, y : 20, _ : [], $0 : './usage' }, + errors : [], + logs : [], + exit : false, + }); + t.end(); +}); + +test('checkPass', function (t) { + var r = checkUsage(function () { + return optimist('-x 10 -y 20'.split(' ')) + .usage('Usage: $0 -x NUM -y NUM') + .check(function (argv) { + if (!('x' in argv)) throw 'You forgot about -x'; + if (!('y' in argv)) throw 'You forgot about -y'; + }) + .argv; + }); + t.same(r, { + result : { x : 10, y : 20, _ : [], $0 : './usage' }, + errors : [], + logs : [], + exit : false, + }); + t.end(); +}); + +test('checkFail', function (t) { + var r = checkUsage(function () { + return optimist('-x 10 -z 20'.split(' ')) + .usage('Usage: $0 -x NUM -y NUM') + .check(function (argv) { + if (!('x' in argv)) throw 'You forgot about -x'; + if (!('y' in argv)) throw 'You forgot about -y'; + }) + .argv; + }); + + t.same( + r.result, + { x : 10, z : 20, _ : [], $0 : './usage' } + ); + + t.same( + r.errors.join('\n').split(/\n+/), + [ + 'Usage: ./usage -x NUM -y NUM', + 'You forgot about -y' + ] + ); + + t.same(r.logs, []); + t.ok(r.exit); + t.end(); +}); + +test('checkCondPass', function (t) { + function checker (argv) { + return 'x' in argv && 'y' in argv; + } + + var r = checkUsage(function () { + return optimist('-x 10 -y 20'.split(' ')) + .usage('Usage: $0 -x NUM -y NUM') + .check(checker) + .argv; + }); + t.same(r, { + result : { x : 10, y : 20, _ : [], $0 : './usage' }, + errors : [], + logs : [], + exit : false, + }); + t.end(); +}); + +test('checkCondFail', function (t) { + function checker (argv) { + return 'x' in argv && 'y' in argv; + } + + var r = checkUsage(function () { + return optimist('-x 10 -z 20'.split(' ')) + .usage('Usage: $0 -x NUM -y NUM') + .check(checker) + .argv; + }); + + t.same( + r.result, + { x : 10, z : 20, _ : [], $0 : './usage' } + ); + + t.same( + r.errors.join('\n').split(/\n+/).join('\n'), + 'Usage: ./usage -x NUM -y NUM\n' + + 'Argument check failed: ' + checker.toString() + ); + + t.same(r.logs, []); + t.ok(r.exit); + t.end(); +}); + +test('countPass', function (t) { + var r = checkUsage(function () { + return optimist('1 2 3 --moo'.split(' ')) + .usage('Usage: $0 [x] [y] [z] {OPTIONS}') + .demand(3) + .argv; + }); + t.same(r, { + result : { _ : [ '1', '2', '3' ], moo : true, $0 : './usage' }, + errors : [], + logs : [], + exit : false, + }); + t.end(); +}); + +test('countFail', function (t) { + var r = checkUsage(function () { + return optimist('1 2 --moo'.split(' ')) + .usage('Usage: $0 [x] [y] [z] {OPTIONS}') + .demand(3) + .argv; + }); + t.same( + r.result, + { _ : [ '1', '2' ], moo : true, $0 : './usage' } + ); + + t.same( + r.errors.join('\n').split(/\n+/), + [ + 'Usage: ./usage [x] [y] [z] {OPTIONS}', + 'Not enough non-option arguments: got 2, need at least 3', + ] + ); + + t.same(r.logs, []); + t.ok(r.exit); + t.end(); +}); + +test('defaultSingles', function (t) { + var r = checkUsage(function () { + return optimist('--foo 50 --baz 70 --powsy'.split(' ')) + .default('foo', 5) + .default('bar', 6) + .default('baz', 7) + .argv + ; + }); + t.same(r.result, { + foo : '50', + bar : 6, + baz : '70', + powsy : true, + _ : [], + $0 : './usage', + }); + t.end(); +}); + +test('defaultAliases', function (t) { + var r = checkUsage(function () { + return optimist('') + .alias('f', 'foo') + .default('f', 5) + .argv + ; + }); + t.same(r.result, { + f : '5', + foo : '5', + _ : [], + $0 : './usage', + }); + t.end(); +}); + +test('defaultHash', function (t) { + var r = checkUsage(function () { + return optimist('--foo 50 --baz 70'.split(' ')) + .default({ foo : 10, bar : 20, quux : 30 }) + .argv + ; + }); + t.same(r.result, { + _ : [], + $0 : './usage', + foo : 50, + baz : 70, + bar : 20, + quux : 30, + }); + t.end(); +}); + +test('rebase', function (t) { + t.equal( + optimist.rebase('/home/substack', '/home/substack/foo/bar/baz'), + './foo/bar/baz' + ); + t.equal( + optimist.rebase('/home/substack/foo/bar/baz', '/home/substack'), + '../../..' + ); + t.equal( + optimist.rebase('/home/substack/foo', '/home/substack/pow/zoom.txt'), + '../pow/zoom.txt' + ); + t.end(); +}); + +function checkUsage (f) { + + var exit = false; + + process._exit = process.exit; + process._env = process.env; + process._argv = process.argv; + + process.exit = function (t) { exit = true }; + process.env = Hash.merge(process.env, { _ : 'node' }); + process.argv = [ './usage' ]; + + var errors = []; + var logs = []; + + console._error = console.error; + console.error = function (msg) { errors.push(msg) }; + console._log = console.log; + console.log = function (msg) { logs.push(msg) }; + + var result = f(); + + process.exit = process._exit; + process.env = process._env; + process.argv = process._argv; + + console.error = console._error; + console.log = console._log; + + return { + errors : errors, + logs : logs, + exit : exit, + result : result, + }; +}; diff --git a/node_modules/cowsay/node_modules/optimist/test/whitespace.js b/node_modules/cowsay/node_modules/optimist/test/whitespace.js new file mode 100644 index 0000000..90b9075 --- /dev/null +++ b/node_modules/cowsay/node_modules/optimist/test/whitespace.js @@ -0,0 +1,8 @@ +var optimist = require('../'); +var test = require('tap').test; + +test('whitespace should be whitespace' , function (t) { + t.plan(1); + var x = optimist.parse([ '-x', '\t' ]).x; + t.equal(x, '\t'); +}); diff --git a/node_modules/cowsay/package.json b/node_modules/cowsay/package.json new file mode 100644 index 0000000..78423b4 --- /dev/null +++ b/node_modules/cowsay/package.json @@ -0,0 +1,75 @@ +{ + "name": "cowsay", + "version": "1.1.8", + "description": "cowsay is a configurable talking cow", + "keywords": [ + "cow", + "cowsay", + "cowthink", + "figlet", + "talking", + "ASCII" + ], + "homepage": "https://github.com/piuccio/cowsay", + "author": { + "name": "Fabio Crisci", + "email": "piuccio@gmail.com", + "url": "https://github.com/piuccio/" + }, + "main": "./index", + "bin": { + "cowsay": "./cli.js", + "cowthink": "./cli.js" + }, + "files": [ + "index.js", + "cli.js", + "cows/", + "lib/" + ], + "repository": { + "type": "git", + "url": "git+https://github.com/piuccio/cowsay.git" + }, + "scripts": { + "test": "node test.js" + }, + "dependencies": { + "get-stdin": "^4.0.1", + "optimist": "~0.6.1" + }, + "devDependencies": { + "nodeunit": "~0.9.1" + }, + "preferGlobal": true, + "gitHead": "ca8a291e4f581abe7b0d0fdcaa84dbaf0c5f9f92", + "bugs": { + "url": "https://github.com/piuccio/cowsay/issues" + }, + "_id": "cowsay@1.1.8", + "_shasum": "28fd87fe39ccc3a9b4242d9e0aad129d4d4dc25b", + "_from": "cowsay@*", + "_npmVersion": "3.8.6", + "_nodeVersion": "6.1.0", + "_npmUser": { + "name": "piuccio", + "email": "piuccio@gmail.com" + }, + "dist": { + "shasum": "28fd87fe39ccc3a9b4242d9e0aad129d4d4dc25b", + "tarball": "https://registry.npmjs.org/cowsay/-/cowsay-1.1.8.tgz" + }, + "maintainers": [ + { + "name": "piuccio", + "email": "piuccio@gmail.com" + } + ], + "_npmOperationalInternal": { + "host": "packages-12-west.internal.npmjs.com", + "tmp": "tmp/cowsay-1.1.8.tgz_1466069668823_0.375789862126112" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/cowsay/-/cowsay-1.1.8.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/package.json b/package.json index d05dcec..6e7c9d9 100644 --- a/package.json +++ b/package.json @@ -12,6 +12,7 @@ "morgan": "^1.1.1", "oauth": "*", "qs": "*", + "cowsay":"*", "cookie-parser": "^1.0.0", "toastr": "^2.1.2", "connect-flash" : "^0.1.1", diff --git a/server.js b/server.js index 1b5f255..966a1bb 100644 --- a/server.js +++ b/server.js @@ -1,6 +1,8 @@ var express = require('express'); var app = express(); +var rcow = require('cowsay'); var morgan = require('morgan'); +var http = require('http'); var bodyParser = require('body-parser'); var cookieParser = require('cookie-parser'); var methodOverride = require('method-override'); @@ -10,14 +12,57 @@ var fs = require('fs'); // var readableStream = fs.createReadStream(''); // var writeStream = fs.createWriteStream(''); // readableStream.setEncoding('utf8'); // input data encode type is unknonw yet +server = http.createServer( function(request, response) { + var params = request.url.substr(1).split('/'); + if( params[0] == STREAM_SECRET ) { + width = (params[1] || 320)|0; + height = (params[2] || 240)|0; + // broadcast data in base64 format + if('base64' == STREAM_FORMAT) { + var data = [], dataLen = 0; + request.on('data', function (chunk) { + data.push(chunk); + dataLen += chunk.length; + }); + request.on('end', function (chunk) { + var buf = new Buffer(dataLen); + for (var i = 0, len = data.length, pos = 0; i < len; i++) { + data[i].copy(buf, pos); + pos += data[i].length; + } + socketServer.broadcast(buf, {binary: false}); + }); + // broadcast data in binary format + }else{ + console.log( + 'Stream Connected: ' + request.socket.remoteAddress + + ':' + request.socket.remotePort + ' size: ' + width + 'x' + height + ); + request.on('data', function(date) { + socketServer.broadcast(date, {binary: true}); + }); + } + }else { + console.log( + 'Failed Stream Connection: '+ request.socket.remoteAddress + + request.socket.remotePort + ' - wrong secret.' + ); + response.end(); + } + + }).listen(STREAM_PORT); +host = '127.0.0.1'; +//server.listen(port, host); +//console.log('Listening at http://' + host + ':' + port); app.set('json spaces', 4); -app.use(exprezss.static(__dirname)); +app.use(express.static(__dirname)); app.use(cookieParser()); app.use(bodyParser.urlencoded({'extended': 'true'})); app.use(bodyParser.json()); app.use(bodyParser.json({type: 'application/vnd.api+json'})); app.use(methodOverride('X-HTTP-Method-Override')); - -app.listen(port); -console.log("App listening on port" + port); +console.log('Listening for MPEG Stream on http://127.0.0.1:'+STREAM_PORT+'///'); +console.log('Awaiting WebSocket connections on ws://127.0.0.1:'+WEBSOCKET_PORT+'/'); +// app.listen(port); +// console.log("App listening on port" + port); //console.log("Linkedin URL:" + proxyhost); From 701e38dd6c91a8717cca88862c88594a97428905 Mon Sep 17 00:00:00 2001 From: Larry Poon Date: Fri, 28 Oct 2016 12:44:10 -0500 Subject: [PATCH 3/9] rtsp --- .idea/.name | 1 + .idea/ClassroomLiveStream.iml | 9 + .idea/compiler.xml | 22 + .idea/copyright/profiles_settings.xml | 3 + .idea/misc.xml | 14 + .idea/modules.xml | 8 + .idea/vcs.xml | 6 + .idea/workspace.xml | 265 + README.txt | 1 + client.js | 71 + index.html | 168 + libstreaming-examples | 1 + node_modules/child_process/README.md | 9 + node_modules/child_process/package.json | 47 + node_modules/events/.npmignore | 1 + node_modules/events/.travis.yml | 8 + node_modules/events/.zuul.yml | 12 + node_modules/events/History.md | 42 + node_modules/events/LICENSE | 22 + node_modules/events/Readme.md | 19 + node_modules/events/events.js | 302 + node_modules/events/package.json | 68 + node_modules/events/tests/add-listeners.js | 63 + .../events/tests/check-listener-leaks.js | 86 + node_modules/events/tests/common.js | 42 + node_modules/events/tests/index.js | 25 + node_modules/events/tests/legacy-compat.js | 18 + node_modules/events/tests/listener-count.js | 36 + .../events/tests/listeners-side-effects.js | 55 + node_modules/events/tests/listeners.js | 51 + node_modules/events/tests/max-listeners.js | 50 + node_modules/events/tests/modify-in-emit.js | 76 + node_modules/events/tests/num-args.js | 44 + node_modules/events/tests/once.js | 59 + .../events/tests/remove-all-listeners.js | 80 + node_modules/events/tests/remove-listeners.js | 84 + .../tests/set-max-listeners-side-effects.js | 29 + node_modules/events/tests/subclass.js | 51 + node_modules/http/package.json | 31 + node_modules/rtsp-server/.npmignore | 1 + node_modules/rtsp-server/.travis.yml | 7 + node_modules/rtsp-server/LICENSE | 21 + node_modules/rtsp-server/README.md | 62 + node_modules/rtsp-server/index.js | 61 + .../rtsp-server/lib/client-methods.js | 14 + .../rtsp-server/lib/server-methods.js | 22 + .../rtsp-server/node_modules/debug/.jshintrc | 3 + .../rtsp-server/node_modules/debug/.npmignore | 6 + .../rtsp-server/node_modules/debug/History.md | 195 + .../rtsp-server/node_modules/debug/Makefile | 36 + .../rtsp-server/node_modules/debug/Readme.md | 188 + .../rtsp-server/node_modules/debug/bower.json | 28 + .../rtsp-server/node_modules/debug/browser.js | 168 + .../node_modules/debug/component.json | 19 + .../rtsp-server/node_modules/debug/debug.js | 197 + .../rtsp-server/node_modules/debug/node.js | 209 + .../debug/node_modules/ms/.npmignore | 5 + .../debug/node_modules/ms/History.md | 66 + .../debug/node_modules/ms/LICENSE | 20 + .../debug/node_modules/ms/README.md | 35 + .../debug/node_modules/ms/index.js | 125 + .../debug/node_modules/ms/package.json | 48 + .../node_modules/debug/package.json | 73 + .../node_modules/rtsp-stream/.npmignore | 1 + .../node_modules/rtsp-stream/.travis.yml | 5 + .../node_modules/rtsp-stream/LICENSE | 21 + .../node_modules/rtsp-stream/README.md | 280 + .../node_modules/rtsp-stream/decoder.js | 122 + .../node_modules/rtsp-stream/encoder.js | 65 + .../node_modules/rtsp-stream/index.js | 9 + .../node_modules/rtsp-stream/lib/debug.js | 5 + .../rtsp-stream/lib/incoming-message.js | 42 + .../rtsp-stream/lib/outgoing-message.js | 91 + .../rtsp-stream/lib/request-line.js | 19 + .../node_modules/rtsp-stream/lib/request.js | 33 + .../node_modules/rtsp-stream/lib/response.js | 30 + .../rtsp-stream/lib/status-codes.js | 58 + .../rtsp-stream/lib/status-line.js | 19 + .../node_modules/http-headers/.npmignore | 25 + .../node_modules/http-headers/.travis.yml | 8 + .../node_modules/http-headers/LICENSE | 21 + .../node_modules/http-headers/README.md | 104 + .../node_modules/http-headers/index.js | 55 + .../node_modules/strip-lines/.npmignore | 1 + .../node_modules/strip-lines/.travis.yml | 8 + .../node_modules/strip-lines/LICENSE | 21 + .../node_modules/strip-lines/README.md | 39 + .../node_modules/strip-lines/index.js | 16 + .../node_modules/strip-lines/package.json | 63 + .../node_modules/strip-lines/test.js | 64 + .../node_modules/http-headers/package.json | 66 + .../node_modules/http-headers/test.js | 91 + .../node_modules/next-line/.npmignore | 1 + .../node_modules/next-line/.travis.yml | 8 + .../node_modules/next-line/LICENSE | 21 + .../node_modules/next-line/README.md | 30 + .../node_modules/next-line/index.js | 38 + .../node_modules/next-line/package.json | 64 + .../node_modules/next-line/test.js | 40 + .../node_modules/readable-stream/.npmignore | 8 + .../node_modules/readable-stream/.travis.yml | 49 + .../node_modules/readable-stream/LICENSE | 18 + .../node_modules/readable-stream/README.md | 36 + .../readable-stream/doc/stream.md | 2015 +++++ .../doc/wg-meetings/2015-01-30.md | 60 + .../node_modules/readable-stream/duplex.js | 1 + .../readable-stream/lib/_stream_duplex.js | 75 + .../lib/_stream_passthrough.js | 26 + .../readable-stream/lib/_stream_readable.js | 937 ++ .../readable-stream/lib/_stream_transform.js | 180 + .../readable-stream/lib/_stream_writable.js | 526 ++ .../lib/internal/streams/BufferList.js | 64 + .../node_modules/buffer-shims/index.js | 108 + .../node_modules/buffer-shims/license.md | 19 + .../node_modules/buffer-shims/package.json | 51 + .../node_modules/buffer-shims/readme.md | 21 + .../node_modules/core-util-is/LICENSE | 19 + .../node_modules/core-util-is/README.md | 3 + .../node_modules/core-util-is/float.patch | 604 ++ .../node_modules/core-util-is/lib/util.js | 107 + .../node_modules/core-util-is/package.json | 60 + .../node_modules/core-util-is/test.js | 68 + .../node_modules/inherits/LICENSE | 16 + .../node_modules/inherits/README.md | 42 + .../node_modules/inherits/inherits.js | 7 + .../node_modules/inherits/inherits_browser.js | 23 + .../node_modules/inherits/package.json | 63 + .../node_modules/isarray/.npmignore | 1 + .../node_modules/isarray/.travis.yml | 4 + .../node_modules/isarray/Makefile | 6 + .../node_modules/isarray/README.md | 60 + .../node_modules/isarray/component.json | 19 + .../node_modules/isarray/index.js | 5 + .../node_modules/isarray/package.json | 71 + .../node_modules/isarray/test.js | 20 + .../process-nextick-args/.travis.yml | 12 + .../process-nextick-args/index.js | 43 + .../process-nextick-args/license.md | 19 + .../process-nextick-args/package.json | 49 + .../process-nextick-args/readme.md | 18 + .../node_modules/process-nextick-args/test.js | 24 + .../node_modules/string_decoder/.npmignore | 2 + .../node_modules/string_decoder/LICENSE | 20 + .../node_modules/string_decoder/README.md | 7 + .../node_modules/string_decoder/index.js | 221 + .../node_modules/string_decoder/package.json | 54 + .../node_modules/util-deprecate/History.md | 16 + .../node_modules/util-deprecate/LICENSE | 24 + .../node_modules/util-deprecate/README.md | 53 + .../node_modules/util-deprecate/browser.js | 67 + .../node_modules/util-deprecate/node.js | 6 + .../node_modules/util-deprecate/package.json | 54 + .../node_modules/readable-stream/package.json | 92 + .../readable-stream/passthrough.js | 1 + .../node_modules/readable-stream/readable.js | 16 + .../node_modules/readable-stream/transform.js | 1 + .../node_modules/readable-stream/writable.js | 1 + .../node_modules/rtsp-stream/package.json | 76 + .../node_modules/rtsp-stream/test/decoder.js | 180 + .../node_modules/rtsp-stream/test/encoder.js | 243 + .../rtsp-stream/test/fixtures/announce.txt | 5 + .../rtsp-stream/test/fixtures/multiple.txt | 10 + .../rtsp-stream/test/fixtures/ok-body.txt | 5 + .../test/fixtures/ok-multiple-bodies.txt | 10 + .../rtsp-stream/test/fixtures/ok.txt | 4 + .../rtsp-stream/test/fixtures/options.txt | 4 + .../test/fixtures/without-with-body.txt | 9 + .../rtsp-stream/test/incoming-message.js | 56 + .../node_modules/rtsp-stream/test/test.js | 38 + node_modules/rtsp-server/package.json | 66 + node_modules/rtsp-server/test.js | 60 + node_modules/socket.io/History.md | 602 ++ node_modules/socket.io/LICENSE | 22 + node_modules/socket.io/Readme.md | 465 + node_modules/socket.io/lib/client.js | 254 + node_modules/socket.io/lib/index.js | 385 + node_modules/socket.io/lib/namespace.js | 272 + node_modules/socket.io/lib/socket.js | 484 ++ .../socket.io/node_modules/debug/.jshintrc | 3 + .../socket.io/node_modules/debug/.npmignore | 6 + .../socket.io/node_modules/debug/History.md | 195 + .../socket.io/node_modules/debug/Makefile | 36 + .../socket.io/node_modules/debug/Readme.md | 188 + .../socket.io/node_modules/debug/bower.json | 28 + .../socket.io/node_modules/debug/browser.js | 168 + .../node_modules/debug/component.json | 19 + .../socket.io/node_modules/debug/debug.js | 197 + .../socket.io/node_modules/debug/node.js | 209 + .../debug/node_modules/ms/.npmignore | 5 + .../debug/node_modules/ms/History.md | 66 + .../debug/node_modules/ms/LICENSE | 20 + .../debug/node_modules/ms/README.md | 35 + .../debug/node_modules/ms/index.js | 125 + .../debug/node_modules/ms/package.json | 47 + .../socket.io/node_modules/debug/package.json | 72 + .../node_modules/engine.io/History.md | 528 ++ .../socket.io/node_modules/engine.io/LICENSE | 19 + .../node_modules/engine.io/README.md | 536 ++ .../socket.io/node_modules/engine.io/index.js | 4 + .../node_modules/engine.io/lib/engine.io.js | 126 + .../node_modules/engine.io/lib/server.js | 465 + .../node_modules/engine.io/lib/socket.js | 471 + .../node_modules/engine.io/lib/transport.js | 127 + .../engine.io/lib/transports/index.js | 36 + .../engine.io/lib/transports/polling-jsonp.js | 74 + .../engine.io/lib/transports/polling-xhr.js | 70 + .../engine.io/lib/transports/polling.js | 407 + .../engine.io/lib/transports/websocket.js | 125 + .../engine.io/node_modules/accepts/HISTORY.md | 212 + .../engine.io/node_modules/accepts/LICENSE | 23 + .../engine.io/node_modules/accepts/README.md | 135 + .../engine.io/node_modules/accepts/index.js | 231 + .../node_modules/mime-types/HISTORY.md | 204 + .../accepts/node_modules/mime-types/LICENSE | 23 + .../accepts/node_modules/mime-types/README.md | 103 + .../accepts/node_modules/mime-types/index.js | 188 + .../node_modules/mime-db/HISTORY.md | 365 + .../mime-types/node_modules/mime-db/LICENSE | 22 + .../mime-types/node_modules/mime-db/README.md | 82 + .../mime-types/node_modules/mime-db/db.json | 6692 ++++++++++++++ .../mime-types/node_modules/mime-db/index.js | 11 + .../node_modules/mime-db/package.json | 99 + .../node_modules/mime-types/package.json | 94 + .../node_modules/negotiator/HISTORY.md | 98 + .../accepts/node_modules/negotiator/LICENSE | 24 + .../accepts/node_modules/negotiator/README.md | 203 + .../accepts/node_modules/negotiator/index.js | 124 + .../node_modules/negotiator/lib/charset.js | 169 + .../node_modules/negotiator/lib/encoding.js | 184 + .../node_modules/negotiator/lib/language.js | 179 + .../node_modules/negotiator/lib/mediaType.js | 294 + .../node_modules/negotiator/package.json | 91 + .../node_modules/accepts/package.json | 78 + .../node_modules/base64id/.npmignore | 3 + .../engine.io/node_modules/base64id/README.md | 18 + .../node_modules/base64id/lib/base64id.js | 103 + .../node_modules/base64id/package.json | 43 + .../node_modules/engine.io-parser/History.md | 136 + .../node_modules/engine.io-parser/LICENSE | 22 + .../node_modules/engine.io-parser/Readme.md | 202 + .../node_modules/engine.io-parser/index.js | 2 + .../engine.io-parser/lib/browser.js | 609 ++ .../engine.io-parser/lib/index.js | 474 + .../node_modules/engine.io-parser/lib/keys.js | 19 + .../node_modules/after/.npmignore | 2 + .../node_modules/after/.travis.yml | 5 + .../node_modules/after/LICENCE | 19 + .../node_modules/after/README.md | 75 + .../node_modules/after/index.js | 28 + .../node_modules/after/package.json | 62 + .../node_modules/after/test/after-test.js | 120 + .../node_modules/arraybuffer.slice/.npmignore | 17 + .../node_modules/arraybuffer.slice/Makefile | 8 + .../node_modules/arraybuffer.slice/README.md | 17 + .../node_modules/arraybuffer.slice/index.js | 29 + .../arraybuffer.slice/package.json | 39 + .../arraybuffer.slice/test/slice-buffer.js | 227 + .../base64-arraybuffer/.npmignore | 3 + .../base64-arraybuffer/.travis.yml | 19 + .../base64-arraybuffer/LICENSE-MIT | 22 + .../node_modules/base64-arraybuffer/README.md | 20 + .../lib/base64-arraybuffer.js | 67 + .../base64-arraybuffer/package.json | 61 + .../node_modules/blob/.npmignore | 2 + .../node_modules/blob/.zuul.yml | 14 + .../node_modules/blob/Makefile | 14 + .../node_modules/blob/README.md | 14 + .../node_modules/blob/index.js | 96 + .../node_modules/blob/package.json | 44 + .../node_modules/blob/test/index.js | 94 + .../node_modules/has-binary/.npmignore | 15 + .../node_modules/has-binary/History.md | 11 + .../node_modules/has-binary/LICENSE | 20 + .../node_modules/has-binary/Makefile | 3 + .../node_modules/has-binary/README.md | 4 + .../node_modules/has-binary/fixtures/big.json | 1 + .../node_modules/has-binary/index.js | 58 + .../has-binary/node_modules/isarray/README.md | 54 + .../node_modules/isarray/build/build.js | 209 + .../node_modules/isarray/component.json | 19 + .../has-binary/node_modules/isarray/index.js | 3 + .../node_modules/isarray/package.json | 53 + .../node_modules/has-binary/package.json | 39 + .../node_modules/has-binary/test.js | 108 + .../node_modules/wtf-8/LICENSE-MIT.txt | 20 + .../node_modules/wtf-8/README.md | 105 + .../node_modules/wtf-8/package.json | 63 + .../node_modules/wtf-8/wtf-8.js | 234 + .../engine.io-parser/package.json | 66 + .../engine.io/node_modules/ws/.npmignore | 11 + .../engine.io/node_modules/ws/.travis.yml | 15 + .../engine.io/node_modules/ws/Makefile | 45 + .../engine.io/node_modules/ws/README.md | 235 + .../engine.io/node_modules/ws/SECURITY.md | 33 + .../engine.io/node_modules/ws/index.js | 49 + .../node_modules/ws/lib/BufferPool.js | 63 + .../ws/lib/BufferUtil.fallback.js | 47 + .../node_modules/ws/lib/BufferUtil.js | 13 + .../node_modules/ws/lib/ErrorCodes.js | 24 + .../node_modules/ws/lib/Extensions.js | 70 + .../node_modules/ws/lib/PerMessageDeflate.js | 337 + .../node_modules/ws/lib/Receiver.hixie.js | 194 + .../engine.io/node_modules/ws/lib/Receiver.js | 793 ++ .../node_modules/ws/lib/Sender.hixie.js | 124 + .../engine.io/node_modules/ws/lib/Sender.js | 324 + .../ws/lib/Validation.fallback.js | 11 + .../node_modules/ws/lib/Validation.js | 13 + .../node_modules/ws/lib/WebSocket.js | 987 +++ .../node_modules/ws/lib/WebSocketServer.js | 554 ++ .../ws/node_modules/options/.npmignore | 7 + .../ws/node_modules/options/Makefile | 12 + .../ws/node_modules/options/README.md | 69 + .../ws/node_modules/options/lib/options.js | 86 + .../ws/node_modules/options/package.json | 51 + .../ws/node_modules/ultron/.npmignore | 3 + .../ws/node_modules/ultron/.travis.yml | 21 + .../ws/node_modules/ultron/LICENSE | 22 + .../ws/node_modules/ultron/README.md | 97 + .../ws/node_modules/ultron/index.js | 129 + .../ws/node_modules/ultron/package.json | 74 + .../ws/node_modules/ultron/test.js | 327 + .../engine.io/node_modules/ws/package.json | 82 + .../node_modules/engine.io/package.json | 94 + .../node_modules/has-binary/.npmignore | 15 + .../node_modules/has-binary/History.md | 19 + .../socket.io/node_modules/has-binary/LICENSE | 20 + .../node_modules/has-binary/Makefile | 3 + .../node_modules/has-binary/README.md | 4 + .../node_modules/has-binary/index.js | 59 + .../has-binary/node_modules/isarray/README.md | 54 + .../node_modules/isarray/build/build.js | 209 + .../node_modules/isarray/component.json | 19 + .../has-binary/node_modules/isarray/index.js | 3 + .../node_modules/isarray/package.json | 53 + .../node_modules/has-binary/package.json | 40 + .../socket.io/node_modules/has-binary/test.js | 73 + .../node_modules/socket.io-adapter/.npmignore | 1 + .../node_modules/socket.io-adapter/History.md | 33 + .../node_modules/socket.io-adapter/LICENSE | 20 + .../node_modules/socket.io-adapter/Readme.md | 16 + .../node_modules/socket.io-adapter/index.js | 236 + .../node_modules/socket.io-parser/.npmignore | 5 + .../node_modules/socket.io-parser/.travis.yml | 11 + .../node_modules/socket.io-parser/.zuul.yml | 16 + .../node_modules/socket.io-parser/History.md | 87 + .../node_modules/socket.io-parser/Makefile | 11 + .../node_modules/socket.io-parser/Readme.md | 73 + .../socket.io-parser/bench/bench.js | 10 + .../socket.io-parser/bench/index.js | 81 + .../node_modules/socket.io-parser/binary.js | 141 + .../node_modules/socket.io-parser/index.js | 396 + .../socket.io-parser/is-buffer.js | 13 + .../node_modules/benchmark/LICENSE.txt | 22 + .../node_modules/benchmark/README.md | 131 + .../node_modules/benchmark/benchmark.js | 3918 +++++++++ .../node_modules/benchmark/doc/README.md | 2629 ++++++ .../node_modules/benchmark/package.json | 61 + .../node_modules/benchmark/test/run-test.sh | 9 + .../node_modules/benchmark/test/test.js | 2074 +++++ .../node_modules/component-emitter/.npmignore | 2 + .../component-emitter/.travis.yml | 4 + .../node_modules/component-emitter/History.md | 52 + .../node_modules/component-emitter/Makefile | 7 + .../node_modules/component-emitter/Readme.md | 74 + .../node_modules/component-emitter/bower.json | 21 + .../component-emitter/component.json | 14 + .../node_modules/component-emitter/index.js | 164 + .../component-emitter/package.json | 47 + .../node_modules/debug/Readme.md | 115 + .../node_modules/debug/debug.js | 137 + .../node_modules/debug/index.js | 5 + .../node_modules/debug/lib/debug.js | 147 + .../node_modules/debug/package.json | 63 + .../node_modules/isarray/README.md | 54 + .../node_modules/isarray/build/build.js | 209 + .../node_modules/isarray/component.json | 19 + .../node_modules/isarray/index.js | 3 + .../node_modules/isarray/package.json | 53 + .../node_modules/json3/.gitmodules | 6 + .../node_modules/json3/.jamignore | 10 + .../node_modules/json3/.npmignore | 11 + .../node_modules/json3/.travis.yml | 33 + .../node_modules/json3/LICENSE | 20 + .../node_modules/json3/README.md | 126 + .../node_modules/json3/coverage/coverage.json | 1 + .../coverage/lcov-report/lib/json3.js.html | 2903 +++++++ .../json3/coverage/lcov-report/prettify.css | 1 + .../json3/coverage/lcov-report/prettify.js | 1 + .../node_modules/json3/coverage/lcov.info | 2035 +++++ .../node_modules/json3/lib/json3.js | 861 ++ .../node_modules/json3/lib/json3.min.js | 18 + .../node_modules/json3/package.json | 102 + .../socket.io-parser/package.json | 51 + .../socket.io-adapter/package.json | 42 + .../node_modules/socket.io-client/History.md | 485 ++ .../node_modules/socket.io-client/LICENSE | 22 + .../node_modules/socket.io-client/README.md | 188 + .../socket.io-client/lib/index.js | 109 + .../socket.io-client/lib/manager.js | 560 ++ .../node_modules/socket.io-client/lib/on.js | 24 + .../socket.io-client/lib/socket.js | 419 + .../node_modules/socket.io-client/lib/url.js | 75 + .../node_modules/backo2/.npmignore | 1 + .../node_modules/backo2/History.md | 12 + .../node_modules/backo2/Makefile | 8 + .../node_modules/backo2/Readme.md | 34 + .../node_modules/backo2/component.json | 11 + .../node_modules/backo2/index.js | 85 + .../node_modules/backo2/package.json | 45 + .../node_modules/backo2/test/index.js | 18 + .../node_modules/component-bind/.npmignore | 4 + .../node_modules/component-bind/History.md | 13 + .../node_modules/component-bind/Makefile | 7 + .../node_modules/component-bind/Readme.md | 64 + .../component-bind/component.json | 13 + .../node_modules/component-bind/index.js | 23 + .../node_modules/component-bind/package.json | 47 + .../node_modules/component-emitter/History.md | 63 + .../node_modules/component-emitter/LICENSE | 24 + .../node_modules/component-emitter/Readme.md | 74 + .../node_modules/component-emitter/index.js | 161 + .../component-emitter/package.json | 174 + .../node_modules/engine.io-client/History.md | 605 ++ .../node_modules/engine.io-client/LICENSE | 22 + .../node_modules/engine.io-client/README.md | 293 + .../engine.io-client/engine.io.js | 4418 ++++++++++ .../node_modules/engine.io-client/index.js | 2 + .../engine.io-client/lib/index.js | 10 + .../engine.io-client/lib/socket.js | 731 ++ .../engine.io-client/lib/transport.js | 155 + .../engine.io-client/lib/transports/index.js | 53 + .../lib/transports/polling-jsonp.js | 231 + .../lib/transports/polling-xhr.js | 417 + .../lib/transports/polling.js | 245 + .../lib/transports/websocket.js | 274 + .../engine.io-client/lib/xmlhttprequest.js | 37 + .../node_modules/component-emitter/.npmignore | 2 + .../component-emitter/.travis.yml | 4 + .../node_modules/component-emitter/History.md | 52 + .../node_modules/component-emitter/Makefile | 7 + .../node_modules/component-emitter/Readme.md | 74 + .../node_modules/component-emitter/bower.json | 21 + .../component-emitter/component.json | 14 + .../node_modules/component-emitter/index.js | 164 + .../component-emitter/package.json | 47 + .../node_modules/component-inherit/.npmignore | 3 + .../node_modules/component-inherit/History.md | 5 + .../node_modules/component-inherit/Makefile | 16 + .../node_modules/component-inherit/Readme.md | 24 + .../component-inherit/component.json | 10 + .../node_modules/component-inherit/index.js | 7 + .../component-inherit/package.json | 44 + .../component-inherit/test/inherit.js | 21 + .../node_modules/engine.io-parser/History.md | 136 + .../node_modules/engine.io-parser/LICENSE | 22 + .../node_modules/engine.io-parser/Readme.md | 202 + .../node_modules/engine.io-parser/index.js | 2 + .../engine.io-parser/lib/browser.js | 609 ++ .../engine.io-parser/lib/index.js | 474 + .../node_modules/engine.io-parser/lib/keys.js | 19 + .../node_modules/after/.npmignore | 2 + .../node_modules/after/.travis.yml | 5 + .../node_modules/after/LICENCE | 19 + .../node_modules/after/README.md | 75 + .../node_modules/after/index.js | 28 + .../node_modules/after/package.json | 62 + .../node_modules/after/test/after-test.js | 120 + .../node_modules/arraybuffer.slice/.npmignore | 17 + .../node_modules/arraybuffer.slice/Makefile | 8 + .../node_modules/arraybuffer.slice/README.md | 17 + .../node_modules/arraybuffer.slice/index.js | 29 + .../arraybuffer.slice/package.json | 39 + .../arraybuffer.slice/test/slice-buffer.js | 227 + .../base64-arraybuffer/.npmignore | 3 + .../base64-arraybuffer/.travis.yml | 19 + .../base64-arraybuffer/LICENSE-MIT | 22 + .../node_modules/base64-arraybuffer/README.md | 20 + .../lib/base64-arraybuffer.js | 67 + .../base64-arraybuffer/package.json | 62 + .../node_modules/blob/.npmignore | 2 + .../node_modules/blob/.zuul.yml | 14 + .../node_modules/blob/Makefile | 14 + .../node_modules/blob/README.md | 14 + .../node_modules/blob/index.js | 96 + .../node_modules/blob/package.json | 44 + .../node_modules/blob/test/index.js | 94 + .../node_modules/has-binary/.npmignore | 15 + .../node_modules/has-binary/History.md | 11 + .../node_modules/has-binary/LICENSE | 20 + .../node_modules/has-binary/Makefile | 3 + .../node_modules/has-binary/README.md | 4 + .../node_modules/has-binary/fixtures/big.json | 1 + .../node_modules/has-binary/index.js | 58 + .../has-binary/node_modules/isarray/README.md | 54 + .../node_modules/isarray/build/build.js | 209 + .../node_modules/isarray/component.json | 19 + .../has-binary/node_modules/isarray/index.js | 3 + .../node_modules/isarray/package.json | 53 + .../node_modules/has-binary/package.json | 39 + .../node_modules/has-binary/test.js | 108 + .../node_modules/wtf-8/LICENSE-MIT.txt | 20 + .../node_modules/wtf-8/README.md | 105 + .../node_modules/wtf-8/package.json | 64 + .../node_modules/wtf-8/wtf-8.js | 234 + .../engine.io-parser/package.json | 67 + .../node_modules/has-cors/.npmignore | 3 + .../node_modules/has-cors/History.md | 21 + .../node_modules/has-cors/Makefile | 11 + .../node_modules/has-cors/Readme.md | 24 + .../node_modules/has-cors/component.json | 13 + .../node_modules/has-cors/index.js | 17 + .../node_modules/has-cors/package.json | 62 + .../node_modules/has-cors/test.js | 24 + .../node_modules/parsejson/Makefile | 3 + .../node_modules/parsejson/index.js | 32 + .../node_modules/better-assert/.npmignore | 4 + .../node_modules/better-assert/History.md | 15 + .../node_modules/better-assert/Makefile | 5 + .../node_modules/better-assert/Readme.md | 61 + .../node_modules/better-assert/example.js | 10 + .../node_modules/better-assert/index.js | 38 + .../node_modules/callsite/.npmignore | 4 + .../node_modules/callsite/History.md | 10 + .../node_modules/callsite/Makefile | 6 + .../node_modules/callsite/Readme.md | 44 + .../node_modules/callsite/index.js | 10 + .../node_modules/callsite/package.json | 44 + .../node_modules/better-assert/package.json | 64 + .../node_modules/parsejson/package.json | 37 + .../node_modules/parsejson/test.js | 21 + .../node_modules/parseqs/Makefile | 3 + .../node_modules/parseqs/index.js | 37 + .../node_modules/better-assert/.npmignore | 4 + .../node_modules/better-assert/History.md | 15 + .../node_modules/better-assert/Makefile | 5 + .../node_modules/better-assert/Readme.md | 61 + .../node_modules/better-assert/example.js | 10 + .../node_modules/better-assert/index.js | 38 + .../node_modules/callsite/.npmignore | 4 + .../node_modules/callsite/History.md | 10 + .../node_modules/callsite/Makefile | 6 + .../node_modules/callsite/Readme.md | 44 + .../node_modules/callsite/index.js | 10 + .../node_modules/callsite/package.json | 44 + .../node_modules/better-assert/package.json | 64 + .../node_modules/parseqs/package.json | 37 + .../node_modules/parseqs/test.js | 27 + .../node_modules/ws/.npmignore | 11 + .../node_modules/ws/.travis.yml | 15 + .../engine.io-client/node_modules/ws/Makefile | 45 + .../node_modules/ws/README.md | 235 + .../node_modules/ws/SECURITY.md | 33 + .../engine.io-client/node_modules/ws/index.js | 49 + .../node_modules/ws/lib/BufferPool.js | 63 + .../ws/lib/BufferUtil.fallback.js | 47 + .../node_modules/ws/lib/BufferUtil.js | 13 + .../node_modules/ws/lib/ErrorCodes.js | 24 + .../node_modules/ws/lib/Extensions.js | 70 + .../node_modules/ws/lib/PerMessageDeflate.js | 337 + .../node_modules/ws/lib/Receiver.hixie.js | 194 + .../node_modules/ws/lib/Receiver.js | 793 ++ .../node_modules/ws/lib/Sender.hixie.js | 124 + .../node_modules/ws/lib/Sender.js | 324 + .../ws/lib/Validation.fallback.js | 11 + .../node_modules/ws/lib/Validation.js | 13 + .../node_modules/ws/lib/WebSocket.js | 987 +++ .../node_modules/ws/lib/WebSocketServer.js | 554 ++ .../ws/node_modules/options/.npmignore | 7 + .../ws/node_modules/options/Makefile | 12 + .../ws/node_modules/options/README.md | 69 + .../ws/node_modules/options/lib/options.js | 86 + .../ws/node_modules/options/package.json | 51 + .../ws/node_modules/ultron/.npmignore | 3 + .../ws/node_modules/ultron/.travis.yml | 21 + .../ws/node_modules/ultron/LICENSE | 22 + .../ws/node_modules/ultron/README.md | 97 + .../ws/node_modules/ultron/index.js | 129 + .../ws/node_modules/ultron/package.json | 74 + .../ws/node_modules/ultron/test.js | 327 + .../node_modules/ws/package.json | 83 + .../node_modules/xmlhttprequest-ssl/LICENSE | 22 + .../node_modules/xmlhttprequest-ssl/README.md | 61 + .../xmlhttprequest-ssl/autotest.watchr | 8 + .../xmlhttprequest-ssl/example/demo.js | 16 + .../xmlhttprequest-ssl/lib/XMLHttpRequest.js | 646 ++ .../xmlhttprequest-ssl/package.json | 58 + .../tests/test-constants.js | 13 + .../xmlhttprequest-ssl/tests/test-events.js | 50 + .../tests/test-exceptions.js | 59 + .../xmlhttprequest-ssl/tests/test-headers.js | 76 + .../tests/test-redirect-302.js | 41 + .../tests/test-redirect-303.js | 41 + .../tests/test-redirect-307.js | 43 + .../tests/test-request-methods.js | 62 + .../tests/test-request-protocols.js | 32 + .../xmlhttprequest-ssl/tests/testdata.txt | 1 + .../node_modules/yeast/LICENSE | 22 + .../node_modules/yeast/README.md | 82 + .../node_modules/yeast/index.js | 68 + .../node_modules/yeast/package.json | 66 + .../engine.io-client/package.json | 116 + .../node_modules/indexof/.npmignore | 2 + .../node_modules/indexof/Makefile | 11 + .../node_modules/indexof/Readme.md | 15 + .../node_modules/indexof/component.json | 10 + .../node_modules/indexof/index.js | 10 + .../node_modules/indexof/package.json | 32 + .../node_modules/object-component/.npmignore | 3 + .../node_modules/object-component/History.md | 10 + .../node_modules/object-component/Makefile | 16 + .../node_modules/object-component/Readme.md | 31 + .../object-component/component.json | 10 + .../node_modules/object-component/index.js | 84 + .../object-component/package.json | 35 + .../object-component/test/object.js | 48 + .../node_modules/parseuri/History.md | 5 + .../node_modules/parseuri/Makefile | 3 + .../node_modules/parseuri/index.js | 39 + .../node_modules/better-assert/.npmignore | 4 + .../node_modules/better-assert/History.md | 15 + .../node_modules/better-assert/Makefile | 5 + .../node_modules/better-assert/Readme.md | 61 + .../node_modules/better-assert/example.js | 10 + .../node_modules/better-assert/index.js | 38 + .../node_modules/callsite/.npmignore | 4 + .../node_modules/callsite/History.md | 10 + .../node_modules/callsite/Makefile | 6 + .../node_modules/callsite/Readme.md | 44 + .../node_modules/callsite/index.js | 10 + .../node_modules/callsite/package.json | 44 + .../node_modules/better-assert/package.json | 64 + .../node_modules/parseuri/package.json | 45 + .../node_modules/parseuri/test.js | 51 + .../node_modules/to-array/.npmignore | 3 + .../node_modules/to-array/LICENCE | 19 + .../node_modules/to-array/README.md | 22 + .../node_modules/to-array/index.js | 13 + .../node_modules/to-array/package.json | 65 + .../socket.io-client/package.json | 120 + .../socket.io-client/socket.io.js | 7685 +++++++++++++++++ .../node_modules/socket.io-parser/History.md | 127 + .../node_modules/socket.io-parser/LICENSE | 20 + .../node_modules/socket.io-parser/Readme.md | 73 + .../node_modules/socket.io-parser/binary.js | 141 + .../node_modules/socket.io-parser/index.js | 404 + .../socket.io-parser/is-buffer.js | 13 + .../node_modules/component-emitter/.npmignore | 2 + .../component-emitter/.travis.yml | 4 + .../node_modules/component-emitter/History.md | 52 + .../node_modules/component-emitter/Makefile | 7 + .../node_modules/component-emitter/Readme.md | 74 + .../node_modules/component-emitter/bower.json | 21 + .../component-emitter/component.json | 14 + .../node_modules/component-emitter/index.js | 164 + .../component-emitter/package.json | 46 + .../node_modules/isarray/README.md | 54 + .../node_modules/isarray/build/build.js | 209 + .../node_modules/isarray/component.json | 19 + .../node_modules/isarray/index.js | 3 + .../node_modules/isarray/package.json | 53 + .../node_modules/json3/LICENSE | 20 + .../node_modules/json3/README.md | 152 + .../node_modules/json3/lib/json3.js | 902 ++ .../node_modules/json3/lib/json3.min.js | 17 + .../node_modules/json3/package.json | 113 + .../socket.io-parser/package.json | 65 + node_modules/socket.io/package.json | 100 + node_modules/util/.npmignore | 1 + node_modules/util/.travis.yml | 8 + node_modules/util/.zuul.yml | 10 + node_modules/util/LICENSE | 18 + node_modules/util/README.md | 15 + .../util/node_modules/inherits/LICENSE | 16 + .../util/node_modules/inherits/README.md | 42 + .../util/node_modules/inherits/inherits.js | 1 + .../node_modules/inherits/inherits_browser.js | 23 + .../util/node_modules/inherits/package.json | 50 + .../util/node_modules/inherits/test.js | 25 + node_modules/util/package.json | 54 + node_modules/util/support/isBuffer.js | 3 + node_modules/util/support/isBufferBrowser.js | 6 + node_modules/util/test/browser/inspect.js | 41 + node_modules/util/test/browser/is.js | 91 + node_modules/util/test/node/debug.js | 86 + node_modules/util/test/node/format.js | 77 + node_modules/util/test/node/inspect.js | 195 + node_modules/util/test/node/log.js | 58 + node_modules/util/test/node/util.js | 83 + node_modules/util/util.js | 586 ++ package.json | 33 +- rtsp-ffmpeg.js | 192 + rtsp-server.js | 32 + 692 files changed, 91034 insertions(+), 7 deletions(-) create mode 100644 .idea/.name create mode 100644 .idea/ClassroomLiveStream.iml create mode 100644 .idea/compiler.xml create mode 100644 .idea/copyright/profiles_settings.xml create mode 100644 .idea/misc.xml create mode 100644 .idea/modules.xml create mode 100644 .idea/vcs.xml create mode 100644 .idea/workspace.xml create mode 100644 client.js create mode 100644 index.html create mode 160000 libstreaming-examples create mode 100644 node_modules/child_process/README.md create mode 100644 node_modules/child_process/package.json create mode 100644 node_modules/events/.npmignore create mode 100644 node_modules/events/.travis.yml create mode 100644 node_modules/events/.zuul.yml create mode 100644 node_modules/events/History.md create mode 100644 node_modules/events/LICENSE create mode 100644 node_modules/events/Readme.md create mode 100644 node_modules/events/events.js create mode 100644 node_modules/events/package.json create mode 100644 node_modules/events/tests/add-listeners.js create mode 100644 node_modules/events/tests/check-listener-leaks.js create mode 100644 node_modules/events/tests/common.js create mode 100644 node_modules/events/tests/index.js create mode 100644 node_modules/events/tests/legacy-compat.js create mode 100644 node_modules/events/tests/listener-count.js create mode 100644 node_modules/events/tests/listeners-side-effects.js create mode 100644 node_modules/events/tests/listeners.js create mode 100644 node_modules/events/tests/max-listeners.js create mode 100644 node_modules/events/tests/modify-in-emit.js create mode 100644 node_modules/events/tests/num-args.js create mode 100644 node_modules/events/tests/once.js create mode 100644 node_modules/events/tests/remove-all-listeners.js create mode 100644 node_modules/events/tests/remove-listeners.js create mode 100644 node_modules/events/tests/set-max-listeners-side-effects.js create mode 100644 node_modules/events/tests/subclass.js create mode 100644 node_modules/http/package.json create mode 100644 node_modules/rtsp-server/.npmignore create mode 100644 node_modules/rtsp-server/.travis.yml create mode 100644 node_modules/rtsp-server/LICENSE create mode 100644 node_modules/rtsp-server/README.md create mode 100644 node_modules/rtsp-server/index.js create mode 100644 node_modules/rtsp-server/lib/client-methods.js create mode 100644 node_modules/rtsp-server/lib/server-methods.js create mode 100644 node_modules/rtsp-server/node_modules/debug/.jshintrc create mode 100644 node_modules/rtsp-server/node_modules/debug/.npmignore create mode 100644 node_modules/rtsp-server/node_modules/debug/History.md create mode 100644 node_modules/rtsp-server/node_modules/debug/Makefile create mode 100644 node_modules/rtsp-server/node_modules/debug/Readme.md create mode 100644 node_modules/rtsp-server/node_modules/debug/bower.json create mode 100644 node_modules/rtsp-server/node_modules/debug/browser.js create mode 100644 node_modules/rtsp-server/node_modules/debug/component.json create mode 100644 node_modules/rtsp-server/node_modules/debug/debug.js create mode 100644 node_modules/rtsp-server/node_modules/debug/node.js create mode 100644 node_modules/rtsp-server/node_modules/debug/node_modules/ms/.npmignore create mode 100644 node_modules/rtsp-server/node_modules/debug/node_modules/ms/History.md create mode 100644 node_modules/rtsp-server/node_modules/debug/node_modules/ms/LICENSE create mode 100644 node_modules/rtsp-server/node_modules/debug/node_modules/ms/README.md create mode 100644 node_modules/rtsp-server/node_modules/debug/node_modules/ms/index.js create mode 100644 node_modules/rtsp-server/node_modules/debug/node_modules/ms/package.json create mode 100644 node_modules/rtsp-server/node_modules/debug/package.json create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/.npmignore create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/.travis.yml create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/LICENSE create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/README.md create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/decoder.js create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/encoder.js create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/index.js create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/lib/debug.js create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/lib/incoming-message.js create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/lib/outgoing-message.js create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/lib/request-line.js create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/lib/request.js create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/lib/response.js create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/lib/status-codes.js create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/lib/status-line.js create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/.npmignore create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/.travis.yml create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/LICENSE create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/README.md create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/index.js create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/node_modules/strip-lines/.npmignore create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/node_modules/strip-lines/.travis.yml create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/node_modules/strip-lines/LICENSE create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/node_modules/strip-lines/README.md create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/node_modules/strip-lines/index.js create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/node_modules/strip-lines/package.json create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/node_modules/strip-lines/test.js create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/package.json create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/test.js create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/next-line/.npmignore create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/next-line/.travis.yml create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/next-line/LICENSE create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/next-line/README.md create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/next-line/index.js create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/next-line/package.json create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/next-line/test.js create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/.npmignore create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/.travis.yml create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/LICENSE create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/README.md create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/doc/stream.md create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/doc/wg-meetings/2015-01-30.md create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/duplex.js create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/lib/_stream_duplex.js create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/lib/_stream_passthrough.js create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/lib/_stream_readable.js create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/lib/_stream_transform.js create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/lib/_stream_writable.js create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/lib/internal/streams/BufferList.js create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/buffer-shims/index.js create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/buffer-shims/license.md create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/buffer-shims/package.json create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/buffer-shims/readme.md create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/core-util-is/LICENSE create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/core-util-is/README.md create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/core-util-is/float.patch create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/core-util-is/lib/util.js create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/core-util-is/package.json create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/core-util-is/test.js create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/inherits/LICENSE create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/inherits/README.md create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/inherits/inherits.js create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/inherits/inherits_browser.js create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/inherits/package.json create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/isarray/.npmignore create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/isarray/.travis.yml create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/isarray/Makefile create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/isarray/README.md create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/isarray/component.json create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/isarray/index.js create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/isarray/package.json create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/isarray/test.js create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/process-nextick-args/.travis.yml create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/process-nextick-args/index.js create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/process-nextick-args/license.md create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/process-nextick-args/package.json create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/process-nextick-args/readme.md create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/process-nextick-args/test.js create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/string_decoder/.npmignore create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/string_decoder/LICENSE create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/string_decoder/README.md create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/string_decoder/index.js create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/string_decoder/package.json create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/util-deprecate/History.md create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/util-deprecate/LICENSE create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/util-deprecate/README.md create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/util-deprecate/browser.js create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/util-deprecate/node.js create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/util-deprecate/package.json create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/package.json create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/passthrough.js create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/readable.js create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/transform.js create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/writable.js create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/package.json create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/test/decoder.js create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/test/encoder.js create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/test/fixtures/announce.txt create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/test/fixtures/multiple.txt create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/test/fixtures/ok-body.txt create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/test/fixtures/ok-multiple-bodies.txt create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/test/fixtures/ok.txt create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/test/fixtures/options.txt create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/test/fixtures/without-with-body.txt create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/test/incoming-message.js create mode 100644 node_modules/rtsp-server/node_modules/rtsp-stream/test/test.js create mode 100644 node_modules/rtsp-server/package.json create mode 100644 node_modules/rtsp-server/test.js create mode 100644 node_modules/socket.io/History.md create mode 100644 node_modules/socket.io/LICENSE create mode 100644 node_modules/socket.io/Readme.md create mode 100644 node_modules/socket.io/lib/client.js create mode 100644 node_modules/socket.io/lib/index.js create mode 100644 node_modules/socket.io/lib/namespace.js create mode 100644 node_modules/socket.io/lib/socket.js create mode 100644 node_modules/socket.io/node_modules/debug/.jshintrc create mode 100644 node_modules/socket.io/node_modules/debug/.npmignore create mode 100644 node_modules/socket.io/node_modules/debug/History.md create mode 100644 node_modules/socket.io/node_modules/debug/Makefile create mode 100644 node_modules/socket.io/node_modules/debug/Readme.md create mode 100644 node_modules/socket.io/node_modules/debug/bower.json create mode 100644 node_modules/socket.io/node_modules/debug/browser.js create mode 100644 node_modules/socket.io/node_modules/debug/component.json create mode 100644 node_modules/socket.io/node_modules/debug/debug.js create mode 100644 node_modules/socket.io/node_modules/debug/node.js create mode 100644 node_modules/socket.io/node_modules/debug/node_modules/ms/.npmignore create mode 100644 node_modules/socket.io/node_modules/debug/node_modules/ms/History.md create mode 100644 node_modules/socket.io/node_modules/debug/node_modules/ms/LICENSE create mode 100644 node_modules/socket.io/node_modules/debug/node_modules/ms/README.md create mode 100644 node_modules/socket.io/node_modules/debug/node_modules/ms/index.js create mode 100644 node_modules/socket.io/node_modules/debug/node_modules/ms/package.json create mode 100644 node_modules/socket.io/node_modules/debug/package.json create mode 100644 node_modules/socket.io/node_modules/engine.io/History.md create mode 100644 node_modules/socket.io/node_modules/engine.io/LICENSE create mode 100644 node_modules/socket.io/node_modules/engine.io/README.md create mode 100644 node_modules/socket.io/node_modules/engine.io/index.js create mode 100644 node_modules/socket.io/node_modules/engine.io/lib/engine.io.js create mode 100644 node_modules/socket.io/node_modules/engine.io/lib/server.js create mode 100644 node_modules/socket.io/node_modules/engine.io/lib/socket.js create mode 100644 node_modules/socket.io/node_modules/engine.io/lib/transport.js create mode 100644 node_modules/socket.io/node_modules/engine.io/lib/transports/index.js create mode 100644 node_modules/socket.io/node_modules/engine.io/lib/transports/polling-jsonp.js create mode 100644 node_modules/socket.io/node_modules/engine.io/lib/transports/polling-xhr.js create mode 100644 node_modules/socket.io/node_modules/engine.io/lib/transports/polling.js create mode 100644 node_modules/socket.io/node_modules/engine.io/lib/transports/websocket.js create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/accepts/HISTORY.md create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/accepts/LICENSE create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/accepts/README.md create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/accepts/index.js create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/accepts/node_modules/mime-types/HISTORY.md create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/accepts/node_modules/mime-types/LICENSE create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/accepts/node_modules/mime-types/README.md create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/accepts/node_modules/mime-types/index.js create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/accepts/node_modules/mime-types/node_modules/mime-db/HISTORY.md create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/accepts/node_modules/mime-types/node_modules/mime-db/LICENSE create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/accepts/node_modules/mime-types/node_modules/mime-db/README.md create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/accepts/node_modules/mime-types/node_modules/mime-db/db.json create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/accepts/node_modules/mime-types/node_modules/mime-db/index.js create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/accepts/node_modules/mime-types/node_modules/mime-db/package.json create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/accepts/node_modules/mime-types/package.json create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/accepts/node_modules/negotiator/HISTORY.md create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/accepts/node_modules/negotiator/LICENSE create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/accepts/node_modules/negotiator/README.md create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/accepts/node_modules/negotiator/index.js create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/accepts/node_modules/negotiator/lib/charset.js create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/accepts/node_modules/negotiator/lib/encoding.js create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/accepts/node_modules/negotiator/lib/language.js create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/accepts/node_modules/negotiator/lib/mediaType.js create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/accepts/node_modules/negotiator/package.json create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/accepts/package.json create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/base64id/.npmignore create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/base64id/README.md create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/base64id/lib/base64id.js create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/base64id/package.json create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/History.md create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/LICENSE create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/Readme.md create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/index.js create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/lib/browser.js create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/lib/index.js create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/lib/keys.js create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/after/.npmignore create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/after/.travis.yml create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/after/LICENCE create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/after/README.md create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/after/index.js create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/after/package.json create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/after/test/after-test.js create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/arraybuffer.slice/.npmignore create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/arraybuffer.slice/Makefile create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/arraybuffer.slice/README.md create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/arraybuffer.slice/index.js create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/arraybuffer.slice/package.json create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/arraybuffer.slice/test/slice-buffer.js create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/base64-arraybuffer/.npmignore create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/base64-arraybuffer/.travis.yml create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/base64-arraybuffer/LICENSE-MIT create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/base64-arraybuffer/README.md create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/base64-arraybuffer/lib/base64-arraybuffer.js create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/base64-arraybuffer/package.json create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/blob/.npmignore create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/blob/.zuul.yml create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/blob/Makefile create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/blob/README.md create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/blob/index.js create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/blob/package.json create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/blob/test/index.js create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/.npmignore create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/History.md create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/LICENSE create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/Makefile create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/README.md create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/fixtures/big.json create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/index.js create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/node_modules/isarray/README.md create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/node_modules/isarray/build/build.js create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/node_modules/isarray/component.json create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/node_modules/isarray/index.js create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/node_modules/isarray/package.json create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/package.json create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/test.js create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/wtf-8/LICENSE-MIT.txt create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/wtf-8/README.md create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/wtf-8/package.json create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/wtf-8/wtf-8.js create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/package.json create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/ws/.npmignore create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/ws/.travis.yml create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/ws/Makefile create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/ws/README.md create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/ws/SECURITY.md create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/ws/index.js create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/BufferPool.js create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/BufferUtil.fallback.js create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/BufferUtil.js create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/ErrorCodes.js create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/Extensions.js create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/PerMessageDeflate.js create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/Receiver.hixie.js create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/Receiver.js create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/Sender.hixie.js create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/Sender.js create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/Validation.fallback.js create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/Validation.js create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/WebSocket.js create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/WebSocketServer.js create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/ws/node_modules/options/.npmignore create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/ws/node_modules/options/Makefile create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/ws/node_modules/options/README.md create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/ws/node_modules/options/lib/options.js create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/ws/node_modules/options/package.json create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/ws/node_modules/ultron/.npmignore create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/ws/node_modules/ultron/.travis.yml create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/ws/node_modules/ultron/LICENSE create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/ws/node_modules/ultron/README.md create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/ws/node_modules/ultron/index.js create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/ws/node_modules/ultron/package.json create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/ws/node_modules/ultron/test.js create mode 100644 node_modules/socket.io/node_modules/engine.io/node_modules/ws/package.json create mode 100644 node_modules/socket.io/node_modules/engine.io/package.json create mode 100644 node_modules/socket.io/node_modules/has-binary/.npmignore create mode 100644 node_modules/socket.io/node_modules/has-binary/History.md create mode 100644 node_modules/socket.io/node_modules/has-binary/LICENSE create mode 100644 node_modules/socket.io/node_modules/has-binary/Makefile create mode 100644 node_modules/socket.io/node_modules/has-binary/README.md create mode 100644 node_modules/socket.io/node_modules/has-binary/index.js create mode 100644 node_modules/socket.io/node_modules/has-binary/node_modules/isarray/README.md create mode 100644 node_modules/socket.io/node_modules/has-binary/node_modules/isarray/build/build.js create mode 100644 node_modules/socket.io/node_modules/has-binary/node_modules/isarray/component.json create mode 100644 node_modules/socket.io/node_modules/has-binary/node_modules/isarray/index.js create mode 100644 node_modules/socket.io/node_modules/has-binary/node_modules/isarray/package.json create mode 100644 node_modules/socket.io/node_modules/has-binary/package.json create mode 100644 node_modules/socket.io/node_modules/has-binary/test.js create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/.npmignore create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/History.md create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/LICENSE create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/Readme.md create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/index.js create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/.npmignore create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/.travis.yml create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/.zuul.yml create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/History.md create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/Makefile create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/Readme.md create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/bench/bench.js create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/bench/index.js create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/binary.js create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/index.js create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/is-buffer.js create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/benchmark/LICENSE.txt create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/benchmark/README.md create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/benchmark/benchmark.js create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/benchmark/doc/README.md create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/benchmark/package.json create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/benchmark/test/run-test.sh create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/benchmark/test/test.js create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/component-emitter/.npmignore create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/component-emitter/.travis.yml create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/component-emitter/History.md create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/component-emitter/Makefile create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/component-emitter/Readme.md create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/component-emitter/bower.json create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/component-emitter/component.json create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/component-emitter/index.js create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/component-emitter/package.json create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/debug/Readme.md create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/debug/debug.js create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/debug/index.js create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/debug/lib/debug.js create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/debug/package.json create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/isarray/README.md create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/isarray/build/build.js create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/isarray/component.json create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/isarray/index.js create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/isarray/package.json create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/.gitmodules create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/.jamignore create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/.npmignore create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/.travis.yml create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/LICENSE create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/README.md create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/coverage/coverage.json create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/coverage/lcov-report/lib/json3.js.html create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/coverage/lcov-report/prettify.css create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/coverage/lcov-report/prettify.js create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/coverage/lcov.info create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/lib/json3.js create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/lib/json3.min.js create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/package.json create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/package.json create mode 100644 node_modules/socket.io/node_modules/socket.io-adapter/package.json create mode 100644 node_modules/socket.io/node_modules/socket.io-client/History.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/LICENSE create mode 100644 node_modules/socket.io/node_modules/socket.io-client/README.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/lib/index.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/lib/manager.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/lib/on.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/lib/socket.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/lib/url.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/backo2/.npmignore create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/backo2/History.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/backo2/Makefile create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/backo2/Readme.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/backo2/component.json create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/backo2/index.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/backo2/package.json create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/backo2/test/index.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/component-bind/.npmignore create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/component-bind/History.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/component-bind/Makefile create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/component-bind/Readme.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/component-bind/component.json create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/component-bind/index.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/component-bind/package.json create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/component-emitter/History.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/component-emitter/LICENSE create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/component-emitter/Readme.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/component-emitter/index.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/component-emitter/package.json create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/History.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/LICENSE create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/README.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/engine.io.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/index.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/lib/index.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/lib/socket.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/lib/transport.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/lib/transports/index.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/lib/transports/polling-jsonp.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/lib/transports/polling-xhr.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/lib/transports/polling.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/lib/transports/websocket.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/lib/xmlhttprequest.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/component-emitter/.npmignore create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/component-emitter/.travis.yml create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/component-emitter/History.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/component-emitter/Makefile create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/component-emitter/Readme.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/component-emitter/bower.json create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/component-emitter/component.json create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/component-emitter/index.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/component-emitter/package.json create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/component-inherit/.npmignore create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/component-inherit/History.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/component-inherit/Makefile create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/component-inherit/Readme.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/component-inherit/component.json create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/component-inherit/index.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/component-inherit/package.json create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/component-inherit/test/inherit.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/History.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/LICENSE create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/Readme.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/index.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/lib/browser.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/lib/index.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/lib/keys.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/node_modules/after/.npmignore create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/node_modules/after/.travis.yml create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/node_modules/after/LICENCE create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/node_modules/after/README.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/node_modules/after/index.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/node_modules/after/package.json create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/node_modules/after/test/after-test.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/node_modules/arraybuffer.slice/.npmignore create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/node_modules/arraybuffer.slice/Makefile create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/node_modules/arraybuffer.slice/README.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/node_modules/arraybuffer.slice/index.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/node_modules/arraybuffer.slice/package.json create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/node_modules/arraybuffer.slice/test/slice-buffer.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/node_modules/base64-arraybuffer/.npmignore create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/node_modules/base64-arraybuffer/.travis.yml create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/node_modules/base64-arraybuffer/LICENSE-MIT create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/node_modules/base64-arraybuffer/README.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/node_modules/base64-arraybuffer/lib/base64-arraybuffer.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/node_modules/base64-arraybuffer/package.json create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/node_modules/blob/.npmignore create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/node_modules/blob/.zuul.yml create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/node_modules/blob/Makefile create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/node_modules/blob/README.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/node_modules/blob/index.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/node_modules/blob/package.json create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/node_modules/blob/test/index.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/node_modules/has-binary/.npmignore create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/node_modules/has-binary/History.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/node_modules/has-binary/LICENSE create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/node_modules/has-binary/Makefile create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/node_modules/has-binary/README.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/node_modules/has-binary/fixtures/big.json create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/node_modules/has-binary/index.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/node_modules/has-binary/node_modules/isarray/README.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/node_modules/has-binary/node_modules/isarray/build/build.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/node_modules/has-binary/node_modules/isarray/component.json create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/node_modules/has-binary/node_modules/isarray/index.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/node_modules/has-binary/node_modules/isarray/package.json create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/node_modules/has-binary/package.json create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/node_modules/has-binary/test.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/node_modules/wtf-8/LICENSE-MIT.txt create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/node_modules/wtf-8/README.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/node_modules/wtf-8/package.json create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/node_modules/wtf-8/wtf-8.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/engine.io-parser/package.json create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/has-cors/.npmignore create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/has-cors/History.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/has-cors/Makefile create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/has-cors/Readme.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/has-cors/component.json create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/has-cors/index.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/has-cors/package.json create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/has-cors/test.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/parsejson/Makefile create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/parsejson/index.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/parsejson/node_modules/better-assert/.npmignore create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/parsejson/node_modules/better-assert/History.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/parsejson/node_modules/better-assert/Makefile create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/parsejson/node_modules/better-assert/Readme.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/parsejson/node_modules/better-assert/example.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/parsejson/node_modules/better-assert/index.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/parsejson/node_modules/better-assert/node_modules/callsite/.npmignore create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/parsejson/node_modules/better-assert/node_modules/callsite/History.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/parsejson/node_modules/better-assert/node_modules/callsite/Makefile create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/parsejson/node_modules/better-assert/node_modules/callsite/Readme.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/parsejson/node_modules/better-assert/node_modules/callsite/index.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/parsejson/node_modules/better-assert/node_modules/callsite/package.json create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/parsejson/node_modules/better-assert/package.json create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/parsejson/package.json create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/parsejson/test.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/parseqs/Makefile create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/parseqs/index.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/parseqs/node_modules/better-assert/.npmignore create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/parseqs/node_modules/better-assert/History.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/parseqs/node_modules/better-assert/Makefile create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/parseqs/node_modules/better-assert/Readme.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/parseqs/node_modules/better-assert/example.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/parseqs/node_modules/better-assert/index.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/parseqs/node_modules/better-assert/node_modules/callsite/.npmignore create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/parseqs/node_modules/better-assert/node_modules/callsite/History.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/parseqs/node_modules/better-assert/node_modules/callsite/Makefile create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/parseqs/node_modules/better-assert/node_modules/callsite/Readme.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/parseqs/node_modules/better-assert/node_modules/callsite/index.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/parseqs/node_modules/better-assert/node_modules/callsite/package.json create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/parseqs/node_modules/better-assert/package.json create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/parseqs/package.json create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/parseqs/test.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/ws/.npmignore create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/ws/.travis.yml create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/ws/Makefile create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/ws/README.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/ws/SECURITY.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/ws/index.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/ws/lib/BufferPool.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/ws/lib/BufferUtil.fallback.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/ws/lib/BufferUtil.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/ws/lib/ErrorCodes.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/ws/lib/Extensions.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/ws/lib/PerMessageDeflate.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/ws/lib/Receiver.hixie.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/ws/lib/Receiver.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/ws/lib/Sender.hixie.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/ws/lib/Sender.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/ws/lib/Validation.fallback.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/ws/lib/Validation.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/ws/lib/WebSocket.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/ws/lib/WebSocketServer.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/ws/node_modules/options/.npmignore create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/ws/node_modules/options/Makefile create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/ws/node_modules/options/README.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/ws/node_modules/options/lib/options.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/ws/node_modules/options/package.json create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/ws/node_modules/ultron/.npmignore create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/ws/node_modules/ultron/.travis.yml create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/ws/node_modules/ultron/LICENSE create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/ws/node_modules/ultron/README.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/ws/node_modules/ultron/index.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/ws/node_modules/ultron/package.json create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/ws/node_modules/ultron/test.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/ws/package.json create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/xmlhttprequest-ssl/LICENSE create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/xmlhttprequest-ssl/README.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/xmlhttprequest-ssl/autotest.watchr create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/xmlhttprequest-ssl/example/demo.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/xmlhttprequest-ssl/lib/XMLHttpRequest.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/xmlhttprequest-ssl/package.json create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/xmlhttprequest-ssl/tests/test-constants.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/xmlhttprequest-ssl/tests/test-events.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/xmlhttprequest-ssl/tests/test-exceptions.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/xmlhttprequest-ssl/tests/test-headers.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/xmlhttprequest-ssl/tests/test-redirect-302.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/xmlhttprequest-ssl/tests/test-redirect-303.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/xmlhttprequest-ssl/tests/test-redirect-307.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/xmlhttprequest-ssl/tests/test-request-methods.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/xmlhttprequest-ssl/tests/test-request-protocols.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/xmlhttprequest-ssl/tests/testdata.txt create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/yeast/LICENSE create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/yeast/README.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/yeast/index.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/yeast/package.json create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/package.json create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/indexof/.npmignore create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/indexof/Makefile create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/indexof/Readme.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/indexof/component.json create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/indexof/index.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/indexof/package.json create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/object-component/.npmignore create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/object-component/History.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/object-component/Makefile create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/object-component/Readme.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/object-component/component.json create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/object-component/index.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/object-component/package.json create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/object-component/test/object.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/parseuri/History.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/parseuri/Makefile create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/parseuri/index.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/parseuri/node_modules/better-assert/.npmignore create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/parseuri/node_modules/better-assert/History.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/parseuri/node_modules/better-assert/Makefile create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/parseuri/node_modules/better-assert/Readme.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/parseuri/node_modules/better-assert/example.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/parseuri/node_modules/better-assert/index.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/parseuri/node_modules/better-assert/node_modules/callsite/.npmignore create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/parseuri/node_modules/better-assert/node_modules/callsite/History.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/parseuri/node_modules/better-assert/node_modules/callsite/Makefile create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/parseuri/node_modules/better-assert/node_modules/callsite/Readme.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/parseuri/node_modules/better-assert/node_modules/callsite/index.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/parseuri/node_modules/better-assert/node_modules/callsite/package.json create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/parseuri/node_modules/better-assert/package.json create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/parseuri/package.json create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/parseuri/test.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/to-array/.npmignore create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/to-array/LICENCE create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/to-array/README.md create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/to-array/index.js create mode 100644 node_modules/socket.io/node_modules/socket.io-client/node_modules/to-array/package.json create mode 100644 node_modules/socket.io/node_modules/socket.io-client/package.json create mode 100644 node_modules/socket.io/node_modules/socket.io-client/socket.io.js create mode 100644 node_modules/socket.io/node_modules/socket.io-parser/History.md create mode 100644 node_modules/socket.io/node_modules/socket.io-parser/LICENSE create mode 100644 node_modules/socket.io/node_modules/socket.io-parser/Readme.md create mode 100644 node_modules/socket.io/node_modules/socket.io-parser/binary.js create mode 100644 node_modules/socket.io/node_modules/socket.io-parser/index.js create mode 100644 node_modules/socket.io/node_modules/socket.io-parser/is-buffer.js create mode 100644 node_modules/socket.io/node_modules/socket.io-parser/node_modules/component-emitter/.npmignore create mode 100644 node_modules/socket.io/node_modules/socket.io-parser/node_modules/component-emitter/.travis.yml create mode 100644 node_modules/socket.io/node_modules/socket.io-parser/node_modules/component-emitter/History.md create mode 100644 node_modules/socket.io/node_modules/socket.io-parser/node_modules/component-emitter/Makefile create mode 100644 node_modules/socket.io/node_modules/socket.io-parser/node_modules/component-emitter/Readme.md create mode 100644 node_modules/socket.io/node_modules/socket.io-parser/node_modules/component-emitter/bower.json create mode 100644 node_modules/socket.io/node_modules/socket.io-parser/node_modules/component-emitter/component.json create mode 100644 node_modules/socket.io/node_modules/socket.io-parser/node_modules/component-emitter/index.js create mode 100644 node_modules/socket.io/node_modules/socket.io-parser/node_modules/component-emitter/package.json create mode 100644 node_modules/socket.io/node_modules/socket.io-parser/node_modules/isarray/README.md create mode 100644 node_modules/socket.io/node_modules/socket.io-parser/node_modules/isarray/build/build.js create mode 100644 node_modules/socket.io/node_modules/socket.io-parser/node_modules/isarray/component.json create mode 100644 node_modules/socket.io/node_modules/socket.io-parser/node_modules/isarray/index.js create mode 100644 node_modules/socket.io/node_modules/socket.io-parser/node_modules/isarray/package.json create mode 100644 node_modules/socket.io/node_modules/socket.io-parser/node_modules/json3/LICENSE create mode 100644 node_modules/socket.io/node_modules/socket.io-parser/node_modules/json3/README.md create mode 100644 node_modules/socket.io/node_modules/socket.io-parser/node_modules/json3/lib/json3.js create mode 100644 node_modules/socket.io/node_modules/socket.io-parser/node_modules/json3/lib/json3.min.js create mode 100644 node_modules/socket.io/node_modules/socket.io-parser/node_modules/json3/package.json create mode 100644 node_modules/socket.io/node_modules/socket.io-parser/package.json create mode 100644 node_modules/socket.io/package.json create mode 100644 node_modules/util/.npmignore create mode 100644 node_modules/util/.travis.yml create mode 100644 node_modules/util/.zuul.yml create mode 100644 node_modules/util/LICENSE create mode 100644 node_modules/util/README.md create mode 100644 node_modules/util/node_modules/inherits/LICENSE create mode 100644 node_modules/util/node_modules/inherits/README.md create mode 100644 node_modules/util/node_modules/inherits/inherits.js create mode 100644 node_modules/util/node_modules/inherits/inherits_browser.js create mode 100644 node_modules/util/node_modules/inherits/package.json create mode 100644 node_modules/util/node_modules/inherits/test.js create mode 100644 node_modules/util/package.json create mode 100644 node_modules/util/support/isBuffer.js create mode 100644 node_modules/util/support/isBufferBrowser.js create mode 100644 node_modules/util/test/browser/inspect.js create mode 100644 node_modules/util/test/browser/is.js create mode 100644 node_modules/util/test/node/debug.js create mode 100644 node_modules/util/test/node/format.js create mode 100644 node_modules/util/test/node/inspect.js create mode 100644 node_modules/util/test/node/log.js create mode 100644 node_modules/util/test/node/util.js create mode 100644 node_modules/util/util.js create mode 100644 rtsp-ffmpeg.js create mode 100644 rtsp-server.js diff --git a/.idea/.name b/.idea/.name new file mode 100644 index 0000000..ee40304 --- /dev/null +++ b/.idea/.name @@ -0,0 +1 @@ +ClassroomLiveStream \ No newline at end of file diff --git a/.idea/ClassroomLiveStream.iml b/.idea/ClassroomLiveStream.iml new file mode 100644 index 0000000..d6ebd48 --- /dev/null +++ b/.idea/ClassroomLiveStream.iml @@ -0,0 +1,9 @@ + + + + + + + + + \ No newline at end of file diff --git a/.idea/compiler.xml b/.idea/compiler.xml new file mode 100644 index 0000000..9a8b7e5 --- /dev/null +++ b/.idea/compiler.xml @@ -0,0 +1,22 @@ + + + + + \ No newline at end of file diff --git a/.idea/copyright/profiles_settings.xml b/.idea/copyright/profiles_settings.xml new file mode 100644 index 0000000..e7bedf3 --- /dev/null +++ b/.idea/copyright/profiles_settings.xml @@ -0,0 +1,3 @@ + + + \ No newline at end of file diff --git a/.idea/misc.xml b/.idea/misc.xml new file mode 100644 index 0000000..2e5f0fd --- /dev/null +++ b/.idea/misc.xml @@ -0,0 +1,14 @@ + + + + + + + + + + + + + + \ No newline at end of file diff --git a/.idea/modules.xml b/.idea/modules.xml new file mode 100644 index 0000000..cf2f7c0 --- /dev/null +++ b/.idea/modules.xml @@ -0,0 +1,8 @@ + + + + + + + + \ No newline at end of file diff --git a/.idea/vcs.xml b/.idea/vcs.xml new file mode 100644 index 0000000..35eb1dd --- /dev/null +++ b/.idea/vcs.xml @@ -0,0 +1,6 @@ + + + + + + \ No newline at end of file diff --git a/.idea/workspace.xml b/.idea/workspace.xml new file mode 100644 index 0000000..dea9f3a --- /dev/null +++ b/.idea/workspace.xml @@ -0,0 +1,265 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + localhost + 5050 + + + + + + + 1476916061877 + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/README.txt b/README.txt index e69de29..40902e3 100644 --- a/README.txt +++ b/README.txt @@ -0,0 +1 @@ +Classroom Live Streaming diff --git a/client.js b/client.js new file mode 100644 index 0000000..7fc71a3 --- /dev/null +++ b/client.js @@ -0,0 +1,71 @@ +const app = require('express')() + , server = require('http').Server(app) + , io = require('socket.io')(server) + , rtsp = require('./rtsp-ffmpeg') + ; + +server.listen(6147, function(){ + console.log(server.address()); + console.log('Listening on localhost:6147'); +}); + + +var cams = [ + 'rtsp://r3---sn-5hn7su76.c.youtube.com/CiILENy73wIaGQnup-1SztVOYBMYESARFEgGUgZ2aWRlb3MM/0/0/0/video.3gp' + // , 'rtsp://192.168.68.111/h264main' + // , 'rtsp://r1---sn-5hn7su76.c.youtube.com/CiILENy73wIaGQn8uA5p5adowhMYDSANFEgGUgZ2aWRlb3MM/0/0/0/video.3gp' + ,'rtsp://localhost' + ].map(function(uri, i) { + + var stream = new rtsp.FFMpeg({input: uri, resolution: '320x240', quality: 3}); + + stream.on('start', function() { + + console.log('stream ' + i + ' started'); + + }); + + stream.on('stop', function() { + + console.log('stream ' + i + ' stopped'); + + }); + + return stream; + + }); + +cams.forEach(function(camStream, i) { + + var ns = io.of('/cam' + i); + + ns.on('connection', function(wsocket) { + + console.log('connected to /cam' + i); + + var pipeStream = function(data) { + wsocket.emit('data', data); + }; + + camStream.on('data', pipeStream); + + wsocket.on('disconnect', function() { + console.log('disconnected from /cam' + i); + camStream.removeListener('data', pipeStream); + }); + }); +}); + + + +io.on('connection', function(socket) { + + socket.emit('start', cams.length); + +}); + +app.get('/', function (req, res) { + + res.sendFile(__dirname + '/index.html'); + +}); diff --git a/index.html b/index.html new file mode 100644 index 0000000..a3e65cf --- /dev/null +++ b/index.html @@ -0,0 +1,168 @@ + + + + + + + + +
              + + + + + + + + + +Contact GitHub API Training Shop Blog About + +© 2016 GitHub, Inc. Terms Privacy Security Status Help diff --git a/libstreaming-examples b/libstreaming-examples new file mode 160000 index 0000000..8a1aecf --- /dev/null +++ b/libstreaming-examples @@ -0,0 +1 @@ +Subproject commit 8a1aecf98b70fda0e441f82eb61052181b908c58 diff --git a/node_modules/child_process/README.md b/node_modules/child_process/README.md new file mode 100644 index 0000000..5e9a74c --- /dev/null +++ b/node_modules/child_process/README.md @@ -0,0 +1,9 @@ +# Security holding package + +This package name is not currently in use, but was formerly occupied +by another package. To avoid malicious use, npm is hanging on to the +package name, but loosely, and we'll probably give it to you if you +want it. + +You may adopt this package by contacting support@npmjs.com and +requesting the name. diff --git a/node_modules/child_process/package.json b/node_modules/child_process/package.json new file mode 100644 index 0000000..7baf5db --- /dev/null +++ b/node_modules/child_process/package.json @@ -0,0 +1,47 @@ +{ + "name": "child_process", + "version": "1.0.2", + "description": "This package name is not currently in use, but was formerly occupied by another package. To avoid malicious use, npm is hanging on to the package name, but loosely, and we'll probably give it to you if you want it.", + "main": "index.js", + "scripts": { + "test": "echo \"Error: no test specified\" && exit 1" + }, + "repository": { + "type": "git", + "url": "git+https://github.com/npm/security-holder.git" + }, + "keywords": [], + "author": "", + "license": "ISC", + "bugs": { + "url": "https://github.com/npm/security-holder/issues" + }, + "homepage": "https://github.com/npm/security-holder#readme", + "gitHead": "9ef10011153183d323ed420df5bb17eaf08ab730", + "_id": "child_process@1.0.2", + "_shasum": "b1f7e7fc73d25e7fd1d455adc94e143830182b5a", + "_from": "child_process@latest", + "_npmVersion": "3.9.2", + "_nodeVersion": "4.2.6", + "_npmUser": { + "name": "npm", + "email": "npm@npmjs.com" + }, + "dist": { + "shasum": "b1f7e7fc73d25e7fd1d455adc94e143830182b5a", + "tarball": "https://registry.npmjs.org/child_process/-/child_process-1.0.2.tgz" + }, + "maintainers": [ + { + "name": "npm", + "email": "npm@npmjs.com" + } + ], + "_npmOperationalInternal": { + "host": "packages-12-west.internal.npmjs.com", + "tmp": "tmp/child_process-1.0.2.tgz_1472177094795_0.5847098815720528" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/child_process/-/child_process-1.0.2.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/events/.npmignore b/node_modules/events/.npmignore new file mode 100644 index 0000000..3c3629e --- /dev/null +++ b/node_modules/events/.npmignore @@ -0,0 +1 @@ +node_modules diff --git a/node_modules/events/.travis.yml b/node_modules/events/.travis.yml new file mode 100644 index 0000000..002b042 --- /dev/null +++ b/node_modules/events/.travis.yml @@ -0,0 +1,8 @@ +sudo: false +language: node_js +node_js: +- '0.10' +env: + global: + - secure: XcBiD8yReflut9q7leKsigDZ0mI3qTKH+QrNVY8DaqlomJOZw8aOrVuX9Jz12l86ZJ41nbxmKnRNkFzcVr9mbP9YaeTb3DpeOBWmvaoSfud9Wnc16VfXtc1FCcwDhSVcSiM3UtnrmFU5cH+Dw1LPh5PbfylYOS/nJxUvG0FFLqI= + - secure: jNWtEbqhUdQ0xXDHvCYfUbKYeJCi6a7B4LsrcxYCyWWn4NIgncE5x2YbB+FSUUFVYfz0dsn5RKP1oHB99f0laUEo18HBNkrAS/rtyOdVzcpJjbQ6kgSILGjnJD/Ty1B57Rcz3iyev5Y7bLZ6Y1FbDnk/i9/l0faOGz8vTC3Vdkc= diff --git a/node_modules/events/.zuul.yml b/node_modules/events/.zuul.yml new file mode 100644 index 0000000..a8e35af --- /dev/null +++ b/node_modules/events/.zuul.yml @@ -0,0 +1,12 @@ +ui: mocha-qunit +browsers: + - name: chrome + version: latest + - name: firefox + version: latest + - name: safari + version: 5..latest + - name: iphone + version: latest + - name: ie + version: 8..latest diff --git a/node_modules/events/History.md b/node_modules/events/History.md new file mode 100644 index 0000000..b345858 --- /dev/null +++ b/node_modules/events/History.md @@ -0,0 +1,42 @@ +# 1.1.1 (2016-06-22) + + - add more context to errors if they are not instanceof Error + +# 1.1.0 (2015-09-29) + + - add Emitter#listerCount (to match node v4 api) + +# 1.0.2 (2014-08-28) + + - remove un-reachable code + - update devDeps + +## 1.0.1 / 2014-05-11 + + - check for console.trace before using it + +## 1.0.0 / 2013-12-10 + + - Update to latest events code from node.js 0.10 + - copy tests from node.js + +## 0.4.0 / 2011-07-03 ## + + - Switching to graphquire@0.8.0 + +## 0.3.0 / 2011-07-03 ## + + - Switching to URL based module require. + +## 0.2.0 / 2011-06-10 ## + + - Simplified package structure. + - Graphquire for dependency management. + +## 0.1.1 / 2011-05-16 ## + + - Unhandled errors are logged via console.error + +## 0.1.0 / 2011-04-22 ## + + - Initial release diff --git a/node_modules/events/LICENSE b/node_modules/events/LICENSE new file mode 100644 index 0000000..52ed3b0 --- /dev/null +++ b/node_modules/events/LICENSE @@ -0,0 +1,22 @@ +MIT + +Copyright Joyent, Inc. and other Node contributors. + +Permission is hereby granted, free of charge, to any person obtaining a +copy of this software and associated documentation files (the +"Software"), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to permit +persons to whom the Software is furnished to do so, subject to the +following conditions: + +The above copyright notice and this permission notice shall be included +in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS +OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN +NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, +DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR +OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE +USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/events/Readme.md b/node_modules/events/Readme.md new file mode 100644 index 0000000..02694ef --- /dev/null +++ b/node_modules/events/Readme.md @@ -0,0 +1,19 @@ +# events [![Build Status](https://travis-ci.org/Gozala/events.png?branch=master)](https://travis-ci.org/Gozala/events) + +Node's event emitter for all engines. + +## Install ## + +``` +npm install events +``` + +## Require ## + +```javascript +var EventEmitter = require('events').EventEmitter +``` + +## Usage ## + +See the [node.js event emitter docs](http://nodejs.org/api/events.html) diff --git a/node_modules/events/events.js b/node_modules/events/events.js new file mode 100644 index 0000000..1619a62 --- /dev/null +++ b/node_modules/events/events.js @@ -0,0 +1,302 @@ +// Copyright Joyent, Inc. and other Node contributors. +// +// Permission is hereby granted, free of charge, to any person obtaining a +// copy of this software and associated documentation files (the +// "Software"), to deal in the Software without restriction, including +// without limitation the rights to use, copy, modify, merge, publish, +// distribute, sublicense, and/or sell copies of the Software, and to permit +// persons to whom the Software is furnished to do so, subject to the +// following conditions: +// +// The above copyright notice and this permission notice shall be included +// in all copies or substantial portions of the Software. +// +// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS +// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN +// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, +// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR +// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE +// USE OR OTHER DEALINGS IN THE SOFTWARE. + +function EventEmitter() { + this._events = this._events || {}; + this._maxListeners = this._maxListeners || undefined; +} +module.exports = EventEmitter; + +// Backwards-compat with node 0.10.x +EventEmitter.EventEmitter = EventEmitter; + +EventEmitter.prototype._events = undefined; +EventEmitter.prototype._maxListeners = undefined; + +// By default EventEmitters will print a warning if more than 10 listeners are +// added to it. This is a useful default which helps finding memory leaks. +EventEmitter.defaultMaxListeners = 10; + +// Obviously not all Emitters should be limited to 10. This function allows +// that to be increased. Set to zero for unlimited. +EventEmitter.prototype.setMaxListeners = function(n) { + if (!isNumber(n) || n < 0 || isNaN(n)) + throw TypeError('n must be a positive number'); + this._maxListeners = n; + return this; +}; + +EventEmitter.prototype.emit = function(type) { + var er, handler, len, args, i, listeners; + + if (!this._events) + this._events = {}; + + // If there is no 'error' event listener then throw. + if (type === 'error') { + if (!this._events.error || + (isObject(this._events.error) && !this._events.error.length)) { + er = arguments[1]; + if (er instanceof Error) { + throw er; // Unhandled 'error' event + } else { + // At least give some kind of context to the user + var err = new Error('Uncaught, unspecified "error" event. (' + er + ')'); + err.context = er; + throw err; + } + } + } + + handler = this._events[type]; + + if (isUndefined(handler)) + return false; + + if (isFunction(handler)) { + switch (arguments.length) { + // fast cases + case 1: + handler.call(this); + break; + case 2: + handler.call(this, arguments[1]); + break; + case 3: + handler.call(this, arguments[1], arguments[2]); + break; + // slower + default: + args = Array.prototype.slice.call(arguments, 1); + handler.apply(this, args); + } + } else if (isObject(handler)) { + args = Array.prototype.slice.call(arguments, 1); + listeners = handler.slice(); + len = listeners.length; + for (i = 0; i < len; i++) + listeners[i].apply(this, args); + } + + return true; +}; + +EventEmitter.prototype.addListener = function(type, listener) { + var m; + + if (!isFunction(listener)) + throw TypeError('listener must be a function'); + + if (!this._events) + this._events = {}; + + // To avoid recursion in the case that type === "newListener"! Before + // adding it to the listeners, first emit "newListener". + if (this._events.newListener) + this.emit('newListener', type, + isFunction(listener.listener) ? + listener.listener : listener); + + if (!this._events[type]) + // Optimize the case of one listener. Don't need the extra array object. + this._events[type] = listener; + else if (isObject(this._events[type])) + // If we've already got an array, just append. + this._events[type].push(listener); + else + // Adding the second element, need to change to array. + this._events[type] = [this._events[type], listener]; + + // Check for listener leak + if (isObject(this._events[type]) && !this._events[type].warned) { + if (!isUndefined(this._maxListeners)) { + m = this._maxListeners; + } else { + m = EventEmitter.defaultMaxListeners; + } + + if (m && m > 0 && this._events[type].length > m) { + this._events[type].warned = true; + console.error('(node) warning: possible EventEmitter memory ' + + 'leak detected. %d listeners added. ' + + 'Use emitter.setMaxListeners() to increase limit.', + this._events[type].length); + if (typeof console.trace === 'function') { + // not supported in IE 10 + console.trace(); + } + } + } + + return this; +}; + +EventEmitter.prototype.on = EventEmitter.prototype.addListener; + +EventEmitter.prototype.once = function(type, listener) { + if (!isFunction(listener)) + throw TypeError('listener must be a function'); + + var fired = false; + + function g() { + this.removeListener(type, g); + + if (!fired) { + fired = true; + listener.apply(this, arguments); + } + } + + g.listener = listener; + this.on(type, g); + + return this; +}; + +// emits a 'removeListener' event iff the listener was removed +EventEmitter.prototype.removeListener = function(type, listener) { + var list, position, length, i; + + if (!isFunction(listener)) + throw TypeError('listener must be a function'); + + if (!this._events || !this._events[type]) + return this; + + list = this._events[type]; + length = list.length; + position = -1; + + if (list === listener || + (isFunction(list.listener) && list.listener === listener)) { + delete this._events[type]; + if (this._events.removeListener) + this.emit('removeListener', type, listener); + + } else if (isObject(list)) { + for (i = length; i-- > 0;) { + if (list[i] === listener || + (list[i].listener && list[i].listener === listener)) { + position = i; + break; + } + } + + if (position < 0) + return this; + + if (list.length === 1) { + list.length = 0; + delete this._events[type]; + } else { + list.splice(position, 1); + } + + if (this._events.removeListener) + this.emit('removeListener', type, listener); + } + + return this; +}; + +EventEmitter.prototype.removeAllListeners = function(type) { + var key, listeners; + + if (!this._events) + return this; + + // not listening for removeListener, no need to emit + if (!this._events.removeListener) { + if (arguments.length === 0) + this._events = {}; + else if (this._events[type]) + delete this._events[type]; + return this; + } + + // emit removeListener for all listeners on all events + if (arguments.length === 0) { + for (key in this._events) { + if (key === 'removeListener') continue; + this.removeAllListeners(key); + } + this.removeAllListeners('removeListener'); + this._events = {}; + return this; + } + + listeners = this._events[type]; + + if (isFunction(listeners)) { + this.removeListener(type, listeners); + } else if (listeners) { + // LIFO order + while (listeners.length) + this.removeListener(type, listeners[listeners.length - 1]); + } + delete this._events[type]; + + return this; +}; + +EventEmitter.prototype.listeners = function(type) { + var ret; + if (!this._events || !this._events[type]) + ret = []; + else if (isFunction(this._events[type])) + ret = [this._events[type]]; + else + ret = this._events[type].slice(); + return ret; +}; + +EventEmitter.prototype.listenerCount = function(type) { + if (this._events) { + var evlistener = this._events[type]; + + if (isFunction(evlistener)) + return 1; + else if (evlistener) + return evlistener.length; + } + return 0; +}; + +EventEmitter.listenerCount = function(emitter, type) { + return emitter.listenerCount(type); +}; + +function isFunction(arg) { + return typeof arg === 'function'; +} + +function isNumber(arg) { + return typeof arg === 'number'; +} + +function isObject(arg) { + return typeof arg === 'object' && arg !== null; +} + +function isUndefined(arg) { + return arg === void 0; +} diff --git a/node_modules/events/package.json b/node_modules/events/package.json new file mode 100644 index 0000000..1bf3bcd --- /dev/null +++ b/node_modules/events/package.json @@ -0,0 +1,68 @@ +{ + "name": "events", + "id": "events", + "version": "1.1.1", + "description": "Node's event emitter for all engines.", + "keywords": [ + "events", + "eventEmitter", + "eventDispatcher", + "listeners" + ], + "author": { + "name": "Irakli Gozalishvili", + "email": "rfobic@gmail.com", + "url": "http://jeditoolkit.com" + }, + "repository": { + "type": "git", + "url": "git://github.com/Gozala/events.git", + "web": "https://github.com/Gozala/events" + }, + "bugs": { + "url": "http://github.com/Gozala/events/issues/" + }, + "main": "./events.js", + "engines": { + "node": ">=0.4.x" + }, + "devDependencies": { + "mocha": "~1.21.4", + "zuul": "~1.10.2" + }, + "scripts": { + "test": "mocha --ui qunit -- tests/index.js && zuul -- tests/index.js" + }, + "license": "MIT", + "gitHead": "623b6f54f3cdccedd71b8b0f5e4b755bacdb5c62", + "homepage": "https://github.com/Gozala/events#readme", + "_id": "events@1.1.1", + "_shasum": "9ebdb7635ad099c70dcc4c2a1f5004288e8bd924", + "_from": "events@latest", + "_npmVersion": "3.8.9", + "_nodeVersion": "6.2.0", + "_npmUser": { + "name": "defunctzombie", + "email": "shtylman@gmail.com" + }, + "dist": { + "shasum": "9ebdb7635ad099c70dcc4c2a1f5004288e8bd924", + "tarball": "https://registry.npmjs.org/events/-/events-1.1.1.tgz" + }, + "maintainers": [ + { + "name": "gozala", + "email": "rfobic@gmail.com" + }, + { + "name": "defunctzombie", + "email": "shtylman@gmail.com" + } + ], + "_npmOperationalInternal": { + "host": "packages-12-west.internal.npmjs.com", + "tmp": "tmp/events-1.1.1.tgz_1466611759829_0.353814059169963" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/events/-/events-1.1.1.tgz" +} diff --git a/node_modules/events/tests/add-listeners.js b/node_modules/events/tests/add-listeners.js new file mode 100644 index 0000000..5ab874c --- /dev/null +++ b/node_modules/events/tests/add-listeners.js @@ -0,0 +1,63 @@ +// Copyright Joyent, Inc. and other Node contributors. +// +// Permission is hereby granted, free of charge, to any person obtaining a +// copy of this software and associated documentation files (the +// "Software"), to deal in the Software without restriction, including +// without limitation the rights to use, copy, modify, merge, publish, +// distribute, sublicense, and/or sell copies of the Software, and to permit +// persons to whom the Software is furnished to do so, subject to the +// following conditions: +// +// The above copyright notice and this permission notice shall be included +// in all copies or substantial portions of the Software. +// +// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS +// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN +// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, +// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR +// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE +// USE OR OTHER DEALINGS IN THE SOFTWARE. + +var assert = require('assert'); +var events = require('../'); + +var e = new events.EventEmitter(); + +var events_new_listener_emited = []; +var listeners_new_listener_emited = []; +var times_hello_emited = 0; + +// sanity check +assert.equal(e.addListener, e.on); + +e.on('newListener', function(event, listener) { + console.log('newListener: ' + event); + events_new_listener_emited.push(event); + listeners_new_listener_emited.push(listener); +}); + +function hello(a, b) { + console.log('hello'); + times_hello_emited += 1; + assert.equal('a', a); + assert.equal('b', b); +} +e.on('hello', hello); + +var foo = function() {}; +e.once('foo', foo); + +console.log('start'); + +e.emit('hello', 'a', 'b'); + + +// just make sure that this doesn't throw: +var f = new events.EventEmitter(); +f.setMaxListeners(0); + +assert.deepEqual(['hello', 'foo'], events_new_listener_emited); +assert.deepEqual([hello, foo], listeners_new_listener_emited); +assert.equal(1, times_hello_emited); + diff --git a/node_modules/events/tests/check-listener-leaks.js b/node_modules/events/tests/check-listener-leaks.js new file mode 100644 index 0000000..e07866a --- /dev/null +++ b/node_modules/events/tests/check-listener-leaks.js @@ -0,0 +1,86 @@ +// Copyright Joyent, Inc. and other Node contributors. +// +// Permission is hereby granted, free of charge, to any person obtaining a +// copy of this software and associated documentation files (the +// "Software"), to deal in the Software without restriction, including +// without limitation the rights to use, copy, modify, merge, publish, +// distribute, sublicense, and/or sell copies of the Software, and to permit +// persons to whom the Software is furnished to do so, subject to the +// following conditions: +// +// The above copyright notice and this permission notice shall be included +// in all copies or substantial portions of the Software. +// +// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS +// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN +// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, +// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR +// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE +// USE OR OTHER DEALINGS IN THE SOFTWARE. + +var assert = require('assert'); +var events = require('../'); + +var e = new events.EventEmitter(); + +// default +for (var i = 0; i < 10; i++) { + e.on('default', function() {}); +} +assert.ok(!e._events['default'].hasOwnProperty('warned')); +e.on('default', function() {}); +assert.ok(e._events['default'].warned); + +// specific +e.setMaxListeners(5); +for (var i = 0; i < 5; i++) { + e.on('specific', function() {}); +} +assert.ok(!e._events['specific'].hasOwnProperty('warned')); +e.on('specific', function() {}); +assert.ok(e._events['specific'].warned); + +// only one +e.setMaxListeners(1); +e.on('only one', function() {}); +assert.ok(!e._events['only one'].hasOwnProperty('warned')); +e.on('only one', function() {}); +assert.ok(e._events['only one'].hasOwnProperty('warned')); + +// unlimited +e.setMaxListeners(0); +for (var i = 0; i < 1000; i++) { + e.on('unlimited', function() {}); +} +assert.ok(!e._events['unlimited'].hasOwnProperty('warned')); + +// process-wide +events.EventEmitter.defaultMaxListeners = 42; +e = new events.EventEmitter(); + +for (var i = 0; i < 42; ++i) { + e.on('fortytwo', function() {}); +} +assert.ok(!e._events['fortytwo'].hasOwnProperty('warned')); +e.on('fortytwo', function() {}); +assert.ok(e._events['fortytwo'].hasOwnProperty('warned')); +delete e._events['fortytwo'].warned; + +events.EventEmitter.defaultMaxListeners = 44; +e.on('fortytwo', function() {}); +assert.ok(!e._events['fortytwo'].hasOwnProperty('warned')); +e.on('fortytwo', function() {}); +assert.ok(e._events['fortytwo'].hasOwnProperty('warned')); + +// but _maxListeners still has precedence over defaultMaxListeners +events.EventEmitter.defaultMaxListeners = 42; +e = new events.EventEmitter(); +e.setMaxListeners(1); +e.on('uno', function() {}); +assert.ok(!e._events['uno'].hasOwnProperty('warned')); +e.on('uno', function() {}); +assert.ok(e._events['uno'].hasOwnProperty('warned')); + +// chainable +assert.strictEqual(e, e.setMaxListeners(1)); diff --git a/node_modules/events/tests/common.js b/node_modules/events/tests/common.js new file mode 100644 index 0000000..66f70a3 --- /dev/null +++ b/node_modules/events/tests/common.js @@ -0,0 +1,42 @@ +var assert = require('assert'); + +var mustCallChecks = []; + +function runCallChecks() { + var failed_count = 0; + for (var i=0 ; i< mustCallChecks.length; ++i) { + var context = mustCallChecks[i]; + if (context.actual === context.expected) { + continue; + } + + failed_count++; + console.log('Mismatched %s function calls. Expected %d, actual %d.', + context.name, + context.expected, + context.actual); + console.log(context.stack.split('\n').slice(2).join('\n')); + } + + assert(failed_count === 0); +} + +after(runCallChecks); + +exports.mustCall = function(fn, expected) { + if (typeof expected !== 'number') expected = 1; + + var context = { + expected: expected, + actual: 0, + stack: (new Error).stack, + name: fn.name || '' + }; + + mustCallChecks.push(context); + + return function() { + context.actual++; + return fn.apply(this, arguments); + }; +}; diff --git a/node_modules/events/tests/index.js b/node_modules/events/tests/index.js new file mode 100644 index 0000000..f144530 --- /dev/null +++ b/node_modules/events/tests/index.js @@ -0,0 +1,25 @@ + +require('./legacy-compat'); + +// we do this to easily wrap each file in a mocha test +// and also have browserify be able to statically analyze this file +var orig_require = require; +var require = function(file) { + test(file, function() { + orig_require(file); + }); +} + +require('./add-listeners.js'); +require('./check-listener-leaks.js'); +require('./listener-count.js'); +require('./listeners-side-effects.js'); +require('./listeners.js'); +require('./max-listeners.js'); +require('./modify-in-emit.js'); +require('./num-args.js'); +require('./once.js'); +require('./set-max-listeners-side-effects.js'); +require('./subclass.js'); +require('./remove-all-listeners.js'); +require('./remove-listeners.js'); diff --git a/node_modules/events/tests/legacy-compat.js b/node_modules/events/tests/legacy-compat.js new file mode 100644 index 0000000..afbc0ab --- /dev/null +++ b/node_modules/events/tests/legacy-compat.js @@ -0,0 +1,18 @@ +// sigh... life is hard +if (!global.console) { + console = {} +} + +var fns = ['log', 'error', 'trace']; +for (var i=0 ; ifoo should not be emitted', '!'); +}; + +e.once('foo', remove); +e.removeListener('foo', remove); +e.emit('foo'); + +var times_recurse_emitted = 0; + +e.once('e', function() { + e.emit('e'); + times_recurse_emitted++; +}); + +e.once('e', function() { + times_recurse_emitted++; +}); + +e.emit('e'); + +assert.equal(1, times_hello_emited); +assert.equal(2, times_recurse_emitted); diff --git a/node_modules/events/tests/remove-all-listeners.js b/node_modules/events/tests/remove-all-listeners.js new file mode 100644 index 0000000..b3dc886 --- /dev/null +++ b/node_modules/events/tests/remove-all-listeners.js @@ -0,0 +1,80 @@ +// Copyright Joyent, Inc. and other Node contributors. +// +// Permission is hereby granted, free of charge, to any person obtaining a +// copy of this software and associated documentation files (the +// "Software"), to deal in the Software without restriction, including +// without limitation the rights to use, copy, modify, merge, publish, +// distribute, sublicense, and/or sell copies of the Software, and to permit +// persons to whom the Software is furnished to do so, subject to the +// following conditions: +// +// The above copyright notice and this permission notice shall be included +// in all copies or substantial portions of the Software. +// +// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS +// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN +// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, +// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR +// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE +// USE OR OTHER DEALINGS IN THE SOFTWARE. + +var common = require('./common'); +var assert = require('assert'); +var events = require('../'); + +var after_checks = []; +after(function() { + for (var i=0 ; i= v31 + * debug: prefer an instance `log()` function over the global one (#119) + * Readme: update documentation about styled console logs for FF v31 (#116, @wryk) + +1.0.3 / 2014-07-09 +================== + + * Add support for multiple wildcards in namespaces (#122, @seegno) + * browser: fix lint + +1.0.2 / 2014-06-10 +================== + + * browser: update color palette (#113, @gscottolson) + * common: make console logging function configurable (#108, @timoxley) + * node: fix %o colors on old node <= 0.8.x + * Makefile: find node path using shell/which (#109, @timoxley) + +1.0.1 / 2014-06-06 +================== + + * browser: use `removeItem()` to clear localStorage + * browser, node: don't set DEBUG if namespaces is undefined (#107, @leedm777) + * package: add "contributors" section + * node: fix comment typo + * README: list authors + +1.0.0 / 2014-06-04 +================== + + * make ms diff be global, not be scope + * debug: ignore empty strings in enable() + * node: make DEBUG_COLORS able to disable coloring + * *: export the `colors` array + * npmignore: don't publish the `dist` dir + * Makefile: refactor to use browserify + * package: add "browserify" as a dev dependency + * Readme: add Web Inspector Colors section + * node: reset terminal color for the debug content + * node: map "%o" to `util.inspect()` + * browser: map "%j" to `JSON.stringify()` + * debug: add custom "formatters" + * debug: use "ms" module for humanizing the diff + * Readme: add "bash" syntax highlighting + * browser: add Firebug color support + * browser: add colors for WebKit browsers + * node: apply log to `console` + * rewrite: abstract common logic for Node & browsers + * add .jshintrc file + +0.8.1 / 2014-04-14 +================== + + * package: re-add the "component" section + +0.8.0 / 2014-03-30 +================== + + * add `enable()` method for nodejs. Closes #27 + * change from stderr to stdout + * remove unnecessary index.js file + +0.7.4 / 2013-11-13 +================== + + * remove "browserify" key from package.json (fixes something in browserify) + +0.7.3 / 2013-10-30 +================== + + * fix: catch localStorage security error when cookies are blocked (Chrome) + * add debug(err) support. Closes #46 + * add .browser prop to package.json. Closes #42 + +0.7.2 / 2013-02-06 +================== + + * fix package.json + * fix: Mobile Safari (private mode) is broken with debug + * fix: Use unicode to send escape character to shell instead of octal to work with strict mode javascript + +0.7.1 / 2013-02-05 +================== + + * add repository URL to package.json + * add DEBUG_COLORED to force colored output + * add browserify support + * fix component. Closes #24 + +0.7.0 / 2012-05-04 +================== + + * Added .component to package.json + * Added debug.component.js build + +0.6.0 / 2012-03-16 +================== + + * Added support for "-" prefix in DEBUG [Vinay Pulim] + * Added `.enabled` flag to the node version [TooTallNate] + +0.5.0 / 2012-02-02 +================== + + * Added: humanize diffs. Closes #8 + * Added `debug.disable()` to the CS variant + * Removed padding. Closes #10 + * Fixed: persist client-side variant again. Closes #9 + +0.4.0 / 2012-02-01 +================== + + * Added browser variant support for older browsers [TooTallNate] + * Added `debug.enable('project:*')` to browser variant [TooTallNate] + * Added padding to diff (moved it to the right) + +0.3.0 / 2012-01-26 +================== + + * Added millisecond diff when isatty, otherwise UTC string + +0.2.0 / 2012-01-22 +================== + + * Added wildcard support + +0.1.0 / 2011-12-02 +================== + + * Added: remove colors unless stderr isatty [TooTallNate] + +0.0.1 / 2010-01-03 +================== + + * Initial release diff --git a/node_modules/rtsp-server/node_modules/debug/Makefile b/node_modules/rtsp-server/node_modules/debug/Makefile new file mode 100644 index 0000000..5cf4a59 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/debug/Makefile @@ -0,0 +1,36 @@ + +# get Makefile directory name: http://stackoverflow.com/a/5982798/376773 +THIS_MAKEFILE_PATH:=$(word $(words $(MAKEFILE_LIST)),$(MAKEFILE_LIST)) +THIS_DIR:=$(shell cd $(dir $(THIS_MAKEFILE_PATH));pwd) + +# BIN directory +BIN := $(THIS_DIR)/node_modules/.bin + +# applications +NODE ?= $(shell which node) +NPM ?= $(NODE) $(shell which npm) +BROWSERIFY ?= $(NODE) $(BIN)/browserify + +all: dist/debug.js + +install: node_modules + +clean: + @rm -rf dist + +dist: + @mkdir -p $@ + +dist/debug.js: node_modules browser.js debug.js dist + @$(BROWSERIFY) \ + --standalone debug \ + . > $@ + +distclean: clean + @rm -rf node_modules + +node_modules: package.json + @NODE_ENV= $(NPM) install + @touch node_modules + +.PHONY: all install clean distclean diff --git a/node_modules/rtsp-server/node_modules/debug/Readme.md b/node_modules/rtsp-server/node_modules/debug/Readme.md new file mode 100644 index 0000000..b4f45e3 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/debug/Readme.md @@ -0,0 +1,188 @@ +# debug + + tiny node.js debugging utility modelled after node core's debugging technique. + +## Installation + +```bash +$ npm install debug +``` + +## Usage + + With `debug` you simply invoke the exported function to generate your debug function, passing it a name which will determine if a noop function is returned, or a decorated `console.error`, so all of the `console` format string goodies you're used to work fine. A unique color is selected per-function for visibility. + +Example _app.js_: + +```js +var debug = require('debug')('http') + , http = require('http') + , name = 'My App'; + +// fake app + +debug('booting %s', name); + +http.createServer(function(req, res){ + debug(req.method + ' ' + req.url); + res.end('hello\n'); +}).listen(3000, function(){ + debug('listening'); +}); + +// fake worker of some kind + +require('./worker'); +``` + +Example _worker.js_: + +```js +var debug = require('debug')('worker'); + +setInterval(function(){ + debug('doing some work'); +}, 1000); +``` + + The __DEBUG__ environment variable is then used to enable these based on space or comma-delimited names. Here are some examples: + + ![debug http and worker](http://f.cl.ly/items/18471z1H402O24072r1J/Screenshot.png) + + ![debug worker](http://f.cl.ly/items/1X413v1a3M0d3C2c1E0i/Screenshot.png) + +#### Windows note + + On Windows the environment variable is set using the `set` command. + + ```cmd + set DEBUG=*,-not_this + ``` + +Then, run the program to be debugged as usual. + +## Millisecond diff + + When actively developing an application it can be useful to see when the time spent between one `debug()` call and the next. Suppose for example you invoke `debug()` before requesting a resource, and after as well, the "+NNNms" will show you how much time was spent between calls. + + ![](http://f.cl.ly/items/2i3h1d3t121M2Z1A3Q0N/Screenshot.png) + + When stdout is not a TTY, `Date#toUTCString()` is used, making it more useful for logging the debug information as shown below: + + ![](http://f.cl.ly/items/112H3i0e0o0P0a2Q2r11/Screenshot.png) + +## Conventions + + If you're using this in one or more of your libraries, you _should_ use the name of your library so that developers may toggle debugging as desired without guessing names. If you have more than one debuggers you _should_ prefix them with your library name and use ":" to separate features. For example "bodyParser" from Connect would then be "connect:bodyParser". + +## Wildcards + + The `*` character may be used as a wildcard. Suppose for example your library has debuggers named "connect:bodyParser", "connect:compress", "connect:session", instead of listing all three with `DEBUG=connect:bodyParser,connect:compress,connect:session`, you may simply do `DEBUG=connect:*`, or to run everything using this module simply use `DEBUG=*`. + + You can also exclude specific debuggers by prefixing them with a "-" character. For example, `DEBUG=*,-connect:*` would include all debuggers except those starting with "connect:". + +## Browser support + + Debug works in the browser as well, currently persisted by `localStorage`. Consider the situation shown below where you have `worker:a` and `worker:b`, and wish to debug both. Somewhere in the code on your page, include: + +```js +window.myDebug = require("debug"); +``` + + ("debug" is a global object in the browser so we give this object a different name.) When your page is open in the browser, type the following in the console: + +```js +myDebug.enable("worker:*") +``` + + Refresh the page. Debug output will continue to be sent to the console until it is disabled by typing `myDebug.disable()` in the console. + +```js +a = debug('worker:a'); +b = debug('worker:b'); + +setInterval(function(){ + a('doing some work'); +}, 1000); + +setInterval(function(){ + b('doing some work'); +}, 1200); +``` + +#### Web Inspector Colors + + Colors are also enabled on "Web Inspectors" that understand the `%c` formatting + option. These are WebKit web inspectors, Firefox ([since version + 31](https://hacks.mozilla.org/2014/05/editable-box-model-multiple-selection-sublime-text-keys-much-more-firefox-developer-tools-episode-31/)) + and the Firebug plugin for Firefox (any version). + + Colored output looks something like: + + ![](https://cloud.githubusercontent.com/assets/71256/3139768/b98c5fd8-e8ef-11e3-862a-f7253b6f47c6.png) + +### stderr vs stdout + +You can set an alternative logging method per-namespace by overriding the `log` method on a per-namespace or globally: + +Example _stdout.js_: + +```js +var debug = require('debug'); +var error = debug('app:error'); + +// by default stderr is used +error('goes to stderr!'); + +var log = debug('app:log'); +// set this namespace to log via console.log +log.log = console.log.bind(console); // don't forget to bind to console! +log('goes to stdout'); +error('still goes to stderr!'); + +// set all output to go via console.info +// overrides all per-namespace log settings +debug.log = console.info.bind(console); +error('now goes to stdout via console.info'); +log('still goes to stdout, but via console.info now'); +``` + +### Save debug output to a file + +You can save all debug statements to a file by piping them. + +Example: + +```bash +$ DEBUG_FD=3 node your-app.js 3> whatever.log +``` + +## Authors + + - TJ Holowaychuk + - Nathan Rajlich + +## License + +(The MIT License) + +Copyright (c) 2014 TJ Holowaychuk <tj@vision-media.ca> + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/rtsp-server/node_modules/debug/bower.json b/node_modules/rtsp-server/node_modules/debug/bower.json new file mode 100644 index 0000000..6af573f --- /dev/null +++ b/node_modules/rtsp-server/node_modules/debug/bower.json @@ -0,0 +1,28 @@ +{ + "name": "visionmedia-debug", + "main": "dist/debug.js", + "version": "2.2.0", + "homepage": "https://github.com/visionmedia/debug", + "authors": [ + "TJ Holowaychuk " + ], + "description": "visionmedia-debug", + "moduleType": [ + "amd", + "es6", + "globals", + "node" + ], + "keywords": [ + "visionmedia", + "debug" + ], + "license": "MIT", + "ignore": [ + "**/.*", + "node_modules", + "bower_components", + "test", + "tests" + ] +} diff --git a/node_modules/rtsp-server/node_modules/debug/browser.js b/node_modules/rtsp-server/node_modules/debug/browser.js new file mode 100644 index 0000000..7c76452 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/debug/browser.js @@ -0,0 +1,168 @@ + +/** + * This is the web browser implementation of `debug()`. + * + * Expose `debug()` as the module. + */ + +exports = module.exports = require('./debug'); +exports.log = log; +exports.formatArgs = formatArgs; +exports.save = save; +exports.load = load; +exports.useColors = useColors; +exports.storage = 'undefined' != typeof chrome + && 'undefined' != typeof chrome.storage + ? chrome.storage.local + : localstorage(); + +/** + * Colors. + */ + +exports.colors = [ + 'lightseagreen', + 'forestgreen', + 'goldenrod', + 'dodgerblue', + 'darkorchid', + 'crimson' +]; + +/** + * Currently only WebKit-based Web Inspectors, Firefox >= v31, + * and the Firebug extension (any Firefox version) are known + * to support "%c" CSS customizations. + * + * TODO: add a `localStorage` variable to explicitly enable/disable colors + */ + +function useColors() { + // is webkit? http://stackoverflow.com/a/16459606/376773 + return ('WebkitAppearance' in document.documentElement.style) || + // is firebug? http://stackoverflow.com/a/398120/376773 + (window.console && (console.firebug || (console.exception && console.table))) || + // is firefox >= v31? + // https://developer.mozilla.org/en-US/docs/Tools/Web_Console#Styling_messages + (navigator.userAgent.toLowerCase().match(/firefox\/(\d+)/) && parseInt(RegExp.$1, 10) >= 31); +} + +/** + * Map %j to `JSON.stringify()`, since no Web Inspectors do that by default. + */ + +exports.formatters.j = function(v) { + return JSON.stringify(v); +}; + + +/** + * Colorize log arguments if enabled. + * + * @api public + */ + +function formatArgs() { + var args = arguments; + var useColors = this.useColors; + + args[0] = (useColors ? '%c' : '') + + this.namespace + + (useColors ? ' %c' : ' ') + + args[0] + + (useColors ? '%c ' : ' ') + + '+' + exports.humanize(this.diff); + + if (!useColors) return args; + + var c = 'color: ' + this.color; + args = [args[0], c, 'color: inherit'].concat(Array.prototype.slice.call(args, 1)); + + // the final "%c" is somewhat tricky, because there could be other + // arguments passed either before or after the %c, so we need to + // figure out the correct index to insert the CSS into + var index = 0; + var lastC = 0; + args[0].replace(/%[a-z%]/g, function(match) { + if ('%%' === match) return; + index++; + if ('%c' === match) { + // we only are interested in the *last* %c + // (the user may have provided their own) + lastC = index; + } + }); + + args.splice(lastC, 0, c); + return args; +} + +/** + * Invokes `console.log()` when available. + * No-op when `console.log` is not a "function". + * + * @api public + */ + +function log() { + // this hackery is required for IE8/9, where + // the `console.log` function doesn't have 'apply' + return 'object' === typeof console + && console.log + && Function.prototype.apply.call(console.log, console, arguments); +} + +/** + * Save `namespaces`. + * + * @param {String} namespaces + * @api private + */ + +function save(namespaces) { + try { + if (null == namespaces) { + exports.storage.removeItem('debug'); + } else { + exports.storage.debug = namespaces; + } + } catch(e) {} +} + +/** + * Load `namespaces`. + * + * @return {String} returns the previously persisted debug modes + * @api private + */ + +function load() { + var r; + try { + r = exports.storage.debug; + } catch(e) {} + return r; +} + +/** + * Enable namespaces listed in `localStorage.debug` initially. + */ + +exports.enable(load()); + +/** + * Localstorage attempts to return the localstorage. + * + * This is necessary because safari throws + * when a user disables cookies/localstorage + * and you attempt to access it. + * + * @return {LocalStorage} + * @api private + */ + +function localstorage(){ + try { + return window.localStorage; + } catch (e) {} +} diff --git a/node_modules/rtsp-server/node_modules/debug/component.json b/node_modules/rtsp-server/node_modules/debug/component.json new file mode 100644 index 0000000..ca10637 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/debug/component.json @@ -0,0 +1,19 @@ +{ + "name": "debug", + "repo": "visionmedia/debug", + "description": "small debugging utility", + "version": "2.2.0", + "keywords": [ + "debug", + "log", + "debugger" + ], + "main": "browser.js", + "scripts": [ + "browser.js", + "debug.js" + ], + "dependencies": { + "rauchg/ms.js": "0.7.1" + } +} diff --git a/node_modules/rtsp-server/node_modules/debug/debug.js b/node_modules/rtsp-server/node_modules/debug/debug.js new file mode 100644 index 0000000..7571a86 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/debug/debug.js @@ -0,0 +1,197 @@ + +/** + * This is the common logic for both the Node.js and web browser + * implementations of `debug()`. + * + * Expose `debug()` as the module. + */ + +exports = module.exports = debug; +exports.coerce = coerce; +exports.disable = disable; +exports.enable = enable; +exports.enabled = enabled; +exports.humanize = require('ms'); + +/** + * The currently active debug mode names, and names to skip. + */ + +exports.names = []; +exports.skips = []; + +/** + * Map of special "%n" handling functions, for the debug "format" argument. + * + * Valid key names are a single, lowercased letter, i.e. "n". + */ + +exports.formatters = {}; + +/** + * Previously assigned color. + */ + +var prevColor = 0; + +/** + * Previous log timestamp. + */ + +var prevTime; + +/** + * Select a color. + * + * @return {Number} + * @api private + */ + +function selectColor() { + return exports.colors[prevColor++ % exports.colors.length]; +} + +/** + * Create a debugger with the given `namespace`. + * + * @param {String} namespace + * @return {Function} + * @api public + */ + +function debug(namespace) { + + // define the `disabled` version + function disabled() { + } + disabled.enabled = false; + + // define the `enabled` version + function enabled() { + + var self = enabled; + + // set `diff` timestamp + var curr = +new Date(); + var ms = curr - (prevTime || curr); + self.diff = ms; + self.prev = prevTime; + self.curr = curr; + prevTime = curr; + + // add the `color` if not set + if (null == self.useColors) self.useColors = exports.useColors(); + if (null == self.color && self.useColors) self.color = selectColor(); + + var args = Array.prototype.slice.call(arguments); + + args[0] = exports.coerce(args[0]); + + if ('string' !== typeof args[0]) { + // anything else let's inspect with %o + args = ['%o'].concat(args); + } + + // apply any `formatters` transformations + var index = 0; + args[0] = args[0].replace(/%([a-z%])/g, function(match, format) { + // if we encounter an escaped % then don't increase the array index + if (match === '%%') return match; + index++; + var formatter = exports.formatters[format]; + if ('function' === typeof formatter) { + var val = args[index]; + match = formatter.call(self, val); + + // now we need to remove `args[index]` since it's inlined in the `format` + args.splice(index, 1); + index--; + } + return match; + }); + + if ('function' === typeof exports.formatArgs) { + args = exports.formatArgs.apply(self, args); + } + var logFn = enabled.log || exports.log || console.log.bind(console); + logFn.apply(self, args); + } + enabled.enabled = true; + + var fn = exports.enabled(namespace) ? enabled : disabled; + + fn.namespace = namespace; + + return fn; +} + +/** + * Enables a debug mode by namespaces. This can include modes + * separated by a colon and wildcards. + * + * @param {String} namespaces + * @api public + */ + +function enable(namespaces) { + exports.save(namespaces); + + var split = (namespaces || '').split(/[\s,]+/); + var len = split.length; + + for (var i = 0; i < len; i++) { + if (!split[i]) continue; // ignore empty strings + namespaces = split[i].replace(/\*/g, '.*?'); + if (namespaces[0] === '-') { + exports.skips.push(new RegExp('^' + namespaces.substr(1) + '$')); + } else { + exports.names.push(new RegExp('^' + namespaces + '$')); + } + } +} + +/** + * Disable debug output. + * + * @api public + */ + +function disable() { + exports.enable(''); +} + +/** + * Returns true if the given mode name is enabled, false otherwise. + * + * @param {String} name + * @return {Boolean} + * @api public + */ + +function enabled(name) { + var i, len; + for (i = 0, len = exports.skips.length; i < len; i++) { + if (exports.skips[i].test(name)) { + return false; + } + } + for (i = 0, len = exports.names.length; i < len; i++) { + if (exports.names[i].test(name)) { + return true; + } + } + return false; +} + +/** + * Coerce `val`. + * + * @param {Mixed} val + * @return {Mixed} + * @api private + */ + +function coerce(val) { + if (val instanceof Error) return val.stack || val.message; + return val; +} diff --git a/node_modules/rtsp-server/node_modules/debug/node.js b/node_modules/rtsp-server/node_modules/debug/node.js new file mode 100644 index 0000000..1d392a8 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/debug/node.js @@ -0,0 +1,209 @@ + +/** + * Module dependencies. + */ + +var tty = require('tty'); +var util = require('util'); + +/** + * This is the Node.js implementation of `debug()`. + * + * Expose `debug()` as the module. + */ + +exports = module.exports = require('./debug'); +exports.log = log; +exports.formatArgs = formatArgs; +exports.save = save; +exports.load = load; +exports.useColors = useColors; + +/** + * Colors. + */ + +exports.colors = [6, 2, 3, 4, 5, 1]; + +/** + * The file descriptor to write the `debug()` calls to. + * Set the `DEBUG_FD` env variable to override with another value. i.e.: + * + * $ DEBUG_FD=3 node script.js 3>debug.log + */ + +var fd = parseInt(process.env.DEBUG_FD, 10) || 2; +var stream = 1 === fd ? process.stdout : + 2 === fd ? process.stderr : + createWritableStdioStream(fd); + +/** + * Is stdout a TTY? Colored output is enabled when `true`. + */ + +function useColors() { + var debugColors = (process.env.DEBUG_COLORS || '').trim().toLowerCase(); + if (0 === debugColors.length) { + return tty.isatty(fd); + } else { + return '0' !== debugColors + && 'no' !== debugColors + && 'false' !== debugColors + && 'disabled' !== debugColors; + } +} + +/** + * Map %o to `util.inspect()`, since Node doesn't do that out of the box. + */ + +var inspect = (4 === util.inspect.length ? + // node <= 0.8.x + function (v, colors) { + return util.inspect(v, void 0, void 0, colors); + } : + // node > 0.8.x + function (v, colors) { + return util.inspect(v, { colors: colors }); + } +); + +exports.formatters.o = function(v) { + return inspect(v, this.useColors) + .replace(/\s*\n\s*/g, ' '); +}; + +/** + * Adds ANSI color escape codes if enabled. + * + * @api public + */ + +function formatArgs() { + var args = arguments; + var useColors = this.useColors; + var name = this.namespace; + + if (useColors) { + var c = this.color; + + args[0] = ' \u001b[3' + c + ';1m' + name + ' ' + + '\u001b[0m' + + args[0] + '\u001b[3' + c + 'm' + + ' +' + exports.humanize(this.diff) + '\u001b[0m'; + } else { + args[0] = new Date().toUTCString() + + ' ' + name + ' ' + args[0]; + } + return args; +} + +/** + * Invokes `console.error()` with the specified arguments. + */ + +function log() { + return stream.write(util.format.apply(this, arguments) + '\n'); +} + +/** + * Save `namespaces`. + * + * @param {String} namespaces + * @api private + */ + +function save(namespaces) { + if (null == namespaces) { + // If you set a process.env field to null or undefined, it gets cast to the + // string 'null' or 'undefined'. Just delete instead. + delete process.env.DEBUG; + } else { + process.env.DEBUG = namespaces; + } +} + +/** + * Load `namespaces`. + * + * @return {String} returns the previously persisted debug modes + * @api private + */ + +function load() { + return process.env.DEBUG; +} + +/** + * Copied from `node/src/node.js`. + * + * XXX: It's lame that node doesn't expose this API out-of-the-box. It also + * relies on the undocumented `tty_wrap.guessHandleType()` which is also lame. + */ + +function createWritableStdioStream (fd) { + var stream; + var tty_wrap = process.binding('tty_wrap'); + + // Note stream._type is used for test-module-load-list.js + + switch (tty_wrap.guessHandleType(fd)) { + case 'TTY': + stream = new tty.WriteStream(fd); + stream._type = 'tty'; + + // Hack to have stream not keep the event loop alive. + // See https://github.com/joyent/node/issues/1726 + if (stream._handle && stream._handle.unref) { + stream._handle.unref(); + } + break; + + case 'FILE': + var fs = require('fs'); + stream = new fs.SyncWriteStream(fd, { autoClose: false }); + stream._type = 'fs'; + break; + + case 'PIPE': + case 'TCP': + var net = require('net'); + stream = new net.Socket({ + fd: fd, + readable: false, + writable: true + }); + + // FIXME Should probably have an option in net.Socket to create a + // stream from an existing fd which is writable only. But for now + // we'll just add this hack and set the `readable` member to false. + // Test: ./node test/fixtures/echo.js < /etc/passwd + stream.readable = false; + stream.read = null; + stream._type = 'pipe'; + + // FIXME Hack to have stream not keep the event loop alive. + // See https://github.com/joyent/node/issues/1726 + if (stream._handle && stream._handle.unref) { + stream._handle.unref(); + } + break; + + default: + // Probably an error on in uv_guess_handle() + throw new Error('Implement me. Unknown stream file type!'); + } + + // For supporting legacy API we put the FD here. + stream.fd = fd; + + stream._isStdio = true; + + return stream; +} + +/** + * Enable namespaces listed in `process.env.DEBUG` initially. + */ + +exports.enable(load()); diff --git a/node_modules/rtsp-server/node_modules/debug/node_modules/ms/.npmignore b/node_modules/rtsp-server/node_modules/debug/node_modules/ms/.npmignore new file mode 100644 index 0000000..d1aa0ce --- /dev/null +++ b/node_modules/rtsp-server/node_modules/debug/node_modules/ms/.npmignore @@ -0,0 +1,5 @@ +node_modules +test +History.md +Makefile +component.json diff --git a/node_modules/rtsp-server/node_modules/debug/node_modules/ms/History.md b/node_modules/rtsp-server/node_modules/debug/node_modules/ms/History.md new file mode 100644 index 0000000..32fdfc1 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/debug/node_modules/ms/History.md @@ -0,0 +1,66 @@ + +0.7.1 / 2015-04-20 +================== + + * prevent extraordinary long inputs (@evilpacket) + * Fixed broken readme link + +0.7.0 / 2014-11-24 +================== + + * add time abbreviations, updated tests and readme for the new units + * fix example in the readme. + * add LICENSE file + +0.6.2 / 2013-12-05 +================== + + * Adding repository section to package.json to suppress warning from NPM. + +0.6.1 / 2013-05-10 +================== + + * fix singularization [visionmedia] + +0.6.0 / 2013-03-15 +================== + + * fix minutes + +0.5.1 / 2013-02-24 +================== + + * add component namespace + +0.5.0 / 2012-11-09 +================== + + * add short formatting as default and .long option + * add .license property to component.json + * add version to component.json + +0.4.0 / 2012-10-22 +================== + + * add rounding to fix crazy decimals + +0.3.0 / 2012-09-07 +================== + + * fix `ms()` [visionmedia] + +0.2.0 / 2012-09-03 +================== + + * add component.json [visionmedia] + * add days support [visionmedia] + * add hours support [visionmedia] + * add minutes support [visionmedia] + * add seconds support [visionmedia] + * add ms string support [visionmedia] + * refactor tests to facilitate ms(number) [visionmedia] + +0.1.0 / 2012-03-07 +================== + + * Initial release diff --git a/node_modules/rtsp-server/node_modules/debug/node_modules/ms/LICENSE b/node_modules/rtsp-server/node_modules/debug/node_modules/ms/LICENSE new file mode 100644 index 0000000..6c07561 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/debug/node_modules/ms/LICENSE @@ -0,0 +1,20 @@ +(The MIT License) + +Copyright (c) 2014 Guillermo Rauch + +Permission is hereby granted, free of charge, to any person obtaining a copy of +this software and associated documentation files (the "Software"), to deal in +the Software without restriction, including without limitation the rights to +use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of +the Software, and to permit persons to whom the Software is furnished to do so, +subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS +FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR +COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER +IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN +CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/rtsp-server/node_modules/debug/node_modules/ms/README.md b/node_modules/rtsp-server/node_modules/debug/node_modules/ms/README.md new file mode 100644 index 0000000..9b4fd03 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/debug/node_modules/ms/README.md @@ -0,0 +1,35 @@ +# ms.js: miliseconds conversion utility + +```js +ms('2 days') // 172800000 +ms('1d') // 86400000 +ms('10h') // 36000000 +ms('2.5 hrs') // 9000000 +ms('2h') // 7200000 +ms('1m') // 60000 +ms('5s') // 5000 +ms('100') // 100 +``` + +```js +ms(60000) // "1m" +ms(2 * 60000) // "2m" +ms(ms('10 hours')) // "10h" +``` + +```js +ms(60000, { long: true }) // "1 minute" +ms(2 * 60000, { long: true }) // "2 minutes" +ms(ms('10 hours'), { long: true }) // "10 hours" +``` + +- Node/Browser compatible. Published as [`ms`](https://www.npmjs.org/package/ms) in [NPM](http://nodejs.org/download). +- If a number is supplied to `ms`, a string with a unit is returned. +- If a string that contains the number is supplied, it returns it as +a number (e.g: it returns `100` for `'100'`). +- If you pass a string with a number and a valid unit, the number of +equivalent ms is returned. + +## License + +MIT diff --git a/node_modules/rtsp-server/node_modules/debug/node_modules/ms/index.js b/node_modules/rtsp-server/node_modules/debug/node_modules/ms/index.js new file mode 100644 index 0000000..4f92771 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/debug/node_modules/ms/index.js @@ -0,0 +1,125 @@ +/** + * Helpers. + */ + +var s = 1000; +var m = s * 60; +var h = m * 60; +var d = h * 24; +var y = d * 365.25; + +/** + * Parse or format the given `val`. + * + * Options: + * + * - `long` verbose formatting [false] + * + * @param {String|Number} val + * @param {Object} options + * @return {String|Number} + * @api public + */ + +module.exports = function(val, options){ + options = options || {}; + if ('string' == typeof val) return parse(val); + return options.long + ? long(val) + : short(val); +}; + +/** + * Parse the given `str` and return milliseconds. + * + * @param {String} str + * @return {Number} + * @api private + */ + +function parse(str) { + str = '' + str; + if (str.length > 10000) return; + var match = /^((?:\d+)?\.?\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|years?|yrs?|y)?$/i.exec(str); + if (!match) return; + var n = parseFloat(match[1]); + var type = (match[2] || 'ms').toLowerCase(); + switch (type) { + case 'years': + case 'year': + case 'yrs': + case 'yr': + case 'y': + return n * y; + case 'days': + case 'day': + case 'd': + return n * d; + case 'hours': + case 'hour': + case 'hrs': + case 'hr': + case 'h': + return n * h; + case 'minutes': + case 'minute': + case 'mins': + case 'min': + case 'm': + return n * m; + case 'seconds': + case 'second': + case 'secs': + case 'sec': + case 's': + return n * s; + case 'milliseconds': + case 'millisecond': + case 'msecs': + case 'msec': + case 'ms': + return n; + } +} + +/** + * Short format for `ms`. + * + * @param {Number} ms + * @return {String} + * @api private + */ + +function short(ms) { + if (ms >= d) return Math.round(ms / d) + 'd'; + if (ms >= h) return Math.round(ms / h) + 'h'; + if (ms >= m) return Math.round(ms / m) + 'm'; + if (ms >= s) return Math.round(ms / s) + 's'; + return ms + 'ms'; +} + +/** + * Long format for `ms`. + * + * @param {Number} ms + * @return {String} + * @api private + */ + +function long(ms) { + return plural(ms, d, 'day') + || plural(ms, h, 'hour') + || plural(ms, m, 'minute') + || plural(ms, s, 'second') + || ms + ' ms'; +} + +/** + * Pluralization helper. + */ + +function plural(ms, n, name) { + if (ms < n) return; + if (ms < n * 1.5) return Math.floor(ms / n) + ' ' + name; + return Math.ceil(ms / n) + ' ' + name + 's'; +} diff --git a/node_modules/rtsp-server/node_modules/debug/node_modules/ms/package.json b/node_modules/rtsp-server/node_modules/debug/node_modules/ms/package.json new file mode 100644 index 0000000..64818de --- /dev/null +++ b/node_modules/rtsp-server/node_modules/debug/node_modules/ms/package.json @@ -0,0 +1,48 @@ +{ + "name": "ms", + "version": "0.7.1", + "description": "Tiny ms conversion utility", + "repository": { + "type": "git", + "url": "git://github.com/guille/ms.js.git" + }, + "main": "./index", + "devDependencies": { + "mocha": "*", + "expect.js": "*", + "serve": "*" + }, + "component": { + "scripts": { + "ms/index.js": "index.js" + } + }, + "gitHead": "713dcf26d9e6fd9dbc95affe7eff9783b7f1b909", + "bugs": { + "url": "https://github.com/guille/ms.js/issues" + }, + "homepage": "https://github.com/guille/ms.js", + "_id": "ms@0.7.1", + "scripts": {}, + "_shasum": "9cd13c03adbff25b65effde7ce864ee952017098", + "_from": "ms@0.7.1", + "_npmVersion": "2.7.5", + "_nodeVersion": "0.12.2", + "_npmUser": { + "name": "rauchg", + "email": "rauchg@gmail.com" + }, + "maintainers": [ + { + "name": "rauchg", + "email": "rauchg@gmail.com" + } + ], + "dist": { + "shasum": "9cd13c03adbff25b65effde7ce864ee952017098", + "tarball": "https://registry.npmjs.org/ms/-/ms-0.7.1.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/ms/-/ms-0.7.1.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/rtsp-server/node_modules/debug/package.json b/node_modules/rtsp-server/node_modules/debug/package.json new file mode 100644 index 0000000..90e98ee --- /dev/null +++ b/node_modules/rtsp-server/node_modules/debug/package.json @@ -0,0 +1,73 @@ +{ + "name": "debug", + "version": "2.2.0", + "repository": { + "type": "git", + "url": "git://github.com/visionmedia/debug.git" + }, + "description": "small debugging utility", + "keywords": [ + "debug", + "log", + "debugger" + ], + "author": { + "name": "TJ Holowaychuk", + "email": "tj@vision-media.ca" + }, + "contributors": [ + { + "name": "Nathan Rajlich", + "email": "nathan@tootallnate.net", + "url": "http://n8.io" + } + ], + "license": "MIT", + "dependencies": { + "ms": "0.7.1" + }, + "devDependencies": { + "browserify": "9.0.3", + "mocha": "*" + }, + "main": "./node.js", + "browser": "./browser.js", + "component": { + "scripts": { + "debug/index.js": "browser.js", + "debug/debug.js": "debug.js" + } + }, + "gitHead": "b38458422b5aa8aa6d286b10dfe427e8a67e2b35", + "bugs": { + "url": "https://github.com/visionmedia/debug/issues" + }, + "homepage": "https://github.com/visionmedia/debug", + "_id": "debug@2.2.0", + "scripts": {}, + "_shasum": "f87057e995b1a1f6ae6a4960664137bc56f039da", + "_from": "debug@>=2.2.0 <3.0.0", + "_npmVersion": "2.7.4", + "_nodeVersion": "0.12.2", + "_npmUser": { + "name": "tootallnate", + "email": "nathan@tootallnate.net" + }, + "maintainers": [ + { + "name": "tjholowaychuk", + "email": "tj@vision-media.ca" + }, + { + "name": "tootallnate", + "email": "nathan@tootallnate.net" + } + ], + "dist": { + "shasum": "f87057e995b1a1f6ae6a4960664137bc56f039da", + "tarball": "https://registry.npmjs.org/debug/-/debug-2.2.0.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/debug/-/debug-2.2.0.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/.npmignore b/node_modules/rtsp-server/node_modules/rtsp-stream/.npmignore new file mode 100644 index 0000000..3c3629e --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/.npmignore @@ -0,0 +1 @@ +node_modules diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/.travis.yml b/node_modules/rtsp-server/node_modules/rtsp-stream/.travis.yml new file mode 100644 index 0000000..648bd6c --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/.travis.yml @@ -0,0 +1,5 @@ +language: node_js +node_js: +- '4' +- '0.12' +- '0.10' diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/LICENSE b/node_modules/rtsp-server/node_modules/rtsp-stream/LICENSE new file mode 100644 index 0000000..7cdc145 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/LICENSE @@ -0,0 +1,21 @@ +The MIT License (MIT) + +Copyright (c) 2015 Thomas Watson Steen + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/README.md b/node_modules/rtsp-server/node_modules/rtsp-stream/README.md new file mode 100644 index 0000000..f9aaeb7 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/README.md @@ -0,0 +1,280 @@ +# rtsp-stream + +A transport agnostic RTSP serial multiplexer module for Node. Use it to +encode or decode RTSP data streams. + +This project aims for 100% compliance with [RFC +2326](https://tools.ietf.org/html/rfc2326). If you find something +missing, please [open an +issue](https://github.com/watson/rtsp-stream/issues). + +Protocol features currently supported: + +- Client to server requests/responses +- Server to client requests/responses +- Persistent transport connections +- Connectionless mode (this is just data stream parsing, so sessions + must be handled elsewhere) +- Pipelining + +Protocol features that are out of scope for this module: + +- Session handling + +[![Build status](https://travis-ci.org/watson/rtsp-stream.svg?branch=master)](https://travis-ci.org/watson/rtsp-stream) +[![js-standard-style](https://img.shields.io/badge/code%20style-standard-brightgreen.svg?style=flat)](https://github.com/feross/standard) + +## Installation + +``` +npm install rtsp-stream +``` + +## Usage + +Let's set up a TCP server, listen on port 5000 and have it respond to +RTSP requests: + +```js +var net = require('net') +var rtsp = require('rtsp-stream') + +var server = net.createServer(function (socket) { + var decoder = new rtsp.Decoder() + var encoder = new rtsp.Encoder() + + decoder.on('request', function (req) { + console.log(req.method, req.uri) + + // output the request body + req.pipe(process.stdout) + + req.on('end', function () { + // prepare a new response to the client + var res = encoder.response() + + res.setHeader('CSeq', req.headers['cseq']) + res.end('Hello World!') + }) + }) + + // pipe the data from the client into the decoder + socket.pipe(decoder) + + // ...and pipe the response back to the client from the encoder + encoder.pipe(socket) +}) + +server.listen(5000) +``` + +### Server -> Client request + +In some scenarios the server will make a request to the client. Here is +what the RFC [have to say](https://tools.ietf.org/html/rfc2326#page-28) +about that: + +> Unlike HTTP, RTSP allows the media server to send requests to the +> media client. However, this is only supported for persistent +> connections, as the media server otherwise has no reliable way of +> reaching the client. Also, this is the only way that requests from +> media server to client are likely to traverse firewalls. + +In the example below, the server sends two request to the client using +the `Encoder` object: + +```js +decoder.on('response', function (res) { + console.log('Response to CSeq %s (code %s)', res.headers['cseq'], res.statusCode) + + // output the response body + res.pipe(process.stdout) +}) + +var body = 'Hello World!' +var options = { + method: 'OPTIONS', + uri: '*', + headers: { + CSeq: 1, + 'Content-Length': Buffer.byteLength(body) + } + body: body +} + +encoder.request(options, function () { + console.log('done sending request 1 to client') +}) + +var req = encoder.request({ method: 'OPTIONS', uri: '*' }) +req.setHeader('CSeq', 2) +req.setHeader('Content-Length', Buffer.byteLength(body)) +req.end(body) +``` + +## API + +The rtsp-stream module exposes the following: + +- `STATUS_CODES` - List of valid RTSP status codes +- `Decoder` - The decoder object +- `Encoder` - The encoder object +- `IncomingMessage` - A readable stream representing an incoming RTSP + message. Can be either a request or a response. Given as the first + argument to the `Decoder` request and response event +- `OutgoingMessage` - A writable stream representing an outgoing RTSP + message. Can be either a request or a response +- `Request` - A writable stream of type `OutgoingMessage` representing + an outgoing RTSP request. Generated by `encoder.request()` +- `Response` - A writable stream of type `OutgoingMessage` representing + an outgoing RTSP response. Generated by `encoder.response()` + +### `Decoder` + +A writable stream used to parse incoming RTSP data. Emits the following +events: + +#### Event: request + +Emitted every time a new request header is found. The event listener is +called with a single arguemnt: + +- `req` - An `rtspStream.IncomingMessage` object + +#### Event: response + +Emitted every time a new response header is found. The event listener is +called with a single arguemnt: + +- `res` - An `rtspStream.IncomingMessage` object + +### `Encoder` + +A readable stream. Outputs valid RTSP responses. + +#### `Encoder.response()` + +Returns a writable stream of type `Response`. + +#### `Encoder.request()` + +Returns a writable stream of type `Request`. + +### `IncomingMessage` + +Exposes the body of the incoming RTSP message by implementing a readable +stream interface. + +Also exposes the RTSP start-line using the following properties: + +#### `IncomingMessage.rtspVersion` + +The RTSP protocol version used in the message. By all intents and +purposes you can expect this to always be `1.0`. + +#### `IncomingMessage.method` + +*Only used if the message is a request* + +The RTSP request method used in the request. The following are +standardized in [RFC 2326](https://tools.ietf.org/html/rfc2326), but +others are also used in the wild: + +- `DESCRIBE` +- `ANNOUNCE` +- `GET_PARAMETER` +- `OPTIONS` +- `PAUSE` +- `PLAY` +- `RECORD` +- `SETUP` +- `SET_PARAMETER` +- `TEARDOWN` + +#### `IncomingMessage.uri` + +*Only used if the message is a request* + +The RTSP request URI used. + +#### `IncomingMessage.statusCode` + +*Only used if the message is a response* + +The RTSP response code used. + +#### `IncomingMessage.statusMessage` + +*Only used if the message is a response* + +The message matching the RTSP response code used. + +#### `IncomingMessage.headers` + +An object containing the headers used on the RTSP request. Object keys +represent header fields and the object values the header values. + +All header field names are lowercased for your convenience. + +Values from repeating header fields are joined in an array. + +### `OutgoingMessage` + +A writable stream representing an outgoing RTSP message. Can be either a +request or a response. + +#### `OutgoingMessage.headersSent` + +A boolean. `true` if the response headers have flushed. + +#### `OutgoingMessage.setHeader(name, value)` + +Set a header to be sent along with the RTSP response body. Throws an +error if called after the headers have been flushed. + +#### `OutgoingMessage.getHeader(name)` + +Get a header value. Case insensitive. + +#### `OutgoingMessage.removeHeader(name)` + +Remove a header so it is not sent to the client. Case insensitive. +Throws an error if called after the headers have been flushed. + +### `Request` + +A writable stream of type `OutgoingMessage` representing an outgoing +RTSP request. Generated by `encoder.request()`. + +### `Response` + +A writable stream of type `OutgoingMessage` representing an outgoing +RTSP response. Generated by `encoder.response()`. + +#### `Response.statusCode` + +The status code used in the response. Defaults to `200`. For alist of +valid status codes see the `rtspStream.STATUS_CODES` object. + +#### `Response.writeHead([statusCode[, statusMessage][, headers]])` + +Force writing of the RTSP response headers to the client. Will be called +automatically on the first to call to either `response.write()` or +`response.end()`. + +Throws an error if called after the headers have been flushed. + +Arguments: + +- `statusCode` - Set a custom status code (overrides the + `response.statusCode` property) +- `statusMessage` - Set a custom status message related to the status + code (e.g. the default status message for the status code `200` is + `OK`) +- `headers` - A key/value headers object used to set extra headers to be + sent along with the RTSP response. This will augment the headers + already set using the `response.setHeader()` function + +## License + +MIT diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/decoder.js b/node_modules/rtsp-server/node_modules/rtsp-stream/decoder.js new file mode 100644 index 0000000..248988a --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/decoder.js @@ -0,0 +1,122 @@ +'use strict' + +var util = require('util') +var stream = require('readable-stream') +var IncomingMessage = require('./lib/incoming-message') +var debug = require('./lib/debug') + +var HEADER_MAX_BYTES = 1024 // TODO: Figure out the best max size of the header +var CR = 0x0d +var NL = 0x0a +var NO_BODY_STATUS_CODES = [100, 304] + +var Decoder = module.exports = function (opts) { + if (!(this instanceof Decoder)) return new Decoder(opts) + + stream.Writable.call(this, opts) + + this._inBody = false + this._headerOffset = 0 + this._header = new Buffer(HEADER_MAX_BYTES) + this._bodyBytesWritten = 0 +} + +util.inherits(Decoder, stream.Writable) + +Decoder.prototype._write = function (chunk, encoding, cb) { + this._writeOffset(chunk, 0, cb) +} + +Decoder.prototype._writeOffset = function (chunk, offset, cb) { + while (offset < chunk.length) { + debug('decoding chunk', util.inspect(chunk.slice(offset).toString())) + if (this._inBody) { + offset = this._writeBody(chunk, offset, cb) + if (offset === 0) return // chunk not consumed - _writeOffset will be called again when ready + } else { + offset = this._writeHead(chunk, offset) + } + } + cb() +} + +Decoder.prototype._writeHead = function (chunk, offset) { + if (this._headerOffset === 0) debug('start of header') + + chunk.copy(this._header, this._headerOffset, offset) + var origHeaderOffset = this._headerOffset + this._headerOffset += chunk.length - offset + var bodyStart = offset + indexOfBody(this._header, Math.max(origHeaderOffset - 3, 0), this._headerOffset) + if (!~bodyStart) return chunk.length // still reading the header + + debug('end of header') + + this._msg = new IncomingMessage(this._header) + + this._headerOffset = 0 + this._header = new Buffer(HEADER_MAX_BYTES) + + if (~NO_BODY_STATUS_CODES.indexOf(this._msg.statusCode)) { + this._bodySize = 0 + } else { + this._bodySize = parseInt(this._msg.headers['content-length'], 10) || 0 + } + + if (this._bodySize > 0) this._inBody = true + + // _writeBody logic to handle back-pressure + var self = this + this._msg.on('drain', function () { + if (!this._chunk) return + self._writeOffset(this._chunk, this._end, this._cb) + this._chunk = null + this._end = null + this._cb = null + }) + + if (this._msg.method) this.emit('request', this._msg) + else this.emit('response', this._msg) + + return bodyStart - origHeaderOffset +} + +// If the given chunk cannot be consumed due to back-pressure, _writeBody will +// return 0 indicating that no part of the chunk have been processed. At the +// same time _writeBody will take over responsibility for the chunk. The +// callback is only called in that particular case +Decoder.prototype._writeBody = function (chunk, offset, cb) { + if (this._bodyBytesWritten === 0) debug('start of body') + + var bytesLeft = this._bodySize - this._bodyBytesWritten + var end = bytesLeft < chunk.length - offset ? offset + bytesLeft : chunk.length + + var drained = this._msg.write(chunk.slice(offset, end)) + + this._bodyBytesWritten += chunk.length + + if (this._bodyBytesWritten >= this._bodySize) { + debug('end of body') + this._inBody = false + this._bodyBytesWritten = 0 + this._msg.end() + } + + if (!drained) { + debug('back pressure detected in IncomingMessage') + this._msg._chunk = chunk + this._msg._end = end + this._msg._cb = cb + return 0 // indicate we didn't consume the chunk (yet) + } + + return end +} + +function indexOfBody (buf, start, end) { + for (var n = start; n < end - 1; n++) { + if (buf[n] === CR && buf[n + 1] === NL && buf[n + 2] === CR && buf[n + 3] === NL && n <= end - 4) return n + 4 + if (buf[n] === NL && buf[n + 1] === NL) return n + 2 + if (buf[n] === CR && buf[n + 1] === CR) return n + 2 // weird, but the RFC allows it + } + return -1 +} diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/encoder.js b/node_modules/rtsp-server/node_modules/rtsp-stream/encoder.js new file mode 100644 index 0000000..d56cb92 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/encoder.js @@ -0,0 +1,65 @@ +'use strict' + +var util = require('util') +var stream = require('readable-stream') +var Response = require('./lib/response') +var Request = require('./lib/request') + +var Encoder = module.exports = function (opts) { + if (!(this instanceof Encoder)) return new Encoder(opts) + stream.Readable.call(this, opts) + this._messageQueue = [] +} + +util.inherits(Encoder, stream.Readable) + +Encoder.prototype._read = function (size) { + if (this._drainedCallback) { + var cb = this._drainedCallback + this._drainedCallback = null + cb() + } +} + +Encoder.prototype._push = function (chunk, encoding, cb) { + var drained = this.push(chunk, encoding) + if (drained) return cb() + this._drainedCallback = cb +} + +// Build a new response. We have to take extra care if more than one +// response is active at the same time. In that case, the order in which +// the responses was created should be the same as the order of which +// their data is emitted from the encoder stream. Also, data from one +// response must not be mixed with data from another response. +Encoder.prototype.response = function () { + var res = new Response(this) + this._pushQueue(res) + return res +} + +// Options: +// - method +// - uri +// - headers (optional) +// - body (optional) +Encoder.prototype.request = function (opts, cb) { + var req = new Request(this, opts) + if (cb) req.on('finish', cb) + this._pushQueue(req) + return req +} + +Encoder.prototype._pushQueue = function (msg) { + this._messageQueue.push(msg) + if (this._messageQueue.length > 1) return + msg.once('finish', this._shiftQueue.bind(this)) + msg._kick() +} + +Encoder.prototype._shiftQueue = function () { + this._messageQueue.shift() + if (this._messageQueue.length === 0) return + this._messageQueue[0].once('finish', this._shiftQueue.bind(this)) + this._messageQueue[0]._kick() +} diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/index.js b/node_modules/rtsp-server/node_modules/rtsp-stream/index.js new file mode 100644 index 0000000..9fb0c03 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/index.js @@ -0,0 +1,9 @@ +'use strict' + +exports.STATUS_CODES = require('./lib/status-codes') +exports.Decoder = require('./decoder') +exports.Encoder = require('./encoder') +exports.IncomingMessage = require('./lib/incoming-message') +exports.OutgoingMessage = require('./lib/outgoing-message') +exports.Request = require('./lib/request') +exports.Response = require('./lib/response') diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/lib/debug.js b/node_modules/rtsp-server/node_modules/rtsp-stream/lib/debug.js new file mode 100644 index 0000000..b0863c6 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/lib/debug.js @@ -0,0 +1,5 @@ +'use strict' + +var pkg = require('../package') + +module.exports = require('debug')(pkg.name) diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/lib/incoming-message.js b/node_modules/rtsp-server/node_modules/rtsp-stream/lib/incoming-message.js new file mode 100644 index 0000000..dc2c612 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/lib/incoming-message.js @@ -0,0 +1,42 @@ +'use strict' + +var util = require('util') +var stream = require('readable-stream') +var nextLine = require('next-line') +var httpHeaders = require('http-headers') +var requestLine = require('./request-line') +var statusLine = require('./status-line') + +var STATUS_LINE_START = new Buffer('RTSP/1.0') + +var IncomingMessage = module.exports = function (head, opts) { + if (!(this instanceof IncomingMessage)) return new IncomingMessage(head, opts) + + stream.PassThrough.call(this, opts) + + if (typeof head === 'string') head = new Buffer(head) + + var line = nextLine(head)() + + if (isResponse(head)) { + line = statusLine.parse(line) + this.statusCode = line.statusCode + this.statusMessage = line.statusMessage + } else { + line = requestLine.parse(line) + this.method = line.method + this.uri = line.uri + } + + this.rtspVersion = line.rtspVersion + this.headers = httpHeaders(head) +} + +util.inherits(IncomingMessage, stream.PassThrough) + +function isResponse (head) { + for (var i = 0; i < 8; i++) { + if (STATUS_LINE_START[i] !== head[i]) return false + } + return true +} diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/lib/outgoing-message.js b/node_modules/rtsp-server/node_modules/rtsp-stream/lib/outgoing-message.js new file mode 100644 index 0000000..faef06e --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/lib/outgoing-message.js @@ -0,0 +1,91 @@ +'use strict' + +var util = require('util') +var stream = require('readable-stream') +var debug = require('./debug') + +var OutgoingMessage = module.exports = function (encoder, opts) { + if (!(this instanceof OutgoingMessage)) return new OutgoingMessage(encoder, opts) + + stream.Writable.call(this, opts) + + this.headersSent = false + this._encoder = encoder + this._headers = {} + + this.on('finish', function () { + if (!this.headersSent) this.writeHead() // must be implemented by descendants + }) +} + +util.inherits(OutgoingMessage, stream.Writable) + +OutgoingMessage.prototype._write = function (chunk, encoding, cb) { + if (this._active) { + if (!this.headersSent) this.writeHead() // must be implemented by descendants + this._encoder._push(chunk, encoding, cb) + } else { + this._bufChunk = chunk + this._bufEncoding = encoding + this._bufCallback = cb + } +} + +OutgoingMessage.prototype._kick = function () { + this._active = true + if (!this._bufChunk) return + var chunk = this._bufChunk + var encoding = this._bufEncoding + var cb = this._bufCallback + this._bufChunk = null + this._bufEncoding = null + this._bufCallback = null + this._write(chunk, encoding, cb) +} + +OutgoingMessage.prototype.setHeader = function (name, value) { + if (this.headersSent) throw new Error('Headers already sent!') + this._headers[name.toLowerCase()] = [name, value] +} + +OutgoingMessage.prototype.getHeader = function (name) { + var header = this._headers[name.toLowerCase()] + return header ? header[1] : undefined +} + +OutgoingMessage.prototype.removeHeader = function (name) { + if (this.headersSent) throw new Error('Headers already sent!') + delete this._headers[name.toLowerCase()] +} + +OutgoingMessage.prototype._writeHead = function (startLine, headers) { + var self = this + + if (this.headersSent) throw new Error('Headers already sent!') + + if (headers) { + Object.keys(headers).forEach(function (name) { + self.setHeader(name, headers[name]) + }) + } + + this._encoder.push(startLine, 'utf8') + debug('start-line sent', startLine.trim()) + + var debugHeaders = {} + Object.keys(this._headers).forEach(function (key) { + var header = self._headers[key] + var name = header[0] + var value = header[1] + debugHeaders[name] = value + if (!Array.isArray(value)) value = [value] + value.forEach(function (value) { + self._encoder.push(util.format('%s: %s\r\n', name, value), 'utf8') + }) + }) + + this._encoder.push('\r\n', 'utf8') + debug('headers sent', debugHeaders) + + this.headersSent = true +} diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/lib/request-line.js b/node_modules/rtsp-server/node_modules/rtsp-stream/lib/request-line.js new file mode 100644 index 0000000..56d4b05 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/lib/request-line.js @@ -0,0 +1,19 @@ +'use strict' + +var util = require('util') + +var regexp = /^([A-Z_]+) ([^ ]+) RTSP\/(\d\.\d)[\r\n]*$/ + +// Format: +// Method SP Request-URI SP HTTP-Version CRLF +// Example: +// OPTIONS rtsp://example.com/media.mp4 RTSP/1.0 +exports.parse = function (line) { + var match = line.match(regexp) + if (!match) throw new Error('Invalid RTSP Request-Line: ' + util.inspect(line)) + return { + method: match[1], + uri: match[2], + rtspVersion: match[3] + } +} diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/lib/request.js b/node_modules/rtsp-server/node_modules/rtsp-stream/lib/request.js new file mode 100644 index 0000000..8760997 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/lib/request.js @@ -0,0 +1,33 @@ +'use strict' + +var util = require('util') +var OutgoingMessage = require('./outgoing-message') + +var Request = module.exports = function (encoder, opts, streamOpts) { + if (!(this instanceof Request)) return new Request(encoder, opts, streamOpts) + + OutgoingMessage.call(this, encoder, streamOpts) + + this.method = opts.method + this.uri = opts.uri + + var self = this + if (opts.headers) { + Object.keys(opts.headers).forEach(function (name) { + self.setHeader(name, opts.headers[name]) + }) + } + + if (opts.body) { + this.write(opts.body) + process.nextTick(this.end.bind(this)) + } +} + +util.inherits(Request, OutgoingMessage) + +Request.prototype.writeHead = function () { + if (this.headersSent) throw new Error('Headers already sent!') + var requestLine = util.format('%s %s RTSP/1.0\r\n', this.method, this.uri) + this._writeHead(requestLine) +} diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/lib/response.js b/node_modules/rtsp-server/node_modules/rtsp-stream/lib/response.js new file mode 100644 index 0000000..796adbf --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/lib/response.js @@ -0,0 +1,30 @@ +'use strict' + +var util = require('util') +var OutgoingMessage = require('./outgoing-message') +var STATUS_CODES = require('./status-codes') + +var Response = module.exports = function (encoder, opts) { + if (!(this instanceof Response)) return new Response(encoder, opts) + + OutgoingMessage.call(this, encoder, opts) + + this.statusCode = 200 +} + +util.inherits(Response, OutgoingMessage) + +Response.prototype.writeHead = function (statusCode, statusMessage, headers) { + if (this.headersSent) throw new Error('Headers already sent!') + + if (typeof statusMessage === 'object') { + headers = statusMessage + statusMessage = null + } + + if (statusCode) this.statusCode = statusCode + this.statusMessage = statusMessage || this.statusMessage || STATUS_CODES[String(this.statusCode)] + var statusLine = util.format('RTSP/1.0 %s %s\r\n', this.statusCode, this.statusMessage) + + this._writeHead(statusLine, headers) +} diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/lib/status-codes.js b/node_modules/rtsp-server/node_modules/rtsp-stream/lib/status-codes.js new file mode 100644 index 0000000..8b4c4a8 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/lib/status-codes.js @@ -0,0 +1,58 @@ +'use strict' + +// Where applicable, HTTP status codes are reused. Custom RTSP status codes +// have been marked as such below +// +// Check RFC 2326 section 11 for details: +// https://tools.ietf.org/html/rfc2326#page-41 + +module.exports = { + '100': 'Continue', + + '200': 'OK', + '201': 'Created', + '250': 'Low on Storage Space', // RTSP + + '300': 'Multiple Choices', + '301': 'Moved Permanently', + '302': 'Moved Temporarily', + '303': 'See Other', + '304': 'Not Modified', + '305': 'Use Proxy', + + '400': 'Bad Request', + '401': 'Unauthorized', + '402': 'Payment Required', + '403': 'Forbidden', + '404': 'Not Found', + '405': 'Method Not Allowed', + '406': 'Not Acceptable', + '407': 'Proxy Authentication Required', + '408': 'Request Time-out', + '410': 'Gone', + '411': 'Length Required', + '412': 'Precondition Failed', + '413': 'Request Entity Too Large', + '414': 'Request-URI Too Large', + '415': 'Unsupported Media Type', + '451': 'Parameter Not Understood', // RTSP + '452': 'Conference Not Found', // RTSP + '453': 'Not Enough Bandwidth', // RTSP + '454': 'Session Not Found', // RTSP + '455': 'Method Not Valid in This State', // RTSP + '456': 'Header Field Not Valid for Resource', // RTSP + '457': 'Invalid Range', // RTSP + '458': 'Parameter Is Read-Only', // RTSP + '459': 'Aggregate Operation Not Allowed', // RTSP + '460': 'Only Aggregate Operation Allowed', // RTSP + '461': 'Unsupported Transport', // RTSP + '462': 'Destination Unreachable', // RTSP + + '500': 'Internal Server Error', + '501': 'Not Implemented', + '502': 'Bad Gateway', + '503': 'Service Unavailable', + '504': 'Gateway Time-out', + '505': 'HTTP Version Not Supported', + '551': 'Option not supported' // RTSP +} diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/lib/status-line.js b/node_modules/rtsp-server/node_modules/rtsp-stream/lib/status-line.js new file mode 100644 index 0000000..0bdd55a --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/lib/status-line.js @@ -0,0 +1,19 @@ +'use strict' + +var util = require('util') + +var regexp = /^RTSP\/(\d\.\d) (\d{3}) (.*)[\r\n]*$/ + +// Format: +// RTSP-Version SP Status-Code SP Reason-Phrase CRLF +// Example: +// RTSP/1.0 200 OK +exports.parse = function (line) { + var match = line.match(regexp) + if (!match) throw new Error('Invalid RTSP Status-Line: ' + util.inspect(line)) + return { + rtspVersion: match[1], + statusCode: parseInt(match[2], 10), + statusMessage: match[3] + } +} diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/.npmignore b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/.npmignore new file mode 100644 index 0000000..da23d0d --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/.npmignore @@ -0,0 +1,25 @@ +# Logs +logs +*.log + +# Runtime data +pids +*.pid +*.seed + +# Directory for instrumented libs generated by jscoverage/JSCover +lib-cov + +# Coverage directory used by tools like istanbul +coverage + +# Grunt intermediate storage (http://gruntjs.com/creating-plugins#storing-task-files) +.grunt + +# Compiled binary addons (http://nodejs.org/api/addons.html) +build/Release + +# Dependency directory +# Deployed apps should consider commenting this line out: +# see https://npmjs.org/doc/faq.html#Should-I-check-my-node_modules-folder-into-git +node_modules diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/.travis.yml b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/.travis.yml new file mode 100644 index 0000000..f0418c1 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/.travis.yml @@ -0,0 +1,8 @@ +language: node_js +node_js: +- '0.12' +- '0.10' +- '0.8' +- 'iojs' +before_install: +- npm install -g npm@~1.4.6 diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/LICENSE b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/LICENSE new file mode 100644 index 0000000..7cdc145 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/LICENSE @@ -0,0 +1,21 @@ +The MIT License (MIT) + +Copyright (c) 2015 Thomas Watson Steen + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/README.md b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/README.md new file mode 100644 index 0000000..84fc9f6 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/README.md @@ -0,0 +1,104 @@ +# http-headers + +[![Build status](https://travis-ci.org/watson/http-headers.svg?branch=master)](https://travis-ci.org/watson/http-headers) +[![js-standard-style](https://img.shields.io/badge/code%20style-standard-brightgreen.svg?style=flat)](https://github.com/feross/standard) + +Extract and parse headers from an HTTP request or reponse. + +Converts: + +``` +HTTP/1.1 200 OK +Date: Tue, 10 Jun 2014 07:19:27 GMT +Connection: keep-alive +Transfer-Encoding: chunked + +Hello World +``` + +To this: + +```js +{ date: 'Tue, 10 Jun 2014 07:19:27 GMT', + connection: 'keep-alive', + 'transfer-encoding': 'chunked' } +``` + +**Features:** + +- Auto-detects and ignores HTTP start-line if present +- Auto-detects and ignores body if present +- Fully [RFC 2068](http://www.rfc-base.org/txt/rfc-2068.txt) compliant + (please [open an issue](https://github.com/watson/http-headers/issues) + if you find a discrepancy) +- Support multi-line headers (lines will be joined with a space) +- Support repeating headers (values will be joined with `, `) + +## Installation + +``` +npm install http-headers +``` + +## Usage + +```js +var net = require('net') +var httpHeaders = require('http-headers') + +// create TCP server +net.createServer(function (c) { + var buffers = [] + c.on('data', buffers.push.bind(buffers)) + c.on('end', function () { + var data = Buffer.concat(buffers) + + // parse incoming data as an HTTP request and extra HTTP headers + console.log('Request headers:', httpHeaders(data)) + }) +}).listen(8080) +``` + +### `http.ServerReponse` support + +If given an instance of `http.ServerResponse`, the reponse headers is +automatically extracted, parsed and returned: + +```js +var http = require('http') +var httpHeaders = require('http-headers') + +http.createServer(function (req, res) { + res.end('Hello World') + console.log('Response headers:', httpHeaders(res)) +}).listen(8080) +``` + +#### Why? + +If you've ever needed to log or in another way access the headers sent +to the client on a `http.ServerResponse` in Node.js, you know it's not +as easy as with the `http.IncomingMessage` headers (which you just +access via `request.headers['content-type']`). + +Response headers are not directly available on the `response` object. +Instead all headers are preprocessed as a string on the private +`response._header` property and needs to be processed in order to be +available as an object. + +This module makes the task super simple. + +## API + +The http-headers module exposes a single parser function: + +``` +httpHeaders([ string | buffer | http.ServerReponse ]) +``` + +The module returns a JavaScript object with each element representing a +parsed header. All header names are lowercased. + +## License + +MIT diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/index.js b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/index.js new file mode 100644 index 0000000..0ff8783 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/index.js @@ -0,0 +1,55 @@ +'use strict' + +var strip = require('strip-lines') +var nextLine = require('next-line') + +// RFC-2068 Start-Line definitions: +// Request-Line: Method SP Request-URI SP HTTP-Version CRLF +// Status-Line: HTTP-Version SP Status-Code SP Reason-Phrase CRLF +var startLine = /^[A-Z_]+(\/\d\.\d)? / + +module.exports = function (str) { + return parse(normalize(str)) +} + +function normalize (str) { + if (str && str._header) str = str._header // extra headers from http.ServerResponse object + if (!str || typeof str.toString !== 'function') return '' + str = str.toString().trim() + if (startLine.test(str)) str = strip(str, 1) + return str +} + +function parse (str) { + var headers = {} + var next = nextLine(str) + var line = next() + var index, name, value + + while (line) { + // subsequent lines in multi-line headers start with whitespace + if (line[0] === ' ' || line[0] === '\t') { + value += ' ' + line.trim() + line = next() + continue + } + + if (name) addMessageHeader() + + index = line.indexOf(':') + name = line.substr(0, index) + value = line.substr(index + 1).trim() + + line = next() + } + + if (name) addMessageHeader() + + return headers + + function addMessageHeader () { + name = name.toLowerCase() + if (name in headers) headers[name] += ', ' + value + else headers[name] = value + } +} diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/node_modules/strip-lines/.npmignore b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/node_modules/strip-lines/.npmignore new file mode 100644 index 0000000..3c3629e --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/node_modules/strip-lines/.npmignore @@ -0,0 +1 @@ +node_modules diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/node_modules/strip-lines/.travis.yml b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/node_modules/strip-lines/.travis.yml new file mode 100644 index 0000000..f0418c1 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/node_modules/strip-lines/.travis.yml @@ -0,0 +1,8 @@ +language: node_js +node_js: +- '0.12' +- '0.10' +- '0.8' +- 'iojs' +before_install: +- npm install -g npm@~1.4.6 diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/node_modules/strip-lines/LICENSE b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/node_modules/strip-lines/LICENSE new file mode 100644 index 0000000..7cdc145 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/node_modules/strip-lines/LICENSE @@ -0,0 +1,21 @@ +The MIT License (MIT) + +Copyright (c) 2015 Thomas Watson Steen + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/node_modules/strip-lines/README.md b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/node_modules/strip-lines/README.md new file mode 100644 index 0000000..87f1c71 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/node_modules/strip-lines/README.md @@ -0,0 +1,39 @@ +# strip-lines + +Remove n lines from the beginning of a string. + +[![Build status](https://travis-ci.org/watson/strip-lines.svg?branch=master)](https://travis-ci.org/watson/strip-lines) +[![js-standard-style](https://img.shields.io/badge/code%20style-standard-brightgreen.svg?style=flat)](https://github.com/feross/standard) + +## Installation + +``` +npm install strip-lines +``` + +## Usage + +```js +var strip = require('strip-lines') + +var str = 'foo\r\nbar\nbaz' + +// remove the first 2 lines from `str` +console.log(strip(str, 2)) // => baz +``` + +## API + +The module exposes a single function which takes two arguments: + +``` +strip(string, lines) +``` + +- `string` - The string that should be parsed +- `lines` - The number of lines to remove from the beginning of the + provided `string` + +## License + +MIT diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/node_modules/strip-lines/index.js b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/node_modules/strip-lines/index.js new file mode 100644 index 0000000..d350086 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/node_modules/strip-lines/index.js @@ -0,0 +1,16 @@ +'use strict' + +module.exports = function (str, lines) { + while (lines-- && str) str = removeSingleLine(str) + return str || '' +} + +function removeSingleLine (str) { + var index = str.indexOf('\r\n') + if (index !== -1) return str.substr(index + 2) + index = str.indexOf('\n') + if (index !== -1) return str.substr(index + 1) + index = str.indexOf('\r') + if (index !== -1) return str.substr(index + 1) + return '' +} diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/node_modules/strip-lines/package.json b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/node_modules/strip-lines/package.json new file mode 100644 index 0000000..bb125a0 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/node_modules/strip-lines/package.json @@ -0,0 +1,63 @@ +{ + "name": "strip-lines", + "version": "1.0.1", + "description": "Remove n lines from the beginning of a string", + "main": "index.js", + "scripts": { + "test": "standard && tape test.js" + }, + "keywords": [ + "strip", + "remove", + "trim", + "line", + "lines", + "crlf", + "newline" + ], + "author": { + "name": "Thomas Watson Steen", + "email": "w@tson.dk", + "url": "https://twitter.com/wa7son" + }, + "license": "MIT", + "dependencies": {}, + "devDependencies": { + "standard": "^5.1.1", + "tape": "^4.2.0" + }, + "repository": { + "type": "git", + "url": "git+https://github.com/watson/strip-lines.git" + }, + "bugs": { + "url": "https://github.com/watson/strip-lines/issues" + }, + "homepage": "https://github.com/watson/strip-lines#readme", + "coordinates": [ + 55.6877134, + 12.5956538 + ], + "gitHead": "6e17b32f080571df8bce0e678789a13a12bd522b", + "_id": "strip-lines@1.0.1", + "_shasum": "6737616ccb20f89fd81a18759e60aef93aa8bd75", + "_from": "strip-lines@>=1.0.1 <2.0.0", + "_npmVersion": "2.13.4", + "_nodeVersion": "0.12.7", + "_npmUser": { + "name": "watson", + "email": "w@tson.dk" + }, + "maintainers": [ + { + "name": "watson", + "email": "w@tson.dk" + } + ], + "dist": { + "shasum": "6737616ccb20f89fd81a18759e60aef93aa8bd75", + "tarball": "https://registry.npmjs.org/strip-lines/-/strip-lines-1.0.1.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/strip-lines/-/strip-lines-1.0.1.tgz" +} diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/node_modules/strip-lines/test.js b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/node_modules/strip-lines/test.js new file mode 100644 index 0000000..00713d8 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/node_modules/strip-lines/test.js @@ -0,0 +1,64 @@ +'use strict' + +var test = require('tape') +var strip = require('./') + +test('CRLF', function (t) { + t.equal(strip('foo\r\nbar\r\nbaz', 1), 'bar\r\nbaz') + t.end() +}) + +test('CR', function (t) { + t.equal(strip('foo\rbar\rbaz', 1), 'bar\rbaz') + t.end() +}) + +test('LF', function (t) { + t.equal(strip('foo\nbar\nbaz', 1), 'bar\nbaz') + t.end() +}) + +test('Mixed line break', function (t) { + t.equal(strip('foo\r\nbar\nbaz', 1), 'bar\nbaz') + t.end() +}) + +test('empty string', function (t) { + t.equal(strip('', 1), '') + t.end() +}) + +test('undefined', function (t) { + t.equal(strip(undefined, 1), '') + t.end() +}) + +test('CRLF (2 lines)', function (t) { + t.equal(strip('foo\r\nbar\r\nbaz', 2), 'baz') + t.end() +}) + +test('CR (2 lines)', function (t) { + t.equal(strip('foo\rbar\rbaz', 2), 'baz') + t.end() +}) + +test('LF (2 lines)', function (t) { + t.equal(strip('foo\nbar\nbaz', 2), 'baz') + t.end() +}) + +test('Mixed line break (2 lines)', function (t) { + t.equal(strip('foo\r\nbar\nbaz', 2), 'baz') + t.end() +}) + +test('empty string (2 lines)', function (t) { + t.equal(strip('', 2), '') + t.end() +}) + +test('undefined (2 lines)', function (t) { + t.equal(strip(undefined, 2), '') + t.end() +}) diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/package.json b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/package.json new file mode 100644 index 0000000..8e9879d --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/package.json @@ -0,0 +1,66 @@ +{ + "name": "http-headers", + "version": "1.2.0", + "description": "Parse http headers", + "main": "index.js", + "scripts": { + "test": "standard && tape test.js" + }, + "repository": { + "type": "git", + "url": "git://github.com/watson/http-headers.git" + }, + "dependencies": { + "next-line": "^1.0.0", + "strip-lines": "^1.0.1" + }, + "devDependencies": { + "standard": "^5.1.1", + "tape": "^4.2.0" + }, + "keywords": [ + "http", + "https", + "header", + "headers", + "parse", + "parsing", + "ServerResponse", + "response" + ], + "author": { + "name": "Thomas Watson Steen", + "email": "w@tson.dk", + "url": "https://twitter.com/wa7son" + }, + "license": "MIT", + "bugs": { + "url": "https://github.com/watson/http-headers/issues" + }, + "homepage": "https://github.com/watson/http-headers", + "coordinates": [ + 55.68773059999999, + 12.5956059 + ], + "gitHead": "8592404b6611650cc2dcb603cc2ec6fc4d928b5a", + "_id": "http-headers@1.2.0", + "_shasum": "0c754239fc14aec858bda1cbd069f171bfa6a3fa", + "_from": "http-headers@>=1.2.0 <2.0.0", + "_npmVersion": "1.4.28", + "_npmUser": { + "name": "watson", + "email": "w@tson.dk" + }, + "maintainers": [ + { + "name": "watson", + "email": "w@tson.dk" + } + ], + "dist": { + "shasum": "0c754239fc14aec858bda1cbd069f171bfa6a3fa", + "tarball": "https://registry.npmjs.org/http-headers/-/http-headers-1.2.0.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/http-headers/-/http-headers-1.2.0.tgz" +} diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/test.js b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/test.js new file mode 100644 index 0000000..5b3856d --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/http-headers/test.js @@ -0,0 +1,91 @@ +'use strict' + +var test = require('tape') +var http = require('http') +var httpHeaders = require('./') + +var requestLine = 'GET /foo HTTP/1.1\r\n' +var statusLine = 'HTTP/1.1 200 OK\r\n' +var msgHeaders = 'Date: Tue, 10 Jun 2014 07:29:20 GMT\r\n' + + 'Connection: keep-alive\r\n' + + 'Transfer-Encoding: chunked\r\n' + + 'X-List: A\r\n' + + 'X-Multi-Line-Header: Foo\r\n' + + ' Bar\r\n' + + 'X-List: B\r\n' + + '\r\n' +var requestMsg = requestLine + msgHeaders + 'Hello: World' +var responseMsg = statusLine + msgHeaders + 'Hello: World' + +var result = { + date: 'Tue, 10 Jun 2014 07:29:20 GMT', + connection: 'keep-alive', + 'transfer-encoding': 'chunked', + 'x-list': 'A, B', + 'x-multi-line-header': 'Foo Bar' +} + +test('no argument', function (t) { + t.deepEqual(httpHeaders(), {}) + t.end() +}) + +test('empty string', function (t) { + t.deepEqual(httpHeaders(''), {}) + t.end() +}) + +test('empty object', function (t) { + t.deepEqual(httpHeaders({}), {}) + t.end() +}) + +test('empty buffer', function (t) { + t.deepEqual(httpHeaders(new Buffer('')), {}) + t.end() +}) + +test('start-line + header', function (t) { + t.deepEqual(httpHeaders(requestLine + msgHeaders), result) + t.deepEqual(httpHeaders(statusLine + msgHeaders), result) + t.deepEqual(httpHeaders(new Buffer(requestLine + msgHeaders)), result) + t.deepEqual(httpHeaders(new Buffer(statusLine + msgHeaders)), result) + t.end() +}) + +test('headers only', function (t) { + t.deepEqual(httpHeaders(msgHeaders), result) + t.deepEqual(httpHeaders(new Buffer(msgHeaders)), result) + t.end() +}) + +test('full http response', function (t) { + t.deepEqual(httpHeaders(requestMsg), result) + t.deepEqual(httpHeaders(responseMsg), result) + t.deepEqual(httpHeaders(new Buffer(requestMsg)), result) + t.deepEqual(httpHeaders(new Buffer(responseMsg)), result) + t.end() +}) + +test('http.ServerResponse', function (t) { + t.test('real http.ServerResponse object', function (t) { + var res = new http.ServerResponse({}) + t.deepEqual(httpHeaders(res), {}) + t.end() + }) + + t.test('no _header property', function (t) { + t.deepEqual(httpHeaders({ _header: undefined }), {}) + t.end() + }) + + t.test('empty string as _header', function (t) { + t.deepEqual(httpHeaders({ _header: '' }), {}) + t.end() + }) + + t.test('normal _header property', function (t) { + t.deepEqual(httpHeaders({ _header: statusLine + msgHeaders }), result) + t.end() + }) +}) diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/next-line/.npmignore b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/next-line/.npmignore new file mode 100644 index 0000000..3c3629e --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/next-line/.npmignore @@ -0,0 +1 @@ +node_modules diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/next-line/.travis.yml b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/next-line/.travis.yml new file mode 100644 index 0000000..f0418c1 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/next-line/.travis.yml @@ -0,0 +1,8 @@ +language: node_js +node_js: +- '0.12' +- '0.10' +- '0.8' +- 'iojs' +before_install: +- npm install -g npm@~1.4.6 diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/next-line/LICENSE b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/next-line/LICENSE new file mode 100644 index 0000000..7cdc145 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/next-line/LICENSE @@ -0,0 +1,21 @@ +The MIT License (MIT) + +Copyright (c) 2015 Thomas Watson Steen + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/next-line/README.md b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/next-line/README.md new file mode 100644 index 0000000..eeeb45b --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/next-line/README.md @@ -0,0 +1,30 @@ +# next-line + +Iterator over lines in a string: + +- Support different newline types: CRLF, LF, CR +- Support mixed newline formats in the same string + +[![Build status](https://travis-ci.org/watson/next-line.svg?branch=master)](https://travis-ci.org/watson/next-line) +[![js-standard-style](https://img.shields.io/badge/code%20style-standard-brightgreen.svg?style=flat)](https://github.com/feross/standard) + +## Installation + +``` +npm install next-line +``` + +## Usage + +```js +var next = require('next-line')('foo\r\nbar\nbaz') + +console.log(next()) // => foo +console.log(next()) // => bar +console.log(next()) // => baz +console.log(next()) // => null +``` + +## License + +MIT diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/next-line/index.js b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/next-line/index.js new file mode 100644 index 0000000..86ed25c --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/next-line/index.js @@ -0,0 +1,38 @@ +'use strict' + +module.exports = function (str) { + var offset = 0 + str = str.toString() + + return iterator + + function iterator () { + var i1 = str.indexOf('\r\n', offset) + var i2 = str.indexOf('\n', offset) + var i3 = str.indexOf('\r', offset) + + var indexes = [i1, i2, i3] + var index = indexes + .sort(function (a, b) { + if (a > b) return 1 + if (a < b) return -1 + return 0 + }) + .filter(function (index) { + return index !== -1 + })[0] + + if (index !== undefined) return extract(index, index === i1 ? 2 : 1) + + var length = str.length + if (length === offset) return null + + return extract(length, 0) + } + + function extract (index, skip) { + var line = str.substr(offset, index - offset) + offset = index + skip + return line + } +} diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/next-line/package.json b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/next-line/package.json new file mode 100644 index 0000000..656c3dc --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/next-line/package.json @@ -0,0 +1,64 @@ +{ + "name": "next-line", + "version": "1.1.0", + "description": "Iterator over lines in a string", + "main": "index.js", + "scripts": { + "test": "standard && tape test.js" + }, + "repository": { + "type": "git", + "url": "git+https://github.com/watson/next-line.git" + }, + "keywords": [ + "line", + "lines", + "string", + "str", + "crlf", + "iterate", + "iterator", + "loop", + "next" + ], + "author": { + "name": "Thomas Watson Steen", + "email": "w@tson.dk", + "url": "https://twitter.com/wa7son" + }, + "license": "MIT", + "bugs": { + "url": "https://github.com/watson/next-line/issues" + }, + "homepage": "https://github.com/watson/next-line#readme", + "devDependencies": { + "standard": "^5.1.1", + "tape": "^4.2.0" + }, + "coordinates": [ + 55.6877161, + 12.5955598 + ], + "gitHead": "4e2f83a77b350706fb699452abb6b0582e4da2b8", + "_id": "next-line@1.1.0", + "_shasum": "fcae57853052b6a9bae8208e40dd7d3c2d304603", + "_from": "next-line@>=1.1.0 <2.0.0", + "_npmVersion": "2.13.4", + "_nodeVersion": "0.12.7", + "_npmUser": { + "name": "watson", + "email": "w@tson.dk" + }, + "maintainers": [ + { + "name": "watson", + "email": "w@tson.dk" + } + ], + "dist": { + "shasum": "fcae57853052b6a9bae8208e40dd7d3c2d304603", + "tarball": "https://registry.npmjs.org/next-line/-/next-line-1.1.0.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/next-line/-/next-line-1.1.0.tgz" +} diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/next-line/test.js b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/next-line/test.js new file mode 100644 index 0000000..25d8803 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/next-line/test.js @@ -0,0 +1,40 @@ +'use strict' + +var test = require('tape') +var nextLine = require('./') + +var strings = [ + 'a\nb\nc\nd\n\ne', + 'a\rb\rc\rd\r\re', + 'a\r\nb\r\nc\r\nd\r\n\r\ne', + 'a\r\nb\nc\rd\r\n\ne', + 'a\r\nb\rc\nd\r\n\re' +] + +strings.forEach(function (str, index) { + test('string ' + index, function (t) { + var next = nextLine(str) + t.equal(next(), 'a') + t.equal(next(), 'b') + t.equal(next(), 'c') + t.equal(next(), 'd') + t.equal(next(), '') + t.equal(next(), 'e') + t.equal(next(), null) + t.end() + }) +}) + +strings.forEach(function (str, index) { + test('buffer ' + index, function (t) { + var next = nextLine(new Buffer(str)) + t.equal(next(), 'a') + t.equal(next(), 'b') + t.equal(next(), 'c') + t.equal(next(), 'd') + t.equal(next(), '') + t.equal(next(), 'e') + t.equal(next(), null) + t.end() + }) +}) diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/.npmignore b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/.npmignore new file mode 100644 index 0000000..265ff73 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/.npmignore @@ -0,0 +1,8 @@ +build/ +test/ +examples/ +fs.js +zlib.js +.zuul.yml +.nyc_output +coverage diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/.travis.yml b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/.travis.yml new file mode 100644 index 0000000..84504c9 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/.travis.yml @@ -0,0 +1,49 @@ +sudo: false +language: node_js +before_install: + - npm install -g npm@2 + - npm install -g npm +notifications: + email: false +matrix: + fast_finish: true + include: + - node_js: '0.8' + env: TASK=test + - node_js: '0.10' + env: TASK=test + - node_js: '0.11' + env: TASK=test + - node_js: '0.12' + env: TASK=test + - node_js: 1 + env: TASK=test + - node_js: 2 + env: TASK=test + - node_js: 3 + env: TASK=test + - node_js: 4 + env: TASK=test + - node_js: 5 + env: TASK=test + - node_js: 6 + env: TASK=test + - node_js: 5 + env: TASK=browser BROWSER_NAME=android BROWSER_VERSION="4.0..latest" + - node_js: 5 + env: TASK=browser BROWSER_NAME=ie BROWSER_VERSION="9..latest" + - node_js: 5 + env: TASK=browser BROWSER_NAME=opera BROWSER_VERSION="11..latest" + - node_js: 5 + env: TASK=browser BROWSER_NAME=chrome BROWSER_VERSION="-3..latest" + - node_js: 5 + env: TASK=browser BROWSER_NAME=firefox BROWSER_VERSION="-3..latest" + - node_js: 5 + env: TASK=browser BROWSER_NAME=safari BROWSER_VERSION="5..latest" + - node_js: 5 + env: TASK=browser BROWSER_NAME=microsoftedge BROWSER_VERSION=latest +script: "npm run $TASK" +env: + global: + - secure: rE2Vvo7vnjabYNULNyLFxOyt98BoJexDqsiOnfiD6kLYYsiQGfr/sbZkPMOFm9qfQG7pjqx+zZWZjGSswhTt+626C0t/njXqug7Yps4c3dFblzGfreQHp7wNX5TFsvrxd6dAowVasMp61sJcRnB2w8cUzoe3RAYUDHyiHktwqMc= + - secure: g9YINaKAdMatsJ28G9jCGbSaguXCyxSTy+pBO6Ch0Cf57ZLOTka3HqDj8p3nV28LUIHZ3ut5WO43CeYKwt4AUtLpBS3a0dndHdY6D83uY6b2qh5hXlrcbeQTq2cvw2y95F7hm4D1kwrgZ7ViqaKggRcEupAL69YbJnxeUDKWEdI= diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/LICENSE b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/LICENSE new file mode 100644 index 0000000..e3d4e69 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/LICENSE @@ -0,0 +1,18 @@ +Copyright Joyent, Inc. and other Node contributors. All rights reserved. +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to +deal in the Software without restriction, including without limitation the +rights to use, copy, modify, merge, publish, distribute, sublicense, and/or +sell copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING +FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS +IN THE SOFTWARE. diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/README.md b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/README.md new file mode 100644 index 0000000..9fb4fea --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/README.md @@ -0,0 +1,36 @@ +# readable-stream + +***Node-core v6.3.1 streams for userland*** [![Build Status](https://travis-ci.org/nodejs/readable-stream.svg?branch=master)](https://travis-ci.org/nodejs/readable-stream) + + +[![NPM](https://nodei.co/npm/readable-stream.png?downloads=true&downloadRank=true)](https://nodei.co/npm/readable-stream/) +[![NPM](https://nodei.co/npm-dl/readable-stream.png?&months=6&height=3)](https://nodei.co/npm/readable-stream/) + + +[![Sauce Test Status](https://saucelabs.com/browser-matrix/readable-stream.svg)](https://saucelabs.com/u/readable-stream) + +```bash +npm install --save readable-stream +``` + +***Node-core streams for userland*** + +This package is a mirror of the Streams2 and Streams3 implementations in +Node-core, including [documentation](doc/stream.md). + +If you want to guarantee a stable streams base, regardless of what version of +Node you, or the users of your libraries are using, use **readable-stream** *only* and avoid the *"stream"* module in Node-core, for background see [this blogpost](http://r.va.gg/2014/06/why-i-dont-use-nodes-core-stream-module.html). + +As of version 2.0.0 **readable-stream** uses semantic versioning. + +# Streams WG Team Members + +* **Chris Dickinson** ([@chrisdickinson](https://github.com/chrisdickinson)) <christopher.s.dickinson@gmail.com> + - Release GPG key: 9554F04D7259F04124DE6B476D5A82AC7E37093B +* **Calvin Metcalf** ([@calvinmetcalf](https://github.com/calvinmetcalf)) <calvin.metcalf@gmail.com> + - Release GPG key: F3EF5F62A87FC27A22E643F714CE4FF5015AA242 +* **Rod Vagg** ([@rvagg](https://github.com/rvagg)) <rod@vagg.org> + - Release GPG key: DD8F2338BAE7501E3DD5AC78C273792F7D83545D +* **Sam Newman** ([@sonewman](https://github.com/sonewman)) <newmansam@outlook.com> +* **Mathias Buus** ([@mafintosh](https://github.com/mafintosh)) <mathiasbuus@gmail.com> +* **Domenic Denicola** ([@domenic](https://github.com/domenic)) <d@domenic.me> diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/doc/stream.md b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/doc/stream.md new file mode 100644 index 0000000..fc269c8 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/doc/stream.md @@ -0,0 +1,2015 @@ +# Stream + + Stability: 2 - Stable + +A stream is an abstract interface for working with streaming data in Node.js. +The `stream` module provides a base API that makes it easy to build objects +that implement the stream interface. + +There are many stream objects provided by Node.js. For instance, a +[request to an HTTP server][http-incoming-message] and [`process.stdout`][] +are both stream instances. + +Streams can be readable, writable, or both. All streams are instances of +[`EventEmitter`][]. + +The `stream` module can be accessed using: + +```js +const stream = require('stream'); +``` + +While it is important for all Node.js users to understand how streams works, +the `stream` module itself is most useful for developer's that are creating new +types of stream instances. Developer's who are primarily *consuming* stream +objects will rarely (if ever) have need to use the `stream` module directly. + +## Organization of this document + +This document is divided into two primary sections and third section for +additional notes. The first section explains the elements of the stream API that +are required to *use* streams within an application. The second section explains +the elements of the API that are required to *implement* new types of streams. + +## Types of Streams + +There are four fundamental stream types within Node.js: + +* [Readable][] - streams from which data can be read (for example + [`fs.createReadStream()`][]). +* [Writable][] - streams to which data can be written (for example + [`fs.createWriteStream()`][]). +* [Duplex][] - streams that are both Readable and Writable (for example + [`net.Socket`][]). +* [Transform][] - Duplex streams that can modify or transform the data as it + is written and read (for example [`zlib.createDeflate()`][]). + +### Object Mode + +All streams created by Node.js APIs operate exclusively on strings and `Buffer` +objects. It is possible, however, for stream implementations to work with other +types of JavaScript values (with the exception of `null` which serves a special +purpose within streams). Such streams are considered to operate in "object +mode". + +Stream instances are switched into object mode using the `objectMode` option +when the stream is created. Attempting to switch an existing stream into +object mode is not safe. + +### Buffering + + + +Both [Writable][] and [Readable][] streams will store data in an internal +buffer that can be retrieved using `writable._writableState.getBuffer()` or +`readable._readableState.buffer`, respectively. + +The amount of data potentially buffered depends on the `highWaterMark` option +passed into the streams constructor. For normal streams, the `highWaterMark` +option specifies a total number of bytes. For streams operating in object mode, +the `highWaterMark` specifies a total number of objects. + +Data is buffered in Readable streams when the implementation calls +[`stream.push(chunk)`][stream-push]. If the consumer of the Stream does not +call [`stream.read()`][stream-read], the data will sit in the internal +queue until it is consumed. + +Once the total size of the internal read buffer reaches the threshold specified +by `highWaterMark`, the stream will temporarily stop reading data from the +underlying resource until the data currently buffered can be consumed (that is, +the stream will stop calling the internal `readable._read()` method that is +used to fill the read buffer). + +Data is buffered in Writable streams when the +[`writable.write(chunk)`][stream-write] method is called repeatedly. While the +total size of the internal write buffer is below the threshold set by +`highWaterMark`, calls to `writable.write()` will return `true`. Once the +the size of the internal buffer reaches or exceeds the `highWaterMark`, `false` +will be returned. + +A key goal of the `stream` API, and in particular the [`stream.pipe()`] method, +is to limit the buffering of data to acceptable levels such that sources and +destinations of differing speeds will not overwhelm the available memory. + +Because [Duplex][] and [Transform][] streams are both Readable and Writable, +each maintain *two* separate internal buffers used for reading and writing, +allowing each side to operate independently of the other while maintaining an +appropriate and efficient flow of data. For example, [`net.Socket`][] instances +are [Duplex][] streams whose Readable side allows consumption of data received +*from* the socket and whose Writable side allows writing data *to* the socket. +Because data may be written to the socket at a faster or slower rate than data +is received, it is important each side operate (and buffer) independently of +the other. + +## API for Stream Consumers + + + +Almost all Node.js applications, no matter how simple, use streams in some +manner. The following is an example of using streams in a Node.js application +that implements an HTTP server: + +```js +const http = require('http'); + +const server = http.createServer( (req, res) => { + // req is an http.IncomingMessage, which is a Readable Stream + // res is an http.ServerResponse, which is a Writable Stream + + let body = ''; + // Get the data as utf8 strings. + // If an encoding is not set, Buffer objects will be received. + req.setEncoding('utf8'); + + // Readable streams emit 'data' events once a listener is added + req.on('data', (chunk) => { + body += chunk; + }); + + // the end event indicates that the entire body has been received + req.on('end', () => { + try { + const data = JSON.parse(body); + } catch (er) { + // uh oh! bad json! + res.statusCode = 400; + return res.end(`error: ${er.message}`); + } + + // write back something interesting to the user: + res.write(typeof data); + res.end(); + }); +}); + +server.listen(1337); + +// $ curl localhost:1337 -d '{}' +// object +// $ curl localhost:1337 -d '"foo"' +// string +// $ curl localhost:1337 -d 'not json' +// error: Unexpected token o +``` + +[Writable][] streams (such as `res` in the example) expose methods such as +`write()` and `end()` that are used to write data onto the stream. + +[Readable][] streams use the [`EventEmitter`][] API for notifying application +code when data is available to be read off the stream. That available data can +be read from the stream in multiple ways. + +Both [Writable][] and [Readable][] streams use the [`EventEmitter`][] API in +various ways to communicate the current state of the stream. + +[Duplex][] and [Transform][] streams are both [Writable][] and [Readable][]. + +Applications that are either writing data to or consuming data from a stream +are not required to implement the stream interfaces directly and will generally +have no reason to call `require('stream')`. + +Developers wishing to implement new types of streams should refer to the +section [API for Stream Implementers][]. + +### Writable Streams + +Writable streams are an abstraction for a *destination* to which data is +written. + +Examples of [Writable][] streams include: + +* [HTTP requests, on the client][] +* [HTTP responses, on the server][] +* [fs write streams][] +* [zlib streams][zlib] +* [crypto streams][crypto] +* [TCP sockets][] +* [child process stdin][] +* [`process.stdout`][], [`process.stderr`][] + +*Note*: Some of these examples are actually [Duplex][] streams that implement +the [Writable][] interface. + +All [Writable][] streams implement the interface defined by the +`stream.Writable` class. + +While specific instances of [Writable][] streams may differ in various ways, +all Writable streams follow the same fundamental usage pattern as illustrated +in the example below: + +```js +const myStream = getWritableStreamSomehow(); +myStream.write('some data'); +myStream.write('some more data'); +myStream.end('done writing data'); +``` + +#### Class: stream.Writable + + + + +##### Event: 'close' + + +The `'close'` event is emitted when the stream and any of its underlying +resources (a file descriptor, for example) have been closed. The event indicates +that no more events will be emitted, and no further computation will occur. + +Not all Writable streams will emit the `'close'` event. + +##### Event: 'drain' + + +If a call to [`stream.write(chunk)`][stream-write] returns `false`, the +`'drain'` event will be emitted when it is appropriate to resume writing data +to the stream. + +```js +// Write the data to the supplied writable stream one million times. +// Be attentive to back-pressure. +function writeOneMillionTimes(writer, data, encoding, callback) { + let i = 1000000; + write(); + function write() { + var ok = true; + do { + i--; + if (i === 0) { + // last time! + writer.write(data, encoding, callback); + } else { + // see if we should continue, or wait + // don't pass the callback, because we're not done yet. + ok = writer.write(data, encoding); + } + } while (i > 0 && ok); + if (i > 0) { + // had to stop early! + // write some more once it drains + writer.once('drain', write); + } + } +} +``` + +##### Event: 'error' + + +* {Error} + +The `'error'` event is emitted if an error occurred while writing or piping +data. The listener callback is passed a single `Error` argument when called. + +*Note*: The stream is not closed when the `'error'` event is emitted. + +##### Event: 'finish' + + +The `'finish'` event is emitted after the [`stream.end()`][stream-end] method +has been called, and all data has been flushed to the underlying system. + +```js +const writer = getWritableStreamSomehow(); +for (var i = 0; i < 100; i ++) { + writer.write('hello, #${i}!\n'); +} +writer.end('This is the end\n'); +writer.on('finish', () => { + console.error('All writes are now complete.'); +}); +``` + +##### Event: 'pipe' + + +* `src` {stream.Readable} source stream that is piping to this writable + +The `'pipe'` event is emitted when the [`stream.pipe()`][] method is called on +a readable stream, adding this writable to its set of destinations. + +```js +const writer = getWritableStreamSomehow(); +const reader = getReadableStreamSomehow(); +writer.on('pipe', (src) => { + console.error('something is piping into the writer'); + assert.equal(src, reader); +}); +reader.pipe(writer); +``` + +##### Event: 'unpipe' + + +* `src` {[Readable][] Stream} The source stream that + [unpiped][`stream.unpipe()`] this writable + +The `'unpipe'` event is emitted when the [`stream.unpipe()`][] method is called +on a [Readable][] stream, removing this [Writable][] from its set of +destinations. + +```js +const writer = getWritableStreamSomehow(); +const reader = getReadableStreamSomehow(); +writer.on('unpipe', (src) => { + console.error('Something has stopped piping into the writer.'); + assert.equal(src, reader); +}); +reader.pipe(writer); +reader.unpipe(writer); +``` + +##### writable.cork() + + +The `writable.cork()` method forces all written data to be buffered in memory. +The buffered data will be flushed when either the [`stream.uncork()`][] or +[`stream.end()`][stream-end] methods are called. + +The primary intent of `writable.cork()` is to avoid a situation where writing +many small chunks of data to a stream do not cause an backup in the internal +buffer that would have an adverse impact on performance. In such situations, +implementations that implement the `writable._writev()` method can perform +buffered writes in a more optimized manner. + +##### writable.end([chunk][, encoding][, callback]) + + +* `chunk` {String|Buffer|any} Optional data to write. For streams not operating + in object mode, `chunk` must be a string or a `Buffer`. For object mode + streams, `chunk` may be any JavaScript value other than `null`. +* `encoding` {String} The encoding, if `chunk` is a String +* `callback` {Function} Optional callback for when the stream is finished + +Calling the `writable.end()` method signals that no more data will be written +to the [Writable][]. The optional `chunk` and `encoding` arguments allow one +final additional chunk of data to be written immediately before closing the +stream. If provided, the optional `callback` function is attached as a listener +for the [`'finish'`][] event. + +Calling the [`stream.write()`][stream-write] method after calling +[`stream.end()`][stream-end] will raise an error. + +```js +// write 'hello, ' and then end with 'world!' +const file = fs.createWriteStream('example.txt'); +file.write('hello, '); +file.end('world!'); +// writing more now is not allowed! +``` + +##### writable.setDefaultEncoding(encoding) + + +* `encoding` {String} The new default encoding +* Return: `this` + +The `writable.setDefaultEncoding()` method sets the default `encoding` for a +[Writable][] stream. + +##### writable.uncork() + + +The `writable.uncork()` method flushes all data buffered since +[`stream.cork()`][] was called. + +When using `writable.cork()` and `writable.uncork()` to manage the buffering +of writes to a stream, it is recommended that calls to `writable.uncork()` be +deferred using `process.nextTick()`. Doing so allows batching of all +`writable.write()` calls that occur within a given Node.js event loop phase. + +```js +stream.cork(); +stream.write('some '); +stream.write('data '); +process.nextTick(() => stream.uncork()); +``` + +If the `writable.cork()` method is called multiple times on a stream, the same +number of calls to `writable.uncork()` must be called to flush the buffered +data. + +``` +stream.cork(); +stream.write('some '); +stream.cork(); +stream.write('data '); +process.nextTick(() => { + stream.uncork(); + // The data will not be flushed until uncork() is called a second time. + stream.uncork(); +}); +``` + +##### writable.write(chunk[, encoding][, callback]) + + +* `chunk` {String|Buffer} The data to write +* `encoding` {String} The encoding, if `chunk` is a String +* `callback` {Function} Callback for when this chunk of data is flushed +* Returns: {Boolean} `false` if the stream wishes for the calling code to + wait for the `'drain'` event to be emitted before continuing to write + additional data; otherwise `true`. + +The `writable.write()` method writes some data to the stream, and calls the +supplied `callback` once the data has been fully handled. If an error +occurs, the `callback` *may or may not* be called with the error as its +first argument. To reliably detect write errors, add a listener for the +`'error'` event. + +The return value indicates whether the written `chunk` was buffered internally +and the buffer has exceeded the `highWaterMark` configured when the stream was +created. If `false` is returned, further attempts to write data to the stream +should be paused until the `'drain'` event is emitted. + +A Writable stream in object mode will always ignore the `encoding` argument. + +### Readable Streams + +Readable streams are an abstraction for a *source* from which data is +consumed. + +Examples of Readable streams include: + +* [HTTP responses, on the client][http-incoming-message] +* [HTTP requests, on the server][http-incoming-message] +* [fs read streams][] +* [zlib streams][zlib] +* [crypto streams][crypto] +* [TCP sockets][] +* [child process stdout and stderr][] +* [`process.stdin`][] + +All [Readable][] streams implement the interface defined by the +`stream.Readable` class. + +#### Two Modes + +Readable streams effectively operate in one of two modes: flowing and paused. + +When in flowing mode, data is read from the underlying system automatically +and provided to an application as quickly as possible using events via the +[`EventEmitter`][] interface. + +In paused mode, the [`stream.read()`][stream-read] method must be called +explicitly to read chunks of data from the stream. + +All [Readable][] streams begin in paused mode but can be switched to flowing +mode in one of the following ways: + +* Adding a [`'data'`][] event handler. +* Calling the [`stream.resume()`][stream-resume] method. +* Calling the [`stream.pipe()`][] method to send the data to a [Writable][]. + +The Readable can switch back to paused mode using one of the following: + +* If there are no pipe destinations, by calling the + [`stream.pause()`][stream-pause] method. +* If there are pipe destinations, by removing any [`'data'`][] event + handlers, and removing all pipe destinations by calling the + [`stream.unpipe()`][] method. + +The important concept to remember is that a Readable will not generate data +until a mechanism for either consuming or ignoring that data is provided. If +the consuming mechanism is disabled or taken away, the Readable will *attempt* +to stop generating the data. + +*Note*: For backwards compatibility reasons, removing [`'data'`][] event +handlers will **not** automatically pause the stream. Also, if there are piped +destinations, then calling [`stream.pause()`][stream-pause] will not guarantee +that the stream will *remain* paused once those destinations drain and ask for +more data. + +*Note*: If a [Readable][] is switched into flowing mode and there are no +consumers available handle the data, that data will be lost. This can occur, +for instance, when the `readable.resume()` method is called without a listener +attached to the `'data'` event, or when a `'data'` event handler is removed +from the stream. + +#### Three States + +The "two modes" of operation for a Readable stream are a simplified abstraction +for the more complicated internal state management that is happening within the +Readable stream implementation. + +Specifically, at any given point in time, every Readable is in one of three +possible states: + +* `readable._readableState.flowing = null` +* `readable._readableState.flowing = false` +* `readable._readableState.flowing = true` + +When `readable._readableState.flowing` is `null`, no mechanism for consuming the +streams data is provided so the stream will not generate its data. + +Attaching a listener for the `'data'` event, calling the `readable.pipe()` +method, or calling the `readable.resume()` method will switch +`readable._readableState.flowing` to `true`, causing the Readable to begin +actively emitting events as data is generated. + +Calling `readable.pause()`, `readable.unpipe()`, or receiving "back pressure" +will cause the `readable._readableState.flowing` to be set as `false`, +temporarily halting the flowing of events but *not* halting the generation of +data. + +While `readable._readableState.flowing` is `false`, data may be accumulating +within the streams internal buffer. + +#### Choose One + +The Readable stream API evolved across multiple Node.js versions and provides +multiple methods of consuming stream data. In general, developers should choose +*one* of the methods of consuming data and *should never* use multiple methods +to consume data from a single stream. + +Use of the `readable.pipe()` method is recommended for most users as it has been +implemented to provide the easiest way of consuming stream data. Developers that +require more fine-grained control over the transfer and generation of data can +use the [`EventEmitter`][] and `readable.pause()`/`readable.resume()` APIs. + +#### Class: stream.Readable + + + + +##### Event: 'close' + + +The `'close'` event is emitted when the stream and any of its underlying +resources (a file descriptor, for example) have been closed. The event indicates +that no more events will be emitted, and no further computation will occur. + +Not all [Readable][] streams will emit the `'close'` event. + +##### Event: 'data' + + +* `chunk` {Buffer|String|any} The chunk of data. For streams that are not + operating in object mode, the chunk will be either a string or `Buffer`. + For streams that are in object mode, the chunk can be any JavaScript value + other than `null`. + +The `'data'` event is emitted whenever the stream is relinquishing ownership of +a chunk of data to a consumer. This may occur whenever the stream is switched +in flowing mode by calling `readable.pipe()`, `readable.resume()`, or by +attaching a listener callback to the `'data'` event. The `'data'` event will +also be emitted whenever the `readable.read()` method is called and a chunk of +data is available to be returned. + +Attaching a `'data'` event listener to a stream that has not been explicitly +paused will switch the stream into flowing mode. Data will then be passed as +soon as it is available. + +The listener callback will be passed the chunk of data as a string if a default +encoding has been specified for the stream using the +`readable.setEncoding()` method; otherwise the data will be passed as a +`Buffer`. + +```js +const readable = getReadableStreamSomehow(); +readable.on('data', (chunk) => { + console.log(`Received ${chunk.length} bytes of data.`); +}); +``` + +##### Event: 'end' + + +The `'end'` event is emitted when there is no more data to be consumed from +the stream. + +*Note*: The `'end'` event **will not be emitted** unless the data is +completely consumed. This can be accomplished by switching the stream into +flowing mode, or by calling [`stream.read()`][stream-read] repeatedly until +all data has been consumed. + +```js +const readable = getReadableStreamSomehow(); +readable.on('data', (chunk) => { + console.log(`Received ${chunk.length} bytes of data.`); +}); +readable.on('end', () => { + console.log('There will be no more data.'); +}); +``` + +##### Event: 'error' + + +* {Error} + +The `'error'` event may be emitted by a Readable implementation at any time. +Typically, this may occur if the underlying stream in unable to generate data +due to an underlying internal failure, or when a stream implementation attempts +to push an invalid chunk of data. + +The listener callback will be passed a single `Error` object. + +##### Event: 'readable' + + +The `'readable'` event is emitted when there is data available to be read from +the stream. In some cases, attaching a listener for the `'readable'` event will +cause some amount of data to be read into an internal buffer. + +```javascript +const readable = getReadableStreamSomehow(); +readable.on('readable', () => { + // there is some data to read now +}); +``` +The `'readable'` event will also be emitted once the end of the stream data +has been reached but before the `'end'` event is emitted. + +Effectively, the `'readable'` event indicates that the stream has new +information: either new data is available or the end of the stream has been +reached. In the former case, [`stream.read()`][stream-read] will return the +available data. In the latter case, [`stream.read()`][stream-read] will return +`null`. For instance, in the following example, `foo.txt` is an empty file: + +```js +const fs = require('fs'); +const rr = fs.createReadStream('foo.txt'); +rr.on('readable', () => { + console.log('readable:', rr.read()); +}); +rr.on('end', () => { + console.log('end'); +}); +``` + +The output of running this script is: + +``` +$ node test.js +readable: null +end +``` + +*Note*: In general, the `readable.pipe()` and `'data'` event mechanisms are +preferred over the use of the `'readable'` event. + +##### readable.isPaused() + + +* Return: {Boolean} + +The `readable.isPaused()` method returns the current operating state of the +Readable. This is used primarily by the mechanism that underlies the +`readable.pipe()` method. In most typical cases, there will be no reason to +use this method directly. + +```js +const readable = new stream.Readable + +readable.isPaused() // === false +readable.pause() +readable.isPaused() // === true +readable.resume() +readable.isPaused() // === false +``` + +##### readable.pause() + + +* Return: `this` + +The `readable.pause()` method will cause a stream in flowing mode to stop +emitting [`'data'`][] events, switching out of flowing mode. Any data that +becomes available will remain in the internal buffer. + +```js +const readable = getReadableStreamSomehow(); +readable.on('data', (chunk) => { + console.log(`Received ${chunk.length} bytes of data.`); + readable.pause(); + console.log('There will be no additional data for 1 second.'); + setTimeout(() => { + console.log('Now data will start flowing again.'); + readable.resume(); + }, 1000); +}); +``` + +##### readable.pipe(destination[, options]) + + +* `destination` {stream.Writable} The destination for writing data +* `options` {Object} Pipe options + * `end` {Boolean} End the writer when the reader ends. Defaults to `true`. + +The `readable.pipe()` method attaches a [Writable][] stream to the `readable`, +causing it to switch automatically into flowing mode and push all of its data +to the attached [Writable][]. The flow of data will be automatically managed so +that the destination Writable stream is not overwhelmed by a faster Readable +stream. + +The following example pipes all of the data from the `readable` into a file +named `file.txt`: + +```js +const readable = getReadableStreamSomehow(); +const writable = fs.createWriteStream('file.txt'); +// All the data from readable goes into 'file.txt' +readable.pipe(writable); +``` +It is possible to attach multiple Writable streams to a single Readable stream. + +The `readable.pipe()` method returns a reference to the *destination* stream +making it possible to set up chains of piped streams: + +```js +const r = fs.createReadStream('file.txt'); +const z = zlib.createGzip(); +const w = fs.createWriteStream('file.txt.gz'); +r.pipe(z).pipe(w); +``` + +By default, [`stream.end()`][stream-end] is called on the destination Writable +stream when the source Readable stream emits [`'end'`][], so that the +destination is no longer writable. To disable this default behavior, the `end` +option can be passed as `false`, causing the destination stream to remain open, +as illustrated in the following example: + +```js +reader.pipe(writer, { end: false }); +reader.on('end', () => { + writer.end('Goodbye\n'); +}); +``` + +One important caveat is that if the Readable stream emits an error during +processing, the Writable destination *is not closed* automatically. If an +error occurs, it will be necessary to *manually* close each stream in order +to prevent memory leaks. + +*Note*: The [`process.stderr`][] and [`process.stdout`][] Writable streams are +never closed until the Node.js process exits, regardless of the specified +options. + +##### readable.read([size]) + + +* `size` {Number} Optional argument to specify how much data to read. +* Return {String|Buffer|Null} + +The `readable.read()` method pulls some data out of the internal buffer and +returns it. If no data available to be read, `null` is returned. By default, +the data will be returned as a `Buffer` object unless an encoding has been +specified using the `readable.setEncoding()` method or the stream is operating +in object mode. + +The optional `size` argument specifies a specific number of bytes to read. If +`size` bytes are not available to be read, `null` will be returned *unless* +the stream has ended, in which case all of the data remaining in the internal +buffer will be returned (*even if it exceeds `size` bytes*). + +If the `size` argument is not specified, all of the data contained in the +internal buffer will be returned. + +The `readable.read()` method should only be called on Readable streams operating +in paused mode. In flowing mode, `readable.read()` is called automatically until +the internal buffer is fully drained. + +```js +const readable = getReadableStreamSomehow(); +readable.on('readable', () => { + var chunk; + while (null !== (chunk = readable.read())) { + console.log(`Received ${chunk.length} bytes of data.`); + } +}); +``` + +In general, it is recommended that developers avoid the use of the `'readable'` +event and the `readable.read()` method in favor of using either +`readable.pipe()` or the `'data'` event. + +A Readable stream in object mode will always return a single item from +a call to [`readable.read(size)`][stream-read], regardless of the value of the +`size` argument. + +*Note:* If the `readable.read()` method returns a chunk of data, a `'data'` +event will also be emitted. + +*Note*: Calling [`stream.read([size])`][stream-read] after the [`'end'`][] +event has been emitted will return `null`. No runtime error will be raised. + +##### readable.resume() + + +* Return: `this` + +The `readable.resume()` method causes an explicitly paused Readable stream to +resume emitting [`'data'`][] events, switching the stream into flowing mode. + +The `readable.resume()` method can be used to fully consume the data from a +stream without actually processing any of that data as illustrated in the +following example: + +```js +getReadableStreamSomehow() + .resume() + .on('end', () => { + console.log('Reached the end, but did not read anything.'); + }); +``` + +##### readable.setEncoding(encoding) + + +* `encoding` {String} The encoding to use. +* Return: `this` + +The `readable.setEncoding()` method sets the default character encoding for +data read from the Readable stream. + +Setting an encoding causes the stream data +to be returned as string of the specified encoding rather than as `Buffer` +objects. For instance, calling `readable.setEncoding('utf8')` will cause the +output data will be interpreted as UTF-8 data, and passed as strings. Calling +`readable.setEncoding('hex')` will cause the data to be encoded in hexadecimal +string format. + +The Readable stream will properly handle multi-byte characters delivered through +the stream that would otherwise become improperly decoded if simply pulled from +the stream as `Buffer` objects. + +Encoding can be disabled by calling `readable.setEncoding(null)`. This approach +is useful when working with binary data or with large multi-byte strings spread +out over multiple chunks. + +```js +const readable = getReadableStreamSomehow(); +readable.setEncoding('utf8'); +readable.on('data', (chunk) => { + assert.equal(typeof chunk, 'string'); + console.log('got %d characters of string data', chunk.length); +}); +``` + +##### readable.unpipe([destination]) + + +* `destination` {stream.Writable} Optional specific stream to unpipe + +The `readable.unpipe()` method detaches a Writable stream previously attached +using the [`stream.pipe()`][] method. + +If the `destination` is not specified, then *all* pipes are detached. + +If the `destination` is specified, but no pipe is set up for it, then +the method does nothing. + +```js +const readable = getReadableStreamSomehow(); +const writable = fs.createWriteStream('file.txt'); +// All the data from readable goes into 'file.txt', +// but only for the first second +readable.pipe(writable); +setTimeout(() => { + console.log('Stop writing to file.txt'); + readable.unpipe(writable); + console.log('Manually close the file stream'); + writable.end(); +}, 1000); +``` + +##### readable.unshift(chunk) + + +* `chunk` {Buffer|String} Chunk of data to unshift onto the read queue + +The `readable.unshift()` method pushes a chunk of data back into the internal +buffer. This is useful in certain situations where a stream is being consumed by +code that needs to "un-consume" some amount of data that it has optimistically +pulled out of the source, so that the data can be passed on to some other party. + +*Note*: The `stream.unshift(chunk)` method cannot be called after the +[`'end'`][] event has been emitted or a runtime error will be thrown. + +Developers using `stream.unshift()` often should consider switching to +use of a [Transform][] stream instead. See the [API for Stream Implementers][] +section for more information. + +```js +// Pull off a header delimited by \n\n +// use unshift() if we get too much +// Call the callback with (error, header, stream) +const StringDecoder = require('string_decoder').StringDecoder; +function parseHeader(stream, callback) { + stream.on('error', callback); + stream.on('readable', onReadable); + const decoder = new StringDecoder('utf8'); + var header = ''; + function onReadable() { + var chunk; + while (null !== (chunk = stream.read())) { + var str = decoder.write(chunk); + if (str.match(/\n\n/)) { + // found the header boundary + var split = str.split(/\n\n/); + header += split.shift(); + const remaining = split.join('\n\n'); + const buf = Buffer.from(remaining, 'utf8'); + if (buf.length) + stream.unshift(buf); + stream.removeListener('error', callback); + stream.removeListener('readable', onReadable); + // now the body of the message can be read from the stream. + callback(null, header, stream); + } else { + // still reading the header. + header += str; + } + } + } +} +``` + +*Note*: Unlike [`stream.push(chunk)`][stream-push], `stream.unshift(chunk)` +will not end the reading process by resetting the internal reading state of the +stream. This can cause unexpected results if `readable.unshift()` is called +during a read (i.e. from within a [`stream._read()`][stream-_read] +implementation on a custom stream). Following the call to `readable.unshift()` +with an immediate [`stream.push('')`][stream-push] will reset the reading state +appropriately, however it is best to simply avoid calling `readable.unshift()` +while in the process of performing a read. + +##### readable.wrap(stream) + + +* `stream` {Stream} An "old style" readable stream + +Versions of Node.js prior to v0.10 had streams that did not implement the +entire `stream` module API as it is currently defined. (See [Compatibility][] +for more information.) + +When using an older Node.js library that emits [`'data'`][] events and has a +[`stream.pause()`][stream-pause] method that is advisory only, the +`readable.wrap()` method can be used to create a [Readable][] stream that uses +the old stream as its data source. + +It will rarely be necessary to use `readable.wrap()` but the method has been +provided as a convenience for interacting with older Node.js applications and +libraries. + +For example: + +```js +const OldReader = require('./old-api-module.js').OldReader; +const Readable = require('stream').Readable; +const oreader = new OldReader; +const myReader = new Readable().wrap(oreader); + +myReader.on('readable', () => { + myReader.read(); // etc. +}); +``` + +### Duplex and Transform Streams + +#### Class: stream.Duplex + + + + +Duplex streams are streams that implement both the [Readable][] and +[Writable][] interfaces. + +Examples of Duplex streams include: + +* [TCP sockets][] +* [zlib streams][zlib] +* [crypto streams][crypto] + +#### Class: stream.Transform + + + + +Transform streams are [Duplex][] streams where the output is in some way +related to the input. Like all [Duplex][] streams, Transform streams +implement both the [Readable][] and [Writable][] interfaces. + +Examples of Transform streams include: + +* [zlib streams][zlib] +* [crypto streams][crypto] + + +## API for Stream Implementers + + + +The `stream` module API has been designed to make it possible to easily +implement streams using JavaScript's prototypical inheritance model. + +First, a stream developer would declare a new JavaScript class that extends one +of the four basic stream classes (`stream.Writable`, `stream.Readable`, +`stream.Duplex`, or `stream.Transform`), making sure the call the appropriate +parent class constructor: + +```js +const Writable = require('stream').Writable; + +class MyWritable extends Writable { + constructor(options) { + super(options); + } +} +``` + +The new stream class must then implement one or more specific methods, depending +on the type of stream being created, as detailed in the chart below: + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
              +

              Use-case

              +
              +

              Class

              +
              +

              Method(s) to implement

              +
              +

              Reading only

              +
              +

              [Readable](#stream_class_stream_readable)

              +
              +

              [_read][stream-_read]

              +
              +

              Writing only

              +
              +

              [Writable](#stream_class_stream_writable)

              +
              +

              [_write][stream-_write], [_writev][stream-_writev]

              +
              +

              Reading and writing

              +
              +

              [Duplex](#stream_class_stream_duplex)

              +
              +

              [_read][stream-_read], [_write][stream-_write], [_writev][stream-_writev]

              +
              +

              Operate on written data, then read the result

              +
              +

              [Transform](#stream_class_stream_transform)

              +
              +

              [_transform][stream-_transform], [_flush][stream-_flush]

              +
              + +*Note*: The implementation code for a stream should *never* call the "public" +methods of a stream that are intended for use by consumers (as described in +the [API for Stream Consumers][] section). Doing so may lead to adverse +side effects in application code consuming the stream. + +### Simplified Construction + +For many simple cases, it is possible to construct a stream without relying on +inheritance. This can be accomplished by directly creating instances of the +`stream.Writable`, `stream.Readable`, `stream.Duplex` or `stream.Transform` +objects and passing appropriate methods as constructor options. + +For example: + +```js +const Writable = require('stream').Writable; + +const myWritable = new Writable({ + write(chunk, encoding, callback) { + // ... + } +}); +``` + +### Implementing a Writable Stream + +The `stream.Writable` class is extended to implement a [Writable][] stream. + +Custom Writable streams *must* call the `new stream.Writable([options])` +constructor and implement the `writable._write()` method. The +`writable._writev()` method *may* also be implemented. + +#### Constructor: new stream.Writable([options]) + +* `options` {Object} + * `highWaterMark` {Number} Buffer level when + [`stream.write()`][stream-write] starts returning `false`. Defaults to + `16384` (16kb), or `16` for `objectMode` streams. + * `decodeStrings` {Boolean} Whether or not to decode strings into + Buffers before passing them to [`stream._write()`][stream-_write]. + Defaults to `true` + * `objectMode` {Boolean} Whether or not the + [`stream.write(anyObj)`][stream-write] is a valid operation. When set, + it becomes possible to write JavaScript values other than string or + `Buffer` if supported by the stream implementation. Defaults to `false` + * `write` {Function} Implementation for the + [`stream._write()`][stream-_write] method. + * `writev` {Function} Implementation for the + [`stream._writev()`][stream-_writev] method. + +For example: + +```js +const Writable = require('stream').Writable; + +class MyWritable extends Writable { + constructor(options) { + // Calls the stream.Writable() constructor + super(options); + } +} +``` + +Or, when using pre-ES6 style constructors: + +```js +const Writable = require('stream').Writable; +const util = require('util'); + +function MyWritable(options) { + if (!(this instanceof MyWritable)) + return new MyWritable(options); + Writable.call(this, options); +} +util.inherits(MyWritable, Writable); +``` + +Or, using the Simplified Constructor approach: + +```js +const Writable = require('stream').Writable; + +const myWritable = new Writable({ + write(chunk, encoding, callback) { + // ... + }, + writev(chunks, callback) { + // ... + } +}); +``` + +#### writable.\_write(chunk, encoding, callback) + +* `chunk` {Buffer|String} The chunk to be written. Will **always** + be a buffer unless the `decodeStrings` option was set to `false`. +* `encoding` {String} If the chunk is a string, then `encoding` is the + character encoding of that string. If chunk is a `Buffer`, or if the + stream is operating in object mode, `encoding` may be ignored. +* `callback` {Function} Call this function (optionally with an error + argument) when processing is complete for the supplied chunk. + +All Writable stream implementations must provide a +[`writable._write()`][stream-_write] method to send data to the underlying +resource. + +*Note*: [Transform][] streams provide their own implementation of the +[`writable._write()`][stream-_write]. + +*Note*: **This function MUST NOT be called by application code directly.** It +should be implemented by child classes, and called only by the internal Writable +class methods only. + +The `callback` method must be called to signal either that the write completed +successfully or failed with an error. The first argument passed to the +`callback` must be the `Error` object if the call failed or `null` if the +write succeeded. + +It is important to note that all calls to `writable.write()` that occur between +the time `writable._write()` is called and the `callback` is called will cause +the written data to be buffered. Once the `callback` is invoked, the stream will +emit a `'drain'` event. If a stream implementation is capable of processing +multiple chunks of data at once, the `writable._writev()` method should be +implemented. + +If the `decodeStrings` property is set in the constructor options, then +`chunk` may be a string rather than a Buffer, and `encoding` will +indicate the character encoding of the string. This is to support +implementations that have an optimized handling for certain string +data encodings. If the `decodeStrings` property is explicitly set to `false`, +the `encoding` argument can be safely ignored, and `chunk` will always be a +`Buffer`. + +The `writable._write()` method is prefixed with an underscore because it is +internal to the class that defines it, and should never be called directly by +user programs. + +#### writable.\_writev(chunks, callback) + +* `chunks` {Array} The chunks to be written. Each chunk has following + format: `{ chunk: ..., encoding: ... }`. +* `callback` {Function} A callback function (optionally with an error + argument) to be invoked when processing is complete for the supplied chunks. + +*Note*: **This function MUST NOT be called by application code directly.** It +should be implemented by child classes, and called only by the internal Writable +class methods only. + +The `writable._writev()` method may be implemented in addition to +`writable._write()` in stream implementations that are capable of processing +multiple chunks of data at once. If implemented, the method will be called with +all chunks of data currently buffered in the write queue. + +The `writable._writev()` method is prefixed with an underscore because it is +internal to the class that defines it, and should never be called directly by +user programs. + +#### Errors While Writing + +It is recommended that errors occurring during the processing of the +`writable._write()` and `writable._writev()` methods are reported by invoking +the callback and passing the error as the first argument. This will cause an +`'error'` event to be emitted by the Writable. Throwing an Error from within +`writable._write()` can result in expected and inconsistent behavior depending +on how the stream is being used. Using the callback ensures consistent and +predictable handling of errors. + +```js +const Writable = require('stream').Writable; + +const myWritable = new Writable({ + write(chunk, encoding, callback) { + if (chunk.toString().indexOf('a') >= 0) { + callback(new Error('chunk is invalid')); + } else { + callback(); + } + } +}); +``` + +#### An Example Writable Stream + +The following illustrates a rather simplistic (and somewhat pointless) custom +Writable stream implementation. While this specific Writable stream instance +is not of any real particular usefulness, the example illustrates each of the +required elements of a custom [Writable][] stream instance: + +```js +const Writable = require('stream').Writable; + +class MyWritable extends Writable { + constructor(options) { + super(options); + } + + _write(chunk, encoding, callback) { + if (chunk.toString().indexOf('a') >= 0) { + callback(new Error('chunk is invalid')); + } else { + callback(); + } + } +} +``` + +### Implementing a Readable Stream + +The `stream.Readable` class is extended to implement a [Readable][] stream. + +Custom Readable streams *must* call the `new stream.Readable([options])` +constructor and implement the `readable._read()` method. + +#### new stream.Readable([options]) + +* `options` {Object} + * `highWaterMark` {Number} The maximum number of bytes to store in + the internal buffer before ceasing to read from the underlying + resource. Defaults to `16384` (16kb), or `16` for `objectMode` streams + * `encoding` {String} If specified, then buffers will be decoded to + strings using the specified encoding. Defaults to `null` + * `objectMode` {Boolean} Whether this stream should behave + as a stream of objects. Meaning that [`stream.read(n)`][stream-read] returns + a single value instead of a Buffer of size n. Defaults to `false` + * `read` {Function} Implementation for the [`stream._read()`][stream-_read] + method. + +For example: + +```js +const Readable = require('stream').Readable; + +class MyReadable extends Readable { + constructor(options) { + // Calls the stream.Readable(options) constructor + super(options); + } +} +``` + +Or, when using pre-ES6 style constructors: + +```js +const Readable = require('stream').Readable; +const util = require('util'); + +function MyReadable(options) { + if (!(this instanceof MyReadable)) + return new MyReadable(options); + Readable.call(this, options); +} +util.inherits(MyReadable, Readable); +``` + +Or, using the Simplified Constructor approach: + +```js +const Readable = require('stream').Readable; + +const myReadable = new Readable({ + read(size) { + // ... + } +}); +``` + +#### readable.\_read(size) + +* `size` {Number} Number of bytes to read asynchronously + +*Note*: **This function MUST NOT be called by application code directly.** It +should be implemented by child classes, and called only by the internal Readable +class methods only. + +All Readable stream implementations must provide an implementation of the +`readable._read()` method to fetch data from the underlying resource. + +When `readable._read()` is called, if data is available from the resource, the +implementation should begin pushing that data into the read queue using the +[`this.push(dataChunk)`][stream-push] method. `_read()` should continue reading +from the resource and pushing data until `readable.push()` returns `false`. Only +when `_read()` is called again after it has stopped should it resume pushing +additional data onto the queue. + +*Note*: Once the `readable._read()` method has been called, it will not be +called again until the [`readable.push()`][stream-push] method is called. + +The `size` argument is advisory. For implementations where a "read" is a +single operation that returns data can use the `size` argument to determine how +much data to fetch. Other implementations may ignore this argument and simply +provide data whenever it becomes available. There is no need to "wait" until +`size` bytes are available before calling [`stream.push(chunk)`][stream-push]. + +The `readable._read()` method is prefixed with an underscore because it is +internal to the class that defines it, and should never be called directly by +user programs. + +#### readable.push(chunk[, encoding]) + +* `chunk` {Buffer|Null|String} Chunk of data to push into the read queue +* `encoding` {String} Encoding of String chunks. Must be a valid + Buffer encoding, such as `'utf8'` or `'ascii'` +* Returns {Boolean} `true` if additional chunks of data may continued to be + pushed; `false` otherwise. + +When `chunk` is a `Buffer` or `string`, the `chunk` of data will be added to the +internal queue for users of the stream to consume. Passing `chunk` as `null` +signals the end of the stream (EOF), after which no more data can be written. + +When the Readable is operating in paused mode, the data added with +`readable.push()` can be read out by calling the +[`readable.read()`][stream-read] method when the [`'readable'`][] event is +emitted. + +When the Readable is operating in flowing mode, the data added with +`readable.push()` will be delivered by emitting a `'data'` event. + +The `readable.push()` method is designed to be as flexible as possible. For +example, when wrapping a lower-level source that provides some form of +pause/resume mechanism, and a data callback, the low-level source can be wrapped +by the custom Readable instance as illustrated in the following example: + +```js +// source is an object with readStop() and readStart() methods, +// and an `ondata` member that gets called when it has data, and +// an `onend` member that gets called when the data is over. + +class SourceWrapper extends Readable { + constructor(options) { + super(options); + + this._source = getLowlevelSourceObject(); + + // Every time there's data, push it into the internal buffer. + this._source.ondata = (chunk) => { + // if push() returns false, then stop reading from source + if (!this.push(chunk)) + this._source.readStop(); + }; + + // When the source ends, push the EOF-signaling `null` chunk + this._source.onend = () => { + this.push(null); + }; + } + // _read will be called when the stream wants to pull more data in + // the advisory size argument is ignored in this case. + _read(size) { + this._source.readStart(); + } +} +``` +*Note*: The `readable.push()` method is intended be called only by Readable +Implementers, and only from within the `readable._read()` method. + +#### Errors While Reading + +It is recommended that errors occurring during the processing of the +`readable._read()` method are emitted using the `'error'` event rather than +being thrown. Throwing an Error from within `readable._read()` can result in +expected and inconsistent behavior depending on whether the stream is operating +in flowing or paused mode. Using the `'error'` event ensures consistent and +predictable handling of errors. + +```js +const Readable = require('stream').Readable; + +const myReadable = new Readable({ + read(size) { + if (checkSomeErrorCondition()) { + process.nextTick(() => this.emit('error', err)); + return; + } + // do some work + } +}); +``` + +#### An Example Counting Stream + + + +The following is a basic example of a Readable stream that emits the numerals +from 1 to 1,000,000 in ascending order, and then ends. + +```js +const Readable = require('stream').Readable; + +class Counter extends Readable { + constructor(opt) { + super(opt); + this._max = 1000000; + this._index = 1; + } + + _read() { + var i = this._index++; + if (i > this._max) + this.push(null); + else { + var str = '' + i; + var buf = Buffer.from(str, 'ascii'); + this.push(buf); + } + } +} +``` + +### Implementing a Duplex Stream + +A [Duplex][] stream is one that implements both [Readable][] and [Writable][], +such as a TCP socket connection. + +Because Javascript does not have support for multiple inheritance, the +`stream.Duplex` class is extended to implement a [Duplex][] stream (as opposed +to extending the `stream.Readable` *and* `stream.Writable` classes). + +*Note*: The `stream.Duplex` class prototypically inherits from `stream.Readable` +and parasitically from `stream.Writable`. + +Custom Duplex streams *must* call the `new stream.Duplex([options])` +constructor and implement *both* the `readable._read()` and +`writable._write()` methods. + +#### new stream.Duplex(options) + +* `options` {Object} Passed to both Writable and Readable + constructors. Also has the following fields: + * `allowHalfOpen` {Boolean} Defaults to `true`. If set to `false`, then + the stream will automatically end the readable side when the + writable side ends and vice versa. + * `readableObjectMode` {Boolean} Defaults to `false`. Sets `objectMode` + for readable side of the stream. Has no effect if `objectMode` + is `true`. + * `writableObjectMode` {Boolean} Defaults to `false`. Sets `objectMode` + for writable side of the stream. Has no effect if `objectMode` + is `true`. + +For example: + +```js +const Duplex = require('stream').Duplex; + +class MyDuplex extends Duplex { + constructor(options) { + super(options); + } +} +``` + +Or, when using pre-ES6 style constructors: + +```js +const Duplex = require('stream').Duplex; +const util = require('util'); + +function MyDuplex(options) { + if (!(this instanceof MyDuplex)) + return new MyDuplex(options); + Duplex.call(this, options); +} +util.inherits(MyDuplex, Duplex); +``` + +Or, using the Simplified Constructor approach: + +```js +const Duplex = require('stream').Duplex; + +const myDuplex = new Duplex({ + read(size) { + // ... + }, + write(chunk, encoding, callback) { + // ... + } +}); +``` + +#### An Example Duplex Stream + +The following illustrates a simple example of a Duplex stream that wraps a +hypothetical lower-level source object to which data can be written, and +from which data can be read, albeit using an API that is not compatible with +Node.js streams. +The following illustrates a simple example of a Duplex stream that buffers +incoming written data via the [Writable][] interface that is read back out +via the [Readable][] interface. + +```js +const Duplex = require('stream').Duplex; +const kSource = Symbol('source'); + +class MyDuplex extends Duplex { + constructor(source, options) { + super(options); + this[kSource] = source; + } + + _write(chunk, encoding, callback) { + // The underlying source only deals with strings + if (Buffer.isBuffer(chunk)) + chunk = chunk.toString(encoding); + this[kSource].writeSomeData(chunk, encoding); + callback(); + } + + _read(size) { + this[kSource].fetchSomeData(size, (data, encoding) => { + this.push(Buffer.from(data, encoding)); + }); + } +} +``` + +The most important aspect of a Duplex stream is that the Readable and Writable +sides operate independently of one another despite co-existing within a single +object instance. + +#### Object Mode Duplex Streams + +For Duplex streams, `objectMode` can be set exclusively for either the Readable +or Writable side using the `readableObjectMode` and `writableObjectMode` options +respectively. + +In the following example, for instance, a new Transform stream (which is a +type of [Duplex][] stream) is created that has an object mode Writable side +that accepts JavaScript numbers that are converted to hexidecimal strings on +the Readable side. + +```js +const Transform = require('stream').Transform; + +// All Transform streams are also Duplex Streams +const myTransform = new Transform({ + writableObjectMode: true, + + transform(chunk, encoding, callback) { + // Coerce the chunk to a number if necessary + chunk |= 0; + + // Transform the chunk into something else. + const data = chunk.toString(16); + + // Push the data onto the readable queue. + callback(null, '0'.repeat(data.length % 2) + data); + } +}); + +myTransform.setEncoding('ascii'); +myTransform.on('data', (chunk) => console.log(chunk)); + +myTransform.write(1); + // Prints: 01 +myTransform.write(10); + // Prints: 0a +myTransform.write(100); + // Prints: 64 +``` + +### Implementing a Transform Stream + +A [Transform][] stream is a [Duplex][] stream where the output is computed +in some way from the input. Examples include [zlib][] streams or [crypto][] +streams that compress, encrypt, or decrypt data. + +*Note*: There is no requirement that the output be the same size as the input, +the same number of chunks, or arrive at the same time. For example, a +Hash stream will only ever have a single chunk of output which is +provided when the input is ended. A `zlib` stream will produce output +that is either much smaller or much larger than its input. + +The `stream.Transform` class is extended to implement a [Transform][] stream. + +The `stream.Transform` class prototypically inherits from `stream.Duplex` and +implements its own versions of the `writable._write()` and `readable._read()` +methods. Custom Transform implementations *must* implement the +[`transform._transform()`][stream-_transform] method and *may* also implement +the [`transform._flush()`][stream-_flush] method. + +*Note*: Care must be taken when using Transform streams in that data written +to the stream can cause the Writable side of the stream to become paused if +the output on the Readable side is not consumed. + +#### new stream.Transform([options]) + +* `options` {Object} Passed to both Writable and Readable + constructors. Also has the following fields: + * `transform` {Function} Implementation for the + [`stream._transform()`][stream-_transform] method. + * `flush` {Function} Implementation for the [`stream._flush()`][stream-_flush] + method. + +For example: + +```js +const Transform = require('stream').Transform; + +class MyTransform extends Transform { + constructor(options) { + super(options); + } +} +``` + +Or, when using pre-ES6 style constructors: + +```js +const Transform = require('stream').Transform; +const util = require('util'); + +function MyTransform(options) { + if (!(this instanceof MyTransform)) + return new MyTransform(options); + Transform.call(this, options); +} +util.inherits(MyTransform, Transform); +``` + +Or, using the Simplified Constructor approach: + +```js +const Transform = require('stream').Transform; + +const myTransform = new Transform({ + transform(chunk, encoding, callback) { + // ... + } +}); +``` + +#### Events: 'finish' and 'end' + +The [`'finish'`][] and [`'end'`][] events are from the `stream.Writable` +and `stream.Readable` classes, respectively. The `'finish'` event is emitted +after [`stream.end()`][stream-end] is called and all chunks have been processed +by [`stream._transform()`][stream-_transform]. The `'end'` event is emitted +after all data has been output, which occurs after the callback in +[`transform._flush()`][stream-_flush] has been called. + +#### transform.\_flush(callback) + +* `callback` {Function} A callback function (optionally with an error + argument) to be called when remaining data has been flushed. + +*Note*: **This function MUST NOT be called by application code directly.** It +should be implemented by child classes, and called only by the internal Readable +class methods only. + +In some cases, a transform operation may need to emit an additional bit of +data at the end of the stream. For example, a `zlib` compression stream will +store an amount of internal state used to optimally compress the output. When +the stream ends, however, that additional data needs to be flushed so that the +compressed data will be complete. + +Custom [Transform][] implementations *may* implement the `transform._flush()` +method. This will be called when there is no more written data to be consumed, +but before the [`'end'`][] event is emitted signaling the end of the +[Readable][] stream. + +Within the `transform._flush()` implementation, the `readable.push()` method +may be called zero or more times, as appropriate. The `callback` function must +be called when the flush operation is complete. + +The `transform._flush()` method is prefixed with an underscore because it is +internal to the class that defines it, and should never be called directly by +user programs. + +#### transform.\_transform(chunk, encoding, callback) + +* `chunk` {Buffer|String} The chunk to be transformed. Will **always** + be a buffer unless the `decodeStrings` option was set to `false`. +* `encoding` {String} If the chunk is a string, then this is the + encoding type. If chunk is a buffer, then this is the special + value - 'buffer', ignore it in this case. +* `callback` {Function} A callback function (optionally with an error + argument and data) to be called after the supplied `chunk` has been + processed. + +*Note*: **This function MUST NOT be called by application code directly.** It +should be implemented by child classes, and called only by the internal Readable +class methods only. + +All Transform stream implementations must provide a `_transform()` +method to accept input and produce output. The `transform._transform()` +implementation handles the bytes being written, computes an output, then passes +that output off to the readable portion using the `readable.push()` method. + +The `transform.push()` method may be called zero or more times to generate +output from a single input chunk, depending on how much is to be output +as a result of the chunk. + +It is possible that no output is generated from any given chunk of input data. + +The `callback` function must be called only when the current chunk is completely +consumed. The first argument passed to the `callback` must be an `Error` object +if an error occurred while processing the input or `null` otherwise. If a second +argument is passed to the `callback`, it will be forwarded on to the +`readable.push()` method. In other words the following are equivalent: + +```js +transform.prototype._transform = function (data, encoding, callback) { + this.push(data); + callback(); +}; + +transform.prototype._transform = function (data, encoding, callback) { + callback(null, data); +}; +``` + +The `transform._transform()` method is prefixed with an underscore because it +is internal to the class that defines it, and should never be called directly by +user programs. + +#### Class: stream.PassThrough + +The `stream.PassThrough` class is a trivial implementation of a [Transform][] +stream that simply passes the input bytes across to the output. Its purpose is +primarily for examples and testing, but there are some use cases where +`stream.PassThrough` is useful as a building block for novel sorts of streams. + +## Additional Notes + + + +### Compatibility with Older Node.js Versions + + + +In versions of Node.js prior to v0.10, the Readable stream interface was +simpler, but also less powerful and less useful. + +* Rather than waiting for calls the [`stream.read()`][stream-read] method, + [`'data'`][] events would begin emitting immediately. Applications that + would need to perform some amount of work to decide how to handle data + were required to store read data into buffers so the data would not be lost. +* The [`stream.pause()`][stream-pause] method was advisory, rather than + guaranteed. This meant that it was still necessary to be prepared to receive + [`'data'`][] events *even when the stream was in a paused state*. + +In Node.js v0.10, the [Readable][] class was added. For backwards compatibility +with older Node.js programs, Readable streams switch into "flowing mode" when a +[`'data'`][] event handler is added, or when the +[`stream.resume()`][stream-resume] method is called. The effect is that, even +when not using the new [`stream.read()`][stream-read] method and +[`'readable'`][] event, it is no longer necessary to worry about losing +[`'data'`][] chunks. + +While most applications will continue to function normally, this introduces an +edge case in the following conditions: + +* No [`'data'`][] event listener is added. +* The [`stream.resume()`][stream-resume] method is never called. +* The stream is not piped to any writable destination. + +For example, consider the following code: + +```js +// WARNING! BROKEN! +net.createServer((socket) => { + + // we add an 'end' method, but never consume the data + socket.on('end', () => { + // It will never get here. + socket.end('The message was received but was not processed.\n'); + }); + +}).listen(1337); +``` + +In versions of Node.js prior to v0.10, the incoming message data would be +simply discarded. However, in Node.js v0.10 and beyond, the socket remains +paused forever. + +The workaround in this situation is to call the +[`stream.resume()`][stream-resume] method to begin the flow of data: + +```js +// Workaround +net.createServer((socket) => { + + socket.on('end', () => { + socket.end('The message was received but was not processed.\n'); + }); + + // start the flow of data, discarding it. + socket.resume(); + +}).listen(1337); +``` + +In addition to new Readable streams switching into flowing mode, +pre-v0.10 style streams can be wrapped in a Readable class using the +[`readable.wrap()`][`stream.wrap()`] method. + + +### `readable.read(0)` + +There are some cases where it is necessary to trigger a refresh of the +underlying readable stream mechanisms, without actually consuming any +data. In such cases, it is possible to call `readable.read(0)`, which will +always return `null`. + +If the internal read buffer is below the `highWaterMark`, and the +stream is not currently reading, then calling `stream.read(0)` will trigger +a low-level [`stream._read()`][stream-_read] call. + +While most applications will almost never need to do this, there are +situations within Node.js where this is done, particularly in the +Readable stream class internals. + +### `readable.push('')` + +Use of `readable.push('')` is not recommended. + +Pushing a zero-byte string or `Buffer` to a stream that is not in object mode +has an interesting side effect. Because it *is* a call to +[`readable.push()`][stream-push], the call will end the reading process. +However, because the argument is an empty string, no data is added to the +readable buffer so there is nothing for a user to consume. + +[`'data'`]: #stream_event_data +[`'drain'`]: #stream_event_drain +[`'end'`]: #stream_event_end +[`'finish'`]: #stream_event_finish +[`'readable'`]: #stream_event_readable +[`buf.toString(encoding)`]: https://nodejs.org/docs/v6.3.1/api/buffer.html#buffer_buf_tostring_encoding_start_end +[`EventEmitter`]: https://nodejs.org/docs/v6.3.1/api/events.html#events_class_eventemitter +[`process.stderr`]: https://nodejs.org/docs/v6.3.1/api/process.html#process_process_stderr +[`process.stdin`]: https://nodejs.org/docs/v6.3.1/api/process.html#process_process_stdin +[`process.stdout`]: https://nodejs.org/docs/v6.3.1/api/process.html#process_process_stdout +[`stream.cork()`]: #stream_writable_cork +[`stream.pipe()`]: #stream_readable_pipe_destination_options +[`stream.uncork()`]: #stream_writable_uncork +[`stream.unpipe()`]: #stream_readable_unpipe_destination +[`stream.wrap()`]: #stream_readable_wrap_stream +[`tls.CryptoStream`]: https://nodejs.org/docs/v6.3.1/api/tls.html#tls_class_cryptostream +[API for Stream Consumers]: #stream_api_for_stream_consumers +[API for Stream Implementers]: #stream_api_for_stream_implementers +[child process stdin]: https://nodejs.org/docs/v6.3.1/api/child_process.html#child_process_child_stdin +[child process stdout and stderr]: https://nodejs.org/docs/v6.3.1/api/child_process.html#child_process_child_stdout +[Compatibility]: #stream_compatibility_with_older_node_js_versions +[crypto]: crypto.html +[Duplex]: #stream_class_stream_duplex +[fs read streams]: https://nodejs.org/docs/v6.3.1/api/fs.html#fs_class_fs_readstream +[fs write streams]: https://nodejs.org/docs/v6.3.1/api/fs.html#fs_class_fs_writestream +[`fs.createReadStream()`]: https://nodejs.org/docs/v6.3.1/api/fs.html#fs_fs_createreadstream_path_options +[`fs.createWriteStream()`]: https://nodejs.org/docs/v6.3.1/api/fs.html#fs_fs_createwritestream_path_options +[`net.Socket`]: https://nodejs.org/docs/v6.3.1/api/net.html#net_class_net_socket +[`zlib.createDeflate()`]: https://nodejs.org/docs/v6.3.1/api/zlib.html#zlib_zlib_createdeflate_options +[HTTP requests, on the client]: https://nodejs.org/docs/v6.3.1/api/http.html#http_class_http_clientrequest +[HTTP responses, on the server]: https://nodejs.org/docs/v6.3.1/api/http.html#http_class_http_serverresponse +[http-incoming-message]: https://nodejs.org/docs/v6.3.1/api/http.html#http_class_http_incomingmessage +[Object mode]: #stream_object_mode +[Readable]: #stream_class_stream_readable +[SimpleProtocol v2]: #stream_example_simpleprotocol_parser_v2 +[stream-_flush]: #stream_transform_flush_callback +[stream-_read]: #stream_readable_read_size_1 +[stream-_transform]: #stream_transform_transform_chunk_encoding_callback +[stream-_write]: #stream_writable_write_chunk_encoding_callback_1 +[stream-_writev]: #stream_writable_writev_chunks_callback +[stream-end]: #stream_writable_end_chunk_encoding_callback +[stream-pause]: #stream_readable_pause +[stream-push]: #stream_readable_push_chunk_encoding +[stream-read]: #stream_readable_read_size +[stream-resume]: #stream_readable_resume +[stream-write]: #stream_writable_write_chunk_encoding_callback +[TCP sockets]: https://nodejs.org/docs/v6.3.1/api/net.html#net_class_net_socket +[Transform]: #stream_class_stream_transform +[Writable]: #stream_class_stream_writable +[zlib]: zlib.html diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/doc/wg-meetings/2015-01-30.md b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/doc/wg-meetings/2015-01-30.md new file mode 100644 index 0000000..83275f1 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/doc/wg-meetings/2015-01-30.md @@ -0,0 +1,60 @@ +# streams WG Meeting 2015-01-30 + +## Links + +* **Google Hangouts Video**: http://www.youtube.com/watch?v=I9nDOSGfwZg +* **GitHub Issue**: https://github.com/iojs/readable-stream/issues/106 +* **Original Minutes Google Doc**: https://docs.google.com/document/d/17aTgLnjMXIrfjgNaTUnHQO7m3xgzHR2VXBTmi03Qii4/ + +## Agenda + +Extracted from https://github.com/iojs/readable-stream/labels/wg-agenda prior to meeting. + +* adopt a charter [#105](https://github.com/iojs/readable-stream/issues/105) +* release and versioning strategy [#101](https://github.com/iojs/readable-stream/issues/101) +* simpler stream creation [#102](https://github.com/iojs/readable-stream/issues/102) +* proposal: deprecate implicit flowing of streams [#99](https://github.com/iojs/readable-stream/issues/99) + +## Minutes + +### adopt a charter + +* group: +1's all around + +### What versioning scheme should be adopted? +* group: +1’s 3.0.0 +* domenic+group: pulling in patches from other sources where appropriate +* mikeal: version independently, suggesting versions for io.js +* mikeal+domenic: work with TC to notify in advance of changes +simpler stream creation + +### streamline creation of streams +* sam: streamline creation of streams +* domenic: nice simple solution posted + but, we lose the opportunity to change the model + may not be backwards incompatible (double check keys) + + **action item:** domenic will check + +### remove implicit flowing of streams on(‘data’) +* add isFlowing / isPaused +* mikeal: worrying that we’re documenting polyfill methods – confuses users +* domenic: more reflective API is probably good, with warning labels for users +* new section for mad scientists (reflective stream access) +* calvin: name the “third state” +* mikeal: maybe borrow the name from whatwg? +* domenic: we’re missing the “third state” +* consensus: kind of difficult to name the third state +* mikeal: figure out differences in states / compat +* mathias: always flow on data – eliminates third state + * explore what it breaks + +**action items:** +* ask isaac for ability to list packages by what public io.js APIs they use (esp. Stream) +* ask rod/build for infrastructure +* **chris**: explore the “flow on data” approach +* add isPaused/isFlowing +* add new docs section +* move isPaused to that section + + diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/duplex.js b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/duplex.js new file mode 100644 index 0000000..ca807af --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/duplex.js @@ -0,0 +1 @@ +module.exports = require("./lib/_stream_duplex.js") diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/lib/_stream_duplex.js b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/lib/_stream_duplex.js new file mode 100644 index 0000000..736693b --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/lib/_stream_duplex.js @@ -0,0 +1,75 @@ +// a duplex stream is just a stream that is both readable and writable. +// Since JS doesn't have multiple prototypal inheritance, this class +// prototypally inherits from Readable, and then parasitically from +// Writable. + +'use strict'; + +/**/ + +var objectKeys = Object.keys || function (obj) { + var keys = []; + for (var key in obj) { + keys.push(key); + }return keys; +}; +/**/ + +module.exports = Duplex; + +/**/ +var processNextTick = require('process-nextick-args'); +/**/ + +/**/ +var util = require('core-util-is'); +util.inherits = require('inherits'); +/**/ + +var Readable = require('./_stream_readable'); +var Writable = require('./_stream_writable'); + +util.inherits(Duplex, Readable); + +var keys = objectKeys(Writable.prototype); +for (var v = 0; v < keys.length; v++) { + var method = keys[v]; + if (!Duplex.prototype[method]) Duplex.prototype[method] = Writable.prototype[method]; +} + +function Duplex(options) { + if (!(this instanceof Duplex)) return new Duplex(options); + + Readable.call(this, options); + Writable.call(this, options); + + if (options && options.readable === false) this.readable = false; + + if (options && options.writable === false) this.writable = false; + + this.allowHalfOpen = true; + if (options && options.allowHalfOpen === false) this.allowHalfOpen = false; + + this.once('end', onend); +} + +// the no-half-open enforcer +function onend() { + // if we allow half-open state, or if the writable side ended, + // then we're ok. + if (this.allowHalfOpen || this._writableState.ended) return; + + // no more data can be written. + // But allow more writes to happen in this tick. + processNextTick(onEndNT, this); +} + +function onEndNT(self) { + self.end(); +} + +function forEach(xs, f) { + for (var i = 0, l = xs.length; i < l; i++) { + f(xs[i], i); + } +} \ No newline at end of file diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/lib/_stream_passthrough.js b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/lib/_stream_passthrough.js new file mode 100644 index 0000000..d06f71f --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/lib/_stream_passthrough.js @@ -0,0 +1,26 @@ +// a passthrough stream. +// basically just the most minimal sort of Transform stream. +// Every written chunk gets output as-is. + +'use strict'; + +module.exports = PassThrough; + +var Transform = require('./_stream_transform'); + +/**/ +var util = require('core-util-is'); +util.inherits = require('inherits'); +/**/ + +util.inherits(PassThrough, Transform); + +function PassThrough(options) { + if (!(this instanceof PassThrough)) return new PassThrough(options); + + Transform.call(this, options); +} + +PassThrough.prototype._transform = function (chunk, encoding, cb) { + cb(null, chunk); +}; \ No newline at end of file diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/lib/_stream_readable.js b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/lib/_stream_readable.js new file mode 100644 index 0000000..208cc65 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/lib/_stream_readable.js @@ -0,0 +1,937 @@ +'use strict'; + +module.exports = Readable; + +/**/ +var processNextTick = require('process-nextick-args'); +/**/ + +/**/ +var isArray = require('isarray'); +/**/ + +Readable.ReadableState = ReadableState; + +/**/ +var EE = require('events').EventEmitter; + +var EElistenerCount = function (emitter, type) { + return emitter.listeners(type).length; +}; +/**/ + +/**/ +var Stream; +(function () { + try { + Stream = require('st' + 'ream'); + } catch (_) {} finally { + if (!Stream) Stream = require('events').EventEmitter; + } +})(); +/**/ + +var Buffer = require('buffer').Buffer; +/**/ +var bufferShim = require('buffer-shims'); +/**/ + +/**/ +var util = require('core-util-is'); +util.inherits = require('inherits'); +/**/ + +/**/ +var debugUtil = require('util'); +var debug = void 0; +if (debugUtil && debugUtil.debuglog) { + debug = debugUtil.debuglog('stream'); +} else { + debug = function () {}; +} +/**/ + +var BufferList = require('./internal/streams/BufferList'); +var StringDecoder; + +util.inherits(Readable, Stream); + +function prependListener(emitter, event, fn) { + if (typeof emitter.prependListener === 'function') { + return emitter.prependListener(event, fn); + } else { + // This is a hack to make sure that our error handler is attached before any + // userland ones. NEVER DO THIS. This is here only because this code needs + // to continue to work with older versions of Node.js that do not include + // the prependListener() method. The goal is to eventually remove this hack. + if (!emitter._events || !emitter._events[event]) emitter.on(event, fn);else if (isArray(emitter._events[event])) emitter._events[event].unshift(fn);else emitter._events[event] = [fn, emitter._events[event]]; + } +} + +var Duplex; +function ReadableState(options, stream) { + Duplex = Duplex || require('./_stream_duplex'); + + options = options || {}; + + // object stream flag. Used to make read(n) ignore n and to + // make all the buffer merging and length checks go away + this.objectMode = !!options.objectMode; + + if (stream instanceof Duplex) this.objectMode = this.objectMode || !!options.readableObjectMode; + + // the point at which it stops calling _read() to fill the buffer + // Note: 0 is a valid value, means "don't call _read preemptively ever" + var hwm = options.highWaterMark; + var defaultHwm = this.objectMode ? 16 : 16 * 1024; + this.highWaterMark = hwm || hwm === 0 ? hwm : defaultHwm; + + // cast to ints. + this.highWaterMark = ~ ~this.highWaterMark; + + // A linked list is used to store data chunks instead of an array because the + // linked list can remove elements from the beginning faster than + // array.shift() + this.buffer = new BufferList(); + this.length = 0; + this.pipes = null; + this.pipesCount = 0; + this.flowing = null; + this.ended = false; + this.endEmitted = false; + this.reading = false; + + // a flag to be able to tell if the onwrite cb is called immediately, + // or on a later tick. We set this to true at first, because any + // actions that shouldn't happen until "later" should generally also + // not happen before the first write call. + this.sync = true; + + // whenever we return null, then we set a flag to say + // that we're awaiting a 'readable' event emission. + this.needReadable = false; + this.emittedReadable = false; + this.readableListening = false; + this.resumeScheduled = false; + + // Crypto is kind of old and crusty. Historically, its default string + // encoding is 'binary' so we have to make this configurable. + // Everything else in the universe uses 'utf8', though. + this.defaultEncoding = options.defaultEncoding || 'utf8'; + + // when piping, we only care about 'readable' events that happen + // after read()ing all the bytes and not getting any pushback. + this.ranOut = false; + + // the number of writers that are awaiting a drain event in .pipe()s + this.awaitDrain = 0; + + // if true, a maybeReadMore has been scheduled + this.readingMore = false; + + this.decoder = null; + this.encoding = null; + if (options.encoding) { + if (!StringDecoder) StringDecoder = require('string_decoder/').StringDecoder; + this.decoder = new StringDecoder(options.encoding); + this.encoding = options.encoding; + } +} + +var Duplex; +function Readable(options) { + Duplex = Duplex || require('./_stream_duplex'); + + if (!(this instanceof Readable)) return new Readable(options); + + this._readableState = new ReadableState(options, this); + + // legacy + this.readable = true; + + if (options && typeof options.read === 'function') this._read = options.read; + + Stream.call(this); +} + +// Manually shove something into the read() buffer. +// This returns true if the highWaterMark has not been hit yet, +// similar to how Writable.write() returns true if you should +// write() some more. +Readable.prototype.push = function (chunk, encoding) { + var state = this._readableState; + + if (!state.objectMode && typeof chunk === 'string') { + encoding = encoding || state.defaultEncoding; + if (encoding !== state.encoding) { + chunk = bufferShim.from(chunk, encoding); + encoding = ''; + } + } + + return readableAddChunk(this, state, chunk, encoding, false); +}; + +// Unshift should *always* be something directly out of read() +Readable.prototype.unshift = function (chunk) { + var state = this._readableState; + return readableAddChunk(this, state, chunk, '', true); +}; + +Readable.prototype.isPaused = function () { + return this._readableState.flowing === false; +}; + +function readableAddChunk(stream, state, chunk, encoding, addToFront) { + var er = chunkInvalid(state, chunk); + if (er) { + stream.emit('error', er); + } else if (chunk === null) { + state.reading = false; + onEofChunk(stream, state); + } else if (state.objectMode || chunk && chunk.length > 0) { + if (state.ended && !addToFront) { + var e = new Error('stream.push() after EOF'); + stream.emit('error', e); + } else if (state.endEmitted && addToFront) { + var _e = new Error('stream.unshift() after end event'); + stream.emit('error', _e); + } else { + var skipAdd; + if (state.decoder && !addToFront && !encoding) { + chunk = state.decoder.write(chunk); + skipAdd = !state.objectMode && chunk.length === 0; + } + + if (!addToFront) state.reading = false; + + // Don't add to the buffer if we've decoded to an empty string chunk and + // we're not in object mode + if (!skipAdd) { + // if we want the data now, just emit it. + if (state.flowing && state.length === 0 && !state.sync) { + stream.emit('data', chunk); + stream.read(0); + } else { + // update the buffer info. + state.length += state.objectMode ? 1 : chunk.length; + if (addToFront) state.buffer.unshift(chunk);else state.buffer.push(chunk); + + if (state.needReadable) emitReadable(stream); + } + } + + maybeReadMore(stream, state); + } + } else if (!addToFront) { + state.reading = false; + } + + return needMoreData(state); +} + +// if it's past the high water mark, we can push in some more. +// Also, if we have no data yet, we can stand some +// more bytes. This is to work around cases where hwm=0, +// such as the repl. Also, if the push() triggered a +// readable event, and the user called read(largeNumber) such that +// needReadable was set, then we ought to push more, so that another +// 'readable' event will be triggered. +function needMoreData(state) { + return !state.ended && (state.needReadable || state.length < state.highWaterMark || state.length === 0); +} + +// backwards compatibility. +Readable.prototype.setEncoding = function (enc) { + if (!StringDecoder) StringDecoder = require('string_decoder/').StringDecoder; + this._readableState.decoder = new StringDecoder(enc); + this._readableState.encoding = enc; + return this; +}; + +// Don't raise the hwm > 8MB +var MAX_HWM = 0x800000; +function computeNewHighWaterMark(n) { + if (n >= MAX_HWM) { + n = MAX_HWM; + } else { + // Get the next highest power of 2 to prevent increasing hwm excessively in + // tiny amounts + n--; + n |= n >>> 1; + n |= n >>> 2; + n |= n >>> 4; + n |= n >>> 8; + n |= n >>> 16; + n++; + } + return n; +} + +// This function is designed to be inlinable, so please take care when making +// changes to the function body. +function howMuchToRead(n, state) { + if (n <= 0 || state.length === 0 && state.ended) return 0; + if (state.objectMode) return 1; + if (n !== n) { + // Only flow one buffer at a time + if (state.flowing && state.length) return state.buffer.head.data.length;else return state.length; + } + // If we're asking for more than the current hwm, then raise the hwm. + if (n > state.highWaterMark) state.highWaterMark = computeNewHighWaterMark(n); + if (n <= state.length) return n; + // Don't have enough + if (!state.ended) { + state.needReadable = true; + return 0; + } + return state.length; +} + +// you can override either this method, or the async _read(n) below. +Readable.prototype.read = function (n) { + debug('read', n); + n = parseInt(n, 10); + var state = this._readableState; + var nOrig = n; + + if (n !== 0) state.emittedReadable = false; + + // if we're doing read(0) to trigger a readable event, but we + // already have a bunch of data in the buffer, then just trigger + // the 'readable' event and move on. + if (n === 0 && state.needReadable && (state.length >= state.highWaterMark || state.ended)) { + debug('read: emitReadable', state.length, state.ended); + if (state.length === 0 && state.ended) endReadable(this);else emitReadable(this); + return null; + } + + n = howMuchToRead(n, state); + + // if we've ended, and we're now clear, then finish it up. + if (n === 0 && state.ended) { + if (state.length === 0) endReadable(this); + return null; + } + + // All the actual chunk generation logic needs to be + // *below* the call to _read. The reason is that in certain + // synthetic stream cases, such as passthrough streams, _read + // may be a completely synchronous operation which may change + // the state of the read buffer, providing enough data when + // before there was *not* enough. + // + // So, the steps are: + // 1. Figure out what the state of things will be after we do + // a read from the buffer. + // + // 2. If that resulting state will trigger a _read, then call _read. + // Note that this may be asynchronous, or synchronous. Yes, it is + // deeply ugly to write APIs this way, but that still doesn't mean + // that the Readable class should behave improperly, as streams are + // designed to be sync/async agnostic. + // Take note if the _read call is sync or async (ie, if the read call + // has returned yet), so that we know whether or not it's safe to emit + // 'readable' etc. + // + // 3. Actually pull the requested chunks out of the buffer and return. + + // if we need a readable event, then we need to do some reading. + var doRead = state.needReadable; + debug('need readable', doRead); + + // if we currently have less than the highWaterMark, then also read some + if (state.length === 0 || state.length - n < state.highWaterMark) { + doRead = true; + debug('length less than watermark', doRead); + } + + // however, if we've ended, then there's no point, and if we're already + // reading, then it's unnecessary. + if (state.ended || state.reading) { + doRead = false; + debug('reading or ended', doRead); + } else if (doRead) { + debug('do read'); + state.reading = true; + state.sync = true; + // if the length is currently zero, then we *need* a readable event. + if (state.length === 0) state.needReadable = true; + // call internal read method + this._read(state.highWaterMark); + state.sync = false; + // If _read pushed data synchronously, then `reading` will be false, + // and we need to re-evaluate how much data we can return to the user. + if (!state.reading) n = howMuchToRead(nOrig, state); + } + + var ret; + if (n > 0) ret = fromList(n, state);else ret = null; + + if (ret === null) { + state.needReadable = true; + n = 0; + } else { + state.length -= n; + } + + if (state.length === 0) { + // If we have nothing in the buffer, then we want to know + // as soon as we *do* get something into the buffer. + if (!state.ended) state.needReadable = true; + + // If we tried to read() past the EOF, then emit end on the next tick. + if (nOrig !== n && state.ended) endReadable(this); + } + + if (ret !== null) this.emit('data', ret); + + return ret; +}; + +function chunkInvalid(state, chunk) { + var er = null; + if (!Buffer.isBuffer(chunk) && typeof chunk !== 'string' && chunk !== null && chunk !== undefined && !state.objectMode) { + er = new TypeError('Invalid non-string/buffer chunk'); + } + return er; +} + +function onEofChunk(stream, state) { + if (state.ended) return; + if (state.decoder) { + var chunk = state.decoder.end(); + if (chunk && chunk.length) { + state.buffer.push(chunk); + state.length += state.objectMode ? 1 : chunk.length; + } + } + state.ended = true; + + // emit 'readable' now to make sure it gets picked up. + emitReadable(stream); +} + +// Don't emit readable right away in sync mode, because this can trigger +// another read() call => stack overflow. This way, it might trigger +// a nextTick recursion warning, but that's not so bad. +function emitReadable(stream) { + var state = stream._readableState; + state.needReadable = false; + if (!state.emittedReadable) { + debug('emitReadable', state.flowing); + state.emittedReadable = true; + if (state.sync) processNextTick(emitReadable_, stream);else emitReadable_(stream); + } +} + +function emitReadable_(stream) { + debug('emit readable'); + stream.emit('readable'); + flow(stream); +} + +// at this point, the user has presumably seen the 'readable' event, +// and called read() to consume some data. that may have triggered +// in turn another _read(n) call, in which case reading = true if +// it's in progress. +// However, if we're not ended, or reading, and the length < hwm, +// then go ahead and try to read some more preemptively. +function maybeReadMore(stream, state) { + if (!state.readingMore) { + state.readingMore = true; + processNextTick(maybeReadMore_, stream, state); + } +} + +function maybeReadMore_(stream, state) { + var len = state.length; + while (!state.reading && !state.flowing && !state.ended && state.length < state.highWaterMark) { + debug('maybeReadMore read 0'); + stream.read(0); + if (len === state.length) + // didn't get any data, stop spinning. + break;else len = state.length; + } + state.readingMore = false; +} + +// abstract method. to be overridden in specific implementation classes. +// call cb(er, data) where data is <= n in length. +// for virtual (non-string, non-buffer) streams, "length" is somewhat +// arbitrary, and perhaps not very meaningful. +Readable.prototype._read = function (n) { + this.emit('error', new Error('not implemented')); +}; + +Readable.prototype.pipe = function (dest, pipeOpts) { + var src = this; + var state = this._readableState; + + switch (state.pipesCount) { + case 0: + state.pipes = dest; + break; + case 1: + state.pipes = [state.pipes, dest]; + break; + default: + state.pipes.push(dest); + break; + } + state.pipesCount += 1; + debug('pipe count=%d opts=%j', state.pipesCount, pipeOpts); + + var doEnd = (!pipeOpts || pipeOpts.end !== false) && dest !== process.stdout && dest !== process.stderr; + + var endFn = doEnd ? onend : cleanup; + if (state.endEmitted) processNextTick(endFn);else src.once('end', endFn); + + dest.on('unpipe', onunpipe); + function onunpipe(readable) { + debug('onunpipe'); + if (readable === src) { + cleanup(); + } + } + + function onend() { + debug('onend'); + dest.end(); + } + + // when the dest drains, it reduces the awaitDrain counter + // on the source. This would be more elegant with a .once() + // handler in flow(), but adding and removing repeatedly is + // too slow. + var ondrain = pipeOnDrain(src); + dest.on('drain', ondrain); + + var cleanedUp = false; + function cleanup() { + debug('cleanup'); + // cleanup event handlers once the pipe is broken + dest.removeListener('close', onclose); + dest.removeListener('finish', onfinish); + dest.removeListener('drain', ondrain); + dest.removeListener('error', onerror); + dest.removeListener('unpipe', onunpipe); + src.removeListener('end', onend); + src.removeListener('end', cleanup); + src.removeListener('data', ondata); + + cleanedUp = true; + + // if the reader is waiting for a drain event from this + // specific writer, then it would cause it to never start + // flowing again. + // So, if this is awaiting a drain, then we just call it now. + // If we don't know, then assume that we are waiting for one. + if (state.awaitDrain && (!dest._writableState || dest._writableState.needDrain)) ondrain(); + } + + // If the user pushes more data while we're writing to dest then we'll end up + // in ondata again. However, we only want to increase awaitDrain once because + // dest will only emit one 'drain' event for the multiple writes. + // => Introduce a guard on increasing awaitDrain. + var increasedAwaitDrain = false; + src.on('data', ondata); + function ondata(chunk) { + debug('ondata'); + increasedAwaitDrain = false; + var ret = dest.write(chunk); + if (false === ret && !increasedAwaitDrain) { + // If the user unpiped during `dest.write()`, it is possible + // to get stuck in a permanently paused state if that write + // also returned false. + // => Check whether `dest` is still a piping destination. + if ((state.pipesCount === 1 && state.pipes === dest || state.pipesCount > 1 && indexOf(state.pipes, dest) !== -1) && !cleanedUp) { + debug('false write response, pause', src._readableState.awaitDrain); + src._readableState.awaitDrain++; + increasedAwaitDrain = true; + } + src.pause(); + } + } + + // if the dest has an error, then stop piping into it. + // however, don't suppress the throwing behavior for this. + function onerror(er) { + debug('onerror', er); + unpipe(); + dest.removeListener('error', onerror); + if (EElistenerCount(dest, 'error') === 0) dest.emit('error', er); + } + + // Make sure our error handler is attached before userland ones. + prependListener(dest, 'error', onerror); + + // Both close and finish should trigger unpipe, but only once. + function onclose() { + dest.removeListener('finish', onfinish); + unpipe(); + } + dest.once('close', onclose); + function onfinish() { + debug('onfinish'); + dest.removeListener('close', onclose); + unpipe(); + } + dest.once('finish', onfinish); + + function unpipe() { + debug('unpipe'); + src.unpipe(dest); + } + + // tell the dest that it's being piped to + dest.emit('pipe', src); + + // start the flow if it hasn't been started already. + if (!state.flowing) { + debug('pipe resume'); + src.resume(); + } + + return dest; +}; + +function pipeOnDrain(src) { + return function () { + var state = src._readableState; + debug('pipeOnDrain', state.awaitDrain); + if (state.awaitDrain) state.awaitDrain--; + if (state.awaitDrain === 0 && EElistenerCount(src, 'data')) { + state.flowing = true; + flow(src); + } + }; +} + +Readable.prototype.unpipe = function (dest) { + var state = this._readableState; + + // if we're not piping anywhere, then do nothing. + if (state.pipesCount === 0) return this; + + // just one destination. most common case. + if (state.pipesCount === 1) { + // passed in one, but it's not the right one. + if (dest && dest !== state.pipes) return this; + + if (!dest) dest = state.pipes; + + // got a match. + state.pipes = null; + state.pipesCount = 0; + state.flowing = false; + if (dest) dest.emit('unpipe', this); + return this; + } + + // slow case. multiple pipe destinations. + + if (!dest) { + // remove all. + var dests = state.pipes; + var len = state.pipesCount; + state.pipes = null; + state.pipesCount = 0; + state.flowing = false; + + for (var _i = 0; _i < len; _i++) { + dests[_i].emit('unpipe', this); + }return this; + } + + // try to find the right one. + var i = indexOf(state.pipes, dest); + if (i === -1) return this; + + state.pipes.splice(i, 1); + state.pipesCount -= 1; + if (state.pipesCount === 1) state.pipes = state.pipes[0]; + + dest.emit('unpipe', this); + + return this; +}; + +// set up data events if they are asked for +// Ensure readable listeners eventually get something +Readable.prototype.on = function (ev, fn) { + var res = Stream.prototype.on.call(this, ev, fn); + + if (ev === 'data') { + // Start flowing on next tick if stream isn't explicitly paused + if (this._readableState.flowing !== false) this.resume(); + } else if (ev === 'readable') { + var state = this._readableState; + if (!state.endEmitted && !state.readableListening) { + state.readableListening = state.needReadable = true; + state.emittedReadable = false; + if (!state.reading) { + processNextTick(nReadingNextTick, this); + } else if (state.length) { + emitReadable(this, state); + } + } + } + + return res; +}; +Readable.prototype.addListener = Readable.prototype.on; + +function nReadingNextTick(self) { + debug('readable nexttick read 0'); + self.read(0); +} + +// pause() and resume() are remnants of the legacy readable stream API +// If the user uses them, then switch into old mode. +Readable.prototype.resume = function () { + var state = this._readableState; + if (!state.flowing) { + debug('resume'); + state.flowing = true; + resume(this, state); + } + return this; +}; + +function resume(stream, state) { + if (!state.resumeScheduled) { + state.resumeScheduled = true; + processNextTick(resume_, stream, state); + } +} + +function resume_(stream, state) { + if (!state.reading) { + debug('resume read 0'); + stream.read(0); + } + + state.resumeScheduled = false; + state.awaitDrain = 0; + stream.emit('resume'); + flow(stream); + if (state.flowing && !state.reading) stream.read(0); +} + +Readable.prototype.pause = function () { + debug('call pause flowing=%j', this._readableState.flowing); + if (false !== this._readableState.flowing) { + debug('pause'); + this._readableState.flowing = false; + this.emit('pause'); + } + return this; +}; + +function flow(stream) { + var state = stream._readableState; + debug('flow', state.flowing); + while (state.flowing && stream.read() !== null) {} +} + +// wrap an old-style stream as the async data source. +// This is *not* part of the readable stream interface. +// It is an ugly unfortunate mess of history. +Readable.prototype.wrap = function (stream) { + var state = this._readableState; + var paused = false; + + var self = this; + stream.on('end', function () { + debug('wrapped end'); + if (state.decoder && !state.ended) { + var chunk = state.decoder.end(); + if (chunk && chunk.length) self.push(chunk); + } + + self.push(null); + }); + + stream.on('data', function (chunk) { + debug('wrapped data'); + if (state.decoder) chunk = state.decoder.write(chunk); + + // don't skip over falsy values in objectMode + if (state.objectMode && (chunk === null || chunk === undefined)) return;else if (!state.objectMode && (!chunk || !chunk.length)) return; + + var ret = self.push(chunk); + if (!ret) { + paused = true; + stream.pause(); + } + }); + + // proxy all the other methods. + // important when wrapping filters and duplexes. + for (var i in stream) { + if (this[i] === undefined && typeof stream[i] === 'function') { + this[i] = function (method) { + return function () { + return stream[method].apply(stream, arguments); + }; + }(i); + } + } + + // proxy certain important events. + var events = ['error', 'close', 'destroy', 'pause', 'resume']; + forEach(events, function (ev) { + stream.on(ev, self.emit.bind(self, ev)); + }); + + // when we try to consume some more bytes, simply unpause the + // underlying stream. + self._read = function (n) { + debug('wrapped _read', n); + if (paused) { + paused = false; + stream.resume(); + } + }; + + return self; +}; + +// exposed for testing purposes only. +Readable._fromList = fromList; + +// Pluck off n bytes from an array of buffers. +// Length is the combined lengths of all the buffers in the list. +// This function is designed to be inlinable, so please take care when making +// changes to the function body. +function fromList(n, state) { + // nothing buffered + if (state.length === 0) return null; + + var ret; + if (state.objectMode) ret = state.buffer.shift();else if (!n || n >= state.length) { + // read it all, truncate the list + if (state.decoder) ret = state.buffer.join('');else if (state.buffer.length === 1) ret = state.buffer.head.data;else ret = state.buffer.concat(state.length); + state.buffer.clear(); + } else { + // read part of list + ret = fromListPartial(n, state.buffer, state.decoder); + } + + return ret; +} + +// Extracts only enough buffered data to satisfy the amount requested. +// This function is designed to be inlinable, so please take care when making +// changes to the function body. +function fromListPartial(n, list, hasStrings) { + var ret; + if (n < list.head.data.length) { + // slice is the same for buffers and strings + ret = list.head.data.slice(0, n); + list.head.data = list.head.data.slice(n); + } else if (n === list.head.data.length) { + // first chunk is a perfect match + ret = list.shift(); + } else { + // result spans more than one buffer + ret = hasStrings ? copyFromBufferString(n, list) : copyFromBuffer(n, list); + } + return ret; +} + +// Copies a specified amount of characters from the list of buffered data +// chunks. +// This function is designed to be inlinable, so please take care when making +// changes to the function body. +function copyFromBufferString(n, list) { + var p = list.head; + var c = 1; + var ret = p.data; + n -= ret.length; + while (p = p.next) { + var str = p.data; + var nb = n > str.length ? str.length : n; + if (nb === str.length) ret += str;else ret += str.slice(0, n); + n -= nb; + if (n === 0) { + if (nb === str.length) { + ++c; + if (p.next) list.head = p.next;else list.head = list.tail = null; + } else { + list.head = p; + p.data = str.slice(nb); + } + break; + } + ++c; + } + list.length -= c; + return ret; +} + +// Copies a specified amount of bytes from the list of buffered data chunks. +// This function is designed to be inlinable, so please take care when making +// changes to the function body. +function copyFromBuffer(n, list) { + var ret = bufferShim.allocUnsafe(n); + var p = list.head; + var c = 1; + p.data.copy(ret); + n -= p.data.length; + while (p = p.next) { + var buf = p.data; + var nb = n > buf.length ? buf.length : n; + buf.copy(ret, ret.length - n, 0, nb); + n -= nb; + if (n === 0) { + if (nb === buf.length) { + ++c; + if (p.next) list.head = p.next;else list.head = list.tail = null; + } else { + list.head = p; + p.data = buf.slice(nb); + } + break; + } + ++c; + } + list.length -= c; + return ret; +} + +function endReadable(stream) { + var state = stream._readableState; + + // If we get here before consuming all the bytes, then that is a + // bug in node. Should never happen. + if (state.length > 0) throw new Error('"endReadable()" called on non-empty stream'); + + if (!state.endEmitted) { + state.ended = true; + processNextTick(endReadableNT, state, stream); + } +} + +function endReadableNT(state, stream) { + // Check that we didn't get one last unshift. + if (!state.endEmitted && state.length === 0) { + state.endEmitted = true; + stream.readable = false; + stream.emit('end'); + } +} + +function forEach(xs, f) { + for (var i = 0, l = xs.length; i < l; i++) { + f(xs[i], i); + } +} + +function indexOf(xs, x) { + for (var i = 0, l = xs.length; i < l; i++) { + if (xs[i] === x) return i; + } + return -1; +} \ No newline at end of file diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/lib/_stream_transform.js b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/lib/_stream_transform.js new file mode 100644 index 0000000..dbc996e --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/lib/_stream_transform.js @@ -0,0 +1,180 @@ +// a transform stream is a readable/writable stream where you do +// something with the data. Sometimes it's called a "filter", +// but that's not a great name for it, since that implies a thing where +// some bits pass through, and others are simply ignored. (That would +// be a valid example of a transform, of course.) +// +// While the output is causally related to the input, it's not a +// necessarily symmetric or synchronous transformation. For example, +// a zlib stream might take multiple plain-text writes(), and then +// emit a single compressed chunk some time in the future. +// +// Here's how this works: +// +// The Transform stream has all the aspects of the readable and writable +// stream classes. When you write(chunk), that calls _write(chunk,cb) +// internally, and returns false if there's a lot of pending writes +// buffered up. When you call read(), that calls _read(n) until +// there's enough pending readable data buffered up. +// +// In a transform stream, the written data is placed in a buffer. When +// _read(n) is called, it transforms the queued up data, calling the +// buffered _write cb's as it consumes chunks. If consuming a single +// written chunk would result in multiple output chunks, then the first +// outputted bit calls the readcb, and subsequent chunks just go into +// the read buffer, and will cause it to emit 'readable' if necessary. +// +// This way, back-pressure is actually determined by the reading side, +// since _read has to be called to start processing a new chunk. However, +// a pathological inflate type of transform can cause excessive buffering +// here. For example, imagine a stream where every byte of input is +// interpreted as an integer from 0-255, and then results in that many +// bytes of output. Writing the 4 bytes {ff,ff,ff,ff} would result in +// 1kb of data being output. In this case, you could write a very small +// amount of input, and end up with a very large amount of output. In +// such a pathological inflating mechanism, there'd be no way to tell +// the system to stop doing the transform. A single 4MB write could +// cause the system to run out of memory. +// +// However, even in such a pathological case, only a single written chunk +// would be consumed, and then the rest would wait (un-transformed) until +// the results of the previous transformed chunk were consumed. + +'use strict'; + +module.exports = Transform; + +var Duplex = require('./_stream_duplex'); + +/**/ +var util = require('core-util-is'); +util.inherits = require('inherits'); +/**/ + +util.inherits(Transform, Duplex); + +function TransformState(stream) { + this.afterTransform = function (er, data) { + return afterTransform(stream, er, data); + }; + + this.needTransform = false; + this.transforming = false; + this.writecb = null; + this.writechunk = null; + this.writeencoding = null; +} + +function afterTransform(stream, er, data) { + var ts = stream._transformState; + ts.transforming = false; + + var cb = ts.writecb; + + if (!cb) return stream.emit('error', new Error('no writecb in Transform class')); + + ts.writechunk = null; + ts.writecb = null; + + if (data !== null && data !== undefined) stream.push(data); + + cb(er); + + var rs = stream._readableState; + rs.reading = false; + if (rs.needReadable || rs.length < rs.highWaterMark) { + stream._read(rs.highWaterMark); + } +} + +function Transform(options) { + if (!(this instanceof Transform)) return new Transform(options); + + Duplex.call(this, options); + + this._transformState = new TransformState(this); + + // when the writable side finishes, then flush out anything remaining. + var stream = this; + + // start out asking for a readable event once data is transformed. + this._readableState.needReadable = true; + + // we have implemented the _read method, and done the other things + // that Readable wants before the first _read call, so unset the + // sync guard flag. + this._readableState.sync = false; + + if (options) { + if (typeof options.transform === 'function') this._transform = options.transform; + + if (typeof options.flush === 'function') this._flush = options.flush; + } + + this.once('prefinish', function () { + if (typeof this._flush === 'function') this._flush(function (er) { + done(stream, er); + });else done(stream); + }); +} + +Transform.prototype.push = function (chunk, encoding) { + this._transformState.needTransform = false; + return Duplex.prototype.push.call(this, chunk, encoding); +}; + +// This is the part where you do stuff! +// override this function in implementation classes. +// 'chunk' is an input chunk. +// +// Call `push(newChunk)` to pass along transformed output +// to the readable side. You may call 'push' zero or more times. +// +// Call `cb(err)` when you are done with this chunk. If you pass +// an error, then that'll put the hurt on the whole operation. If you +// never call cb(), then you'll never get another chunk. +Transform.prototype._transform = function (chunk, encoding, cb) { + throw new Error('Not implemented'); +}; + +Transform.prototype._write = function (chunk, encoding, cb) { + var ts = this._transformState; + ts.writecb = cb; + ts.writechunk = chunk; + ts.writeencoding = encoding; + if (!ts.transforming) { + var rs = this._readableState; + if (ts.needTransform || rs.needReadable || rs.length < rs.highWaterMark) this._read(rs.highWaterMark); + } +}; + +// Doesn't matter what the args are here. +// _transform does all the work. +// That we got here means that the readable side wants more data. +Transform.prototype._read = function (n) { + var ts = this._transformState; + + if (ts.writechunk !== null && ts.writecb && !ts.transforming) { + ts.transforming = true; + this._transform(ts.writechunk, ts.writeencoding, ts.afterTransform); + } else { + // mark that we need a transform, so that any data that comes in + // will get processed, now that we've asked for it. + ts.needTransform = true; + } +}; + +function done(stream, er) { + if (er) return stream.emit('error', er); + + // if there's nothing in the write buffer, then that means + // that nothing more will ever be provided + var ws = stream._writableState; + var ts = stream._transformState; + + if (ws.length) throw new Error('Calling transform done when ws.length != 0'); + + if (ts.transforming) throw new Error('Calling transform done when still transforming'); + + return stream.push(null); +} \ No newline at end of file diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/lib/_stream_writable.js b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/lib/_stream_writable.js new file mode 100644 index 0000000..ed5efcb --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/lib/_stream_writable.js @@ -0,0 +1,526 @@ +// A bit simpler than readable streams. +// Implement an async ._write(chunk, encoding, cb), and it'll handle all +// the drain event emission and buffering. + +'use strict'; + +module.exports = Writable; + +/**/ +var processNextTick = require('process-nextick-args'); +/**/ + +/**/ +var asyncWrite = !process.browser && ['v0.10', 'v0.9.'].indexOf(process.version.slice(0, 5)) > -1 ? setImmediate : processNextTick; +/**/ + +Writable.WritableState = WritableState; + +/**/ +var util = require('core-util-is'); +util.inherits = require('inherits'); +/**/ + +/**/ +var internalUtil = { + deprecate: require('util-deprecate') +}; +/**/ + +/**/ +var Stream; +(function () { + try { + Stream = require('st' + 'ream'); + } catch (_) {} finally { + if (!Stream) Stream = require('events').EventEmitter; + } +})(); +/**/ + +var Buffer = require('buffer').Buffer; +/**/ +var bufferShim = require('buffer-shims'); +/**/ + +util.inherits(Writable, Stream); + +function nop() {} + +function WriteReq(chunk, encoding, cb) { + this.chunk = chunk; + this.encoding = encoding; + this.callback = cb; + this.next = null; +} + +var Duplex; +function WritableState(options, stream) { + Duplex = Duplex || require('./_stream_duplex'); + + options = options || {}; + + // object stream flag to indicate whether or not this stream + // contains buffers or objects. + this.objectMode = !!options.objectMode; + + if (stream instanceof Duplex) this.objectMode = this.objectMode || !!options.writableObjectMode; + + // the point at which write() starts returning false + // Note: 0 is a valid value, means that we always return false if + // the entire buffer is not flushed immediately on write() + var hwm = options.highWaterMark; + var defaultHwm = this.objectMode ? 16 : 16 * 1024; + this.highWaterMark = hwm || hwm === 0 ? hwm : defaultHwm; + + // cast to ints. + this.highWaterMark = ~ ~this.highWaterMark; + + this.needDrain = false; + // at the start of calling end() + this.ending = false; + // when end() has been called, and returned + this.ended = false; + // when 'finish' is emitted + this.finished = false; + + // should we decode strings into buffers before passing to _write? + // this is here so that some node-core streams can optimize string + // handling at a lower level. + var noDecode = options.decodeStrings === false; + this.decodeStrings = !noDecode; + + // Crypto is kind of old and crusty. Historically, its default string + // encoding is 'binary' so we have to make this configurable. + // Everything else in the universe uses 'utf8', though. + this.defaultEncoding = options.defaultEncoding || 'utf8'; + + // not an actual buffer we keep track of, but a measurement + // of how much we're waiting to get pushed to some underlying + // socket or file. + this.length = 0; + + // a flag to see when we're in the middle of a write. + this.writing = false; + + // when true all writes will be buffered until .uncork() call + this.corked = 0; + + // a flag to be able to tell if the onwrite cb is called immediately, + // or on a later tick. We set this to true at first, because any + // actions that shouldn't happen until "later" should generally also + // not happen before the first write call. + this.sync = true; + + // a flag to know if we're processing previously buffered items, which + // may call the _write() callback in the same tick, so that we don't + // end up in an overlapped onwrite situation. + this.bufferProcessing = false; + + // the callback that's passed to _write(chunk,cb) + this.onwrite = function (er) { + onwrite(stream, er); + }; + + // the callback that the user supplies to write(chunk,encoding,cb) + this.writecb = null; + + // the amount that is being written when _write is called. + this.writelen = 0; + + this.bufferedRequest = null; + this.lastBufferedRequest = null; + + // number of pending user-supplied write callbacks + // this must be 0 before 'finish' can be emitted + this.pendingcb = 0; + + // emit prefinish if the only thing we're waiting for is _write cbs + // This is relevant for synchronous Transform streams + this.prefinished = false; + + // True if the error was already emitted and should not be thrown again + this.errorEmitted = false; + + // count buffered requests + this.bufferedRequestCount = 0; + + // allocate the first CorkedRequest, there is always + // one allocated and free to use, and we maintain at most two + this.corkedRequestsFree = new CorkedRequest(this); +} + +WritableState.prototype.getBuffer = function writableStateGetBuffer() { + var current = this.bufferedRequest; + var out = []; + while (current) { + out.push(current); + current = current.next; + } + return out; +}; + +(function () { + try { + Object.defineProperty(WritableState.prototype, 'buffer', { + get: internalUtil.deprecate(function () { + return this.getBuffer(); + }, '_writableState.buffer is deprecated. Use _writableState.getBuffer ' + 'instead.') + }); + } catch (_) {} +})(); + +var Duplex; +function Writable(options) { + Duplex = Duplex || require('./_stream_duplex'); + + // Writable ctor is applied to Duplexes, though they're not + // instanceof Writable, they're instanceof Readable. + if (!(this instanceof Writable) && !(this instanceof Duplex)) return new Writable(options); + + this._writableState = new WritableState(options, this); + + // legacy. + this.writable = true; + + if (options) { + if (typeof options.write === 'function') this._write = options.write; + + if (typeof options.writev === 'function') this._writev = options.writev; + } + + Stream.call(this); +} + +// Otherwise people can pipe Writable streams, which is just wrong. +Writable.prototype.pipe = function () { + this.emit('error', new Error('Cannot pipe, not readable')); +}; + +function writeAfterEnd(stream, cb) { + var er = new Error('write after end'); + // TODO: defer error events consistently everywhere, not just the cb + stream.emit('error', er); + processNextTick(cb, er); +} + +// If we get something that is not a buffer, string, null, or undefined, +// and we're not in objectMode, then that's an error. +// Otherwise stream chunks are all considered to be of length=1, and the +// watermarks determine how many objects to keep in the buffer, rather than +// how many bytes or characters. +function validChunk(stream, state, chunk, cb) { + var valid = true; + var er = false; + // Always throw error if a null is written + // if we are not in object mode then throw + // if it is not a buffer, string, or undefined. + if (chunk === null) { + er = new TypeError('May not write null values to stream'); + } else if (!Buffer.isBuffer(chunk) && typeof chunk !== 'string' && chunk !== undefined && !state.objectMode) { + er = new TypeError('Invalid non-string/buffer chunk'); + } + if (er) { + stream.emit('error', er); + processNextTick(cb, er); + valid = false; + } + return valid; +} + +Writable.prototype.write = function (chunk, encoding, cb) { + var state = this._writableState; + var ret = false; + + if (typeof encoding === 'function') { + cb = encoding; + encoding = null; + } + + if (Buffer.isBuffer(chunk)) encoding = 'buffer';else if (!encoding) encoding = state.defaultEncoding; + + if (typeof cb !== 'function') cb = nop; + + if (state.ended) writeAfterEnd(this, cb);else if (validChunk(this, state, chunk, cb)) { + state.pendingcb++; + ret = writeOrBuffer(this, state, chunk, encoding, cb); + } + + return ret; +}; + +Writable.prototype.cork = function () { + var state = this._writableState; + + state.corked++; +}; + +Writable.prototype.uncork = function () { + var state = this._writableState; + + if (state.corked) { + state.corked--; + + if (!state.writing && !state.corked && !state.finished && !state.bufferProcessing && state.bufferedRequest) clearBuffer(this, state); + } +}; + +Writable.prototype.setDefaultEncoding = function setDefaultEncoding(encoding) { + // node::ParseEncoding() requires lower case. + if (typeof encoding === 'string') encoding = encoding.toLowerCase(); + if (!(['hex', 'utf8', 'utf-8', 'ascii', 'binary', 'base64', 'ucs2', 'ucs-2', 'utf16le', 'utf-16le', 'raw'].indexOf((encoding + '').toLowerCase()) > -1)) throw new TypeError('Unknown encoding: ' + encoding); + this._writableState.defaultEncoding = encoding; + return this; +}; + +function decodeChunk(state, chunk, encoding) { + if (!state.objectMode && state.decodeStrings !== false && typeof chunk === 'string') { + chunk = bufferShim.from(chunk, encoding); + } + return chunk; +} + +// if we're already writing something, then just put this +// in the queue, and wait our turn. Otherwise, call _write +// If we return false, then we need a drain event, so set that flag. +function writeOrBuffer(stream, state, chunk, encoding, cb) { + chunk = decodeChunk(state, chunk, encoding); + + if (Buffer.isBuffer(chunk)) encoding = 'buffer'; + var len = state.objectMode ? 1 : chunk.length; + + state.length += len; + + var ret = state.length < state.highWaterMark; + // we must ensure that previous needDrain will not be reset to false. + if (!ret) state.needDrain = true; + + if (state.writing || state.corked) { + var last = state.lastBufferedRequest; + state.lastBufferedRequest = new WriteReq(chunk, encoding, cb); + if (last) { + last.next = state.lastBufferedRequest; + } else { + state.bufferedRequest = state.lastBufferedRequest; + } + state.bufferedRequestCount += 1; + } else { + doWrite(stream, state, false, len, chunk, encoding, cb); + } + + return ret; +} + +function doWrite(stream, state, writev, len, chunk, encoding, cb) { + state.writelen = len; + state.writecb = cb; + state.writing = true; + state.sync = true; + if (writev) stream._writev(chunk, state.onwrite);else stream._write(chunk, encoding, state.onwrite); + state.sync = false; +} + +function onwriteError(stream, state, sync, er, cb) { + --state.pendingcb; + if (sync) processNextTick(cb, er);else cb(er); + + stream._writableState.errorEmitted = true; + stream.emit('error', er); +} + +function onwriteStateUpdate(state) { + state.writing = false; + state.writecb = null; + state.length -= state.writelen; + state.writelen = 0; +} + +function onwrite(stream, er) { + var state = stream._writableState; + var sync = state.sync; + var cb = state.writecb; + + onwriteStateUpdate(state); + + if (er) onwriteError(stream, state, sync, er, cb);else { + // Check if we're actually ready to finish, but don't emit yet + var finished = needFinish(state); + + if (!finished && !state.corked && !state.bufferProcessing && state.bufferedRequest) { + clearBuffer(stream, state); + } + + if (sync) { + /**/ + asyncWrite(afterWrite, stream, state, finished, cb); + /**/ + } else { + afterWrite(stream, state, finished, cb); + } + } +} + +function afterWrite(stream, state, finished, cb) { + if (!finished) onwriteDrain(stream, state); + state.pendingcb--; + cb(); + finishMaybe(stream, state); +} + +// Must force callback to be called on nextTick, so that we don't +// emit 'drain' before the write() consumer gets the 'false' return +// value, and has a chance to attach a 'drain' listener. +function onwriteDrain(stream, state) { + if (state.length === 0 && state.needDrain) { + state.needDrain = false; + stream.emit('drain'); + } +} + +// if there's something in the buffer waiting, then process it +function clearBuffer(stream, state) { + state.bufferProcessing = true; + var entry = state.bufferedRequest; + + if (stream._writev && entry && entry.next) { + // Fast case, write everything using _writev() + var l = state.bufferedRequestCount; + var buffer = new Array(l); + var holder = state.corkedRequestsFree; + holder.entry = entry; + + var count = 0; + while (entry) { + buffer[count] = entry; + entry = entry.next; + count += 1; + } + + doWrite(stream, state, true, state.length, buffer, '', holder.finish); + + // doWrite is almost always async, defer these to save a bit of time + // as the hot path ends with doWrite + state.pendingcb++; + state.lastBufferedRequest = null; + if (holder.next) { + state.corkedRequestsFree = holder.next; + holder.next = null; + } else { + state.corkedRequestsFree = new CorkedRequest(state); + } + } else { + // Slow case, write chunks one-by-one + while (entry) { + var chunk = entry.chunk; + var encoding = entry.encoding; + var cb = entry.callback; + var len = state.objectMode ? 1 : chunk.length; + + doWrite(stream, state, false, len, chunk, encoding, cb); + entry = entry.next; + // if we didn't call the onwrite immediately, then + // it means that we need to wait until it does. + // also, that means that the chunk and cb are currently + // being processed, so move the buffer counter past them. + if (state.writing) { + break; + } + } + + if (entry === null) state.lastBufferedRequest = null; + } + + state.bufferedRequestCount = 0; + state.bufferedRequest = entry; + state.bufferProcessing = false; +} + +Writable.prototype._write = function (chunk, encoding, cb) { + cb(new Error('not implemented')); +}; + +Writable.prototype._writev = null; + +Writable.prototype.end = function (chunk, encoding, cb) { + var state = this._writableState; + + if (typeof chunk === 'function') { + cb = chunk; + chunk = null; + encoding = null; + } else if (typeof encoding === 'function') { + cb = encoding; + encoding = null; + } + + if (chunk !== null && chunk !== undefined) this.write(chunk, encoding); + + // .end() fully uncorks + if (state.corked) { + state.corked = 1; + this.uncork(); + } + + // ignore unnecessary end() calls. + if (!state.ending && !state.finished) endWritable(this, state, cb); +}; + +function needFinish(state) { + return state.ending && state.length === 0 && state.bufferedRequest === null && !state.finished && !state.writing; +} + +function prefinish(stream, state) { + if (!state.prefinished) { + state.prefinished = true; + stream.emit('prefinish'); + } +} + +function finishMaybe(stream, state) { + var need = needFinish(state); + if (need) { + if (state.pendingcb === 0) { + prefinish(stream, state); + state.finished = true; + stream.emit('finish'); + } else { + prefinish(stream, state); + } + } + return need; +} + +function endWritable(stream, state, cb) { + state.ending = true; + finishMaybe(stream, state); + if (cb) { + if (state.finished) processNextTick(cb);else stream.once('finish', cb); + } + state.ended = true; + stream.writable = false; +} + +// It seems a linked list but it is not +// there will be only 2 of these for each stream +function CorkedRequest(state) { + var _this = this; + + this.next = null; + this.entry = null; + + this.finish = function (err) { + var entry = _this.entry; + _this.entry = null; + while (entry) { + var cb = entry.callback; + state.pendingcb--; + cb(err); + entry = entry.next; + } + if (state.corkedRequestsFree) { + state.corkedRequestsFree.next = _this; + } else { + state.corkedRequestsFree = _this; + } + }; +} \ No newline at end of file diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/lib/internal/streams/BufferList.js b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/lib/internal/streams/BufferList.js new file mode 100644 index 0000000..e4bfcf0 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/lib/internal/streams/BufferList.js @@ -0,0 +1,64 @@ +'use strict'; + +var Buffer = require('buffer').Buffer; +/**/ +var bufferShim = require('buffer-shims'); +/**/ + +module.exports = BufferList; + +function BufferList() { + this.head = null; + this.tail = null; + this.length = 0; +} + +BufferList.prototype.push = function (v) { + var entry = { data: v, next: null }; + if (this.length > 0) this.tail.next = entry;else this.head = entry; + this.tail = entry; + ++this.length; +}; + +BufferList.prototype.unshift = function (v) { + var entry = { data: v, next: this.head }; + if (this.length === 0) this.tail = entry; + this.head = entry; + ++this.length; +}; + +BufferList.prototype.shift = function () { + if (this.length === 0) return; + var ret = this.head.data; + if (this.length === 1) this.head = this.tail = null;else this.head = this.head.next; + --this.length; + return ret; +}; + +BufferList.prototype.clear = function () { + this.head = this.tail = null; + this.length = 0; +}; + +BufferList.prototype.join = function (s) { + if (this.length === 0) return ''; + var p = this.head; + var ret = '' + p.data; + while (p = p.next) { + ret += s + p.data; + }return ret; +}; + +BufferList.prototype.concat = function (n) { + if (this.length === 0) return bufferShim.alloc(0); + if (this.length === 1) return this.head.data; + var ret = bufferShim.allocUnsafe(n >>> 0); + var p = this.head; + var i = 0; + while (p) { + p.data.copy(ret, i); + i += p.data.length; + p = p.next; + } + return ret; +}; \ No newline at end of file diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/buffer-shims/index.js b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/buffer-shims/index.js new file mode 100644 index 0000000..1cab4c0 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/buffer-shims/index.js @@ -0,0 +1,108 @@ +'use strict'; + +var buffer = require('buffer'); +var Buffer = buffer.Buffer; +var SlowBuffer = buffer.SlowBuffer; +var MAX_LEN = buffer.kMaxLength || 2147483647; +exports.alloc = function alloc(size, fill, encoding) { + if (typeof Buffer.alloc === 'function') { + return Buffer.alloc(size, fill, encoding); + } + if (typeof encoding === 'number') { + throw new TypeError('encoding must not be number'); + } + if (typeof size !== 'number') { + throw new TypeError('size must be a number'); + } + if (size > MAX_LEN) { + throw new RangeError('size is too large'); + } + var enc = encoding; + var _fill = fill; + if (_fill === undefined) { + enc = undefined; + _fill = 0; + } + var buf = new Buffer(size); + if (typeof _fill === 'string') { + var fillBuf = new Buffer(_fill, enc); + var flen = fillBuf.length; + var i = -1; + while (++i < size) { + buf[i] = fillBuf[i % flen]; + } + } else { + buf.fill(_fill); + } + return buf; +} +exports.allocUnsafe = function allocUnsafe(size) { + if (typeof Buffer.allocUnsafe === 'function') { + return Buffer.allocUnsafe(size); + } + if (typeof size !== 'number') { + throw new TypeError('size must be a number'); + } + if (size > MAX_LEN) { + throw new RangeError('size is too large'); + } + return new Buffer(size); +} +exports.from = function from(value, encodingOrOffset, length) { + if (typeof Buffer.from === 'function' && (!global.Uint8Array || Uint8Array.from !== Buffer.from)) { + return Buffer.from(value, encodingOrOffset, length); + } + if (typeof value === 'number') { + throw new TypeError('"value" argument must not be a number'); + } + if (typeof value === 'string') { + return new Buffer(value, encodingOrOffset); + } + if (typeof ArrayBuffer !== 'undefined' && value instanceof ArrayBuffer) { + var offset = encodingOrOffset; + if (arguments.length === 1) { + return new Buffer(value); + } + if (typeof offset === 'undefined') { + offset = 0; + } + var len = length; + if (typeof len === 'undefined') { + len = value.byteLength - offset; + } + if (offset >= value.byteLength) { + throw new RangeError('\'offset\' is out of bounds'); + } + if (len > value.byteLength - offset) { + throw new RangeError('\'length\' is out of bounds'); + } + return new Buffer(value.slice(offset, offset + len)); + } + if (Buffer.isBuffer(value)) { + var out = new Buffer(value.length); + value.copy(out, 0, 0, value.length); + return out; + } + if (value) { + if (Array.isArray(value) || (typeof ArrayBuffer !== 'undefined' && value.buffer instanceof ArrayBuffer) || 'length' in value) { + return new Buffer(value); + } + if (value.type === 'Buffer' && Array.isArray(value.data)) { + return new Buffer(value.data); + } + } + + throw new TypeError('First argument must be a string, Buffer, ' + 'ArrayBuffer, Array, or array-like object.'); +} +exports.allocUnsafeSlow = function allocUnsafeSlow(size) { + if (typeof Buffer.allocUnsafeSlow === 'function') { + return Buffer.allocUnsafeSlow(size); + } + if (typeof size !== 'number') { + throw new TypeError('size must be a number'); + } + if (size >= MAX_LEN) { + throw new RangeError('size is too large'); + } + return new SlowBuffer(size); +} diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/buffer-shims/license.md b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/buffer-shims/license.md new file mode 100644 index 0000000..01cfaef --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/buffer-shims/license.md @@ -0,0 +1,19 @@ +# Copyright (c) 2016 Calvin Metcalf + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +**THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE.** diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/buffer-shims/package.json b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/buffer-shims/package.json new file mode 100644 index 0000000..c35293a --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/buffer-shims/package.json @@ -0,0 +1,51 @@ +{ + "name": "buffer-shims", + "version": "1.0.0", + "description": "some shims for node buffers", + "main": "index.js", + "scripts": { + "test": "tape test/*.js" + }, + "files": [ + "index.js" + ], + "license": "MIT", + "devDependencies": { + "tape": "^4.5.1" + }, + "repository": { + "type": "git", + "url": "git+ssh://git@github.com/calvinmetcalf/buffer-shims.git" + }, + "gitHead": "ea89b3857ab5b8203957922a84e9a48cf4c47e0a", + "bugs": { + "url": "https://github.com/calvinmetcalf/buffer-shims/issues" + }, + "_id": "buffer-shims@1.0.0", + "_shasum": "9978ce317388c649ad8793028c3477ef044a8b51", + "_from": "buffer-shims@>=1.0.0 <2.0.0", + "_npmVersion": "3.8.6", + "_nodeVersion": "5.11.0", + "_npmUser": { + "name": "cwmma", + "email": "calvin.metcalf@gmail.com" + }, + "dist": { + "shasum": "9978ce317388c649ad8793028c3477ef044a8b51", + "tarball": "https://registry.npmjs.org/buffer-shims/-/buffer-shims-1.0.0.tgz" + }, + "maintainers": [ + { + "name": "cwmma", + "email": "calvin.metcalf@gmail.com" + } + ], + "_npmOperationalInternal": { + "host": "packages-16-east.internal.npmjs.com", + "tmp": "tmp/buffer-shims-1.0.0.tgz_1462560889323_0.8640750856138766" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/buffer-shims/-/buffer-shims-1.0.0.tgz", + "readme": "ERROR: No README data found!", + "homepage": "https://github.com/calvinmetcalf/buffer-shims#readme" +} diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/buffer-shims/readme.md b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/buffer-shims/readme.md new file mode 100644 index 0000000..7ea6475 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/buffer-shims/readme.md @@ -0,0 +1,21 @@ +buffer-shims +=== + +functions to make sure the new buffer methods work in older browsers. + +```js +var bufferShim = require('buffer-shims'); +bufferShim.from('foo'); +bufferShim.alloc(9, 'cafeface', 'hex'); +bufferShim.allocUnsafe(15); +bufferShim.allocUnsafeSlow(21); +``` + +should just use the original in newer nodes and on older nodes uses fallbacks. + +Known Issues +=== +- this does not patch the buffer object, only the constructor stuff +- it's actually a polyfill + +![](https://i.imgur.com/zxII3jJ.gif) diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/core-util-is/LICENSE b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/core-util-is/LICENSE new file mode 100644 index 0000000..d8d7f94 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/core-util-is/LICENSE @@ -0,0 +1,19 @@ +Copyright Node.js contributors. All rights reserved. + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to +deal in the Software without restriction, including without limitation the +rights to use, copy, modify, merge, publish, distribute, sublicense, and/or +sell copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING +FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS +IN THE SOFTWARE. diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/core-util-is/README.md b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/core-util-is/README.md new file mode 100644 index 0000000..5a76b41 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/core-util-is/README.md @@ -0,0 +1,3 @@ +# core-util-is + +The `util.is*` functions introduced in Node v0.12. diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/core-util-is/float.patch b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/core-util-is/float.patch new file mode 100644 index 0000000..a06d5c0 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/core-util-is/float.patch @@ -0,0 +1,604 @@ +diff --git a/lib/util.js b/lib/util.js +index a03e874..9074e8e 100644 +--- a/lib/util.js ++++ b/lib/util.js +@@ -19,430 +19,6 @@ + // OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE + // USE OR OTHER DEALINGS IN THE SOFTWARE. + +-var formatRegExp = /%[sdj%]/g; +-exports.format = function(f) { +- if (!isString(f)) { +- var objects = []; +- for (var i = 0; i < arguments.length; i++) { +- objects.push(inspect(arguments[i])); +- } +- return objects.join(' '); +- } +- +- var i = 1; +- var args = arguments; +- var len = args.length; +- var str = String(f).replace(formatRegExp, function(x) { +- if (x === '%%') return '%'; +- if (i >= len) return x; +- switch (x) { +- case '%s': return String(args[i++]); +- case '%d': return Number(args[i++]); +- case '%j': +- try { +- return JSON.stringify(args[i++]); +- } catch (_) { +- return '[Circular]'; +- } +- default: +- return x; +- } +- }); +- for (var x = args[i]; i < len; x = args[++i]) { +- if (isNull(x) || !isObject(x)) { +- str += ' ' + x; +- } else { +- str += ' ' + inspect(x); +- } +- } +- return str; +-}; +- +- +-// Mark that a method should not be used. +-// Returns a modified function which warns once by default. +-// If --no-deprecation is set, then it is a no-op. +-exports.deprecate = function(fn, msg) { +- // Allow for deprecating things in the process of starting up. +- if (isUndefined(global.process)) { +- return function() { +- return exports.deprecate(fn, msg).apply(this, arguments); +- }; +- } +- +- if (process.noDeprecation === true) { +- return fn; +- } +- +- var warned = false; +- function deprecated() { +- if (!warned) { +- if (process.throwDeprecation) { +- throw new Error(msg); +- } else if (process.traceDeprecation) { +- console.trace(msg); +- } else { +- console.error(msg); +- } +- warned = true; +- } +- return fn.apply(this, arguments); +- } +- +- return deprecated; +-}; +- +- +-var debugs = {}; +-var debugEnviron; +-exports.debuglog = function(set) { +- if (isUndefined(debugEnviron)) +- debugEnviron = process.env.NODE_DEBUG || ''; +- set = set.toUpperCase(); +- if (!debugs[set]) { +- if (new RegExp('\\b' + set + '\\b', 'i').test(debugEnviron)) { +- var pid = process.pid; +- debugs[set] = function() { +- var msg = exports.format.apply(exports, arguments); +- console.error('%s %d: %s', set, pid, msg); +- }; +- } else { +- debugs[set] = function() {}; +- } +- } +- return debugs[set]; +-}; +- +- +-/** +- * Echos the value of a value. Trys to print the value out +- * in the best way possible given the different types. +- * +- * @param {Object} obj The object to print out. +- * @param {Object} opts Optional options object that alters the output. +- */ +-/* legacy: obj, showHidden, depth, colors*/ +-function inspect(obj, opts) { +- // default options +- var ctx = { +- seen: [], +- stylize: stylizeNoColor +- }; +- // legacy... +- if (arguments.length >= 3) ctx.depth = arguments[2]; +- if (arguments.length >= 4) ctx.colors = arguments[3]; +- if (isBoolean(opts)) { +- // legacy... +- ctx.showHidden = opts; +- } else if (opts) { +- // got an "options" object +- exports._extend(ctx, opts); +- } +- // set default options +- if (isUndefined(ctx.showHidden)) ctx.showHidden = false; +- if (isUndefined(ctx.depth)) ctx.depth = 2; +- if (isUndefined(ctx.colors)) ctx.colors = false; +- if (isUndefined(ctx.customInspect)) ctx.customInspect = true; +- if (ctx.colors) ctx.stylize = stylizeWithColor; +- return formatValue(ctx, obj, ctx.depth); +-} +-exports.inspect = inspect; +- +- +-// http://en.wikipedia.org/wiki/ANSI_escape_code#graphics +-inspect.colors = { +- 'bold' : [1, 22], +- 'italic' : [3, 23], +- 'underline' : [4, 24], +- 'inverse' : [7, 27], +- 'white' : [37, 39], +- 'grey' : [90, 39], +- 'black' : [30, 39], +- 'blue' : [34, 39], +- 'cyan' : [36, 39], +- 'green' : [32, 39], +- 'magenta' : [35, 39], +- 'red' : [31, 39], +- 'yellow' : [33, 39] +-}; +- +-// Don't use 'blue' not visible on cmd.exe +-inspect.styles = { +- 'special': 'cyan', +- 'number': 'yellow', +- 'boolean': 'yellow', +- 'undefined': 'grey', +- 'null': 'bold', +- 'string': 'green', +- 'date': 'magenta', +- // "name": intentionally not styling +- 'regexp': 'red' +-}; +- +- +-function stylizeWithColor(str, styleType) { +- var style = inspect.styles[styleType]; +- +- if (style) { +- return '\u001b[' + inspect.colors[style][0] + 'm' + str + +- '\u001b[' + inspect.colors[style][1] + 'm'; +- } else { +- return str; +- } +-} +- +- +-function stylizeNoColor(str, styleType) { +- return str; +-} +- +- +-function arrayToHash(array) { +- var hash = {}; +- +- array.forEach(function(val, idx) { +- hash[val] = true; +- }); +- +- return hash; +-} +- +- +-function formatValue(ctx, value, recurseTimes) { +- // Provide a hook for user-specified inspect functions. +- // Check that value is an object with an inspect function on it +- if (ctx.customInspect && +- value && +- isFunction(value.inspect) && +- // Filter out the util module, it's inspect function is special +- value.inspect !== exports.inspect && +- // Also filter out any prototype objects using the circular check. +- !(value.constructor && value.constructor.prototype === value)) { +- var ret = value.inspect(recurseTimes, ctx); +- if (!isString(ret)) { +- ret = formatValue(ctx, ret, recurseTimes); +- } +- return ret; +- } +- +- // Primitive types cannot have properties +- var primitive = formatPrimitive(ctx, value); +- if (primitive) { +- return primitive; +- } +- +- // Look up the keys of the object. +- var keys = Object.keys(value); +- var visibleKeys = arrayToHash(keys); +- +- if (ctx.showHidden) { +- keys = Object.getOwnPropertyNames(value); +- } +- +- // Some type of object without properties can be shortcutted. +- if (keys.length === 0) { +- if (isFunction(value)) { +- var name = value.name ? ': ' + value.name : ''; +- return ctx.stylize('[Function' + name + ']', 'special'); +- } +- if (isRegExp(value)) { +- return ctx.stylize(RegExp.prototype.toString.call(value), 'regexp'); +- } +- if (isDate(value)) { +- return ctx.stylize(Date.prototype.toString.call(value), 'date'); +- } +- if (isError(value)) { +- return formatError(value); +- } +- } +- +- var base = '', array = false, braces = ['{', '}']; +- +- // Make Array say that they are Array +- if (isArray(value)) { +- array = true; +- braces = ['[', ']']; +- } +- +- // Make functions say that they are functions +- if (isFunction(value)) { +- var n = value.name ? ': ' + value.name : ''; +- base = ' [Function' + n + ']'; +- } +- +- // Make RegExps say that they are RegExps +- if (isRegExp(value)) { +- base = ' ' + RegExp.prototype.toString.call(value); +- } +- +- // Make dates with properties first say the date +- if (isDate(value)) { +- base = ' ' + Date.prototype.toUTCString.call(value); +- } +- +- // Make error with message first say the error +- if (isError(value)) { +- base = ' ' + formatError(value); +- } +- +- if (keys.length === 0 && (!array || value.length == 0)) { +- return braces[0] + base + braces[1]; +- } +- +- if (recurseTimes < 0) { +- if (isRegExp(value)) { +- return ctx.stylize(RegExp.prototype.toString.call(value), 'regexp'); +- } else { +- return ctx.stylize('[Object]', 'special'); +- } +- } +- +- ctx.seen.push(value); +- +- var output; +- if (array) { +- output = formatArray(ctx, value, recurseTimes, visibleKeys, keys); +- } else { +- output = keys.map(function(key) { +- return formatProperty(ctx, value, recurseTimes, visibleKeys, key, array); +- }); +- } +- +- ctx.seen.pop(); +- +- return reduceToSingleString(output, base, braces); +-} +- +- +-function formatPrimitive(ctx, value) { +- if (isUndefined(value)) +- return ctx.stylize('undefined', 'undefined'); +- if (isString(value)) { +- var simple = '\'' + JSON.stringify(value).replace(/^"|"$/g, '') +- .replace(/'/g, "\\'") +- .replace(/\\"/g, '"') + '\''; +- return ctx.stylize(simple, 'string'); +- } +- if (isNumber(value)) { +- // Format -0 as '-0'. Strict equality won't distinguish 0 from -0, +- // so instead we use the fact that 1 / -0 < 0 whereas 1 / 0 > 0 . +- if (value === 0 && 1 / value < 0) +- return ctx.stylize('-0', 'number'); +- return ctx.stylize('' + value, 'number'); +- } +- if (isBoolean(value)) +- return ctx.stylize('' + value, 'boolean'); +- // For some reason typeof null is "object", so special case here. +- if (isNull(value)) +- return ctx.stylize('null', 'null'); +-} +- +- +-function formatError(value) { +- return '[' + Error.prototype.toString.call(value) + ']'; +-} +- +- +-function formatArray(ctx, value, recurseTimes, visibleKeys, keys) { +- var output = []; +- for (var i = 0, l = value.length; i < l; ++i) { +- if (hasOwnProperty(value, String(i))) { +- output.push(formatProperty(ctx, value, recurseTimes, visibleKeys, +- String(i), true)); +- } else { +- output.push(''); +- } +- } +- keys.forEach(function(key) { +- if (!key.match(/^\d+$/)) { +- output.push(formatProperty(ctx, value, recurseTimes, visibleKeys, +- key, true)); +- } +- }); +- return output; +-} +- +- +-function formatProperty(ctx, value, recurseTimes, visibleKeys, key, array) { +- var name, str, desc; +- desc = Object.getOwnPropertyDescriptor(value, key) || { value: value[key] }; +- if (desc.get) { +- if (desc.set) { +- str = ctx.stylize('[Getter/Setter]', 'special'); +- } else { +- str = ctx.stylize('[Getter]', 'special'); +- } +- } else { +- if (desc.set) { +- str = ctx.stylize('[Setter]', 'special'); +- } +- } +- if (!hasOwnProperty(visibleKeys, key)) { +- name = '[' + key + ']'; +- } +- if (!str) { +- if (ctx.seen.indexOf(desc.value) < 0) { +- if (isNull(recurseTimes)) { +- str = formatValue(ctx, desc.value, null); +- } else { +- str = formatValue(ctx, desc.value, recurseTimes - 1); +- } +- if (str.indexOf('\n') > -1) { +- if (array) { +- str = str.split('\n').map(function(line) { +- return ' ' + line; +- }).join('\n').substr(2); +- } else { +- str = '\n' + str.split('\n').map(function(line) { +- return ' ' + line; +- }).join('\n'); +- } +- } +- } else { +- str = ctx.stylize('[Circular]', 'special'); +- } +- } +- if (isUndefined(name)) { +- if (array && key.match(/^\d+$/)) { +- return str; +- } +- name = JSON.stringify('' + key); +- if (name.match(/^"([a-zA-Z_][a-zA-Z_0-9]*)"$/)) { +- name = name.substr(1, name.length - 2); +- name = ctx.stylize(name, 'name'); +- } else { +- name = name.replace(/'/g, "\\'") +- .replace(/\\"/g, '"') +- .replace(/(^"|"$)/g, "'"); +- name = ctx.stylize(name, 'string'); +- } +- } +- +- return name + ': ' + str; +-} +- +- +-function reduceToSingleString(output, base, braces) { +- var numLinesEst = 0; +- var length = output.reduce(function(prev, cur) { +- numLinesEst++; +- if (cur.indexOf('\n') >= 0) numLinesEst++; +- return prev + cur.replace(/\u001b\[\d\d?m/g, '').length + 1; +- }, 0); +- +- if (length > 60) { +- return braces[0] + +- (base === '' ? '' : base + '\n ') + +- ' ' + +- output.join(',\n ') + +- ' ' + +- braces[1]; +- } +- +- return braces[0] + base + ' ' + output.join(', ') + ' ' + braces[1]; +-} +- +- + // NOTE: These type checking functions intentionally don't use `instanceof` + // because it is fragile and can be easily faked with `Object.create()`. + function isArray(ar) { +@@ -522,166 +98,10 @@ function isPrimitive(arg) { + exports.isPrimitive = isPrimitive; + + function isBuffer(arg) { +- return arg instanceof Buffer; ++ return Buffer.isBuffer(arg); + } + exports.isBuffer = isBuffer; + + function objectToString(o) { + return Object.prototype.toString.call(o); +-} +- +- +-function pad(n) { +- return n < 10 ? '0' + n.toString(10) : n.toString(10); +-} +- +- +-var months = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', +- 'Oct', 'Nov', 'Dec']; +- +-// 26 Feb 16:19:34 +-function timestamp() { +- var d = new Date(); +- var time = [pad(d.getHours()), +- pad(d.getMinutes()), +- pad(d.getSeconds())].join(':'); +- return [d.getDate(), months[d.getMonth()], time].join(' '); +-} +- +- +-// log is just a thin wrapper to console.log that prepends a timestamp +-exports.log = function() { +- console.log('%s - %s', timestamp(), exports.format.apply(exports, arguments)); +-}; +- +- +-/** +- * Inherit the prototype methods from one constructor into another. +- * +- * The Function.prototype.inherits from lang.js rewritten as a standalone +- * function (not on Function.prototype). NOTE: If this file is to be loaded +- * during bootstrapping this function needs to be rewritten using some native +- * functions as prototype setup using normal JavaScript does not work as +- * expected during bootstrapping (see mirror.js in r114903). +- * +- * @param {function} ctor Constructor function which needs to inherit the +- * prototype. +- * @param {function} superCtor Constructor function to inherit prototype from. +- */ +-exports.inherits = function(ctor, superCtor) { +- ctor.super_ = superCtor; +- ctor.prototype = Object.create(superCtor.prototype, { +- constructor: { +- value: ctor, +- enumerable: false, +- writable: true, +- configurable: true +- } +- }); +-}; +- +-exports._extend = function(origin, add) { +- // Don't do anything if add isn't an object +- if (!add || !isObject(add)) return origin; +- +- var keys = Object.keys(add); +- var i = keys.length; +- while (i--) { +- origin[keys[i]] = add[keys[i]]; +- } +- return origin; +-}; +- +-function hasOwnProperty(obj, prop) { +- return Object.prototype.hasOwnProperty.call(obj, prop); +-} +- +- +-// Deprecated old stuff. +- +-exports.p = exports.deprecate(function() { +- for (var i = 0, len = arguments.length; i < len; ++i) { +- console.error(exports.inspect(arguments[i])); +- } +-}, 'util.p: Use console.error() instead'); +- +- +-exports.exec = exports.deprecate(function() { +- return require('child_process').exec.apply(this, arguments); +-}, 'util.exec is now called `child_process.exec`.'); +- +- +-exports.print = exports.deprecate(function() { +- for (var i = 0, len = arguments.length; i < len; ++i) { +- process.stdout.write(String(arguments[i])); +- } +-}, 'util.print: Use console.log instead'); +- +- +-exports.puts = exports.deprecate(function() { +- for (var i = 0, len = arguments.length; i < len; ++i) { +- process.stdout.write(arguments[i] + '\n'); +- } +-}, 'util.puts: Use console.log instead'); +- +- +-exports.debug = exports.deprecate(function(x) { +- process.stderr.write('DEBUG: ' + x + '\n'); +-}, 'util.debug: Use console.error instead'); +- +- +-exports.error = exports.deprecate(function(x) { +- for (var i = 0, len = arguments.length; i < len; ++i) { +- process.stderr.write(arguments[i] + '\n'); +- } +-}, 'util.error: Use console.error instead'); +- +- +-exports.pump = exports.deprecate(function(readStream, writeStream, callback) { +- var callbackCalled = false; +- +- function call(a, b, c) { +- if (callback && !callbackCalled) { +- callback(a, b, c); +- callbackCalled = true; +- } +- } +- +- readStream.addListener('data', function(chunk) { +- if (writeStream.write(chunk) === false) readStream.pause(); +- }); +- +- writeStream.addListener('drain', function() { +- readStream.resume(); +- }); +- +- readStream.addListener('end', function() { +- writeStream.end(); +- }); +- +- readStream.addListener('close', function() { +- call(); +- }); +- +- readStream.addListener('error', function(err) { +- writeStream.end(); +- call(err); +- }); +- +- writeStream.addListener('error', function(err) { +- readStream.destroy(); +- call(err); +- }); +-}, 'util.pump(): Use readableStream.pipe() instead'); +- +- +-var uv; +-exports._errnoException = function(err, syscall) { +- if (isUndefined(uv)) uv = process.binding('uv'); +- var errname = uv.errname(err); +- var e = new Error(syscall + ' ' + errname); +- e.code = errname; +- e.errno = errname; +- e.syscall = syscall; +- return e; +-}; ++} \ No newline at end of file diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/core-util-is/lib/util.js b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/core-util-is/lib/util.js new file mode 100644 index 0000000..ff4c851 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/core-util-is/lib/util.js @@ -0,0 +1,107 @@ +// Copyright Joyent, Inc. and other Node contributors. +// +// Permission is hereby granted, free of charge, to any person obtaining a +// copy of this software and associated documentation files (the +// "Software"), to deal in the Software without restriction, including +// without limitation the rights to use, copy, modify, merge, publish, +// distribute, sublicense, and/or sell copies of the Software, and to permit +// persons to whom the Software is furnished to do so, subject to the +// following conditions: +// +// The above copyright notice and this permission notice shall be included +// in all copies or substantial portions of the Software. +// +// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS +// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN +// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, +// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR +// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE +// USE OR OTHER DEALINGS IN THE SOFTWARE. + +// NOTE: These type checking functions intentionally don't use `instanceof` +// because it is fragile and can be easily faked with `Object.create()`. + +function isArray(arg) { + if (Array.isArray) { + return Array.isArray(arg); + } + return objectToString(arg) === '[object Array]'; +} +exports.isArray = isArray; + +function isBoolean(arg) { + return typeof arg === 'boolean'; +} +exports.isBoolean = isBoolean; + +function isNull(arg) { + return arg === null; +} +exports.isNull = isNull; + +function isNullOrUndefined(arg) { + return arg == null; +} +exports.isNullOrUndefined = isNullOrUndefined; + +function isNumber(arg) { + return typeof arg === 'number'; +} +exports.isNumber = isNumber; + +function isString(arg) { + return typeof arg === 'string'; +} +exports.isString = isString; + +function isSymbol(arg) { + return typeof arg === 'symbol'; +} +exports.isSymbol = isSymbol; + +function isUndefined(arg) { + return arg === void 0; +} +exports.isUndefined = isUndefined; + +function isRegExp(re) { + return objectToString(re) === '[object RegExp]'; +} +exports.isRegExp = isRegExp; + +function isObject(arg) { + return typeof arg === 'object' && arg !== null; +} +exports.isObject = isObject; + +function isDate(d) { + return objectToString(d) === '[object Date]'; +} +exports.isDate = isDate; + +function isError(e) { + return (objectToString(e) === '[object Error]' || e instanceof Error); +} +exports.isError = isError; + +function isFunction(arg) { + return typeof arg === 'function'; +} +exports.isFunction = isFunction; + +function isPrimitive(arg) { + return arg === null || + typeof arg === 'boolean' || + typeof arg === 'number' || + typeof arg === 'string' || + typeof arg === 'symbol' || // ES6 symbol + typeof arg === 'undefined'; +} +exports.isPrimitive = isPrimitive; + +exports.isBuffer = Buffer.isBuffer; + +function objectToString(o) { + return Object.prototype.toString.call(o); +} diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/core-util-is/package.json b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/core-util-is/package.json new file mode 100644 index 0000000..30ba2df --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/core-util-is/package.json @@ -0,0 +1,60 @@ +{ + "name": "core-util-is", + "version": "1.0.2", + "description": "The `util.is*` functions introduced in Node v0.12.", + "main": "lib/util.js", + "repository": { + "type": "git", + "url": "git://github.com/isaacs/core-util-is.git" + }, + "keywords": [ + "util", + "isBuffer", + "isArray", + "isNumber", + "isString", + "isRegExp", + "isThis", + "isThat", + "polyfill" + ], + "author": { + "name": "Isaac Z. Schlueter", + "email": "i@izs.me", + "url": "http://blog.izs.me/" + }, + "license": "MIT", + "bugs": { + "url": "https://github.com/isaacs/core-util-is/issues" + }, + "scripts": { + "test": "tap test.js" + }, + "devDependencies": { + "tap": "^2.3.0" + }, + "gitHead": "a177da234df5638b363ddc15fa324619a38577c8", + "homepage": "https://github.com/isaacs/core-util-is#readme", + "_id": "core-util-is@1.0.2", + "_shasum": "b5fd54220aa2bc5ab57aab7140c940754503c1a7", + "_from": "core-util-is@>=1.0.0 <1.1.0", + "_npmVersion": "3.3.2", + "_nodeVersion": "4.0.0", + "_npmUser": { + "name": "isaacs", + "email": "i@izs.me" + }, + "dist": { + "shasum": "b5fd54220aa2bc5ab57aab7140c940754503c1a7", + "tarball": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz" + }, + "maintainers": [ + { + "name": "isaacs", + "email": "i@izs.me" + } + ], + "directories": {}, + "_resolved": "http://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/core-util-is/test.js b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/core-util-is/test.js new file mode 100644 index 0000000..1a490c6 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/core-util-is/test.js @@ -0,0 +1,68 @@ +var assert = require('tap'); + +var t = require('./lib/util'); + +assert.equal(t.isArray([]), true); +assert.equal(t.isArray({}), false); + +assert.equal(t.isBoolean(null), false); +assert.equal(t.isBoolean(true), true); +assert.equal(t.isBoolean(false), true); + +assert.equal(t.isNull(null), true); +assert.equal(t.isNull(undefined), false); +assert.equal(t.isNull(false), false); +assert.equal(t.isNull(), false); + +assert.equal(t.isNullOrUndefined(null), true); +assert.equal(t.isNullOrUndefined(undefined), true); +assert.equal(t.isNullOrUndefined(false), false); +assert.equal(t.isNullOrUndefined(), true); + +assert.equal(t.isNumber(null), false); +assert.equal(t.isNumber('1'), false); +assert.equal(t.isNumber(1), true); + +assert.equal(t.isString(null), false); +assert.equal(t.isString('1'), true); +assert.equal(t.isString(1), false); + +assert.equal(t.isSymbol(null), false); +assert.equal(t.isSymbol('1'), false); +assert.equal(t.isSymbol(1), false); +assert.equal(t.isSymbol(Symbol()), true); + +assert.equal(t.isUndefined(null), false); +assert.equal(t.isUndefined(undefined), true); +assert.equal(t.isUndefined(false), false); +assert.equal(t.isUndefined(), true); + +assert.equal(t.isRegExp(null), false); +assert.equal(t.isRegExp('1'), false); +assert.equal(t.isRegExp(new RegExp()), true); + +assert.equal(t.isObject({}), true); +assert.equal(t.isObject([]), true); +assert.equal(t.isObject(new RegExp()), true); +assert.equal(t.isObject(new Date()), true); + +assert.equal(t.isDate(null), false); +assert.equal(t.isDate('1'), false); +assert.equal(t.isDate(new Date()), true); + +assert.equal(t.isError(null), false); +assert.equal(t.isError({ err: true }), false); +assert.equal(t.isError(new Error()), true); + +assert.equal(t.isFunction(null), false); +assert.equal(t.isFunction({ }), false); +assert.equal(t.isFunction(function() {}), true); + +assert.equal(t.isPrimitive(null), true); +assert.equal(t.isPrimitive(''), true); +assert.equal(t.isPrimitive(0), true); +assert.equal(t.isPrimitive(new Date()), false); + +assert.equal(t.isBuffer(null), false); +assert.equal(t.isBuffer({}), false); +assert.equal(t.isBuffer(new Buffer(0)), true); diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/inherits/LICENSE b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/inherits/LICENSE new file mode 100644 index 0000000..dea3013 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/inherits/LICENSE @@ -0,0 +1,16 @@ +The ISC License + +Copyright (c) Isaac Z. Schlueter + +Permission to use, copy, modify, and/or distribute this software for any +purpose with or without fee is hereby granted, provided that the above +copyright notice and this permission notice appear in all copies. + +THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH +REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND +FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, +INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM +LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR +OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR +PERFORMANCE OF THIS SOFTWARE. + diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/inherits/README.md b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/inherits/README.md new file mode 100644 index 0000000..b1c5665 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/inherits/README.md @@ -0,0 +1,42 @@ +Browser-friendly inheritance fully compatible with standard node.js +[inherits](http://nodejs.org/api/util.html#util_util_inherits_constructor_superconstructor). + +This package exports standard `inherits` from node.js `util` module in +node environment, but also provides alternative browser-friendly +implementation through [browser +field](https://gist.github.com/shtylman/4339901). Alternative +implementation is a literal copy of standard one located in standalone +module to avoid requiring of `util`. It also has a shim for old +browsers with no `Object.create` support. + +While keeping you sure you are using standard `inherits` +implementation in node.js environment, it allows bundlers such as +[browserify](https://github.com/substack/node-browserify) to not +include full `util` package to your client code if all you need is +just `inherits` function. It worth, because browser shim for `util` +package is large and `inherits` is often the single function you need +from it. + +It's recommended to use this package instead of +`require('util').inherits` for any code that has chances to be used +not only in node.js but in browser too. + +## usage + +```js +var inherits = require('inherits'); +// then use exactly as the standard one +``` + +## note on version ~1.0 + +Version ~1.0 had completely different motivation and is not compatible +neither with 2.0 nor with standard node.js `inherits`. + +If you are using version ~1.0 and planning to switch to ~2.0, be +careful: + +* new version uses `super_` instead of `super` for referencing + superclass +* new version overwrites current prototype while old one preserves any + existing fields on it diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/inherits/inherits.js b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/inherits/inherits.js new file mode 100644 index 0000000..3b94763 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/inherits/inherits.js @@ -0,0 +1,7 @@ +try { + var util = require('util'); + if (typeof util.inherits !== 'function') throw ''; + module.exports = util.inherits; +} catch (e) { + module.exports = require('./inherits_browser.js'); +} diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/inherits/inherits_browser.js b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/inherits/inherits_browser.js new file mode 100644 index 0000000..c1e78a7 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/inherits/inherits_browser.js @@ -0,0 +1,23 @@ +if (typeof Object.create === 'function') { + // implementation from standard node.js 'util' module + module.exports = function inherits(ctor, superCtor) { + ctor.super_ = superCtor + ctor.prototype = Object.create(superCtor.prototype, { + constructor: { + value: ctor, + enumerable: false, + writable: true, + configurable: true + } + }); + }; +} else { + // old school shim for old browsers + module.exports = function inherits(ctor, superCtor) { + ctor.super_ = superCtor + var TempCtor = function () {} + TempCtor.prototype = superCtor.prototype + ctor.prototype = new TempCtor() + ctor.prototype.constructor = ctor + } +} diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/inherits/package.json b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/inherits/package.json new file mode 100644 index 0000000..0437378 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/inherits/package.json @@ -0,0 +1,63 @@ +{ + "name": "inherits", + "description": "Browser-friendly inheritance fully compatible with standard node.js inherits()", + "version": "2.0.3", + "keywords": [ + "inheritance", + "class", + "klass", + "oop", + "object-oriented", + "inherits", + "browser", + "browserify" + ], + "main": "./inherits.js", + "browser": "./inherits_browser.js", + "repository": { + "type": "git", + "url": "git://github.com/isaacs/inherits.git" + }, + "license": "ISC", + "scripts": { + "test": "node test" + }, + "devDependencies": { + "tap": "^7.1.0" + }, + "files": [ + "inherits.js", + "inherits_browser.js" + ], + "gitHead": "e05d0fb27c61a3ec687214f0476386b765364d5f", + "bugs": { + "url": "https://github.com/isaacs/inherits/issues" + }, + "homepage": "https://github.com/isaacs/inherits#readme", + "_id": "inherits@2.0.3", + "_shasum": "633c2c83e3da42a502f52466022480f4208261de", + "_from": "inherits@>=2.0.1 <2.1.0", + "_npmVersion": "3.10.7", + "_nodeVersion": "6.5.0", + "_npmUser": { + "name": "isaacs", + "email": "i@izs.me" + }, + "dist": { + "shasum": "633c2c83e3da42a502f52466022480f4208261de", + "tarball": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz" + }, + "maintainers": [ + { + "name": "isaacs", + "email": "i@izs.me" + } + ], + "_npmOperationalInternal": { + "host": "packages-16-east.internal.npmjs.com", + "tmp": "tmp/inherits-2.0.3.tgz_1473295776489_0.08142363070510328" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/isarray/.npmignore b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/isarray/.npmignore new file mode 100644 index 0000000..3c3629e --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/isarray/.npmignore @@ -0,0 +1 @@ +node_modules diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/isarray/.travis.yml b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/isarray/.travis.yml new file mode 100644 index 0000000..cc4dba2 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/isarray/.travis.yml @@ -0,0 +1,4 @@ +language: node_js +node_js: + - "0.8" + - "0.10" diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/isarray/Makefile b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/isarray/Makefile new file mode 100644 index 0000000..787d56e --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/isarray/Makefile @@ -0,0 +1,6 @@ + +test: + @node_modules/.bin/tape test.js + +.PHONY: test + diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/isarray/README.md b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/isarray/README.md new file mode 100644 index 0000000..16d2c59 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/isarray/README.md @@ -0,0 +1,60 @@ + +# isarray + +`Array#isArray` for older browsers. + +[![build status](https://secure.travis-ci.org/juliangruber/isarray.svg)](http://travis-ci.org/juliangruber/isarray) +[![downloads](https://img.shields.io/npm/dm/isarray.svg)](https://www.npmjs.org/package/isarray) + +[![browser support](https://ci.testling.com/juliangruber/isarray.png) +](https://ci.testling.com/juliangruber/isarray) + +## Usage + +```js +var isArray = require('isarray'); + +console.log(isArray([])); // => true +console.log(isArray({})); // => false +``` + +## Installation + +With [npm](http://npmjs.org) do + +```bash +$ npm install isarray +``` + +Then bundle for the browser with +[browserify](https://github.com/substack/browserify). + +With [component](http://component.io) do + +```bash +$ component install juliangruber/isarray +``` + +## License + +(MIT) + +Copyright (c) 2013 Julian Gruber <julian@juliangruber.com> + +Permission is hereby granted, free of charge, to any person obtaining a copy of +this software and associated documentation files (the "Software"), to deal in +the Software without restriction, including without limitation the rights to +use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies +of the Software, and to permit persons to whom the Software is furnished to do +so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/isarray/component.json b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/isarray/component.json new file mode 100644 index 0000000..9e31b68 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/isarray/component.json @@ -0,0 +1,19 @@ +{ + "name" : "isarray", + "description" : "Array#isArray for older browsers", + "version" : "0.0.1", + "repository" : "juliangruber/isarray", + "homepage": "https://github.com/juliangruber/isarray", + "main" : "index.js", + "scripts" : [ + "index.js" + ], + "dependencies" : {}, + "keywords": ["browser","isarray","array"], + "author": { + "name": "Julian Gruber", + "email": "mail@juliangruber.com", + "url": "http://juliangruber.com" + }, + "license": "MIT" +} diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/isarray/index.js b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/isarray/index.js new file mode 100644 index 0000000..a57f634 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/isarray/index.js @@ -0,0 +1,5 @@ +var toString = {}.toString; + +module.exports = Array.isArray || function (arr) { + return toString.call(arr) == '[object Array]'; +}; diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/isarray/package.json b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/isarray/package.json new file mode 100644 index 0000000..ab1a8b4 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/isarray/package.json @@ -0,0 +1,71 @@ +{ + "name": "isarray", + "description": "Array#isArray for older browsers", + "version": "1.0.0", + "repository": { + "type": "git", + "url": "git://github.com/juliangruber/isarray.git" + }, + "homepage": "https://github.com/juliangruber/isarray", + "main": "index.js", + "dependencies": {}, + "devDependencies": { + "tape": "~2.13.4" + }, + "keywords": [ + "browser", + "isarray", + "array" + ], + "author": { + "name": "Julian Gruber", + "email": "mail@juliangruber.com", + "url": "http://juliangruber.com" + }, + "license": "MIT", + "testling": { + "files": "test.js", + "browsers": [ + "ie/8..latest", + "firefox/17..latest", + "firefox/nightly", + "chrome/22..latest", + "chrome/canary", + "opera/12..latest", + "opera/next", + "safari/5.1..latest", + "ipad/6.0..latest", + "iphone/6.0..latest", + "android-browser/4.2..latest" + ] + }, + "scripts": { + "test": "tape test.js" + }, + "gitHead": "2a23a281f369e9ae06394c0fb4d2381355a6ba33", + "bugs": { + "url": "https://github.com/juliangruber/isarray/issues" + }, + "_id": "isarray@1.0.0", + "_shasum": "bb935d48582cba168c06834957a54a3e07124f11", + "_from": "isarray@>=1.0.0 <1.1.0", + "_npmVersion": "3.3.12", + "_nodeVersion": "5.1.0", + "_npmUser": { + "name": "juliangruber", + "email": "julian@juliangruber.com" + }, + "dist": { + "shasum": "bb935d48582cba168c06834957a54a3e07124f11", + "tarball": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz" + }, + "maintainers": [ + { + "name": "juliangruber", + "email": "julian@juliangruber.com" + } + ], + "directories": {}, + "_resolved": "http://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/isarray/test.js b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/isarray/test.js new file mode 100644 index 0000000..e0c3444 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/isarray/test.js @@ -0,0 +1,20 @@ +var isArray = require('./'); +var test = require('tape'); + +test('is array', function(t){ + t.ok(isArray([])); + t.notOk(isArray({})); + t.notOk(isArray(null)); + t.notOk(isArray(false)); + + var obj = {}; + obj[0] = true; + t.notOk(isArray(obj)); + + var arr = []; + arr.foo = 'bar'; + t.ok(isArray(arr)); + + t.end(); +}); + diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/process-nextick-args/.travis.yml b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/process-nextick-args/.travis.yml new file mode 100644 index 0000000..36201b1 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/process-nextick-args/.travis.yml @@ -0,0 +1,12 @@ +language: node_js +node_js: + - "0.8" + - "0.10" + - "0.11" + - "0.12" + - "1.7.1" + - 1 + - 2 + - 3 + - 4 + - 5 diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/process-nextick-args/index.js b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/process-nextick-args/index.js new file mode 100644 index 0000000..a4f40f8 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/process-nextick-args/index.js @@ -0,0 +1,43 @@ +'use strict'; + +if (!process.version || + process.version.indexOf('v0.') === 0 || + process.version.indexOf('v1.') === 0 && process.version.indexOf('v1.8.') !== 0) { + module.exports = nextTick; +} else { + module.exports = process.nextTick; +} + +function nextTick(fn, arg1, arg2, arg3) { + if (typeof fn !== 'function') { + throw new TypeError('"callback" argument must be a function'); + } + var len = arguments.length; + var args, i; + switch (len) { + case 0: + case 1: + return process.nextTick(fn); + case 2: + return process.nextTick(function afterTickOne() { + fn.call(null, arg1); + }); + case 3: + return process.nextTick(function afterTickTwo() { + fn.call(null, arg1, arg2); + }); + case 4: + return process.nextTick(function afterTickThree() { + fn.call(null, arg1, arg2, arg3); + }); + default: + args = new Array(len - 1); + i = 0; + while (i < args.length) { + args[i++] = arguments[i]; + } + return process.nextTick(function afterTick() { + fn.apply(null, args); + }); + } +} diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/process-nextick-args/license.md b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/process-nextick-args/license.md new file mode 100644 index 0000000..c67e353 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/process-nextick-args/license.md @@ -0,0 +1,19 @@ +# Copyright (c) 2015 Calvin Metcalf + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +**THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE.** diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/process-nextick-args/package.json b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/process-nextick-args/package.json new file mode 100644 index 0000000..595b7c8 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/process-nextick-args/package.json @@ -0,0 +1,49 @@ +{ + "name": "process-nextick-args", + "version": "1.0.7", + "description": "process.nextTick but always with args", + "main": "index.js", + "scripts": { + "test": "node test.js" + }, + "repository": { + "type": "git", + "url": "git+https://github.com/calvinmetcalf/process-nextick-args.git" + }, + "author": "", + "license": "MIT", + "bugs": { + "url": "https://github.com/calvinmetcalf/process-nextick-args/issues" + }, + "homepage": "https://github.com/calvinmetcalf/process-nextick-args", + "devDependencies": { + "tap": "~0.2.6" + }, + "gitHead": "5c00899ab01dd32f93ad4b5743da33da91404f39", + "_id": "process-nextick-args@1.0.7", + "_shasum": "150e20b756590ad3f91093f25a4f2ad8bff30ba3", + "_from": "process-nextick-args@>=1.0.6 <1.1.0", + "_npmVersion": "3.8.6", + "_nodeVersion": "5.11.0", + "_npmUser": { + "name": "cwmma", + "email": "calvin.metcalf@gmail.com" + }, + "dist": { + "shasum": "150e20b756590ad3f91093f25a4f2ad8bff30ba3", + "tarball": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-1.0.7.tgz" + }, + "maintainers": [ + { + "name": "cwmma", + "email": "calvin.metcalf@gmail.com" + } + ], + "_npmOperationalInternal": { + "host": "packages-12-west.internal.npmjs.com", + "tmp": "tmp/process-nextick-args-1.0.7.tgz_1462394251778_0.36989671061746776" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/process-nextick-args/-/process-nextick-args-1.0.7.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/process-nextick-args/readme.md b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/process-nextick-args/readme.md new file mode 100644 index 0000000..78e7cfa --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/process-nextick-args/readme.md @@ -0,0 +1,18 @@ +process-nextick-args +===== + +[![Build Status](https://travis-ci.org/calvinmetcalf/process-nextick-args.svg?branch=master)](https://travis-ci.org/calvinmetcalf/process-nextick-args) + +```bash +npm install --save process-nextick-args +``` + +Always be able to pass arguments to process.nextTick, no matter the platform + +```js +var nextTick = require('process-nextick-args'); + +nextTick(function (a, b, c) { + console.log(a, b, c); +}, 'step', 3, 'profit'); +``` diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/process-nextick-args/test.js b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/process-nextick-args/test.js new file mode 100644 index 0000000..ef15721 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/process-nextick-args/test.js @@ -0,0 +1,24 @@ +var test = require("tap").test; +var nextTick = require('./'); + +test('should work', function (t) { + t.plan(5); + nextTick(function (a) { + t.ok(a); + nextTick(function (thing) { + t.equals(thing, 7); + }, 7); + }, true); + nextTick(function (a, b, c) { + t.equals(a, 'step'); + t.equals(b, 3); + t.equals(c, 'profit'); + }, 'step', 3, 'profit'); +}); + +test('correct number of arguments', function (t) { + t.plan(1); + nextTick(function () { + t.equals(2, arguments.length, 'correct number'); + }, 1, 2); +}); diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/string_decoder/.npmignore b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/string_decoder/.npmignore new file mode 100644 index 0000000..206320c --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/string_decoder/.npmignore @@ -0,0 +1,2 @@ +build +test diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/string_decoder/LICENSE b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/string_decoder/LICENSE new file mode 100644 index 0000000..6de584a --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/string_decoder/LICENSE @@ -0,0 +1,20 @@ +Copyright Joyent, Inc. and other Node contributors. + +Permission is hereby granted, free of charge, to any person obtaining a +copy of this software and associated documentation files (the +"Software"), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to permit +persons to whom the Software is furnished to do so, subject to the +following conditions: + +The above copyright notice and this permission notice shall be included +in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS +OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN +NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, +DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR +OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE +USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/string_decoder/README.md b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/string_decoder/README.md new file mode 100644 index 0000000..4d2aa00 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/string_decoder/README.md @@ -0,0 +1,7 @@ +**string_decoder.js** (`require('string_decoder')`) from Node.js core + +Copyright Joyent, Inc. and other Node contributors. See LICENCE file for details. + +Version numbers match the versions found in Node core, e.g. 0.10.24 matches Node 0.10.24, likewise 0.11.10 matches Node 0.11.10. **Prefer the stable version over the unstable.** + +The *build/* directory contains a build script that will scrape the source from the [joyent/node](https://github.com/joyent/node) repo given a specific Node version. \ No newline at end of file diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/string_decoder/index.js b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/string_decoder/index.js new file mode 100644 index 0000000..b00e54f --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/string_decoder/index.js @@ -0,0 +1,221 @@ +// Copyright Joyent, Inc. and other Node contributors. +// +// Permission is hereby granted, free of charge, to any person obtaining a +// copy of this software and associated documentation files (the +// "Software"), to deal in the Software without restriction, including +// without limitation the rights to use, copy, modify, merge, publish, +// distribute, sublicense, and/or sell copies of the Software, and to permit +// persons to whom the Software is furnished to do so, subject to the +// following conditions: +// +// The above copyright notice and this permission notice shall be included +// in all copies or substantial portions of the Software. +// +// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS +// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN +// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, +// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR +// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE +// USE OR OTHER DEALINGS IN THE SOFTWARE. + +var Buffer = require('buffer').Buffer; + +var isBufferEncoding = Buffer.isEncoding + || function(encoding) { + switch (encoding && encoding.toLowerCase()) { + case 'hex': case 'utf8': case 'utf-8': case 'ascii': case 'binary': case 'base64': case 'ucs2': case 'ucs-2': case 'utf16le': case 'utf-16le': case 'raw': return true; + default: return false; + } + } + + +function assertEncoding(encoding) { + if (encoding && !isBufferEncoding(encoding)) { + throw new Error('Unknown encoding: ' + encoding); + } +} + +// StringDecoder provides an interface for efficiently splitting a series of +// buffers into a series of JS strings without breaking apart multi-byte +// characters. CESU-8 is handled as part of the UTF-8 encoding. +// +// @TODO Handling all encodings inside a single object makes it very difficult +// to reason about this code, so it should be split up in the future. +// @TODO There should be a utf8-strict encoding that rejects invalid UTF-8 code +// points as used by CESU-8. +var StringDecoder = exports.StringDecoder = function(encoding) { + this.encoding = (encoding || 'utf8').toLowerCase().replace(/[-_]/, ''); + assertEncoding(encoding); + switch (this.encoding) { + case 'utf8': + // CESU-8 represents each of Surrogate Pair by 3-bytes + this.surrogateSize = 3; + break; + case 'ucs2': + case 'utf16le': + // UTF-16 represents each of Surrogate Pair by 2-bytes + this.surrogateSize = 2; + this.detectIncompleteChar = utf16DetectIncompleteChar; + break; + case 'base64': + // Base-64 stores 3 bytes in 4 chars, and pads the remainder. + this.surrogateSize = 3; + this.detectIncompleteChar = base64DetectIncompleteChar; + break; + default: + this.write = passThroughWrite; + return; + } + + // Enough space to store all bytes of a single character. UTF-8 needs 4 + // bytes, but CESU-8 may require up to 6 (3 bytes per surrogate). + this.charBuffer = new Buffer(6); + // Number of bytes received for the current incomplete multi-byte character. + this.charReceived = 0; + // Number of bytes expected for the current incomplete multi-byte character. + this.charLength = 0; +}; + + +// write decodes the given buffer and returns it as JS string that is +// guaranteed to not contain any partial multi-byte characters. Any partial +// character found at the end of the buffer is buffered up, and will be +// returned when calling write again with the remaining bytes. +// +// Note: Converting a Buffer containing an orphan surrogate to a String +// currently works, but converting a String to a Buffer (via `new Buffer`, or +// Buffer#write) will replace incomplete surrogates with the unicode +// replacement character. See https://codereview.chromium.org/121173009/ . +StringDecoder.prototype.write = function(buffer) { + var charStr = ''; + // if our last write ended with an incomplete multibyte character + while (this.charLength) { + // determine how many remaining bytes this buffer has to offer for this char + var available = (buffer.length >= this.charLength - this.charReceived) ? + this.charLength - this.charReceived : + buffer.length; + + // add the new bytes to the char buffer + buffer.copy(this.charBuffer, this.charReceived, 0, available); + this.charReceived += available; + + if (this.charReceived < this.charLength) { + // still not enough chars in this buffer? wait for more ... + return ''; + } + + // remove bytes belonging to the current character from the buffer + buffer = buffer.slice(available, buffer.length); + + // get the character that was split + charStr = this.charBuffer.slice(0, this.charLength).toString(this.encoding); + + // CESU-8: lead surrogate (D800-DBFF) is also the incomplete character + var charCode = charStr.charCodeAt(charStr.length - 1); + if (charCode >= 0xD800 && charCode <= 0xDBFF) { + this.charLength += this.surrogateSize; + charStr = ''; + continue; + } + this.charReceived = this.charLength = 0; + + // if there are no more bytes in this buffer, just emit our char + if (buffer.length === 0) { + return charStr; + } + break; + } + + // determine and set charLength / charReceived + this.detectIncompleteChar(buffer); + + var end = buffer.length; + if (this.charLength) { + // buffer the incomplete character bytes we got + buffer.copy(this.charBuffer, 0, buffer.length - this.charReceived, end); + end -= this.charReceived; + } + + charStr += buffer.toString(this.encoding, 0, end); + + var end = charStr.length - 1; + var charCode = charStr.charCodeAt(end); + // CESU-8: lead surrogate (D800-DBFF) is also the incomplete character + if (charCode >= 0xD800 && charCode <= 0xDBFF) { + var size = this.surrogateSize; + this.charLength += size; + this.charReceived += size; + this.charBuffer.copy(this.charBuffer, size, 0, size); + buffer.copy(this.charBuffer, 0, 0, size); + return charStr.substring(0, end); + } + + // or just emit the charStr + return charStr; +}; + +// detectIncompleteChar determines if there is an incomplete UTF-8 character at +// the end of the given buffer. If so, it sets this.charLength to the byte +// length that character, and sets this.charReceived to the number of bytes +// that are available for this character. +StringDecoder.prototype.detectIncompleteChar = function(buffer) { + // determine how many bytes we have to check at the end of this buffer + var i = (buffer.length >= 3) ? 3 : buffer.length; + + // Figure out if one of the last i bytes of our buffer announces an + // incomplete char. + for (; i > 0; i--) { + var c = buffer[buffer.length - i]; + + // See http://en.wikipedia.org/wiki/UTF-8#Description + + // 110XXXXX + if (i == 1 && c >> 5 == 0x06) { + this.charLength = 2; + break; + } + + // 1110XXXX + if (i <= 2 && c >> 4 == 0x0E) { + this.charLength = 3; + break; + } + + // 11110XXX + if (i <= 3 && c >> 3 == 0x1E) { + this.charLength = 4; + break; + } + } + this.charReceived = i; +}; + +StringDecoder.prototype.end = function(buffer) { + var res = ''; + if (buffer && buffer.length) + res = this.write(buffer); + + if (this.charReceived) { + var cr = this.charReceived; + var buf = this.charBuffer; + var enc = this.encoding; + res += buf.slice(0, cr).toString(enc); + } + + return res; +}; + +function passThroughWrite(buffer) { + return buffer.toString(this.encoding); +} + +function utf16DetectIncompleteChar(buffer) { + this.charReceived = buffer.length % 2; + this.charLength = this.charReceived ? 2 : 0; +} + +function base64DetectIncompleteChar(buffer) { + this.charReceived = buffer.length % 3; + this.charLength = this.charReceived ? 3 : 0; +} diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/string_decoder/package.json b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/string_decoder/package.json new file mode 100644 index 0000000..b67f456 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/string_decoder/package.json @@ -0,0 +1,54 @@ +{ + "name": "string_decoder", + "version": "0.10.31", + "description": "The string_decoder module from Node core", + "main": "index.js", + "dependencies": {}, + "devDependencies": { + "tap": "~0.4.8" + }, + "scripts": { + "test": "tap test/simple/*.js" + }, + "repository": { + "type": "git", + "url": "git://github.com/rvagg/string_decoder.git" + }, + "homepage": "https://github.com/rvagg/string_decoder", + "keywords": [ + "string", + "decoder", + "browser", + "browserify" + ], + "license": "MIT", + "gitHead": "d46d4fd87cf1d06e031c23f1ba170ca7d4ade9a0", + "bugs": { + "url": "https://github.com/rvagg/string_decoder/issues" + }, + "_id": "string_decoder@0.10.31", + "_shasum": "62e203bc41766c6c28c9fc84301dab1c5310fa94", + "_from": "string_decoder@>=0.10.0 <0.11.0", + "_npmVersion": "1.4.23", + "_npmUser": { + "name": "rvagg", + "email": "rod@vagg.org" + }, + "maintainers": [ + { + "name": "substack", + "email": "mail@substack.net" + }, + { + "name": "rvagg", + "email": "rod@vagg.org" + } + ], + "dist": { + "shasum": "62e203bc41766c6c28c9fc84301dab1c5310fa94", + "tarball": "https://registry.npmjs.org/string_decoder/-/string_decoder-0.10.31.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/string_decoder/-/string_decoder-0.10.31.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/util-deprecate/History.md b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/util-deprecate/History.md new file mode 100644 index 0000000..acc8675 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/util-deprecate/History.md @@ -0,0 +1,16 @@ + +1.0.2 / 2015-10-07 +================== + + * use try/catch when checking `localStorage` (#3, @kumavis) + +1.0.1 / 2014-11-25 +================== + + * browser: use `console.warn()` for deprecation calls + * browser: more jsdocs + +1.0.0 / 2014-04-30 +================== + + * initial commit diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/util-deprecate/LICENSE b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/util-deprecate/LICENSE new file mode 100644 index 0000000..6a60e8c --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/util-deprecate/LICENSE @@ -0,0 +1,24 @@ +(The MIT License) + +Copyright (c) 2014 Nathan Rajlich + +Permission is hereby granted, free of charge, to any person +obtaining a copy of this software and associated documentation +files (the "Software"), to deal in the Software without +restriction, including without limitation the rights to use, +copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the +Software is furnished to do so, subject to the following +conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES +OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND +NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT +HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, +WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING +FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR +OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/util-deprecate/README.md b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/util-deprecate/README.md new file mode 100644 index 0000000..75622fa --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/util-deprecate/README.md @@ -0,0 +1,53 @@ +util-deprecate +============== +### The Node.js `util.deprecate()` function with browser support + +In Node.js, this module simply re-exports the `util.deprecate()` function. + +In the web browser (i.e. via browserify), a browser-specific implementation +of the `util.deprecate()` function is used. + + +## API + +A `deprecate()` function is the only thing exposed by this module. + +``` javascript +// setup: +exports.foo = deprecate(foo, 'foo() is deprecated, use bar() instead'); + + +// users see: +foo(); +// foo() is deprecated, use bar() instead +foo(); +foo(); +``` + + +## License + +(The MIT License) + +Copyright (c) 2014 Nathan Rajlich + +Permission is hereby granted, free of charge, to any person +obtaining a copy of this software and associated documentation +files (the "Software"), to deal in the Software without +restriction, including without limitation the rights to use, +copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the +Software is furnished to do so, subject to the following +conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES +OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND +NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT +HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, +WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING +FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR +OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/util-deprecate/browser.js b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/util-deprecate/browser.js new file mode 100644 index 0000000..549ae2f --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/util-deprecate/browser.js @@ -0,0 +1,67 @@ + +/** + * Module exports. + */ + +module.exports = deprecate; + +/** + * Mark that a method should not be used. + * Returns a modified function which warns once by default. + * + * If `localStorage.noDeprecation = true` is set, then it is a no-op. + * + * If `localStorage.throwDeprecation = true` is set, then deprecated functions + * will throw an Error when invoked. + * + * If `localStorage.traceDeprecation = true` is set, then deprecated functions + * will invoke `console.trace()` instead of `console.error()`. + * + * @param {Function} fn - the function to deprecate + * @param {String} msg - the string to print to the console when `fn` is invoked + * @returns {Function} a new "deprecated" version of `fn` + * @api public + */ + +function deprecate (fn, msg) { + if (config('noDeprecation')) { + return fn; + } + + var warned = false; + function deprecated() { + if (!warned) { + if (config('throwDeprecation')) { + throw new Error(msg); + } else if (config('traceDeprecation')) { + console.trace(msg); + } else { + console.warn(msg); + } + warned = true; + } + return fn.apply(this, arguments); + } + + return deprecated; +} + +/** + * Checks `localStorage` for boolean values for the given `name`. + * + * @param {String} name + * @returns {Boolean} + * @api private + */ + +function config (name) { + // accessing global.localStorage can trigger a DOMException in sandboxed iframes + try { + if (!global.localStorage) return false; + } catch (_) { + return false; + } + var val = global.localStorage[name]; + if (null == val) return false; + return String(val).toLowerCase() === 'true'; +} diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/util-deprecate/node.js b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/util-deprecate/node.js new file mode 100644 index 0000000..5e6fcff --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/util-deprecate/node.js @@ -0,0 +1,6 @@ + +/** + * For Node.js, simply re-export the core `util.deprecate` function. + */ + +module.exports = require('util').deprecate; diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/util-deprecate/package.json b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/util-deprecate/package.json new file mode 100644 index 0000000..7258e73 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/node_modules/util-deprecate/package.json @@ -0,0 +1,54 @@ +{ + "name": "util-deprecate", + "version": "1.0.2", + "description": "The Node.js `util.deprecate()` function with browser support", + "main": "node.js", + "browser": "browser.js", + "scripts": { + "test": "echo \"Error: no test specified\" && exit 1" + }, + "repository": { + "type": "git", + "url": "git://github.com/TooTallNate/util-deprecate.git" + }, + "keywords": [ + "util", + "deprecate", + "browserify", + "browser", + "node" + ], + "author": { + "name": "Nathan Rajlich", + "email": "nathan@tootallnate.net", + "url": "http://n8.io/" + }, + "license": "MIT", + "bugs": { + "url": "https://github.com/TooTallNate/util-deprecate/issues" + }, + "homepage": "https://github.com/TooTallNate/util-deprecate", + "gitHead": "475fb6857cd23fafff20c1be846c1350abf8e6d4", + "_id": "util-deprecate@1.0.2", + "_shasum": "450d4dc9fa70de732762fbd2d4a28981419a0ccf", + "_from": "util-deprecate@>=1.0.1 <1.1.0", + "_npmVersion": "2.14.4", + "_nodeVersion": "4.1.2", + "_npmUser": { + "name": "tootallnate", + "email": "nathan@tootallnate.net" + }, + "maintainers": [ + { + "name": "tootallnate", + "email": "nathan@tootallnate.net" + } + ], + "dist": { + "shasum": "450d4dc9fa70de732762fbd2d4a28981419a0ccf", + "tarball": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/package.json b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/package.json new file mode 100644 index 0000000..8d91edc --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/package.json @@ -0,0 +1,92 @@ +{ + "name": "readable-stream", + "version": "2.1.5", + "description": "Streams3, a user-land copy of the stream library from Node.js", + "main": "readable.js", + "dependencies": { + "buffer-shims": "^1.0.0", + "core-util-is": "~1.0.0", + "inherits": "~2.0.1", + "isarray": "~1.0.0", + "process-nextick-args": "~1.0.6", + "string_decoder": "~0.10.x", + "util-deprecate": "~1.0.1" + }, + "devDependencies": { + "assert": "~1.4.0", + "babel-polyfill": "^6.9.1", + "nyc": "^6.4.0", + "tap": "~0.7.1", + "tape": "~4.5.1", + "zuul": "~3.10.0" + }, + "scripts": { + "test": "tap test/parallel/*.js test/ours/*.js", + "browser": "npm run write-zuul && zuul --browser-retries 2 -- test/browser.js", + "write-zuul": "printf \"ui: tape\nbrowsers:\n - name: $BROWSER_NAME\n version: $BROWSER_VERSION\n\">.zuul.yml", + "local": "zuul --local 3000 --no-coverage -- test/browser.js", + "cover": "nyc npm test", + "report": "nyc report --reporter=lcov" + }, + "repository": { + "type": "git", + "url": "git://github.com/nodejs/readable-stream.git" + }, + "keywords": [ + "readable", + "stream", + "pipe" + ], + "browser": { + "util": false + }, + "nyc": { + "include": [ + "lib/**.js" + ] + }, + "license": "MIT", + "gitHead": "758c8b3845af855fde736b6a7f58a15fba00d1e7", + "bugs": { + "url": "https://github.com/nodejs/readable-stream/issues" + }, + "_id": "readable-stream@2.1.5", + "_shasum": "66fa8b720e1438b364681f2ad1a63c618448c9d0", + "_from": "readable-stream@>=2.0.2 <3.0.0", + "_npmVersion": "3.8.6", + "_nodeVersion": "5.12.0", + "_npmUser": { + "name": "cwmma", + "email": "calvin.metcalf@gmail.com" + }, + "dist": { + "shasum": "66fa8b720e1438b364681f2ad1a63c618448c9d0", + "tarball": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.1.5.tgz" + }, + "maintainers": [ + { + "name": "isaacs", + "email": "isaacs@npmjs.com" + }, + { + "name": "tootallnate", + "email": "nathan@tootallnate.net" + }, + { + "name": "rvagg", + "email": "rod@vagg.org" + }, + { + "name": "cwmma", + "email": "calvin.metcalf@gmail.com" + } + ], + "_npmOperationalInternal": { + "host": "packages-16-east.internal.npmjs.com", + "tmp": "tmp/readable-stream-2.1.5.tgz_1471463532993_0.15824943827465177" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/readable-stream/-/readable-stream-2.1.5.tgz", + "readme": "ERROR: No README data found!", + "homepage": "https://github.com/nodejs/readable-stream#readme" +} diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/passthrough.js b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/passthrough.js new file mode 100644 index 0000000..27e8d8a --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/passthrough.js @@ -0,0 +1 @@ +module.exports = require("./lib/_stream_passthrough.js") diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/readable.js b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/readable.js new file mode 100644 index 0000000..be2688a --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/readable.js @@ -0,0 +1,16 @@ +var Stream = (function (){ + try { + return require('st' + 'ream'); // hack to fix a circular dependency issue when used with browserify + } catch(_){} +}()); +exports = module.exports = require('./lib/_stream_readable.js'); +exports.Stream = Stream || exports; +exports.Readable = exports; +exports.Writable = require('./lib/_stream_writable.js'); +exports.Duplex = require('./lib/_stream_duplex.js'); +exports.Transform = require('./lib/_stream_transform.js'); +exports.PassThrough = require('./lib/_stream_passthrough.js'); + +if (!process.browser && process.env.READABLE_STREAM === 'disable' && Stream) { + module.exports = Stream; +} diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/transform.js b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/transform.js new file mode 100644 index 0000000..5d482f0 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/transform.js @@ -0,0 +1 @@ +module.exports = require("./lib/_stream_transform.js") diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/writable.js b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/writable.js new file mode 100644 index 0000000..e1e9efd --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/node_modules/readable-stream/writable.js @@ -0,0 +1 @@ +module.exports = require("./lib/_stream_writable.js") diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/package.json b/node_modules/rtsp-server/node_modules/rtsp-stream/package.json new file mode 100644 index 0000000..7eb6ea1 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/package.json @@ -0,0 +1,76 @@ +{ + "name": "rtsp-stream", + "version": "1.0.0", + "description": "A serial multiplexer for encoding or decoding RTSP streams", + "main": "index.js", + "scripts": { + "test": "standard && tape test/*.js" + }, + "directories": { + "test": "test" + }, + "repository": { + "type": "git", + "url": "git+https://github.com/watson/rtsp-stream.git" + }, + "keywords": [ + "rtsp", + "protocol", + "stream", + "encode", + "decode", + "encoder", + "decoder", + "request", + "response", + "serial", + "multiplexer", + "2326", + "rfc2326" + ], + "dependencies": { + "debug": "^2.2.0", + "http-headers": "^1.2.0", + "next-line": "^1.1.0", + "readable-stream": "^2.0.2" + }, + "devDependencies": { + "choppa": "^1.0.2", + "standard": "^5.2.1", + "tape": "^4.2.0" + }, + "author": { + "name": "Thomas Watson Steen", + "email": "w@tson.dk", + "url": "https://twitter.com/wa7son" + }, + "license": "MIT", + "bugs": { + "url": "https://github.com/watson/rtsp-stream/issues" + }, + "homepage": "https://github.com/watson/rtsp-stream#readme", + "coordinates": [ + 55.6877001, + 12.5956461 + ], + "gitHead": "d71549d56a246503e29eccfb2dc7b00dcbfaa68a", + "_id": "rtsp-stream@1.0.0", + "_shasum": "9fea0d7f81867c1f2723ba54f16dcf6b0518e795", + "_from": "rtsp-stream@>=1.0.0 <2.0.0", + "_npmVersion": "1.4.28", + "_npmUser": { + "name": "watson", + "email": "w@tson.dk" + }, + "maintainers": [ + { + "name": "watson", + "email": "w@tson.dk" + } + ], + "dist": { + "shasum": "9fea0d7f81867c1f2723ba54f16dcf6b0518e795", + "tarball": "https://registry.npmjs.org/rtsp-stream/-/rtsp-stream-1.0.0.tgz" + }, + "_resolved": "http://registry.npmjs.org/rtsp-stream/-/rtsp-stream-1.0.0.tgz" +} diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/test/decoder.js b/node_modules/rtsp-server/node_modules/rtsp-stream/test/decoder.js new file mode 100644 index 0000000..b101b3e --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/test/decoder.js @@ -0,0 +1,180 @@ +'use strict' + +var fs = require('fs') +var path = require('path') +var choppa = require('choppa') +var test = require('tape') +var Decoder = require('../decoder') + +var pipes = [choppa, null] + +pipes.forEach(function (pipe) { + test('request headers', function (t) { + t.plan(4) + + var stream = fs.createReadStream(path.resolve('test', 'fixtures', 'options.txt')) + var decoder = new Decoder() + + decoder.on('request', function (req) { + t.equal(req.method, 'OPTIONS') + t.equal(req.uri, '*') + t.equal(req.rtspVersion, '1.0') + t.deepEqual(req.headers, { 'cseq': '42', 'foo': 'Bar' }) + }) + + if (pipe) stream = stream.pipe(pipe()) + stream.pipe(decoder) + }) + + test('request body', function (t) { + t.plan(1) + + var stream = fs.createReadStream(path.resolve('test', 'fixtures', 'announce.txt')) + var decoder = new Decoder() + + decoder.on('request', function (req) { + var buffers = [] + req.on('data', buffers.push.bind(buffers)) + req.on('end', function () { + var data = Buffer.concat(buffers).toString() + t.equal(data, '1234567890') + }) + }) + + if (pipe) stream = stream.pipe(pipe()) + stream.pipe(decoder) + }) + + test('without and with body', function (t) { + var requests = 0 + var stream = fs.createReadStream(path.resolve('test', 'fixtures', 'without-with-body.txt')) + var decoder = new Decoder() + var expected = [ + '', + 'body' + ] + + decoder.on('request', function (req) { + var requestNumber = ++requests + t.equal(req.headers['cseq'], String(requestNumber)) + var buffers = [] + req.on('data', buffers.push.bind(buffers)) + req.on('end', function () { + var data = Buffer.concat(buffers).toString() + t.equal(data, expected[requestNumber - 1]) + }) + }) + + decoder.on('finish', function () { + t.equal(requests, 2) + t.end() + }) + + if (pipe) stream = stream.pipe(pipe()) + stream.pipe(decoder) + }) + + test('multiple request bodies', function (t) { + var requests = 0 + var stream = fs.createReadStream(path.resolve('test', 'fixtures', 'multiple.txt')) + var decoder = new Decoder() + var methods = [ + 'ANNOUNCE', + 'SET_PARAMETER' + ] + var headers = [ + { cseq: '1', 'content-length': '11' }, + { cseq: '2', foo: 'Bar', 'content-length': '12' } + ] + var bodies = [ + '1st request', + 'last request' + ] + + decoder.on('request', function (req) { + t.equal(req.method, methods[requests]) + t.deepEqual(req.headers, headers[requests]) + var requestNumber = ++requests + t.equal(req.headers['cseq'], String(requestNumber)) + var buffers = [] + req.on('data', buffers.push.bind(buffers)) + req.on('end', function () { + var data = Buffer.concat(buffers).toString() + t.equal(data, bodies[requestNumber - 1]) + }) + }) + + decoder.on('finish', function () { + t.equal(requests, 2) + t.end() + }) + + if (pipe) stream = stream.pipe(pipe()) + stream.pipe(decoder) + }) + + test('response headers', function (t) { + t.plan(4) + + var stream = fs.createReadStream(path.resolve('test', 'fixtures', 'ok.txt')) + var decoder = new Decoder() + + decoder.on('response', function (res) { + t.equal(res.rtspVersion, '1.0') + t.equal(res.statusCode, 200) + t.equal(res.statusMessage, 'OK') + t.deepEqual(res.headers, { 'cseq': '42', 'foo': 'Bar' }) + }) + + if (pipe) stream = stream.pipe(pipe()) + stream.pipe(decoder) + }) + + test('response body', function (t) { + t.plan(1) + + var stream = fs.createReadStream(path.resolve('test', 'fixtures', 'ok-body.txt')) + var decoder = new Decoder() + + decoder.on('response', function (res) { + var buffers = [] + res.on('data', buffers.push.bind(buffers)) + res.on('end', function () { + var data = Buffer.concat(buffers).toString() + t.equal(data, '1234567890') + }) + }) + + if (pipe) stream = stream.pipe(pipe()) + stream.pipe(decoder) + }) + + test('multiple response bodies', function (t) { + var responses = 0 + var stream = fs.createReadStream(path.resolve('test', 'fixtures', 'ok-multiple-bodies.txt')) + var decoder = new Decoder() + var expected = [ + '1st response', + 'last response' + ] + + decoder.on('response', function (res) { + var responseNumber = ++responses + t.equal(res.headers['cseq'], String(responseNumber)) + var buffers = [] + res.on('data', buffers.push.bind(buffers)) + res.on('end', function () { + var data = Buffer.concat(buffers).toString() + t.equal(data, expected[responseNumber - 1]) + }) + }) + + decoder.on('finish', function () { + t.equal(responses, 2) + t.end() + }) + + if (pipe) stream = stream.pipe(pipe()) + stream.pipe(decoder) + }) +}) diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/test/encoder.js b/node_modules/rtsp-server/node_modules/rtsp-stream/test/encoder.js new file mode 100644 index 0000000..b875c58 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/test/encoder.js @@ -0,0 +1,243 @@ +'use strict' + +var test = require('tape') +var Encoder = require('../encoder') + +test('encoder.response()', function (t) { + t.test('no body or headers', function (t) { + t.plan(1) + + var encoder = new Encoder() + + var buffers = [] + encoder.on('data', buffers.push.bind(buffers)) + + var res = encoder.response() + res.end() + + setTimeout(function () { + var data = Buffer.concat(buffers).toString() + t.equal(data, 'RTSP/1.0 200 OK\r\n\r\n') + }, 50) + }) + + t.test('no body - only headers', function (t) { + t.plan(1) + + var encoder = new Encoder() + + var buffers = [] + encoder.on('data', buffers.push.bind(buffers)) + + var res = encoder.response() + res.setHeader('Foo', 'Bar') + res.end() + + setTimeout(function () { + var data = Buffer.concat(buffers).toString() + t.equal(data, 'RTSP/1.0 200 OK\r\nFoo: Bar\r\n\r\n') + }, 50) + }) + + t.test('encode a single response', function (t) { + t.plan(1) + + var encoder = new Encoder() + + var buffers = [] + encoder.on('data', buffers.push.bind(buffers)) + + var res = encoder.response() + res.setHeader('Foo', 'Bar') + res.write('a') + res.end('b') + + setTimeout(function () { + var data = Buffer.concat(buffers).toString() + t.equal(data, 'RTSP/1.0 200 OK\r\nFoo: Bar\r\n\r\nab') + }, 50) + }) + + t.test('encode two responses in series', function (t) { + t.plan(1) + + var encoder = new Encoder() + + var buffers = [] + encoder.on('data', buffers.push.bind(buffers)) + + var res = encoder.response() + res.setHeader('Foo', 'Bar') + res.end('a') + + res = encoder.response() + res.end('b') + + setTimeout(function () { + var data = Buffer.concat(buffers).toString() + t.equal(data, 'RTSP/1.0 200 OK\r\nFoo: Bar\r\n\r\naRTSP/1.0 200 OK\r\n\r\nb') + }, 50) + }) + + t.test('encode two responses in parallel', function (t) { + t.plan(1) + + var encoder = new Encoder() + + var buffers = [] + encoder.on('data', buffers.push.bind(buffers)) + + var res1 = encoder.response() + var res2 = encoder.response() + res1.setHeader('Foo', 'Bar') + res1.write('a1') + res2.write('b1') + res1.write('a2') + res2.write('b2') + res2.end() + res1.end() + + setTimeout(function () { + var data = Buffer.concat(buffers).toString() + t.equal(data, 'RTSP/1.0 200 OK\r\nFoo: Bar\r\n\r\na1a2RTSP/1.0 200 OK\r\n\r\nb1b2') + }, 50) + }) +}) + +test('encoder.request()', function (t) { + t.test('one-line encode a single request using callback', function (t) { + t.plan(1) + + var encoder = new Encoder() + + var buffers = [] + encoder.on('data', buffers.push.bind(buffers)) + + var opts = { + method: 'OPTIONS', + uri: '*', + headers: { 'Foo': 'Bar' }, + body: 'ab' + } + + encoder.request(opts, function () { + var data = Buffer.concat(buffers).toString() + t.equal(data, 'OPTIONS * RTSP/1.0\r\nFoo: Bar\r\n\r\nab') + }) + }) + + t.test('multi-step encode a single request using callback', function (t) { + t.plan(1) + + var encoder = new Encoder() + + var buffers = [] + encoder.on('data', buffers.push.bind(buffers)) + + var opts = { + method: 'OPTIONS', + uri: '*', + headers: { 'Foo': 'Bar' } + } + + var req = encoder.request(opts, function () { + var data = Buffer.concat(buffers).toString() + t.equal(data, 'OPTIONS * RTSP/1.0\r\nFoo: Bar\r\n\r\nab') + }) + + req.write('a') + req.end('b') + }) + + t.test('one-line encode a single request without callback', function (t) { + t.plan(1) + + var encoder = new Encoder() + + var buffers = [] + encoder.on('data', buffers.push.bind(buffers)) + + var opts = { + method: 'OPTIONS', + uri: '*', + headers: { 'Foo': 'Bar' }, + body: 'ab' + } + + var req = encoder.request(opts) + + req.on('finish', function () { + var data = Buffer.concat(buffers).toString() + t.equal(data, 'OPTIONS * RTSP/1.0\r\nFoo: Bar\r\n\r\nab') + }) + }) + + t.test('multi-step encode a single request without callback', function (t) { + t.plan(1) + + var encoder = new Encoder() + + var buffers = [] + encoder.on('data', buffers.push.bind(buffers)) + + var opts = { + method: 'OPTIONS', + uri: '*', + headers: { 'Foo': 'Bar' } + } + + var req = encoder.request(opts) + req.write('a') + req.end('b') + + req.on('finish', function () { + var data = Buffer.concat(buffers).toString() + t.equal(data, 'OPTIONS * RTSP/1.0\r\nFoo: Bar\r\n\r\nab') + }) + }) + + t.test('encode two request in series', function (t) { + t.plan(1) + + var encoder = new Encoder() + + var buffers = [] + encoder.on('data', buffers.push.bind(buffers)) + + var req = encoder.request({ method: 'OPTIONS', uri: '*' }) + req.setHeader('Foo', 'Bar') + req.end('a') + + req = encoder.request({ method: 'OPTIONS', uri: '*' }) + req.end('b') + + setTimeout(function () { + var data = Buffer.concat(buffers).toString() + t.equal(data, 'OPTIONS * RTSP/1.0\r\nFoo: Bar\r\n\r\naOPTIONS * RTSP/1.0\r\n\r\nb') + }, 50) + }) + + t.test('encode two requests in parallel', function (t) { + t.plan(1) + + var encoder = new Encoder() + + var buffers = [] + encoder.on('data', buffers.push.bind(buffers)) + + var req1 = encoder.request({ method: 'OPTIONS', uri: '*' }) + var req2 = encoder.request({ method: 'OPTIONS', uri: '*' }) + req1.setHeader('Foo', 'Bar') + req1.write('a1') + req2.write('b1') + req1.write('a2') + req2.write('b2') + req2.end() + req1.end() + + setTimeout(function () { + var data = Buffer.concat(buffers).toString() + t.equal(data, 'OPTIONS * RTSP/1.0\r\nFoo: Bar\r\n\r\na1a2OPTIONS * RTSP/1.0\r\n\r\nb1b2') + }, 50) + }) +}) diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/test/fixtures/announce.txt b/node_modules/rtsp-server/node_modules/rtsp-stream/test/fixtures/announce.txt new file mode 100644 index 0000000..b0f13af --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/test/fixtures/announce.txt @@ -0,0 +1,5 @@ +ANNOUNCE rtsp://example.com/123 RTSP/1.0 +CSeq: 42 +Content-Length: 10 + +1234567890 \ No newline at end of file diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/test/fixtures/multiple.txt b/node_modules/rtsp-server/node_modules/rtsp-stream/test/fixtures/multiple.txt new file mode 100644 index 0000000..f0b847e --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/test/fixtures/multiple.txt @@ -0,0 +1,10 @@ +ANNOUNCE rtsp://example.com/1 RTSP/1.0 +CSeq: 1 +Content-Length: 11 + +1st requestSET_PARAMETER rtsp://example.com/2 RTSP/1.0 +CSeq: 2 +Foo: Bar +Content-Length: 12 + +last request \ No newline at end of file diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/test/fixtures/ok-body.txt b/node_modules/rtsp-server/node_modules/rtsp-stream/test/fixtures/ok-body.txt new file mode 100644 index 0000000..7cc345a --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/test/fixtures/ok-body.txt @@ -0,0 +1,5 @@ +RTSP/1.0 200 OK +CSeq: 42 +Content-Length: 10 + +1234567890 \ No newline at end of file diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/test/fixtures/ok-multiple-bodies.txt b/node_modules/rtsp-server/node_modules/rtsp-stream/test/fixtures/ok-multiple-bodies.txt new file mode 100644 index 0000000..6a0cf28 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/test/fixtures/ok-multiple-bodies.txt @@ -0,0 +1,10 @@ +RTSP/1.0 200 OK +CSeq: 1 +Content-Length: 12 + +1st responseRTSP/1.0 200 OK +CSeq: 2 +Foo: Bar +Content-Length: 13 + +last response \ No newline at end of file diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/test/fixtures/ok.txt b/node_modules/rtsp-server/node_modules/rtsp-stream/test/fixtures/ok.txt new file mode 100644 index 0000000..c6156b3 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/test/fixtures/ok.txt @@ -0,0 +1,4 @@ +RTSP/1.0 200 OK +CSeq: 42 +Foo: Bar + diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/test/fixtures/options.txt b/node_modules/rtsp-server/node_modules/rtsp-stream/test/fixtures/options.txt new file mode 100644 index 0000000..f8ce006 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/test/fixtures/options.txt @@ -0,0 +1,4 @@ +OPTIONS * RTSP/1.0 +CSeq: 42 +Foo: Bar + diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/test/fixtures/without-with-body.txt b/node_modules/rtsp-server/node_modules/rtsp-stream/test/fixtures/without-with-body.txt new file mode 100644 index 0000000..3e1b3e9 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/test/fixtures/without-with-body.txt @@ -0,0 +1,9 @@ +ANNOUNCE rtsp://example.com/1 RTSP/1.0 +CSeq: 1 + +ANNOUNCE rtsp://example.com/2 RTSP/1.0 +CSeq: 2 +Foo: Bar +Content-Length: 4 + +body \ No newline at end of file diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/test/incoming-message.js b/node_modules/rtsp-server/node_modules/rtsp-stream/test/incoming-message.js new file mode 100644 index 0000000..1378f8c --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/test/incoming-message.js @@ -0,0 +1,56 @@ +'use strict' + +var test = require('tape') +var IncomingMessage = require('../lib/incoming-message') + +var lineBreaks = ['\r\n', '\n', '\r'] +var requestHeadLines = ['OPTIONS * RTSP/1.0', 'CSeq: 42', 'Foo: Bar'] +var responseHeadLines = ['RTSP/1.0 200 OK', 'CSeq: 42', 'Foo: Bar'] + +function head (arr, nl) { + return new Buffer([].concat(arr, ['', '']).join(nl)) +} + +lineBreaks.forEach(function (nl, index) { + test('incoming-message request headers type ' + (index + 1), function (t) { + var msg = new IncomingMessage(head(requestHeadLines, nl)) + t.equal(msg.rtspVersion, '1.0') + t.equal(msg.method, 'OPTIONS') + t.equal(msg.uri, '*') + t.deepEqual(msg.headers, { cseq: '42', foo: 'Bar' }) + t.end() + }) + + test('incoming-message response headers type ' + (index + 1), function (t) { + var msg = new IncomingMessage(head(responseHeadLines, nl)) + t.equal(msg.rtspVersion, '1.0') + t.equal(msg.statusCode, 200) + t.equal(msg.statusMessage, 'OK') + t.deepEqual(msg.headers, { cseq: '42', foo: 'Bar' }) + t.end() + }) + + test('incoming-message request body type ' + (index + 1), function (t) { + t.plan(1) + var msg = new IncomingMessage(head(requestHeadLines, nl)) + var buffers = [] + msg.on('data', buffers.push.bind(buffers)) + msg.on('end', function () { + var data = Buffer.concat(buffers).toString() + t.equal(data, 'foo') + }) + msg.end('foo') + }) + + test('incoming-message response body type ' + (index + 1), function (t) { + t.plan(1) + var msg = new IncomingMessage(head(responseHeadLines, nl)) + var buffers = [] + msg.on('data', buffers.push.bind(buffers)) + msg.on('end', function () { + var data = Buffer.concat(buffers).toString() + t.equal(data, 'foo') + }) + msg.end('foo') + }) +}) diff --git a/node_modules/rtsp-server/node_modules/rtsp-stream/test/test.js b/node_modules/rtsp-server/node_modules/rtsp-stream/test/test.js new file mode 100644 index 0000000..11b7006 --- /dev/null +++ b/node_modules/rtsp-server/node_modules/rtsp-stream/test/test.js @@ -0,0 +1,38 @@ +'use strict' + +var test = require('tape') +var Decoder = require('../decoder') +var Encoder = require('../encoder') + +test('encoder.pipe(decoder)', function (t) { + t.plan(5) + + var decoder = new Decoder() + var encoder = new Encoder() + + decoder.on('request', function (req) { + t.ok(false) + }) + + decoder.on('response', function (res) { + t.equal(res.rtspVersion, '1.0') + t.equal(res.statusCode, 200) + t.equal(res.statusMessage, 'OK') + t.deepEqual(res.headers, { 'cseq': '42', 'foo': 'Bar', 'content-length': '12' }) + + var buffers = [] + res.on('data', buffers.push.bind(buffers)) + res.on('end', function () { + var data = Buffer.concat(buffers).toString() + t.equal(data, 'Hello World!') + }) + }) + + encoder.pipe(decoder) + + var res = encoder.response() + res.setHeader('CSeq', 42) + res.setHeader('Foo', 'Bar') + res.setHeader('Content-Length', 12) + res.write('Hello World!') +}) diff --git a/node_modules/rtsp-server/package.json b/node_modules/rtsp-server/package.json new file mode 100644 index 0000000..726a992 --- /dev/null +++ b/node_modules/rtsp-server/package.json @@ -0,0 +1,66 @@ +{ + "name": "rtsp-server", + "version": "1.2.2", + "description": "Low level module for creating RTSP servers", + "main": "index.js", + "scripts": { + "test": "standard && tape test.js" + }, + "author": { + "name": "Thomas Watson Steen", + "email": "w@tson.dk", + "url": "https://twitter.com/wa7son" + }, + "license": "MIT", + "keywords": [ + "rtsp", + "server", + "rfc2326", + "2326", + "realtime", + "stream", + "streaming", + "protocol" + ], + "dependencies": { + "debug": "^2.2.0", + "rtsp-stream": "^1.0.0" + }, + "devDependencies": { + "standard": "^5.1.1", + "tape": "^4.2.0" + }, + "repository": { + "type": "git", + "url": "git+https://github.com/watson/rtsp-server.git" + }, + "bugs": { + "url": "https://github.com/watson/rtsp-server/issues" + }, + "homepage": "https://github.com/watson/rtsp-server#readme", + "coordinates": [ + 55.68769, + 12.595631 + ], + "gitHead": "fb87268dddea2f6c47785abd233762456d79c350", + "_id": "rtsp-server@1.2.2", + "_shasum": "06e4b298948a03d83a5c717330aff668688b1abf", + "_from": "rtsp-server@latest", + "_npmVersion": "1.4.28", + "_npmUser": { + "name": "watson", + "email": "w@tson.dk" + }, + "maintainers": [ + { + "name": "watson", + "email": "w@tson.dk" + } + ], + "dist": { + "shasum": "06e4b298948a03d83a5c717330aff668688b1abf", + "tarball": "https://registry.npmjs.org/rtsp-server/-/rtsp-server-1.2.2.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/rtsp-server/-/rtsp-server-1.2.2.tgz" +} diff --git a/node_modules/rtsp-server/test.js b/node_modules/rtsp-server/test.js new file mode 100644 index 0000000..941141c --- /dev/null +++ b/node_modules/rtsp-server/test.js @@ -0,0 +1,60 @@ +'use strict' + +var net = require('net') +var test = require('tape') +var rtsp = require('./') + +test('server events', function (t) { + t.plan(3) + + var server = rtsp.createServer() + + server.on('listening', connect) + server.on('connection', function (c) { + t.ok(true) + c.unref() + }) + server.on('request', function (req, res) { + t.ok(req instanceof rtsp.IncomingMessage) + t.ok(res instanceof rtsp.ServerResponse) + server.unref() + }) + server.listen() + + function connect () { + var port = server.address().port + var client = net.connect(port, function () { + client.write('OPTIONS * RTSP/1.0\r\n\r\n') + }) + client.unref() + } +}) + +test('request events', function (t) { + t.plan(3) + + var server = rtsp.createServer(function (req, res) { + req.on('readable', function () { + t.ok(true) + }) + req.on('end', function () { + t.ok(true) + server.unref() + }) + req.on('data', function (chunk) { + t.equal(chunk.toString(), 'foobar') + }) + }) + + server.on('connection', function (c) { + c.unref() + }) + + server.listen(function () { + var port = server.address().port + var client = net.connect(port, function () { + client.write('OPTIONS * RTSP/1.0\r\nContent-Length: 6\r\n\r\nfoobar') + }) + client.unref() + }) +}) diff --git a/node_modules/socket.io/History.md b/node_modules/socket.io/History.md new file mode 100644 index 0000000..bc75c6b --- /dev/null +++ b/node_modules/socket.io/History.md @@ -0,0 +1,602 @@ + +1.5.1 / 2016-10-24 +================== + + * [fix] Avoid swallowing exceptions thrown by user event handlers (#2682) + * [test] Use client function to unify `client` in test script (#2731) + * [docs] Add link to LICENSE (#2221) + * [docs] Fix JSDoc of optional parameters (#2465) + * [docs] Fix typo (#2724) + * [docs] Link readme npm package badge to npm registry page (#2612) + * [docs] Minor fixes (#2526) + * [chore] Bump socket.io-parser to 2.3.0 (#2730) + * [chore] Add Github issue and PR templates (#2733) + * [chore] Bump engine.io to 1.7.2 (#2729) + * [chore] Bump socket.io-parser to 2.3.1 (#2734) + +1.5.0 / 2016-10-06 +================== + + * [feature] stop append /# before id when no namespace (#2508) + * [feature] Add a 'disconnecting' event to access to socket.rooms upon disconnection (#2332) + * [fix] Fix query string management (#2422) + * [fix] add quote to exec paths, prevent error when spaces in path (#2508) + * [docs] Prevent mixup for new programmers (#2599) + * [example] Fix chat display in Firefox (#2477) + * [chore] Add gulp & babel in the build process (#2471) + * [chore] Bump engine.io to 1.7.0 (#2707) + * [chore] Remove unused zuul-ngrok dependency (#2708) + * [chore] Point towards current master of socket.io-client (#2710) + * [chore] Restrict files included in npm package (#2709) + * [chore] Link build badge to master branch (#2549) + +1.4.8 / 2016-06-23 +================== + + * package: bump `engine.io` + +1.4.7 / 2016-06-23 +================== + + * package: bump `engine.io` + +1.4.6 / 2016-05-02 +================== + + * package: bump engine.io + +1.4.5 / 2016-01-26 +================== + + * fix closing the underlying `http.Server` + +1.4.4 / 2016-01-10 +================== + + * package: bump `engine.io` + +1.4.3 / 2016-01-08 +================== + + * bump `socket.io-client` + +1.4.2 / 2016-01-07 +================== + + * bump `engine.io` + +1.4.1 / 2016-01-07 +================== + + * version bump + +1.4.0 / 2015-11-28 +================== + + * socket.io: increase large binary data test timeout + * package: bump `engine.io` for release + * trigger callback even when joining an already joined room + * package: bump parser + * namespace: clear rooms flag after a clients call (fixes #1978) + * package: bump `socket.io-parser` + * fixed tests with large data + * fixed a typo in the example code + * package: bump mocha + * package: bump `has-binary` and `zuul-ngrok` + * package: bump `engine.io` and `socket.io-client` + * README: clarified documentation of Socket.in + * README: fixed up legacy repo links + * test: better timeout for stress test + * socket: don't set request property which has a getter + * removed proxy index file + * support flags on namespace + * improve Socket#packet and Client#packet + * socket: warn node_redis-style about missing `error` + * test: added failing test + * test: increase timeout for large binary data test + * package: bump `has-binary` to work with all objects (fixes #1955) + * fix origin verification default https port [evanlucas] + * support compression [nkzawa] + * changed type of `Client#sockets`, `Namespace#sockets` and `Socket#rooms` to maps (instead of arrays) + +1.3.7 / 2015-09-21 +================== + + * package: bump `socket.io-client` for node4 compatibility + * package: bump `engine.io` for node4 compatibility + +1.3.6 / 2015-07-14 +================== + + * package: bump `engine.io` to fix build on windows + +1.3.5 / 2015-03-03 +================== + + * package: bump `socket.io-parser` + +1.3.4 / 2015-02-14 +================== + + * package: bump `socket.io-client` + +1.3.3 / 2015-02-03 +================== + + * socket: warn node_redis-style about missing `error` + * package: bump parser to better handle bad binary packets + +1.3.2 / 2015-01-19 +================== + + * no change on this release + +1.3.1 / 2015-01-19 +================== + + * no change on this release + * package: bump `engine.io` + +1.3.0 / 2015-01-19 +================== + + * package: bump `engine.io` + * add test for reconnection after server restarts [rase-] + * update license with up-to-date year range [fay-jai] + * fix leaving unknown rooms [defunctzombie] + * allow null origins when allowed origins is a function [drewblaisdell] + * fix tests on node 0.11 + * package: fix `npm test` to run on windows + * package: bump `debug` v2.1.0 [coderaiser] + * added tests for volatile [rase-] + +1.2.1 / 2014-11-21 +================== + + * fix protocol violations and improve error handling (GH-1880) + * package: bump `engine.io` for websocket leak fix [3rd-Eden] + * style tweaks + +1.2.0 / 2014-10-27 +================== + + * package: bump `engine.io` + * downloads badge + * add test to check that empty rooms are autopruned + * added Server#origins(v:Function) description for dynamic CORS + * added test coverage for Server#origins(function) for dynamic CORS + * added optional Server#origins(function) for dynamic CORS + * fix usage example for Server#close + * package: fix main file for example application 'chat' + * package: bump `socket.io-parser` + * update README http ctor to createServer() + * bump adapter with a lot of fixes for room bookkeeping + +1.1.0 / 2014-09-04 +================== + + * examples: minor fix of escaping + * testing for equivalence of namespaces starting with / or without + * update index.js + * added relevant tests + * take "" and "/" as equivalent namespaces on server + * use svg instead of png to get better image quality in readme + * make CI build faster + * fix splice arguments and `socket.rooms` value update in `socket.leaveAll`. + * client cannot connect to non-existing namespaces + * bump engine.io version to get the cached IP address + * fixed handshake object address property and made the test case more strict. + * package: bump `engine.io` + * fixed the failing test where server crashes on disconnect involving connectBuffer + * npmignore: ignore `.gitignore` (fixes #1607) + * test: added failing case for `socket.disconnect` and nsps + * fix repo in package.json + * improve Close documentation + * use ephemeral ports + * fix: We should use the standard http protocol to handler the etag header. + * override default browser font-family for inputs + * update has-binary-data to 1.0.3 + * add close specs + * add ability to stop the http server even if not created inside socket.io + * make sure server gets close + * Add test case for checking that reconnect_failed is fired only once upon failure + * package: bump `socket.io-parser` for `component-emitter` dep fix + +1.0.6 / 2014-06-19 +================== + + * package: bump `socket.io-client` + +1.0.5 / 2014-06-16 +================== + + * package: bump `engine.io` to fix jsonp `\n` bug and CORS warnings + * index: fix typo [yanatan16] + * add `removeListener` to blacklisted events + * examples: clearer instructions to install chat example + * index: fix namespace `connectBuffer` issue + +1.0.4 / 2014-06-02 +================== + + * package: bump socket.io-client + +1.0.3 / 2014-05-31 +================== + + * package: bump `socket.io-client` + * package: bump `socket.io-parser` for binary ACK fix + * package: bump `engine.io` for binary UTF8 fix + * example: fix XSS in chat example + +1.0.2 / 2014-05-28 +================== + + * package: bump `socket.io-parser` for windows fix + +1.0.1 / 2014-05-28 +================== + + * bump due to bad npm tag + +1.0.0 / 2014-05-28 +================== + + * stable release + +1.0.0-pre5 / 2014-05-22 +======================= + + * package: bump `socket.io-client` for parser fixes + * package: bump `engine.io` + +1.0.0-pre4 / 2014-05-19 +======================= + + * package: bump client + +1.0.0-pre3 / 2014-05-17 +======================= + + * package: bump parser + * package: bump engine.io + +1.0.0-pre2 / 2014-04-27 +======================= + + * package: bump `engine.io` + * added backwards compatible of engine.io maxHttpBufferSize + * added test that server and client using same protocol + * added support for setting allowed origins + * added information about logging + * the set function in server can be used to set some attributes for BC + * fix error in callback call 'done' instead of 'next' in docs + * package: bump `socket.io-parser` + * package: bump `expect.js` + * added some new tests, including binary with acks + +1.0.0-pre / 2014-03-14 +====================== + + * implemented `engine.io` + * implemented `socket.io-adapter` + * implemented `socket.io-protocol` + * implemented `debug` and improved instrumentation + * added binary support + * added new `require('io')(srv)` signature + * simplified `socket.io-client` serving + +0.9.14 / 2013-03-29 +=================== + + * manager: fix memory leak with SSL [jpallen] + +0.9.13 / 2012-12-13 +=================== + + * package: fixed `base64id` requirement + +0.9.12 / 2012-12-13 +=================== + + * manager: fix for latest node which is returning a clone with `listeners` [viirya] + +0.9.11 / 2012-11-02 +=================== + + * package: move redis to optionalDependenices [3rd-Eden] + * bumped client + +0.9.10 / 2012-08-10 +=================== + + * Don't lowercase log messages + * Always set the HTTP response in case an error should be returned to the client + * Create or destroy the flash policy server on configuration change + * Honour configuration to disable flash policy server + * Add express 3.0 instructions on Readme.md + * Bump client + +0.9.9 / 2012-08-01 +================== + + * Fixed sync disconnect xhrs handling + * Put license text in its own file (#965) + * Add warning to .listen() to ease the migration to Express 3.x + * Restored compatibility with node 0.4.x + +0.9.8 / 2012-07-24 +================== + + * Bumped client. + +0.9.7 / 2012-07-24 +================== + + * Prevent crash when socket leaves a room twice. + * Corrects unsafe usage of for..in + * Fix for node 0.8 with `gzip compression` [vadimi] + * Update redis to support Node 0.8.x + * Made ID generation securely random + * Fix Redis Store race condition in manager onOpen unsubscribe callback + * Fix for EventEmitters always reusing the same Array instance for listeners + +0.9.6 / 2012-04-17 +================== + + * Fixed XSS in jsonp-polling. + +0.9.5 / 2012-04-05 +================== + + * Added test for polling and socket close. + * Ensure close upon request close. + * Fix disconnection reason being lost for polling transports. + * Ensure that polling transports work with Connection: close. + * Log disconnection reason. + +0.9.4 / 2012-04-01 +================== + + * Disconnecting from namespace improvement (#795) [DanielBaulig] + * Bumped client with polling reconnection loop (#438) + +0.9.3 / 2012-03-28 +================== + + * Fix "Syntax error" on FF Web Console with XHR Polling [mikito] + +0.9.2 / 2012-03-13 +================== + + * More sensible close `timeout default` (fixes disconnect issue) + +0.9.1-1 / 2012-03-02 +==================== + + * Bumped client with NPM dependency fix. + +0.9.1 / 2012-03-02 +================== + + * Changed heartbeat timeout and interval defaults (60 and 25 seconds) + * Make tests work both on 0.4 and 0.6 + * Updated client (improvements + bug fixes). + +0.9.0 / 2012-02-26 +================== + + * Make it possible to use a regexp to match the socket.io resource URL. + We need this because we have to prefix the socket.io URL with a variable ID. + * Supplemental fix to gavinuhma/authfix, it looks like the same Access-Control-Origin logic is needed in the http and xhr-polling transports + * Updated express dep for windows compatibility. + * Combine two substr calls into one in decodePayload to improve performance + * Minor documentation fix + * Minor. Conform to style of other files. + * Switching setting to 'match origin protocol' + * Revert "Fixes leaking Redis subscriptions for #663. The local flag was not getting passed through onClientDisconnect()." + * Revert "Handle leaked dispatch:[id] subscription." + * Merge pull request #667 from dshaw/patch/redis-disconnect + * Handle leaked dispatch:[id] subscription. + * Fixes leaking Redis subscriptions for #663. The local flag was not getting passed through onClientDisconnect(). + * Prevent memory leaking on uncompleted requests & add max post size limitation + * Fix for testcase + * Set Access-Control-Allow-Credentials true, regardless of cookie + * Remove assertvarnish from package as it breaks on 0.6 + * Correct irc channel + * Added proper return after reserved field error + * Fixes manager.js failure to close connection after transport error has happened + * Added implicit port 80 for origin checks. fixes #638 + * Fixed bug #432 in 0.8.7 + * Set Access-Control-Allow-Origin header to origin to enable withCredentials + * Adding configuration variable matchOriginProtocol + * Fixes location mismatch error in Safari. + * Use tty to detect if we should add colors or not by default. + * Updated the package location. + +0.8.7 / 2011-11-05 +================== + + * Fixed memory leaks in closed clients. + * Fixed memory leaks in namespaces. + * Fixed websocket handling for malformed requests from proxies. [einaros] + * Node 0.6 compatibility. [einaros] [3rd-Eden] + * Adapted tests and examples. + +0.8.6 / 2011-10-27 +================== + + * Added JSON decoding on jsonp-polling transport. + * Fixed README example. + * Major speed optimizations [3rd-Eden] [einaros] [visionmedia] + * Added decode/encode benchmarks [visionmedia] + * Added support for black-listing client sent events. + * Fixed logging options, closes #540 [3rd-Eden] + * Added vary header for gzip [3rd-Eden] + * Properly cleaned up async websocket / flashsocket tests, after patching node-websocket-client + * Patched to properly shut down when a finishClose call is made during connection establishment + * Added support for socket.io version on url and far-future Expires [3rd-Eden] [getify] + * Began IE10 compatibility [einaros] [tbranyen] + * Misc WebSocket fixes [einaros] + * Added UTF8 to respone headers for htmlfile [3rd-Eden] + +0.8.5 / 2011-10-07 +================== + + * Added websocket draft HyBi-16 support. [einaros] + * Fixed websocket continuation bugs. [einaros] + * Fixed flashsocket transport name. + * Fixed websocket tests. + * Ensured `parser#decodePayload` doesn't choke. + * Added http referrer verification to manager verifyOrigin. + * Added access control for cross domain xhr handshakes [3rd-Eden] + * Added support for automatic generation of socket.io files [3rd-Eden] + * Added websocket binary support [einaros] + * Added gzip support for socket.io.js [3rd-Eden] + * Expose socket.transport [3rd-Eden] + * Updated client. + +0.8.4 / 2011-09-06 +================== + + * Client build + +0.8.3 / 2011-09-03 +================== + + * Fixed `\n` parsing for non-JSON packets (fixes #479). + * Fixed parsing of certain unicode characters (fixes #451). + * Fixed transport message packet logging. + * Fixed emission of `error` event resulting in an uncaught exception if unhandled (fixes #476). + * Fixed; allow for falsy values as the configuration value of `log level` (fixes #491). + * Fixed repository URI in `package.json`. Fixes #504. + * Added text/plain content-type to handshake responses [einaros] + * Improved single byte writes [einaros] + * Updated socket.io-flashsocket default port from 843 to 10843 [3rd-Eden] + * Updated client. + +0.8.2 / 2011-08-29 +================== + + * Updated client. + +0.8.1 / 2011-08-29 +================== + + * Fixed utf8 bug in send framing in websocket [einaros] + * Fixed typo in docs [Znarkus] + * Fixed bug in send framing for over 64kB of data in websocket [einaros] + * Corrected ping handling in websocket transport [einaros] + +0.8.0 / 2011-08-28 +================== + + * Updated to work with two-level websocket versioning. [einaros] + * Added hybi07 support. [einaros] + * Added hybi10 support. [einaros] + * Added http referrer verification to manager.js verifyOrigin. [einaors] + +0.7.11 / 2011-08-27 +=================== + + * Updated socket.io-client. + +0.7.10 / 2011-08-27 +=================== + + * Updated socket.io-client. + +0.7.9 / 2011-08-12 +================== + + * Updated socket.io-client. + * Make sure we only do garbage collection when the server we receive is actually run. + +0.7.8 / 2011-08-08 +================== + + * Changed; make sure sio#listen passes options to both HTTP server and socket.io manager. + * Added docs for sio#listen. + * Added options parameter support for Manager constructor. + * Added memory leaks tests and test-leaks Makefile task. + * Removed auto npm-linking from make test. + * Make sure that you can disable heartbeats. [3rd-Eden] + * Fixed rooms memory leak [3rd-Eden] + * Send response once we got all POST data, not immediately [Pita] + * Fixed onLeave behavior with missing clientsk [3rd-Eden] + * Prevent duplicate references in rooms. + * Added alias for `to` to `in` and `in` to `to`. + * Fixed roomClients definition. + * Removed dependency on redis for installation without npm [3rd-Eden] + * Expose path and querystring in handshakeData [3rd-Eden] + +0.7.7 / 2011-07-12 +================== + + * Fixed double dispatch handling with emit to closed clients. + * Added test for emitting to closed clients to prevent regression. + * Fixed race condition in redis test. + * Changed Transport#end instrumentation. + * Leveraged $emit instead of emit internally. + * Made tests faster. + * Fixed double disconnect events. + * Fixed disconnect logic + * Simplified remote events handling in Socket. + * Increased testcase timeout. + * Fixed unknown room emitting (GH-291). [3rd-Eden] + * Fixed `address` in handshakeData. [3rd-Eden] + * Removed transports definition in chat example. + * Fixed room cleanup + * Fixed; make sure the client is cleaned up after booting. + * Make sure to mark the client as non-open if the connection is closed. + * Removed unneeded `buffer` declarations. + * Fixed; make sure to clear socket handlers and subscriptions upon transport close. + +0.7.6 / 2011-06-30 +================== + + * Fixed general dispatching when a client has closed. + +0.7.5 / 2011-06-30 +================== + + * Fixed dispatching to clients that are disconnected. + +0.7.4 / 2011-06-30 +================== + + * Fixed; only clear handlers if they were set. [level09] + +0.7.3 / 2011-06-30 +================== + + * Exposed handshake data to clients. + * Refactored dispatcher interface. + * Changed; Moved id generation method into the manager. + * Added sub-namespace authorization. [3rd-Eden] + * Changed; normalized SocketNamespace local eventing [dvv] + * Changed; Use packet.reason or default to 'packet' [3rd-Eden] + * Changed console.error to console.log. + * Fixed; bind both servers at the same time do that the test never times out. + * Added 304 support. + * Removed `Transport#name` for abstract interface. + * Changed; lazily require http and https module only when needed. [3rd-Eden] + +0.7.2 / 2011-06-22 +================== + + * Make sure to write a packet (of type `noop`) when closing a poll. + This solves a problem with cross-domain requests being flagged as aborted and + reconnection being triggered. + * Added `noop` message type. + +0.7.1 / 2011-06-21 +================== + + * Fixed cross-domain XHR. + * Added CORS test to xhr-polling suite. + +0.7.0 / 2010-06-21 +================== + + * http://socket.io/announcement.html diff --git a/node_modules/socket.io/LICENSE b/node_modules/socket.io/LICENSE new file mode 100644 index 0000000..b248ba1 --- /dev/null +++ b/node_modules/socket.io/LICENSE @@ -0,0 +1,22 @@ +(The MIT License) + +Copyright (c) 2014-2015 Automattic + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/socket.io/Readme.md b/node_modules/socket.io/Readme.md new file mode 100644 index 0000000..6ee93d6 --- /dev/null +++ b/node_modules/socket.io/Readme.md @@ -0,0 +1,465 @@ + +# socket.io + +[![Build Status](https://secure.travis-ci.org/socketio/socket.io.svg?branch=master)](https://travis-ci.org/socketio/socket.io) +[![Dependency Status](https://david-dm.org/socketio/socket.io.svg)](https://david-dm.org/socketio/socket.io) +[![devDependency Status](https://david-dm.org/socketio/socket.io/dev-status.svg)](https://david-dm.org/socketio/socket.io#info=devDependencies) +[![NPM version](https://badge.fury.io/js/socket.io.svg)](https://www.npmjs.com/package/socket.io) +![Downloads](https://img.shields.io/npm/dm/socket.io.svg?style=flat) +[![](http://slack.socket.io/badge.svg?)](http://slack.socket.io) + +## How to use + +The following example attaches socket.io to a plain Node.JS +HTTP server listening on port `3000`. + +```js +var server = require('http').createServer(); +var io = require('socket.io')(server); +io.on('connection', function(client){ + client.on('event', function(data){}); + client.on('disconnect', function(){}); +}); +server.listen(3000); +``` + +### Standalone + +```js +var io = require('socket.io')(); +io.on('connection', function(client){}); +io.listen(3000); +``` + +### In conjunction with Express + +Starting with **3.0**, express applications have become request handler +functions that you pass to `http` or `http` `Server` instances. You need +to pass the `Server` to `socket.io`, and not the express application +function. + +```js +var app = require('express')(); +var server = require('http').createServer(app); +var io = require('socket.io')(server); +io.on('connection', function(){ /* … */ }); +server.listen(3000); +``` + +### In conjunction with Koa + +Like Express.JS, Koa works by exposing an application as a request +handler function, but only by calling the `callback` method. + +```js +var app = require('koa')(); +var server = require('http').createServer(app.callback()); +var io = require('socket.io')(server); +io.on('connection', function(){ /* … */ }); +server.listen(3000); +``` + +## API + +### Server + + Exposed by `require('socket.io')`. + +### Server() + + Creates a new `Server`. Works with and without `new`: + + ```js + var io = require('socket.io')(); + // or + var Server = require('socket.io'); + var io = new Server(); + ``` + +### Server(opts:Object) + + Optionally, the first or second argument (see below) of the `Server` + constructor can be an options object. + + The following options are supported: + + - `serveClient` sets the value for Server#serveClient() + - `path` sets the value for Server#path() + + The same options passed to socket.io are always passed to + the `engine.io` `Server` that gets created. See engine.io + [options](https://github.com/socketio/engine.io#methods-1) + as reference. + +### Server(srv:http#Server, opts:Object) + + Creates a new `Server` and attaches it to the given `srv`. Optionally + `opts` can be passed. + +### Server(port:Number, opts:Object) + + Binds socket.io to a new `http.Server` that listens on `port`. + +### Server#serveClient(v:Boolean):Server + + If `v` is `true` the attached server (see `Server#attach`) will serve + the client files. Defaults to `true`. + + This method has no effect after `attach` is called. + + ```js + // pass a server and the `serveClient` option + var io = require('socket.io')(http, { serveClient: false }); + + // or pass no server and then you can call the method + var io = require('socket.io')(); + io.serveClient(false); + io.attach(http); + ``` + + If no arguments are supplied this method returns the current value. + +### Server#path(v:String):Server + + Sets the path `v` under which `engine.io` and the static files will be + served. Defaults to `/socket.io`. + + If no arguments are supplied this method returns the current value. + +### Server#adapter(v:Adapter):Server + + Sets the adapter `v`. Defaults to an instance of the `Adapter` that + ships with socket.io which is memory based. See + [socket.io-adapter](https://github.com/socketio/socket.io-adapter). + + If no arguments are supplied this method returns the current value. + +### Server#origins(v:String):Server + + Sets the allowed origins `v`. Defaults to any origins being allowed. + + If no arguments are supplied this method returns the current value. + +### Server#origins(v:Function):Server + + Sets the allowed origins as dynamic function. Function takes two arguments `origin:String` and `callback(error, success)`, where `success` is a boolean value indicating whether origin is allowed or not. + + __Potential drawbacks__: + * in some situations, when it is not possible to determine `origin` it may have value of `*` + * As this function will be executed for every request, it is advised to make this function work as fast as possible + * If `socket.io` is used together with `Express`, the CORS headers will be affected only for `socket.io` requests. For Express can use [cors](https://github.com/expressjs/cors) + + +### Server#sockets:Namespace + + The default (`/`) namespace. + +### Server#attach(srv:http#Server, opts:Object):Server + + Attaches the `Server` to an engine.io instance on `srv` with the + supplied `opts` (optionally). + +### Server#attach(port:Number, opts:Object):Server + + Attaches the `Server` to an engine.io instance that is bound to `port` + with the given `opts` (optionally). + +### Server#listen + + Synonym of `Server#attach`. + +### Server#bind(srv:engine#Server):Server + + Advanced use only. Binds the server to a specific engine.io `Server` + (or compatible API) instance. + +### Server#onconnection(socket:engine#Socket):Server + + Advanced use only. Creates a new `socket.io` client from the incoming + engine.io (or compatible API) `socket`. + +### Server#of(nsp:String):Namespace + + Initializes and retrieves the given `Namespace` by its pathname + identifier `nsp`. + + If the namespace was already initialized it returns it right away. + +### Server#emit + + Emits an event to all connected clients. The following two are + equivalent: + + ```js + var io = require('socket.io')(); + io.sockets.emit('an event sent to all connected clients'); + io.emit('an event sent to all connected clients'); + ``` + + For other available methods, see `Namespace` below. + +### Server#close + + Closes socket.io server + + ```js + var Server = require('socket.io'); + var PORT = 3030; + var server = require('http').Server(); + + var io = Server(PORT); + + io.close(); // Close current server + + server.listen(PORT); // PORT is free to use + + io = Server(server); + ``` + +### Server#use + + See `Namespace#use` below. + +### Namespace + + Represents a pool of sockets connected under a given scope identified + by a pathname (eg: `/chat`). + + By default the client always connects to `/`. + +#### Events + + - `connection` / `connect`. Fired upon a connection. + + Parameters: + - `Socket` the incoming socket. + +### Namespace#name:String + + The namespace identifier property. + +### Namespace#connected:Object + + Hash of `Socket` objects that are connected to this namespace indexed + by `id`. + +### Namespace#clients(fn:Function) + + Gets a list of client IDs connected to this namespace (across all nodes if applicable). + + An example to get all clients in a namespace: + + ```js + var io = require('socket.io')(); + io.of('/chat').clients(function(error, clients){ + if (error) throw error; + console.log(clients); // => [PZDoMHjiu8PYfRiKAAAF, Anw2LatarvGVVXEIAAAD] + }); + ``` + + An example to get all clients in namespace's room: + + ```js + var io = require('socket.io')(); + io.of('/chat').in('general').clients(function(error, clients){ + if (error) throw error; + console.log(clients); // => [Anw2LatarvGVVXEIAAAD] + }); + ``` + + As with broadcasting, the default is all clients from the default namespace ('/'): + + ```js + var io = require('socket.io')(); + io.clients(function(error, clients){ + if (error) throw error; + console.log(clients); // => [6em3d4TJP8Et9EMNAAAA, G5p55dHhGgUnLUctAAAB] + }); + ``` + +### Namespace#use(fn:Function):Namespace + + Registers a middleware, which is a function that gets executed for + every incoming `Socket` and receives as parameter the socket and a + function to optionally defer execution to the next registered + middleware. + + ```js + var io = require('socket.io')(); + io.use(function(socket, next){ + if (socket.request.headers.cookie) return next(); + next(new Error('Authentication error')); + }); + ``` + + Errors passed to middleware callbacks are sent as special `error` + packets to clients. + +### Socket + + A `Socket` is the fundamental class for interacting with browser + clients. A `Socket` belongs to a certain `Namespace` (by default `/`) + and uses an underlying `Client` to communicate. + + It should be noted the `Socket` doesn't relate directly to the actual + underlying TCP/IP `socket` and it is only the name of the class. + +### Socket#rooms:Object + + A hash of strings identifying the rooms this client is in, indexed by + room name. + +### Socket#client:Client + + A reference to the underlying `Client` object. + +### Socket#conn:Socket + + A reference to the underlying `Client` transport connection (engine.io + `Socket` object). This allows access to the IO transport layer, which + still (mostly) abstracts the actual TCP/IP socket. + +### Socket#request:Request + + A getter proxy that returns the reference to the `request` that + originated the underlying engine.io `Client`. Useful for accessing + request headers such as `Cookie` or `User-Agent`. + +### Socket#id:String + + A unique identifier for the session, that comes from the + underlying `Client`. + +### Socket#emit(name:String[, …]):Socket + + Emits an event identified by the string `name` to the client. + Any other parameters can be included. + + All datastructures are supported, including `Buffer`. JavaScript + functions can't be serialized/deserialized. + + ```js + var io = require('socket.io')(); + io.on('connection', function(client){ + client.emit('an event', { some: 'data' }); + }); + ``` + +### Socket#join(name:String[, fn:Function]):Socket + + Adds the client to the `room`, and fires optionally a callback `fn` + with `err` signature (if any). + + The client is automatically a member of a room identified with its + session id (see `Socket#id`). + + The mechanics of joining rooms are handled by the `Adapter` + that has been configured (see `Server#adapter` above), defaulting to + [socket.io-adapter](https://github.com/socketio/socket.io-adapter). + +### Socket#leave(name:String[, fn:Function]):Socket + + Removes the client from `room`, and fires optionally a callback `fn` + with `err` signature (if any). + + **Rooms are left automatically upon disconnection**. + + The mechanics of leaving rooms are handled by the `Adapter` + that has been configured (see `Server#adapter` above), defaulting to + [socket.io-adapter](https://github.com/socketio/socket.io-adapter). + +### Socket#to(room:String):Socket + + Sets a modifier for a subsequent event emission that the event will + only be _broadcasted_ to clients that have joined the given `room`. + + To emit to multiple rooms, you can call `to` several times. + + ```js + var io = require('socket.io')(); + io.on('connection', function(client){ + client.to('others').emit('an event', { some: 'data' }); + }); + ``` + +### Socket#in(room:String):Socket + + Same as `Socket#to` + +### Socket#compress(v:Boolean):Socket + + Sets a modifier for a subsequent event emission that the event data will + only be _compressed_ if the value is `true`. Defaults to `true` when you don't call the method. + + ```js + var io = require('socket.io')(); + io.on('connection', function(client){ + client.compress(false).emit('an event', { some: 'data' }); + }); + ``` + +### Socket#disconnect(close:Boolean):Socket + + Disconnects this client. If value of close is `true`, closes the underlying connection. + Otherwise, it just disconnects the namespace. + +#### Events + +- `disconnect` + - Fired upon disconnection. + - **Arguments** + - `String`: the reason of the disconnection (either client or server-side) +- `error` + - Fired when an error occurs. + - **Arguments** + - `Object`: error data +- `disconnecting` + - Fired when the client is going to be disconnected (but hasn't left its `rooms` yet). + - **Arguments** + - `String`: the reason of the disconnection (either client or server-side) + +These are reserved events (along with `connect`, `newListener` and `removeListener`) which cannot be used as event names. + + +### Client + + The `Client` class represents an incoming transport (engine.io) + connection. A `Client` can be associated with many multiplexed `Socket` + that belong to different `Namespace`s. + +### Client#conn + + A reference to the underlying `engine.io` `Socket` connection. + +### Client#request + + A getter proxy that returns the reference to the `request` that + originated the engine.io connection. Useful for accessing + request headers such as `Cookie` or `User-Agent`. + +## Debug / logging + +Socket.IO is powered by [debug](https://github.com/visionmedia/debug). +In order to see all the debug output, run your app with the environment variable +`DEBUG` including the desired scope. + +To see the output from all of Socket.IO's debugging scopes you can use: + +``` +DEBUG=socket.io* node myapp +``` + +## Testing + +``` +npm test +``` +This runs the `gulp` task `test`. By default the test will be run with the source code in `lib` directory. + +Set the environmental variable `TEST_VERSION` to `compat` to test the transpiled es5-compat version of the code. + +The `gulp` task `test` will always transpile the source code into es5 and export to `dist` first before running the test. + +## License + +[MIT](LICENSE) diff --git a/node_modules/socket.io/lib/client.js b/node_modules/socket.io/lib/client.js new file mode 100644 index 0000000..c19818d --- /dev/null +++ b/node_modules/socket.io/lib/client.js @@ -0,0 +1,254 @@ + +/** + * Module dependencies. + */ + +var parser = require('socket.io-parser'); +var debug = require('debug')('socket.io:client'); +var url = require('url'); + +/** + * Module exports. + */ + +module.exports = Client; + +/** + * Client constructor. + * + * @param {Server} server instance + * @param {Socket} conn + * @api private + */ + +function Client(server, conn){ + this.server = server; + this.conn = conn; + this.encoder = new parser.Encoder(); + this.decoder = new parser.Decoder(); + this.id = conn.id; + this.request = conn.request; + this.setup(); + this.sockets = {}; + this.nsps = {}; + this.connectBuffer = []; +} + +/** + * Sets up event listeners. + * + * @api private + */ + +Client.prototype.setup = function(){ + this.onclose = this.onclose.bind(this); + this.ondata = this.ondata.bind(this); + this.onerror = this.onerror.bind(this); + this.ondecoded = this.ondecoded.bind(this); + + this.decoder.on('decoded', this.ondecoded); + this.conn.on('data', this.ondata); + this.conn.on('error', this.onerror); + this.conn.on('close', this.onclose); +}; + +/** + * Connects a client to a namespace. + * + * @param {String} name namespace + * @api private + */ + +Client.prototype.connect = function(name, query){ + debug('connecting to namespace %s', name); + var nsp = this.server.nsps[name]; + if (!nsp) { + this.packet({ type: parser.ERROR, nsp: name, data : 'Invalid namespace'}); + return; + } + + if ('/' != name && !this.nsps['/']) { + this.connectBuffer.push(name); + return; + } + + var self = this; + var socket = nsp.add(this, query, function(){ + self.sockets[socket.id] = socket; + self.nsps[nsp.name] = socket; + + if ('/' == nsp.name && self.connectBuffer.length > 0) { + self.connectBuffer.forEach(self.connect, self); + self.connectBuffer = []; + } + }); +}; + +/** + * Disconnects from all namespaces and closes transport. + * + * @api private + */ + +Client.prototype.disconnect = function(){ + for (var id in this.sockets) { + if (this.sockets.hasOwnProperty(id)) { + this.sockets[id].disconnect(); + } + } + this.sockets = {}; + this.close(); +}; + +/** + * Removes a socket. Called by each `Socket`. + * + * @api private + */ + +Client.prototype.remove = function(socket){ + if (this.sockets.hasOwnProperty(socket.id)) { + var nsp = this.sockets[socket.id].nsp.name; + delete this.sockets[socket.id]; + delete this.nsps[nsp]; + } else { + debug('ignoring remove for %s', socket.id); + } +}; + +/** + * Closes the underlying connection. + * + * @api private + */ + +Client.prototype.close = function(){ + if ('open' == this.conn.readyState) { + debug('forcing transport close'); + this.conn.close(); + this.onclose('forced server close'); + } +}; + +/** + * Writes a packet to the transport. + * + * @param {Object} packet object + * @param {Object} opts + * @api private + */ + +Client.prototype.packet = function(packet, opts){ + opts = opts || {}; + var self = this; + + // this writes to the actual connection + function writeToEngine(encodedPackets) { + if (opts.volatile && !self.conn.transport.writable) return; + for (var i = 0; i < encodedPackets.length; i++) { + self.conn.write(encodedPackets[i], { compress: opts.compress }); + } + } + + if ('open' == this.conn.readyState) { + debug('writing packet %j', packet); + if (!opts.preEncoded) { // not broadcasting, need to encode + this.encoder.encode(packet, function (encodedPackets) { // encode, then write results to engine + writeToEngine(encodedPackets); + }); + } else { // a broadcast pre-encodes a packet + writeToEngine(packet); + } + } else { + debug('ignoring packet write %j', packet); + } +}; + +/** + * Called with incoming transport data. + * + * @api private + */ + +Client.prototype.ondata = function(data){ + // try/catch is needed for protocol violations (GH-1880) + try { + this.decoder.add(data); + } catch(e) { + this.onerror(e); + } +}; + +/** + * Called when parser fully decodes a packet. + * + * @api private + */ + +Client.prototype.ondecoded = function(packet) { + if (parser.CONNECT == packet.type) { + this.connect(url.parse(packet.nsp).pathname, url.parse(packet.nsp, true).query); + } else { + var socket = this.nsps[packet.nsp]; + if (socket) { + process.nextTick(function() { + socket.onpacket(packet); + }); + } else { + debug('no socket for namespace %s', packet.nsp); + } + } +}; + +/** + * Handles an error. + * + * @param {Object} err object + * @api private + */ + +Client.prototype.onerror = function(err){ + for (var id in this.sockets) { + if (this.sockets.hasOwnProperty(id)) { + this.sockets[id].onerror(err); + } + } + this.onclose('client error'); +}; + +/** + * Called upon transport close. + * + * @param {String} reason + * @api private + */ + +Client.prototype.onclose = function(reason){ + debug('client close with reason %s', reason); + + // ignore a potential subsequent `close` event + this.destroy(); + + // `nsps` and `sockets` are cleaned up seamlessly + for (var id in this.sockets) { + if (this.sockets.hasOwnProperty(id)) { + this.sockets[id].onclose(reason); + } + } + this.sockets = {}; + + this.decoder.destroy(); // clean up decoder +}; + +/** + * Cleans up event listeners. + * + * @api private + */ + +Client.prototype.destroy = function(){ + this.conn.removeListener('data', this.ondata); + this.conn.removeListener('error', this.onerror); + this.conn.removeListener('close', this.onclose); + this.decoder.removeListener('decoded', this.ondecoded); +}; diff --git a/node_modules/socket.io/lib/index.js b/node_modules/socket.io/lib/index.js new file mode 100644 index 0000000..bae5f9d --- /dev/null +++ b/node_modules/socket.io/lib/index.js @@ -0,0 +1,385 @@ + +/** + * Module dependencies. + */ + +var http = require('http'); +var read = require('fs').readFileSync; +var engine = require('engine.io'); +var client = require('socket.io-client'); +var clientVersion = require('socket.io-client/package').version; +var Client = require('./client'); +var Namespace = require('./namespace'); +var Adapter = require('socket.io-adapter'); +var debug = require('debug')('socket.io:server'); +var url = require('url'); + +/** + * Module exports. + */ + +module.exports = Server; + +/** + * Socket.IO client source. + */ + +var clientSource = read(require.resolve('socket.io-client/socket.io.js'), 'utf-8'); + +/** + * Server constructor. + * + * @param {http.Server|Number|Object} srv http server, port or options + * @param {Object} [opts] + * @api public + */ + +function Server(srv, opts){ + if (!(this instanceof Server)) return new Server(srv, opts); + if ('object' == typeof srv && !srv.listen) { + opts = srv; + srv = null; + } + opts = opts || {}; + this.nsps = {}; + this.path(opts.path || '/socket.io'); + this.serveClient(false !== opts.serveClient); + this.adapter(opts.adapter || Adapter); + this.origins(opts.origins || '*:*'); + this.sockets = this.of('/'); + if (srv) this.attach(srv, opts); +} + +/** + * Server request verification function, that checks for allowed origins + * + * @param {http.IncomingMessage} req request + * @param {Function} fn callback to be called with the result: `fn(err, success)` + */ + +Server.prototype.checkRequest = function(req, fn) { + var origin = req.headers.origin || req.headers.referer; + + // file:// URLs produce a null Origin which can't be authorized via echo-back + if ('null' == origin || null == origin) origin = '*'; + + if (!!origin && typeof(this._origins) == 'function') return this._origins(origin, fn); + if (this._origins.indexOf('*:*') !== -1) return fn(null, true); + if (origin) { + try { + var parts = url.parse(origin); + var defaultPort = 'https:' == parts.protocol ? 443 : 80; + parts.port = parts.port != null + ? parts.port + : defaultPort; + var ok = + ~this._origins.indexOf(parts.hostname + ':' + parts.port) || + ~this._origins.indexOf(parts.hostname + ':*') || + ~this._origins.indexOf('*:' + parts.port); + return fn(null, !!ok); + } catch (ex) { + } + } + fn(null, false); +}; + +/** + * Sets/gets whether client code is being served. + * + * @param {Boolean} v whether to serve client code + * @return {Server|Boolean} self when setting or value when getting + * @api public + */ + +Server.prototype.serveClient = function(v){ + if (!arguments.length) return this._serveClient; + this._serveClient = v; + return this; +}; + +/** + * Old settings for backwards compatibility + */ + +var oldSettings = { + "transports": "transports", + "heartbeat timeout": "pingTimeout", + "heartbeat interval": "pingInterval", + "destroy buffer size": "maxHttpBufferSize" +}; + +/** + * Backwards compatibility. + * + * @api public + */ + +Server.prototype.set = function(key, val){ + if ('authorization' == key && val) { + this.use(function(socket, next) { + val(socket.request, function(err, authorized) { + if (err) return next(new Error(err)); + if (!authorized) return next(new Error('Not authorized')); + next(); + }); + }); + } else if ('origins' == key && val) { + this.origins(val); + } else if ('resource' == key) { + this.path(val); + } else if (oldSettings[key] && this.eio[oldSettings[key]]) { + this.eio[oldSettings[key]] = val; + } else { + console.error('Option %s is not valid. Please refer to the README.', key); + } + + return this; +}; + +/** + * Sets the client serving path. + * + * @param {String} v pathname + * @return {Server|String} self when setting or value when getting + * @api public + */ + +Server.prototype.path = function(v){ + if (!arguments.length) return this._path; + this._path = v.replace(/\/$/, ''); + return this; +}; + +/** + * Sets the adapter for rooms. + * + * @param {Adapter} v pathname + * @return {Server|Adapter} self when setting or value when getting + * @api public + */ + +Server.prototype.adapter = function(v){ + if (!arguments.length) return this._adapter; + this._adapter = v; + for (var i in this.nsps) { + if (this.nsps.hasOwnProperty(i)) { + this.nsps[i].initAdapter(); + } + } + return this; +}; + +/** + * Sets the allowed origins for requests. + * + * @param {String} v origins + * @return {Server|Adapter} self when setting or value when getting + * @api public + */ + +Server.prototype.origins = function(v){ + if (!arguments.length) return this._origins; + + this._origins = v; + return this; +}; + +/** + * Attaches socket.io to a server or port. + * + * @param {http.Server|Number} server or port + * @param {Object} options passed to engine.io + * @return {Server} self + * @api public + */ + +Server.prototype.listen = +Server.prototype.attach = function(srv, opts){ + if ('function' == typeof srv) { + var msg = 'You are trying to attach socket.io to an express ' + + 'request handler function. Please pass a http.Server instance.'; + throw new Error(msg); + } + + // handle a port as a string + if (Number(srv) == srv) { + srv = Number(srv); + } + + if ('number' == typeof srv) { + debug('creating http server and binding to %d', srv); + var port = srv; + srv = http.Server(function(req, res){ + res.writeHead(404); + res.end(); + }); + srv.listen(port); + + } + + // set engine.io path to `/socket.io` + opts = opts || {}; + opts.path = opts.path || this.path(); + // set origins verification + opts.allowRequest = opts.allowRequest || this.checkRequest.bind(this); + + // initialize engine + debug('creating engine.io instance with opts %j', opts); + this.eio = engine.attach(srv, opts); + + // attach static file serving + if (this._serveClient) this.attachServe(srv); + + // Export http server + this.httpServer = srv; + + // bind to engine events + this.bind(this.eio); + + return this; +}; + +/** + * Attaches the static file serving. + * + * @param {Function|http.Server} srv http server + * @api private + */ + +Server.prototype.attachServe = function(srv){ + debug('attaching client serving req handler'); + var url = this._path + '/socket.io.js'; + var evs = srv.listeners('request').slice(0); + var self = this; + srv.removeAllListeners('request'); + srv.on('request', function(req, res) { + if (0 === req.url.indexOf(url)) { + self.serve(req, res); + } else { + for (var i = 0; i < evs.length; i++) { + evs[i].call(srv, req, res); + } + } + }); +}; + +/** + * Handles a request serving `/socket.io.js` + * + * @param {http.Request} req + * @param {http.Response} res + * @api private + */ + +Server.prototype.serve = function(req, res){ + var etag = req.headers['if-none-match']; + if (etag) { + if (clientVersion == etag) { + debug('serve client 304'); + res.writeHead(304); + res.end(); + return; + } + } + + debug('serve client source'); + res.setHeader('Content-Type', 'application/javascript'); + res.setHeader('ETag', clientVersion); + res.writeHead(200); + res.end(clientSource); +}; + +/** + * Binds socket.io to an engine.io instance. + * + * @param {engine.Server} engine engine.io (or compatible) server + * @return {Server} self + * @api public + */ + +Server.prototype.bind = function(engine){ + this.engine = engine; + this.engine.on('connection', this.onconnection.bind(this)); + return this; +}; + +/** + * Called with each incoming transport connection. + * + * @param {engine.Socket} conn + * @return {Server} self + * @api public + */ + +Server.prototype.onconnection = function(conn){ + debug('incoming connection with id %s', conn.id); + var client = new Client(this, conn); + client.connect('/'); + return this; +}; + +/** + * Looks up a namespace. + * + * @param {String} name nsp name + * @param {Function} [fn] optional, nsp `connection` ev handler + * @api public + */ + +Server.prototype.of = function(name, fn){ + if (String(name)[0] !== '/') name = '/' + name; + + var nsp = this.nsps[name]; + if (!nsp) { + debug('initializing namespace %s', name); + nsp = new Namespace(this, name); + this.nsps[name] = nsp; + } + if (fn) nsp.on('connect', fn); + return nsp; +}; + +/** + * Closes server connection + * + * @api public + */ + +Server.prototype.close = function(){ + for (var id in this.nsps['/'].sockets) { + if (this.nsps['/'].sockets.hasOwnProperty(id)) { + this.nsps['/'].sockets[id].onclose(); + } + } + + this.engine.close(); + + if(this.httpServer){ + this.httpServer.close(); + } +}; + +/** + * Expose main namespace (/). + */ + +['on', 'to', 'in', 'use', 'emit', 'send', 'write', 'clients', 'compress'].forEach(function(fn){ + Server.prototype[fn] = function(){ + var nsp = this.sockets[fn]; + return nsp.apply(this.sockets, arguments); + }; +}); + +Namespace.flags.forEach(function(flag){ + Server.prototype.__defineGetter__(flag, function(){ + this.sockets.flags = this.sockets.flags || {}; + this.sockets.flags[flag] = true; + return this; + }); +}); + +/** + * BC with `io.listen` + */ + +Server.listen = Server; diff --git a/node_modules/socket.io/lib/namespace.js b/node_modules/socket.io/lib/namespace.js new file mode 100644 index 0000000..c197f54 --- /dev/null +++ b/node_modules/socket.io/lib/namespace.js @@ -0,0 +1,272 @@ + +/** + * Module dependencies. + */ + +var Socket = require('./socket'); +var Emitter = require('events').EventEmitter; +var parser = require('socket.io-parser'); +var debug = require('debug')('socket.io:namespace'); +var hasBin = require('has-binary'); + +/** + * Module exports. + */ + +module.exports = exports = Namespace; + +/** + * Blacklisted events. + */ + +exports.events = [ + 'connect', // for symmetry with client + 'connection', + 'newListener' +]; + +/** + * Flags. + */ + +exports.flags = [ + 'json', + 'volatile' +]; + +/** + * `EventEmitter#emit` reference. + */ + +var emit = Emitter.prototype.emit; + +/** + * Namespace constructor. + * + * @param {Server} server instance + * @param {Socket} name + * @api private + */ + +function Namespace(server, name){ + this.name = name; + this.server = server; + this.sockets = {}; + this.connected = {}; + this.fns = []; + this.ids = 0; + this.initAdapter(); +} + +/** + * Inherits from `EventEmitter`. + */ + +Namespace.prototype.__proto__ = Emitter.prototype; + +/** + * Apply flags from `Socket`. + */ + +exports.flags.forEach(function(flag){ + Namespace.prototype.__defineGetter__(flag, function(){ + this.flags = this.flags || {}; + this.flags[flag] = true; + return this; + }); +}); + +/** + * Initializes the `Adapter` for this nsp. + * Run upon changing adapter by `Server#adapter` + * in addition to the constructor. + * + * @api private + */ + +Namespace.prototype.initAdapter = function(){ + this.adapter = new (this.server.adapter())(this); +}; + +/** + * Sets up namespace middleware. + * + * @return {Namespace} self + * @api public + */ + +Namespace.prototype.use = function(fn){ + this.fns.push(fn); + return this; +}; + +/** + * Executes the middleware for an incoming client. + * + * @param {Socket} socket that will get added + * @param {Function} fn last fn call in the middleware + * @api private + */ + +Namespace.prototype.run = function(socket, fn){ + var fns = this.fns.slice(0); + if (!fns.length) return fn(null); + + function run(i){ + fns[i](socket, function(err){ + // upon error, short-circuit + if (err) return fn(err); + + // if no middleware left, summon callback + if (!fns[i + 1]) return fn(null); + + // go on to next + run(i + 1); + }); + } + + run(0); +}; + +/** + * Targets a room when emitting. + * + * @param {String} name + * @return {Namespace} self + * @api public + */ + +Namespace.prototype.to = +Namespace.prototype['in'] = function(name){ + this.rooms = this.rooms || []; + if (!~this.rooms.indexOf(name)) this.rooms.push(name); + return this; +}; + +/** + * Adds a new client. + * + * @return {Socket} + * @api private + */ + +Namespace.prototype.add = function(client, query, fn){ + debug('adding socket to nsp %s', this.name); + var socket = new Socket(this, client, query); + var self = this; + this.run(socket, function(err){ + process.nextTick(function(){ + if ('open' == client.conn.readyState) { + if (err) return socket.error(err.data || err.message); + + // track socket + self.sockets[socket.id] = socket; + + // it's paramount that the internal `onconnect` logic + // fires before user-set events to prevent state order + // violations (such as a disconnection before the connection + // logic is complete) + socket.onconnect(); + if (fn) fn(); + + // fire user-set events + self.emit('connect', socket); + self.emit('connection', socket); + } else { + debug('next called after client was closed - ignoring socket'); + } + }); + }); + return socket; +}; + +/** + * Removes a client. Called by each `Socket`. + * + * @api private + */ + +Namespace.prototype.remove = function(socket){ + if (this.sockets.hasOwnProperty(socket.id)) { + delete this.sockets[socket.id]; + } else { + debug('ignoring remove for %s', socket.id); + } +}; + +/** + * Emits to all clients. + * + * @return {Namespace} self + * @api public + */ + +Namespace.prototype.emit = function(ev){ + if (~exports.events.indexOf(ev)) { + emit.apply(this, arguments); + } else { + // set up packet object + var args = Array.prototype.slice.call(arguments); + var parserType = parser.EVENT; // default + if (hasBin(args)) { parserType = parser.BINARY_EVENT; } // binary + + var packet = { type: parserType, data: args }; + + if ('function' == typeof args[args.length - 1]) { + throw new Error('Callbacks are not supported when broadcasting'); + } + + this.adapter.broadcast(packet, { + rooms: this.rooms, + flags: this.flags + }); + + delete this.rooms; + delete this.flags; + } + return this; +}; + +/** + * Sends a `message` event to all clients. + * + * @return {Namespace} self + * @api public + */ + +Namespace.prototype.send = +Namespace.prototype.write = function(){ + var args = Array.prototype.slice.call(arguments); + args.unshift('message'); + this.emit.apply(this, args); + return this; +}; + +/** + * Gets a list of clients. + * + * @return {Namespace} self + * @api public + */ + +Namespace.prototype.clients = function(fn){ + this.adapter.clients(this.rooms, fn); + // delete rooms flag for scenario: + // .in('room').clients() (GH-1978) + delete this.rooms; + return this; +}; + +/** + * Sets the compress flag. + * + * @param {Boolean} compress if `true`, compresses the sending data + * @return {Socket} self + * @api public + */ + +Namespace.prototype.compress = function(compress){ + this.flags = this.flags || {}; + this.flags.compress = compress; + return this; +}; diff --git a/node_modules/socket.io/lib/socket.js b/node_modules/socket.io/lib/socket.js new file mode 100644 index 0000000..2f10c1b --- /dev/null +++ b/node_modules/socket.io/lib/socket.js @@ -0,0 +1,484 @@ + +/** + * Module dependencies. + */ + +var Emitter = require('events').EventEmitter; +var parser = require('socket.io-parser'); +var url = require('url'); +var debug = require('debug')('socket.io:socket'); +var hasBin = require('has-binary'); + +/** + * Module exports. + */ + +module.exports = exports = Socket; + +/** + * Blacklisted events. + * + * @api public + */ + +exports.events = [ + 'error', + 'connect', + 'disconnect', + 'disconnecting', + 'newListener', + 'removeListener' +]; + +/** + * Flags. + * + * @api private + */ + +var flags = [ + 'json', + 'volatile', + 'broadcast' +]; + +/** + * `EventEmitter#emit` reference. + */ + +var emit = Emitter.prototype.emit; + +/** + * Interface to a `Client` for a given `Namespace`. + * + * @param {Namespace} nsp + * @param {Client} client + * @api public + */ + +function Socket(nsp, client, query){ + this.nsp = nsp; + this.server = nsp.server; + this.adapter = this.nsp.adapter; + this.id = nsp.name !== '/' ? nsp.name + '#' + client.id : client.id; + this.client = client; + this.conn = client.conn; + this.rooms = {}; + this.acks = {}; + this.connected = true; + this.disconnected = false; + this.handshake = this.buildHandshake(query); +} + +/** + * Inherits from `EventEmitter`. + */ + +Socket.prototype.__proto__ = Emitter.prototype; + +/** + * Apply flags from `Socket`. + */ + +flags.forEach(function(flag){ + Socket.prototype.__defineGetter__(flag, function(){ + this.flags = this.flags || {}; + this.flags[flag] = true; + return this; + }); +}); + +/** + * `request` engine.io shortcut. + * + * @api public + */ + +Socket.prototype.__defineGetter__('request', function(){ + return this.conn.request; +}); + +/** + * Builds the `handshake` BC object + * + * @api private + */ + +Socket.prototype.buildHandshake = function(query){ + var self = this; + function buildQuery(){ + var requestQuery = url.parse(self.request.url, true).query; + //if socket-specific query exist, replace query strings in requestQuery + if(query){ + query.t = requestQuery.t; + query.EIO = requestQuery.EIO; + query.transport = requestQuery.transport; + return query; + } + return requestQuery || {}; + } + return { + headers: this.request.headers, + time: (new Date) + '', + address: this.conn.remoteAddress, + xdomain: !!this.request.headers.origin, + secure: !!this.request.connection.encrypted, + issued: +(new Date), + url: this.request.url, + query: buildQuery() + }; +}; + +/** + * Emits to this client. + * + * @return {Socket} self + * @api public + */ + +Socket.prototype.emit = function(ev){ + if (~exports.events.indexOf(ev)) { + emit.apply(this, arguments); + } else { + var args = Array.prototype.slice.call(arguments); + var packet = {}; + packet.type = hasBin(args) ? parser.BINARY_EVENT : parser.EVENT; + packet.data = args; + var flags = this.flags || {}; + + // access last argument to see if it's an ACK callback + if ('function' == typeof args[args.length - 1]) { + if (this._rooms || flags.broadcast) { + throw new Error('Callbacks are not supported when broadcasting'); + } + + debug('emitting packet with ack id %d', this.nsp.ids); + this.acks[this.nsp.ids] = args.pop(); + packet.id = this.nsp.ids++; + } + + if (this._rooms || flags.broadcast) { + this.adapter.broadcast(packet, { + except: [this.id], + rooms: this._rooms, + flags: flags + }); + } else { + // dispatch packet + this.packet(packet, { + volatile: flags.volatile, + compress: flags.compress + }); + } + + // reset flags + delete this._rooms; + delete this.flags; + } + return this; +}; + +/** + * Targets a room when broadcasting. + * + * @param {String} name + * @return {Socket} self + * @api public + */ + +Socket.prototype.to = +Socket.prototype.in = function(name){ + this._rooms = this._rooms || []; + if (!~this._rooms.indexOf(name)) this._rooms.push(name); + return this; +}; + +/** + * Sends a `message` event. + * + * @return {Socket} self + * @api public + */ + +Socket.prototype.send = +Socket.prototype.write = function(){ + var args = Array.prototype.slice.call(arguments); + args.unshift('message'); + this.emit.apply(this, args); + return this; +}; + +/** + * Writes a packet. + * + * @param {Object} packet object + * @param {Object} opts options + * @api private + */ + +Socket.prototype.packet = function(packet, opts){ + packet.nsp = this.nsp.name; + opts = opts || {}; + opts.compress = false !== opts.compress; + this.client.packet(packet, opts); +}; + +/** + * Joins a room. + * + * @param {String} room + * @param {Function} fn optional, callback + * @return {Socket} self + * @api private + */ + +Socket.prototype.join = function(room, fn){ + debug('joining room %s', room); + var self = this; + if (this.rooms.hasOwnProperty(room)) { + fn && fn(null); + return this; + } + this.adapter.add(this.id, room, function(err){ + if (err) return fn && fn(err); + debug('joined room %s', room); + self.rooms[room] = room; + fn && fn(null); + }); + return this; +}; + +/** + * Leaves a room. + * + * @param {String} room + * @param {Function} fn optional, callback + * @return {Socket} self + * @api private + */ + +Socket.prototype.leave = function(room, fn){ + debug('leave room %s', room); + var self = this; + this.adapter.del(this.id, room, function(err){ + if (err) return fn && fn(err); + debug('left room %s', room); + delete self.rooms[room]; + fn && fn(null); + }); + return this; +}; + +/** + * Leave all rooms. + * + * @api private + */ + +Socket.prototype.leaveAll = function(){ + this.adapter.delAll(this.id); + this.rooms = {}; +}; + +/** + * Called by `Namespace` upon successful + * middleware execution (ie: authorization). + * + * @api private + */ + +Socket.prototype.onconnect = function(){ + debug('socket connected - writing packet'); + this.nsp.connected[this.id] = this; + this.join(this.id); + this.packet({ type: parser.CONNECT }); +}; + +/** + * Called with each packet. Called by `Client`. + * + * @param {Object} packet + * @api private + */ + +Socket.prototype.onpacket = function(packet){ + debug('got packet %j', packet); + switch (packet.type) { + case parser.EVENT: + this.onevent(packet); + break; + + case parser.BINARY_EVENT: + this.onevent(packet); + break; + + case parser.ACK: + this.onack(packet); + break; + + case parser.BINARY_ACK: + this.onack(packet); + break; + + case parser.DISCONNECT: + this.ondisconnect(); + break; + + case parser.ERROR: + this.emit('error', packet.data); + } +}; + +/** + * Called upon event packet. + * + * @param {Object} packet object + * @api private + */ + +Socket.prototype.onevent = function(packet){ + var args = packet.data || []; + debug('emitting event %j', args); + + if (null != packet.id) { + debug('attaching ack callback to event'); + args.push(this.ack(packet.id)); + } + + emit.apply(this, args); +}; + +/** + * Produces an ack callback to emit with an event. + * + * @param {Number} id packet id + * @api private + */ + +Socket.prototype.ack = function(id){ + var self = this; + var sent = false; + return function(){ + // prevent double callbacks + if (sent) return; + var args = Array.prototype.slice.call(arguments); + debug('sending ack %j', args); + + var type = hasBin(args) ? parser.BINARY_ACK : parser.ACK; + self.packet({ + id: id, + type: type, + data: args + }); + + sent = true; + }; +}; + +/** + * Called upon ack packet. + * + * @api private + */ + +Socket.prototype.onack = function(packet){ + var ack = this.acks[packet.id]; + if ('function' == typeof ack) { + debug('calling ack %s with %j', packet.id, packet.data); + ack.apply(this, packet.data); + delete this.acks[packet.id]; + } else { + debug('bad ack %s', packet.id); + } +}; + +/** + * Called upon client disconnect packet. + * + * @api private + */ + +Socket.prototype.ondisconnect = function(){ + debug('got disconnect packet'); + this.onclose('client namespace disconnect'); +}; + +/** + * Handles a client error. + * + * @api private + */ + +Socket.prototype.onerror = function(err){ + if (this.listeners('error').length) { + this.emit('error', err); + } else { + console.error('Missing error handler on `socket`.'); + console.error(err.stack); + } +}; + +/** + * Called upon closing. Called by `Client`. + * + * @param {String} reason + * @throw {Error} optional error object + * @api private + */ + +Socket.prototype.onclose = function(reason){ + if (!this.connected) return this; + debug('closing socket - reason %s', reason); + this.emit('disconnecting', reason); + this.leaveAll(); + this.nsp.remove(this); + this.client.remove(this); + this.connected = false; + this.disconnected = true; + delete this.nsp.connected[this.id]; + this.emit('disconnect', reason); +}; + +/** + * Produces an `error` packet. + * + * @param {Object} err error object + * @api private + */ + +Socket.prototype.error = function(err){ + this.packet({ type: parser.ERROR, data: err }); +}; + +/** + * Disconnects this client. + * + * @param {Boolean} close if `true`, closes the underlying connection + * @return {Socket} self + * @api public + */ + +Socket.prototype.disconnect = function(close){ + if (!this.connected) return this; + if (close) { + this.client.disconnect(); + } else { + this.packet({ type: parser.DISCONNECT }); + this.onclose('server namespace disconnect'); + } + return this; +}; + +/** + * Sets the compress flag. + * + * @param {Boolean} compress if `true`, compresses the sending data + * @return {Socket} self + * @api public + */ + +Socket.prototype.compress = function(compress){ + this.flags = this.flags || {}; + this.flags.compress = compress; + return this; +}; diff --git a/node_modules/socket.io/node_modules/debug/.jshintrc b/node_modules/socket.io/node_modules/debug/.jshintrc new file mode 100644 index 0000000..299877f --- /dev/null +++ b/node_modules/socket.io/node_modules/debug/.jshintrc @@ -0,0 +1,3 @@ +{ + "laxbreak": true +} diff --git a/node_modules/socket.io/node_modules/debug/.npmignore b/node_modules/socket.io/node_modules/debug/.npmignore new file mode 100644 index 0000000..7e6163d --- /dev/null +++ b/node_modules/socket.io/node_modules/debug/.npmignore @@ -0,0 +1,6 @@ +support +test +examples +example +*.sock +dist diff --git a/node_modules/socket.io/node_modules/debug/History.md b/node_modules/socket.io/node_modules/debug/History.md new file mode 100644 index 0000000..854c971 --- /dev/null +++ b/node_modules/socket.io/node_modules/debug/History.md @@ -0,0 +1,195 @@ + +2.2.0 / 2015-05-09 +================== + + * package: update "ms" to v0.7.1 (#202, @dougwilson) + * README: add logging to file example (#193, @DanielOchoa) + * README: fixed a typo (#191, @amir-s) + * browser: expose `storage` (#190, @stephenmathieson) + * Makefile: add a `distclean` target (#189, @stephenmathieson) + +2.1.3 / 2015-03-13 +================== + + * Updated stdout/stderr example (#186) + * Updated example/stdout.js to match debug current behaviour + * Renamed example/stderr.js to stdout.js + * Update Readme.md (#184) + * replace high intensity foreground color for bold (#182, #183) + +2.1.2 / 2015-03-01 +================== + + * dist: recompile + * update "ms" to v0.7.0 + * package: update "browserify" to v9.0.3 + * component: fix "ms.js" repo location + * changed bower package name + * updated documentation about using debug in a browser + * fix: security error on safari (#167, #168, @yields) + +2.1.1 / 2014-12-29 +================== + + * browser: use `typeof` to check for `console` existence + * browser: check for `console.log` truthiness (fix IE 8/9) + * browser: add support for Chrome apps + * Readme: added Windows usage remarks + * Add `bower.json` to properly support bower install + +2.1.0 / 2014-10-15 +================== + + * node: implement `DEBUG_FD` env variable support + * package: update "browserify" to v6.1.0 + * package: add "license" field to package.json (#135, @panuhorsmalahti) + +2.0.0 / 2014-09-01 +================== + + * package: update "browserify" to v5.11.0 + * node: use stderr rather than stdout for logging (#29, @stephenmathieson) + +1.0.4 / 2014-07-15 +================== + + * dist: recompile + * example: remove `console.info()` log usage + * example: add "Content-Type" UTF-8 header to browser example + * browser: place %c marker after the space character + * browser: reset the "content" color via `color: inherit` + * browser: add colors support for Firefox >= v31 + * debug: prefer an instance `log()` function over the global one (#119) + * Readme: update documentation about styled console logs for FF v31 (#116, @wryk) + +1.0.3 / 2014-07-09 +================== + + * Add support for multiple wildcards in namespaces (#122, @seegno) + * browser: fix lint + +1.0.2 / 2014-06-10 +================== + + * browser: update color palette (#113, @gscottolson) + * common: make console logging function configurable (#108, @timoxley) + * node: fix %o colors on old node <= 0.8.x + * Makefile: find node path using shell/which (#109, @timoxley) + +1.0.1 / 2014-06-06 +================== + + * browser: use `removeItem()` to clear localStorage + * browser, node: don't set DEBUG if namespaces is undefined (#107, @leedm777) + * package: add "contributors" section + * node: fix comment typo + * README: list authors + +1.0.0 / 2014-06-04 +================== + + * make ms diff be global, not be scope + * debug: ignore empty strings in enable() + * node: make DEBUG_COLORS able to disable coloring + * *: export the `colors` array + * npmignore: don't publish the `dist` dir + * Makefile: refactor to use browserify + * package: add "browserify" as a dev dependency + * Readme: add Web Inspector Colors section + * node: reset terminal color for the debug content + * node: map "%o" to `util.inspect()` + * browser: map "%j" to `JSON.stringify()` + * debug: add custom "formatters" + * debug: use "ms" module for humanizing the diff + * Readme: add "bash" syntax highlighting + * browser: add Firebug color support + * browser: add colors for WebKit browsers + * node: apply log to `console` + * rewrite: abstract common logic for Node & browsers + * add .jshintrc file + +0.8.1 / 2014-04-14 +================== + + * package: re-add the "component" section + +0.8.0 / 2014-03-30 +================== + + * add `enable()` method for nodejs. Closes #27 + * change from stderr to stdout + * remove unnecessary index.js file + +0.7.4 / 2013-11-13 +================== + + * remove "browserify" key from package.json (fixes something in browserify) + +0.7.3 / 2013-10-30 +================== + + * fix: catch localStorage security error when cookies are blocked (Chrome) + * add debug(err) support. Closes #46 + * add .browser prop to package.json. Closes #42 + +0.7.2 / 2013-02-06 +================== + + * fix package.json + * fix: Mobile Safari (private mode) is broken with debug + * fix: Use unicode to send escape character to shell instead of octal to work with strict mode javascript + +0.7.1 / 2013-02-05 +================== + + * add repository URL to package.json + * add DEBUG_COLORED to force colored output + * add browserify support + * fix component. Closes #24 + +0.7.0 / 2012-05-04 +================== + + * Added .component to package.json + * Added debug.component.js build + +0.6.0 / 2012-03-16 +================== + + * Added support for "-" prefix in DEBUG [Vinay Pulim] + * Added `.enabled` flag to the node version [TooTallNate] + +0.5.0 / 2012-02-02 +================== + + * Added: humanize diffs. Closes #8 + * Added `debug.disable()` to the CS variant + * Removed padding. Closes #10 + * Fixed: persist client-side variant again. Closes #9 + +0.4.0 / 2012-02-01 +================== + + * Added browser variant support for older browsers [TooTallNate] + * Added `debug.enable('project:*')` to browser variant [TooTallNate] + * Added padding to diff (moved it to the right) + +0.3.0 / 2012-01-26 +================== + + * Added millisecond diff when isatty, otherwise UTC string + +0.2.0 / 2012-01-22 +================== + + * Added wildcard support + +0.1.0 / 2011-12-02 +================== + + * Added: remove colors unless stderr isatty [TooTallNate] + +0.0.1 / 2010-01-03 +================== + + * Initial release diff --git a/node_modules/socket.io/node_modules/debug/Makefile b/node_modules/socket.io/node_modules/debug/Makefile new file mode 100644 index 0000000..5cf4a59 --- /dev/null +++ b/node_modules/socket.io/node_modules/debug/Makefile @@ -0,0 +1,36 @@ + +# get Makefile directory name: http://stackoverflow.com/a/5982798/376773 +THIS_MAKEFILE_PATH:=$(word $(words $(MAKEFILE_LIST)),$(MAKEFILE_LIST)) +THIS_DIR:=$(shell cd $(dir $(THIS_MAKEFILE_PATH));pwd) + +# BIN directory +BIN := $(THIS_DIR)/node_modules/.bin + +# applications +NODE ?= $(shell which node) +NPM ?= $(NODE) $(shell which npm) +BROWSERIFY ?= $(NODE) $(BIN)/browserify + +all: dist/debug.js + +install: node_modules + +clean: + @rm -rf dist + +dist: + @mkdir -p $@ + +dist/debug.js: node_modules browser.js debug.js dist + @$(BROWSERIFY) \ + --standalone debug \ + . > $@ + +distclean: clean + @rm -rf node_modules + +node_modules: package.json + @NODE_ENV= $(NPM) install + @touch node_modules + +.PHONY: all install clean distclean diff --git a/node_modules/socket.io/node_modules/debug/Readme.md b/node_modules/socket.io/node_modules/debug/Readme.md new file mode 100644 index 0000000..b4f45e3 --- /dev/null +++ b/node_modules/socket.io/node_modules/debug/Readme.md @@ -0,0 +1,188 @@ +# debug + + tiny node.js debugging utility modelled after node core's debugging technique. + +## Installation + +```bash +$ npm install debug +``` + +## Usage + + With `debug` you simply invoke the exported function to generate your debug function, passing it a name which will determine if a noop function is returned, or a decorated `console.error`, so all of the `console` format string goodies you're used to work fine. A unique color is selected per-function for visibility. + +Example _app.js_: + +```js +var debug = require('debug')('http') + , http = require('http') + , name = 'My App'; + +// fake app + +debug('booting %s', name); + +http.createServer(function(req, res){ + debug(req.method + ' ' + req.url); + res.end('hello\n'); +}).listen(3000, function(){ + debug('listening'); +}); + +// fake worker of some kind + +require('./worker'); +``` + +Example _worker.js_: + +```js +var debug = require('debug')('worker'); + +setInterval(function(){ + debug('doing some work'); +}, 1000); +``` + + The __DEBUG__ environment variable is then used to enable these based on space or comma-delimited names. Here are some examples: + + ![debug http and worker](http://f.cl.ly/items/18471z1H402O24072r1J/Screenshot.png) + + ![debug worker](http://f.cl.ly/items/1X413v1a3M0d3C2c1E0i/Screenshot.png) + +#### Windows note + + On Windows the environment variable is set using the `set` command. + + ```cmd + set DEBUG=*,-not_this + ``` + +Then, run the program to be debugged as usual. + +## Millisecond diff + + When actively developing an application it can be useful to see when the time spent between one `debug()` call and the next. Suppose for example you invoke `debug()` before requesting a resource, and after as well, the "+NNNms" will show you how much time was spent between calls. + + ![](http://f.cl.ly/items/2i3h1d3t121M2Z1A3Q0N/Screenshot.png) + + When stdout is not a TTY, `Date#toUTCString()` is used, making it more useful for logging the debug information as shown below: + + ![](http://f.cl.ly/items/112H3i0e0o0P0a2Q2r11/Screenshot.png) + +## Conventions + + If you're using this in one or more of your libraries, you _should_ use the name of your library so that developers may toggle debugging as desired without guessing names. If you have more than one debuggers you _should_ prefix them with your library name and use ":" to separate features. For example "bodyParser" from Connect would then be "connect:bodyParser". + +## Wildcards + + The `*` character may be used as a wildcard. Suppose for example your library has debuggers named "connect:bodyParser", "connect:compress", "connect:session", instead of listing all three with `DEBUG=connect:bodyParser,connect:compress,connect:session`, you may simply do `DEBUG=connect:*`, or to run everything using this module simply use `DEBUG=*`. + + You can also exclude specific debuggers by prefixing them with a "-" character. For example, `DEBUG=*,-connect:*` would include all debuggers except those starting with "connect:". + +## Browser support + + Debug works in the browser as well, currently persisted by `localStorage`. Consider the situation shown below where you have `worker:a` and `worker:b`, and wish to debug both. Somewhere in the code on your page, include: + +```js +window.myDebug = require("debug"); +``` + + ("debug" is a global object in the browser so we give this object a different name.) When your page is open in the browser, type the following in the console: + +```js +myDebug.enable("worker:*") +``` + + Refresh the page. Debug output will continue to be sent to the console until it is disabled by typing `myDebug.disable()` in the console. + +```js +a = debug('worker:a'); +b = debug('worker:b'); + +setInterval(function(){ + a('doing some work'); +}, 1000); + +setInterval(function(){ + b('doing some work'); +}, 1200); +``` + +#### Web Inspector Colors + + Colors are also enabled on "Web Inspectors" that understand the `%c` formatting + option. These are WebKit web inspectors, Firefox ([since version + 31](https://hacks.mozilla.org/2014/05/editable-box-model-multiple-selection-sublime-text-keys-much-more-firefox-developer-tools-episode-31/)) + and the Firebug plugin for Firefox (any version). + + Colored output looks something like: + + ![](https://cloud.githubusercontent.com/assets/71256/3139768/b98c5fd8-e8ef-11e3-862a-f7253b6f47c6.png) + +### stderr vs stdout + +You can set an alternative logging method per-namespace by overriding the `log` method on a per-namespace or globally: + +Example _stdout.js_: + +```js +var debug = require('debug'); +var error = debug('app:error'); + +// by default stderr is used +error('goes to stderr!'); + +var log = debug('app:log'); +// set this namespace to log via console.log +log.log = console.log.bind(console); // don't forget to bind to console! +log('goes to stdout'); +error('still goes to stderr!'); + +// set all output to go via console.info +// overrides all per-namespace log settings +debug.log = console.info.bind(console); +error('now goes to stdout via console.info'); +log('still goes to stdout, but via console.info now'); +``` + +### Save debug output to a file + +You can save all debug statements to a file by piping them. + +Example: + +```bash +$ DEBUG_FD=3 node your-app.js 3> whatever.log +``` + +## Authors + + - TJ Holowaychuk + - Nathan Rajlich + +## License + +(The MIT License) + +Copyright (c) 2014 TJ Holowaychuk <tj@vision-media.ca> + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/socket.io/node_modules/debug/bower.json b/node_modules/socket.io/node_modules/debug/bower.json new file mode 100644 index 0000000..6af573f --- /dev/null +++ b/node_modules/socket.io/node_modules/debug/bower.json @@ -0,0 +1,28 @@ +{ + "name": "visionmedia-debug", + "main": "dist/debug.js", + "version": "2.2.0", + "homepage": "https://github.com/visionmedia/debug", + "authors": [ + "TJ Holowaychuk " + ], + "description": "visionmedia-debug", + "moduleType": [ + "amd", + "es6", + "globals", + "node" + ], + "keywords": [ + "visionmedia", + "debug" + ], + "license": "MIT", + "ignore": [ + "**/.*", + "node_modules", + "bower_components", + "test", + "tests" + ] +} diff --git a/node_modules/socket.io/node_modules/debug/browser.js b/node_modules/socket.io/node_modules/debug/browser.js new file mode 100644 index 0000000..7c76452 --- /dev/null +++ b/node_modules/socket.io/node_modules/debug/browser.js @@ -0,0 +1,168 @@ + +/** + * This is the web browser implementation of `debug()`. + * + * Expose `debug()` as the module. + */ + +exports = module.exports = require('./debug'); +exports.log = log; +exports.formatArgs = formatArgs; +exports.save = save; +exports.load = load; +exports.useColors = useColors; +exports.storage = 'undefined' != typeof chrome + && 'undefined' != typeof chrome.storage + ? chrome.storage.local + : localstorage(); + +/** + * Colors. + */ + +exports.colors = [ + 'lightseagreen', + 'forestgreen', + 'goldenrod', + 'dodgerblue', + 'darkorchid', + 'crimson' +]; + +/** + * Currently only WebKit-based Web Inspectors, Firefox >= v31, + * and the Firebug extension (any Firefox version) are known + * to support "%c" CSS customizations. + * + * TODO: add a `localStorage` variable to explicitly enable/disable colors + */ + +function useColors() { + // is webkit? http://stackoverflow.com/a/16459606/376773 + return ('WebkitAppearance' in document.documentElement.style) || + // is firebug? http://stackoverflow.com/a/398120/376773 + (window.console && (console.firebug || (console.exception && console.table))) || + // is firefox >= v31? + // https://developer.mozilla.org/en-US/docs/Tools/Web_Console#Styling_messages + (navigator.userAgent.toLowerCase().match(/firefox\/(\d+)/) && parseInt(RegExp.$1, 10) >= 31); +} + +/** + * Map %j to `JSON.stringify()`, since no Web Inspectors do that by default. + */ + +exports.formatters.j = function(v) { + return JSON.stringify(v); +}; + + +/** + * Colorize log arguments if enabled. + * + * @api public + */ + +function formatArgs() { + var args = arguments; + var useColors = this.useColors; + + args[0] = (useColors ? '%c' : '') + + this.namespace + + (useColors ? ' %c' : ' ') + + args[0] + + (useColors ? '%c ' : ' ') + + '+' + exports.humanize(this.diff); + + if (!useColors) return args; + + var c = 'color: ' + this.color; + args = [args[0], c, 'color: inherit'].concat(Array.prototype.slice.call(args, 1)); + + // the final "%c" is somewhat tricky, because there could be other + // arguments passed either before or after the %c, so we need to + // figure out the correct index to insert the CSS into + var index = 0; + var lastC = 0; + args[0].replace(/%[a-z%]/g, function(match) { + if ('%%' === match) return; + index++; + if ('%c' === match) { + // we only are interested in the *last* %c + // (the user may have provided their own) + lastC = index; + } + }); + + args.splice(lastC, 0, c); + return args; +} + +/** + * Invokes `console.log()` when available. + * No-op when `console.log` is not a "function". + * + * @api public + */ + +function log() { + // this hackery is required for IE8/9, where + // the `console.log` function doesn't have 'apply' + return 'object' === typeof console + && console.log + && Function.prototype.apply.call(console.log, console, arguments); +} + +/** + * Save `namespaces`. + * + * @param {String} namespaces + * @api private + */ + +function save(namespaces) { + try { + if (null == namespaces) { + exports.storage.removeItem('debug'); + } else { + exports.storage.debug = namespaces; + } + } catch(e) {} +} + +/** + * Load `namespaces`. + * + * @return {String} returns the previously persisted debug modes + * @api private + */ + +function load() { + var r; + try { + r = exports.storage.debug; + } catch(e) {} + return r; +} + +/** + * Enable namespaces listed in `localStorage.debug` initially. + */ + +exports.enable(load()); + +/** + * Localstorage attempts to return the localstorage. + * + * This is necessary because safari throws + * when a user disables cookies/localstorage + * and you attempt to access it. + * + * @return {LocalStorage} + * @api private + */ + +function localstorage(){ + try { + return window.localStorage; + } catch (e) {} +} diff --git a/node_modules/socket.io/node_modules/debug/component.json b/node_modules/socket.io/node_modules/debug/component.json new file mode 100644 index 0000000..ca10637 --- /dev/null +++ b/node_modules/socket.io/node_modules/debug/component.json @@ -0,0 +1,19 @@ +{ + "name": "debug", + "repo": "visionmedia/debug", + "description": "small debugging utility", + "version": "2.2.0", + "keywords": [ + "debug", + "log", + "debugger" + ], + "main": "browser.js", + "scripts": [ + "browser.js", + "debug.js" + ], + "dependencies": { + "rauchg/ms.js": "0.7.1" + } +} diff --git a/node_modules/socket.io/node_modules/debug/debug.js b/node_modules/socket.io/node_modules/debug/debug.js new file mode 100644 index 0000000..7571a86 --- /dev/null +++ b/node_modules/socket.io/node_modules/debug/debug.js @@ -0,0 +1,197 @@ + +/** + * This is the common logic for both the Node.js and web browser + * implementations of `debug()`. + * + * Expose `debug()` as the module. + */ + +exports = module.exports = debug; +exports.coerce = coerce; +exports.disable = disable; +exports.enable = enable; +exports.enabled = enabled; +exports.humanize = require('ms'); + +/** + * The currently active debug mode names, and names to skip. + */ + +exports.names = []; +exports.skips = []; + +/** + * Map of special "%n" handling functions, for the debug "format" argument. + * + * Valid key names are a single, lowercased letter, i.e. "n". + */ + +exports.formatters = {}; + +/** + * Previously assigned color. + */ + +var prevColor = 0; + +/** + * Previous log timestamp. + */ + +var prevTime; + +/** + * Select a color. + * + * @return {Number} + * @api private + */ + +function selectColor() { + return exports.colors[prevColor++ % exports.colors.length]; +} + +/** + * Create a debugger with the given `namespace`. + * + * @param {String} namespace + * @return {Function} + * @api public + */ + +function debug(namespace) { + + // define the `disabled` version + function disabled() { + } + disabled.enabled = false; + + // define the `enabled` version + function enabled() { + + var self = enabled; + + // set `diff` timestamp + var curr = +new Date(); + var ms = curr - (prevTime || curr); + self.diff = ms; + self.prev = prevTime; + self.curr = curr; + prevTime = curr; + + // add the `color` if not set + if (null == self.useColors) self.useColors = exports.useColors(); + if (null == self.color && self.useColors) self.color = selectColor(); + + var args = Array.prototype.slice.call(arguments); + + args[0] = exports.coerce(args[0]); + + if ('string' !== typeof args[0]) { + // anything else let's inspect with %o + args = ['%o'].concat(args); + } + + // apply any `formatters` transformations + var index = 0; + args[0] = args[0].replace(/%([a-z%])/g, function(match, format) { + // if we encounter an escaped % then don't increase the array index + if (match === '%%') return match; + index++; + var formatter = exports.formatters[format]; + if ('function' === typeof formatter) { + var val = args[index]; + match = formatter.call(self, val); + + // now we need to remove `args[index]` since it's inlined in the `format` + args.splice(index, 1); + index--; + } + return match; + }); + + if ('function' === typeof exports.formatArgs) { + args = exports.formatArgs.apply(self, args); + } + var logFn = enabled.log || exports.log || console.log.bind(console); + logFn.apply(self, args); + } + enabled.enabled = true; + + var fn = exports.enabled(namespace) ? enabled : disabled; + + fn.namespace = namespace; + + return fn; +} + +/** + * Enables a debug mode by namespaces. This can include modes + * separated by a colon and wildcards. + * + * @param {String} namespaces + * @api public + */ + +function enable(namespaces) { + exports.save(namespaces); + + var split = (namespaces || '').split(/[\s,]+/); + var len = split.length; + + for (var i = 0; i < len; i++) { + if (!split[i]) continue; // ignore empty strings + namespaces = split[i].replace(/\*/g, '.*?'); + if (namespaces[0] === '-') { + exports.skips.push(new RegExp('^' + namespaces.substr(1) + '$')); + } else { + exports.names.push(new RegExp('^' + namespaces + '$')); + } + } +} + +/** + * Disable debug output. + * + * @api public + */ + +function disable() { + exports.enable(''); +} + +/** + * Returns true if the given mode name is enabled, false otherwise. + * + * @param {String} name + * @return {Boolean} + * @api public + */ + +function enabled(name) { + var i, len; + for (i = 0, len = exports.skips.length; i < len; i++) { + if (exports.skips[i].test(name)) { + return false; + } + } + for (i = 0, len = exports.names.length; i < len; i++) { + if (exports.names[i].test(name)) { + return true; + } + } + return false; +} + +/** + * Coerce `val`. + * + * @param {Mixed} val + * @return {Mixed} + * @api private + */ + +function coerce(val) { + if (val instanceof Error) return val.stack || val.message; + return val; +} diff --git a/node_modules/socket.io/node_modules/debug/node.js b/node_modules/socket.io/node_modules/debug/node.js new file mode 100644 index 0000000..1d392a8 --- /dev/null +++ b/node_modules/socket.io/node_modules/debug/node.js @@ -0,0 +1,209 @@ + +/** + * Module dependencies. + */ + +var tty = require('tty'); +var util = require('util'); + +/** + * This is the Node.js implementation of `debug()`. + * + * Expose `debug()` as the module. + */ + +exports = module.exports = require('./debug'); +exports.log = log; +exports.formatArgs = formatArgs; +exports.save = save; +exports.load = load; +exports.useColors = useColors; + +/** + * Colors. + */ + +exports.colors = [6, 2, 3, 4, 5, 1]; + +/** + * The file descriptor to write the `debug()` calls to. + * Set the `DEBUG_FD` env variable to override with another value. i.e.: + * + * $ DEBUG_FD=3 node script.js 3>debug.log + */ + +var fd = parseInt(process.env.DEBUG_FD, 10) || 2; +var stream = 1 === fd ? process.stdout : + 2 === fd ? process.stderr : + createWritableStdioStream(fd); + +/** + * Is stdout a TTY? Colored output is enabled when `true`. + */ + +function useColors() { + var debugColors = (process.env.DEBUG_COLORS || '').trim().toLowerCase(); + if (0 === debugColors.length) { + return tty.isatty(fd); + } else { + return '0' !== debugColors + && 'no' !== debugColors + && 'false' !== debugColors + && 'disabled' !== debugColors; + } +} + +/** + * Map %o to `util.inspect()`, since Node doesn't do that out of the box. + */ + +var inspect = (4 === util.inspect.length ? + // node <= 0.8.x + function (v, colors) { + return util.inspect(v, void 0, void 0, colors); + } : + // node > 0.8.x + function (v, colors) { + return util.inspect(v, { colors: colors }); + } +); + +exports.formatters.o = function(v) { + return inspect(v, this.useColors) + .replace(/\s*\n\s*/g, ' '); +}; + +/** + * Adds ANSI color escape codes if enabled. + * + * @api public + */ + +function formatArgs() { + var args = arguments; + var useColors = this.useColors; + var name = this.namespace; + + if (useColors) { + var c = this.color; + + args[0] = ' \u001b[3' + c + ';1m' + name + ' ' + + '\u001b[0m' + + args[0] + '\u001b[3' + c + 'm' + + ' +' + exports.humanize(this.diff) + '\u001b[0m'; + } else { + args[0] = new Date().toUTCString() + + ' ' + name + ' ' + args[0]; + } + return args; +} + +/** + * Invokes `console.error()` with the specified arguments. + */ + +function log() { + return stream.write(util.format.apply(this, arguments) + '\n'); +} + +/** + * Save `namespaces`. + * + * @param {String} namespaces + * @api private + */ + +function save(namespaces) { + if (null == namespaces) { + // If you set a process.env field to null or undefined, it gets cast to the + // string 'null' or 'undefined'. Just delete instead. + delete process.env.DEBUG; + } else { + process.env.DEBUG = namespaces; + } +} + +/** + * Load `namespaces`. + * + * @return {String} returns the previously persisted debug modes + * @api private + */ + +function load() { + return process.env.DEBUG; +} + +/** + * Copied from `node/src/node.js`. + * + * XXX: It's lame that node doesn't expose this API out-of-the-box. It also + * relies on the undocumented `tty_wrap.guessHandleType()` which is also lame. + */ + +function createWritableStdioStream (fd) { + var stream; + var tty_wrap = process.binding('tty_wrap'); + + // Note stream._type is used for test-module-load-list.js + + switch (tty_wrap.guessHandleType(fd)) { + case 'TTY': + stream = new tty.WriteStream(fd); + stream._type = 'tty'; + + // Hack to have stream not keep the event loop alive. + // See https://github.com/joyent/node/issues/1726 + if (stream._handle && stream._handle.unref) { + stream._handle.unref(); + } + break; + + case 'FILE': + var fs = require('fs'); + stream = new fs.SyncWriteStream(fd, { autoClose: false }); + stream._type = 'fs'; + break; + + case 'PIPE': + case 'TCP': + var net = require('net'); + stream = new net.Socket({ + fd: fd, + readable: false, + writable: true + }); + + // FIXME Should probably have an option in net.Socket to create a + // stream from an existing fd which is writable only. But for now + // we'll just add this hack and set the `readable` member to false. + // Test: ./node test/fixtures/echo.js < /etc/passwd + stream.readable = false; + stream.read = null; + stream._type = 'pipe'; + + // FIXME Hack to have stream not keep the event loop alive. + // See https://github.com/joyent/node/issues/1726 + if (stream._handle && stream._handle.unref) { + stream._handle.unref(); + } + break; + + default: + // Probably an error on in uv_guess_handle() + throw new Error('Implement me. Unknown stream file type!'); + } + + // For supporting legacy API we put the FD here. + stream.fd = fd; + + stream._isStdio = true; + + return stream; +} + +/** + * Enable namespaces listed in `process.env.DEBUG` initially. + */ + +exports.enable(load()); diff --git a/node_modules/socket.io/node_modules/debug/node_modules/ms/.npmignore b/node_modules/socket.io/node_modules/debug/node_modules/ms/.npmignore new file mode 100644 index 0000000..d1aa0ce --- /dev/null +++ b/node_modules/socket.io/node_modules/debug/node_modules/ms/.npmignore @@ -0,0 +1,5 @@ +node_modules +test +History.md +Makefile +component.json diff --git a/node_modules/socket.io/node_modules/debug/node_modules/ms/History.md b/node_modules/socket.io/node_modules/debug/node_modules/ms/History.md new file mode 100644 index 0000000..32fdfc1 --- /dev/null +++ b/node_modules/socket.io/node_modules/debug/node_modules/ms/History.md @@ -0,0 +1,66 @@ + +0.7.1 / 2015-04-20 +================== + + * prevent extraordinary long inputs (@evilpacket) + * Fixed broken readme link + +0.7.0 / 2014-11-24 +================== + + * add time abbreviations, updated tests and readme for the new units + * fix example in the readme. + * add LICENSE file + +0.6.2 / 2013-12-05 +================== + + * Adding repository section to package.json to suppress warning from NPM. + +0.6.1 / 2013-05-10 +================== + + * fix singularization [visionmedia] + +0.6.0 / 2013-03-15 +================== + + * fix minutes + +0.5.1 / 2013-02-24 +================== + + * add component namespace + +0.5.0 / 2012-11-09 +================== + + * add short formatting as default and .long option + * add .license property to component.json + * add version to component.json + +0.4.0 / 2012-10-22 +================== + + * add rounding to fix crazy decimals + +0.3.0 / 2012-09-07 +================== + + * fix `ms()` [visionmedia] + +0.2.0 / 2012-09-03 +================== + + * add component.json [visionmedia] + * add days support [visionmedia] + * add hours support [visionmedia] + * add minutes support [visionmedia] + * add seconds support [visionmedia] + * add ms string support [visionmedia] + * refactor tests to facilitate ms(number) [visionmedia] + +0.1.0 / 2012-03-07 +================== + + * Initial release diff --git a/node_modules/socket.io/node_modules/debug/node_modules/ms/LICENSE b/node_modules/socket.io/node_modules/debug/node_modules/ms/LICENSE new file mode 100644 index 0000000..6c07561 --- /dev/null +++ b/node_modules/socket.io/node_modules/debug/node_modules/ms/LICENSE @@ -0,0 +1,20 @@ +(The MIT License) + +Copyright (c) 2014 Guillermo Rauch + +Permission is hereby granted, free of charge, to any person obtaining a copy of +this software and associated documentation files (the "Software"), to deal in +the Software without restriction, including without limitation the rights to +use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of +the Software, and to permit persons to whom the Software is furnished to do so, +subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS +FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR +COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER +IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN +CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/socket.io/node_modules/debug/node_modules/ms/README.md b/node_modules/socket.io/node_modules/debug/node_modules/ms/README.md new file mode 100644 index 0000000..9b4fd03 --- /dev/null +++ b/node_modules/socket.io/node_modules/debug/node_modules/ms/README.md @@ -0,0 +1,35 @@ +# ms.js: miliseconds conversion utility + +```js +ms('2 days') // 172800000 +ms('1d') // 86400000 +ms('10h') // 36000000 +ms('2.5 hrs') // 9000000 +ms('2h') // 7200000 +ms('1m') // 60000 +ms('5s') // 5000 +ms('100') // 100 +``` + +```js +ms(60000) // "1m" +ms(2 * 60000) // "2m" +ms(ms('10 hours')) // "10h" +``` + +```js +ms(60000, { long: true }) // "1 minute" +ms(2 * 60000, { long: true }) // "2 minutes" +ms(ms('10 hours'), { long: true }) // "10 hours" +``` + +- Node/Browser compatible. Published as [`ms`](https://www.npmjs.org/package/ms) in [NPM](http://nodejs.org/download). +- If a number is supplied to `ms`, a string with a unit is returned. +- If a string that contains the number is supplied, it returns it as +a number (e.g: it returns `100` for `'100'`). +- If you pass a string with a number and a valid unit, the number of +equivalent ms is returned. + +## License + +MIT diff --git a/node_modules/socket.io/node_modules/debug/node_modules/ms/index.js b/node_modules/socket.io/node_modules/debug/node_modules/ms/index.js new file mode 100644 index 0000000..4f92771 --- /dev/null +++ b/node_modules/socket.io/node_modules/debug/node_modules/ms/index.js @@ -0,0 +1,125 @@ +/** + * Helpers. + */ + +var s = 1000; +var m = s * 60; +var h = m * 60; +var d = h * 24; +var y = d * 365.25; + +/** + * Parse or format the given `val`. + * + * Options: + * + * - `long` verbose formatting [false] + * + * @param {String|Number} val + * @param {Object} options + * @return {String|Number} + * @api public + */ + +module.exports = function(val, options){ + options = options || {}; + if ('string' == typeof val) return parse(val); + return options.long + ? long(val) + : short(val); +}; + +/** + * Parse the given `str` and return milliseconds. + * + * @param {String} str + * @return {Number} + * @api private + */ + +function parse(str) { + str = '' + str; + if (str.length > 10000) return; + var match = /^((?:\d+)?\.?\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|years?|yrs?|y)?$/i.exec(str); + if (!match) return; + var n = parseFloat(match[1]); + var type = (match[2] || 'ms').toLowerCase(); + switch (type) { + case 'years': + case 'year': + case 'yrs': + case 'yr': + case 'y': + return n * y; + case 'days': + case 'day': + case 'd': + return n * d; + case 'hours': + case 'hour': + case 'hrs': + case 'hr': + case 'h': + return n * h; + case 'minutes': + case 'minute': + case 'mins': + case 'min': + case 'm': + return n * m; + case 'seconds': + case 'second': + case 'secs': + case 'sec': + case 's': + return n * s; + case 'milliseconds': + case 'millisecond': + case 'msecs': + case 'msec': + case 'ms': + return n; + } +} + +/** + * Short format for `ms`. + * + * @param {Number} ms + * @return {String} + * @api private + */ + +function short(ms) { + if (ms >= d) return Math.round(ms / d) + 'd'; + if (ms >= h) return Math.round(ms / h) + 'h'; + if (ms >= m) return Math.round(ms / m) + 'm'; + if (ms >= s) return Math.round(ms / s) + 's'; + return ms + 'ms'; +} + +/** + * Long format for `ms`. + * + * @param {Number} ms + * @return {String} + * @api private + */ + +function long(ms) { + return plural(ms, d, 'day') + || plural(ms, h, 'hour') + || plural(ms, m, 'minute') + || plural(ms, s, 'second') + || ms + ' ms'; +} + +/** + * Pluralization helper. + */ + +function plural(ms, n, name) { + if (ms < n) return; + if (ms < n * 1.5) return Math.floor(ms / n) + ' ' + name; + return Math.ceil(ms / n) + ' ' + name + 's'; +} diff --git a/node_modules/socket.io/node_modules/debug/node_modules/ms/package.json b/node_modules/socket.io/node_modules/debug/node_modules/ms/package.json new file mode 100644 index 0000000..fb39012 --- /dev/null +++ b/node_modules/socket.io/node_modules/debug/node_modules/ms/package.json @@ -0,0 +1,47 @@ +{ + "name": "ms", + "version": "0.7.1", + "description": "Tiny ms conversion utility", + "repository": { + "type": "git", + "url": "git://github.com/guille/ms.js.git" + }, + "main": "./index", + "devDependencies": { + "mocha": "*", + "expect.js": "*", + "serve": "*" + }, + "component": { + "scripts": { + "ms/index.js": "index.js" + } + }, + "gitHead": "713dcf26d9e6fd9dbc95affe7eff9783b7f1b909", + "bugs": { + "url": "https://github.com/guille/ms.js/issues" + }, + "homepage": "https://github.com/guille/ms.js", + "_id": "ms@0.7.1", + "scripts": {}, + "_shasum": "9cd13c03adbff25b65effde7ce864ee952017098", + "_from": "ms@0.7.1", + "_npmVersion": "2.7.5", + "_nodeVersion": "0.12.2", + "_npmUser": { + "name": "rauchg", + "email": "rauchg@gmail.com" + }, + "maintainers": [ + { + "name": "rauchg", + "email": "rauchg@gmail.com" + } + ], + "dist": { + "shasum": "9cd13c03adbff25b65effde7ce864ee952017098", + "tarball": "https://registry.npmjs.org/ms/-/ms-0.7.1.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/ms/-/ms-0.7.1.tgz" +} diff --git a/node_modules/socket.io/node_modules/debug/package.json b/node_modules/socket.io/node_modules/debug/package.json new file mode 100644 index 0000000..15db0a6 --- /dev/null +++ b/node_modules/socket.io/node_modules/debug/package.json @@ -0,0 +1,72 @@ +{ + "name": "debug", + "version": "2.2.0", + "repository": { + "type": "git", + "url": "git://github.com/visionmedia/debug.git" + }, + "description": "small debugging utility", + "keywords": [ + "debug", + "log", + "debugger" + ], + "author": { + "name": "TJ Holowaychuk", + "email": "tj@vision-media.ca" + }, + "contributors": [ + { + "name": "Nathan Rajlich", + "email": "nathan@tootallnate.net", + "url": "http://n8.io" + } + ], + "license": "MIT", + "dependencies": { + "ms": "0.7.1" + }, + "devDependencies": { + "browserify": "9.0.3", + "mocha": "*" + }, + "main": "./node.js", + "browser": "./browser.js", + "component": { + "scripts": { + "debug/index.js": "browser.js", + "debug/debug.js": "debug.js" + } + }, + "gitHead": "b38458422b5aa8aa6d286b10dfe427e8a67e2b35", + "bugs": { + "url": "https://github.com/visionmedia/debug/issues" + }, + "homepage": "https://github.com/visionmedia/debug", + "_id": "debug@2.2.0", + "scripts": {}, + "_shasum": "f87057e995b1a1f6ae6a4960664137bc56f039da", + "_from": "debug@2.2.0", + "_npmVersion": "2.7.4", + "_nodeVersion": "0.12.2", + "_npmUser": { + "name": "tootallnate", + "email": "nathan@tootallnate.net" + }, + "maintainers": [ + { + "name": "tjholowaychuk", + "email": "tj@vision-media.ca" + }, + { + "name": "tootallnate", + "email": "nathan@tootallnate.net" + } + ], + "dist": { + "shasum": "f87057e995b1a1f6ae6a4960664137bc56f039da", + "tarball": "https://registry.npmjs.org/debug/-/debug-2.2.0.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/debug/-/debug-2.2.0.tgz" +} diff --git a/node_modules/socket.io/node_modules/engine.io/History.md b/node_modules/socket.io/node_modules/engine.io/History.md new file mode 100644 index 0000000..169057f --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/History.md @@ -0,0 +1,528 @@ + +1.7.2 / 2016-10-24 +=================== + + * [docs] Add missing `upgradeTimeout` option in the docs (#437) + * [chore] Add Github issue and PR templates (#436) + +1.7.1 / 2016-10-20 +=================== + + * [fix] Close and free webSocketServer (#393) + * [chore] Bump engine.io-client to 1.7.0 (#429) + * [chore] Bump engine.io-parser to 1.3.1 (#433) + * [chore] Add latest nodejs release in travis settings (#434) + +1.7.0 / 2016-10-05 +=================== + + * [feature] Give the ability to dynamically choose ws implementation (#390) + * [chore] Add gulp & babel in the build process (#384) + * [chore] Ignore dist not to release for now (#387) + * [chore] Upgrade accepts to 1.3.3 + * [chore] Bumping ws to 1.1.1 to address https://nodesecurity.io/advisories/120 (#411) + * [chore] Restoring require('ws') as separate expression for browserify. (#418) + * [chore] Bump engine.io-parser to 1.3.0 (#425) + * [chore] Make the build status badge point towards master (#426) + * [chore] Restrict files included in npm package (#427) + +1.6.11 / 2016-06-23 +=================== + + * package: bump `ws` to support `maxPayload` + +1.6.10 / 2016-06-23 +=================== + + * set a default ws `maxPayload` [security fix] + * bump `accepts` [security fix] + +1.6.9 / 2016-05-03 +================== + + * bump client + +1.6.8 / 2016-01-25 +================== + + * fix graceful close [nkzawa] + * polling: don't set the `closeTimeoutTimer` if the transport is upgraded + +1.6.7 / 2016-01-10 +================== + + * bump version + +1.6.6 / 2016-01-07 +================== + + * bump version + +1.6.5 / 2016-01-05 +================== + + * package: upgrade ws for sec advisory + * server: catch websocket errors before upgrade + +1.6.4 / 2015-12-04 +================== + + * package: bump parser for arraybuffer base64 fix + +1.6.3 / 2015-12-01 +================== + + * restore testing on 0.8 + * improve X-XSS-Protection header definition [nkzawa] + * add threshold for permessage-deflate [nkzawa] + +1.6.2 / 2015-11-30 +================== + + * don't compress control packets + +1.6.1 / 2015-11-28 +================== + + * package: bump `engine.io-client` for `ws` options fix + * fix `latency` example + +1.6.0 / 2015-11-28 +================== + + * add support for environments that extend `Object.prototype` + * remove listeners upon `clearTransport` + * support for all versions of node + * fix lingering sockets that can stay open when upgrade failed + * ensure sockets are closed on error + * bump `ws` for several improvements + * fix for a rare race condition on some error scenarios + * support custom socket id + * use container-based infrastructure for faster build + * fix package.json wrongly referrering to self + * allow overriding the `cookiePath` + * fix potential encoding errors under certain conditions + * support compression + +1.5.4 / 2015-09-09 +================== + + * package: bump `engine.io-parser` + +1.5.3 / 2015-09-09 +================== + + * package: bump `ws` to fix node 4.0.0 + +1.5.2 / 2015-07-09 +================== + + * package: bump `ws` to fix build issues + +1.5.1 / 2015-01-19 +================== + + * no change on this release + * package: bump `engine.io-client` + +1.5.0 / 2015-01-18 +================== + + * package: bump `engine.io-parser` + * polling: correctly abort the ongoing data request when closing [lpinca] + * add cert-related client tests [rase-] + +1.4.3 / 2014-11-21 +================== + + * package: bump `ws` to fix fd leaks + * socket: flush the write buffer before closing the socket [lpinca] + * polling: close the pending poll request when closing transport [lpinca] + +1.4.2 / 2014-10-08 +================== + + * add iframe onload handling to jsonp tests [rase-] + +1.4.1 / 2014-10-03 +================== + + * socket: allow upgrades if the socket is still in closing state + * README: fix typo + +1.4.0 / 2014-09-03 +================== + + * readme: fix formatting for goals numbering + * server: ref fix by @nicokaiser + * server: fix ws memory leak (fixes #268) + * cache remote address in handshake since it might be lost later. + * correct git ref + * update client to commit with bumped parser + * package: bump parser + * npmignore: ignore `.gitignore` + * package: bump `debug` + * package: bump `engine.io-parser` for memleak fix + +1.3.1 / 2014-06-19 +================== + + * package: bump `engine.io-client` + +1.3.0 / 2014-06-13 +================== + + * update example to use v1.2.2 + * fixed newline parsing in jsonp + * make require('engine.io')() return a new Server instance [defunctzombie] + * add Server.attach method [defunctzombie] + * fix GH-211, set CORS headers when sending error message [mokesmokes] + +1.2.2 / 2014-05-30 +================== + + * package: bump `engine.io-parser` for binary utf8 fix + +1.2.1 / 2014-05-22 +================== + + * package: bump engine.io-client + +1.2.0 / 2014-05-18 +================== + + * removed flashsocket, moving to userland + +1.1.1 / 2014-05-14 +================== + + * test: reduce packet size + * package: bump parser + +1.1.0 / 2014-04-27 +================== + + * socket: removed unneeded `clearTimeout` (fixes #250) + * made the request verification process async + * package: bump `engine.io-parser` + * use _query instead of query, fixes compat with restify + * added a maximum buffer size to received data from polling + * fixing looping array via for in to normal loop + +1.0.5 / 2014-03-18 +================== + + * package: bump `engine.io-parser` and `engine.io-client` + +1.0.4 / 2014-03-14 +================== + + * package: bump `engine.io-client` + +1.0.3 / 2014-03-12 +================== + + * package: bump `engine.io-client` + +1.0.2 / 2014-03-12 +================== + + * bump engine.io-client + +1.0.1 / 2014-03-06 +================== + + * package: bump `engine.io-parser` + * transports: fix jshint warnings and style + +1.0.0 / 2014-03-06 +================== + + * polling-xhr: added `OPTIONS` support, fixes CORS + * close() properly when triggered in connection handler + * fix DDOS vector by setting up too many intervals + * binary support + +0.9.0 / 2014-02-09 +================== + + * Prevent errors with connections behind proxies without WS support + like Squid [nicklagrow, samaanghani, davidhcummings] + * Socket#request a simple property [mokesmokes] + * Changed `Socket`'s `upgrade` event to happen after upgrade [mokesmokes] + * Document `Socket#id` [mokesmokes] + +0.8.2 / 2014-01-18 +================== + + * package: bump `engine.io-client` + +0.8.1 / 2014-01-17 +================== + + * package: bump `engine.io-client` + * package: pin dev deps + * examples: fix port output + * fix latency example + +0.8.0 / 2014-01-05 +================== + + * package: bump `engine.io-client` to `0.8.0` + * test: fix syntax, remove globals + +0.7.14 / 2014-01-01 +=================== + + * package: bump `engine.io-client` to `0.7.14` + +0.7.13 / 2013-12-20 +=================== + + * package: bump `engine.io-client` + * transports: added support for XSS filters on IE [guille, 3rd-eden] + +0.7.12 / 2013-11-11 +=================== + + * package: bump `engine.io-client` + +0.7.11 / 2013-11-06 +=================== + + * package: bump engine.io-client + * fix GH-198 + +0.7.10 / 2013-10-28 +=================== + + * package: bump `engine.io-client` + * package: update "ws" to v0.4.31 + +0.7.9 / 2013-08-30 +================== + + * package: bump `engine.io-client` + +0.7.8 / 2013-08-30 +================== + + * package: bump `engine.io-client` + * package: bump ws + +0.7.7 / 2013-08-30 +================== + + * package: bump `engine.io-client` + +0.7.6 / 2013-08-30 +================== + + * package: bump engine.io-client + +0.7.5 / 2013-08-30 +================== + + * package: bump engine.io-client + +0.7.4 / 2013-08-25 +================== + + * package: bump `engine.io-client` + +0.7.3 / 2013-08-23 +================== + + * package: bump engine.io-client (noop) + * package: fix regresison in upgrade cause by ws update + +0.7.2 / 2013-08-23 +================== + + * package: bump `engine.io-client` for `WebSocket` browser fix + +0.7.1 / 2013-08-23 +================== + + * package: bump engine.io-client for ws fix + +0.7.0 / 2013-08-23 +================== + + * package: bump engine.io-client + * updated example + * inline merge + * added support node version 0.10 to .travis.yml + * fixed respond to flash policy request test. Closes #184 + * fixed upgrade with timeout test. Closes #185 + * engine.io: don't use __proto__, closes #170 + +0.6.3 / 2013-06-21 +================== + + * package: bumped `engine.io-client` to `0.6.3` + +0.6.2 / 2013-06-15 +================== + + * fix upgrade stalling edge case introduced with #174 fix + * remove unneeded client code related to iOS + * added test for `engine.io-client` `0.6.1` + +0.6.1 / 2013-06-06 +================== + + * package: bumped `engine.io-client` to `0.6.1` + +0.6.0 / 2013-05-31 +================== + + * socket: clear timer after sending one noop packet (fixes #174) + * clear all timers on socket close + * sending error on transport creation upon a bad request + * added test for client-side buffer cleanup + * changed flushComplete to flush + * ended support for node 0.6 + +0.5.0 / 2013-03-16 +================== + + * polling: implemented new parser + * test writeBuffer isn't cleared onError, removed 'closing' check in .flush() + * fixed bug89 and added tests: writeBuffer not flushed until nextTick + +0.4.3 / 2013-02-08 +================== + + * package: bumped `engine.io-client` to `0.4.3` + +0.4.2 / 2013-02-08 +================== + + * Only end upgrade socket connections if unhandled + * Fix websocket dependency + * Close socket if upgrade is received and socket.readyState != open + +0.4.1 / 2013-01-18 +================== + + * package: bumped versions + * Fixed bugs in previous send callback fix and updated test cases + * Added a test case which makes the code before the send callback fix fail + * socket: emit `data` event (synonym with `message`) + * socket: added `Socket#write` + * engine.io: cleanup + * engine.io: deprecated `resource` + * `npm docs engine.io` works now + +0.3.10 / 2012-12-03 +=================== + + * package: bumped `engine.io-client` with `close` fixes + * add packetCreate event [jxck] + * add packet event to socket [jxck] + * transport: remove `Connection` headers and let node handle it + * server: send validation failure reason to clients + * engine: invoking as a function causes attach + * socket: reset `writeBuffer` before send + +0.3.9 / 2012-10-23 +================== + + * package: bumped `engine.io-client` + +0.3.8 / 2012-10-23 +================== + + * package: bumped engine.io-client + * examples: added first example + +0.3.7 / 2012-10-21 +================== + + * package: bumped `engine.io-client` + +0.3.6 / 2012-10-21 +================== + + [skipped] + +0.3.5 / 2012-10-14 +================== + + * package: reverted last commit - we use the parser from the client + +0.3.4 / 2012-10-14 +================== + + * package: `engine.io-client` moved to `devDependencies` + * socket: added missing jsdoc + +0.3.3 / 2012-10-10 +================== + + * socket: fixed check interval clearing [joewalnes] + * transports: improved instrumentation + +0.3.2 / 2012-10-08 +================== + + * socket: improve check interval for upgrade + +0.3.1 / 2012-10-08 +================== + + * socket: faster upgrades (we perform a check immediately) + * server: don't assume sid is numeric + +0.3.0 / 2012-10-04 +================== + + * socket: `writeBuffer` now gets sliced, and is recoverable after `close` [afshinm] + * server: expect ping from client and send interval with handshake [cadorn] + * polling-jsonp: prevent client breakage with utf8 whitespace + * socket: fix `flush` and `drain` events + * socket: add `send` callback [afshinm] + * transport: avoid unhandled error events for stale transports + * README: documentation improvements [EugenDueck] + +0.2.2 / 2012-08-26 +================== + + * server: remove buffering for flash policy requests + * transport: avoid unhandled error events for stale transports (fixes #69) + * readme: documented `toString` behavior on `send` [EugenDueck] + +0.2.1 / 2012-08-13 +================== + + * polling-xhr: skip Keep-Alive when it's implied [EugenDueck] + * polling-jsonp: skip Keep-Alive when it's implied [EugenDueck] + * README: added plugins list with engine.io-conflation + * socket: added flush/drain events (fixes #56) + * server: avoid passing websocket to non-websocket transports (fixes #24) + +0.2.0 / 2012-08-06 +================== + + * Bumped client + * test: added closing connection test + * server: implemented stronger id generator with collision detection + +0.1.2 / 2012-08-02 +================== + + * Fixed a jsonp bug in Nokia mobile phones and potentially other UAs. + +0.1.1 / 2012-08-01 +================== + + * Fixed errors when a socket is closed while upgrade probe is happening. + * Improved WS error handling + * Replaced websocket.io with ws, now that it supports older drafts + * README fixes + +0.1.0 / 2012-07-03 +================== + + * Initial release. diff --git a/node_modules/socket.io/node_modules/engine.io/LICENSE b/node_modules/socket.io/node_modules/engine.io/LICENSE new file mode 100644 index 0000000..6494c3c --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/LICENSE @@ -0,0 +1,19 @@ +(The MIT License) + +Copyright (c) 2014 Guillermo Rauch + +Permission is hereby granted, free of charge, to any person obtaining a copy of this software +and associated documentation files (the 'Software'), to deal in the Software without restriction, +including without limitation the rights to use, copy, modify, merge, publish, distribute, +sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all copies or +substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING +BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND +NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, +DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + diff --git a/node_modules/socket.io/node_modules/engine.io/README.md b/node_modules/socket.io/node_modules/engine.io/README.md new file mode 100644 index 0000000..7e0c0fb --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/README.md @@ -0,0 +1,536 @@ + +# Engine.IO: the realtime engine + +[![Build Status](https://travis-ci.org/socketio/engine.io.svg?branch=master)](http://travis-ci.org/socketio/engine.io) +[![NPM version](https://badge.fury.io/js/engine.io.svg)](http://badge.fury.io/js/engine.io) + +`Engine.IO` is the implementation of transport-based +cross-browser/cross-device bi-directional communication layer for +[Socket.IO](http://github.com/socketio/socket.io). + +## How to use + +### Server + +#### (A) Listening on a port + +```js +var engine = require('engine.io'); +var server = engine.listen(80); + +server.on('connection', function(socket){ + socket.send('utf 8 string'); + socket.send(new Buffer([0, 1, 2, 3, 4, 5])); // binary data +}); +``` + +#### (B) Intercepting requests for a http.Server + +```js +var engine = require('engine.io'); +var http = require('http').createServer().listen(3000); +var server = engine.attach(http); + +server.on('connection', function (socket) { + socket.on('message', function(data){ }); + socket.on('close', function(){ }); +}); +``` + +#### (C) Passing in requests + +```js +var engine = require('engine.io'); +var server = new engine.Server(); + +server.on('connection', function(socket){ + socket.send('hi'); +}); + +// … +httpServer.on('upgrade', function(req, socket, head){ + server.handleUpgrade(req, socket, head); +}); +httpServer.on('request', function(req, res){ + server.handleRequest(req, res); +}); +``` + +### Client + +```html + + +``` + +For more information on the client refer to the +[engine-client](http://github.com/learnboost/engine.io-client) repository. + +## What features does it have? + +- **Maximum reliability**. Connections are established even in the presence of: + - proxies and load balancers. + - personal firewall and antivirus software. + - for more information refer to **Goals** and **Architecture** sections +- **Minimal client size** aided by: + - lazy loading of flash transports. + - lack of redundant transports. +- **Scalable** + - load balancer friendly +- **Future proof** +- **100% Node.JS core style** + - No API sugar (left for higher level projects) + - Written in readable vanilla JavaScript + +## API + +### Server + +

              + +#### Top-level + +These are exposed by `require('engine.io')`: + +##### Events + +- `flush` + - Called when a socket buffer is being flushed. + - **Arguments** + - `Socket`: socket being flushed + - `Array`: write buffer +- `drain` + - Called when a socket buffer is drained + - **Arguments** + - `Socket`: socket being flushed + +##### Properties + +- `protocol` _(Number)_: protocol revision number +- `Server`: Server class constructor +- `Socket`: Socket class constructor +- `Transport` _(Function)_: transport constructor +- `transports` _(Object)_: map of available transports + +##### Methods + +- `()` + - Returns a new `Server` instance. If the first argument is an `http.Server` then the + new `Server` instance will be attached to it. Otherwise, the arguments are passed + directly to the `Server` constructor. + - **Parameters** + - `http.Server`: optional, server to attach to. + - `Object`: optional, options object (see `Server#constructor` api docs below) + + The following are identical ways to instantiate a server and then attach it. + ```js + var httpServer; // previously created with `http.createServer();` from node.js api. + + // create a server first, and then attach + var eioServer = require('engine.io').Server(); + eioServer.attach(httpServer); + + // or call the module as a function to get `Server` + var eioServer = require('engine.io')(); + eioServer.attach(httpServer); + + // immediately attach + var eioServer = require('engine.io')(httpServer); + ``` + +- `listen` + - Creates an `http.Server` which listens on the given port and attaches WS + to it. It returns `501 Not Implemented` for regular http requests. + - **Parameters** + - `Number`: port to listen on. + - `Object`: optional, options object + - `Function`: callback for `listen`. + - **Options** + - All options from `Server.attach` method, documented below. + - **Additionally** See Server `constructor` below for options you can pass for creating the new Server + - **Returns** `Server` +- `attach` + - Captures `upgrade` requests for a `http.Server`. In other words, makes + a regular http.Server WebSocket-compatible. + - **Parameters** + - `http.Server`: server to attach to. + - `Object`: optional, options object + - **Options** + - All options from `Server.attach` method, documented below. + - **Additionally** See Server `constructor` below for options you can pass for creating the new Server + - **Returns** `Server` a new Server instance. + +

              + +#### Server + +The main server/manager. _Inherits from EventEmitter_. + +##### Events + +- `connection` + - Fired when a new connection is established. + - **Arguments** + - `Socket`: a Socket object + +##### Properties + +**Important**: if you plan to use Engine.IO in a scalable way, please +keep in mind the properties below will only reflect the clients connected +to a single process. + +- `clients` _(Object)_: hash of connected clients by id. +- `clientsCount` _(Number)_: number of connected clients. + +##### Methods + +- **constructor** + - Initializes the server + - **Parameters** + - `Object`: optional, options object + - **Options** + - `pingTimeout` (`Number`): how many ms without a pong packet to + consider the connection closed (`60000`) + - `pingInterval` (`Number`): how many ms before sending a new ping + packet (`25000`) + - `upgradeTimeout` (`Number`): how many ms before an uncompleted transport upgrade is cancelled (`10000`) + - `maxHttpBufferSize` (`Number`): how many bytes or characters a message + can be when polling, before closing the session (to avoid DoS). Default + value is `10E7`. + - `allowRequest` (`Function`): A function that receives a given handshake + or upgrade request as its first parameter, and can decide whether to + continue or not. The second argument is a function that needs to be + called with the decided information: `fn(err, success)`, where + `success` is a boolean value where false means that the request is + rejected, and err is an error code. + - `transports` (` String`): transports to allow connections + to (`['polling', 'websocket']`) + - `allowUpgrades` (`Boolean`): whether to allow transport upgrades + (`true`) + - `perMessageDeflate` (`Object|Boolean`): parameters of the WebSocket permessage-deflate extension + (see [ws module](https://github.com/einaros/ws) api docs). Set to `false` to disable. (`true`) + - `threshold` (`Number`): data is compressed only if the byte size is above this value (`1024`) + - `httpCompression` (`Object|Boolean`): parameters of the http compression for the polling transports + (see [zlib](http://nodejs.org/api/zlib.html#zlib_options) api docs). Set to `false` to disable. (`true`) + - `threshold` (`Number`): data is compressed only if the byte size is above this value (`1024`) + - `cookie` (`String|Boolean`): name of the HTTP cookie that + contains the client sid to send as part of handshake response + headers. Set to `false` to not send one. (`io`) + - `cookiePath` (`String|Boolean`): path of the above `cookie` + option. If false, no path will be sent, which means browsers will only send the cookie on the engine.io attached path (`/engine.io`). + Set this to `/` to send the io cookie on all requests. (`false`) + - `wsEngine` (`String`): what WebSocket server implementation to use. Specified module must conform to the `ws` interface (see [ws module api docs](https://github.com/websockets/ws/blob/master/doc/ws.md)). Default value is `ws`. An alternative c++ addon is also available by installing `uws` module. +- `close` + - Closes all clients + - **Returns** `Server` for chaining +- `handleRequest` + - Called internally when a `Engine` request is intercepted. + - **Parameters** + - `http.ServerRequest`: a node request object + - `http.ServerResponse`: a node response object + - **Returns** `Server` for chaining +- `handleUpgrade` + - Called internally when a `Engine` ws upgrade is intercepted. + - **Parameters** (same as `upgrade` event) + - `http.ServerRequest`: a node request object + - `net.Stream`: TCP socket for the request + - `Buffer`: legacy tail bytes + - **Returns** `Server` for chaining +- `attach` + - Attach this Server instance to an `http.Server` + - Captures `upgrade` requests for a `http.Server`. In other words, makes + a regular http.Server WebSocket-compatible. + - **Parameters** + - `http.Server`: server to attach to. + - `Object`: optional, options object + - **Options** + - `path` (`String`): name of the path to capture (`/engine.io`). + - `destroyUpgrade` (`Boolean`): destroy unhandled upgrade requests (`true`) + - `destroyUpgradeTimeout` (`Number`): milliseconds after which unhandled requests are ended (`1000`) +- `generateId` + - Generate a socket id. + - Overwrite this method to generate your custom socket id. + - **Parameters** + - `http.ServerRequest`: a node request object + - **Returns** A socket id for connected client. + +

              + +#### Socket + +A representation of a client. _Inherits from EventEmitter_. + +##### Events + +- `close` + - Fired when the client is disconnected. + - **Arguments** + - `String`: reason for closing + - `Object`: description object (optional) +- `message` + - Fired when the client sends a message. + - **Arguments** + - `String` or `Buffer`: Unicode string or Buffer with binary contents +- `error` + - Fired when an error occurs. + - **Arguments** + - `Error`: error object +- `flush` + - Called when the write buffer is being flushed. + - **Arguments** + - `Array`: write buffer +- `drain` + - Called when the write buffer is drained +- `packet` + - Called when a socket received a packet (`message`, `ping`) + - **Arguments** + - `type`: packet type + - `data`: packet data (if type is message) +- `packetCreate` + - Called before a socket sends a packet (`message`, `pong`) + - **Arguments** + - `type`: packet type + - `data`: packet data (if type is message) + +##### Properties + +- `id` _(String)_: unique identifier +- `server` _(Server)_: engine parent reference +- `request` _(http.ServerRequest)_: request that originated the Socket +- `upgraded` _(Boolean)_: whether the transport has been upgraded +- `readyState` _(String)_: opening|open|closing|closed +- `transport` _(Transport)_: transport reference + +##### Methods + +- `send`: + - Sends a message, performing `message = toString(arguments[0])` unless + sending binary data, which is sent as is. + - **Parameters** + - `String` | `Buffer` | `ArrayBuffer` | `ArrayBufferView`: a string or any object implementing `toString()`, with outgoing data, or a Buffer or ArrayBuffer with binary data. Also any ArrayBufferView can be sent as is. + - `Object`: optional, options object + - `Function`: optional, a callback executed when the message gets flushed out by the transport + - **Options** + - `compress` (`Boolean`): whether to compress sending data. This option might be ignored and forced to be `true` when using polling. (`true`) + - **Returns** `Socket` for chaining +- `close` + - Disconnects the client + - **Returns** `Socket` for chaining + +### Client + +

              + +Exposed in the `eio` global namespace (in the browser), or by +`require('engine.io-client')` (in Node.JS). + +For the client API refer to the +[engine-client](http://github.com/learnboost/engine.io-client) repository. + +## Debug / logging + +Engine.IO is powered by [debug](http://github.com/visionmedia/debug). +In order to see all the debug output, run your app with the environment variable +`DEBUG` including the desired scope. + +To see the output from all of Engine.IO's debugging scopes you can use: + +``` +DEBUG=engine* node myapp +``` + +## Transports + +- `polling`: XHR / JSONP polling transport. +- `websocket`: WebSocket transport. + +## Plugins + +- [engine.io-conflation](https://github.com/EugenDueck/engine.io-conflation): Makes **conflation and aggregation** of messages straightforward. + +## Support + +The support channels for `engine.io` are the same as `socket.io`: + - irc.freenode.net **#socket.io** + - [Google Groups](http://groups.google.com/group/socket_io) + - [Website](http://socket.io) + +## Development + +To contribute patches, run tests or benchmarks, make sure to clone the +repository: + +``` +git clone git://github.com/LearnBoost/engine.io.git +``` + +Then: + +``` +cd engine.io +npm install +``` + +## Tests + +Tests run with `make test`. It runs the server tests that are aided by +the usage of `engine.io-client`. + +Make sure `npm install` is run first. + +## Goals + +The main goal of `Engine` is ensuring the most reliable realtime communication. +Unlike the previous Socket.IO core, it always establishes a long-polling +connection first, then tries to upgrade to better transports that are "tested" on +the side. + +During the lifetime of the Socket.IO projects, we've found countless drawbacks +to relying on `HTML5 WebSocket` or `Flash Socket` as the first connection +mechanisms. + +Both are clearly the _right way_ of establishing a bidirectional communication, +with HTML5 WebSocket being the way of the future. However, to answer most business +needs, alternative traditional HTTP 1.1 mechanisms are just as good as delivering +the same solution. + +WebSocket based connections have two fundamental benefits: + +1. **Better server performance** + - _A: Load balancers_
              + Load balancing a long polling connection poses a serious architectural nightmare + since requests can come from any number of open sockets by the user agent, but + they all need to be routed to the process and computer that owns the `Engine` + connection. This negatively impacts RAM and CPU usage. + - _B: Network traffic_
              + WebSocket is designed around the premise that each message frame has to be + surrounded by the least amount of data. In HTTP 1.1 transports, each message + frame is surrounded by HTTP headers and chunked encoding frames. If you try to + send the message _"Hello world"_ with xhr-polling, the message ultimately + becomes larger than if you were to send it with WebSocket. + - _C: Lightweight parser_
              + As an effect of **B**, the server has to do a lot more work to parse the network + data and figure out the message when traditional HTTP requests are used + (as in long polling). This means that another advantage of WebSocket is + less server CPU usage. + +2. **Better user experience** + + Due to the reasons stated in point **1**, the most important effect of being able + to establish a WebSocket connection is raw data transfer speed, which translates + in _some_ cases in better user experience. + + Applications with heavy realtime interaction (such as games) will benefit greatly, + whereas applications like realtime chat (Gmail/Facebook), newsfeeds (Facebook) or + timelines (Twitter) will have negligible user experience improvements. + +Having said this, attempting to establish a WebSocket connection directly so far has +proven problematic: + +1. **Proxies**
              + Many corporate proxies block WebSocket traffic. + +2. **Personal firewall and antivirus software**
              + As a result of our research, we've found that at least 3 personal security + applications block WebSocket traffic. + +3. **Cloud application platforms**
              + Platforms like Heroku or No.de have had trouble keeping up with the fast-paced + nature of the evolution of the WebSocket protocol. Applications therefore end up + inevitably using long polling, but the seamless installation experience of + Socket.IO we strive for (_"require() it and it just works"_) disappears. + +Some of these problems have solutions. In the case of proxies and personal programs, +however, the solutions many times involve upgrading software. Experience has shown +that relying on client software upgrades to deliver a business solution is +fruitless: the very existence of this project has to do with a fragmented panorama +of user agent distribution, with clients connecting with latest versions of the most +modern user agents (Chrome, Firefox and Safari), but others with versions as low as +IE 5.5. + +From the user perspective, an unsuccessful WebSocket connection can translate in +up to at least 10 seconds of waiting for the realtime application to begin +exchanging data. This **perceptively** hurts user experience. + +To summarize, **Engine** focuses on reliability and user experience first, marginal +potential UX improvements and increased server performance second. `Engine` is the +result of all the lessons learned with WebSocket in the wild. + +## Architecture + +The main premise of `Engine`, and the core of its existence, is the ability to +swap transports on the fly. A connection starts as xhr-polling, but it can +switch to WebSocket. + +The central problem this poses is: how do we switch transports without losing +messages? + +`Engine` only switches from polling to another transport in between polling +cycles. Since the server closes the connection after a certain timeout when +there's no activity, and the polling transport implementation buffers messages +in between connections, this ensures no message loss and optimal performance. + +Another benefit of this design is that we workaround almost all the limitations +of **Flash Socket**, such as slow connection times, increased file size (we can +safely lazy load it without hurting user experience), etc. + +## FAQ + +### Can I use engine without Socket.IO ? + +Absolutely. Although the recommended framework for building realtime applications +is Socket.IO, since it provides fundamental features for real-world applications +such as multiplexing, reconnection support, etc. + +`Engine` is to Socket.IO what Connect is to Express. An essential piece for building +realtime frameworks, but something you _probably_ won't be using for building +actual applications. + +### Does the server serve the client? + +No. The main reason is that `Engine` is meant to be bundled with frameworks. +Socket.IO includes `Engine`, therefore serving two clients is not necessary. If +you use Socket.IO, including + +```html + + ``` + +## Features + +- Runs on browser and node.js seamlessly +- Runs inside HTML5 WebWorker +- Can encode and decode packets + - Encodes from/to ArrayBuffer or Blob when in browser, and Buffer or ArrayBuffer in Node + +## API + +Note: `cb(type)` means the type is a callback function that contains a parameter of type `type` when called. + +### Node + +- `encodePacket` + - Encodes a packet. + - **Parameters** + - `Object`: the packet to encode, has `type` and `data`. + - `data`: can be a `String`, `Number`, `Buffer`, `ArrayBuffer` + - `Boolean`: optional, binary support + - `Function`: callback, returns the encoded packet (`cb(String)`) +- `decodePacket` + - Decodes a packet. Data also available as an ArrayBuffer if requested. + - Returns data as `String` or (`Blob` on browser, `ArrayBuffer` on Node) + - **Parameters** + - `String` | `ArrayBuffer`: the packet to decode, has `type` and `data` + - `String`: optional, the binary type + +- `encodeBase64Packet` + - Encodes a packet with binary data in a base64 string (`String`) + - **Parameters** + - `Object`: the packet to encode, has `type` and `data` + - `Function`: callback, returns the base64 encoded message (`cb(String)`) +- `decodeBase64Packet` + - Decodes a packet encoded in a base64 string. + - **Parameters** + - `String`: the base64 encoded message + - `String`: optional, the binary type + +- `encodePayload` + - Encodes multiple messages (payload). + - If any contents are binary, they will be encoded as base64 strings. Base64 + encoded strings are marked with a b before the length specifier + - **Parameters** + - `Array`: an array of packets + - `Boolean`: optional, binary support + - `Function`: callback, returns the encoded payload (`cb(String)`) +- `decodePayload` + - Decodes data when a payload is maybe expected. Possible binary contents are + decoded from their base64 representation. + - **Parameters** + - `String`: the payload + - `String`: optional, the binary type + - `Function`: callback, returns (cb(`Object`: packet, `Number`:packet index, `Number`:packet total)) + +- `encodePayloadAsBinary` + - Encodes multiple messages (payload) as binary. + - **Parameters** + - `Array`: an array of packets + - `Function`: callback, returns the encoded payload (`cb(Buffer)`) +- `decodePayloadAsBinary` + - Decodes data when a payload is maybe expected. Strings are decoded by + interpreting each byte as a key code for entries marked to start with 0. See + description of encodePayloadAsBinary. + - **Parameters** + - `Buffer`: the buffer + - `String`: optional, the binary type + - `Function`: callback, returns the decoded packet (`cb(Object)`) + +### Browser + +- `encodePayloadAsArrayBuffer` + - Encodes multiple messages (payload) as binary. + - **Parameters** + - `Array`: an array of packets + - `Function`: callback, returns the encoded payload (`cb(ArrayBuffer)`) +- `encodePayloadAsBlob` + - Encodes multiple messages (payload) as blob. + - **Parameters** + - `Array`: an array of packets + - `Function`: callback, returns the encoded payload (`cb(Blob)`) + +## Tests + +Standalone tests can be run with `make test` which will run both node.js and browser tests. + +Browser tests are run using [zuul](https://github.com/defunctzombie/zuul). +(You must have zuul setup with a saucelabs account.) + +You can run the tests locally using the following command: + +``` +./node_modules/.bin/zuul --local 8080 -- test/index.js +``` + +## Support + +The support channels for `engine.io-parser` are the same as `socket.io`: + - irc.freenode.net **#socket.io** + - [Google Groups](http://groups.google.com/group/socket_io) + - [Website](http://socket.io) + +## Development + +To contribute patches, run tests or benchmarks, make sure to clone the +repository: + +```bash +git clone git://github.com/LearnBoost/engine.io-parser.git +``` + +Then: + +```bash +cd engine.io-parser +npm install +``` + +See the `Tests` section above for how to run tests before submitting any patches. + +## License + +MIT diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/index.js b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/index.js new file mode 100644 index 0000000..887727f --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/index.js @@ -0,0 +1,2 @@ + +module.exports = require('./lib/'); diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/lib/browser.js b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/lib/browser.js new file mode 100644 index 0000000..652dc0c --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/lib/browser.js @@ -0,0 +1,609 @@ +/** + * Module dependencies. + */ + +var keys = require('./keys'); +var hasBinary = require('has-binary'); +var sliceBuffer = require('arraybuffer.slice'); +var after = require('after'); +var utf8 = require('wtf-8'); + +var base64encoder; +if (global && global.ArrayBuffer) { + base64encoder = require('base64-arraybuffer'); +} + +/** + * Check if we are running an android browser. That requires us to use + * ArrayBuffer with polling transports... + * + * http://ghinda.net/jpeg-blob-ajax-android/ + */ + +var isAndroid = typeof navigator !== 'undefined' && /Android/i.test(navigator.userAgent); + +/** + * Check if we are running in PhantomJS. + * Uploading a Blob with PhantomJS does not work correctly, as reported here: + * https://github.com/ariya/phantomjs/issues/11395 + * @type boolean + */ +var isPhantomJS = typeof navigator !== 'undefined' && /PhantomJS/i.test(navigator.userAgent); + +/** + * When true, avoids using Blobs to encode payloads. + * @type boolean + */ +var dontSendBlobs = isAndroid || isPhantomJS; + +/** + * Current protocol version. + */ + +exports.protocol = 3; + +/** + * Packet types. + */ + +var packets = exports.packets = { + open: 0 // non-ws + , close: 1 // non-ws + , ping: 2 + , pong: 3 + , message: 4 + , upgrade: 5 + , noop: 6 +}; + +var packetslist = keys(packets); + +/** + * Premade error packet. + */ + +var err = { type: 'error', data: 'parser error' }; + +/** + * Create a blob api even for blob builder when vendor prefixes exist + */ + +var Blob = require('blob'); + +/** + * Encodes a packet. + * + * [ ] + * + * Example: + * + * 5hello world + * 3 + * 4 + * + * Binary is encoded in an identical principle + * + * @api private + */ + +exports.encodePacket = function (packet, supportsBinary, utf8encode, callback) { + if ('function' == typeof supportsBinary) { + callback = supportsBinary; + supportsBinary = false; + } + + if ('function' == typeof utf8encode) { + callback = utf8encode; + utf8encode = null; + } + + var data = (packet.data === undefined) + ? undefined + : packet.data.buffer || packet.data; + + if (global.ArrayBuffer && data instanceof ArrayBuffer) { + return encodeArrayBuffer(packet, supportsBinary, callback); + } else if (Blob && data instanceof global.Blob) { + return encodeBlob(packet, supportsBinary, callback); + } + + // might be an object with { base64: true, data: dataAsBase64String } + if (data && data.base64) { + return encodeBase64Object(packet, callback); + } + + // Sending data as a utf-8 string + var encoded = packets[packet.type]; + + // data fragment is optional + if (undefined !== packet.data) { + encoded += utf8encode ? utf8.encode(String(packet.data)) : String(packet.data); + } + + return callback('' + encoded); + +}; + +function encodeBase64Object(packet, callback) { + // packet data is an object { base64: true, data: dataAsBase64String } + var message = 'b' + exports.packets[packet.type] + packet.data.data; + return callback(message); +} + +/** + * Encode packet helpers for binary types + */ + +function encodeArrayBuffer(packet, supportsBinary, callback) { + if (!supportsBinary) { + return exports.encodeBase64Packet(packet, callback); + } + + var data = packet.data; + var contentArray = new Uint8Array(data); + var resultBuffer = new Uint8Array(1 + data.byteLength); + + resultBuffer[0] = packets[packet.type]; + for (var i = 0; i < contentArray.length; i++) { + resultBuffer[i+1] = contentArray[i]; + } + + return callback(resultBuffer.buffer); +} + +function encodeBlobAsArrayBuffer(packet, supportsBinary, callback) { + if (!supportsBinary) { + return exports.encodeBase64Packet(packet, callback); + } + + var fr = new FileReader(); + fr.onload = function() { + packet.data = fr.result; + exports.encodePacket(packet, supportsBinary, true, callback); + }; + return fr.readAsArrayBuffer(packet.data); +} + +function encodeBlob(packet, supportsBinary, callback) { + if (!supportsBinary) { + return exports.encodeBase64Packet(packet, callback); + } + + if (dontSendBlobs) { + return encodeBlobAsArrayBuffer(packet, supportsBinary, callback); + } + + var length = new Uint8Array(1); + length[0] = packets[packet.type]; + var blob = new Blob([length.buffer, packet.data]); + + return callback(blob); +} + +/** + * Encodes a packet with binary data in a base64 string + * + * @param {Object} packet, has `type` and `data` + * @return {String} base64 encoded message + */ + +exports.encodeBase64Packet = function(packet, callback) { + var message = 'b' + exports.packets[packet.type]; + if (Blob && packet.data instanceof global.Blob) { + var fr = new FileReader(); + fr.onload = function() { + var b64 = fr.result.split(',')[1]; + callback(message + b64); + }; + return fr.readAsDataURL(packet.data); + } + + var b64data; + try { + b64data = String.fromCharCode.apply(null, new Uint8Array(packet.data)); + } catch (e) { + // iPhone Safari doesn't let you apply with typed arrays + var typed = new Uint8Array(packet.data); + var basic = new Array(typed.length); + for (var i = 0; i < typed.length; i++) { + basic[i] = typed[i]; + } + b64data = String.fromCharCode.apply(null, basic); + } + message += global.btoa(b64data); + return callback(message); +}; + +/** + * Decodes a packet. Changes format to Blob if requested. + * + * @return {Object} with `type` and `data` (if any) + * @api private + */ + +exports.decodePacket = function (data, binaryType, utf8decode) { + if (data === undefined) { + return err; + } + // String data + if (typeof data == 'string') { + if (data.charAt(0) == 'b') { + return exports.decodeBase64Packet(data.substr(1), binaryType); + } + + if (utf8decode) { + data = tryDecode(data); + if (data === false) { + return err; + } + } + var type = data.charAt(0); + + if (Number(type) != type || !packetslist[type]) { + return err; + } + + if (data.length > 1) { + return { type: packetslist[type], data: data.substring(1) }; + } else { + return { type: packetslist[type] }; + } + } + + var asArray = new Uint8Array(data); + var type = asArray[0]; + var rest = sliceBuffer(data, 1); + if (Blob && binaryType === 'blob') { + rest = new Blob([rest]); + } + return { type: packetslist[type], data: rest }; +}; + +function tryDecode(data) { + try { + data = utf8.decode(data); + } catch (e) { + return false; + } + return data; +} + +/** + * Decodes a packet encoded in a base64 string + * + * @param {String} base64 encoded message + * @return {Object} with `type` and `data` (if any) + */ + +exports.decodeBase64Packet = function(msg, binaryType) { + var type = packetslist[msg.charAt(0)]; + if (!base64encoder) { + return { type: type, data: { base64: true, data: msg.substr(1) } }; + } + + var data = base64encoder.decode(msg.substr(1)); + + if (binaryType === 'blob' && Blob) { + data = new Blob([data]); + } + + return { type: type, data: data }; +}; + +/** + * Encodes multiple messages (payload). + * + * :data + * + * Example: + * + * 11:hello world2:hi + * + * If any contents are binary, they will be encoded as base64 strings. Base64 + * encoded strings are marked with a b before the length specifier + * + * @param {Array} packets + * @api private + */ + +exports.encodePayload = function (packets, supportsBinary, callback) { + if (typeof supportsBinary == 'function') { + callback = supportsBinary; + supportsBinary = null; + } + + var isBinary = hasBinary(packets); + + if (supportsBinary && isBinary) { + if (Blob && !dontSendBlobs) { + return exports.encodePayloadAsBlob(packets, callback); + } + + return exports.encodePayloadAsArrayBuffer(packets, callback); + } + + if (!packets.length) { + return callback('0:'); + } + + function setLengthHeader(message) { + return message.length + ':' + message; + } + + function encodeOne(packet, doneCallback) { + exports.encodePacket(packet, !isBinary ? false : supportsBinary, true, function(message) { + doneCallback(null, setLengthHeader(message)); + }); + } + + map(packets, encodeOne, function(err, results) { + return callback(results.join('')); + }); +}; + +/** + * Async array map using after + */ + +function map(ary, each, done) { + var result = new Array(ary.length); + var next = after(ary.length, done); + + var eachWithIndex = function(i, el, cb) { + each(el, function(error, msg) { + result[i] = msg; + cb(error, result); + }); + }; + + for (var i = 0; i < ary.length; i++) { + eachWithIndex(i, ary[i], next); + } +} + +/* + * Decodes data when a payload is maybe expected. Possible binary contents are + * decoded from their base64 representation + * + * @param {String} data, callback method + * @api public + */ + +exports.decodePayload = function (data, binaryType, callback) { + if (typeof data != 'string') { + return exports.decodePayloadAsBinary(data, binaryType, callback); + } + + if (typeof binaryType === 'function') { + callback = binaryType; + binaryType = null; + } + + var packet; + if (data == '') { + // parser error - ignoring payload + return callback(err, 0, 1); + } + + var length = '' + , n, msg; + + for (var i = 0, l = data.length; i < l; i++) { + var chr = data.charAt(i); + + if (':' != chr) { + length += chr; + } else { + if ('' == length || (length != (n = Number(length)))) { + // parser error - ignoring payload + return callback(err, 0, 1); + } + + msg = data.substr(i + 1, n); + + if (length != msg.length) { + // parser error - ignoring payload + return callback(err, 0, 1); + } + + if (msg.length) { + packet = exports.decodePacket(msg, binaryType, true); + + if (err.type == packet.type && err.data == packet.data) { + // parser error in individual packet - ignoring payload + return callback(err, 0, 1); + } + + var ret = callback(packet, i + n, l); + if (false === ret) return; + } + + // advance cursor + i += n; + length = ''; + } + } + + if (length != '') { + // parser error - ignoring payload + return callback(err, 0, 1); + } + +}; + +/** + * Encodes multiple messages (payload) as binary. + * + * <1 = binary, 0 = string>[...] + * + * Example: + * 1 3 255 1 2 3, if the binary contents are interpreted as 8 bit integers + * + * @param {Array} packets + * @return {ArrayBuffer} encoded payload + * @api private + */ + +exports.encodePayloadAsArrayBuffer = function(packets, callback) { + if (!packets.length) { + return callback(new ArrayBuffer(0)); + } + + function encodeOne(packet, doneCallback) { + exports.encodePacket(packet, true, true, function(data) { + return doneCallback(null, data); + }); + } + + map(packets, encodeOne, function(err, encodedPackets) { + var totalLength = encodedPackets.reduce(function(acc, p) { + var len; + if (typeof p === 'string'){ + len = p.length; + } else { + len = p.byteLength; + } + return acc + len.toString().length + len + 2; // string/binary identifier + separator = 2 + }, 0); + + var resultArray = new Uint8Array(totalLength); + + var bufferIndex = 0; + encodedPackets.forEach(function(p) { + var isString = typeof p === 'string'; + var ab = p; + if (isString) { + var view = new Uint8Array(p.length); + for (var i = 0; i < p.length; i++) { + view[i] = p.charCodeAt(i); + } + ab = view.buffer; + } + + if (isString) { // not true binary + resultArray[bufferIndex++] = 0; + } else { // true binary + resultArray[bufferIndex++] = 1; + } + + var lenStr = ab.byteLength.toString(); + for (var i = 0; i < lenStr.length; i++) { + resultArray[bufferIndex++] = parseInt(lenStr[i]); + } + resultArray[bufferIndex++] = 255; + + var view = new Uint8Array(ab); + for (var i = 0; i < view.length; i++) { + resultArray[bufferIndex++] = view[i]; + } + }); + + return callback(resultArray.buffer); + }); +}; + +/** + * Encode as Blob + */ + +exports.encodePayloadAsBlob = function(packets, callback) { + function encodeOne(packet, doneCallback) { + exports.encodePacket(packet, true, true, function(encoded) { + var binaryIdentifier = new Uint8Array(1); + binaryIdentifier[0] = 1; + if (typeof encoded === 'string') { + var view = new Uint8Array(encoded.length); + for (var i = 0; i < encoded.length; i++) { + view[i] = encoded.charCodeAt(i); + } + encoded = view.buffer; + binaryIdentifier[0] = 0; + } + + var len = (encoded instanceof ArrayBuffer) + ? encoded.byteLength + : encoded.size; + + var lenStr = len.toString(); + var lengthAry = new Uint8Array(lenStr.length + 1); + for (var i = 0; i < lenStr.length; i++) { + lengthAry[i] = parseInt(lenStr[i]); + } + lengthAry[lenStr.length] = 255; + + if (Blob) { + var blob = new Blob([binaryIdentifier.buffer, lengthAry.buffer, encoded]); + doneCallback(null, blob); + } + }); + } + + map(packets, encodeOne, function(err, results) { + return callback(new Blob(results)); + }); +}; + +/* + * Decodes data when a payload is maybe expected. Strings are decoded by + * interpreting each byte as a key code for entries marked to start with 0. See + * description of encodePayloadAsBinary + * + * @param {ArrayBuffer} data, callback method + * @api public + */ + +exports.decodePayloadAsBinary = function (data, binaryType, callback) { + if (typeof binaryType === 'function') { + callback = binaryType; + binaryType = null; + } + + var bufferTail = data; + var buffers = []; + + var numberTooLong = false; + while (bufferTail.byteLength > 0) { + var tailArray = new Uint8Array(bufferTail); + var isString = tailArray[0] === 0; + var msgLength = ''; + + for (var i = 1; ; i++) { + if (tailArray[i] == 255) break; + + if (msgLength.length > 310) { + numberTooLong = true; + break; + } + + msgLength += tailArray[i]; + } + + if(numberTooLong) return callback(err, 0, 1); + + bufferTail = sliceBuffer(bufferTail, 2 + msgLength.length); + msgLength = parseInt(msgLength); + + var msg = sliceBuffer(bufferTail, 0, msgLength); + if (isString) { + try { + msg = String.fromCharCode.apply(null, new Uint8Array(msg)); + } catch (e) { + // iPhone Safari doesn't let you apply to typed arrays + var typed = new Uint8Array(msg); + msg = ''; + for (var i = 0; i < typed.length; i++) { + msg += String.fromCharCode(typed[i]); + } + } + } + + buffers.push(msg); + bufferTail = sliceBuffer(bufferTail, msgLength); + } + + var total = buffers.length; + buffers.forEach(function(buffer, i) { + callback(exports.decodePacket(buffer, binaryType, true), i, total); + }); +}; diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/lib/index.js b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/lib/index.js new file mode 100644 index 0000000..716b1d5 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/lib/index.js @@ -0,0 +1,474 @@ +/** + * Module dependencies. + */ + +var utf8 = require('wtf-8'); +var after = require('after'); +var keys = require('./keys'); + +/** + * Current protocol version. + */ +exports.protocol = 3; + +/** + * Packet types. + */ + +var packets = exports.packets = { + open: 0 // non-ws + , close: 1 // non-ws + , ping: 2 + , pong: 3 + , message: 4 + , upgrade: 5 + , noop: 6 +}; + +var packetslist = keys(packets); + +/** + * Premade error packet. + */ + +var err = { type: 'error', data: 'parser error' }; + +/** + * Encodes a packet. + * + * [ ] + * + * Example: + * + * 5hello world + * 3 + * 4 + * + * Binary is encoded in an identical principle + * + * @api private + */ + +exports.encodePacket = function (packet, supportsBinary, utf8encode, callback) { + if ('function' == typeof supportsBinary) { + callback = supportsBinary; + supportsBinary = null; + } + + if ('function' == typeof utf8encode ) { + callback = utf8encode; + utf8encode = null; + } + + if (Buffer.isBuffer(packet.data)) { + return encodeBuffer(packet, supportsBinary, callback); + } else if (packet.data && (packet.data.buffer || packet.data) instanceof ArrayBuffer) { + packet.data = arrayBufferToBuffer(packet.data); + return encodeBuffer(packet, supportsBinary, callback); + } + + // Sending data as a utf-8 string + var encoded = packets[packet.type]; + + // data fragment is optional + if (undefined !== packet.data) { + encoded += utf8encode ? utf8.encode(String(packet.data)) : String(packet.data); + } + + return callback('' + encoded); +}; + +/** + * Encode Buffer data + */ + +function encodeBuffer(packet, supportsBinary, callback) { + var data = packet.data; + if (!supportsBinary) { + return exports.encodeBase64Packet(packet, callback); + } + + var typeBuffer = new Buffer(1); + typeBuffer[0] = packets[packet.type]; + return callback(Buffer.concat([typeBuffer, data])); +} + +/** + * Encodes a packet with binary data in a base64 string + * + * @param {Object} packet, has `type` and `data` + * @return {String} base64 encoded message + */ + +exports.encodeBase64Packet = function(packet, callback){ + if (!Buffer.isBuffer(packet.data)) { + packet.data = arrayBufferToBuffer(packet.data); + } + + var message = 'b' + packets[packet.type]; + message += packet.data.toString('base64'); + return callback(message); +}; + +/** + * Decodes a packet. Data also available as an ArrayBuffer if requested. + * + * @return {Object} with `type` and `data` (if any) + * @api private + */ + +exports.decodePacket = function (data, binaryType, utf8decode) { + if (data === undefined) { + return err; + } + // String data + if (typeof data == 'string') { + if (data.charAt(0) == 'b') { + return exports.decodeBase64Packet(data.substr(1), binaryType); + } + + var type = data.charAt(0); + + if (utf8decode) { + data = tryDecode(data); + if (data === false) { + return err; + } + } + + if (Number(type) != type || !packetslist[type]) { + return err; + } + + if (data.length > 1) { + return { type: packetslist[type], data: data.substring(1) }; + } else { + return { type: packetslist[type] }; + } + } + + // Binary data + if (binaryType === 'arraybuffer') { + // wrap Buffer/ArrayBuffer data into an Uint8Array + var intArray = new Uint8Array(data); + var type = intArray[0]; + return { type: packetslist[type], data: intArray.buffer.slice(1) }; + } + + if (data instanceof ArrayBuffer) { + data = arrayBufferToBuffer(data); + } + var type = data[0]; + return { type: packetslist[type], data: data.slice(1) }; +}; + +function tryDecode(data) { + try { + data = utf8.decode(data); + } catch (e) { + return false; + } + return data; +} + +/** + * Decodes a packet encoded in a base64 string. + * + * @param {String} base64 encoded message + * @return {Object} with `type` and `data` (if any) + */ + +exports.decodeBase64Packet = function(msg, binaryType) { + var type = packetslist[msg.charAt(0)]; + var data = new Buffer(msg.substr(1), 'base64'); + if (binaryType === 'arraybuffer') { + var abv = new Uint8Array(data.length); + for (var i = 0; i < abv.length; i++){ + abv[i] = data[i]; + } + data = abv.buffer; + } + return { type: type, data: data }; +}; + +/** + * Encodes multiple messages (payload). + * + * :data + * + * Example: + * + * 11:hello world2:hi + * + * If any contents are binary, they will be encoded as base64 strings. Base64 + * encoded strings are marked with a b before the length specifier + * + * @param {Array} packets + * @api private + */ + +exports.encodePayload = function (packets, supportsBinary, callback) { + if (typeof supportsBinary == 'function') { + callback = supportsBinary; + supportsBinary = null; + } + + if (supportsBinary) { + return exports.encodePayloadAsBinary(packets, callback); + } + + if (!packets.length) { + return callback('0:'); + } + + function setLengthHeader(message) { + return message.length + ':' + message; + } + + function encodeOne(packet, doneCallback) { + exports.encodePacket(packet, supportsBinary, true, function(message) { + doneCallback(null, setLengthHeader(message)); + }); + } + + map(packets, encodeOne, function(err, results) { + return callback(results.join('')); + }); +}; + +/** + * Async array map using after + */ + +function map(ary, each, done) { + var result = new Array(ary.length); + var next = after(ary.length, done); + + var eachWithIndex = function(i, el, cb) { + each(el, function(error, msg) { + result[i] = msg; + cb(error, result); + }); + }; + + for (var i = 0; i < ary.length; i++) { + eachWithIndex(i, ary[i], next); + } +} + +/* + * Decodes data when a payload is maybe expected. Possible binary contents are + * decoded from their base64 representation + * + * @param {String} data, callback method + * @api public + */ + +exports.decodePayload = function (data, binaryType, callback) { + if ('string' != typeof data) { + return exports.decodePayloadAsBinary(data, binaryType, callback); + } + + if (typeof binaryType === 'function') { + callback = binaryType; + binaryType = null; + } + + var packet; + if (data == '') { + // parser error - ignoring payload + return callback(err, 0, 1); + } + + var length = '' + , n, msg; + + for (var i = 0, l = data.length; i < l; i++) { + var chr = data.charAt(i); + + if (':' != chr) { + length += chr; + } else { + if ('' == length || (length != (n = Number(length)))) { + // parser error - ignoring payload + return callback(err, 0, 1); + } + + msg = data.substr(i + 1, n); + + if (length != msg.length) { + // parser error - ignoring payload + return callback(err, 0, 1); + } + + if (msg.length) { + packet = exports.decodePacket(msg, binaryType, true); + + if (err.type == packet.type && err.data == packet.data) { + // parser error in individual packet - ignoring payload + return callback(err, 0, 1); + } + + var ret = callback(packet, i + n, l); + if (false === ret) return; + } + + // advance cursor + i += n; + length = ''; + } + } + + if (length != '') { + // parser error - ignoring payload + return callback(err, 0, 1); + } + +}; + +/** + * + * Converts a buffer to a utf8.js encoded string + * + * @api private + */ + +function bufferToString(buffer) { + var str = ''; + for (var i = 0; i < buffer.length; i++) { + str += String.fromCharCode(buffer[i]); + } + return str; +} + +/** + * + * Converts a utf8.js encoded string to a buffer + * + * @api private + */ + +function stringToBuffer(string) { + var buf = new Buffer(string.length); + for (var i = 0; i < string.length; i++) { + buf.writeUInt8(string.charCodeAt(i), i); + } + return buf; +} + +/** + * + * Converts an ArrayBuffer to a Buffer + * + * @api private + */ + +function arrayBufferToBuffer(data) { + // data is either an ArrayBuffer or ArrayBufferView. + var array = new Uint8Array(data.buffer || data); + var length = data.byteLength || data.length; + var offset = data.byteOffset || 0; + var buffer = new Buffer(length); + + for (var i = 0; i < length; i++) { + buffer[i] = array[offset + i]; + } + return buffer; +} + +/** + * Encodes multiple messages (payload) as binary. + * + * <1 = binary, 0 = string>[...] + * + * Example: + * 1 3 255 1 2 3, if the binary contents are interpreted as 8 bit integers + * + * @param {Array} packets + * @return {Buffer} encoded payload + * @api private + */ + +exports.encodePayloadAsBinary = function (packets, callback) { + if (!packets.length) { + return callback(new Buffer(0)); + } + + function encodeOne(p, doneCallback) { + exports.encodePacket(p, true, true, function(packet) { + + if (typeof packet === 'string') { + var encodingLength = '' + packet.length; + var sizeBuffer = new Buffer(encodingLength.length + 2); + sizeBuffer[0] = 0; // is a string (not true binary = 0) + for (var i = 0; i < encodingLength.length; i++) { + sizeBuffer[i + 1] = parseInt(encodingLength[i], 10); + } + sizeBuffer[sizeBuffer.length - 1] = 255; + return doneCallback(null, Buffer.concat([sizeBuffer, stringToBuffer(packet)])); + } + + var encodingLength = '' + packet.length; + var sizeBuffer = new Buffer(encodingLength.length + 2); + sizeBuffer[0] = 1; // is binary (true binary = 1) + for (var i = 0; i < encodingLength.length; i++) { + sizeBuffer[i + 1] = parseInt(encodingLength[i], 10); + } + sizeBuffer[sizeBuffer.length - 1] = 255; + doneCallback(null, Buffer.concat([sizeBuffer, packet])); + }); + } + + map(packets, encodeOne, function(err, results) { + return callback(Buffer.concat(results)); + }); +}; + +/* + * Decodes data when a payload is maybe expected. Strings are decoded by + * interpreting each byte as a key code for entries marked to start with 0. See + * description of encodePayloadAsBinary + + * @param {Buffer} data, callback method + * @api public + */ + +exports.decodePayloadAsBinary = function (data, binaryType, callback) { + if (typeof binaryType === 'function') { + callback = binaryType; + binaryType = null; + } + + var bufferTail = data; + var buffers = []; + + while (bufferTail.length > 0) { + var strLen = ''; + var isString = bufferTail[0] === 0; + var numberTooLong = false; + for (var i = 1; ; i++) { + if (bufferTail[i] == 255) break; + // 310 = char length of Number.MAX_VALUE + if (strLen.length > 310) { + numberTooLong = true; + break; + } + strLen += '' + bufferTail[i]; + } + if(numberTooLong) return callback(err, 0, 1); + bufferTail = bufferTail.slice(strLen.length + 1); + + var msgLength = parseInt(strLen, 10); + + var msg = bufferTail.slice(1, msgLength + 1); + if (isString) msg = bufferToString(msg); + buffers.push(msg); + bufferTail = bufferTail.slice(msgLength + 1); + } + + var total = buffers.length; + buffers.forEach(function(buffer, i) { + callback(exports.decodePacket(buffer, binaryType, true), i, total); + }); +}; diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/lib/keys.js b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/lib/keys.js new file mode 100644 index 0000000..947dafd --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/lib/keys.js @@ -0,0 +1,19 @@ + +/** + * Gets the keys for an object. + * + * @return {Array} keys + * @api private + */ + +module.exports = Object.keys || function keys (obj){ + var arr = []; + var has = Object.prototype.hasOwnProperty; + + for (var i in obj) { + if (has.call(obj, i)) { + arr.push(i); + } + } + return arr; +}; diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/after/.npmignore b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/after/.npmignore new file mode 100644 index 0000000..6c78602 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/after/.npmignore @@ -0,0 +1,2 @@ +node_modules +.monitor diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/after/.travis.yml b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/after/.travis.yml new file mode 100644 index 0000000..84fd7ca --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/after/.travis.yml @@ -0,0 +1,5 @@ +language: node_js +node_js: + - 0.6 + - 0.8 + - 0.9 diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/after/LICENCE b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/after/LICENCE new file mode 100644 index 0000000..7c35130 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/after/LICENCE @@ -0,0 +1,19 @@ +Copyright (c) 2011 Raynos. + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. \ No newline at end of file diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/after/README.md b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/after/README.md new file mode 100644 index 0000000..0012d35 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/after/README.md @@ -0,0 +1,75 @@ +# After [![Build Status][1]][2] + +Invoke callback after n calls + +## Status: production ready + +## Example + + var after = require("after") + , next = after(3, logItWorks) + + next() + next() + next() // it works + + function logItWorks() { + console.log("it works!") + } + +## Example with error handling + + var after = require("after") + , next = after(3, logError) + + next() + next(new Error("oops")) // logs oops + next() // does nothing + + function logError(err) { + console.log(err) + } + +## After < 0.6.0 + +Older versions of after had iterators and flows in them. + +These have been replaced with seperate modules + + - [iterators][8] + - [composite][9] + +## Installation + +`npm install after` + +## Tests + +`npm test` + +## Blog post + + - [Flow control in node.js][3] + +## Examples : + + - [Determining the end of asynchronous operations][4] + - [In javascript what are best practices for executing multiple asynchronous functions][5] + - [JavaScript performance long running tasks][6] + - [Synchronous database queries with node.js][7] + +## Contributors + + - Raynos + +## MIT Licenced + + [1]: https://secure.travis-ci.org/Raynos/after.png + [2]: http://travis-ci.org/Raynos/after + [3]: http://raynos.org/blog/2/Flow-control-in-node.js + [4]: http://stackoverflow.com/questions/6852059/determining-the-end-of-asynchronous-operations-javascript/6852307#6852307 + [5]: http://stackoverflow.com/questions/6869872/in-javascript-what-are-best-practices-for-executing-multiple-asynchronous-functi/6870031#6870031 + [6]: http://stackoverflow.com/questions/6864397/javascript-performance-long-running-tasks/6889419#6889419 + [7]: http://stackoverflow.com/questions/6597493/synchronous-database-queries-with-node-js/6620091#6620091 + [8]: http://github.com/Raynos/iterators + [9]: http://github.com/Raynos/composite diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/after/index.js b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/after/index.js new file mode 100644 index 0000000..ec24879 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/after/index.js @@ -0,0 +1,28 @@ +module.exports = after + +function after(count, callback, err_cb) { + var bail = false + err_cb = err_cb || noop + proxy.count = count + + return (count === 0) ? callback() : proxy + + function proxy(err, result) { + if (proxy.count <= 0) { + throw new Error('after called too many times') + } + --proxy.count + + // after first error, rest are passed to err_cb + if (err) { + bail = true + callback(err) + // future error callbacks will go to error handler + callback = err_cb + } else if (proxy.count === 0 && !bail) { + callback(null, result) + } + } +} + +function noop() {} diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/after/package.json b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/after/package.json new file mode 100644 index 0000000..312df97 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/after/package.json @@ -0,0 +1,62 @@ +{ + "name": "after", + "description": "after - tiny flow control", + "version": "0.8.1", + "author": { + "name": "Raynos", + "email": "raynos2@gmail.com" + }, + "contributors": [ + { + "name": "Raynos", + "email": "raynos2@gmail.com", + "url": "http://raynos.org" + } + ], + "scripts": { + "test": "mocha --ui tdd --reporter spec test/*.js" + }, + "devDependencies": { + "mocha": "~1.8.1" + }, + "keywords": [ + "flowcontrol", + "after", + "flow", + "control", + "arch" + ], + "repository": { + "type": "git", + "url": "git://github.com/Raynos/after.git" + }, + "bugs": { + "url": "https://github.com/Raynos/after/issues" + }, + "_id": "after@0.8.1", + "dist": { + "shasum": "ab5d4fb883f596816d3515f8f791c0af486dd627", + "tarball": "https://registry.npmjs.org/after/-/after-0.8.1.tgz" + }, + "_from": "after@0.8.1", + "_npmVersion": "1.2.25", + "_npmUser": { + "name": "raynos", + "email": "raynos2@gmail.com" + }, + "maintainers": [ + { + "name": "raynos", + "email": "raynos2@gmail.com" + }, + { + "name": "shtylman", + "email": "shtylman@gmail.com" + } + ], + "directories": {}, + "_shasum": "ab5d4fb883f596816d3515f8f791c0af486dd627", + "_resolved": "http://registry.npmjs.org/after/-/after-0.8.1.tgz", + "readme": "ERROR: No README data found!", + "homepage": "https://github.com/Raynos/after#readme" +} diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/after/test/after-test.js b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/after/test/after-test.js new file mode 100644 index 0000000..0d63f4c --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/after/test/after-test.js @@ -0,0 +1,120 @@ +/*global suite, test*/ + +var assert = require("assert") + , after = require("../") + +test("exists", function () { + assert(typeof after === "function", "after is not a function") +}) + +test("after when called with 0 invokes", function (done) { + after(0, done) +}); + +test("after 1", function (done) { + var next = after(1, done) + next() +}) + +test("after 5", function (done) { + var next = after(5, done) + , i = 5 + + while (i--) { + next() + } +}) + +test("manipulate count", function (done) { + var next = after(1, done) + , i = 5 + + next.count = i + while (i--) { + next() + } +}) + +test("after terminates on error", function (done) { + var next = after(2, function(err) { + assert.equal(err.message, 'test'); + done(); + }) + next(new Error('test')) + next(new Error('test2')) +}) + +test('gee', function(done) { + done = after(2, done) + + function cb(err) { + assert.equal(err.message, 1); + done() + } + + var next = after(3, cb, function(err) { + assert.equal(err.message, 2) + done() + }); + + next() + next(new Error(1)) + next(new Error(2)) +}) + +test('eee', function(done) { + done = after(3, done) + + function cb(err) { + assert.equal(err.message, 1); + done() + } + + var next = after(3, cb, function(err) { + assert.equal(err.message, 2) + done() + }); + + next(new Error(1)) + next(new Error(2)) + next(new Error(2)) +}) + +test('gge', function(done) { + function cb(err) { + assert.equal(err.message, 1); + done() + } + + var next = after(3, cb, function(err) { + // should not happen + assert.ok(false); + }); + + next() + next() + next(new Error(1)) +}) + +test('egg', function(done) { + function cb(err) { + assert.equal(err.message, 1); + done() + } + + var next = after(3, cb, function(err) { + // should not happen + assert.ok(false); + }); + + next(new Error(1)) + next() + next() +}) + +test('throws on too many calls', function(done) { + var next = after(1, done); + next() + assert.throws(next, /after called too many times/); +}); + diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/arraybuffer.slice/.npmignore b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/arraybuffer.slice/.npmignore new file mode 100644 index 0000000..cfbee8d --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/arraybuffer.slice/.npmignore @@ -0,0 +1,17 @@ +lib-cov +lcov.info +*.seed +*.log +*.csv +*.dat +*.out +*.pid +*.gz + +pids +logs +results +build +.grunt + +node_modules diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/arraybuffer.slice/Makefile b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/arraybuffer.slice/Makefile new file mode 100644 index 0000000..849887f --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/arraybuffer.slice/Makefile @@ -0,0 +1,8 @@ + +REPORTER = dot + +test: + @./node_modules/.bin/mocha \ + --reporter $(REPORTER) + +.PHONY: test diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/arraybuffer.slice/README.md b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/arraybuffer.slice/README.md new file mode 100644 index 0000000..15e465e --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/arraybuffer.slice/README.md @@ -0,0 +1,17 @@ +# How to +```javascript +var sliceBuffer = require('arraybuffer.slice'); +var ab = (new Int8Array(5)).buffer; +var sliced = sliceBuffer(ab, 1, 3); +sliced = sliceBuffer(ab, 1); +``` + +# Licence (MIT) +Copyright (C) 2013 Rase- + + +Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/arraybuffer.slice/index.js b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/arraybuffer.slice/index.js new file mode 100644 index 0000000..11ac556 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/arraybuffer.slice/index.js @@ -0,0 +1,29 @@ +/** + * An abstraction for slicing an arraybuffer even when + * ArrayBuffer.prototype.slice is not supported + * + * @api public + */ + +module.exports = function(arraybuffer, start, end) { + var bytes = arraybuffer.byteLength; + start = start || 0; + end = end || bytes; + + if (arraybuffer.slice) { return arraybuffer.slice(start, end); } + + if (start < 0) { start += bytes; } + if (end < 0) { end += bytes; } + if (end > bytes) { end = bytes; } + + if (start >= bytes || start >= end || bytes === 0) { + return new ArrayBuffer(0); + } + + var abv = new Uint8Array(arraybuffer); + var result = new Uint8Array(end - start); + for (var i = start, ii = 0; i < end; i++, ii++) { + result[ii] = abv[i]; + } + return result.buffer; +}; diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/arraybuffer.slice/package.json b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/arraybuffer.slice/package.json new file mode 100644 index 0000000..aaa27db --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/arraybuffer.slice/package.json @@ -0,0 +1,39 @@ +{ + "name": "arraybuffer.slice", + "description": "Exports a function for slicing ArrayBuffers (no polyfilling)", + "version": "0.0.6", + "homepage": "https://github.com/rase-/arraybuffer.slice", + "dependencies": {}, + "devDependencies": { + "mocha": "1.17.1", + "expect.js": "0.2.0" + }, + "repository": { + "type": "git", + "url": "git+ssh://git@github.com/rase-/arraybuffer.slice.git" + }, + "bugs": { + "url": "https://github.com/rase-/arraybuffer.slice/issues" + }, + "_id": "arraybuffer.slice@0.0.6", + "dist": { + "shasum": "f33b2159f0532a3f3107a272c0ccfbd1ad2979ca", + "tarball": "https://registry.npmjs.org/arraybuffer.slice/-/arraybuffer.slice-0.0.6.tgz" + }, + "_from": "arraybuffer.slice@0.0.6", + "_npmVersion": "1.3.5", + "_npmUser": { + "name": "rase-", + "email": "tonykovanen@hotmail.com" + }, + "maintainers": [ + { + "name": "rase-", + "email": "tonykovanen@hotmail.com" + } + ], + "directories": {}, + "_shasum": "f33b2159f0532a3f3107a272c0ccfbd1ad2979ca", + "_resolved": "http://registry.npmjs.org/arraybuffer.slice/-/arraybuffer.slice-0.0.6.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/arraybuffer.slice/test/slice-buffer.js b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/arraybuffer.slice/test/slice-buffer.js new file mode 100644 index 0000000..4778da6 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/arraybuffer.slice/test/slice-buffer.js @@ -0,0 +1,227 @@ +/* + * Test dependencies + */ + +var sliceBuffer = require('../index.js'); +var expect = require('expect.js'); + +/** + * Tests + */ + +describe('sliceBuffer', function() { + describe('using standard slice', function() { + it('should slice correctly with only start provided', function() { + var abv = new Uint8Array(10); + for (var i = 0; i < abv.length; i++) { + abv[i] = i; + } + + var sliced = sliceBuffer(abv.buffer, 3); + var sabv = new Uint8Array(sliced); + for (var i = 3, ii = 0; i < abv.length; i++, ii++) { + expect(abv[i]).to.equal(sabv[ii]); + } + }); + + it('should slice correctly with start and end provided', function() { + var abv = new Uint8Array(10); + for (var i = 0; i < abv.length; i++) { + abv[i] = i; + } + + var sliced = sliceBuffer(abv.buffer, 3, 8); + var sabv = new Uint8Array(sliced); + for (var i = 3, ii = 0; i < 8; i++, ii++) { + expect(abv[i]).to.equal(sabv[ii]); + } + }); + + it('should slice correctly with negative start', function() { + var abv = new Uint8Array(10); + for (var i = 0; i < abv.length; i++) { + abv[i] = i; + } + + var sliced = sliceBuffer(abv.buffer, -3); + var sabv = new Uint8Array(sliced); + for (var i = abv.length - 3, ii = 0; i < abv.length; i++, ii++) { + expect(abv[i]).to.equal(sabv[ii]); + } + }); + + it('should slice correctly with negative end', function() { + var abv = new Uint8Array(10); + for (var i = 0; i < abv.length; i++) { + abv[i] = i; + } + + var sliced = sliceBuffer(abv.buffer, 0, -3); + var sabv = new Uint8Array(sliced); + for (var i = 0, ii = 0; i < abv.length - 3; i++, ii++) { + expect(abv[i]).to.equal(sabv[ii]); + } + }); + + it('should slice correctly with negative start and end', function() { + var abv = new Uint8Array(10); + for (var i = 0; i < abv.length; i++) { + abv[i] = i; + } + + var sliced = sliceBuffer(abv.buffer, -6, -3); + var sabv = new Uint8Array(sliced); + for (var i = abv.length - 6, ii = 0; i < abv.length - 3; i++, ii++) { + expect(abv[i]).to.equal(sabv[ii]); + } + }); + + it('should slice correctly with equal start and end', function() { + var abv = new Uint8Array(10); + for (var i = 0; i < abv.length; i++) { + abv[i] = i; + } + + var sliced = sliceBuffer(abv.buffer, 1, 1); + expect(sliced.byteLength).to.equal(0); + }); + + it('should slice correctly when end larger than buffer', function() { + var abv = new Uint8Array(10); + for (var i = 0; i < abv.length; i++) { + abv[i] = i; + } + + var sliced = sliceBuffer(abv.buffer, 0, 100); + expect(new Uint8Array(sliced)).to.eql(abv); + }); + + it('shoud slice correctly when start larger than end', function() { + var abv = new Uint8Array(10); + for (var i = 0; i < abv.length; i++) { + abv[i] = i; + } + + var sliced = sliceBuffer(abv.buffer, 6, 5); + expect(sliced.byteLength).to.equal(0); + }); + }); + + describe('using fallback', function() { + it('should slice correctly with only start provided', function() { + var abv = new Uint8Array(10); + for (var i = 0; i < abv.length; i++) { + abv[i] = i; + } + var ab = abv.buffer; + ab.slice = undefined; + + var sliced = sliceBuffer(ab, 3); + var sabv = new Uint8Array(sliced); + for (var i = 3, ii = 0; i < abv.length; i++, ii++) { + expect(abv[i]).to.equal(sabv[ii]); + } + }); + + it('should slice correctly with start and end provided', function() { + var abv = new Uint8Array(10); + for (var i = 0; i < abv.length; i++) { + abv[i] = i; + } + var ab = abv.buffer; + ab.slice = undefined; + + + var sliced = sliceBuffer(ab, 3, 8); + var sabv = new Uint8Array(sliced); + for (var i = 3, ii = 0; i < 8; i++, ii++) { + expect(abv[i]).to.equal(sabv[ii]); + } + }); + + it('should slice correctly with negative start', function() { + var abv = new Uint8Array(10); + for (var i = 0; i < abv.length; i++) { + abv[i] = i; + } + var ab = abv.buffer; + ab.slice = undefined; + + + var sliced = sliceBuffer(ab, -3); + var sabv = new Uint8Array(sliced); + for (var i = abv.length - 3, ii = 0; i < abv.length; i++, ii++) { + expect(abv[i]).to.equal(sabv[ii]); + } + }); + + it('should slice correctly with negative end', function() { + var abv = new Uint8Array(10); + for (var i = 0; i < abv.length; i++) { + abv[i] = i; + } + var ab = abv.buffer; + ab.slice = undefined; + + var sliced = sliceBuffer(ab, 0, -3); + var sabv = new Uint8Array(sliced); + for (var i = 0, ii = 0; i < abv.length - 3; i++, ii++) { + expect(abv[i]).to.equal(sabv[ii]); + } + }); + + it('should slice correctly with negative start and end', function() { + var abv = new Uint8Array(10); + for (var i = 0; i < abv.length; i++) { + abv[i] = i; + } + var ab = abv.buffer; + ab.slice = undefined; + + var sliced = sliceBuffer(ab, -6, -3); + var sabv = new Uint8Array(sliced); + for (var i = abv.length - 6, ii = 0; i < abv.length - 3; i++, ii++) { + expect(abv[i]).to.equal(sabv[ii]); + } + }); + + it('should slice correctly with equal start and end', function() { + var abv = new Uint8Array(10); + for (var i = 0; i < abv.length; i++) { + abv[i] = i; + } + var ab = abv.buffer; + ab.slice = undefined; + + var sliced = sliceBuffer(ab, 1, 1); + expect(sliced.byteLength).to.equal(0); + }); + + it('should slice correctly when end larger than buffer', function() { + var abv = new Uint8Array(10); + for (var i = 0; i < abv.length; i++) { + abv[i] = i; + } + var ab = abv.buffer; + ab.slice = undefined; + + var sliced = sliceBuffer(ab, 0, 100); + var sabv = new Uint8Array(sliced); + for (var i = 0; i < abv.length; i++) { + expect(abv[i]).to.equal(sabv[i]); + } + }); + + it('shoud slice correctly when start larger than end', function() { + var abv = new Uint8Array(10); + for (var i = 0; i < abv.length; i++) { + abv[i] = i; + } + var ab = abv.buffer; + ab.slice = undefined; + + var sliced = sliceBuffer(ab, 6, 5); + expect(sliced.byteLength).to.equal(0); + }); + }); +}); diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/base64-arraybuffer/.npmignore b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/base64-arraybuffer/.npmignore new file mode 100644 index 0000000..332ee5a --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/base64-arraybuffer/.npmignore @@ -0,0 +1,3 @@ +/node_modules/ +Gruntfile.js +/test/ diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/base64-arraybuffer/.travis.yml b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/base64-arraybuffer/.travis.yml new file mode 100644 index 0000000..19259a5 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/base64-arraybuffer/.travis.yml @@ -0,0 +1,19 @@ +language: node_js +node_js: +- '0.12' +- iojs-1 +- iojs-2 +- iojs-3 +- '4.1' +before_script: +- npm install +before_install: npm install -g npm@'>=2.13.5' +deploy: + provider: npm + email: niklasvh@gmail.com + api_key: + secure: oHV9ArprTj5WOk7MP1UF7QMJ70huXw+y7xXb5wF4+V2H8Hyfa5TfE0DiOmqrube1WXTeH1FLgq54shp/sJWi47Hkg/GyeoB5NnsPhYEaJkaON9UG5blML+ODiNVsEnq/1kNBQ8e0+0JItMPLGySKyFmuZ3yflulXKS8O88mfINo= + on: + tags: true + branch: master + repo: niklasvh/base64-arraybuffer diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/base64-arraybuffer/LICENSE-MIT b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/base64-arraybuffer/LICENSE-MIT new file mode 100644 index 0000000..ed27b41 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/base64-arraybuffer/LICENSE-MIT @@ -0,0 +1,22 @@ +Copyright (c) 2012 Niklas von Hertzen + +Permission is hereby granted, free of charge, to any person +obtaining a copy of this software and associated documentation +files (the "Software"), to deal in the Software without +restriction, including without limitation the rights to use, +copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the +Software is furnished to do so, subject to the following +conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES +OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND +NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT +HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, +WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING +FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR +OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/base64-arraybuffer/README.md b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/base64-arraybuffer/README.md new file mode 100644 index 0000000..50009e4 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/base64-arraybuffer/README.md @@ -0,0 +1,20 @@ +# base64-arraybuffer + +[![Build Status](https://travis-ci.org/niklasvh/base64-arraybuffer.png)](https://travis-ci.org/niklasvh/base64-arraybuffer) +[![NPM Downloads](https://img.shields.io/npm/dm/base64-arraybuffer.svg)](https://www.npmjs.org/package/base64-arraybuffer) +[![NPM Version](https://img.shields.io/npm/v/base64-arraybuffer.svg)](https://www.npmjs.org/package/base64-arraybuffer) + +Encode/decode base64 data into ArrayBuffers + +## Getting Started +Install the module with: `npm install base64-arraybuffer` + +## API +The library encodes and decodes base64 to and from ArrayBuffers + + - __encode(buffer)__ - Encodes `ArrayBuffer` into base64 string + - __decode(str)__ - Decodes base64 string to `ArrayBuffer` + +## License +Copyright (c) 2012 Niklas von Hertzen +Licensed under the MIT license. diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/base64-arraybuffer/lib/base64-arraybuffer.js b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/base64-arraybuffer/lib/base64-arraybuffer.js new file mode 100644 index 0000000..e6b6306 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/base64-arraybuffer/lib/base64-arraybuffer.js @@ -0,0 +1,67 @@ +/* + * base64-arraybuffer + * https://github.com/niklasvh/base64-arraybuffer + * + * Copyright (c) 2012 Niklas von Hertzen + * Licensed under the MIT license. + */ +(function(){ + "use strict"; + + var chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"; + + // Use a lookup table to find the index. + var lookup = new Uint8Array(256); + for (var i = 0; i < chars.length; i++) { + lookup[chars.charCodeAt(i)] = i; + } + + exports.encode = function(arraybuffer) { + var bytes = new Uint8Array(arraybuffer), + i, len = bytes.length, base64 = ""; + + for (i = 0; i < len; i+=3) { + base64 += chars[bytes[i] >> 2]; + base64 += chars[((bytes[i] & 3) << 4) | (bytes[i + 1] >> 4)]; + base64 += chars[((bytes[i + 1] & 15) << 2) | (bytes[i + 2] >> 6)]; + base64 += chars[bytes[i + 2] & 63]; + } + + if ((len % 3) === 2) { + base64 = base64.substring(0, base64.length - 1) + "="; + } else if (len % 3 === 1) { + base64 = base64.substring(0, base64.length - 2) + "=="; + } + + return base64; + }; + + exports.decode = function(base64) { + var bufferLength = base64.length * 0.75, + len = base64.length, i, p = 0, + encoded1, encoded2, encoded3, encoded4; + + if (base64[base64.length - 1] === "=") { + bufferLength--; + if (base64[base64.length - 2] === "=") { + bufferLength--; + } + } + + var arraybuffer = new ArrayBuffer(bufferLength), + bytes = new Uint8Array(arraybuffer); + + for (i = 0; i < len; i+=4) { + encoded1 = lookup[base64.charCodeAt(i)]; + encoded2 = lookup[base64.charCodeAt(i+1)]; + encoded3 = lookup[base64.charCodeAt(i+2)]; + encoded4 = lookup[base64.charCodeAt(i+3)]; + + bytes[p++] = (encoded1 << 2) | (encoded2 >> 4); + bytes[p++] = ((encoded2 & 15) << 4) | (encoded3 >> 2); + bytes[p++] = ((encoded3 & 3) << 6) | (encoded4 & 63); + } + + return arraybuffer; + }; +})(); diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/base64-arraybuffer/package.json b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/base64-arraybuffer/package.json new file mode 100644 index 0000000..fac021d --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/base64-arraybuffer/package.json @@ -0,0 +1,61 @@ +{ + "name": "base64-arraybuffer", + "description": "Encode/decode base64 data into ArrayBuffers", + "version": "0.1.5", + "homepage": "https://github.com/niklasvh/base64-arraybuffer", + "author": { + "name": "Niklas von Hertzen", + "email": "niklasvh@gmail.com", + "url": "http://hertzen.com" + }, + "repository": { + "type": "git", + "url": "git+https://github.com/niklasvh/base64-arraybuffer.git" + }, + "bugs": { + "url": "https://github.com/niklasvh/base64-arraybuffer/issues" + }, + "licenses": [ + { + "type": "MIT", + "url": "https://github.com/niklasvh/base64-arraybuffer/blob/master/LICENSE-MIT" + } + ], + "main": "lib/base64-arraybuffer", + "engines": { + "node": ">= 0.6.0" + }, + "scripts": { + "test": "grunt nodeunit" + }, + "devDependencies": { + "grunt": "^0.4.5", + "grunt-cli": "^0.1.13", + "grunt-contrib-jshint": "^0.11.2", + "grunt-contrib-nodeunit": "^0.4.1", + "grunt-contrib-watch": "^0.6.1" + }, + "keywords": [], + "gitHead": "e9457ccb7b140f5ae54a2880c8e9b967ffb03a7d", + "_id": "base64-arraybuffer@0.1.5", + "_shasum": "73926771923b5a19747ad666aa5cd4bf9c6e9ce8", + "_from": "base64-arraybuffer@0.1.5", + "_npmVersion": "3.4.0", + "_nodeVersion": "2.5.0", + "_npmUser": { + "name": "niklasvh", + "email": "niklasvh@gmail.com" + }, + "dist": { + "shasum": "73926771923b5a19747ad666aa5cd4bf9c6e9ce8", + "tarball": "https://registry.npmjs.org/base64-arraybuffer/-/base64-arraybuffer-0.1.5.tgz" + }, + "maintainers": [ + { + "name": "niklasvh", + "email": "niklasvh@gmail.com" + } + ], + "directories": {}, + "_resolved": "http://registry.npmjs.org/base64-arraybuffer/-/base64-arraybuffer-0.1.5.tgz" +} diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/blob/.npmignore b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/blob/.npmignore new file mode 100644 index 0000000..548a368 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/blob/.npmignore @@ -0,0 +1,2 @@ +node_modules +blob.js diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/blob/.zuul.yml b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/blob/.zuul.yml new file mode 100644 index 0000000..380c395 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/blob/.zuul.yml @@ -0,0 +1,14 @@ +ui: mocha-bdd +browsers: + - name: chrome + version: 8..latest + - name: firefox + version: 7..latest + - name: safari + version: 6..latest + - name: opera + version: 12.1..latest + - name: ie + version: 10..latest + - name: android + version: latest diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/blob/Makefile b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/blob/Makefile new file mode 100644 index 0000000..7d9601a --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/blob/Makefile @@ -0,0 +1,14 @@ +REPORTER = dot + +build: blob.js + +blob.js: + @./node_modules/.bin/browserify --standalone blob index.js > blob.js + +test: + @./node_modules/.bin/zuul -- test/index.js + +clean: + rm blob.js + +.PHONY: test blob.js diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/blob/README.md b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/blob/README.md new file mode 100644 index 0000000..6915955 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/blob/README.md @@ -0,0 +1,14 @@ +Blob +==== + +A module that exports a constructor that uses window.Blob when available, and a BlobBuilder with any vendor prefix in other cases. If neither is available, it exports undefined. + +Usage: + +```javascript +var Blob = require('blob'); +var b = new Blob(['hi', 'constructing', 'a', 'blob']); +``` + +## Licence +MIT diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/blob/index.js b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/blob/index.js new file mode 100644 index 0000000..cad3f84 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/blob/index.js @@ -0,0 +1,96 @@ +/** + * Create a blob builder even when vendor prefixes exist + */ + +var BlobBuilder = global.BlobBuilder + || global.WebKitBlobBuilder + || global.MSBlobBuilder + || global.MozBlobBuilder; + +/** + * Check if Blob constructor is supported + */ + +var blobSupported = (function() { + try { + var a = new Blob(['hi']); + return a.size === 2; + } catch(e) { + return false; + } +})(); + +/** + * Check if Blob constructor supports ArrayBufferViews + * Fails in Safari 6, so we need to map to ArrayBuffers there. + */ + +var blobSupportsArrayBufferView = blobSupported && (function() { + try { + var b = new Blob([new Uint8Array([1,2])]); + return b.size === 2; + } catch(e) { + return false; + } +})(); + +/** + * Check if BlobBuilder is supported + */ + +var blobBuilderSupported = BlobBuilder + && BlobBuilder.prototype.append + && BlobBuilder.prototype.getBlob; + +/** + * Helper function that maps ArrayBufferViews to ArrayBuffers + * Used by BlobBuilder constructor and old browsers that didn't + * support it in the Blob constructor. + */ + +function mapArrayBufferViews(ary) { + for (var i = 0; i < ary.length; i++) { + var chunk = ary[i]; + if (chunk.buffer instanceof ArrayBuffer) { + var buf = chunk.buffer; + + // if this is a subarray, make a copy so we only + // include the subarray region from the underlying buffer + if (chunk.byteLength !== buf.byteLength) { + var copy = new Uint8Array(chunk.byteLength); + copy.set(new Uint8Array(buf, chunk.byteOffset, chunk.byteLength)); + buf = copy.buffer; + } + + ary[i] = buf; + } + } +} + +function BlobBuilderConstructor(ary, options) { + options = options || {}; + + var bb = new BlobBuilder(); + mapArrayBufferViews(ary); + + for (var i = 0; i < ary.length; i++) { + bb.append(ary[i]); + } + + return (options.type) ? bb.getBlob(options.type) : bb.getBlob(); +}; + +function BlobConstructor(ary, options) { + mapArrayBufferViews(ary); + return new Blob(ary, options || {}); +}; + +module.exports = (function() { + if (blobSupported) { + return blobSupportsArrayBufferView ? global.Blob : BlobConstructor; + } else if (blobBuilderSupported) { + return BlobBuilderConstructor; + } else { + return undefined; + } +})(); diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/blob/package.json b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/blob/package.json new file mode 100644 index 0000000..83896a1 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/blob/package.json @@ -0,0 +1,44 @@ +{ + "name": "blob", + "description": "Abstracts out Blob and uses BlobBulder in cases where it is supported with any vendor prefix.", + "version": "0.0.4", + "homepage": "https://github.com/rase-/blob", + "dependencies": {}, + "devDependencies": { + "mocha": "1.17.1", + "expect.js": "0.2.0", + "zuul": "1.5.4", + "browserify": "3.30.1" + }, + "repository": { + "type": "git", + "url": "git+ssh://git@github.com/rase-/blob.git" + }, + "scripts": { + "test": "make test" + }, + "bugs": { + "url": "https://github.com/rase-/blob/issues" + }, + "_id": "blob@0.0.4", + "dist": { + "shasum": "bcf13052ca54463f30f9fc7e95b9a47630a94921", + "tarball": "https://registry.npmjs.org/blob/-/blob-0.0.4.tgz" + }, + "_from": "blob@0.0.4", + "_npmVersion": "1.4.6", + "_npmUser": { + "name": "rase-", + "email": "tonykovanen@hotmail.com" + }, + "maintainers": [ + { + "name": "rase-", + "email": "tonykovanen@hotmail.com" + } + ], + "directories": {}, + "_shasum": "bcf13052ca54463f30f9fc7e95b9a47630a94921", + "_resolved": "http://registry.npmjs.org/blob/-/blob-0.0.4.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/blob/test/index.js b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/blob/test/index.js new file mode 100644 index 0000000..df9303f --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/blob/test/index.js @@ -0,0 +1,94 @@ +var Blob = require('../'); +var expect = require('expect.js'); + +describe('blob', function() { + if (!Blob) { + it('should not have a blob or a blob builder in the global namespace, or blob should not be a constructor function if the module exports false', function() { + try { + var ab = (new Uint8Array(5)).buffer; + global.Blob([ab]); + expect().fail('Blob shouldn\'t be constructable'); + } catch (e) {} + + var BlobBuilder = global.BlobBuilder + || global.WebKitBlobBuilder + || global.MSBlobBuilder + || global.MozBlobBuilder; + expect(BlobBuilder).to.be(undefined); + }); + } else { + it('should encode a proper sized blob when given a string argument', function() { + var b = new Blob(['hi']); + expect(b.size).to.be(2); + }); + + it('should encode a blob with proper size when given two strings as arguments', function() { + var b = new Blob(['hi', 'hello']); + expect(b.size).to.be(7); + }); + + it('should encode arraybuffers with right content', function(done) { + var ary = new Uint8Array(5); + for (var i = 0; i < 5; i++) ary[i] = i; + var b = new Blob([ary.buffer]); + var fr = new FileReader(); + fr.onload = function() { + var newAry = new Uint8Array(this.result); + for (var i = 0; i < 5; i++) expect(newAry[i]).to.be(i); + done(); + }; + fr.readAsArrayBuffer(b); + }); + + it('should encode typed arrays with right content', function(done) { + var ary = new Uint8Array(5); + for (var i = 0; i < 5; i++) ary[i] = i; + var b = new Blob([ary]); + var fr = new FileReader(); + fr.onload = function() { + var newAry = new Uint8Array(this.result); + for (var i = 0; i < 5; i++) expect(newAry[i]).to.be(i); + done(); + }; + fr.readAsArrayBuffer(b); + }); + + it('should encode sliced typed arrays with right content', function(done) { + var ary = new Uint8Array(5); + for (var i = 0; i < 5; i++) ary[i] = i; + var b = new Blob([ary.subarray(2)]); + var fr = new FileReader(); + fr.onload = function() { + var newAry = new Uint8Array(this.result); + for (var i = 0; i < 3; i++) expect(newAry[i]).to.be(i + 2); + done(); + }; + fr.readAsArrayBuffer(b); + }); + + it('should encode with blobs', function(done) { + var ary = new Uint8Array(5); + for (var i = 0; i < 5; i++) ary[i] = i; + var b = new Blob([new Blob([ary.buffer])]); + var fr = new FileReader(); + fr.onload = function() { + var newAry = new Uint8Array(this.result); + for (var i = 0; i < 5; i++) expect(newAry[i]).to.be(i); + done(); + }; + fr.readAsArrayBuffer(b); + }); + + it('should enode mixed contents to right size', function() { + var ary = new Uint8Array(5); + for (var i = 0; i < 5; i++) ary[i] = i; + var b = new Blob([ary.buffer, 'hello']); + expect(b.size).to.be(10); + }); + + it('should accept mime type', function() { + var b = new Blob(['hi', 'hello'], { type: 'text/html' }); + expect(b.type).to.be('text/html'); + }); + } +}); diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/.npmignore b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/.npmignore new file mode 100644 index 0000000..a72b52e --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/.npmignore @@ -0,0 +1,15 @@ +lib-cov +*.seed +*.log +*.csv +*.dat +*.out +*.pid +*.gz + +pids +logs +results + +npm-debug.log +node_modules diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/History.md b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/History.md new file mode 100644 index 0000000..a1e3867 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/History.md @@ -0,0 +1,11 @@ + +0.1.6 / 2015-01-24 +================== + + * fix "undefined function" bug when iterating + an object created with Object.create(null) [gunta] + +0.1.5 / 2014-09-04 +================== + + * prevent browserify from bundling `Buffer` diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/LICENSE b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/LICENSE new file mode 100644 index 0000000..e6603cd --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/LICENSE @@ -0,0 +1,20 @@ +The MIT License (MIT) + +Copyright (c) 2014 Kevin Roark + +Permission is hereby granted, free of charge, to any person obtaining a copy of +this software and associated documentation files (the "Software"), to deal in +the Software without restriction, including without limitation the rights to +use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of +the Software, and to permit persons to whom the Software is furnished to do so, +subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS +FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR +COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER +IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN +CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/Makefile b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/Makefile new file mode 100644 index 0000000..1d90629 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/Makefile @@ -0,0 +1,3 @@ + +test: + @./node_modules/.bin/mocha test.js diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/README.md b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/README.md new file mode 100644 index 0000000..76a0035 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/README.md @@ -0,0 +1,4 @@ +has-binarydata.js +================= + +Simple module to test if an object contains binary data diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/fixtures/big.json b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/fixtures/big.json new file mode 100644 index 0000000..3172879 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/fixtures/big.json @@ -0,0 +1 @@ +{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":{"k":"cool"}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}} diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/index.js b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/index.js new file mode 100644 index 0000000..7684d23 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/index.js @@ -0,0 +1,58 @@ + +/* + * Module requirements. + */ + +var isArray = require('isarray'); + +/** + * Module exports. + */ + +module.exports = hasBinary; + +/** + * Checks for binary data. + * + * Right now only Buffer and ArrayBuffer are supported.. + * + * @param {Object} anything + * @api public + */ + +function hasBinary(data) { + + function _hasBinary(obj) { + if (!obj) return false; + + if ( (global.Buffer && global.Buffer.isBuffer(obj)) || + (global.ArrayBuffer && obj instanceof ArrayBuffer) || + (global.Blob && obj instanceof Blob) || + (global.File && obj instanceof File) + ) { + return true; + } + + if (isArray(obj)) { + for (var i = 0; i < obj.length; i++) { + if (_hasBinary(obj[i])) { + return true; + } + } + } else if (obj && 'object' == typeof obj) { + if (obj.toJSON) { + obj = obj.toJSON(); + } + + for (var key in obj) { + if (Object.prototype.hasOwnProperty.call(obj, key) && _hasBinary(obj[key])) { + return true; + } + } + } + + return false; + } + + return _hasBinary(data); +} diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/node_modules/isarray/README.md b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/node_modules/isarray/README.md new file mode 100644 index 0000000..052a62b --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/node_modules/isarray/README.md @@ -0,0 +1,54 @@ + +# isarray + +`Array#isArray` for older browsers. + +## Usage + +```js +var isArray = require('isarray'); + +console.log(isArray([])); // => true +console.log(isArray({})); // => false +``` + +## Installation + +With [npm](http://npmjs.org) do + +```bash +$ npm install isarray +``` + +Then bundle for the browser with +[browserify](https://github.com/substack/browserify). + +With [component](http://component.io) do + +```bash +$ component install juliangruber/isarray +``` + +## License + +(MIT) + +Copyright (c) 2013 Julian Gruber <julian@juliangruber.com> + +Permission is hereby granted, free of charge, to any person obtaining a copy of +this software and associated documentation files (the "Software"), to deal in +the Software without restriction, including without limitation the rights to +use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies +of the Software, and to permit persons to whom the Software is furnished to do +so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/node_modules/isarray/build/build.js b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/node_modules/isarray/build/build.js new file mode 100644 index 0000000..ec58596 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/node_modules/isarray/build/build.js @@ -0,0 +1,209 @@ + +/** + * Require the given path. + * + * @param {String} path + * @return {Object} exports + * @api public + */ + +function require(path, parent, orig) { + var resolved = require.resolve(path); + + // lookup failed + if (null == resolved) { + orig = orig || path; + parent = parent || 'root'; + var err = new Error('Failed to require "' + orig + '" from "' + parent + '"'); + err.path = orig; + err.parent = parent; + err.require = true; + throw err; + } + + var module = require.modules[resolved]; + + // perform real require() + // by invoking the module's + // registered function + if (!module.exports) { + module.exports = {}; + module.client = module.component = true; + module.call(this, module.exports, require.relative(resolved), module); + } + + return module.exports; +} + +/** + * Registered modules. + */ + +require.modules = {}; + +/** + * Registered aliases. + */ + +require.aliases = {}; + +/** + * Resolve `path`. + * + * Lookup: + * + * - PATH/index.js + * - PATH.js + * - PATH + * + * @param {String} path + * @return {String} path or null + * @api private + */ + +require.resolve = function(path) { + if (path.charAt(0) === '/') path = path.slice(1); + var index = path + '/index.js'; + + var paths = [ + path, + path + '.js', + path + '.json', + path + '/index.js', + path + '/index.json' + ]; + + for (var i = 0; i < paths.length; i++) { + var path = paths[i]; + if (require.modules.hasOwnProperty(path)) return path; + } + + if (require.aliases.hasOwnProperty(index)) { + return require.aliases[index]; + } +}; + +/** + * Normalize `path` relative to the current path. + * + * @param {String} curr + * @param {String} path + * @return {String} + * @api private + */ + +require.normalize = function(curr, path) { + var segs = []; + + if ('.' != path.charAt(0)) return path; + + curr = curr.split('/'); + path = path.split('/'); + + for (var i = 0; i < path.length; ++i) { + if ('..' == path[i]) { + curr.pop(); + } else if ('.' != path[i] && '' != path[i]) { + segs.push(path[i]); + } + } + + return curr.concat(segs).join('/'); +}; + +/** + * Register module at `path` with callback `definition`. + * + * @param {String} path + * @param {Function} definition + * @api private + */ + +require.register = function(path, definition) { + require.modules[path] = definition; +}; + +/** + * Alias a module definition. + * + * @param {String} from + * @param {String} to + * @api private + */ + +require.alias = function(from, to) { + if (!require.modules.hasOwnProperty(from)) { + throw new Error('Failed to alias "' + from + '", it does not exist'); + } + require.aliases[to] = from; +}; + +/** + * Return a require function relative to the `parent` path. + * + * @param {String} parent + * @return {Function} + * @api private + */ + +require.relative = function(parent) { + var p = require.normalize(parent, '..'); + + /** + * lastIndexOf helper. + */ + + function lastIndexOf(arr, obj) { + var i = arr.length; + while (i--) { + if (arr[i] === obj) return i; + } + return -1; + } + + /** + * The relative require() itself. + */ + + function localRequire(path) { + var resolved = localRequire.resolve(path); + return require(resolved, parent, path); + } + + /** + * Resolve relative to the parent. + */ + + localRequire.resolve = function(path) { + var c = path.charAt(0); + if ('/' == c) return path.slice(1); + if ('.' == c) return require.normalize(p, path); + + // resolve deps by returning + // the dep in the nearest "deps" + // directory + var segs = parent.split('/'); + var i = lastIndexOf(segs, 'deps') + 1; + if (!i) i = 0; + path = segs.slice(0, i + 1).join('/') + '/deps/' + path; + return path; + }; + + /** + * Check if module is defined at `path`. + */ + + localRequire.exists = function(path) { + return require.modules.hasOwnProperty(localRequire.resolve(path)); + }; + + return localRequire; +}; +require.register("isarray/index.js", function(exports, require, module){ +module.exports = Array.isArray || function (arr) { + return Object.prototype.toString.call(arr) == '[object Array]'; +}; + +}); +require.alias("isarray/index.js", "isarray/index.js"); + diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/node_modules/isarray/component.json b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/node_modules/isarray/component.json new file mode 100644 index 0000000..9e31b68 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/node_modules/isarray/component.json @@ -0,0 +1,19 @@ +{ + "name" : "isarray", + "description" : "Array#isArray for older browsers", + "version" : "0.0.1", + "repository" : "juliangruber/isarray", + "homepage": "https://github.com/juliangruber/isarray", + "main" : "index.js", + "scripts" : [ + "index.js" + ], + "dependencies" : {}, + "keywords": ["browser","isarray","array"], + "author": { + "name": "Julian Gruber", + "email": "mail@juliangruber.com", + "url": "http://juliangruber.com" + }, + "license": "MIT" +} diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/node_modules/isarray/index.js b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/node_modules/isarray/index.js new file mode 100644 index 0000000..5f5ad45 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/node_modules/isarray/index.js @@ -0,0 +1,3 @@ +module.exports = Array.isArray || function (arr) { + return Object.prototype.toString.call(arr) == '[object Array]'; +}; diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/node_modules/isarray/package.json b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/node_modules/isarray/package.json new file mode 100644 index 0000000..a5886f3 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/node_modules/isarray/package.json @@ -0,0 +1,53 @@ +{ + "name": "isarray", + "description": "Array#isArray for older browsers", + "version": "0.0.1", + "repository": { + "type": "git", + "url": "git://github.com/juliangruber/isarray.git" + }, + "homepage": "https://github.com/juliangruber/isarray", + "main": "index.js", + "scripts": { + "test": "tap test/*.js" + }, + "dependencies": {}, + "devDependencies": { + "tap": "*" + }, + "keywords": [ + "browser", + "isarray", + "array" + ], + "author": { + "name": "Julian Gruber", + "email": "mail@juliangruber.com", + "url": "http://juliangruber.com" + }, + "license": "MIT", + "_id": "isarray@0.0.1", + "dist": { + "shasum": "8a18acfca9a8f4177e09abfc6038939b05d1eedf", + "tarball": "https://registry.npmjs.org/isarray/-/isarray-0.0.1.tgz" + }, + "_from": "isarray@0.0.1", + "_npmVersion": "1.2.18", + "_npmUser": { + "name": "juliangruber", + "email": "julian@juliangruber.com" + }, + "maintainers": [ + { + "name": "juliangruber", + "email": "julian@juliangruber.com" + } + ], + "directories": {}, + "_shasum": "8a18acfca9a8f4177e09abfc6038939b05d1eedf", + "_resolved": "http://registry.npmjs.org/isarray/-/isarray-0.0.1.tgz", + "bugs": { + "url": "https://github.com/juliangruber/isarray/issues" + }, + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/package.json b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/package.json new file mode 100644 index 0000000..92c88fd --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/package.json @@ -0,0 +1,39 @@ +{ + "name": "has-binary", + "version": "0.1.6", + "description": "A function that takes anything in javascript and returns true if its argument contains binary data.", + "dependencies": { + "isarray": "0.0.1" + }, + "devDependencies": { + "better-assert": "1.0.0", + "mocha": "1.17.1" + }, + "author": { + "name": "Kevin Roark" + }, + "license": "MIT", + "gitHead": "a37d7ed88fb88e49d5ed1ca15e6cc7dd004dd0e8", + "_id": "has-binary@0.1.6", + "scripts": {}, + "_shasum": "25326f39cfa4f616ad8787894e3af2cfbc7b6e10", + "_from": "has-binary@0.1.6", + "_npmVersion": "1.4.28", + "_npmUser": { + "name": "rauchg", + "email": "rauchg@gmail.com" + }, + "maintainers": [ + { + "name": "rauchg", + "email": "rauchg@gmail.com" + } + ], + "dist": { + "shasum": "25326f39cfa4f616ad8787894e3af2cfbc7b6e10", + "tarball": "https://registry.npmjs.org/has-binary/-/has-binary-0.1.6.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/has-binary/-/has-binary-0.1.6.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/test.js b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/test.js new file mode 100644 index 0000000..5320d4f --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/has-binary/test.js @@ -0,0 +1,108 @@ + +var hasBinary = require('./'); +var assert = require('better-assert'); +var fs = require('fs'); + +var start = new Date(); + +describe('has-binarydata', function(){ + + it('should work with buffer', function(){ + assert(hasBinary(fs.readFileSync('./test.js'))); + }); + + it('should work with an array that does not contain binary', function() { + var arr = [1, 'cool', 2]; + assert(!hasBinary(arr)); + }); + + it('should work with an array that contains a buffer', function() { + var arr = [1, new Buffer('asdfasdf', 'utf8'), 2]; + assert(hasBinary(arr)); + }); + + it('should work with an object that does not contain binary', function() { + var ob = {a: 'a', b: [], c: 1234}; + assert(!hasBinary(ob)); + }); + + it('should work with an object that contains a buffer', function() { + var ob = {a: 'a', b: new Buffer('abc'), c: 1234}; + assert(hasBinary(ob)); + }); + + it('should work with null', function() { + assert(!hasBinary(null)); + }); + + it('should work with undefined', function() { + assert(!hasBinary(undefined)); + }); + + it('should work with a complex object that contains undefined and no binary', function() { + var ob = { + x: ['a', 'b', 123], + y: undefined, + z: {a: 'x', b: 'y', c: 3, d: null}, + w: [] + }; + assert(!hasBinary(ob)); + }); + + it('should work with a complex object that contains undefined and binary', function() { + var ob = { + x: ['a', 'b', 123], + y: undefined, + z: {a: 'x', b: 'y', c: 3, d: null}, + w: [], + bin: new Buffer('xxx') + }; + assert(hasBinary(ob)); + }); + + it('should handle a very large json object with no binary', function(done) { + this.timeout(); + fs.readFile(__dirname + '/fixtures/big.json', function(err, data) { + if (err) { + console.log(err); + assert(false); + } + data = JSON.parse(data); + assert(!hasBinary(data)); + done(); + }); + }); + + it('should handle a very large json object with binary', function(done) { + this.timeout(); + fs.readFile(__dirname + '/fixtures/big.json', function(err, data) { + if (err) { + console.log(err); + assert(false); + } + var ob = JSON.parse(data); + ob.bin = {bin: {bin: {bin: new Buffer('abc')}}}; + assert(hasBinary(ob)); + done(); + }); + }); + + if (global.ArrayBuffer) { + it('should work with an ArrayBuffer', function() { + assert(hasBinary(new ArrayBuffer())); + }); + } + + if (global.Blob) { + it('should work with a Blob', function() { + assert(hasBinary(new Blob())); + }); + } + + it('should print the test time', function() { + var end = new Date(); + var diff = end - start; + console.log('\ntest time: ' + diff + ' ms'); + }); + +}); diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/wtf-8/LICENSE-MIT.txt b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/wtf-8/LICENSE-MIT.txt new file mode 100644 index 0000000..a41e0a7 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/wtf-8/LICENSE-MIT.txt @@ -0,0 +1,20 @@ +Copyright Mathias Bynens + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +"Software"), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND +NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE +LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION +OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION +WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/wtf-8/README.md b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/wtf-8/README.md new file mode 100644 index 0000000..b06c77e --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/wtf-8/README.md @@ -0,0 +1,105 @@ +# wtf-8 [![Build status](https://travis-ci.org/mathiasbynens/wtf-8.svg?branch=master)](https://travis-ci.org/mathiasbynens/wtf-8) [![Dependency status](https://gemnasium.com/mathiasbynens/wtf-8.svg)](https://gemnasium.com/mathiasbynens/wtf-8) + +_wtf-8_ is a well-tested [WTF-8](https://simonsapin.github.io/wtf-8/) encoder/decoder written in JavaScript. WTF-8 is a superset of UTF-8: it can encode/decode any given Unicode code point, including those of (unpaired) surrogates. [Here’s an online demo.](https://mothereff.in/wtf-8) + +Feel free to fork if you see possible improvements! + +## Installation + +Via [npm](http://npmjs.org/): + +```bash +npm install wtf-8 +``` + +Via [Bower](http://bower.io/): + +```bash +bower install wtf-8 +``` + +Via [Component](https://github.com/component/component): + +```bash +component install mathiasbynens/wtf-8 +``` + +In a browser: + +```html + +``` + +In [Narwhal](http://narwhaljs.org/), [Node.js](http://nodejs.org/), and [RingoJS ≥ v0.8.0](http://ringojs.org/): + +```js +var wtf8 = require('wtf-8'); +``` + +In [Rhino](http://www.mozilla.org/rhino/): + +```js +load('wtf-8.js'); +``` + +Using an AMD loader like [RequireJS](http://requirejs.org/): + +```js +require( + { + 'paths': { + 'wtf-8': 'path/to/wtf-8' + } + }, + ['wtf-8'], + function(wtf8) { + console.log(wtf8); + } +); +``` + +## API + +### `wtf8.encode(string)` + +Encodes any given JavaScript string (`string`) as WTF-8, and returns the WTF-8-encoded version of the string. + +```js +// U+00A9 COPYRIGHT SIGN; see http://codepoints.net/U+00A9 +wtf8.encode('\xA9'); +// → '\xC2\xA9' +// U+10001 LINEAR B SYLLABLE B038 E; see http://codepoints.net/U+10001 +wtf8.encode('\uD800\uDC01'); +// → '\xF0\x90\x80\x81' +``` + +### `wtf8.decode(byteString)` + +Decodes any given WTF-8-encoded string (`byteString`) as WTF-8, and returns the WTF-8-decoded version of the string. It throws an error when malformed WTF-8 is detected. + +```js +wtf8.decode('\xC2\xA9'); +// → '\xA9' + +wtf8.decode('\xF0\x90\x80\x81'); +// → '\uD800\uDC01' +// → U+10001 LINEAR B SYLLABLE B038 E +``` + +### `wtf8.version` + +A string representing the semantic version number. + +## Support + +_wtf-8_ has been tested in (at least) the latest versions of Chrome, Opera, Firefox, Safari, IE, Node.js, Narwhal, RingoJS, PhantomJS, and Rhino. + +## Author + +| [![twitter/mathias](https://gravatar.com/avatar/24e08a9ea84deb17ae121074d0f17125?s=70)](https://twitter.com/mathias "Follow @mathias on Twitter") | +|---| +| [Mathias Bynens](https://mathiasbynens.be/) | + +## License + +_wtf-8_ is available under the [MIT](https://mths.be/mit) license. diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/wtf-8/package.json b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/wtf-8/package.json new file mode 100644 index 0000000..ed646ff --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/wtf-8/package.json @@ -0,0 +1,63 @@ +{ + "name": "wtf-8", + "version": "1.0.0", + "description": "A well-tested WTF-8 encoder/decoder written in JavaScript.", + "homepage": "https://mths.be/wtf8", + "main": "wtf-8.js", + "keywords": [ + "charset", + "encoding", + "unicode", + "wtf8", + "wtf-8" + ], + "license": "MIT", + "author": { + "name": "Mathias Bynens", + "url": "https://mathiasbynens.be/" + }, + "repository": { + "type": "git", + "url": "https://github.com/mathiasbynens/wtf-8.js.git" + }, + "files": [ + "LICENSE-MIT.txt", + "wtf-8.js" + ], + "bugs": { + "url": "https://github.com/mathiasbynens/wtf-8.js/issues" + }, + "scripts": { + "test": "node tests/tests.js" + }, + "devDependencies": { + "coveralls": "^2.11.1", + "grunt": "^0.4.5", + "grunt-shell": "^1.1.1", + "istanbul": "^0.3.2", + "qunit-extras": "^1.2.0", + "qunitjs": "~1.11.0", + "requirejs": "^2.1.14" + }, + "gitHead": "51cdb2ad51f6ea330643be9725be8f213f43d535", + "_id": "wtf-8@1.0.0", + "_shasum": "392d8ba2d0f1c34d1ee2d630f15d0efb68e1048a", + "_from": "wtf-8@1.0.0", + "_npmVersion": "2.0.0", + "_npmUser": { + "name": "mathias", + "email": "mathias@qiwi.be" + }, + "maintainers": [ + { + "name": "mathias", + "email": "mathias@qiwi.be" + } + ], + "dist": { + "shasum": "392d8ba2d0f1c34d1ee2d630f15d0efb68e1048a", + "tarball": "https://registry.npmjs.org/wtf-8/-/wtf-8-1.0.0.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/wtf-8/-/wtf-8-1.0.0.tgz" +} diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/wtf-8/wtf-8.js b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/wtf-8/wtf-8.js new file mode 100644 index 0000000..3237158 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/node_modules/wtf-8/wtf-8.js @@ -0,0 +1,234 @@ +/*! https://mths.be/wtf8 v1.0.0 by @mathias */ +;(function(root) { + + // Detect free variables `exports` + var freeExports = typeof exports == 'object' && exports; + + // Detect free variable `module` + var freeModule = typeof module == 'object' && module && + module.exports == freeExports && module; + + // Detect free variable `global`, from Node.js or Browserified code, + // and use it as `root` + var freeGlobal = typeof global == 'object' && global; + if (freeGlobal.global === freeGlobal || freeGlobal.window === freeGlobal) { + root = freeGlobal; + } + + /*--------------------------------------------------------------------------*/ + + var stringFromCharCode = String.fromCharCode; + + // Taken from https://mths.be/punycode + function ucs2decode(string) { + var output = []; + var counter = 0; + var length = string.length; + var value; + var extra; + while (counter < length) { + value = string.charCodeAt(counter++); + if (value >= 0xD800 && value <= 0xDBFF && counter < length) { + // high surrogate, and there is a next character + extra = string.charCodeAt(counter++); + if ((extra & 0xFC00) == 0xDC00) { // low surrogate + output.push(((value & 0x3FF) << 10) + (extra & 0x3FF) + 0x10000); + } else { + // unmatched surrogate; only append this code unit, in case the next + // code unit is the high surrogate of a surrogate pair + output.push(value); + counter--; + } + } else { + output.push(value); + } + } + return output; + } + + // Taken from https://mths.be/punycode + function ucs2encode(array) { + var length = array.length; + var index = -1; + var value; + var output = ''; + while (++index < length) { + value = array[index]; + if (value > 0xFFFF) { + value -= 0x10000; + output += stringFromCharCode(value >>> 10 & 0x3FF | 0xD800); + value = 0xDC00 | value & 0x3FF; + } + output += stringFromCharCode(value); + } + return output; + } + + /*--------------------------------------------------------------------------*/ + + function createByte(codePoint, shift) { + return stringFromCharCode(((codePoint >> shift) & 0x3F) | 0x80); + } + + function encodeCodePoint(codePoint) { + if ((codePoint & 0xFFFFFF80) == 0) { // 1-byte sequence + return stringFromCharCode(codePoint); + } + var symbol = ''; + if ((codePoint & 0xFFFFF800) == 0) { // 2-byte sequence + symbol = stringFromCharCode(((codePoint >> 6) & 0x1F) | 0xC0); + } + else if ((codePoint & 0xFFFF0000) == 0) { // 3-byte sequence + symbol = stringFromCharCode(((codePoint >> 12) & 0x0F) | 0xE0); + symbol += createByte(codePoint, 6); + } + else if ((codePoint & 0xFFE00000) == 0) { // 4-byte sequence + symbol = stringFromCharCode(((codePoint >> 18) & 0x07) | 0xF0); + symbol += createByte(codePoint, 12); + symbol += createByte(codePoint, 6); + } + symbol += stringFromCharCode((codePoint & 0x3F) | 0x80); + return symbol; + } + + function wtf8encode(string) { + var codePoints = ucs2decode(string); + var length = codePoints.length; + var index = -1; + var codePoint; + var byteString = ''; + while (++index < length) { + codePoint = codePoints[index]; + byteString += encodeCodePoint(codePoint); + } + return byteString; + } + + /*--------------------------------------------------------------------------*/ + + function readContinuationByte() { + if (byteIndex >= byteCount) { + throw Error('Invalid byte index'); + } + + var continuationByte = byteArray[byteIndex] & 0xFF; + byteIndex++; + + if ((continuationByte & 0xC0) == 0x80) { + return continuationByte & 0x3F; + } + + // If we end up here, it’s not a continuation byte. + throw Error('Invalid continuation byte'); + } + + function decodeSymbol() { + var byte1; + var byte2; + var byte3; + var byte4; + var codePoint; + + if (byteIndex > byteCount) { + throw Error('Invalid byte index'); + } + + if (byteIndex == byteCount) { + return false; + } + + // Read the first byte. + byte1 = byteArray[byteIndex] & 0xFF; + byteIndex++; + + // 1-byte sequence (no continuation bytes) + if ((byte1 & 0x80) == 0) { + return byte1; + } + + // 2-byte sequence + if ((byte1 & 0xE0) == 0xC0) { + var byte2 = readContinuationByte(); + codePoint = ((byte1 & 0x1F) << 6) | byte2; + if (codePoint >= 0x80) { + return codePoint; + } else { + throw Error('Invalid continuation byte'); + } + } + + // 3-byte sequence (may include unpaired surrogates) + if ((byte1 & 0xF0) == 0xE0) { + byte2 = readContinuationByte(); + byte3 = readContinuationByte(); + codePoint = ((byte1 & 0x0F) << 12) | (byte2 << 6) | byte3; + if (codePoint >= 0x0800) { + return codePoint; + } else { + throw Error('Invalid continuation byte'); + } + } + + // 4-byte sequence + if ((byte1 & 0xF8) == 0xF0) { + byte2 = readContinuationByte(); + byte3 = readContinuationByte(); + byte4 = readContinuationByte(); + codePoint = ((byte1 & 0x0F) << 0x12) | (byte2 << 0x0C) | + (byte3 << 0x06) | byte4; + if (codePoint >= 0x010000 && codePoint <= 0x10FFFF) { + return codePoint; + } + } + + throw Error('Invalid WTF-8 detected'); + } + + var byteArray; + var byteCount; + var byteIndex; + function wtf8decode(byteString) { + byteArray = ucs2decode(byteString); + byteCount = byteArray.length; + byteIndex = 0; + var codePoints = []; + var tmp; + while ((tmp = decodeSymbol()) !== false) { + codePoints.push(tmp); + } + return ucs2encode(codePoints); + } + + /*--------------------------------------------------------------------------*/ + + var wtf8 = { + 'version': '1.0.0', + 'encode': wtf8encode, + 'decode': wtf8decode + }; + + // Some AMD build optimizers, like r.js, check for specific condition patterns + // like the following: + if ( + typeof define == 'function' && + typeof define.amd == 'object' && + define.amd + ) { + define(function() { + return wtf8; + }); + } else if (freeExports && !freeExports.nodeType) { + if (freeModule) { // in Node.js or RingoJS v0.8.0+ + freeModule.exports = wtf8; + } else { // in Narwhal or RingoJS v0.7.0- + var object = {}; + var hasOwnProperty = object.hasOwnProperty; + for (var key in wtf8) { + hasOwnProperty.call(wtf8, key) && (freeExports[key] = wtf8[key]); + } + } + } else { // in Rhino or a web browser + root.wtf8 = wtf8; + } + +}(this)); diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/package.json b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/package.json new file mode 100644 index 0000000..f7761d2 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/engine.io-parser/package.json @@ -0,0 +1,66 @@ +{ + "name": "engine.io-parser", + "description": "Parser for the client for the realtime Engine", + "license": "MIT", + "version": "1.3.1", + "homepage": "https://github.com/socketio/engine.io-parser", + "devDependencies": { + "expect.js": "0.3.1", + "mocha": "2.2.5", + "zuul": "3.11.0", + "zuul-ngrok": "4.0.0" + }, + "dependencies": { + "after": "0.8.1", + "arraybuffer.slice": "0.0.6", + "base64-arraybuffer": "0.1.5", + "blob": "0.0.4", + "has-binary": "0.1.6", + "wtf-8": "1.0.0" + }, + "scripts": { + "test": "make test" + }, + "repository": { + "type": "git", + "url": "git+ssh://git@github.com/socketio/engine.io-parser.git" + }, + "files": [ + "index.js", + "lib/" + ], + "browser": "./lib/browser.js", + "gitHead": "ada9dbe77bf345b5284c7a913bead0295b48ed74", + "bugs": { + "url": "https://github.com/socketio/engine.io-parser/issues" + }, + "_id": "engine.io-parser@1.3.1", + "_shasum": "9554f1ae33107d6fbd170ca5466d2f833f6a07cf", + "_from": "engine.io-parser@1.3.1", + "_npmVersion": "2.15.8", + "_nodeVersion": "4.4.7", + "_npmUser": { + "name": "darrachequesne", + "email": "damien.arrachequesne@gmail.com" + }, + "dist": { + "shasum": "9554f1ae33107d6fbd170ca5466d2f833f6a07cf", + "tarball": "https://registry.npmjs.org/engine.io-parser/-/engine.io-parser-1.3.1.tgz" + }, + "maintainers": [ + { + "name": "darrachequesne", + "email": "damien.arrachequesne@gmail.com" + }, + { + "name": "rauchg", + "email": "rauchg@gmail.com" + } + ], + "_npmOperationalInternal": { + "host": "packages-18-east.internal.npmjs.com", + "tmp": "tmp/engine.io-parser-1.3.1.tgz_1476967470566_0.9431107800919563" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/engine.io-parser/-/engine.io-parser-1.3.1.tgz" +} diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/ws/.npmignore b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/.npmignore new file mode 100644 index 0000000..1eba800 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/.npmignore @@ -0,0 +1,11 @@ +npm-debug.log +node_modules +.*.swp +.lock-* +build + +bench +doc +examples +test + diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/ws/.travis.yml b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/.travis.yml new file mode 100644 index 0000000..5002b49 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/.travis.yml @@ -0,0 +1,15 @@ +language: node_js +sudo: false +node_js: + - "5" + - "4" + - "0.12" +addons: + apt: + sources: + - ubuntu-toolchain-r-test + packages: + - gcc-4.9 + - g++-4.9 +before_install: + - export CC="gcc-4.9" CXX="g++-4.9" diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/ws/Makefile b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/Makefile new file mode 100644 index 0000000..94612c5 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/Makefile @@ -0,0 +1,45 @@ +ALL_TESTS = $(shell find test/ -name '*.test.js') +ALL_INTEGRATION = $(shell find test/ -name '*.integration.js') + +run-tests: + @./node_modules/.bin/mocha \ + -t 5000 \ + -s 2400 \ + $(TESTFLAGS) \ + $(TESTS) + +run-integrationtests: + @./node_modules/.bin/mocha \ + -t 5000 \ + -s 6000 \ + $(TESTFLAGS) \ + $(TESTS) + +run-coverage: + @./node_modules/.bin/istanbul cover --report html \ + ./node_modules/.bin/_mocha -- \ + -t 5000 \ + -s 6000 \ + $(TESTFLAGS) \ + $(TESTS) + +test: + @$(MAKE) NODE_TLS_REJECT_UNAUTHORIZED=0 NODE_PATH=lib TESTS="$(ALL_TESTS)" run-tests + +integrationtest: + @$(MAKE) NODE_TLS_REJECT_UNAUTHORIZED=0 NODE_PATH=lib TESTS="$(ALL_INTEGRATION)" run-integrationtests + +coverage: + @$(MAKE) NODE_TLS_REJECT_UNAUTHORIZED=0 NODE_PATH=lib TESTS="$(ALL_TESTS)" run-coverage + +benchmark: + @node bench/sender.benchmark.js + @node bench/parser.benchmark.js + +autobahn: + @NODE_PATH=lib node test/autobahn.js + +autobahn-server: + @NODE_PATH=lib node test/autobahn-server.js + +.PHONY: test coverage diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/ws/README.md b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/README.md new file mode 100644 index 0000000..93106d7 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/README.md @@ -0,0 +1,235 @@ +# ws: a node.js websocket library + +[![Build Status](https://travis-ci.org/websockets/ws.svg?branch=master)](https://travis-ci.org/websockets/ws) + +`ws` is a simple to use WebSocket implementation, up-to-date against RFC-6455, +and [probably the fastest WebSocket library for node.js][archive]. + +Passes the quite extensive Autobahn test suite. See http://websockets.github.com/ws +for the full reports. + +## Protocol support + +* **Hixie draft 76** (Old and deprecated, but still in use by Safari and Opera. + Added to ws version 0.4.2, but server only. Can be disabled by setting the + `disableHixie` option to true.) +* **HyBi drafts 07-12** (Use the option `protocolVersion: 8`) +* **HyBi drafts 13-17** (Current default, alternatively option `protocolVersion: 13`) + +### Installing + +``` +npm install --save ws +``` + +### Opt-in for performance + +There are 2 optional modules that can be installed along side with the `ws` +module. These modules are binary addons which improve certain operations, but as +they are binary addons they require compilation which can fail if no c++ +compiler is installed on the host system. + +- `npm install --save bufferutil`: Improves internal buffer operations which + allows for faster processing of masked WebSocket frames and general buffer + operations. +- `npm install --save utf-8-validate`: The specification requires validation of + invalid UTF-8 chars, some of these validations could not be done in JavaScript + hence the need for a binary addon. In most cases you will already be + validating the input that you receive for security purposes leading to double + validation. But if you want to be 100% spec-conforming and have fast + validation of UTF-8 then this module is a must. + +### Sending and receiving text data + +```js +var WebSocket = require('ws'); +var ws = new WebSocket('ws://www.host.com/path'); + +ws.on('open', function open() { + ws.send('something'); +}); + +ws.on('message', function(data, flags) { + // flags.binary will be set if a binary data is received. + // flags.masked will be set if the data was masked. +}); +``` + +### Sending binary data + +```js +var WebSocket = require('ws'); +var ws = new WebSocket('ws://www.host.com/path'); + +ws.on('open', function open() { + var array = new Float32Array(5); + + for (var i = 0; i < array.length; ++i) { + array[i] = i / 2; + } + + ws.send(array, { binary: true, mask: true }); +}); +``` + +Setting `mask`, as done for the send options above, will cause the data to be +masked according to the WebSocket protocol. The same option applies for text +data. + +### Server example + +```js +var WebSocketServer = require('ws').Server + , wss = new WebSocketServer({ port: 8080 }); + +wss.on('connection', function connection(ws) { + ws.on('message', function incoming(message) { + console.log('received: %s', message); + }); + + ws.send('something'); +}); +``` + +### ExpressJS example + +```js +var server = require('http').createServer() + , url = require('url') + , WebSocketServer = require('ws').Server + , wss = new WebSocketServer({ server: server }) + , express = require('express') + , app = express() + , port = 4080; + +app.use(function (req, res) { + res.send({ msg: "hello" }); +}); + +wss.on('connection', function connection(ws) { + var location = url.parse(ws.upgradeReq.url, true); + // you might use location.query.access_token to authenticate or share sessions + // or ws.upgradeReq.headers.cookie (see http://stackoverflow.com/a/16395220/151312) + + ws.on('message', function incoming(message) { + console.log('received: %s', message); + }); + + ws.send('something'); +}); + +server.on('request', app); +server.listen(port, function () { console.log('Listening on ' + server.address().port) }); +``` + +### Server sending broadcast data + +```js +var WebSocketServer = require('ws').Server + , wss = new WebSocketServer({ port: 8080 }); + +wss.broadcast = function broadcast(data) { + wss.clients.forEach(function each(client) { + client.send(data); + }); +}; +``` + +### Error handling best practices + +```js +// If the WebSocket is closed before the following send is attempted +ws.send('something'); + +// Errors (both immediate and async write errors) can be detected in an optional +// callback. The callback is also the only way of being notified that data has +// actually been sent. +ws.send('something', function ack(error) { + // if error is not defined, the send has been completed, + // otherwise the error object will indicate what failed. +}); + +// Immediate errors can also be handled with try/catch-blocks, but **note** that +// since sends are inherently asynchronous, socket write failures will *not* be +// captured when this technique is used. +try { ws.send('something'); } +catch (e) { /* handle error */ } +``` + +### echo.websocket.org demo + +```js +var WebSocket = require('ws'); +var ws = new WebSocket('ws://echo.websocket.org/', { + protocolVersion: 8, + origin: 'http://websocket.org' +}); + +ws.on('open', function open() { + console.log('connected'); + ws.send(Date.now().toString(), {mask: true}); +}); + +ws.on('close', function close() { + console.log('disconnected'); +}); + +ws.on('message', function message(data, flags) { + console.log('Roundtrip time: ' + (Date.now() - parseInt(data)) + 'ms', flags); + + setTimeout(function timeout() { + ws.send(Date.now().toString(), {mask: true}); + }, 500); +}); +``` + +### Other examples + +For a full example with a browser client communicating with a ws server, see the +examples folder. + +Note that the usage together with Express 3.0 is quite different from Express +2.x. The difference is expressed in the two different serverstats-examples. + +Otherwise, see the test cases. + +### Running the tests + +``` +make test +``` + +## API Docs + +See [`/doc/ws.md`](https://github.com/websockets/ws/blob/master/doc/ws.md) for Node.js-like docs for the ws classes. + +## Changelog + +We're using the GitHub [`releases`](https://github.com/websockets/ws/releases) for changelog entries. + +## License + +(The MIT License) + +Copyright (c) 2011 Einar Otto Stangvik <einaros@gmail.com> + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + +[archive]: http://web.archive.org/web/20130314230536/http://hobbycoding.posterous.com/the-fastest-websocket-module-for-nodejs diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/ws/SECURITY.md b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/SECURITY.md new file mode 100644 index 0000000..fd8e07b --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/SECURITY.md @@ -0,0 +1,33 @@ +# Security Guidelines + +Please contact us directly at **security@3rd-Eden.com** for any bug that might +impact the security of this project. Please prefix the subject of your email +with `[security]` in lowercase and square brackets. Our email filters will +automatically prevent these messages from being moved to our spam box. + +You will receive an acknowledgement of your report within **24 hours**. + +All emails that do not include security vulnerabilities will be removed and +blocked instantly. + +## Exceptions + +If you do not receive an acknowledgement within the said time frame please give +us the benefit of the doubt as it's possible that we haven't seen it yet. In +this case please send us a message **without details** using one of the +following methods: + +- Contact the lead developers of this project on their personal e-mails. You + can find the e-mails in the git logs, for example using the following command: + `git --no-pager show -s --format='%an <%ae>' ` where `` is the + SHA1 of their latest commit in the project. +- Create a GitHub issue stating contact details and the severity of the issue. + +Once we have acknowledged receipt of your report and confirmed the bug +ourselves we will work with you to fix the vulnerability and publicly acknowledge +your responsible disclosure, if you wish. In addition to that we will report +all vulnerabilities to the [Node Security Project](https://nodesecurity.io/). + +## History + +04 Jan 2016: [Buffer vulnerablity](https://github.com/websockets/ws/releases/tag/1.0.1) diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/ws/index.js b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/index.js new file mode 100644 index 0000000..a7e8644 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/index.js @@ -0,0 +1,49 @@ +'use strict'; + +/*! + * ws: a node.js websocket client + * Copyright(c) 2011 Einar Otto Stangvik + * MIT Licensed + */ + +var WS = module.exports = require('./lib/WebSocket'); + +WS.Server = require('./lib/WebSocketServer'); +WS.Sender = require('./lib/Sender'); +WS.Receiver = require('./lib/Receiver'); + +/** + * Create a new WebSocket server. + * + * @param {Object} options Server options + * @param {Function} fn Optional connection listener. + * @returns {WS.Server} + * @api public + */ +WS.createServer = function createServer(options, fn) { + var server = new WS.Server(options); + + if (typeof fn === 'function') { + server.on('connection', fn); + } + + return server; +}; + +/** + * Create a new WebSocket connection. + * + * @param {String} address The URL/address we need to connect to. + * @param {Function} fn Open listener. + * @returns {WS} + * @api public + */ +WS.connect = WS.createConnection = function connect(address, fn) { + var client = new WS(address); + + if (typeof fn === 'function') { + client.on('open', fn); + } + + return client; +}; diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/BufferPool.js b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/BufferPool.js new file mode 100644 index 0000000..8ee5990 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/BufferPool.js @@ -0,0 +1,63 @@ +/*! + * ws: a node.js websocket client + * Copyright(c) 2011 Einar Otto Stangvik + * MIT Licensed + */ + +var util = require('util'); + +function BufferPool(initialSize, growStrategy, shrinkStrategy) { + if (this instanceof BufferPool === false) { + throw new TypeError("Classes can't be function-called"); + } + + if (typeof initialSize === 'function') { + shrinkStrategy = growStrategy; + growStrategy = initialSize; + initialSize = 0; + } + else if (typeof initialSize === 'undefined') { + initialSize = 0; + } + this._growStrategy = (growStrategy || function(db, size) { + return db.used + size; + }).bind(null, this); + this._shrinkStrategy = (shrinkStrategy || function(db) { + return initialSize; + }).bind(null, this); + this._buffer = initialSize ? new Buffer(initialSize) : null; + this._offset = 0; + this._used = 0; + this._changeFactor = 0; + this.__defineGetter__('size', function(){ + return this._buffer == null ? 0 : this._buffer.length; + }); + this.__defineGetter__('used', function(){ + return this._used; + }); +} + +BufferPool.prototype.get = function(length) { + if (this._buffer == null || this._offset + length > this._buffer.length) { + var newBuf = new Buffer(this._growStrategy(length)); + this._buffer = newBuf; + this._offset = 0; + } + this._used += length; + var buf = this._buffer.slice(this._offset, this._offset + length); + this._offset += length; + return buf; +} + +BufferPool.prototype.reset = function(forceNewBuffer) { + var len = this._shrinkStrategy(); + if (len < this.size) this._changeFactor -= 1; + if (forceNewBuffer || this._changeFactor < -2) { + this._changeFactor = 0; + this._buffer = len ? new Buffer(len) : null; + } + this._offset = 0; + this._used = 0; +} + +module.exports = BufferPool; diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/BufferUtil.fallback.js b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/BufferUtil.fallback.js new file mode 100644 index 0000000..7abd0d8 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/BufferUtil.fallback.js @@ -0,0 +1,47 @@ +/*! + * ws: a node.js websocket client + * Copyright(c) 2011 Einar Otto Stangvik + * MIT Licensed + */ + +exports.BufferUtil = { + merge: function(mergedBuffer, buffers) { + var offset = 0; + for (var i = 0, l = buffers.length; i < l; ++i) { + var buf = buffers[i]; + buf.copy(mergedBuffer, offset); + offset += buf.length; + } + }, + mask: function(source, mask, output, offset, length) { + var maskNum = mask.readUInt32LE(0, true); + var i = 0; + for (; i < length - 3; i += 4) { + var num = maskNum ^ source.readUInt32LE(i, true); + if (num < 0) num = 4294967296 + num; + output.writeUInt32LE(num, offset + i, true); + } + switch (length % 4) { + case 3: output[offset + i + 2] = source[i + 2] ^ mask[2]; + case 2: output[offset + i + 1] = source[i + 1] ^ mask[1]; + case 1: output[offset + i] = source[i] ^ mask[0]; + case 0:; + } + }, + unmask: function(data, mask) { + var maskNum = mask.readUInt32LE(0, true); + var length = data.length; + var i = 0; + for (; i < length - 3; i += 4) { + var num = maskNum ^ data.readUInt32LE(i, true); + if (num < 0) num = 4294967296 + num; + data.writeUInt32LE(num, i, true); + } + switch (length % 4) { + case 3: data[i + 2] = data[i + 2] ^ mask[2]; + case 2: data[i + 1] = data[i + 1] ^ mask[1]; + case 1: data[i] = data[i] ^ mask[0]; + case 0:; + } + } +} diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/BufferUtil.js b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/BufferUtil.js new file mode 100644 index 0000000..18c6998 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/BufferUtil.js @@ -0,0 +1,13 @@ +'use strict'; + +/*! + * ws: a node.js websocket client + * Copyright(c) 2011 Einar Otto Stangvik + * MIT Licensed + */ + +try { + module.exports = require('bufferutil'); +} catch (e) { + module.exports = require('./BufferUtil.fallback'); +} diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/ErrorCodes.js b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/ErrorCodes.js new file mode 100644 index 0000000..55ebd52 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/ErrorCodes.js @@ -0,0 +1,24 @@ +/*! + * ws: a node.js websocket client + * Copyright(c) 2011 Einar Otto Stangvik + * MIT Licensed + */ + +module.exports = { + isValidErrorCode: function(code) { + return (code >= 1000 && code <= 1011 && code != 1004 && code != 1005 && code != 1006) || + (code >= 3000 && code <= 4999); + }, + 1000: 'normal', + 1001: 'going away', + 1002: 'protocol error', + 1003: 'unsupported data', + 1004: 'reserved', + 1005: 'reserved for extensions', + 1006: 'reserved for extensions', + 1007: 'inconsistent or invalid data', + 1008: 'policy violation', + 1009: 'message too big', + 1010: 'extension handshake missing', + 1011: 'an unexpected condition prevented the request from being fulfilled', +}; \ No newline at end of file diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/Extensions.js b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/Extensions.js new file mode 100644 index 0000000..a465ace --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/Extensions.js @@ -0,0 +1,70 @@ + +var util = require('util'); + +/** + * Module exports. + */ + +exports.parse = parse; +exports.format = format; + +/** + * Parse extensions header value + */ + +function parse(value) { + value = value || ''; + + var extensions = {}; + + value.split(',').forEach(function(v) { + var params = v.split(';'); + var token = params.shift().trim(); + var paramsList = extensions[token] = extensions[token] || []; + var parsedParams = {}; + + params.forEach(function(param) { + var parts = param.trim().split('='); + var key = parts[0]; + var value = parts[1]; + if (typeof value === 'undefined') { + value = true; + } else { + // unquote value + if (value[0] === '"') { + value = value.slice(1); + } + if (value[value.length - 1] === '"') { + value = value.slice(0, value.length - 1); + } + } + (parsedParams[key] = parsedParams[key] || []).push(value); + }); + + paramsList.push(parsedParams); + }); + + return extensions; +} + +/** + * Format extensions header value + */ + +function format(value) { + return Object.keys(value).map(function(token) { + var paramsList = value[token]; + if (!util.isArray(paramsList)) { + paramsList = [paramsList]; + } + return paramsList.map(function(params) { + return [token].concat(Object.keys(params).map(function(k) { + var p = params[k]; + if (!util.isArray(p)) p = [p]; + return p.map(function(v) { + return v === true ? k : k + '=' + v; + }).join('; '); + })).join('; '); + }).join(', '); + }).join(', '); +} diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/PerMessageDeflate.js b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/PerMessageDeflate.js new file mode 100644 index 0000000..00a6ea6 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/PerMessageDeflate.js @@ -0,0 +1,337 @@ + +var zlib = require('zlib'); + +var AVAILABLE_WINDOW_BITS = [8, 9, 10, 11, 12, 13, 14, 15]; +var DEFAULT_WINDOW_BITS = 15; +var DEFAULT_MEM_LEVEL = 8; + +PerMessageDeflate.extensionName = 'permessage-deflate'; + +/** + * Per-message Compression Extensions implementation + */ + +function PerMessageDeflate(options, isServer,maxPayload) { + if (this instanceof PerMessageDeflate === false) { + throw new TypeError("Classes can't be function-called"); + } + + this._options = options || {}; + this._isServer = !!isServer; + this._inflate = null; + this._deflate = null; + this.params = null; + this._maxPayload = maxPayload || 0; +} + +/** + * Create extension parameters offer + * + * @api public + */ + +PerMessageDeflate.prototype.offer = function() { + var params = {}; + if (this._options.serverNoContextTakeover) { + params.server_no_context_takeover = true; + } + if (this._options.clientNoContextTakeover) { + params.client_no_context_takeover = true; + } + if (this._options.serverMaxWindowBits) { + params.server_max_window_bits = this._options.serverMaxWindowBits; + } + if (this._options.clientMaxWindowBits) { + params.client_max_window_bits = this._options.clientMaxWindowBits; + } else if (this._options.clientMaxWindowBits == null) { + params.client_max_window_bits = true; + } + return params; +}; + +/** + * Accept extension offer + * + * @api public + */ + +PerMessageDeflate.prototype.accept = function(paramsList) { + paramsList = this.normalizeParams(paramsList); + + var params; + if (this._isServer) { + params = this.acceptAsServer(paramsList); + } else { + params = this.acceptAsClient(paramsList); + } + + this.params = params; + return params; +}; + +/** + * Releases all resources used by the extension + * + * @api public + */ + +PerMessageDeflate.prototype.cleanup = function() { + if (this._inflate) { + if (this._inflate.writeInProgress) { + this._inflate.pendingClose = true; + } else { + if (this._inflate.close) this._inflate.close(); + this._inflate = null; + } + } + if (this._deflate) { + if (this._deflate.writeInProgress) { + this._deflate.pendingClose = true; + } else { + if (this._deflate.close) this._deflate.close(); + this._deflate = null; + } + } +}; + +/** + * Accept extension offer from client + * + * @api private + */ + +PerMessageDeflate.prototype.acceptAsServer = function(paramsList) { + var accepted = {}; + var result = paramsList.some(function(params) { + accepted = {}; + if (this._options.serverNoContextTakeover === false && params.server_no_context_takeover) { + return; + } + if (this._options.serverMaxWindowBits === false && params.server_max_window_bits) { + return; + } + if (typeof this._options.serverMaxWindowBits === 'number' && + typeof params.server_max_window_bits === 'number' && + this._options.serverMaxWindowBits > params.server_max_window_bits) { + return; + } + if (typeof this._options.clientMaxWindowBits === 'number' && !params.client_max_window_bits) { + return; + } + + if (this._options.serverNoContextTakeover || params.server_no_context_takeover) { + accepted.server_no_context_takeover = true; + } + if (this._options.clientNoContextTakeover) { + accepted.client_no_context_takeover = true; + } + if (this._options.clientNoContextTakeover !== false && params.client_no_context_takeover) { + accepted.client_no_context_takeover = true; + } + if (typeof this._options.serverMaxWindowBits === 'number') { + accepted.server_max_window_bits = this._options.serverMaxWindowBits; + } else if (typeof params.server_max_window_bits === 'number') { + accepted.server_max_window_bits = params.server_max_window_bits; + } + if (typeof this._options.clientMaxWindowBits === 'number') { + accepted.client_max_window_bits = this._options.clientMaxWindowBits; + } else if (this._options.clientMaxWindowBits !== false && typeof params.client_max_window_bits === 'number') { + accepted.client_max_window_bits = params.client_max_window_bits; + } + return true; + }, this); + + if (!result) { + throw new Error('Doesn\'t support the offered configuration'); + } + + return accepted; +}; + +/** + * Accept extension response from server + * + * @api privaye + */ + +PerMessageDeflate.prototype.acceptAsClient = function(paramsList) { + var params = paramsList[0]; + if (this._options.clientNoContextTakeover != null) { + if (this._options.clientNoContextTakeover === false && params.client_no_context_takeover) { + throw new Error('Invalid value for "client_no_context_takeover"'); + } + } + if (this._options.clientMaxWindowBits != null) { + if (this._options.clientMaxWindowBits === false && params.client_max_window_bits) { + throw new Error('Invalid value for "client_max_window_bits"'); + } + if (typeof this._options.clientMaxWindowBits === 'number' && + (!params.client_max_window_bits || params.client_max_window_bits > this._options.clientMaxWindowBits)) { + throw new Error('Invalid value for "client_max_window_bits"'); + } + } + return params; +}; + +/** + * Normalize extensions parameters + * + * @api private + */ + +PerMessageDeflate.prototype.normalizeParams = function(paramsList) { + return paramsList.map(function(params) { + Object.keys(params).forEach(function(key) { + var value = params[key]; + if (value.length > 1) { + throw new Error('Multiple extension parameters for ' + key); + } + + value = value[0]; + + switch (key) { + case 'server_no_context_takeover': + case 'client_no_context_takeover': + if (value !== true) { + throw new Error('invalid extension parameter value for ' + key + ' (' + value + ')'); + } + params[key] = true; + break; + case 'server_max_window_bits': + case 'client_max_window_bits': + if (typeof value === 'string') { + value = parseInt(value, 10); + if (!~AVAILABLE_WINDOW_BITS.indexOf(value)) { + throw new Error('invalid extension parameter value for ' + key + ' (' + value + ')'); + } + } + if (!this._isServer && value === true) { + throw new Error('Missing extension parameter value for ' + key); + } + params[key] = value; + break; + default: + throw new Error('Not defined extension parameter (' + key + ')'); + } + }, this); + return params; + }, this); +}; + +/** + * Decompress message + * + * @api public + */ + +PerMessageDeflate.prototype.decompress = function (data, fin, callback) { + var endpoint = this._isServer ? 'client' : 'server'; + + if (!this._inflate) { + var maxWindowBits = this.params[endpoint + '_max_window_bits']; + this._inflate = zlib.createInflateRaw({ + windowBits: 'number' === typeof maxWindowBits ? maxWindowBits : DEFAULT_WINDOW_BITS + }); + } + this._inflate.writeInProgress = true; + + var self = this; + var buffers = []; + var cumulativeBufferLength=0; + + this._inflate.on('error', onError).on('data', onData); + this._inflate.write(data); + if (fin) { + this._inflate.write(new Buffer([0x00, 0x00, 0xff, 0xff])); + } + this._inflate.flush(function() { + cleanup(); + callback(null, Buffer.concat(buffers)); + }); + + function onError(err) { + cleanup(); + callback(err); + } + + function onData(data) { + if(self._maxPayload!==undefined && self._maxPayload!==null && self._maxPayload>0){ + cumulativeBufferLength+=data.length; + if(cumulativeBufferLength>self._maxPayload){ + buffers=[]; + cleanup(); + var err={type:1009}; + callback(err); + return; + } + } + buffers.push(data); + } + + function cleanup() { + if (!self._inflate) return; + self._inflate.removeListener('error', onError); + self._inflate.removeListener('data', onData); + self._inflate.writeInProgress = false; + if ((fin && self.params[endpoint + '_no_context_takeover']) || self._inflate.pendingClose) { + if (self._inflate.close) self._inflate.close(); + self._inflate = null; + } + } +}; + +/** + * Compress message + * + * @api public + */ + +PerMessageDeflate.prototype.compress = function (data, fin, callback) { + var endpoint = this._isServer ? 'server' : 'client'; + + if (!this._deflate) { + var maxWindowBits = this.params[endpoint + '_max_window_bits']; + this._deflate = zlib.createDeflateRaw({ + flush: zlib.Z_SYNC_FLUSH, + windowBits: 'number' === typeof maxWindowBits ? maxWindowBits : DEFAULT_WINDOW_BITS, + memLevel: this._options.memLevel || DEFAULT_MEM_LEVEL + }); + } + this._deflate.writeInProgress = true; + + var self = this; + var buffers = []; + + this._deflate.on('error', onError).on('data', onData); + this._deflate.write(data); + this._deflate.flush(function() { + cleanup(); + var data = Buffer.concat(buffers); + if (fin) { + data = data.slice(0, data.length - 4); + } + callback(null, data); + }); + + function onError(err) { + cleanup(); + callback(err); + } + + function onData(data) { + buffers.push(data); + } + + function cleanup() { + if (!self._deflate) return; + self._deflate.removeListener('error', onError); + self._deflate.removeListener('data', onData); + self._deflate.writeInProgress = false; + if ((fin && self.params[endpoint + '_no_context_takeover']) || self._deflate.pendingClose) { + if (self._deflate.close) self._deflate.close(); + self._deflate = null; + } + } +}; + +module.exports = PerMessageDeflate; diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/Receiver.hixie.js b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/Receiver.hixie.js new file mode 100644 index 0000000..598ccbd --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/Receiver.hixie.js @@ -0,0 +1,194 @@ +/*! + * ws: a node.js websocket client + * Copyright(c) 2011 Einar Otto Stangvik + * MIT Licensed + */ + +var util = require('util'); + +/** + * State constants + */ + +var EMPTY = 0 + , BODY = 1; +var BINARYLENGTH = 2 + , BINARYBODY = 3; + +/** + * Hixie Receiver implementation + */ + +function Receiver () { + if (this instanceof Receiver === false) { + throw new TypeError("Classes can't be function-called"); + } + + this.state = EMPTY; + this.buffers = []; + this.messageEnd = -1; + this.spanLength = 0; + this.dead = false; + + this.onerror = function() {}; + this.ontext = function() {}; + this.onbinary = function() {}; + this.onclose = function() {}; + this.onping = function() {}; + this.onpong = function() {}; +} + +module.exports = Receiver; + +/** + * Add new data to the parser. + * + * @api public + */ + +Receiver.prototype.add = function(data) { + if (this.dead) return; + var self = this; + function doAdd() { + if (self.state === EMPTY) { + if (data.length == 2 && data[0] == 0xFF && data[1] == 0x00) { + self.reset(); + self.onclose(); + return; + } + if (data[0] === 0x80) { + self.messageEnd = 0; + self.state = BINARYLENGTH; + data = data.slice(1); + } else { + + if (data[0] !== 0x00) { + self.error('payload must start with 0x00 byte', true); + return; + } + data = data.slice(1); + self.state = BODY; + + } + } + if (self.state === BINARYLENGTH) { + var i = 0; + while ((i < data.length) && (data[i] & 0x80)) { + self.messageEnd = 128 * self.messageEnd + (data[i] & 0x7f); + ++i; + } + if (i < data.length) { + self.messageEnd = 128 * self.messageEnd + (data[i] & 0x7f); + self.state = BINARYBODY; + ++i; + } + if (i > 0) + data = data.slice(i); + } + if (self.state === BINARYBODY) { + var dataleft = self.messageEnd - self.spanLength; + if (data.length >= dataleft) { + // consume the whole buffer to finish the frame + self.buffers.push(data); + self.spanLength += dataleft; + self.messageEnd = dataleft; + return self.parse(); + } + // frame's not done even if we consume it all + self.buffers.push(data); + self.spanLength += data.length; + return; + } + self.buffers.push(data); + if ((self.messageEnd = bufferIndex(data, 0xFF)) != -1) { + self.spanLength += self.messageEnd; + return self.parse(); + } + else self.spanLength += data.length; + } + while(data) data = doAdd(); +}; + +/** + * Releases all resources used by the receiver. + * + * @api public + */ + +Receiver.prototype.cleanup = function() { + this.dead = true; + this.state = EMPTY; + this.buffers = []; +}; + +/** + * Process buffered data. + * + * @api public + */ + +Receiver.prototype.parse = function() { + var output = new Buffer(this.spanLength); + var outputIndex = 0; + for (var bi = 0, bl = this.buffers.length; bi < bl - 1; ++bi) { + var buffer = this.buffers[bi]; + buffer.copy(output, outputIndex); + outputIndex += buffer.length; + } + var lastBuffer = this.buffers[this.buffers.length - 1]; + if (this.messageEnd > 0) lastBuffer.copy(output, outputIndex, 0, this.messageEnd); + if (this.state !== BODY) --this.messageEnd; + var tail = null; + if (this.messageEnd < lastBuffer.length - 1) { + tail = lastBuffer.slice(this.messageEnd + 1); + } + this.reset(); + this.ontext(output.toString('utf8')); + return tail; +}; + +/** + * Handles an error + * + * @api private + */ + +Receiver.prototype.error = function (reason, terminate) { + if (this.dead) return; + this.reset(); + if(typeof reason == 'string'){ + this.onerror(new Error(reason), terminate); + } + else if(reason.constructor == Error){ + this.onerror(reason, terminate); + } + else{ + this.onerror(new Error("An error occured"),terminate); + } + return this; +}; + +/** + * Reset parser state + * + * @api private + */ + +Receiver.prototype.reset = function (reason) { + if (this.dead) return; + this.state = EMPTY; + this.buffers = []; + this.messageEnd = -1; + this.spanLength = 0; +}; + +/** + * Internal api + */ + +function bufferIndex(buffer, byte) { + for (var i = 0, l = buffer.length; i < l; ++i) { + if (buffer[i] === byte) return i; + } + return -1; +} diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/Receiver.js b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/Receiver.js new file mode 100644 index 0000000..0bf29d8 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/Receiver.js @@ -0,0 +1,793 @@ +/*! + * ws: a node.js websocket client + * Copyright(c) 2011 Einar Otto Stangvik + * MIT Licensed + */ + +var util = require('util') + , Validation = require('./Validation').Validation + , ErrorCodes = require('./ErrorCodes') + , BufferPool = require('./BufferPool') + , bufferUtil = require('./BufferUtil').BufferUtil + , PerMessageDeflate = require('./PerMessageDeflate'); + +/** + * HyBi Receiver implementation + */ + +function Receiver (extensions,maxPayload) { + if (this instanceof Receiver === false) { + throw new TypeError("Classes can't be function-called"); + } + if(typeof extensions==='number'){ + maxPayload=extensions; + extensions={}; + } + + + // memory pool for fragmented messages + var fragmentedPoolPrevUsed = -1; + this.fragmentedBufferPool = new BufferPool(1024, function(db, length) { + return db.used + length; + }, function(db) { + return fragmentedPoolPrevUsed = fragmentedPoolPrevUsed >= 0 ? + Math.ceil((fragmentedPoolPrevUsed + db.used) / 2) : + db.used; + }); + + // memory pool for unfragmented messages + var unfragmentedPoolPrevUsed = -1; + this.unfragmentedBufferPool = new BufferPool(1024, function(db, length) { + return db.used + length; + }, function(db) { + return unfragmentedPoolPrevUsed = unfragmentedPoolPrevUsed >= 0 ? + Math.ceil((unfragmentedPoolPrevUsed + db.used) / 2) : + db.used; + }); + this.extensions = extensions || {}; + this.maxPayload = maxPayload || 0; + this.currentPayloadLength = 0; + this.state = { + activeFragmentedOperation: null, + lastFragment: false, + masked: false, + opcode: 0, + fragmentedOperation: false + }; + this.overflow = []; + this.headerBuffer = new Buffer(10); + this.expectOffset = 0; + this.expectBuffer = null; + this.expectHandler = null; + this.currentMessage = []; + this.currentMessageLength = 0; + this.messageHandlers = []; + this.expectHeader(2, this.processPacket); + this.dead = false; + this.processing = false; + + this.onerror = function() {}; + this.ontext = function() {}; + this.onbinary = function() {}; + this.onclose = function() {}; + this.onping = function() {}; + this.onpong = function() {}; +} + +module.exports = Receiver; + +/** + * Add new data to the parser. + * + * @api public + */ + +Receiver.prototype.add = function(data) { + if (this.dead) return; + var dataLength = data.length; + if (dataLength == 0) return; + if (this.expectBuffer == null) { + this.overflow.push(data); + return; + } + var toRead = Math.min(dataLength, this.expectBuffer.length - this.expectOffset); + fastCopy(toRead, data, this.expectBuffer, this.expectOffset); + this.expectOffset += toRead; + if (toRead < dataLength) { + this.overflow.push(data.slice(toRead)); + } + while (this.expectBuffer && this.expectOffset == this.expectBuffer.length) { + var bufferForHandler = this.expectBuffer; + this.expectBuffer = null; + this.expectOffset = 0; + this.expectHandler.call(this, bufferForHandler); + } +}; + +/** + * Releases all resources used by the receiver. + * + * @api public + */ + +Receiver.prototype.cleanup = function() { + this.dead = true; + this.overflow = null; + this.headerBuffer = null; + this.expectBuffer = null; + this.expectHandler = null; + this.unfragmentedBufferPool = null; + this.fragmentedBufferPool = null; + this.state = null; + this.currentMessage = null; + this.onerror = null; + this.ontext = null; + this.onbinary = null; + this.onclose = null; + this.onping = null; + this.onpong = null; +}; + +/** + * Waits for a certain amount of header bytes to be available, then fires a callback. + * + * @api private + */ + +Receiver.prototype.expectHeader = function(length, handler) { + if (length == 0) { + handler(null); + return; + } + this.expectBuffer = this.headerBuffer.slice(this.expectOffset, this.expectOffset + length); + this.expectHandler = handler; + var toRead = length; + while (toRead > 0 && this.overflow.length > 0) { + var fromOverflow = this.overflow.pop(); + if (toRead < fromOverflow.length) this.overflow.push(fromOverflow.slice(toRead)); + var read = Math.min(fromOverflow.length, toRead); + fastCopy(read, fromOverflow, this.expectBuffer, this.expectOffset); + this.expectOffset += read; + toRead -= read; + } +}; + +/** + * Waits for a certain amount of data bytes to be available, then fires a callback. + * + * @api private + */ + +Receiver.prototype.expectData = function(length, handler) { + if (length == 0) { + handler(null); + return; + } + this.expectBuffer = this.allocateFromPool(length, this.state.fragmentedOperation); + this.expectHandler = handler; + var toRead = length; + while (toRead > 0 && this.overflow.length > 0) { + var fromOverflow = this.overflow.pop(); + if (toRead < fromOverflow.length) this.overflow.push(fromOverflow.slice(toRead)); + var read = Math.min(fromOverflow.length, toRead); + fastCopy(read, fromOverflow, this.expectBuffer, this.expectOffset); + this.expectOffset += read; + toRead -= read; + } +}; + +/** + * Allocates memory from the buffer pool. + * + * @api private + */ + +Receiver.prototype.allocateFromPool = function(length, isFragmented) { + return (isFragmented ? this.fragmentedBufferPool : this.unfragmentedBufferPool).get(length); +}; + +/** + * Start processing a new packet. + * + * @api private + */ + +Receiver.prototype.processPacket = function (data) { + if (this.extensions[PerMessageDeflate.extensionName]) { + if ((data[0] & 0x30) != 0) { + this.error('reserved fields (2, 3) must be empty', 1002); + return; + } + } else { + if ((data[0] & 0x70) != 0) { + this.error('reserved fields must be empty', 1002); + return; + } + } + this.state.lastFragment = (data[0] & 0x80) == 0x80; + this.state.masked = (data[1] & 0x80) == 0x80; + var compressed = (data[0] & 0x40) == 0x40; + var opcode = data[0] & 0xf; + if (opcode === 0) { + if (compressed) { + this.error('continuation frame cannot have the Per-message Compressed bits', 1002); + return; + } + // continuation frame + this.state.fragmentedOperation = true; + this.state.opcode = this.state.activeFragmentedOperation; + if (!(this.state.opcode == 1 || this.state.opcode == 2)) { + this.error('continuation frame cannot follow current opcode', 1002); + return; + } + } + else { + if (opcode < 3 && this.state.activeFragmentedOperation != null) { + this.error('data frames after the initial data frame must have opcode 0', 1002); + return; + } + if (opcode >= 8 && compressed) { + this.error('control frames cannot have the Per-message Compressed bits', 1002); + return; + } + this.state.compressed = compressed; + this.state.opcode = opcode; + if (this.state.lastFragment === false) { + this.state.fragmentedOperation = true; + this.state.activeFragmentedOperation = opcode; + } + else this.state.fragmentedOperation = false; + } + var handler = opcodes[this.state.opcode]; + if (typeof handler == 'undefined') this.error('no handler for opcode ' + this.state.opcode, 1002); + else { + handler.start.call(this, data); + } +}; + +/** + * Endprocessing a packet. + * + * @api private + */ + +Receiver.prototype.endPacket = function() { + if (this.dead) return; + if (!this.state.fragmentedOperation) this.unfragmentedBufferPool.reset(true); + else if (this.state.lastFragment) this.fragmentedBufferPool.reset(true); + this.expectOffset = 0; + this.expectBuffer = null; + this.expectHandler = null; + if (this.state.lastFragment && this.state.opcode === this.state.activeFragmentedOperation) { + // end current fragmented operation + this.state.activeFragmentedOperation = null; + } + this.currentPayloadLength = 0; + this.state.lastFragment = false; + this.state.opcode = this.state.activeFragmentedOperation != null ? this.state.activeFragmentedOperation : 0; + this.state.masked = false; + this.expectHeader(2, this.processPacket); +}; + +/** + * Reset the parser state. + * + * @api private + */ + +Receiver.prototype.reset = function() { + if (this.dead) return; + this.state = { + activeFragmentedOperation: null, + lastFragment: false, + masked: false, + opcode: 0, + fragmentedOperation: false + }; + this.fragmentedBufferPool.reset(true); + this.unfragmentedBufferPool.reset(true); + this.expectOffset = 0; + this.expectBuffer = null; + this.expectHandler = null; + this.overflow = []; + this.currentMessage = []; + this.currentMessageLength = 0; + this.messageHandlers = []; + this.currentPayloadLength = 0; +}; + +/** + * Unmask received data. + * + * @api private + */ + +Receiver.prototype.unmask = function (mask, buf, binary) { + if (mask != null && buf != null) bufferUtil.unmask(buf, mask); + if (binary) return buf; + return buf != null ? buf.toString('utf8') : ''; +}; + +/** + * Handles an error + * + * @api private + */ + +Receiver.prototype.error = function (reason, protocolErrorCode) { + if (this.dead) return; + this.reset(); + if(typeof reason == 'string'){ + this.onerror(new Error(reason), protocolErrorCode); + } + else if(reason.constructor == Error){ + this.onerror(reason, protocolErrorCode); + } + else{ + this.onerror(new Error("An error occured"),protocolErrorCode); + } + return this; +}; + +/** + * Execute message handler buffers + * + * @api private + */ + +Receiver.prototype.flush = function() { + if (this.processing || this.dead) return; + + var handler = this.messageHandlers.shift(); + if (!handler) return; + + this.processing = true; + var self = this; + + handler(function() { + self.processing = false; + self.flush(); + }); +}; + +/** + * Apply extensions to message + * + * @api private + */ + +Receiver.prototype.applyExtensions = function(messageBuffer, fin, compressed, callback) { + var self = this; + if (compressed) { + this.extensions[PerMessageDeflate.extensionName].decompress(messageBuffer, fin, function(err, buffer) { + if (self.dead) return; + if (err) { + callback(new Error('invalid compressed data')); + return; + } + callback(null, buffer); + }); + } else { + callback(null, messageBuffer); + } +}; + +/** +* Checks payload size, disconnects socket when it exceeds maxPayload +* +* @api private +*/ +Receiver.prototype.maxPayloadExceeded = function(length) { + if (this.maxPayload=== undefined || this.maxPayload === null || this.maxPayload < 1) { + return false; + } + var fullLength = this.currentPayloadLength + length; + if (fullLength < this.maxPayload) { + this.currentPayloadLength = fullLength; + return false; + } + this.error('payload cannot exceed ' + this.maxPayload + ' bytes', 1009); + this.messageBuffer=[]; + this.cleanup(); + + return true; +}; + +/** + * Buffer utilities + */ + +function readUInt16BE(start) { + return (this[start]<<8) + + this[start+1]; +} + +function readUInt32BE(start) { + return (this[start]<<24) + + (this[start+1]<<16) + + (this[start+2]<<8) + + this[start+3]; +} + +function fastCopy(length, srcBuffer, dstBuffer, dstOffset) { + switch (length) { + default: srcBuffer.copy(dstBuffer, dstOffset, 0, length); break; + case 16: dstBuffer[dstOffset+15] = srcBuffer[15]; + case 15: dstBuffer[dstOffset+14] = srcBuffer[14]; + case 14: dstBuffer[dstOffset+13] = srcBuffer[13]; + case 13: dstBuffer[dstOffset+12] = srcBuffer[12]; + case 12: dstBuffer[dstOffset+11] = srcBuffer[11]; + case 11: dstBuffer[dstOffset+10] = srcBuffer[10]; + case 10: dstBuffer[dstOffset+9] = srcBuffer[9]; + case 9: dstBuffer[dstOffset+8] = srcBuffer[8]; + case 8: dstBuffer[dstOffset+7] = srcBuffer[7]; + case 7: dstBuffer[dstOffset+6] = srcBuffer[6]; + case 6: dstBuffer[dstOffset+5] = srcBuffer[5]; + case 5: dstBuffer[dstOffset+4] = srcBuffer[4]; + case 4: dstBuffer[dstOffset+3] = srcBuffer[3]; + case 3: dstBuffer[dstOffset+2] = srcBuffer[2]; + case 2: dstBuffer[dstOffset+1] = srcBuffer[1]; + case 1: dstBuffer[dstOffset] = srcBuffer[0]; + } +} + +function clone(obj) { + var cloned = {}; + for (var k in obj) { + if (obj.hasOwnProperty(k)) { + cloned[k] = obj[k]; + } + } + return cloned; +} + +/** + * Opcode handlers + */ + +var opcodes = { + // text + '1': { + start: function(data) { + var self = this; + // decode length + var firstLength = data[1] & 0x7f; + if (firstLength < 126) { + if (self.maxPayloadExceeded(firstLength)){ + self.error('Maximumpayload exceeded in compressed text message. Aborting...', 1009); + return; + } + opcodes['1'].getData.call(self, firstLength); + } + else if (firstLength == 126) { + self.expectHeader(2, function(data) { + var length = readUInt16BE.call(data, 0); + if (self.maxPayloadExceeded(length)){ + self.error('Maximumpayload exceeded in compressed text message. Aborting...', 1009); + return; + } + opcodes['1'].getData.call(self, length); + }); + } + else if (firstLength == 127) { + self.expectHeader(8, function(data) { + if (readUInt32BE.call(data, 0) != 0) { + self.error('packets with length spanning more than 32 bit is currently not supported', 1008); + return; + } + var length = readUInt32BE.call(data, 4); + if (self.maxPayloadExceeded(length)){ + self.error('Maximumpayload exceeded in compressed text message. Aborting...', 1009); + return; + } + opcodes['1'].getData.call(self, readUInt32BE.call(data, 4)); + }); + } + }, + getData: function(length) { + var self = this; + if (self.state.masked) { + self.expectHeader(4, function(data) { + var mask = data; + self.expectData(length, function(data) { + opcodes['1'].finish.call(self, mask, data); + }); + }); + } + else { + self.expectData(length, function(data) { + opcodes['1'].finish.call(self, null, data); + }); + } + }, + finish: function(mask, data) { + var self = this; + var packet = this.unmask(mask, data, true) || new Buffer(0); + var state = clone(this.state); + this.messageHandlers.push(function(callback) { + self.applyExtensions(packet, state.lastFragment, state.compressed, function(err, buffer) { + if (err) { + if(err.type===1009){ + return self.error('Maximumpayload exceeded in compressed text message. Aborting...', 1009); + } + return self.error(err.message, 1007); + } + if (buffer != null) { + if( self.maxPayload==0 || (self.maxPayload > 0 && (self.currentMessageLength + buffer.length) < self.maxPayload) ){ + self.currentMessage.push(buffer); + } + else{ + self.currentMessage=null; + self.currentMessage = []; + self.currentMessageLength = 0; + self.error(new Error('Maximum payload exceeded. maxPayload: '+self.maxPayload), 1009); + return; + } + self.currentMessageLength += buffer.length; + } + if (state.lastFragment) { + var messageBuffer = Buffer.concat(self.currentMessage); + self.currentMessage = []; + self.currentMessageLength = 0; + if (!Validation.isValidUTF8(messageBuffer)) { + self.error('invalid utf8 sequence', 1007); + return; + } + self.ontext(messageBuffer.toString('utf8'), {masked: state.masked, buffer: messageBuffer}); + } + callback(); + }); + }); + this.flush(); + this.endPacket(); + } + }, + // binary + '2': { + start: function(data) { + var self = this; + // decode length + var firstLength = data[1] & 0x7f; + if (firstLength < 126) { + if (self.maxPayloadExceeded(firstLength)){ + self.error('Max payload exceeded in compressed text message. Aborting...', 1009); + return; + } + opcodes['2'].getData.call(self, firstLength); + } + else if (firstLength == 126) { + self.expectHeader(2, function(data) { + var length = readUInt16BE.call(data, 0); + if (self.maxPayloadExceeded(length)){ + self.error('Max payload exceeded in compressed text message. Aborting...', 1009); + return; + } + opcodes['2'].getData.call(self, length); + }); + } + else if (firstLength == 127) { + self.expectHeader(8, function(data) { + if (readUInt32BE.call(data, 0) != 0) { + self.error('packets with length spanning more than 32 bit is currently not supported', 1008); + return; + } + var length = readUInt32BE.call(data, 4, true); + if (self.maxPayloadExceeded(length)){ + self.error('Max payload exceeded in compressed text message. Aborting...', 1009); + return; + } + opcodes['2'].getData.call(self, length); + }); + } + }, + getData: function(length) { + var self = this; + if (self.state.masked) { + self.expectHeader(4, function(data) { + var mask = data; + self.expectData(length, function(data) { + opcodes['2'].finish.call(self, mask, data); + }); + }); + } + else { + self.expectData(length, function(data) { + opcodes['2'].finish.call(self, null, data); + }); + } + }, + finish: function(mask, data) { + var self = this; + var packet = this.unmask(mask, data, true) || new Buffer(0); + var state = clone(this.state); + this.messageHandlers.push(function(callback) { + self.applyExtensions(packet, state.lastFragment, state.compressed, function(err, buffer) { + if (err) { + if(err.type===1009){ + return self.error('Max payload exceeded in compressed binary message. Aborting...', 1009); + } + return self.error(err.message, 1007); + } + if (buffer != null) { + if( self.maxPayload==0 || (self.maxPayload > 0 && (self.currentMessageLength + buffer.length) < self.maxPayload) ){ + self.currentMessage.push(buffer); + } + else{ + self.currentMessage=null; + self.currentMessage = []; + self.currentMessageLength = 0; + self.error(new Error('Maximum payload exceeded'), 1009); + return; + } + self.currentMessageLength += buffer.length; + } + if (state.lastFragment) { + var messageBuffer = Buffer.concat(self.currentMessage); + self.currentMessage = []; + self.currentMessageLength = 0; + self.onbinary(messageBuffer, {masked: state.masked, buffer: messageBuffer}); + } + callback(); + }); + }); + this.flush(); + this.endPacket(); + } + }, + // close + '8': { + start: function(data) { + var self = this; + if (self.state.lastFragment == false) { + self.error('fragmented close is not supported', 1002); + return; + } + + // decode length + var firstLength = data[1] & 0x7f; + if (firstLength < 126) { + opcodes['8'].getData.call(self, firstLength); + } + else { + self.error('control frames cannot have more than 125 bytes of data', 1002); + } + }, + getData: function(length) { + var self = this; + if (self.state.masked) { + self.expectHeader(4, function(data) { + var mask = data; + self.expectData(length, function(data) { + opcodes['8'].finish.call(self, mask, data); + }); + }); + } + else { + self.expectData(length, function(data) { + opcodes['8'].finish.call(self, null, data); + }); + } + }, + finish: function(mask, data) { + var self = this; + data = self.unmask(mask, data, true); + + var state = clone(this.state); + this.messageHandlers.push(function() { + if (data && data.length == 1) { + self.error('close packets with data must be at least two bytes long', 1002); + return; + } + var code = data && data.length > 1 ? readUInt16BE.call(data, 0) : 1000; + if (!ErrorCodes.isValidErrorCode(code)) { + self.error('invalid error code', 1002); + return; + } + var message = ''; + if (data && data.length > 2) { + var messageBuffer = data.slice(2); + if (!Validation.isValidUTF8(messageBuffer)) { + self.error('invalid utf8 sequence', 1007); + return; + } + message = messageBuffer.toString('utf8'); + } + self.onclose(code, message, {masked: state.masked}); + self.reset(); + }); + this.flush(); + }, + }, + // ping + '9': { + start: function(data) { + var self = this; + if (self.state.lastFragment == false) { + self.error('fragmented ping is not supported', 1002); + return; + } + + // decode length + var firstLength = data[1] & 0x7f; + if (firstLength < 126) { + opcodes['9'].getData.call(self, firstLength); + } + else { + self.error('control frames cannot have more than 125 bytes of data', 1002); + } + }, + getData: function(length) { + var self = this; + if (self.state.masked) { + self.expectHeader(4, function(data) { + var mask = data; + self.expectData(length, function(data) { + opcodes['9'].finish.call(self, mask, data); + }); + }); + } + else { + self.expectData(length, function(data) { + opcodes['9'].finish.call(self, null, data); + }); + } + }, + finish: function(mask, data) { + var self = this; + data = this.unmask(mask, data, true); + var state = clone(this.state); + this.messageHandlers.push(function(callback) { + self.onping(data, {masked: state.masked, binary: true}); + callback(); + }); + this.flush(); + this.endPacket(); + } + }, + // pong + '10': { + start: function(data) { + var self = this; + if (self.state.lastFragment == false) { + self.error('fragmented pong is not supported', 1002); + return; + } + + // decode length + var firstLength = data[1] & 0x7f; + if (firstLength < 126) { + opcodes['10'].getData.call(self, firstLength); + } + else { + self.error('control frames cannot have more than 125 bytes of data', 1002); + } + }, + getData: function(length) { + var self = this; + if (this.state.masked) { + this.expectHeader(4, function(data) { + var mask = data; + self.expectData(length, function(data) { + opcodes['10'].finish.call(self, mask, data); + }); + }); + } + else { + this.expectData(length, function(data) { + opcodes['10'].finish.call(self, null, data); + }); + } + }, + finish: function(mask, data) { + var self = this; + data = self.unmask(mask, data, true); + var state = clone(this.state); + this.messageHandlers.push(function(callback) { + self.onpong(data, {masked: state.masked, binary: true}); + callback(); + }); + this.flush(); + this.endPacket(); + } + } +} diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/Sender.hixie.js b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/Sender.hixie.js new file mode 100644 index 0000000..b87d9dd --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/Sender.hixie.js @@ -0,0 +1,124 @@ +/*! + * ws: a node.js websocket client + * Copyright(c) 2011 Einar Otto Stangvik + * MIT Licensed + */ + +var events = require('events') + , util = require('util') + , EventEmitter = events.EventEmitter; + +/** + * Hixie Sender implementation + */ + +function Sender(socket) { + if (this instanceof Sender === false) { + throw new TypeError("Classes can't be function-called"); + } + + events.EventEmitter.call(this); + + this.socket = socket; + this.continuationFrame = false; + this.isClosed = false; +} + +module.exports = Sender; + +/** + * Inherits from EventEmitter. + */ + +util.inherits(Sender, events.EventEmitter); + +/** + * Frames and writes data. + * + * @api public + */ + +Sender.prototype.send = function(data, options, cb) { + if (this.isClosed) return; + + var isString = typeof data == 'string' + , length = isString ? Buffer.byteLength(data) : data.length + , lengthbytes = (length > 127) ? 2 : 1 // assume less than 2**14 bytes + , writeStartMarker = this.continuationFrame == false + , writeEndMarker = !options || !(typeof options.fin != 'undefined' && !options.fin) + , buffer = new Buffer((writeStartMarker ? ((options && options.binary) ? (1 + lengthbytes) : 1) : 0) + length + ((writeEndMarker && !(options && options.binary)) ? 1 : 0)) + , offset = writeStartMarker ? 1 : 0; + + if (writeStartMarker) { + if (options && options.binary) { + buffer.write('\x80', 'binary'); + // assume length less than 2**14 bytes + if (lengthbytes > 1) + buffer.write(String.fromCharCode(128+length/128), offset++, 'binary'); + buffer.write(String.fromCharCode(length&0x7f), offset++, 'binary'); + } else + buffer.write('\x00', 'binary'); + } + + if (isString) buffer.write(data, offset, 'utf8'); + else data.copy(buffer, offset, 0); + + if (writeEndMarker) { + if (options && options.binary) { + // sending binary, not writing end marker + } else + buffer.write('\xff', offset + length, 'binary'); + this.continuationFrame = false; + } + else this.continuationFrame = true; + + try { + this.socket.write(buffer, 'binary', cb); + } catch (e) { + this.error(e.toString()); + } +}; + +/** + * Sends a close instruction to the remote party. + * + * @api public + */ + +Sender.prototype.close = function(code, data, mask, cb) { + if (this.isClosed) return; + this.isClosed = true; + try { + if (this.continuationFrame) this.socket.write(new Buffer([0xff], 'binary')); + this.socket.write(new Buffer([0xff, 0x00]), 'binary', cb); + } catch (e) { + this.error(e.toString()); + } +}; + +/** + * Sends a ping message to the remote party. Not available for hixie. + * + * @api public + */ + +Sender.prototype.ping = function(data, options) {}; + +/** + * Sends a pong message to the remote party. Not available for hixie. + * + * @api public + */ + +Sender.prototype.pong = function(data, options) {}; + +/** + * Handles an error + * + * @api private + */ + +Sender.prototype.error = function (reason) { + this.emit('error', reason); + return this; +}; diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/Sender.js b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/Sender.js new file mode 100644 index 0000000..6ef2ea2 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/Sender.js @@ -0,0 +1,324 @@ +/*! + * ws: a node.js websocket client + * Copyright(c) 2011 Einar Otto Stangvik + * MIT Licensed + */ + +var events = require('events') + , util = require('util') + , EventEmitter = events.EventEmitter + , ErrorCodes = require('./ErrorCodes') + , bufferUtil = require('./BufferUtil').BufferUtil + , PerMessageDeflate = require('./PerMessageDeflate'); + +/** + * HyBi Sender implementation + */ + +function Sender(socket, extensions) { + if (this instanceof Sender === false) { + throw new TypeError("Classes can't be function-called"); + } + + events.EventEmitter.call(this); + + this._socket = socket; + this.extensions = extensions || {}; + this.firstFragment = true; + this.compress = false; + this.messageHandlers = []; + this.processing = false; +} + +/** + * Inherits from EventEmitter. + */ + +util.inherits(Sender, events.EventEmitter); + +/** + * Sends a close instruction to the remote party. + * + * @api public + */ + +Sender.prototype.close = function(code, data, mask, cb) { + if (typeof code !== 'undefined') { + if (typeof code !== 'number' || + !ErrorCodes.isValidErrorCode(code)) throw new Error('first argument must be a valid error code number'); + } + code = code || 1000; + var dataBuffer = new Buffer(2 + (data ? Buffer.byteLength(data) : 0)); + writeUInt16BE.call(dataBuffer, code, 0); + if (dataBuffer.length > 2) dataBuffer.write(data, 2); + + var self = this; + this.messageHandlers.push(function(callback) { + self.frameAndSend(0x8, dataBuffer, true, mask); + callback(); + if (typeof cb == 'function') cb(); + }); + this.flush(); +}; + +/** + * Sends a ping message to the remote party. + * + * @api public + */ + +Sender.prototype.ping = function(data, options) { + var mask = options && options.mask; + var self = this; + this.messageHandlers.push(function(callback) { + self.frameAndSend(0x9, data || '', true, mask); + callback(); + }); + this.flush(); +}; + +/** + * Sends a pong message to the remote party. + * + * @api public + */ + +Sender.prototype.pong = function(data, options) { + var mask = options && options.mask; + var self = this; + this.messageHandlers.push(function(callback) { + self.frameAndSend(0xa, data || '', true, mask); + callback(); + }); + this.flush(); +}; + +/** + * Sends text or binary data to the remote party. + * + * @api public + */ + +Sender.prototype.send = function(data, options, cb) { + var finalFragment = options && options.fin === false ? false : true; + var mask = options && options.mask; + var compress = options && options.compress; + var opcode = options && options.binary ? 2 : 1; + if (this.firstFragment === false) { + opcode = 0; + compress = false; + } else { + this.firstFragment = false; + this.compress = compress; + } + if (finalFragment) this.firstFragment = true + + var compressFragment = this.compress; + + var self = this; + this.messageHandlers.push(function(callback) { + self.applyExtensions(data, finalFragment, compressFragment, function(err, data) { + if (err) { + if (typeof cb == 'function') cb(err); + else self.emit('error', err); + return; + } + self.frameAndSend(opcode, data, finalFragment, mask, compress, cb); + callback(); + }); + }); + this.flush(); +}; + +/** + * Frames and sends a piece of data according to the HyBi WebSocket protocol. + * + * @api private + */ + +Sender.prototype.frameAndSend = function(opcode, data, finalFragment, maskData, compressed, cb) { + var canModifyData = false; + + if (!data) { + try { + this._socket.write(new Buffer([opcode | (finalFragment ? 0x80 : 0), 0 | (maskData ? 0x80 : 0)].concat(maskData ? [0, 0, 0, 0] : [])), 'binary', cb); + } + catch (e) { + if (typeof cb == 'function') cb(e); + else this.emit('error', e); + } + return; + } + + if (!Buffer.isBuffer(data)) { + canModifyData = true; + if (data && (typeof data.byteLength !== 'undefined' || typeof data.buffer !== 'undefined')) { + data = getArrayBuffer(data); + } else { + // + // If people want to send a number, this would allocate the number in + // bytes as memory size instead of storing the number as buffer value. So + // we need to transform it to string in order to prevent possible + // vulnerabilities / memory attacks. + // + if (typeof data === 'number') data = data.toString(); + + data = new Buffer(data); + } + } + + var dataLength = data.length + , dataOffset = maskData ? 6 : 2 + , secondByte = dataLength; + + if (dataLength >= 65536) { + dataOffset += 8; + secondByte = 127; + } + else if (dataLength > 125) { + dataOffset += 2; + secondByte = 126; + } + + var mergeBuffers = dataLength < 32768 || (maskData && !canModifyData); + var totalLength = mergeBuffers ? dataLength + dataOffset : dataOffset; + var outputBuffer = new Buffer(totalLength); + outputBuffer[0] = finalFragment ? opcode | 0x80 : opcode; + if (compressed) outputBuffer[0] |= 0x40; + + switch (secondByte) { + case 126: + writeUInt16BE.call(outputBuffer, dataLength, 2); + break; + case 127: + writeUInt32BE.call(outputBuffer, 0, 2); + writeUInt32BE.call(outputBuffer, dataLength, 6); + } + + if (maskData) { + outputBuffer[1] = secondByte | 0x80; + var mask = getRandomMask(); + outputBuffer[dataOffset - 4] = mask[0]; + outputBuffer[dataOffset - 3] = mask[1]; + outputBuffer[dataOffset - 2] = mask[2]; + outputBuffer[dataOffset - 1] = mask[3]; + if (mergeBuffers) { + bufferUtil.mask(data, mask, outputBuffer, dataOffset, dataLength); + try { + this._socket.write(outputBuffer, 'binary', cb); + } + catch (e) { + if (typeof cb == 'function') cb(e); + else this.emit('error', e); + } + } + else { + bufferUtil.mask(data, mask, data, 0, dataLength); + try { + this._socket.write(outputBuffer, 'binary'); + this._socket.write(data, 'binary', cb); + } + catch (e) { + if (typeof cb == 'function') cb(e); + else this.emit('error', e); + } + } + } + else { + outputBuffer[1] = secondByte; + if (mergeBuffers) { + data.copy(outputBuffer, dataOffset); + try { + this._socket.write(outputBuffer, 'binary', cb); + } + catch (e) { + if (typeof cb == 'function') cb(e); + else this.emit('error', e); + } + } + else { + try { + this._socket.write(outputBuffer, 'binary'); + this._socket.write(data, 'binary', cb); + } + catch (e) { + if (typeof cb == 'function') cb(e); + else this.emit('error', e); + } + } + } +}; + +/** + * Execute message handler buffers + * + * @api private + */ + +Sender.prototype.flush = function() { + if (this.processing) return; + + var handler = this.messageHandlers.shift(); + if (!handler) return; + + this.processing = true; + + var self = this; + + handler(function() { + self.processing = false; + self.flush(); + }); +}; + +/** + * Apply extensions to message + * + * @api private + */ + +Sender.prototype.applyExtensions = function(data, fin, compress, callback) { + if (compress && data) { + if ((data.buffer || data) instanceof ArrayBuffer) { + data = getArrayBuffer(data); + } + this.extensions[PerMessageDeflate.extensionName].compress(data, fin, callback); + } else { + callback(null, data); + } +}; + +module.exports = Sender; + +function writeUInt16BE(value, offset) { + this[offset] = (value & 0xff00)>>8; + this[offset+1] = value & 0xff; +} + +function writeUInt32BE(value, offset) { + this[offset] = (value & 0xff000000)>>24; + this[offset+1] = (value & 0xff0000)>>16; + this[offset+2] = (value & 0xff00)>>8; + this[offset+3] = value & 0xff; +} + +function getArrayBuffer(data) { + // data is either an ArrayBuffer or ArrayBufferView. + var array = new Uint8Array(data.buffer || data) + , l = data.byteLength || data.length + , o = data.byteOffset || 0 + , buffer = new Buffer(l); + for (var i = 0; i < l; ++i) { + buffer[i] = array[o+i]; + } + return buffer; +} + +function getRandomMask() { + return new Buffer([ + ~~(Math.random() * 255), + ~~(Math.random() * 255), + ~~(Math.random() * 255), + ~~(Math.random() * 255) + ]); +} diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/Validation.fallback.js b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/Validation.fallback.js new file mode 100644 index 0000000..639b0d3 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/Validation.fallback.js @@ -0,0 +1,11 @@ +/*! + * ws: a node.js websocket client + * Copyright(c) 2011 Einar Otto Stangvik + * MIT Licensed + */ + +exports.Validation = { + isValidUTF8: function(buffer) { + return true; + } +}; diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/Validation.js b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/Validation.js new file mode 100644 index 0000000..0795fb7 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/Validation.js @@ -0,0 +1,13 @@ +'use strict'; + +/*! + * ws: a node.js websocket client + * Copyright(c) 2011 Einar Otto Stangvik + * MIT Licensed + */ + +try { + module.exports = require('utf-8-validate'); +} catch (e) { + module.exports = require('./Validation.fallback'); +} diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/WebSocket.js b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/WebSocket.js new file mode 100644 index 0000000..bb09e85 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/WebSocket.js @@ -0,0 +1,987 @@ +'use strict'; + +/*! + * ws: a node.js websocket client + * Copyright(c) 2011 Einar Otto Stangvik + * MIT Licensed + */ + +var url = require('url') + , util = require('util') + , http = require('http') + , https = require('https') + , crypto = require('crypto') + , stream = require('stream') + , Ultron = require('ultron') + , Options = require('options') + , Sender = require('./Sender') + , Receiver = require('./Receiver') + , SenderHixie = require('./Sender.hixie') + , ReceiverHixie = require('./Receiver.hixie') + , Extensions = require('./Extensions') + , PerMessageDeflate = require('./PerMessageDeflate') + , EventEmitter = require('events').EventEmitter; + +/** + * Constants + */ + +// Default protocol version + +var protocolVersion = 13; + +// Close timeout + +var closeTimeout = 30 * 1000; // Allow 30 seconds to terminate the connection cleanly + +/** + * WebSocket implementation + * + * @constructor + * @param {String} address Connection address. + * @param {String|Array} protocols WebSocket protocols. + * @param {Object} options Additional connection options. + * @api public + */ +function WebSocket(address, protocols, options) { + if (this instanceof WebSocket === false) { + return new WebSocket(address, protocols, options); + } + + EventEmitter.call(this); + + if (protocols && !Array.isArray(protocols) && 'object' === typeof protocols) { + // accept the "options" Object as the 2nd argument + options = protocols; + protocols = null; + } + + if ('string' === typeof protocols) { + protocols = [ protocols ]; + } + + if (!Array.isArray(protocols)) { + protocols = []; + } + + this._socket = null; + this._ultron = null; + this._closeReceived = false; + this.bytesReceived = 0; + this.readyState = null; + this.supports = {}; + this.extensions = {}; + this._binaryType = 'nodebuffer'; + + if (Array.isArray(address)) { + initAsServerClient.apply(this, address.concat(options)); + } else { + initAsClient.apply(this, [address, protocols, options]); + } +} + +/** + * Inherits from EventEmitter. + */ +util.inherits(WebSocket, EventEmitter); + +/** + * Ready States + */ +["CONNECTING", "OPEN", "CLOSING", "CLOSED"].forEach(function each(state, index) { + WebSocket.prototype[state] = WebSocket[state] = index; +}); + +/** + * Gracefully closes the connection, after sending a description message to the server + * + * @param {Object} data to be sent to the server + * @api public + */ +WebSocket.prototype.close = function close(code, data) { + if (this.readyState === WebSocket.CLOSED) return; + + if (this.readyState === WebSocket.CONNECTING) { + this.readyState = WebSocket.CLOSED; + return; + } + + if (this.readyState === WebSocket.CLOSING) { + if (this._closeReceived && this._isServer) { + this.terminate(); + } + return; + } + + var self = this; + try { + this.readyState = WebSocket.CLOSING; + this._closeCode = code; + this._closeMessage = data; + var mask = !this._isServer; + this._sender.close(code, data, mask, function(err) { + if (err) self.emit('error', err); + + if (self._closeReceived && self._isServer) { + self.terminate(); + } else { + // ensure that the connection is cleaned up even when no response of closing handshake. + clearTimeout(self._closeTimer); + self._closeTimer = setTimeout(cleanupWebsocketResources.bind(self, true), closeTimeout); + } + }); + } catch (e) { + this.emit('error', e); + } +}; + +/** + * Pause the client stream + * + * @api public + */ +WebSocket.prototype.pause = function pauser() { + if (this.readyState !== WebSocket.OPEN) throw new Error('not opened'); + + return this._socket.pause(); +}; + +/** + * Sends a ping + * + * @param {Object} data to be sent to the server + * @param {Object} Members - mask: boolean, binary: boolean + * @param {boolean} dontFailWhenClosed indicates whether or not to throw if the connection isnt open + * @api public + */ +WebSocket.prototype.ping = function ping(data, options, dontFailWhenClosed) { + if (this.readyState !== WebSocket.OPEN) { + if (dontFailWhenClosed === true) return; + throw new Error('not opened'); + } + + options = options || {}; + + if (typeof options.mask === 'undefined') options.mask = !this._isServer; + + this._sender.ping(data, options); +}; + +/** + * Sends a pong + * + * @param {Object} data to be sent to the server + * @param {Object} Members - mask: boolean, binary: boolean + * @param {boolean} dontFailWhenClosed indicates whether or not to throw if the connection isnt open + * @api public + */ +WebSocket.prototype.pong = function(data, options, dontFailWhenClosed) { + if (this.readyState !== WebSocket.OPEN) { + if (dontFailWhenClosed === true) return; + throw new Error('not opened'); + } + + options = options || {}; + + if (typeof options.mask === 'undefined') options.mask = !this._isServer; + + this._sender.pong(data, options); +}; + +/** + * Resume the client stream + * + * @api public + */ +WebSocket.prototype.resume = function resume() { + if (this.readyState !== WebSocket.OPEN) throw new Error('not opened'); + + return this._socket.resume(); +}; + +/** + * Sends a piece of data + * + * @param {Object} data to be sent to the server + * @param {Object} Members - mask: boolean, binary: boolean, compress: boolean + * @param {function} Optional callback which is executed after the send completes + * @api public + */ + +WebSocket.prototype.send = function send(data, options, cb) { + if (typeof options === 'function') { + cb = options; + options = {}; + } + + if (this.readyState !== WebSocket.OPEN) { + if (typeof cb === 'function') cb(new Error('not opened')); + else throw new Error('not opened'); + return; + } + + if (!data) data = ''; + if (this._queue) { + var self = this; + this._queue.push(function() { self.send(data, options, cb); }); + return; + } + + options = options || {}; + options.fin = true; + + if (typeof options.binary === 'undefined') { + options.binary = (data instanceof ArrayBuffer || data instanceof Buffer || + data instanceof Uint8Array || + data instanceof Uint16Array || + data instanceof Uint32Array || + data instanceof Int8Array || + data instanceof Int16Array || + data instanceof Int32Array || + data instanceof Float32Array || + data instanceof Float64Array); + } + + if (typeof options.mask === 'undefined') options.mask = !this._isServer; + if (typeof options.compress === 'undefined') options.compress = true; + if (!this.extensions[PerMessageDeflate.extensionName]) { + options.compress = false; + } + + var readable = typeof stream.Readable === 'function' + ? stream.Readable + : stream.Stream; + + if (data instanceof readable) { + startQueue(this); + var self = this; + + sendStream(this, data, options, function send(error) { + process.nextTick(function tock() { + executeQueueSends(self); + }); + + if (typeof cb === 'function') cb(error); + }); + } else { + this._sender.send(data, options, cb); + } +}; + +/** + * Streams data through calls to a user supplied function + * + * @param {Object} Members - mask: boolean, binary: boolean, compress: boolean + * @param {function} 'function (error, send)' which is executed on successive ticks of which send is 'function (data, final)'. + * @api public + */ +WebSocket.prototype.stream = function stream(options, cb) { + if (typeof options === 'function') { + cb = options; + options = {}; + } + + var self = this; + + if (typeof cb !== 'function') throw new Error('callback must be provided'); + + if (this.readyState !== WebSocket.OPEN) { + if (typeof cb === 'function') cb(new Error('not opened')); + else throw new Error('not opened'); + return; + } + + if (this._queue) { + this._queue.push(function () { self.stream(options, cb); }); + return; + } + + options = options || {}; + + if (typeof options.mask === 'undefined') options.mask = !this._isServer; + if (typeof options.compress === 'undefined') options.compress = true; + if (!this.extensions[PerMessageDeflate.extensionName]) { + options.compress = false; + } + + startQueue(this); + + function send(data, final) { + try { + if (self.readyState !== WebSocket.OPEN) throw new Error('not opened'); + options.fin = final === true; + self._sender.send(data, options); + if (!final) process.nextTick(cb.bind(null, null, send)); + else executeQueueSends(self); + } catch (e) { + if (typeof cb === 'function') cb(e); + else { + delete self._queue; + self.emit('error', e); + } + } + } + + process.nextTick(cb.bind(null, null, send)); +}; + +/** + * Immediately shuts down the connection + * + * @api public + */ +WebSocket.prototype.terminate = function terminate() { + if (this.readyState === WebSocket.CLOSED) return; + + if (this._socket) { + this.readyState = WebSocket.CLOSING; + + // End the connection + try { this._socket.end(); } + catch (e) { + // Socket error during end() call, so just destroy it right now + cleanupWebsocketResources.call(this, true); + return; + } + + // Add a timeout to ensure that the connection is completely + // cleaned up within 30 seconds, even if the clean close procedure + // fails for whatever reason + // First cleanup any pre-existing timeout from an earlier "terminate" call, + // if one exists. Otherwise terminate calls in quick succession will leak timeouts + // and hold the program open for `closeTimout` time. + if (this._closeTimer) { clearTimeout(this._closeTimer); } + this._closeTimer = setTimeout(cleanupWebsocketResources.bind(this, true), closeTimeout); + } else if (this.readyState === WebSocket.CONNECTING) { + cleanupWebsocketResources.call(this, true); + } +}; + +/** + * Expose bufferedAmount + * + * @api public + */ +Object.defineProperty(WebSocket.prototype, 'bufferedAmount', { + get: function get() { + var amount = 0; + if (this._socket) { + amount = this._socket.bufferSize || 0; + } + return amount; + } +}); + +/** + * Expose binaryType + * + * This deviates from the W3C interface since ws doesn't support the required + * default "blob" type (instead we define a custom "nodebuffer" type). + * + * @see http://dev.w3.org/html5/websockets/#the-websocket-interface + * @api public + */ +Object.defineProperty(WebSocket.prototype, 'binaryType', { + get: function get() { + return this._binaryType; + }, + set: function set(type) { + if (type === 'arraybuffer' || type === 'nodebuffer') + this._binaryType = type; + else + throw new SyntaxError('unsupported binaryType: must be either "nodebuffer" or "arraybuffer"'); + } +}); + +/** + * Emulates the W3C Browser based WebSocket interface using function members. + * + * @see http://dev.w3.org/html5/websockets/#the-websocket-interface + * @api public + */ +['open', 'error', 'close', 'message'].forEach(function(method) { + Object.defineProperty(WebSocket.prototype, 'on' + method, { + /** + * Returns the current listener + * + * @returns {Mixed} the set function or undefined + * @api public + */ + get: function get() { + var listener = this.listeners(method)[0]; + return listener ? (listener._listener ? listener._listener : listener) : undefined; + }, + + /** + * Start listening for events + * + * @param {Function} listener the listener + * @returns {Mixed} the set function or undefined + * @api public + */ + set: function set(listener) { + this.removeAllListeners(method); + this.addEventListener(method, listener); + } + }); +}); + +/** + * Emulates the W3C Browser based WebSocket interface using addEventListener. + * + * @see https://developer.mozilla.org/en/DOM/element.addEventListener + * @see http://dev.w3.org/html5/websockets/#the-websocket-interface + * @api public + */ +WebSocket.prototype.addEventListener = function(method, listener) { + var target = this; + + function onMessage (data, flags) { + if (flags.binary && this.binaryType === 'arraybuffer') + data = new Uint8Array(data).buffer; + listener.call(target, new MessageEvent(data, !!flags.binary, target)); + } + + function onClose (code, message) { + listener.call(target, new CloseEvent(code, message, target)); + } + + function onError (event) { + event.type = 'error'; + event.target = target; + listener.call(target, event); + } + + function onOpen () { + listener.call(target, new OpenEvent(target)); + } + + if (typeof listener === 'function') { + if (method === 'message') { + // store a reference so we can return the original function from the + // addEventListener hook + onMessage._listener = listener; + this.on(method, onMessage); + } else if (method === 'close') { + // store a reference so we can return the original function from the + // addEventListener hook + onClose._listener = listener; + this.on(method, onClose); + } else if (method === 'error') { + // store a reference so we can return the original function from the + // addEventListener hook + onError._listener = listener; + this.on(method, onError); + } else if (method === 'open') { + // store a reference so we can return the original function from the + // addEventListener hook + onOpen._listener = listener; + this.on(method, onOpen); + } else { + this.on(method, listener); + } + } +}; + +module.exports = WebSocket; +module.exports.buildHostHeader = buildHostHeader + +/** + * W3C MessageEvent + * + * @see http://www.w3.org/TR/html5/comms.html + * @constructor + * @api private + */ +function MessageEvent(dataArg, isBinary, target) { + this.type = 'message'; + this.data = dataArg; + this.target = target; + this.binary = isBinary; // non-standard. +} + +/** + * W3C CloseEvent + * + * @see http://www.w3.org/TR/html5/comms.html + * @constructor + * @api private + */ +function CloseEvent(code, reason, target) { + this.type = 'close'; + this.wasClean = (typeof code === 'undefined' || code === 1000); + this.code = code; + this.reason = reason; + this.target = target; +} + +/** + * W3C OpenEvent + * + * @see http://www.w3.org/TR/html5/comms.html + * @constructor + * @api private + */ +function OpenEvent(target) { + this.type = 'open'; + this.target = target; +} + +// Append port number to Host header, only if specified in the url +// and non-default +function buildHostHeader(isSecure, hostname, port) { + var headerHost = hostname; + if (hostname) { + if ((isSecure && (port != 443)) || (!isSecure && (port != 80))){ + headerHost = headerHost + ':' + port; + } + } + return headerHost; +} + +/** + * Entirely private apis, + * which may or may not be bound to a sepcific WebSocket instance. + */ +function initAsServerClient(req, socket, upgradeHead, options) { + options = new Options({ + protocolVersion: protocolVersion, + protocol: null, + extensions: {}, + maxPayload: 0 + }).merge(options); + + // expose state properties + this.protocol = options.value.protocol; + this.protocolVersion = options.value.protocolVersion; + this.extensions = options.value.extensions; + this.supports.binary = (this.protocolVersion !== 'hixie-76'); + this.upgradeReq = req; + this.readyState = WebSocket.CONNECTING; + this._isServer = true; + this.maxPayload = options.value.maxPayload; + // establish connection + if (options.value.protocolVersion === 'hixie-76') { + establishConnection.call(this, ReceiverHixie, SenderHixie, socket, upgradeHead); + } else { + establishConnection.call(this, Receiver, Sender, socket, upgradeHead); + } +} + +function initAsClient(address, protocols, options) { + options = new Options({ + origin: null, + protocolVersion: protocolVersion, + host: null, + headers: null, + protocol: protocols.join(','), + agent: null, + + // ssl-related options + pfx: null, + key: null, + passphrase: null, + cert: null, + ca: null, + ciphers: null, + rejectUnauthorized: null, + perMessageDeflate: true, + localAddress: null + }).merge(options); + + if (options.value.protocolVersion !== 8 && options.value.protocolVersion !== 13) { + throw new Error('unsupported protocol version'); + } + + // verify URL and establish http class + var serverUrl = url.parse(address); + var isUnixSocket = serverUrl.protocol === 'ws+unix:'; + if (!serverUrl.host && !isUnixSocket) throw new Error('invalid url'); + var isSecure = serverUrl.protocol === 'wss:' || serverUrl.protocol === 'https:'; + var httpObj = isSecure ? https : http; + var port = serverUrl.port || (isSecure ? 443 : 80); + var auth = serverUrl.auth; + + // prepare extensions + var extensionsOffer = {}; + var perMessageDeflate; + if (options.value.perMessageDeflate) { + perMessageDeflate = new PerMessageDeflate(typeof options.value.perMessageDeflate !== true ? options.value.perMessageDeflate : {}, false); + extensionsOffer[PerMessageDeflate.extensionName] = perMessageDeflate.offer(); + } + + // expose state properties + this._isServer = false; + this.url = address; + this.protocolVersion = options.value.protocolVersion; + this.supports.binary = (this.protocolVersion !== 'hixie-76'); + + // begin handshake + var key = new Buffer(options.value.protocolVersion + '-' + Date.now()).toString('base64'); + var shasum = crypto.createHash('sha1'); + shasum.update(key + '258EAFA5-E914-47DA-95CA-C5AB0DC85B11'); + var expectedServerKey = shasum.digest('base64'); + + var agent = options.value.agent; + + var headerHost = buildHostHeader(isSecure, serverUrl.hostname, port) + + var requestOptions = { + port: port, + host: serverUrl.hostname, + headers: { + 'Connection': 'Upgrade', + 'Upgrade': 'websocket', + 'Host': headerHost, + 'Sec-WebSocket-Version': options.value.protocolVersion, + 'Sec-WebSocket-Key': key + } + }; + + // If we have basic auth. + if (auth) { + requestOptions.headers.Authorization = 'Basic ' + new Buffer(auth).toString('base64'); + } + + if (options.value.protocol) { + requestOptions.headers['Sec-WebSocket-Protocol'] = options.value.protocol; + } + + if (options.value.host) { + requestOptions.headers.Host = options.value.host; + } + + if (options.value.headers) { + for (var header in options.value.headers) { + if (options.value.headers.hasOwnProperty(header)) { + requestOptions.headers[header] = options.value.headers[header]; + } + } + } + + if (Object.keys(extensionsOffer).length) { + requestOptions.headers['Sec-WebSocket-Extensions'] = Extensions.format(extensionsOffer); + } + + if (options.isDefinedAndNonNull('pfx') + || options.isDefinedAndNonNull('key') + || options.isDefinedAndNonNull('passphrase') + || options.isDefinedAndNonNull('cert') + || options.isDefinedAndNonNull('ca') + || options.isDefinedAndNonNull('ciphers') + || options.isDefinedAndNonNull('rejectUnauthorized')) { + + if (options.isDefinedAndNonNull('pfx')) requestOptions.pfx = options.value.pfx; + if (options.isDefinedAndNonNull('key')) requestOptions.key = options.value.key; + if (options.isDefinedAndNonNull('passphrase')) requestOptions.passphrase = options.value.passphrase; + if (options.isDefinedAndNonNull('cert')) requestOptions.cert = options.value.cert; + if (options.isDefinedAndNonNull('ca')) requestOptions.ca = options.value.ca; + if (options.isDefinedAndNonNull('ciphers')) requestOptions.ciphers = options.value.ciphers; + if (options.isDefinedAndNonNull('rejectUnauthorized')) requestOptions.rejectUnauthorized = options.value.rejectUnauthorized; + + if (!agent) { + // global agent ignores client side certificates + agent = new httpObj.Agent(requestOptions); + } + } + + requestOptions.path = serverUrl.path || '/'; + + if (agent) { + requestOptions.agent = agent; + } + + if (isUnixSocket) { + requestOptions.socketPath = serverUrl.pathname; + } + + if (options.value.localAddress) { + requestOptions.localAddress = options.value.localAddress; + } + + if (options.value.origin) { + if (options.value.protocolVersion < 13) requestOptions.headers['Sec-WebSocket-Origin'] = options.value.origin; + else requestOptions.headers.Origin = options.value.origin; + } + + var self = this; + var req = httpObj.request(requestOptions); + + req.on('error', function onerror(error) { + self.emit('error', error); + cleanupWebsocketResources.call(self, error); + }); + + req.once('response', function response(res) { + var error; + + if (!self.emit('unexpected-response', req, res)) { + error = new Error('unexpected server response (' + res.statusCode + ')'); + req.abort(); + self.emit('error', error); + } + + cleanupWebsocketResources.call(self, error); + }); + + req.once('upgrade', function upgrade(res, socket, upgradeHead) { + if (self.readyState === WebSocket.CLOSED) { + // client closed before server accepted connection + self.emit('close'); + self.removeAllListeners(); + socket.end(); + return; + } + + var serverKey = res.headers['sec-websocket-accept']; + if (typeof serverKey === 'undefined' || serverKey !== expectedServerKey) { + self.emit('error', 'invalid server key'); + self.removeAllListeners(); + socket.end(); + return; + } + + var serverProt = res.headers['sec-websocket-protocol']; + var protList = (options.value.protocol || "").split(/, */); + var protError = null; + + if (!options.value.protocol && serverProt) { + protError = 'server sent a subprotocol even though none requested'; + } else if (options.value.protocol && !serverProt) { + protError = 'server sent no subprotocol even though requested'; + } else if (serverProt && protList.indexOf(serverProt) === -1) { + protError = 'server responded with an invalid protocol'; + } + + if (protError) { + self.emit('error', protError); + self.removeAllListeners(); + socket.end(); + return; + } else if (serverProt) { + self.protocol = serverProt; + } + + var serverExtensions = Extensions.parse(res.headers['sec-websocket-extensions']); + if (perMessageDeflate && serverExtensions[PerMessageDeflate.extensionName]) { + try { + perMessageDeflate.accept(serverExtensions[PerMessageDeflate.extensionName]); + } catch (err) { + self.emit('error', 'invalid extension parameter'); + self.removeAllListeners(); + socket.end(); + return; + } + self.extensions[PerMessageDeflate.extensionName] = perMessageDeflate; + } + + establishConnection.call(self, Receiver, Sender, socket, upgradeHead); + + // perform cleanup on http resources + req.removeAllListeners(); + req = null; + agent = null; + }); + + req.end(); + this.readyState = WebSocket.CONNECTING; +} + +function establishConnection(ReceiverClass, SenderClass, socket, upgradeHead) { + var ultron = this._ultron = new Ultron(socket) + , called = false + , self = this; + + socket.setTimeout(0); + socket.setNoDelay(true); + + this._receiver = new ReceiverClass(this.extensions,this.maxPayload); + this._socket = socket; + + // socket cleanup handlers + ultron.on('end', cleanupWebsocketResources.bind(this)); + ultron.on('close', cleanupWebsocketResources.bind(this)); + ultron.on('error', cleanupWebsocketResources.bind(this)); + + // ensure that the upgradeHead is added to the receiver + function firstHandler(data) { + if (called || self.readyState === WebSocket.CLOSED) return; + + called = true; + socket.removeListener('data', firstHandler); + ultron.on('data', realHandler); + + if (upgradeHead && upgradeHead.length > 0) { + realHandler(upgradeHead); + upgradeHead = null; + } + + if (data) realHandler(data); + } + + // subsequent packets are pushed straight to the receiver + function realHandler(data) { + self.bytesReceived += data.length; + self._receiver.add(data); + } + + ultron.on('data', firstHandler); + + // if data was passed along with the http upgrade, + // this will schedule a push of that on to the receiver. + // this has to be done on next tick, since the caller + // hasn't had a chance to set event handlers on this client + // object yet. + process.nextTick(firstHandler); + + // receiver event handlers + self._receiver.ontext = function ontext(data, flags) { + flags = flags || {}; + + self.emit('message', data, flags); + }; + + self._receiver.onbinary = function onbinary(data, flags) { + flags = flags || {}; + + flags.binary = true; + self.emit('message', data, flags); + }; + + self._receiver.onping = function onping(data, flags) { + flags = flags || {}; + + self.pong(data, { + mask: !self._isServer, + binary: flags.binary === true + }, true); + + self.emit('ping', data, flags); + }; + + self._receiver.onpong = function onpong(data, flags) { + self.emit('pong', data, flags || {}); + }; + + self._receiver.onclose = function onclose(code, data, flags) { + flags = flags || {}; + + self._closeReceived = true; + self.close(code, data); + }; + + self._receiver.onerror = function onerror(reason, errorCode) { + // close the connection when the receiver reports a HyBi error code + self.close(typeof errorCode !== 'undefined' ? errorCode : 1002, ''); + self.emit('error', (reason instanceof Error) ? reason : (new Error(reason))); + }; + + // finalize the client + this._sender = new SenderClass(socket, this.extensions); + this._sender.on('error', function onerror(error) { + self.close(1002, ''); + self.emit('error', error); + }); + + this.readyState = WebSocket.OPEN; + this.emit('open'); +} + +function startQueue(instance) { + instance._queue = instance._queue || []; +} + +function executeQueueSends(instance) { + var queue = instance._queue; + if (typeof queue === 'undefined') return; + + delete instance._queue; + for (var i = 0, l = queue.length; i < l; ++i) { + queue[i](); + } +} + +function sendStream(instance, stream, options, cb) { + stream.on('data', function incoming(data) { + if (instance.readyState !== WebSocket.OPEN) { + if (typeof cb === 'function') cb(new Error('not opened')); + else { + delete instance._queue; + instance.emit('error', new Error('not opened')); + } + return; + } + + options.fin = false; + instance._sender.send(data, options); + }); + + stream.on('end', function end() { + if (instance.readyState !== WebSocket.OPEN) { + if (typeof cb === 'function') cb(new Error('not opened')); + else { + delete instance._queue; + instance.emit('error', new Error('not opened')); + } + return; + } + + options.fin = true; + instance._sender.send(null, options); + + if (typeof cb === 'function') cb(null); + }); +} + +function cleanupWebsocketResources(error) { + if (this.readyState === WebSocket.CLOSED) return; + + this.readyState = WebSocket.CLOSED; + + clearTimeout(this._closeTimer); + this._closeTimer = null; + + // If the connection was closed abnormally (with an error), or if + // the close control frame was not received then the close code + // must default to 1006. + if (error || !this._closeReceived) { + this._closeCode = 1006; + } + this.emit('close', this._closeCode || 1000, this._closeMessage || ''); + + if (this._socket) { + if (this._ultron) this._ultron.destroy(); + this._socket.on('error', function onerror() { + try { this.destroy(); } + catch (e) {} + }); + + try { + if (!error) this._socket.end(); + else this._socket.destroy(); + } catch (e) { /* Ignore termination errors */ } + + this._socket = null; + this._ultron = null; + } + + if (this._sender) { + this._sender.removeAllListeners(); + this._sender = null; + } + + if (this._receiver) { + this._receiver.cleanup(); + this._receiver = null; + } + + if (this.extensions[PerMessageDeflate.extensionName]) { + this.extensions[PerMessageDeflate.extensionName].cleanup(); + } + + this.extensions = null; + + this.removeAllListeners(); + this.on('error', function onerror() {}); // catch all errors after this + delete this._queue; +} diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/WebSocketServer.js b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/WebSocketServer.js new file mode 100644 index 0000000..92077cd --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/lib/WebSocketServer.js @@ -0,0 +1,554 @@ +/*! + * ws: a node.js websocket client + * Copyright(c) 2011 Einar Otto Stangvik + * MIT Licensed + */ + +var util = require('util') + , events = require('events') + , http = require('http') + , crypto = require('crypto') + , Options = require('options') + , WebSocket = require('./WebSocket') + , Extensions = require('./Extensions') + , PerMessageDeflate = require('./PerMessageDeflate') + , tls = require('tls') + , url = require('url'); + +/** + * WebSocket Server implementation + */ + +function WebSocketServer(options, callback) { + if (this instanceof WebSocketServer === false) { + return new WebSocketServer(options, callback); + } + + events.EventEmitter.call(this); + + options = new Options({ + host: '0.0.0.0', + port: null, + server: null, + verifyClient: null, + handleProtocols: null, + path: null, + noServer: false, + disableHixie: false, + clientTracking: true, + perMessageDeflate: true, + maxPayload: 100 * 1024 * 1024 + }).merge(options); + + if (!options.isDefinedAndNonNull('port') && !options.isDefinedAndNonNull('server') && !options.value.noServer) { + throw new TypeError('`port` or a `server` must be provided'); + } + + var self = this; + + if (options.isDefinedAndNonNull('port')) { + this._server = http.createServer(function (req, res) { + var body = http.STATUS_CODES[426]; + res.writeHead(426, { + 'Content-Length': body.length, + 'Content-Type': 'text/plain' + }); + res.end(body); + }); + this._server.allowHalfOpen = false; + this._server.listen(options.value.port, options.value.host, callback); + this._closeServer = function() { if (self._server) self._server.close(); }; + } + else if (options.value.server) { + this._server = options.value.server; + if (options.value.path) { + // take note of the path, to avoid collisions when multiple websocket servers are + // listening on the same http server + if (this._server._webSocketPaths && options.value.server._webSocketPaths[options.value.path]) { + throw new Error('two instances of WebSocketServer cannot listen on the same http server path'); + } + if (typeof this._server._webSocketPaths !== 'object') { + this._server._webSocketPaths = {}; + } + this._server._webSocketPaths[options.value.path] = 1; + } + } + if (this._server) { + this._onceServerListening = function() { self.emit('listening'); }; + this._server.once('listening', this._onceServerListening); + } + + if (typeof this._server != 'undefined') { + this._onServerError = function(error) { self.emit('error', error) }; + this._server.on('error', this._onServerError); + this._onServerUpgrade = function(req, socket, upgradeHead) { + //copy upgradeHead to avoid retention of large slab buffers used in node core + var head = new Buffer(upgradeHead.length); + upgradeHead.copy(head); + + self.handleUpgrade(req, socket, head, function(client) { + self.emit('connection'+req.url, client); + self.emit('connection', client); + }); + }; + this._server.on('upgrade', this._onServerUpgrade); + } + + this.options = options.value; + this.path = options.value.path; + this.clients = []; +} + +/** + * Inherits from EventEmitter. + */ + +util.inherits(WebSocketServer, events.EventEmitter); + +/** + * Immediately shuts down the connection. + * + * @api public + */ + +WebSocketServer.prototype.close = function(callback) { + // terminate all associated clients + var error = null; + try { + for (var i = 0, l = this.clients.length; i < l; ++i) { + this.clients[i].terminate(); + } + } + catch (e) { + error = e; + } + + // remove path descriptor, if any + if (this.path && this._server._webSocketPaths) { + delete this._server._webSocketPaths[this.path]; + if (Object.keys(this._server._webSocketPaths).length == 0) { + delete this._server._webSocketPaths; + } + } + + // close the http server if it was internally created + try { + if (typeof this._closeServer !== 'undefined') { + this._closeServer(); + } + } + finally { + if (this._server) { + this._server.removeListener('listening', this._onceServerListening); + this._server.removeListener('error', this._onServerError); + this._server.removeListener('upgrade', this._onServerUpgrade); + } + delete this._server; + } + if(callback) + callback(error); + else if(error) + throw error; +} + +/** + * Handle a HTTP Upgrade request. + * + * @api public + */ + +WebSocketServer.prototype.handleUpgrade = function(req, socket, upgradeHead, cb) { + // check for wrong path + if (this.options.path) { + var u = url.parse(req.url); + if (u && u.pathname !== this.options.path) return; + } + + if (typeof req.headers.upgrade === 'undefined' || req.headers.upgrade.toLowerCase() !== 'websocket') { + abortConnection(socket, 400, 'Bad Request'); + return; + } + + if (req.headers['sec-websocket-key1']) handleHixieUpgrade.apply(this, arguments); + else handleHybiUpgrade.apply(this, arguments); +} + +module.exports = WebSocketServer; + +/** + * Entirely private apis, + * which may or may not be bound to a sepcific WebSocket instance. + */ + +function handleHybiUpgrade(req, socket, upgradeHead, cb) { + // handle premature socket errors + var errorHandler = function() { + try { socket.destroy(); } catch (e) {} + } + socket.on('error', errorHandler); + + // verify key presence + if (!req.headers['sec-websocket-key']) { + abortConnection(socket, 400, 'Bad Request'); + return; + } + + // verify version + var version = parseInt(req.headers['sec-websocket-version']); + if ([8, 13].indexOf(version) === -1) { + abortConnection(socket, 400, 'Bad Request'); + return; + } + + // verify protocol + var protocols = req.headers['sec-websocket-protocol']; + + // verify client + var origin = version < 13 ? + req.headers['sec-websocket-origin'] : + req.headers['origin']; + + // handle extensions offer + var extensionsOffer = Extensions.parse(req.headers['sec-websocket-extensions']); + + // handler to call when the connection sequence completes + var self = this; + var completeHybiUpgrade2 = function(protocol) { + + // calc key + var key = req.headers['sec-websocket-key']; + var shasum = crypto.createHash('sha1'); + shasum.update(key + "258EAFA5-E914-47DA-95CA-C5AB0DC85B11"); + key = shasum.digest('base64'); + + var headers = [ + 'HTTP/1.1 101 Switching Protocols' + , 'Upgrade: websocket' + , 'Connection: Upgrade' + , 'Sec-WebSocket-Accept: ' + key + ]; + + if (typeof protocol != 'undefined') { + headers.push('Sec-WebSocket-Protocol: ' + protocol); + } + + var extensions = {}; + try { + extensions = acceptExtensions.call(self, extensionsOffer); + } catch (err) { + abortConnection(socket, 400, 'Bad Request'); + return; + } + + if (Object.keys(extensions).length) { + var serverExtensions = {}; + Object.keys(extensions).forEach(function(token) { + serverExtensions[token] = [extensions[token].params] + }); + headers.push('Sec-WebSocket-Extensions: ' + Extensions.format(serverExtensions)); + } + + // allows external modification/inspection of handshake headers + self.emit('headers', headers); + + socket.setTimeout(0); + socket.setNoDelay(true); + try { + socket.write(headers.concat('', '').join('\r\n')); + } + catch (e) { + // if the upgrade write fails, shut the connection down hard + try { socket.destroy(); } catch (e) {} + return; + } + + var client = new WebSocket([req, socket, upgradeHead], { + protocolVersion: version, + protocol: protocol, + extensions: extensions, + maxPayload: self.options.maxPayload + }); + + if (self.options.clientTracking) { + self.clients.push(client); + client.on('close', function() { + var index = self.clients.indexOf(client); + if (index != -1) { + self.clients.splice(index, 1); + } + }); + } + + // signal upgrade complete + socket.removeListener('error', errorHandler); + cb(client); + } + + // optionally call external protocol selection handler before + // calling completeHybiUpgrade2 + var completeHybiUpgrade1 = function() { + // choose from the sub-protocols + if (typeof self.options.handleProtocols == 'function') { + var protList = (protocols || "").split(/, */); + var callbackCalled = false; + var res = self.options.handleProtocols(protList, function(result, protocol) { + callbackCalled = true; + if (!result) abortConnection(socket, 401, 'Unauthorized'); + else completeHybiUpgrade2(protocol); + }); + if (!callbackCalled) { + // the handleProtocols handler never called our callback + abortConnection(socket, 501, 'Could not process protocols'); + } + return; + } else { + if (typeof protocols !== 'undefined') { + completeHybiUpgrade2(protocols.split(/, */)[0]); + } + else { + completeHybiUpgrade2(); + } + } + } + + // optionally call external client verification handler + if (typeof this.options.verifyClient == 'function') { + var info = { + origin: origin, + secure: typeof req.connection.authorized !== 'undefined' || typeof req.connection.encrypted !== 'undefined', + req: req + }; + if (this.options.verifyClient.length == 2) { + this.options.verifyClient(info, function(result, code, name) { + if (typeof code === 'undefined') code = 401; + if (typeof name === 'undefined') name = http.STATUS_CODES[code]; + + if (!result) abortConnection(socket, code, name); + else completeHybiUpgrade1(); + }); + return; + } + else if (!this.options.verifyClient(info)) { + abortConnection(socket, 401, 'Unauthorized'); + return; + } + } + + completeHybiUpgrade1(); +} + +function handleHixieUpgrade(req, socket, upgradeHead, cb) { + // handle premature socket errors + var errorHandler = function() { + try { socket.destroy(); } catch (e) {} + } + socket.on('error', errorHandler); + + // bail if options prevent hixie + if (this.options.disableHixie) { + abortConnection(socket, 401, 'Hixie support disabled'); + return; + } + + // verify key presence + if (!req.headers['sec-websocket-key2']) { + abortConnection(socket, 400, 'Bad Request'); + return; + } + + var origin = req.headers['origin'] + , self = this; + + // setup handshake completion to run after client has been verified + var onClientVerified = function() { + var wshost; + if (!req.headers['x-forwarded-host']) + wshost = req.headers.host; + else + wshost = req.headers['x-forwarded-host']; + var location = ((req.headers['x-forwarded-proto'] === 'https' || socket.encrypted) ? 'wss' : 'ws') + '://' + wshost + req.url + , protocol = req.headers['sec-websocket-protocol']; + + // build the response header and return a Buffer + var buildResponseHeader = function() { + var headers = [ + 'HTTP/1.1 101 Switching Protocols' + , 'Upgrade: WebSocket' + , 'Connection: Upgrade' + , 'Sec-WebSocket-Location: ' + location + ]; + if (typeof protocol != 'undefined') headers.push('Sec-WebSocket-Protocol: ' + protocol); + if (typeof origin != 'undefined') headers.push('Sec-WebSocket-Origin: ' + origin); + + return new Buffer(headers.concat('', '').join('\r\n')); + }; + + // send handshake response before receiving the nonce + var handshakeResponse = function() { + + socket.setTimeout(0); + socket.setNoDelay(true); + + var headerBuffer = buildResponseHeader(); + + try { + socket.write(headerBuffer, 'binary', function(err) { + // remove listener if there was an error + if (err) socket.removeListener('data', handler); + return; + }); + } catch (e) { + try { socket.destroy(); } catch (e) {} + return; + }; + }; + + // handshake completion code to run once nonce has been successfully retrieved + var completeHandshake = function(nonce, rest, headerBuffer) { + // calculate key + var k1 = req.headers['sec-websocket-key1'] + , k2 = req.headers['sec-websocket-key2'] + , md5 = crypto.createHash('md5'); + + [k1, k2].forEach(function (k) { + var n = parseInt(k.replace(/[^\d]/g, '')) + , spaces = k.replace(/[^ ]/g, '').length; + if (spaces === 0 || n % spaces !== 0){ + abortConnection(socket, 400, 'Bad Request'); + return; + } + n /= spaces; + md5.update(String.fromCharCode( + n >> 24 & 0xFF, + n >> 16 & 0xFF, + n >> 8 & 0xFF, + n & 0xFF)); + }); + md5.update(nonce.toString('binary')); + + socket.setTimeout(0); + socket.setNoDelay(true); + + try { + var hashBuffer = new Buffer(md5.digest('binary'), 'binary'); + var handshakeBuffer = new Buffer(headerBuffer.length + hashBuffer.length); + headerBuffer.copy(handshakeBuffer, 0); + hashBuffer.copy(handshakeBuffer, headerBuffer.length); + + // do a single write, which - upon success - causes a new client websocket to be setup + socket.write(handshakeBuffer, 'binary', function(err) { + if (err) return; // do not create client if an error happens + var client = new WebSocket([req, socket, rest], { + protocolVersion: 'hixie-76', + protocol: protocol + }); + if (self.options.clientTracking) { + self.clients.push(client); + client.on('close', function() { + var index = self.clients.indexOf(client); + if (index != -1) { + self.clients.splice(index, 1); + } + }); + } + + // signal upgrade complete + socket.removeListener('error', errorHandler); + cb(client); + }); + } + catch (e) { + try { socket.destroy(); } catch (e) {} + return; + } + } + + // retrieve nonce + var nonceLength = 8; + if (upgradeHead && upgradeHead.length >= nonceLength) { + var nonce = upgradeHead.slice(0, nonceLength); + var rest = upgradeHead.length > nonceLength ? upgradeHead.slice(nonceLength) : null; + completeHandshake.call(self, nonce, rest, buildResponseHeader()); + } + else { + // nonce not present in upgradeHead + var nonce = new Buffer(nonceLength); + upgradeHead.copy(nonce, 0); + var received = upgradeHead.length; + var rest = null; + var handler = function (data) { + var toRead = Math.min(data.length, nonceLength - received); + if (toRead === 0) return; + data.copy(nonce, received, 0, toRead); + received += toRead; + if (received == nonceLength) { + socket.removeListener('data', handler); + if (toRead < data.length) rest = data.slice(toRead); + + // complete the handshake but send empty buffer for headers since they have already been sent + completeHandshake.call(self, nonce, rest, new Buffer(0)); + } + } + + // handle additional data as we receive it + socket.on('data', handler); + + // send header response before we have the nonce to fix haproxy buffering + handshakeResponse(); + } + } + + // verify client + if (typeof this.options.verifyClient == 'function') { + var info = { + origin: origin, + secure: typeof req.connection.authorized !== 'undefined' || typeof req.connection.encrypted !== 'undefined', + req: req + }; + if (this.options.verifyClient.length == 2) { + var self = this; + this.options.verifyClient(info, function(result, code, name) { + if (typeof code === 'undefined') code = 401; + if (typeof name === 'undefined') name = http.STATUS_CODES[code]; + + if (!result) abortConnection(socket, code, name); + else onClientVerified.apply(self); + }); + return; + } + else if (!this.options.verifyClient(info)) { + abortConnection(socket, 401, 'Unauthorized'); + return; + } + } + + // no client verification required + onClientVerified(); +} + +function acceptExtensions(offer) { + var extensions = {}; + var options = this.options.perMessageDeflate; + var maxPayload = this.options.maxPayload; + if (options && offer[PerMessageDeflate.extensionName]) { + var perMessageDeflate = new PerMessageDeflate(options !== true ? options : {}, true, maxPayload); + perMessageDeflate.accept(offer[PerMessageDeflate.extensionName]); + extensions[PerMessageDeflate.extensionName] = perMessageDeflate; + } + return extensions; +} + +function abortConnection(socket, code, name) { + try { + var response = [ + 'HTTP/1.1 ' + code + ' ' + name, + 'Content-type: text/html' + ]; + socket.write(response.concat('', '').join('\r\n')); + } + catch (e) { /* ignore errors - we've aborted this connection */ } + finally { + // ensure that an early aborted connection is shut down completely + try { socket.destroy(); } catch (e) {} + } +} diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/ws/node_modules/options/.npmignore b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/node_modules/options/.npmignore new file mode 100644 index 0000000..1b18fb3 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/node_modules/options/.npmignore @@ -0,0 +1,7 @@ +npm-debug.log +node_modules +.*.swp +.lock-* +build/ + +test diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/ws/node_modules/options/Makefile b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/node_modules/options/Makefile new file mode 100644 index 0000000..7496b6f --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/node_modules/options/Makefile @@ -0,0 +1,12 @@ +ALL_TESTS = $(shell find test/ -name '*.test.js') + +run-tests: + @./node_modules/.bin/mocha \ + -t 2000 \ + $(TESTFLAGS) \ + $(TESTS) + +test: + @$(MAKE) NODE_PATH=lib TESTS="$(ALL_TESTS)" run-tests + +.PHONY: test diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/ws/node_modules/options/README.md b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/node_modules/options/README.md new file mode 100644 index 0000000..0dabc75 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/node_modules/options/README.md @@ -0,0 +1,69 @@ +# options.js # + +A very light-weight in-code option parsers for node.js. + +## Usage ## + +``` js +var Options = require("options"); + +// Create an Options object +function foo(options) { + var default_options = { + foo : "bar" + }; + + // Create an option object with default value + var opts = new Options(default_options); + + // Merge options + opts = opts.merge(options); + + // Reset to default value + opts.reset(); + + // Copy selected attributes out + var seled_att = opts.copy("foo"); + + // Read json options from a file. + opts.read("options.file"); // Sync + opts.read("options.file", function(err){ // Async + if(err){ // If error occurs + console.log("File error."); + }else{ + // No error + } + }); + + // Attributes defined or not + opts.isDefinedAndNonNull("foobar"); + opts.isDefined("foobar"); +} + +``` + + +## License ## + +(The MIT License) + +Copyright (c) 2012 Einar Otto Stangvik <einaros@gmail.com> + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/ws/node_modules/options/lib/options.js b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/node_modules/options/lib/options.js new file mode 100644 index 0000000..4fc45e9 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/node_modules/options/lib/options.js @@ -0,0 +1,86 @@ +/*! + * Copyright(c) 2011 Einar Otto Stangvik + * MIT Licensed + */ + +var fs = require('fs'); + +function Options(defaults) { + var internalValues = {}; + var values = this.value = {}; + Object.keys(defaults).forEach(function(key) { + internalValues[key] = defaults[key]; + Object.defineProperty(values, key, { + get: function() { return internalValues[key]; }, + configurable: false, + enumerable: true + }); + }); + this.reset = function() { + Object.keys(defaults).forEach(function(key) { + internalValues[key] = defaults[key]; + }); + return this; + }; + this.merge = function(options, required) { + options = options || {}; + if (Object.prototype.toString.call(required) === '[object Array]') { + var missing = []; + for (var i = 0, l = required.length; i < l; ++i) { + var key = required[i]; + if (!(key in options)) { + missing.push(key); + } + } + if (missing.length > 0) { + if (missing.length > 1) { + throw new Error('options ' + + missing.slice(0, missing.length - 1).join(', ') + ' and ' + + missing[missing.length - 1] + ' must be defined'); + } + else throw new Error('option ' + missing[0] + ' must be defined'); + } + } + Object.keys(options).forEach(function(key) { + if (key in internalValues) { + internalValues[key] = options[key]; + } + }); + return this; + }; + this.copy = function(keys) { + var obj = {}; + Object.keys(defaults).forEach(function(key) { + if (keys.indexOf(key) !== -1) { + obj[key] = values[key]; + } + }); + return obj; + }; + this.read = function(filename, cb) { + if (typeof cb == 'function') { + var self = this; + fs.readFile(filename, function(error, data) { + if (error) return cb(error); + var conf = JSON.parse(data); + self.merge(conf); + cb(); + }); + } + else { + var conf = JSON.parse(fs.readFileSync(filename)); + this.merge(conf); + } + return this; + }; + this.isDefined = function(key) { + return typeof values[key] != 'undefined'; + }; + this.isDefinedAndNonNull = function(key) { + return typeof values[key] != 'undefined' && values[key] !== null; + }; + Object.freeze(values); + Object.freeze(this); +} + +module.exports = Options; diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/ws/node_modules/options/package.json b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/node_modules/options/package.json new file mode 100644 index 0000000..f19afdc --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/node_modules/options/package.json @@ -0,0 +1,51 @@ +{ + "author": { + "name": "Einar Otto Stangvik", + "email": "einaros@gmail.com", + "url": "http://2x.io" + }, + "name": "options", + "description": "A very light-weight in-code option parsers for node.js.", + "version": "0.0.6", + "repository": { + "type": "git", + "url": "git://github.com/einaros/options.js.git" + }, + "main": "lib/options", + "scripts": { + "test": "make test" + }, + "engines": { + "node": ">=0.4.0" + }, + "dependencies": {}, + "devDependencies": { + "mocha": "latest" + }, + "gitHead": "ff53d0a092c897cb95964232a96fe17da65c11af", + "bugs": { + "url": "https://github.com/einaros/options.js/issues" + }, + "homepage": "https://github.com/einaros/options.js", + "_id": "options@0.0.6", + "_shasum": "ec22d312806bb53e731773e7cdaefcf1c643128f", + "_from": "options@>=0.0.5", + "_npmVersion": "1.4.21", + "_npmUser": { + "name": "einaros", + "email": "einaros@gmail.com" + }, + "maintainers": [ + { + "name": "einaros", + "email": "einaros@gmail.com" + } + ], + "dist": { + "shasum": "ec22d312806bb53e731773e7cdaefcf1c643128f", + "tarball": "https://registry.npmjs.org/options/-/options-0.0.6.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/options/-/options-0.0.6.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/ws/node_modules/ultron/.npmignore b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/node_modules/ultron/.npmignore new file mode 100644 index 0000000..66210a2 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/node_modules/ultron/.npmignore @@ -0,0 +1,3 @@ +node_modules +coverage +.tern-port diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/ws/node_modules/ultron/.travis.yml b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/node_modules/ultron/.travis.yml new file mode 100644 index 0000000..a505004 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/node_modules/ultron/.travis.yml @@ -0,0 +1,21 @@ +sudo: false +language: node_js +node_js: + - "0.12" + - "0.10" + - "0.8" + - "iojs" +before_install: + - 'if [ "${TRAVIS_NODE_VERSION}" == "0.8" ]; then npm install -g npm@2.11.1; fi' +script: + - "npm run test-travis" +after_script: + - "npm install coveralls@2.11.x && cat coverage/lcov.info | coveralls" +matrix: + fast_finish: true +notifications: + irc: + channels: + - "irc.freenode.org#unshift" + on_success: change + on_failure: change diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/ws/node_modules/ultron/LICENSE b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/node_modules/ultron/LICENSE new file mode 100644 index 0000000..6dc9316 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/node_modules/ultron/LICENSE @@ -0,0 +1,22 @@ +The MIT License (MIT) + +Copyright (c) 2015 Unshift.io, Arnout Kazemier, the Contributors. + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. + diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/ws/node_modules/ultron/README.md b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/node_modules/ultron/README.md new file mode 100644 index 0000000..84fa3f2 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/node_modules/ultron/README.md @@ -0,0 +1,97 @@ +# Ultron + +[![Made by unshift](https://img.shields.io/badge/made%20by-unshift-00ffcc.svg?style=flat-square)](http://unshift.io)[![Version npm](http://img.shields.io/npm/v/ultron.svg?style=flat-square)](http://browsenpm.org/package/ultron)[![Build Status](http://img.shields.io/travis/unshiftio/ultron/master.svg?style=flat-square)](https://travis-ci.org/unshiftio/ultron)[![Dependencies](https://img.shields.io/david/unshiftio/ultron.svg?style=flat-square)](https://david-dm.org/unshiftio/ultron)[![Coverage Status](http://img.shields.io/coveralls/unshiftio/ultron/master.svg?style=flat-square)](https://coveralls.io/r/unshiftio/ultron?branch=master)[![IRC channel](http://img.shields.io/badge/IRC-irc.freenode.net%23unshift-00a8ff.svg?style=flat-square)](http://webchat.freenode.net/?channels=unshift) + +Ultron is a high-intelligence robot. It gathers intelligence so it can start +improving upon his rudimentary design. It will learn your event emitting +patterns and find ways to exterminate them. Allowing you to remove only the +event emitters that **you** assigned and not the ones that your users or +developers assigned. This can prevent race conditions, memory leaks and even file +descriptor leaks from ever happening as you won't remove clean up processes. + +## Installation + +The module is designed to be used in browsers using browserify and in Node.js. +You can install the module through the public npm registry by running the +following command in CLI: + +``` +npm install --save ultron +``` + +## Usage + +In all examples we assume that you've required the library as following: + +```js +'use strict'; + +var Ultron = require('ultron'); +``` + +Now that we've required the library we can construct our first `Ultron` instance. +The constructor requires one argument which should be the `EventEmitter` +instance that we need to operate upon. This can be the `EventEmitter` module +that ships with Node.js or `EventEmitter3` or anything else as long as it +follow the same API and internal structure as these 2. So with that in mind we +can create the instance: + +```js +// +// For the sake of this example we're going to construct an empty EventEmitter +// +var EventEmitter = require('events').EventEmitter; // or require('eventmitter3'); +var events = new EventEmitter(); + +var ultron = new Ultron(events); +``` + +You can now use the following API's from the Ultron instance: + +### Ultron.on + +Register a new event listener for the given event. It follows the exact same API +as `EventEmitter.on` but it will return itself instead of returning the +EventEmitter instance. If you are using EventEmitter3 it also supports the +context param: + +```js +ultron.on('event-name', handler, { custom: 'function context' }); +``` + +### Ultron.once + +Exactly the same as the [Ultron.on](#ultronon) but it only allows the execution +once. + +### Ultron.remove + +This is where all the magic happens and the safe removal starts. This function +accepts different argument styles: + +- No arguments, assume that all events need to be removed so it will work as + `removeAllListeners()` API. +- 1 argument, when it's a string it will be split on ` ` and `,` to create a + list of events that need to be cleared. +- Multiple arguments, we assume that they are all names of events that need to + be cleared. + +```js +ultron.remove('foo, bar baz'); // Removes foo, bar and baz. +ultron.remove('foo', 'bar', 'baz'); // Removes foo, bar and baz. +ultron.remove(); // Removes everything. +``` + +If you just want to remove a single event listener using a function reference +you can still use the EventEmitter's `removeListener(event, fn)` API: + +```js +function foo() {} + +ulton.on('foo', foo); +events.removeListener('foo', foo); +``` + +## License + +MIT diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/ws/node_modules/ultron/index.js b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/node_modules/ultron/index.js new file mode 100644 index 0000000..af17ab7 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/node_modules/ultron/index.js @@ -0,0 +1,129 @@ +'use strict'; + +var has = Object.prototype.hasOwnProperty; + +/** + * An auto incrementing id which we can use to create "unique" Ultron instances + * so we can track the event emitters that are added through the Ultron + * interface. + * + * @type {Number} + * @private + */ +var id = 0; + +/** + * Ultron is high-intelligence robot. It gathers intelligence so it can start improving + * upon his rudimentary design. It will learn from your EventEmitting patterns + * and exterminate them. + * + * @constructor + * @param {EventEmitter} ee EventEmitter instance we need to wrap. + * @api public + */ +function Ultron(ee) { + if (!(this instanceof Ultron)) return new Ultron(ee); + + this.id = id++; + this.ee = ee; +} + +/** + * Register a new EventListener for the given event. + * + * @param {String} event Name of the event. + * @param {Functon} fn Callback function. + * @param {Mixed} context The context of the function. + * @returns {Ultron} + * @api public + */ +Ultron.prototype.on = function on(event, fn, context) { + fn.__ultron = this.id; + this.ee.on(event, fn, context); + + return this; +}; +/** + * Add an EventListener that's only called once. + * + * @param {String} event Name of the event. + * @param {Function} fn Callback function. + * @param {Mixed} context The context of the function. + * @returns {Ultron} + * @api public + */ +Ultron.prototype.once = function once(event, fn, context) { + fn.__ultron = this.id; + this.ee.once(event, fn, context); + + return this; +}; + +/** + * Remove the listeners we assigned for the given event. + * + * @returns {Ultron} + * @api public + */ +Ultron.prototype.remove = function remove() { + var args = arguments + , event; + + // + // When no event names are provided we assume that we need to clear all the + // events that were assigned through us. + // + if (args.length === 1 && 'string' === typeof args[0]) { + args = args[0].split(/[, ]+/); + } else if (!args.length) { + args = []; + + for (event in this.ee._events) { + if (has.call(this.ee._events, event)) args.push(event); + } + } + + for (var i = 0; i < args.length; i++) { + var listeners = this.ee.listeners(args[i]); + + for (var j = 0; j < listeners.length; j++) { + event = listeners[j]; + + // + // Once listeners have a `listener` property that stores the real listener + // in the EventEmitter that ships with Node.js. + // + if (event.listener) { + if (event.listener.__ultron !== this.id) continue; + delete event.listener.__ultron; + } else { + if (event.__ultron !== this.id) continue; + delete event.__ultron; + } + + this.ee.removeListener(args[i], event); + } + } + + return this; +}; + +/** + * Destroy the Ultron instance, remove all listeners and release all references. + * + * @returns {Boolean} + * @api public + */ +Ultron.prototype.destroy = function destroy() { + if (!this.ee) return false; + + this.remove(); + this.ee = null; + + return true; +}; + +// +// Expose the module. +// +module.exports = Ultron; diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/ws/node_modules/ultron/package.json b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/node_modules/ultron/package.json new file mode 100644 index 0000000..a86450c --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/node_modules/ultron/package.json @@ -0,0 +1,74 @@ +{ + "name": "ultron", + "version": "1.0.2", + "description": "Ultron is high-intelligence robot. It gathers intel so it can start improving upon his rudimentary design", + "main": "index.js", + "scripts": { + "100%": "istanbul check-coverage --statements 100 --functions 100 --lines 100 --branches 100", + "test": "mocha test.js", + "watch": "mocha --watch test.js", + "coverage": "istanbul cover ./node_modules/.bin/_mocha -- test.js", + "test-travis": "istanbul cover node_modules/.bin/_mocha --report lcovonly -- test.js" + }, + "repository": { + "type": "git", + "url": "git+https://github.com/unshiftio/ultron.git" + }, + "keywords": [ + "Ultron", + "robot", + "gather", + "intelligence", + "event", + "events", + "eventemitter", + "emitter", + "cleanup" + ], + "author": { + "name": "Arnout Kazemier" + }, + "license": "MIT", + "devDependencies": { + "assume": "1.2.x", + "eventemitter3": "1.1.x", + "istanbul": "0.3.x", + "mocha": "2.2.x", + "pre-commit": "1.0.x" + }, + "bugs": { + "url": "https://github.com/unshiftio/ultron/issues" + }, + "homepage": "https://github.com/unshiftio/ultron", + "gitHead": "a10482ae98a09120821545456c90c6d60d540f7c", + "_id": "ultron@1.0.2", + "_shasum": "ace116ab557cd197386a4e88f4685378c8b2e4fa", + "_from": "ultron@>=1.0.0 <1.1.0", + "_npmVersion": "2.9.1", + "_nodeVersion": "0.12.3", + "_npmUser": { + "name": "3rdeden", + "email": "npm@3rd-Eden.com" + }, + "maintainers": [ + { + "name": "unshift", + "email": "npm@unshift.io" + }, + { + "name": "v1", + "email": "info@3rd-Eden.com" + }, + { + "name": "3rdeden", + "email": "npm@3rd-Eden.com" + } + ], + "dist": { + "shasum": "ace116ab557cd197386a4e88f4685378c8b2e4fa", + "tarball": "https://registry.npmjs.org/ultron/-/ultron-1.0.2.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/ultron/-/ultron-1.0.2.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/ws/node_modules/ultron/test.js b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/node_modules/ultron/test.js new file mode 100644 index 0000000..1fd4f1b --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/node_modules/ultron/test.js @@ -0,0 +1,327 @@ +/* istanbul ignore next */ +describe('Ultron', function () { + 'use strict'; + + var EventEmitter = require('eventemitter3') + , EE = require('events').EventEmitter + , assume = require('assume') + , Ultron = require('./') + , ultron + , ee; + + beforeEach(function () { + ee = new EventEmitter(); + ultron = new Ultron(ee); + }); + + afterEach(function () { + ultron.destroy(); + ee.removeAllListeners(); + }); + + it('is exposed as a function', function () { + assume(Ultron).is.a('function'); + }); + + it('can be initialized without the new keyword', function () { + assume(Ultron(ee)).is.instanceOf(Ultron); + }); + + it('assigns a unique id to every instance', function () { + for (var i = 0; i < 100; i++) { + assume(ultron.id).does.not.equal((new Ultron()).id); + } + }); + + it('allows removal through the event emitter', function () { + function foo() {} + function bar() {} + + ultron.on('foo', foo); + ultron.once('foo', bar); + + assume(foo.__ultron).equals(ultron.id); + assume(bar.__ultron).equals(ultron.id); + assume(ee.listeners('foo').length).equals(2); + + ee.removeListener('foo', foo); + assume(ee.listeners('foo').length).equals(1); + + ee.removeListener('foo', bar); + assume(ee.listeners('foo').length).equals(0); + }); + + describe('#on', function () { + it('assigns a listener', function () { + assume(ee.listeners('foo').length).equals(0); + + function foo() {} + + ultron.on('foo', foo); + assume(ee.listeners('foo').length).equals(1); + assume(ee.listeners('foo')[0]).equals(foo); + }); + + it('tags the assigned function', function () { + assume(ee.listeners('foo').length).equals(0); + + ultron.on('foo', function () {}); + assume(ee.listeners('foo')[0].__ultron).equals(ultron.id); + }); + + it('also passes in the context', function (next) { + var context = 1313; + + ultron.on('foo', function (a, b, c) { + assume(a).equals('a'); + assume(b).equals('b'); + assume(c).equals('c'); + + assume(this).equals(context); + + next(); + }, context); + + ee.emit('foo', 'a', 'b', 'c'); + }); + + it('works with regular eventemitters as well', function (next) { + var ee = new EE() + , ultron = new Ultron(ee); + + ultron.on('foo', function (a, b, c) { + assume(a).equals('a'); + assume(b).equals('b'); + assume(c).equals('c'); + + next(); + }); + + ee.emit('foo', 'a', 'b', 'c'); + }); + }); + + describe('#once', function () { + it('assigns a listener', function () { + assume(ee.listeners('foo').length).equals(0); + + function foo() {} + ultron.once('foo', foo); + assume(ee.listeners('foo').length).equals(1); + assume(ee.listeners('foo')[0]).equals(foo); + }); + + it('tags the assigned function', function () { + assume(ee.listeners('foo').length).equals(0); + + ultron.once('foo', function () {}); + assume(ee.listeners('foo')[0].__ultron).equals(ultron.id); + }); + + it('also passes in the context', function (next) { + var context = 1313; + + ultron.once('foo', function (a, b, c) { + assume(a).equals('a'); + assume(b).equals('b'); + assume(c).equals('c'); + + assume(this).equals(context); + + next(); + }, context); + + ee.emit('foo', 'a', 'b', 'c'); + ee.emit('foo', 'a', 'b', 'c'); // Ensure that we don't double execute + }); + + it('works with regular eventemitters as well', function (next) { + var ee = new EE() + , ultron = new Ultron(ee); + + ultron.once('foo', function (a, b, c) { + assume(a).equals('a'); + assume(b).equals('b'); + assume(c).equals('c'); + + next(); + }); + + ee.emit('foo', 'a', 'b', 'c'); + ee.emit('foo', 'a', 'b', 'c'); // Ensure that we don't double execute + }); + }); + + describe('#remove', function () { + it('removes only our assigned `on` listeners', function () { + function foo() {} + function bar() {} + + ee.on('foo', foo); + ultron.on('foo', bar); + assume(ee.listeners('foo').length).equals(2); + + ultron.remove('foo'); + assume(ee.listeners('foo').length).equals(1); + assume(ee.listeners('foo')[0]).equals(foo); + }); + + it('removes our private __ultron references', function () { + function once() {} + function on() {} + + assume('__ultron' in once).is.false(); + assume('__ultron' in on).is.false(); + + ultron.on('foo', on); + ultron.once('bar', once); + + assume('__ultron' in once).is.true(); + assume('__ultron' in on).is.true(); + + ultron.remove('foo, bar'); + + assume('__ultron' in once).is.false(); + assume('__ultron' in on).is.false(); + + ultron.destroy(); + + ee = new EE(); + ultron = new Ultron(ee); + + assume('__ultron' in once).is.false(); + assume('__ultron' in on).is.false(); + + ultron.on('foo', on); + ultron.once('bar', once); + + assume('__ultron' in once).is.true(); + assume('__ultron' in on).is.true(); + + ultron.remove('foo, bar'); + + assume('__ultron' in once).is.false(); + assume('__ultron' in on).is.false(); + }); + + it('removes only our assigned `once` listeners', function () { + function foo() {} + function bar() {} + + ee.once('foo', foo); + ultron.once('foo', bar); + assume(ee.listeners('foo').length).equals(2); + + ultron.remove('foo'); + assume(ee.listeners('foo').length).equals(1); + assume(ee.listeners('foo')[0]).equals(foo); + }); + + it('removes only our assigned `once` listeners from regular EE', function () { + var ee = new EE() + , ultron = new Ultron(ee); + + function foo() {} + function bar() {} + + ee.once('foo', foo); + ultron.once('foo', bar); + assume(ee.listeners('foo').length).equals(2); + + ultron.remove('foo'); + assume(ee.listeners('foo').length).equals(1); + assume(ee.listeners('foo')[0].listener).equals(foo); + }); + + it('removes all assigned events if called without args', function () { + function foo() {} + function bar() {} + + ultron.on('foo', foo); + ultron.on('bar', bar); + + assume(ee.listeners('foo').length).equals(1); + assume(ee.listeners('bar').length).equals(1); + + ultron.remove(); + + assume(ee.listeners('foo').length).equals(0); + assume(ee.listeners('bar').length).equals(0); + }); + + it('removes multiple listeners based on args', function () { + function foo() {} + function bar() {} + function baz() {} + + ultron.on('foo', foo); + ultron.on('bar', bar); + ultron.on('baz', baz); + + assume(ee.listeners('foo').length).equals(1); + assume(ee.listeners('bar').length).equals(1); + assume(ee.listeners('baz').length).equals(1); + + ultron.remove('foo', 'bar'); + + assume(ee.listeners('foo').length).equals(0); + assume(ee.listeners('bar').length).equals(0); + assume(ee.listeners('baz').length).equals(1); + }); + + it('removes multiple listeners if first arg is seperated string', function () { + function foo() {} + function bar() {} + function baz() {} + + ultron.on('foo', foo); + ultron.on('bar', bar); + ultron.on('baz', baz); + + assume(ee.listeners('foo').length).equals(1); + assume(ee.listeners('bar').length).equals(1); + assume(ee.listeners('baz').length).equals(1); + + ultron.remove('foo, bar'); + + assume(ee.listeners('foo').length).equals(0); + assume(ee.listeners('bar').length).equals(0); + assume(ee.listeners('baz').length).equals(1); + }); + }); + + describe('#destroy', function () { + it('removes all listeners', function () { + function foo() {} + function bar() {} + function baz() {} + + ultron.on('foo', foo); + ultron.on('bar', bar); + ultron.on('baz', baz); + + assume(ee.listeners('foo').length).equals(1); + assume(ee.listeners('bar').length).equals(1); + assume(ee.listeners('baz').length).equals(1); + + ultron.destroy(); + + assume(ee.listeners('foo').length).equals(0); + assume(ee.listeners('bar').length).equals(0); + assume(ee.listeners('baz').length).equals(0); + }); + + it('removes the .ee reference', function () { + assume(ultron.ee).equals(ee); + ultron.destroy(); + assume(ultron.ee).equals(null); + }); + + it('returns booleans for state indication', function () { + assume(ultron.destroy()).is.true(); + assume(ultron.destroy()).is.false(); + assume(ultron.destroy()).is.false(); + assume(ultron.destroy()).is.false(); + }); + }); +}); diff --git a/node_modules/socket.io/node_modules/engine.io/node_modules/ws/package.json b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/package.json new file mode 100644 index 0000000..28d395b --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/node_modules/ws/package.json @@ -0,0 +1,82 @@ +{ + "author": { + "name": "Einar Otto Stangvik", + "email": "einaros@gmail.com", + "url": "http://2x.io" + }, + "name": "ws", + "description": "simple to use, blazing fast and thoroughly tested websocket client, server and console for node.js, up-to-date against RFC-6455", + "version": "1.1.1", + "license": "MIT", + "main": "index.js", + "keywords": [ + "Hixie", + "HyBi", + "Push", + "RFC-6455", + "WebSocket", + "WebSockets", + "real-time" + ], + "repository": { + "type": "git", + "url": "git://github.com/websockets/ws.git" + }, + "scripts": { + "test": "make test" + }, + "dependencies": { + "options": ">=0.0.5", + "ultron": "1.0.x" + }, + "devDependencies": { + "ansi": "0.3.x", + "benchmark": "0.3.x", + "bufferutil": "1.2.x", + "expect.js": "0.3.x", + "istanbul": "^0.4.1", + "mocha": "2.3.x", + "should": "8.0.x", + "tinycolor": "0.0.x", + "utf-8-validate": "1.2.x" + }, + "gypfile": true, + "gitHead": "c7bb7306cb0e1d17df141f61a220056eaa5e3502", + "bugs": { + "url": "https://github.com/websockets/ws/issues" + }, + "homepage": "https://github.com/websockets/ws#readme", + "_id": "ws@1.1.1", + "_shasum": "082ddb6c641e85d4bb451f03d52f06eabdb1f018", + "_from": "ws@1.1.1", + "_npmVersion": "3.8.0", + "_nodeVersion": "4.3.1", + "_npmUser": { + "name": "3rdeden", + "email": "npm@3rd-Eden.com" + }, + "maintainers": [ + { + "name": "einaros", + "email": "einaros@gmail.com" + }, + { + "name": "v1", + "email": "info@3rd-Eden.com" + }, + { + "name": "3rdeden", + "email": "npm@3rd-Eden.com" + } + ], + "dist": { + "shasum": "082ddb6c641e85d4bb451f03d52f06eabdb1f018", + "tarball": "https://registry.npmjs.org/ws/-/ws-1.1.1.tgz" + }, + "_npmOperationalInternal": { + "host": "packages-16-east.internal.npmjs.com", + "tmp": "tmp/ws-1.1.1.tgz_1466770957650_0.7956828831229359" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/ws/-/ws-1.1.1.tgz" +} diff --git a/node_modules/socket.io/node_modules/engine.io/package.json b/node_modules/socket.io/node_modules/engine.io/package.json new file mode 100644 index 0000000..5a7c561 --- /dev/null +++ b/node_modules/socket.io/node_modules/engine.io/package.json @@ -0,0 +1,94 @@ +{ + "name": "engine.io", + "version": "1.7.2", + "description": "The realtime engine behind Socket.IO. Provides the foundation of a bidirectional connection between client and server", + "main": "./lib/engine.io", + "author": { + "name": "Guillermo Rauch", + "email": "guillermo@learnboost.com" + }, + "homepage": "https://github.com/socketio/engine.io", + "contributors": [ + { + "name": "Eugen Dueck", + "url": "https://github.com/EugenDueck" + }, + { + "name": "Afshin Mehrabani", + "url": "https://github.com/afshinm" + }, + { + "name": "Christoph Dorn", + "url": "https://github.com/cadorn" + }, + { + "name": "Mark Mokryn", + "email": "mokesmokes@gmail.com" + } + ], + "license": "MIT", + "dependencies": { + "accepts": "1.3.3", + "base64id": "0.1.0", + "debug": "2.2.0", + "engine.io-parser": "1.3.1", + "ws": "1.1.1" + }, + "devDependencies": { + "babel-preset-es2015": "6.3.13", + "engine.io-client": "1.7.2", + "expect.js": "0.2.0", + "gulp": "3.9.0", + "gulp-babel": "6.1.1", + "gulp-mocha": "2.2.0", + "gulp-nsp": "^2.4.1", + "mocha": "2.3.4", + "s": "0.1.1", + "superagent": "0.15.4", + "uws": "0.4.0" + }, + "scripts": { + "test": "gulp test; EIO_WS_ENGINE=uws gulp test;" + }, + "repository": { + "type": "git", + "url": "git+ssh://git@github.com/socketio/engine.io.git" + }, + "files": [ + "index.js", + "lib/" + ], + "gitHead": "0c983bd0853e4540c3d65ce66771060a8e3124bb", + "bugs": { + "url": "https://github.com/socketio/engine.io/issues" + }, + "_id": "engine.io@1.7.2", + "_shasum": "877c14fa0486f8b664d46a8101bf74feef2e4e46", + "_from": "engine.io@1.7.2", + "_npmVersion": "2.15.8", + "_nodeVersion": "4.4.7", + "_npmUser": { + "name": "darrachequesne", + "email": "damien.arrachequesne@gmail.com" + }, + "dist": { + "shasum": "877c14fa0486f8b664d46a8101bf74feef2e4e46", + "tarball": "https://registry.npmjs.org/engine.io/-/engine.io-1.7.2.tgz" + }, + "maintainers": [ + { + "name": "darrachequesne", + "email": "damien.arrachequesne@gmail.com" + }, + { + "name": "rauchg", + "email": "rauchg@gmail.com" + } + ], + "_npmOperationalInternal": { + "host": "packages-12-west.internal.npmjs.com", + "tmp": "tmp/engine.io-1.7.2.tgz_1477265689940_0.7890683426521719" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/engine.io/-/engine.io-1.7.2.tgz" +} diff --git a/node_modules/socket.io/node_modules/has-binary/.npmignore b/node_modules/socket.io/node_modules/has-binary/.npmignore new file mode 100644 index 0000000..a72b52e --- /dev/null +++ b/node_modules/socket.io/node_modules/has-binary/.npmignore @@ -0,0 +1,15 @@ +lib-cov +*.seed +*.log +*.csv +*.dat +*.out +*.pid +*.gz + +pids +logs +results + +npm-debug.log +node_modules diff --git a/node_modules/socket.io/node_modules/has-binary/History.md b/node_modules/socket.io/node_modules/has-binary/History.md new file mode 100644 index 0000000..9a5f2e8 --- /dev/null +++ b/node_modules/socket.io/node_modules/has-binary/History.md @@ -0,0 +1,19 @@ + +0.1.7 / 2015-11-18 +================== + + * fix toJSON [@jderuere] + * fix `global.isBuffer` usage [@tonetheman] + * fix tests on modern versions of node + * bump mocha + +0.1.6 / 2015-01-24 +================== + + * fix "undefined function" bug when iterating + an object created with Object.create(null) [gunta] + +0.1.5 / 2014-09-04 +================== + + * prevent browserify from bundling `Buffer` diff --git a/node_modules/socket.io/node_modules/has-binary/LICENSE b/node_modules/socket.io/node_modules/has-binary/LICENSE new file mode 100644 index 0000000..e6603cd --- /dev/null +++ b/node_modules/socket.io/node_modules/has-binary/LICENSE @@ -0,0 +1,20 @@ +The MIT License (MIT) + +Copyright (c) 2014 Kevin Roark + +Permission is hereby granted, free of charge, to any person obtaining a copy of +this software and associated documentation files (the "Software"), to deal in +the Software without restriction, including without limitation the rights to +use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of +the Software, and to permit persons to whom the Software is furnished to do so, +subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS +FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR +COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER +IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN +CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/socket.io/node_modules/has-binary/Makefile b/node_modules/socket.io/node_modules/has-binary/Makefile new file mode 100644 index 0000000..1d90629 --- /dev/null +++ b/node_modules/socket.io/node_modules/has-binary/Makefile @@ -0,0 +1,3 @@ + +test: + @./node_modules/.bin/mocha test.js diff --git a/node_modules/socket.io/node_modules/has-binary/README.md b/node_modules/socket.io/node_modules/has-binary/README.md new file mode 100644 index 0000000..76a0035 --- /dev/null +++ b/node_modules/socket.io/node_modules/has-binary/README.md @@ -0,0 +1,4 @@ +has-binarydata.js +================= + +Simple module to test if an object contains binary data diff --git a/node_modules/socket.io/node_modules/has-binary/index.js b/node_modules/socket.io/node_modules/has-binary/index.js new file mode 100644 index 0000000..434ccfa --- /dev/null +++ b/node_modules/socket.io/node_modules/has-binary/index.js @@ -0,0 +1,59 @@ + +/* + * Module requirements. + */ + +var isArray = require('isarray'); + +/** + * Module exports. + */ + +module.exports = hasBinary; + +/** + * Checks for binary data. + * + * Right now only Buffer and ArrayBuffer are supported.. + * + * @param {Object} anything + * @api public + */ + +function hasBinary(data) { + + function _hasBinary(obj) { + if (!obj) return false; + + if ( (global.Buffer && global.Buffer.isBuffer && global.Buffer.isBuffer(obj)) || + (global.ArrayBuffer && obj instanceof ArrayBuffer) || + (global.Blob && obj instanceof Blob) || + (global.File && obj instanceof File) + ) { + return true; + } + + if (isArray(obj)) { + for (var i = 0; i < obj.length; i++) { + if (_hasBinary(obj[i])) { + return true; + } + } + } else if (obj && 'object' == typeof obj) { + // see: https://github.com/Automattic/has-binary/pull/4 + if (obj.toJSON && 'function' == typeof obj.toJSON) { + obj = obj.toJSON(); + } + + for (var key in obj) { + if (Object.prototype.hasOwnProperty.call(obj, key) && _hasBinary(obj[key])) { + return true; + } + } + } + + return false; + } + + return _hasBinary(data); +} diff --git a/node_modules/socket.io/node_modules/has-binary/node_modules/isarray/README.md b/node_modules/socket.io/node_modules/has-binary/node_modules/isarray/README.md new file mode 100644 index 0000000..052a62b --- /dev/null +++ b/node_modules/socket.io/node_modules/has-binary/node_modules/isarray/README.md @@ -0,0 +1,54 @@ + +# isarray + +`Array#isArray` for older browsers. + +## Usage + +```js +var isArray = require('isarray'); + +console.log(isArray([])); // => true +console.log(isArray({})); // => false +``` + +## Installation + +With [npm](http://npmjs.org) do + +```bash +$ npm install isarray +``` + +Then bundle for the browser with +[browserify](https://github.com/substack/browserify). + +With [component](http://component.io) do + +```bash +$ component install juliangruber/isarray +``` + +## License + +(MIT) + +Copyright (c) 2013 Julian Gruber <julian@juliangruber.com> + +Permission is hereby granted, free of charge, to any person obtaining a copy of +this software and associated documentation files (the "Software"), to deal in +the Software without restriction, including without limitation the rights to +use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies +of the Software, and to permit persons to whom the Software is furnished to do +so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/node_modules/socket.io/node_modules/has-binary/node_modules/isarray/build/build.js b/node_modules/socket.io/node_modules/has-binary/node_modules/isarray/build/build.js new file mode 100644 index 0000000..ec58596 --- /dev/null +++ b/node_modules/socket.io/node_modules/has-binary/node_modules/isarray/build/build.js @@ -0,0 +1,209 @@ + +/** + * Require the given path. + * + * @param {String} path + * @return {Object} exports + * @api public + */ + +function require(path, parent, orig) { + var resolved = require.resolve(path); + + // lookup failed + if (null == resolved) { + orig = orig || path; + parent = parent || 'root'; + var err = new Error('Failed to require "' + orig + '" from "' + parent + '"'); + err.path = orig; + err.parent = parent; + err.require = true; + throw err; + } + + var module = require.modules[resolved]; + + // perform real require() + // by invoking the module's + // registered function + if (!module.exports) { + module.exports = {}; + module.client = module.component = true; + module.call(this, module.exports, require.relative(resolved), module); + } + + return module.exports; +} + +/** + * Registered modules. + */ + +require.modules = {}; + +/** + * Registered aliases. + */ + +require.aliases = {}; + +/** + * Resolve `path`. + * + * Lookup: + * + * - PATH/index.js + * - PATH.js + * - PATH + * + * @param {String} path + * @return {String} path or null + * @api private + */ + +require.resolve = function(path) { + if (path.charAt(0) === '/') path = path.slice(1); + var index = path + '/index.js'; + + var paths = [ + path, + path + '.js', + path + '.json', + path + '/index.js', + path + '/index.json' + ]; + + for (var i = 0; i < paths.length; i++) { + var path = paths[i]; + if (require.modules.hasOwnProperty(path)) return path; + } + + if (require.aliases.hasOwnProperty(index)) { + return require.aliases[index]; + } +}; + +/** + * Normalize `path` relative to the current path. + * + * @param {String} curr + * @param {String} path + * @return {String} + * @api private + */ + +require.normalize = function(curr, path) { + var segs = []; + + if ('.' != path.charAt(0)) return path; + + curr = curr.split('/'); + path = path.split('/'); + + for (var i = 0; i < path.length; ++i) { + if ('..' == path[i]) { + curr.pop(); + } else if ('.' != path[i] && '' != path[i]) { + segs.push(path[i]); + } + } + + return curr.concat(segs).join('/'); +}; + +/** + * Register module at `path` with callback `definition`. + * + * @param {String} path + * @param {Function} definition + * @api private + */ + +require.register = function(path, definition) { + require.modules[path] = definition; +}; + +/** + * Alias a module definition. + * + * @param {String} from + * @param {String} to + * @api private + */ + +require.alias = function(from, to) { + if (!require.modules.hasOwnProperty(from)) { + throw new Error('Failed to alias "' + from + '", it does not exist'); + } + require.aliases[to] = from; +}; + +/** + * Return a require function relative to the `parent` path. + * + * @param {String} parent + * @return {Function} + * @api private + */ + +require.relative = function(parent) { + var p = require.normalize(parent, '..'); + + /** + * lastIndexOf helper. + */ + + function lastIndexOf(arr, obj) { + var i = arr.length; + while (i--) { + if (arr[i] === obj) return i; + } + return -1; + } + + /** + * The relative require() itself. + */ + + function localRequire(path) { + var resolved = localRequire.resolve(path); + return require(resolved, parent, path); + } + + /** + * Resolve relative to the parent. + */ + + localRequire.resolve = function(path) { + var c = path.charAt(0); + if ('/' == c) return path.slice(1); + if ('.' == c) return require.normalize(p, path); + + // resolve deps by returning + // the dep in the nearest "deps" + // directory + var segs = parent.split('/'); + var i = lastIndexOf(segs, 'deps') + 1; + if (!i) i = 0; + path = segs.slice(0, i + 1).join('/') + '/deps/' + path; + return path; + }; + + /** + * Check if module is defined at `path`. + */ + + localRequire.exists = function(path) { + return require.modules.hasOwnProperty(localRequire.resolve(path)); + }; + + return localRequire; +}; +require.register("isarray/index.js", function(exports, require, module){ +module.exports = Array.isArray || function (arr) { + return Object.prototype.toString.call(arr) == '[object Array]'; +}; + +}); +require.alias("isarray/index.js", "isarray/index.js"); + diff --git a/node_modules/socket.io/node_modules/has-binary/node_modules/isarray/component.json b/node_modules/socket.io/node_modules/has-binary/node_modules/isarray/component.json new file mode 100644 index 0000000..9e31b68 --- /dev/null +++ b/node_modules/socket.io/node_modules/has-binary/node_modules/isarray/component.json @@ -0,0 +1,19 @@ +{ + "name" : "isarray", + "description" : "Array#isArray for older browsers", + "version" : "0.0.1", + "repository" : "juliangruber/isarray", + "homepage": "https://github.com/juliangruber/isarray", + "main" : "index.js", + "scripts" : [ + "index.js" + ], + "dependencies" : {}, + "keywords": ["browser","isarray","array"], + "author": { + "name": "Julian Gruber", + "email": "mail@juliangruber.com", + "url": "http://juliangruber.com" + }, + "license": "MIT" +} diff --git a/node_modules/socket.io/node_modules/has-binary/node_modules/isarray/index.js b/node_modules/socket.io/node_modules/has-binary/node_modules/isarray/index.js new file mode 100644 index 0000000..5f5ad45 --- /dev/null +++ b/node_modules/socket.io/node_modules/has-binary/node_modules/isarray/index.js @@ -0,0 +1,3 @@ +module.exports = Array.isArray || function (arr) { + return Object.prototype.toString.call(arr) == '[object Array]'; +}; diff --git a/node_modules/socket.io/node_modules/has-binary/node_modules/isarray/package.json b/node_modules/socket.io/node_modules/has-binary/node_modules/isarray/package.json new file mode 100644 index 0000000..a5886f3 --- /dev/null +++ b/node_modules/socket.io/node_modules/has-binary/node_modules/isarray/package.json @@ -0,0 +1,53 @@ +{ + "name": "isarray", + "description": "Array#isArray for older browsers", + "version": "0.0.1", + "repository": { + "type": "git", + "url": "git://github.com/juliangruber/isarray.git" + }, + "homepage": "https://github.com/juliangruber/isarray", + "main": "index.js", + "scripts": { + "test": "tap test/*.js" + }, + "dependencies": {}, + "devDependencies": { + "tap": "*" + }, + "keywords": [ + "browser", + "isarray", + "array" + ], + "author": { + "name": "Julian Gruber", + "email": "mail@juliangruber.com", + "url": "http://juliangruber.com" + }, + "license": "MIT", + "_id": "isarray@0.0.1", + "dist": { + "shasum": "8a18acfca9a8f4177e09abfc6038939b05d1eedf", + "tarball": "https://registry.npmjs.org/isarray/-/isarray-0.0.1.tgz" + }, + "_from": "isarray@0.0.1", + "_npmVersion": "1.2.18", + "_npmUser": { + "name": "juliangruber", + "email": "julian@juliangruber.com" + }, + "maintainers": [ + { + "name": "juliangruber", + "email": "julian@juliangruber.com" + } + ], + "directories": {}, + "_shasum": "8a18acfca9a8f4177e09abfc6038939b05d1eedf", + "_resolved": "http://registry.npmjs.org/isarray/-/isarray-0.0.1.tgz", + "bugs": { + "url": "https://github.com/juliangruber/isarray/issues" + }, + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/socket.io/node_modules/has-binary/package.json b/node_modules/socket.io/node_modules/has-binary/package.json new file mode 100644 index 0000000..0e2ece0 --- /dev/null +++ b/node_modules/socket.io/node_modules/has-binary/package.json @@ -0,0 +1,40 @@ +{ + "name": "has-binary", + "version": "0.1.7", + "description": "A function that takes anything in javascript and returns true if its argument contains binary data.", + "dependencies": { + "isarray": "0.0.1" + }, + "devDependencies": { + "better-assert": "1.0.0", + "mocha": "2.3.4" + }, + "author": { + "name": "Kevin Roark" + }, + "license": "MIT", + "gitHead": "73875a20978a219f726f7d313ccd1de19335f5a1", + "_id": "has-binary@0.1.7", + "scripts": {}, + "_shasum": "68e61eb16210c9545a0a5cce06a873912fe1e68c", + "_from": "has-binary@0.1.7", + "_npmVersion": "2.14.7", + "_nodeVersion": "4.2.2", + "_npmUser": { + "name": "rauchg", + "email": "rauchg@gmail.com" + }, + "maintainers": [ + { + "name": "rauchg", + "email": "rauchg@gmail.com" + } + ], + "dist": { + "shasum": "68e61eb16210c9545a0a5cce06a873912fe1e68c", + "tarball": "https://registry.npmjs.org/has-binary/-/has-binary-0.1.7.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/has-binary/-/has-binary-0.1.7.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/socket.io/node_modules/has-binary/test.js b/node_modules/socket.io/node_modules/has-binary/test.js new file mode 100644 index 0000000..c6bd5aa --- /dev/null +++ b/node_modules/socket.io/node_modules/has-binary/test.js @@ -0,0 +1,73 @@ + +var hasBinary = require('./'); +var assert = require('better-assert'); +var fs = require('fs'); + +describe('has-binarydata', function(){ + + it('should work with buffer', function(){ + assert(hasBinary(fs.readFileSync('./test.js'))); + }); + + it('should work with an array that does not contain binary', function() { + var arr = [1, 'cool', 2]; + assert(!hasBinary(arr)); + }); + + it('should work with an array that contains a buffer', function() { + var arr = [1, new Buffer('asdfasdf', 'utf8'), 2]; + assert(hasBinary(arr)); + }); + + it('should work with an object that does not contain binary', function() { + var ob = {a: 'a', b: [], c: 1234, toJSON: '{\"a\": \"a\"}'}; + assert(!hasBinary(ob)); + }); + + it('should work with an object that contains a buffer', function() { + var ob = {a: 'a', b: new Buffer('abc'), c: 1234, toJSON: '{\"a\": \"a\"}'}; + assert(hasBinary(ob)); + }); + + it('should work with null', function() { + assert(!hasBinary(null)); + }); + + it('should work with undefined', function() { + assert(!hasBinary(undefined)); + }); + + it('should work with a complex object that contains undefined and no binary', function() { + var ob = { + x: ['a', 'b', 123], + y: undefined, + z: {a: 'x', b: 'y', c: 3, d: null}, + w: [] + }; + assert(!hasBinary(ob)); + }); + + it('should work with a complex object that contains undefined and binary', function() { + var ob = { + x: ['a', 'b', 123], + y: undefined, + z: {a: 'x', b: 'y', c: 3, d: null}, + w: [], + bin: new Buffer('xxx') + }; + assert(hasBinary(ob)); + }); + + if (global.ArrayBuffer) { + it('should work with an ArrayBuffer', function() { + assert(hasBinary(new ArrayBuffer())); + }); + } + + if (global.Blob) { + it('should work with a Blob', function() { + assert(hasBinary(new Blob())); + }); + } + +}); diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/.npmignore b/node_modules/socket.io/node_modules/socket.io-adapter/.npmignore new file mode 100644 index 0000000..3c3629e --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/.npmignore @@ -0,0 +1 @@ +node_modules diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/History.md b/node_modules/socket.io/node_modules/socket.io-adapter/History.md new file mode 100644 index 0000000..02abe95 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/History.md @@ -0,0 +1,33 @@ + +0.4.0 / 2015-12-03 +================== + + * package: bump `debug` + * use a `Room` class to efficiently track room size + * allow `clients(fn)` + * call the callback on `delAll` + +0.3.1 / 2014-10-27 +================== + + * bump parser version + * fix room autopruning + * add autoprunning of empty rooms + * rooms are now created as objects + * added the repository field. + * updated the debug dependency. + +0.3.0 / 2014-05-30 +================== + + * bump `socket.io-parser` for binary ack fix + +0.2.0 / 2014-03-14 +================== + + * upgraded faster parser + +0.1.0 / 2014-03-07 +================== + + * initial commit diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/LICENSE b/node_modules/socket.io/node_modules/socket.io-adapter/LICENSE new file mode 100644 index 0000000..7e43606 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/LICENSE @@ -0,0 +1,20 @@ +(The MIT License) + +Copyright (c) 2014 Guillermo Rauch + +Permission is hereby granted, free of charge, to any person obtaining a copy of +this software and associated documentation files (the 'Software'), to deal in +the Software without restriction, including without limitation the rights to +use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of +the Software, and to permit persons to whom the Software is furnished to do so, +subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS +FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR +COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER +IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN +CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/Readme.md b/node_modules/socket.io/node_modules/socket.io-adapter/Readme.md new file mode 100644 index 0000000..bcef653 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/Readme.md @@ -0,0 +1,16 @@ + +# socket.io-adapter + +Default socket.io in-memory adapter class. + +## How to use + +This module is not intended for end-user usage, but can be used as an +interface to inheirt from from other adapters you might want to build. + +As an example of an adapter that builds on top of this, please take a look +at [socket.io-redis](https://github.com/learnboost/socket.io-redis). + +## License + +MIT diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/index.js b/node_modules/socket.io/node_modules/socket.io-adapter/index.js new file mode 100644 index 0000000..d5e2201 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/index.js @@ -0,0 +1,236 @@ + +/** + * Module dependencies. + */ + +var Emitter = require('events').EventEmitter; +var parser = require('socket.io-parser'); + +/** + * Module exports. + */ + +module.exports = Adapter; + +/** + * Memory adapter constructor. + * + * @param {Namespace} nsp + * @api public + */ + +function Adapter(nsp){ + this.nsp = nsp; + this.rooms = {}; + this.sids = {}; + this.encoder = new parser.Encoder(); +} + +/** + * Inherits from `EventEmitter`. + */ + +Adapter.prototype.__proto__ = Emitter.prototype; + +/** + * Adds a socket to a room. + * + * @param {String} socket id + * @param {String} room name + * @param {Function} callback + * @api public + */ + +Adapter.prototype.add = function(id, room, fn){ + this.sids[id] = this.sids[id] || {}; + this.sids[id][room] = true; + this.rooms[room] = this.rooms[room] || Room(); + this.rooms[room].add(id); + if (fn) process.nextTick(fn.bind(null, null)); +}; + +/** + * Removes a socket from a room. + * + * @param {String} socket id + * @param {String} room name + * @param {Function} callback + * @api public + */ + +Adapter.prototype.del = function(id, room, fn){ + this.sids[id] = this.sids[id] || {}; + delete this.sids[id][room]; + if (this.rooms.hasOwnProperty(room)) { + this.rooms[room].del(id); + if (this.rooms[room].length === 0) delete this.rooms[room]; + } + + if (fn) process.nextTick(fn.bind(null, null)); +}; + +/** + * Removes a socket from all rooms it's joined. + * + * @param {String} socket id + * @param {Function} callback + * @api public + */ + +Adapter.prototype.delAll = function(id, fn){ + var rooms = this.sids[id]; + if (rooms) { + for (var room in rooms) { + if (this.rooms.hasOwnProperty(room)) { + this.rooms[room].del(id); + if (this.rooms[room].length === 0) delete this.rooms[room]; + } + } + } + delete this.sids[id]; + + if (fn) process.nextTick(fn.bind(null, null)); +}; + +/** + * Broadcasts a packet. + * + * Options: + * - `flags` {Object} flags for this packet + * - `except` {Array} sids that should be excluded + * - `rooms` {Array} list of rooms to broadcast to + * + * @param {Object} packet object + * @api public + */ + +Adapter.prototype.broadcast = function(packet, opts){ + var rooms = opts.rooms || []; + var except = opts.except || []; + var flags = opts.flags || {}; + var packetOpts = { + preEncoded: true, + volatile: flags.volatile, + compress: flags.compress + }; + var ids = {}; + var self = this; + var socket; + + packet.nsp = this.nsp.name; + this.encoder.encode(packet, function(encodedPackets) { + if (rooms.length) { + for (var i = 0; i < rooms.length; i++) { + var room = self.rooms[rooms[i]]; + if (!room) continue; + var sockets = room.sockets; + for (var id in sockets) { + if (sockets.hasOwnProperty(id)) { + if (ids[id] || ~except.indexOf(id)) continue; + socket = self.nsp.connected[id]; + if (socket) { + socket.packet(encodedPackets, packetOpts); + ids[id] = true; + } + } + } + } + } else { + for (var id in self.sids) { + if (self.sids.hasOwnProperty(id)) { + if (~except.indexOf(id)) continue; + socket = self.nsp.connected[id]; + if (socket) socket.packet(encodedPackets, packetOpts); + } + } + } + }); +}; + +/** + * Gets a list of clients by sid. + * + * @param {Array} explicit set of rooms to check. + * @api public + */ + +Adapter.prototype.clients = function(rooms, fn){ + if ('function' == typeof rooms){ + fn = rooms; + rooms = null; + } + + rooms = rooms || []; + + var ids = {}; + var self = this; + var sids = []; + var socket; + + if (rooms.length) { + for (var i = 0; i < rooms.length; i++) { + var room = self.rooms[rooms[i]]; + if (!room) continue; + var sockets = room.sockets; + for (var id in sockets) { + if (sockets.hasOwnProperty(id)) { + if (ids[id]) continue; + socket = self.nsp.connected[id]; + if (socket) { + sids.push(id); + ids[id] = true; + } + } + } + } + } else { + for (var id in self.sids) { + if (self.sids.hasOwnProperty(id)) { + socket = self.nsp.connected[id]; + if (socket) sids.push(id); + } + } + } + + if (fn) process.nextTick(fn.bind(null, null, sids)); +}; + +/** +* Room constructor. +* +* @api private +*/ + +function Room(){ + if (!(this instanceof Room)) return new Room(); + this.sockets = {}; + this.length = 0; +} + +/** + * Adds a socket to a room. + * + * @param {String} socket id + * @api private + */ + +Room.prototype.add = function(id){ + if (!this.sockets.hasOwnProperty(id)) { + this.sockets[id] = true; + this.length++; + } +}; + +/** + * Removes a socket from a room. + * + * @param {String} socket id + * @api private + */ + +Room.prototype.del = function(id){ + if (this.sockets.hasOwnProperty(id)) { + delete this.sockets[id]; + this.length--; + } +}; diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/.npmignore b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/.npmignore new file mode 100644 index 0000000..7fbb06f --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/.npmignore @@ -0,0 +1,5 @@ +node_modules +build +components + +test diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/.travis.yml b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/.travis.yml new file mode 100644 index 0000000..c1c830a --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/.travis.yml @@ -0,0 +1,11 @@ +language: node_js +node_js: + - 0.10 +notifications: + irc: irc.freenode.org##socket.io +git: + depth: 1 +env: + global: + - secure: 28HHk1J0H64KNjzmmlxG/Ro0EPuLnhO0rU+kZjjthDHj/FaugIsqjAVQ1Dl6heWV2/MlVzw6nDCyMNiGwiVk0ruZPQ0SYdAKLplrdMtzAihbU3xx+ULFQPLM3SoW0ZFCEpe8dWPGy4WdgW7aLByeel9TJb3vlhAu7p7AvrcO7Fs= + - secure: rKEG0Cfw0vkw8thk63RHYG7h8XWYcBlvZ0w1IWpr2dAfnnLMi1palSTrBrFQc77flk7rN00zGIe76FhKydV9r4WWYAUYKPqo4k+9/FkpzjZlNtL49QRoNwC9jmJ8OeUwGowA13gZPyl/5P13wVaKCB0YrKnzz5LHo3Sp7So6J8U= diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/.zuul.yml b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/.zuul.yml new file mode 100644 index 0000000..38bc342 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/.zuul.yml @@ -0,0 +1,16 @@ +ui: mocha-bdd +browsers: + - name: chrome + version: 29..latest + - name: firefox + version: latest + - name: safari + version: latest + - name: ie + version: 10 + platform: Windows 2012 + - name: ie + version: 9 + version: [6..9, latest] + - name: iphone + version: oldest..latest diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/History.md b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/History.md new file mode 100644 index 0000000..3563380 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/History.md @@ -0,0 +1,87 @@ + +2.2.2 / 2014-09-04 +================== + + * prevent direct `Buffer` reference that breaks browserify + * binary: reuse `isBuf` helper + +2.2.1 / 2014-06-20 +================== + + * added benchmarking [kevin-roark] + * upgrade component-emitter to 1.1.2 [kevin-roark] + * update protocol version [kevin-roark] + * less indentation and a small optimization [kevin-roark] + +2.2.0 / 2014-05-30 +================== + + * added a BINARY_ACK type [kevin-roark] + +2.1.5 / 2014-05-24 +================== + + * don't iterate keys of `Date` objects [Rase-] + +2.1.4 / 2014-05-17 +================== + + * fix null reconstruction bug [kevin-roark] + +2.1.3 / 2014-04-27 +================== + + * bump zuul version + * updated protocol version + +2.1.2 / 2014-03-06 +================== + + * added support for binary in ACK packets + +2.1.1 / 2014-03-04 +================== + + * removed has-binary-data dependency + * fixed the object check in binary.removeBlobs + +2.1.0 / 2014-03-01 +================== + + * faster and smaller binary parser and protocol [kevin-roark] + +2.0.0 / 2014-02-19 +================== + + * binary support [kevin-roark] + +1.1.2 / 2014-02-11 +================== + + * package: bump `json3` to fix IE6-7 + +1.1.1 / 2014-02-10 +================== + + * package: bump debug to fix browserify issues + +1.1.0 / 2013-12-25 +================== + + * index: use `json3` + +1.0.3 / 2012-12-18 +================== + + * index: added instrumentation through `debug` + * index: make sure decoded `id` is a `Number` + +1.0.2 / 2012-12-18 +================== + + * index: allow for falsy values in `id` and `data` + +1.0.1 / 2012-12-10 +================== + + * Revision 1 diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/Makefile b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/Makefile new file mode 100644 index 0000000..ee0a3b2 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/Makefile @@ -0,0 +1,11 @@ + +REPORTER = dot + +test: + @./node_modules/.bin/mocha \ + --reporter $(REPORTER) \ + --bail \ + test/index.js + @./node_modules/.bin/zuul -- test/index.js + +.PHONY: test diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/Readme.md b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/Readme.md new file mode 100644 index 0000000..2fa0f82 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/Readme.md @@ -0,0 +1,73 @@ + +# socket.io-parser + +[![Build Status](https://secure.travis-ci.org/Automattic/socket.io-parser.svg)](http://travis-ci.org/Automattic/socket.io-parser) +[![NPM version](https://badge.fury.io/js/socket.io-parser.svg)](http://badge.fury.io/js/socket.io-parser) + +A socket.io encoder and decoder written in JavaScript complying with version `3` +of [socket.io-protocol](https://github.com/learnboost/socket.io-protocol). +Used by [socket.io](https://github.com/learnboost/socket.io) and +[socket.io-client](https://github.com/learnboost/socket.io-client). + +## Parser API + + socket.io-parser is the reference implementation of socket.io-protocol. Read + the full API here: + [socket.io-protocol](https://github.com/learnboost/socket.io-protocol). + +## Example Usage + +### Encoding and decoding a packet + +```js +var parser = require('socket.io-parser'); +var encoder = new parser.Encoder(); +var packet = { + type: parser.EVENT, + data: 'test-packet', + id: 13 +}; +encoder.encode(packet, function(encodedPackets) { + var decoder = new parser.Decoder(); + decoder.on('decoded', function(decodedPacket) { + // decodedPacket.type == parser.EVENT + // decodedPacket.data == 'test-packet' + // decodedPacket.id == 13 + }); + + for (var i = 0; i < encodedPackets.length; i++) { + decoder.add(encodedPackets[i]); + } +}); +``` + +### Encoding and decoding a packet with binary data + +```js +var parser = require('socket.io-parser'); +var encoder = new parser.Encoder(); +var packet = { + type: parser.BINARY_EVENT, + data: {i: new Buffer(1234), j: new Blob([new ArrayBuffer(2)])} + id: 15 +}; +encoder.encode(packet, function(encodedPackets) { + var decoder = new parser.Decoder(); + decoder.on('decoded', function(decodedPacket) { + // decodedPacket.type == parser.BINARY_EVENTEVENT + // Buffer.isBuffer(decodedPacket.data.i) == true + // Buffer.isBuffer(decodedPacket.data.j) == true + // decodedPacket.id == 15 + }); + + for (var i = 0; i < encodedPackets.length; i++) { + decoder.add(encodedPackets[i]); + } +}); +``` +See the test suite for more examples of how socket.io-parser is used. + + +## License + +MIT diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/bench/bench.js b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/bench/bench.js new file mode 100644 index 0000000..d767d5a --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/bench/bench.js @@ -0,0 +1,10 @@ +var bencher = require('./index'); +bencher(function(benchmark) { + function logMean(test) { + console.log(test.name + ' mean run time: ' + test.stats.mean); + } + + for (var i = 0; i < benchmark.length; i++) { + logMean(benchmark[i]); + } +}); diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/bench/index.js b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/bench/index.js new file mode 100644 index 0000000..8c1994e --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/bench/index.js @@ -0,0 +1,81 @@ +var Benchmark = require('benchmark'); +var parser = require('../index'); + +function test(packet, deferred) { + var encoder = new parser.Encoder(); + var decoder = new parser.Decoder(); + encoder.encode(packet, function(encodedPackets) { + var decoder = new parser.Decoder(); + decoder.on('decoded', function(packet) { + deferred.resolve(); + }); + + decoder.add(encodedPackets[0]); + }); +} + +var dataObject = { + 'a': [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17], + 'b': 'xxxyyyzzzalsdfalskdjfalksdjfalksdjfalksdjfjjfjfjfjjfjfjfj', + 'data': { + 'is': 'cool', + 'or': { + 'is': { + 'it': true + } + } + } +}; +var bigArray = []; +for (var i = 0; i < 250; i++) { + bigArray.push(dataObject); +} + + + +module.exports = function(callback) { + var suite = new Benchmark.Suite(); + + suite.add('small json parse', {defer: true, fn: function(deferred) { + var packet = { + type: parser.EVENT, + nsp: '/bench', + data: dataObject + }; + test(packet, deferred); + }}) + .add('big json parse', {defer: true, fn: function(deferred) { + var packet = { + type: parser.EVENT, + nsp: '/bench', + data: bigArray + }; + test(packet, deferred); + }}) + .add('json with small binary parse', {defer: true, fn: function(deferred) { + var packet = { + type: parser.EVENT, + nsp: '/bench', + data: {'a': [1, 2, 3], 'b': 'xxxyyyzzz', 'data': new Buffer(1000)} + }; + test(packet, deferred); + }}) + .add('json with big binary parse', {defer: true, fn: function(deferred) { + var bigBinaryData = { + bin1: new Buffer(10000), + arr: bigArray, + bin2: new Buffer(10000), + bin3: new Buffer(10000) + }; + var packet = { + type: parser.EVENT, + nsp: '/bench', + data: bigBinaryData + }; + test(packet, deferred); + }}) + .on('complete', function() { + callback(this); + }) + .run({'async': true}); +}; diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/binary.js b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/binary.js new file mode 100644 index 0000000..b31f40c --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/binary.js @@ -0,0 +1,141 @@ +/*global Blob,File*/ + +/** + * Module requirements + */ + +var isArray = require('isarray'); +var isBuf = require('./is-buffer'); + +/** + * Replaces every Buffer | ArrayBuffer in packet with a numbered placeholder. + * Anything with blobs or files should be fed through removeBlobs before coming + * here. + * + * @param {Object} packet - socket.io event packet + * @return {Object} with deconstructed packet and list of buffers + * @api public + */ + +exports.deconstructPacket = function(packet){ + var buffers = []; + var packetData = packet.data; + + function _deconstructPacket(data) { + if (!data) return data; + + if (isBuf(data)) { + var placeholder = { _placeholder: true, num: buffers.length }; + buffers.push(data); + return placeholder; + } else if (isArray(data)) { + var newData = new Array(data.length); + for (var i = 0; i < data.length; i++) { + newData[i] = _deconstructPacket(data[i]); + } + return newData; + } else if ('object' == typeof data && !(data instanceof Date)) { + var newData = {}; + for (var key in data) { + newData[key] = _deconstructPacket(data[key]); + } + return newData; + } + return data; + } + + var pack = packet; + pack.data = _deconstructPacket(packetData); + pack.attachments = buffers.length; // number of binary 'attachments' + return {packet: pack, buffers: buffers}; +}; + +/** + * Reconstructs a binary packet from its placeholder packet and buffers + * + * @param {Object} packet - event packet with placeholders + * @param {Array} buffers - binary buffers to put in placeholder positions + * @return {Object} reconstructed packet + * @api public + */ + +exports.reconstructPacket = function(packet, buffers) { + var curPlaceHolder = 0; + + function _reconstructPacket(data) { + if (data && data._placeholder) { + var buf = buffers[data.num]; // appropriate buffer (should be natural order anyway) + return buf; + } else if (isArray(data)) { + for (var i = 0; i < data.length; i++) { + data[i] = _reconstructPacket(data[i]); + } + return data; + } else if (data && 'object' == typeof data) { + for (var key in data) { + data[key] = _reconstructPacket(data[key]); + } + return data; + } + return data; + } + + packet.data = _reconstructPacket(packet.data); + packet.attachments = undefined; // no longer useful + return packet; +}; + +/** + * Asynchronously removes Blobs or Files from data via + * FileReader's readAsArrayBuffer method. Used before encoding + * data as msgpack. Calls callback with the blobless data. + * + * @param {Object} data + * @param {Function} callback + * @api private + */ + +exports.removeBlobs = function(data, callback) { + function _removeBlobs(obj, curKey, containingObject) { + if (!obj) return obj; + + // convert any blob + if ((global.Blob && obj instanceof Blob) || + (global.File && obj instanceof File)) { + pendingBlobs++; + + // async filereader + var fileReader = new FileReader(); + fileReader.onload = function() { // this.result == arraybuffer + if (containingObject) { + containingObject[curKey] = this.result; + } + else { + bloblessData = this.result; + } + + // if nothing pending its callback time + if(! --pendingBlobs) { + callback(bloblessData); + } + }; + + fileReader.readAsArrayBuffer(obj); // blob -> arraybuffer + } else if (isArray(obj)) { // handle array + for (var i = 0; i < obj.length; i++) { + _removeBlobs(obj[i], i, obj); + } + } else if (obj && 'object' == typeof obj && !isBuf(obj)) { // and object + for (var key in obj) { + _removeBlobs(obj[key], key, obj); + } + } + } + + var pendingBlobs = 0; + var bloblessData = data; + _removeBlobs(bloblessData); + if (!pendingBlobs) { + callback(bloblessData); + } +}; diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/index.js b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/index.js new file mode 100644 index 0000000..378c4dd --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/index.js @@ -0,0 +1,396 @@ + +/** + * Module dependencies. + */ + +var debug = require('debug')('socket.io-parser'); +var json = require('json3'); +var isArray = require('isarray'); +var Emitter = require('component-emitter'); +var binary = require('./binary'); +var isBuf = require('./is-buffer'); + +/** + * Protocol version. + * + * @api public + */ + +exports.protocol = 4; + +/** + * Packet types. + * + * @api public + */ + +exports.types = [ + 'CONNECT', + 'DISCONNECT', + 'EVENT', + 'BINARY_EVENT', + 'ACK', + 'BINARY_ACK', + 'ERROR' +]; + +/** + * Packet type `connect`. + * + * @api public + */ + +exports.CONNECT = 0; + +/** + * Packet type `disconnect`. + * + * @api public + */ + +exports.DISCONNECT = 1; + +/** + * Packet type `event`. + * + * @api public + */ + +exports.EVENT = 2; + +/** + * Packet type `ack`. + * + * @api public + */ + +exports.ACK = 3; + +/** + * Packet type `error`. + * + * @api public + */ + +exports.ERROR = 4; + +/** + * Packet type 'binary event' + * + * @api public + */ + +exports.BINARY_EVENT = 5; + +/** + * Packet type `binary ack`. For acks with binary arguments. + * + * @api public + */ + +exports.BINARY_ACK = 6; + +/** + * Encoder constructor. + * + * @api public + */ + +exports.Encoder = Encoder; + +/** + * Decoder constructor. + * + * @api public + */ + +exports.Decoder = Decoder; + +/** + * A socket.io Encoder instance + * + * @api public + */ + +function Encoder() {} + +/** + * Encode a packet as a single string if non-binary, or as a + * buffer sequence, depending on packet type. + * + * @param {Object} obj - packet object + * @param {Function} callback - function to handle encodings (likely engine.write) + * @return Calls callback with Array of encodings + * @api public + */ + +Encoder.prototype.encode = function(obj, callback){ + debug('encoding packet %j', obj); + + if (exports.BINARY_EVENT == obj.type || exports.BINARY_ACK == obj.type) { + encodeAsBinary(obj, callback); + } + else { + var encoding = encodeAsString(obj); + callback([encoding]); + } +}; + +/** + * Encode packet as string. + * + * @param {Object} packet + * @return {String} encoded + * @api private + */ + +function encodeAsString(obj) { + var str = ''; + var nsp = false; + + // first is type + str += obj.type; + + // attachments if we have them + if (exports.BINARY_EVENT == obj.type || exports.BINARY_ACK == obj.type) { + str += obj.attachments; + str += '-'; + } + + // if we have a namespace other than `/` + // we append it followed by a comma `,` + if (obj.nsp && '/' != obj.nsp) { + nsp = true; + str += obj.nsp; + } + + // immediately followed by the id + if (null != obj.id) { + if (nsp) { + str += ','; + nsp = false; + } + str += obj.id; + } + + // json data + if (null != obj.data) { + if (nsp) str += ','; + str += json.stringify(obj.data); + } + + debug('encoded %j as %s', obj, str); + return str; +} + +/** + * Encode packet as 'buffer sequence' by removing blobs, and + * deconstructing packet into object with placeholders and + * a list of buffers. + * + * @param {Object} packet + * @return {Buffer} encoded + * @api private + */ + +function encodeAsBinary(obj, callback) { + + function writeEncoding(bloblessData) { + var deconstruction = binary.deconstructPacket(bloblessData); + var pack = encodeAsString(deconstruction.packet); + var buffers = deconstruction.buffers; + + buffers.unshift(pack); // add packet info to beginning of data list + callback(buffers); // write all the buffers + } + + binary.removeBlobs(obj, writeEncoding); +} + +/** + * A socket.io Decoder instance + * + * @return {Object} decoder + * @api public + */ + +function Decoder() { + this.reconstructor = null; +} + +/** + * Mix in `Emitter` with Decoder. + */ + +Emitter(Decoder.prototype); + +/** + * Decodes an ecoded packet string into packet JSON. + * + * @param {String} obj - encoded packet + * @return {Object} packet + * @api public + */ + +Decoder.prototype.add = function(obj) { + var packet; + if ('string' == typeof obj) { + packet = decodeString(obj); + if (exports.BINARY_EVENT == packet.type || exports.BINARY_ACK == packet.type) { // binary packet's json + this.reconstructor = new BinaryReconstructor(packet); + + // no attachments, labeled binary but no binary data to follow + if (this.reconstructor.reconPack.attachments == 0) { + this.emit('decoded', packet); + } + } else { // non-binary full packet + this.emit('decoded', packet); + } + } + else if (isBuf(obj) || obj.base64) { // raw binary data + if (!this.reconstructor) { + throw new Error('got binary data when not reconstructing a packet'); + } else { + packet = this.reconstructor.takeBinaryData(obj); + if (packet) { // received final buffer + this.reconstructor = null; + this.emit('decoded', packet); + } + } + } + else { + throw new Error('Unknown type: ' + obj); + } +}; + +/** + * Decode a packet String (JSON data) + * + * @param {String} str + * @return {Object} packet + * @api private + */ + +function decodeString(str) { + var p = {}; + var i = 0; + + // look up type + p.type = Number(str.charAt(0)); + if (null == exports.types[p.type]) return error(); + + // look up attachments if type binary + if (exports.BINARY_EVENT == p.type || exports.BINARY_ACK == p.type) { + p.attachments = ''; + while (str.charAt(++i) != '-') { + p.attachments += str.charAt(i); + } + p.attachments = Number(p.attachments); + } + + // look up namespace (if any) + if ('/' == str.charAt(i + 1)) { + p.nsp = ''; + while (++i) { + var c = str.charAt(i); + if (',' == c) break; + p.nsp += c; + if (i + 1 == str.length) break; + } + } else { + p.nsp = '/'; + } + + // look up id + var next = str.charAt(i + 1); + if ('' != next && Number(next) == next) { + p.id = ''; + while (++i) { + var c = str.charAt(i); + if (null == c || Number(c) != c) { + --i; + break; + } + p.id += str.charAt(i); + if (i + 1 == str.length) break; + } + p.id = Number(p.id); + } + + // look up json data + if (str.charAt(++i)) { + try { + p.data = json.parse(str.substr(i)); + } catch(e){ + return error(); + } + } + + debug('decoded %s as %j', str, p); + return p; +} + +/** + * Deallocates a parser's resources + * + * @api public + */ + +Decoder.prototype.destroy = function() { + if (this.reconstructor) { + this.reconstructor.finishedReconstruction(); + } +}; + +/** + * A manager of a binary event's 'buffer sequence'. Should + * be constructed whenever a packet of type BINARY_EVENT is + * decoded. + * + * @param {Object} packet + * @return {BinaryReconstructor} initialized reconstructor + * @api private + */ + +function BinaryReconstructor(packet) { + this.reconPack = packet; + this.buffers = []; +} + +/** + * Method to be called when binary data received from connection + * after a BINARY_EVENT packet. + * + * @param {Buffer | ArrayBuffer} binData - the raw binary data received + * @return {null | Object} returns null if more binary data is expected or + * a reconstructed packet object if all buffers have been received. + * @api private + */ + +BinaryReconstructor.prototype.takeBinaryData = function(binData) { + this.buffers.push(binData); + if (this.buffers.length == this.reconPack.attachments) { // done with buffer list + var packet = binary.reconstructPacket(this.reconPack, this.buffers); + this.finishedReconstruction(); + return packet; + } + return null; +}; + +/** + * Cleans up binary packet reconstruction variables. + * + * @api private + */ + +BinaryReconstructor.prototype.finishedReconstruction = function() { + this.reconPack = null; + this.buffers = []; +}; + +function error(data){ + return { + type: exports.ERROR, + data: 'parser error' + }; +} diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/is-buffer.js b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/is-buffer.js new file mode 100644 index 0000000..977df88 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/is-buffer.js @@ -0,0 +1,13 @@ + +module.exports = isBuf; + +/** + * Returns true if obj is a buffer or an arraybuffer. + * + * @api private + */ + +function isBuf(obj) { + return (global.Buffer && global.Buffer.isBuffer(obj)) || + (global.ArrayBuffer && obj instanceof ArrayBuffer); +} diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/benchmark/LICENSE.txt b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/benchmark/LICENSE.txt new file mode 100644 index 0000000..e33e63f --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/benchmark/LICENSE.txt @@ -0,0 +1,22 @@ +Copyright 2010-2012 Mathias Bynens +Based on JSLitmus.js, copyright Robert Kieffer +Modified by John-David Dalton + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +"Software"), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND +NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE +LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION +OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION +WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/benchmark/README.md b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/benchmark/README.md new file mode 100644 index 0000000..a3ab3f8 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/benchmark/README.md @@ -0,0 +1,131 @@ +# Benchmark.js v1.0.0 + +A [robust](http://calendar.perfplanet.com/2010/bulletproof-javascript-benchmarks/ "Bulletproof JavaScript benchmarks") benchmarking library that works on nearly all JavaScript platforms1, supports high-resolution timers, and returns statistically significant results. As seen on [jsPerf](http://jsperf.com/). + +## BestieJS + +Benchmark.js is part of the BestieJS *"Best in Class"* module collection. This means we promote solid browser/environment support, ES5 precedents, unit testing, and plenty of documentation. + +## Documentation + +The documentation for Benchmark.js can be viewed here: + +For a list of upcoming features, check out our [roadmap](https://github.com/bestiejs/benchmark.js/wiki/Roadmap). + +## Support + +Benchmark.js has been tested in at least Adobe AIR 3.1, Chrome 5-21, Firefox 1.5-13, IE 6-9, Opera 9.25-12.01, Safari 3-6, Node.js 0.8.6, Narwhal 0.3.2, RingoJS 0.8, and Rhino 1.7RC5. + +## Installation and usage + +In a browser or Adobe AIR: + +~~~ html + +~~~ + +Optionally, expose Java’s nanosecond timer by adding the `nano` applet to the ``: + +~~~ html + +~~~ + +Or enable Chrome’s microsecond timer by using the [command line switch](http://peter.sh/experiments/chromium-command-line-switches/#enable-benchmarking): + + --enable-benchmarking + +Via [npm](http://npmjs.org/): + +~~~ bash +npm install benchmark +~~~ + +In [Node.js](http://nodejs.org/) and [RingoJS v0.8.0+](http://ringojs.org/): + +~~~ js +var Benchmark = require('benchmark'); +~~~ + +Optionally, use the [microtime module](https://github.com/wadey/node-microtime) by Wade Simmons: + +~~~ bash +npm install microtime +~~~ + +In [RingoJS v0.7.0-](http://ringojs.org/): + +~~~ js +var Benchmark = require('benchmark').Benchmark; +~~~ + +In [Rhino](http://www.mozilla.org/rhino/): + +~~~ js +load('benchmark.js'); +~~~ + +In an AMD loader like [RequireJS](http://requirejs.org/): + +~~~ js +require({ + 'paths': { + 'benchmark': 'path/to/benchmark' + } +}, +['benchmark'], function(Benchmark) { + console.log(Benchmark.version); +}); + +// or with platform.js +// https://github.com/bestiejs/platform.js +require({ + 'paths': { + 'benchmark': 'path/to/benchmark', + 'platform': 'path/to/platform' + } +}, +['benchmark', 'platform'], function(Benchmark, platform) { + Benchmark.platform = platform; + console.log(Benchmark.platform.name); +}); +~~~ + +Usage example: + +~~~ js +var suite = new Benchmark.Suite; + +// add tests +suite.add('RegExp#test', function() { + /o/.test('Hello World!'); +}) +.add('String#indexOf', function() { + 'Hello World!'.indexOf('o') > -1; +}) +// add listeners +.on('cycle', function(event) { + console.log(String(event.target)); +}) +.on('complete', function() { + console.log('Fastest is ' + this.filter('fastest').pluck('name')); +}) +// run async +.run({ 'async': true }); + +// logs: +// > RegExp#test x 4,161,532 +-0.99% (59 cycles) +// > String#indexOf x 6,139,623 +-1.00% (131 cycles) +// > Fastest is String#indexOf +~~~ + +## Authors + +* [Mathias Bynens](http://mathiasbynens.be/) + [![twitter/mathias](http://gravatar.com/avatar/24e08a9ea84deb17ae121074d0f17125?s=70)](https://twitter.com/mathias "Follow @mathias on Twitter") +* [John-David Dalton](http://allyoucanleet.com/) + [![twitter/jdalton](http://gravatar.com/avatar/299a3d891ff1920b69c364d061007043?s=70)](https://twitter.com/jdalton "Follow @jdalton on Twitter") + +## Contributors + +* [Kit Cambridge](http://kitcambridge.github.com/) + [![twitter/kitcambridge](http://gravatar.com/avatar/6662a1d02f351b5ef2f8b4d815804661?s=70)](https://twitter.com/kitcambridge "Follow @kitcambridge on Twitter") diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/benchmark/benchmark.js b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/benchmark/benchmark.js new file mode 100644 index 0000000..d8eb309 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/benchmark/benchmark.js @@ -0,0 +1,3918 @@ +/*! + * Benchmark.js v1.0.0 + * Copyright 2010-2012 Mathias Bynens + * Based on JSLitmus.js, copyright Robert Kieffer + * Modified by John-David Dalton + * Available under MIT license + */ +;(function(window, undefined) { + 'use strict'; + + /** Used to assign each benchmark an incrimented id */ + var counter = 0; + + /** Detect DOM document object */ + var doc = isHostType(window, 'document') && document; + + /** Detect free variable `define` */ + var freeDefine = typeof define == 'function' && + typeof define.amd == 'object' && define.amd && define; + + /** Detect free variable `exports` */ + var freeExports = typeof exports == 'object' && exports && + (typeof global == 'object' && global && global == global.global && (window = global), exports); + + /** Detect free variable `require` */ + var freeRequire = typeof require == 'function' && require; + + /** Used to crawl all properties regardless of enumerability */ + var getAllKeys = Object.getOwnPropertyNames; + + /** Used to get property descriptors */ + var getDescriptor = Object.getOwnPropertyDescriptor; + + /** Used in case an object doesn't have its own method */ + var hasOwnProperty = {}.hasOwnProperty; + + /** Used to check if an object is extensible */ + var isExtensible = Object.isExtensible || function() { return true; }; + + /** Used to access Wade Simmons' Node microtime module */ + var microtimeObject = req('microtime'); + + /** Used to access the browser's high resolution timer */ + var perfObject = isHostType(window, 'performance') && performance; + + /** Used to call the browser's high resolution timer */ + var perfName = perfObject && ( + perfObject.now && 'now' || + perfObject.webkitNow && 'webkitNow' + ); + + /** Used to access Node's high resolution timer */ + var processObject = isHostType(window, 'process') && process; + + /** Used to check if an own property is enumerable */ + var propertyIsEnumerable = {}.propertyIsEnumerable; + + /** Used to set property descriptors */ + var setDescriptor = Object.defineProperty; + + /** Used to resolve a value's internal [[Class]] */ + var toString = {}.toString; + + /** Used to prevent a `removeChild` memory leak in IE < 9 */ + var trash = doc && doc.createElement('div'); + + /** Used to integrity check compiled tests */ + var uid = 'uid' + (+new Date); + + /** Used to avoid infinite recursion when methods call each other */ + var calledBy = {}; + + /** Used to avoid hz of Infinity */ + var divisors = { + '1': 4096, + '2': 512, + '3': 64, + '4': 8, + '5': 0 + }; + + /** + * T-Distribution two-tailed critical values for 95% confidence + * http://www.itl.nist.gov/div898/handbook/eda/section3/eda3672.htm + */ + var tTable = { + '1': 12.706,'2': 4.303, '3': 3.182, '4': 2.776, '5': 2.571, '6': 2.447, + '7': 2.365, '8': 2.306, '9': 2.262, '10': 2.228, '11': 2.201, '12': 2.179, + '13': 2.16, '14': 2.145, '15': 2.131, '16': 2.12, '17': 2.11, '18': 2.101, + '19': 2.093, '20': 2.086, '21': 2.08, '22': 2.074, '23': 2.069, '24': 2.064, + '25': 2.06, '26': 2.056, '27': 2.052, '28': 2.048, '29': 2.045, '30': 2.042, + 'infinity': 1.96 + }; + + /** + * Critical Mann-Whitney U-values for 95% confidence + * http://www.saburchill.com/IBbiology/stats/003.html + */ + var uTable = { + '5': [0, 1, 2], + '6': [1, 2, 3, 5], + '7': [1, 3, 5, 6, 8], + '8': [2, 4, 6, 8, 10, 13], + '9': [2, 4, 7, 10, 12, 15, 17], + '10': [3, 5, 8, 11, 14, 17, 20, 23], + '11': [3, 6, 9, 13, 16, 19, 23, 26, 30], + '12': [4, 7, 11, 14, 18, 22, 26, 29, 33, 37], + '13': [4, 8, 12, 16, 20, 24, 28, 33, 37, 41, 45], + '14': [5, 9, 13, 17, 22, 26, 31, 36, 40, 45, 50, 55], + '15': [5, 10, 14, 19, 24, 29, 34, 39, 44, 49, 54, 59, 64], + '16': [6, 11, 15, 21, 26, 31, 37, 42, 47, 53, 59, 64, 70, 75], + '17': [6, 11, 17, 22, 28, 34, 39, 45, 51, 57, 63, 67, 75, 81, 87], + '18': [7, 12, 18, 24, 30, 36, 42, 48, 55, 61, 67, 74, 80, 86, 93, 99], + '19': [7, 13, 19, 25, 32, 38, 45, 52, 58, 65, 72, 78, 85, 92, 99, 106, 113], + '20': [8, 14, 20, 27, 34, 41, 48, 55, 62, 69, 76, 83, 90, 98, 105, 112, 119, 127], + '21': [8, 15, 22, 29, 36, 43, 50, 58, 65, 73, 80, 88, 96, 103, 111, 119, 126, 134, 142], + '22': [9, 16, 23, 30, 38, 45, 53, 61, 69, 77, 85, 93, 101, 109, 117, 125, 133, 141, 150, 158], + '23': [9, 17, 24, 32, 40, 48, 56, 64, 73, 81, 89, 98, 106, 115, 123, 132, 140, 149, 157, 166, 175], + '24': [10, 17, 25, 33, 42, 50, 59, 67, 76, 85, 94, 102, 111, 120, 129, 138, 147, 156, 165, 174, 183, 192], + '25': [10, 18, 27, 35, 44, 53, 62, 71, 80, 89, 98, 107, 117, 126, 135, 145, 154, 163, 173, 182, 192, 201, 211], + '26': [11, 19, 28, 37, 46, 55, 64, 74, 83, 93, 102, 112, 122, 132, 141, 151, 161, 171, 181, 191, 200, 210, 220, 230], + '27': [11, 20, 29, 38, 48, 57, 67, 77, 87, 97, 107, 118, 125, 138, 147, 158, 168, 178, 188, 199, 209, 219, 230, 240, 250], + '28': [12, 21, 30, 40, 50, 60, 70, 80, 90, 101, 111, 122, 132, 143, 154, 164, 175, 186, 196, 207, 218, 228, 239, 250, 261, 272], + '29': [13, 22, 32, 42, 52, 62, 73, 83, 94, 105, 116, 127, 138, 149, 160, 171, 182, 193, 204, 215, 226, 238, 249, 260, 271, 282, 294], + '30': [13, 23, 33, 43, 54, 65, 76, 87, 98, 109, 120, 131, 143, 154, 166, 177, 189, 200, 212, 223, 235, 247, 258, 270, 282, 293, 305, 317] + }; + + /** + * An object used to flag environments/features. + * + * @static + * @memberOf Benchmark + * @type Object + */ + var support = {}; + + (function() { + + /** + * Detect Adobe AIR. + * + * @memberOf Benchmark.support + * @type Boolean + */ + support.air = isClassOf(window.runtime, 'ScriptBridgingProxyObject'); + + /** + * Detect if `arguments` objects have the correct internal [[Class]] value. + * + * @memberOf Benchmark.support + * @type Boolean + */ + support.argumentsClass = isClassOf(arguments, 'Arguments'); + + /** + * Detect if in a browser environment. + * + * @memberOf Benchmark.support + * @type Boolean + */ + support.browser = doc && isHostType(window, 'navigator'); + + /** + * Detect if strings support accessing characters by index. + * + * @memberOf Benchmark.support + * @type Boolean + */ + support.charByIndex = + // IE 8 supports indexes on string literals but not string objects + ('x'[0] + Object('x')[0]) == 'xx'; + + /** + * Detect if strings have indexes as own properties. + * + * @memberOf Benchmark.support + * @type Boolean + */ + support.charByOwnIndex = + // Narwhal, Rhino, RingoJS, IE 8, and Opera < 10.52 support indexes on + // strings but don't detect them as own properties + support.charByIndex && hasKey('x', '0'); + + /** + * Detect if Java is enabled/exposed. + * + * @memberOf Benchmark.support + * @type Boolean + */ + support.java = isClassOf(window.java, 'JavaPackage'); + + /** + * Detect if the Timers API exists. + * + * @memberOf Benchmark.support + * @type Boolean + */ + support.timeout = isHostType(window, 'setTimeout') && isHostType(window, 'clearTimeout'); + + /** + * Detect if functions support decompilation. + * + * @name decompilation + * @memberOf Benchmark.support + * @type Boolean + */ + try { + // Safari 2.x removes commas in object literals + // from Function#toString results + // http://webk.it/11609 + // Firefox 3.6 and Opera 9.25 strip grouping + // parentheses from Function#toString results + // http://bugzil.la/559438 + support.decompilation = Function( + 'return (' + (function(x) { return { 'x': '' + (1 + x) + '', 'y': 0 }; }) + ')' + )()(0).x === '1'; + } catch(e) { + support.decompilation = false; + } + + /** + * Detect ES5+ property descriptor API. + * + * @name descriptors + * @memberOf Benchmark.support + * @type Boolean + */ + try { + var o = {}; + support.descriptors = (setDescriptor(o, o, o), 'value' in getDescriptor(o, o)); + } catch(e) { + support.descriptors = false; + } + + /** + * Detect ES5+ Object.getOwnPropertyNames(). + * + * @name getAllKeys + * @memberOf Benchmark.support + * @type Boolean + */ + try { + support.getAllKeys = /\bvalueOf\b/.test(getAllKeys(Object.prototype)); + } catch(e) { + support.getAllKeys = false; + } + + /** + * Detect if own properties are iterated before inherited properties (all but IE < 9). + * + * @name iteratesOwnLast + * @memberOf Benchmark.support + * @type Boolean + */ + support.iteratesOwnFirst = (function() { + var props = []; + function ctor() { this.x = 1; } + ctor.prototype = { 'y': 1 }; + for (var prop in new ctor) { props.push(prop); } + return props[0] == 'x'; + }()); + + /** + * Detect if a node's [[Class]] is resolvable (all but IE < 9) + * and that the JS engine errors when attempting to coerce an object to a + * string without a `toString` property value of `typeof` "function". + * + * @name nodeClass + * @memberOf Benchmark.support + * @type Boolean + */ + try { + support.nodeClass = ({ 'toString': 0 } + '', toString.call(doc || 0) != '[object Object]'); + } catch(e) { + support.nodeClass = true; + } + }()); + + /** + * Timer object used by `clock()` and `Deferred#resolve`. + * + * @private + * @type Object + */ + var timer = { + + /** + * The timer namespace object or constructor. + * + * @private + * @memberOf timer + * @type Function|Object + */ + 'ns': Date, + + /** + * Starts the deferred timer. + * + * @private + * @memberOf timer + * @param {Object} deferred The deferred instance. + */ + 'start': null, // lazy defined in `clock()` + + /** + * Stops the deferred timer. + * + * @private + * @memberOf timer + * @param {Object} deferred The deferred instance. + */ + 'stop': null // lazy defined in `clock()` + }; + + /** Shortcut for inverse results */ + var noArgumentsClass = !support.argumentsClass, + noCharByIndex = !support.charByIndex, + noCharByOwnIndex = !support.charByOwnIndex; + + /** Math shortcuts */ + var abs = Math.abs, + floor = Math.floor, + max = Math.max, + min = Math.min, + pow = Math.pow, + sqrt = Math.sqrt; + + /*--------------------------------------------------------------------------*/ + + /** + * The Benchmark constructor. + * + * @constructor + * @param {String} name A name to identify the benchmark. + * @param {Function|String} fn The test to benchmark. + * @param {Object} [options={}] Options object. + * @example + * + * // basic usage (the `new` operator is optional) + * var bench = new Benchmark(fn); + * + * // or using a name first + * var bench = new Benchmark('foo', fn); + * + * // or with options + * var bench = new Benchmark('foo', fn, { + * + * // displayed by Benchmark#toString if `name` is not available + * 'id': 'xyz', + * + * // called when the benchmark starts running + * 'onStart': onStart, + * + * // called after each run cycle + * 'onCycle': onCycle, + * + * // called when aborted + * 'onAbort': onAbort, + * + * // called when a test errors + * 'onError': onError, + * + * // called when reset + * 'onReset': onReset, + * + * // called when the benchmark completes running + * 'onComplete': onComplete, + * + * // compiled/called before the test loop + * 'setup': setup, + * + * // compiled/called after the test loop + * 'teardown': teardown + * }); + * + * // or name and options + * var bench = new Benchmark('foo', { + * + * // a flag to indicate the benchmark is deferred + * 'defer': true, + * + * // benchmark test function + * 'fn': function(deferred) { + * // call resolve() when the deferred test is finished + * deferred.resolve(); + * } + * }); + * + * // or options only + * var bench = new Benchmark({ + * + * // benchmark name + * 'name': 'foo', + * + * // benchmark test as a string + * 'fn': '[1,2,3,4].sort()' + * }); + * + * // a test's `this` binding is set to the benchmark instance + * var bench = new Benchmark('foo', function() { + * 'My name is '.concat(this.name); // My name is foo + * }); + */ + function Benchmark(name, fn, options) { + var me = this; + + // allow instance creation without the `new` operator + if (me == null || me.constructor != Benchmark) { + return new Benchmark(name, fn, options); + } + // juggle arguments + if (isClassOf(name, 'Object')) { + // 1 argument (options) + options = name; + } + else if (isClassOf(name, 'Function')) { + // 2 arguments (fn, options) + options = fn; + fn = name; + } + else if (isClassOf(fn, 'Object')) { + // 2 arguments (name, options) + options = fn; + fn = null; + me.name = name; + } + else { + // 3 arguments (name, fn [, options]) + me.name = name; + } + setOptions(me, options); + me.id || (me.id = ++counter); + me.fn == null && (me.fn = fn); + me.stats = deepClone(me.stats); + me.times = deepClone(me.times); + } + + /** + * The Deferred constructor. + * + * @constructor + * @memberOf Benchmark + * @param {Object} clone The cloned benchmark instance. + */ + function Deferred(clone) { + var me = this; + if (me == null || me.constructor != Deferred) { + return new Deferred(clone); + } + me.benchmark = clone; + clock(me); + } + + /** + * The Event constructor. + * + * @constructor + * @memberOf Benchmark + * @param {String|Object} type The event type. + */ + function Event(type) { + var me = this; + return (me == null || me.constructor != Event) + ? new Event(type) + : (type instanceof Event) + ? type + : extend(me, { 'timeStamp': +new Date }, typeof type == 'string' ? { 'type': type } : type); + } + + /** + * The Suite constructor. + * + * @constructor + * @memberOf Benchmark + * @param {String} name A name to identify the suite. + * @param {Object} [options={}] Options object. + * @example + * + * // basic usage (the `new` operator is optional) + * var suite = new Benchmark.Suite; + * + * // or using a name first + * var suite = new Benchmark.Suite('foo'); + * + * // or with options + * var suite = new Benchmark.Suite('foo', { + * + * // called when the suite starts running + * 'onStart': onStart, + * + * // called between running benchmarks + * 'onCycle': onCycle, + * + * // called when aborted + * 'onAbort': onAbort, + * + * // called when a test errors + * 'onError': onError, + * + * // called when reset + * 'onReset': onReset, + * + * // called when the suite completes running + * 'onComplete': onComplete + * }); + */ + function Suite(name, options) { + var me = this; + + // allow instance creation without the `new` operator + if (me == null || me.constructor != Suite) { + return new Suite(name, options); + } + // juggle arguments + if (isClassOf(name, 'Object')) { + // 1 argument (options) + options = name; + } else { + // 2 arguments (name [, options]) + me.name = name; + } + setOptions(me, options); + } + + /*--------------------------------------------------------------------------*/ + + /** + * Note: Some array methods have been implemented in plain JavaScript to avoid + * bugs in IE, Opera, Rhino, and Mobile Safari. + * + * IE compatibility mode and IE < 9 have buggy Array `shift()` and `splice()` + * functions that fail to remove the last element, `object[0]`, of + * array-like-objects even though the `length` property is set to `0`. + * The `shift()` method is buggy in IE 8 compatibility mode, while `splice()` + * is buggy regardless of mode in IE < 9 and buggy in compatibility mode in IE 9. + * + * In Opera < 9.50 and some older/beta Mobile Safari versions using `unshift()` + * generically to augment the `arguments` object will pave the value at index 0 + * without incrimenting the other values's indexes. + * https://github.com/documentcloud/underscore/issues/9 + * + * Rhino and environments it powers, like Narwhal and RingoJS, may have + * buggy Array `concat()`, `reverse()`, `shift()`, `slice()`, `splice()` and + * `unshift()` functions that make sparse arrays non-sparse by assigning the + * undefined indexes a value of undefined. + * https://github.com/mozilla/rhino/commit/702abfed3f8ca043b2636efd31c14ba7552603dd + */ + + /** + * Creates an array containing the elements of the host array followed by the + * elements of each argument in order. + * + * @memberOf Benchmark.Suite + * @returns {Array} The new array. + */ + function concat() { + var value, + j = -1, + length = arguments.length, + result = slice.call(this), + index = result.length; + + while (++j < length) { + value = arguments[j]; + if (isClassOf(value, 'Array')) { + for (var k = 0, l = value.length; k < l; k++, index++) { + if (k in value) { + result[index] = value[k]; + } + } + } else { + result[index++] = value; + } + } + return result; + } + + /** + * Utility function used by `shift()`, `splice()`, and `unshift()`. + * + * @private + * @param {Number} start The index to start inserting elements. + * @param {Number} deleteCount The number of elements to delete from the insert point. + * @param {Array} elements The elements to insert. + * @returns {Array} An array of deleted elements. + */ + function insert(start, deleteCount, elements) { + // `result` should have its length set to the `deleteCount` + // see https://bugs.ecmascript.org/show_bug.cgi?id=332 + var deleteEnd = start + deleteCount, + elementCount = elements ? elements.length : 0, + index = start - 1, + length = start + elementCount, + object = this, + result = Array(deleteCount), + tail = slice.call(object, deleteEnd); + + // delete elements from the array + while (++index < deleteEnd) { + if (index in object) { + result[index - start] = object[index]; + delete object[index]; + } + } + // insert elements + index = start - 1; + while (++index < length) { + object[index] = elements[index - start]; + } + // append tail elements + start = index--; + length = max(0, (object.length >>> 0) - deleteCount + elementCount); + while (++index < length) { + if ((index - start) in tail) { + object[index] = tail[index - start]; + } else if (index in object) { + delete object[index]; + } + } + // delete excess elements + deleteCount = deleteCount > elementCount ? deleteCount - elementCount : 0; + while (deleteCount--) { + index = length + deleteCount; + if (index in object) { + delete object[index]; + } + } + object.length = length; + return result; + } + + /** + * Rearrange the host array's elements in reverse order. + * + * @memberOf Benchmark.Suite + * @returns {Array} The reversed array. + */ + function reverse() { + var upperIndex, + value, + index = -1, + object = Object(this), + length = object.length >>> 0, + middle = floor(length / 2); + + if (length > 1) { + while (++index < middle) { + upperIndex = length - index - 1; + value = upperIndex in object ? object[upperIndex] : uid; + if (index in object) { + object[upperIndex] = object[index]; + } else { + delete object[upperIndex]; + } + if (value != uid) { + object[index] = value; + } else { + delete object[index]; + } + } + } + return object; + } + + /** + * Removes the first element of the host array and returns it. + * + * @memberOf Benchmark.Suite + * @returns {Mixed} The first element of the array. + */ + function shift() { + return insert.call(this, 0, 1)[0]; + } + + /** + * Creates an array of the host array's elements from the start index up to, + * but not including, the end index. + * + * @memberOf Benchmark.Suite + * @param {Number} start The starting index. + * @param {Number} end The end index. + * @returns {Array} The new array. + */ + function slice(start, end) { + var index = -1, + object = Object(this), + length = object.length >>> 0, + result = []; + + start = toInteger(start); + start = start < 0 ? max(length + start, 0) : min(start, length); + start--; + end = end == null ? length : toInteger(end); + end = end < 0 ? max(length + end, 0) : min(end, length); + + while ((++index, ++start) < end) { + if (start in object) { + result[index] = object[start]; + } + } + return result; + } + + /** + * Allows removing a range of elements and/or inserting elements into the + * host array. + * + * @memberOf Benchmark.Suite + * @param {Number} start The start index. + * @param {Number} deleteCount The number of elements to delete. + * @param {Mixed} [val1, val2, ...] values to insert at the `start` index. + * @returns {Array} An array of removed elements. + */ + function splice(start, deleteCount) { + var object = Object(this), + length = object.length >>> 0; + + start = toInteger(start); + start = start < 0 ? max(length + start, 0) : min(start, length); + + // support the de-facto SpiderMonkey extension + // https://developer.mozilla.org/en/JavaScript/Reference/Global_Objects/Array/splice#Parameters + // https://bugs.ecmascript.org/show_bug.cgi?id=429 + deleteCount = arguments.length == 1 + ? length - start + : min(max(toInteger(deleteCount), 0), length - start); + + return insert.call(object, start, deleteCount, slice.call(arguments, 2)); + } + + /** + * Converts the specified `value` to an integer. + * + * @private + * @param {Mixed} value The value to convert. + * @returns {Number} The resulting integer. + */ + function toInteger(value) { + value = +value; + return value === 0 || !isFinite(value) ? value || 0 : value - (value % 1); + } + + /** + * Appends arguments to the host array. + * + * @memberOf Benchmark.Suite + * @returns {Number} The new length. + */ + function unshift() { + var object = Object(this); + insert.call(object, 0, 0, arguments); + return object.length; + } + + /*--------------------------------------------------------------------------*/ + + /** + * A generic `Function#bind` like method. + * + * @private + * @param {Function} fn The function to be bound to `thisArg`. + * @param {Mixed} thisArg The `this` binding for the given function. + * @returns {Function} The bound function. + */ + function bind(fn, thisArg) { + return function() { fn.apply(thisArg, arguments); }; + } + + /** + * Creates a function from the given arguments string and body. + * + * @private + * @param {String} args The comma separated function arguments. + * @param {String} body The function body. + * @returns {Function} The new function. + */ + function createFunction() { + // lazy define + createFunction = function(args, body) { + var result, + anchor = freeDefine ? define.amd : Benchmark, + prop = uid + 'createFunction'; + + runScript((freeDefine ? 'define.amd.' : 'Benchmark.') + prop + '=function(' + args + '){' + body + '}'); + result = anchor[prop]; + delete anchor[prop]; + return result; + }; + // fix JaegerMonkey bug + // http://bugzil.la/639720 + createFunction = support.browser && (createFunction('', 'return"' + uid + '"') || noop)() == uid ? createFunction : Function; + return createFunction.apply(null, arguments); + } + + /** + * Delay the execution of a function based on the benchmark's `delay` property. + * + * @private + * @param {Object} bench The benchmark instance. + * @param {Object} fn The function to execute. + */ + function delay(bench, fn) { + bench._timerId = setTimeout(fn, bench.delay * 1e3); + } + + /** + * Destroys the given element. + * + * @private + * @param {Element} element The element to destroy. + */ + function destroyElement(element) { + trash.appendChild(element); + trash.innerHTML = ''; + } + + /** + * Iterates over an object's properties, executing the `callback` for each. + * Callbacks may terminate the loop by explicitly returning `false`. + * + * @private + * @param {Object} object The object to iterate over. + * @param {Function} callback The function executed per own property. + * @param {Object} options The options object. + * @returns {Object} Returns the object iterated over. + */ + function forProps() { + var forShadowed, + skipSeen, + forArgs = true, + shadowed = ['constructor', 'hasOwnProperty', 'isPrototypeOf', 'propertyIsEnumerable', 'toLocaleString', 'toString', 'valueOf']; + + (function(enumFlag, key) { + // must use a non-native constructor to catch the Safari 2 issue + function Klass() { this.valueOf = 0; }; + Klass.prototype.valueOf = 0; + // check various for-in bugs + for (key in new Klass) { + enumFlag += key == 'valueOf' ? 1 : 0; + } + // check if `arguments` objects have non-enumerable indexes + for (key in arguments) { + key == '0' && (forArgs = false); + } + // Safari 2 iterates over shadowed properties twice + // http://replay.waybackmachine.org/20090428222941/http://tobielangel.com/2007/1/29/for-in-loop-broken-in-safari/ + skipSeen = enumFlag == 2; + // IE < 9 incorrectly makes an object's properties non-enumerable if they have + // the same name as other non-enumerable properties in its prototype chain. + forShadowed = !enumFlag; + }(0)); + + // lazy define + forProps = function(object, callback, options) { + options || (options = {}); + + var result = object; + object = Object(object); + + var ctor, + key, + keys, + skipCtor, + done = !result, + which = options.which, + allFlag = which == 'all', + index = -1, + iteratee = object, + length = object.length, + ownFlag = allFlag || which == 'own', + seen = {}, + skipProto = isClassOf(object, 'Function'), + thisArg = options.bind; + + if (thisArg !== undefined) { + callback = bind(callback, thisArg); + } + // iterate all properties + if (allFlag && support.getAllKeys) { + for (index = 0, keys = getAllKeys(object), length = keys.length; index < length; index++) { + key = keys[index]; + if (callback(object[key], key, object) === false) { + break; + } + } + } + // else iterate only enumerable properties + else { + for (key in object) { + // Firefox < 3.6, Opera > 9.50 - Opera < 11.60, and Safari < 5.1 + // (if the prototype or a property on the prototype has been set) + // incorrectly set a function's `prototype` property [[Enumerable]] value + // to `true`. Because of this we standardize on skipping the `prototype` + // property of functions regardless of their [[Enumerable]] value. + if ((done = + !(skipProto && key == 'prototype') && + !(skipSeen && (hasKey(seen, key) || !(seen[key] = true))) && + (!ownFlag || ownFlag && hasKey(object, key)) && + callback(object[key], key, object) === false)) { + break; + } + } + // in IE < 9 strings don't support accessing characters by index + if (!done && (forArgs && isArguments(object) || + ((noCharByIndex || noCharByOwnIndex) && isClassOf(object, 'String') && + (iteratee = noCharByIndex ? object.split('') : object)))) { + while (++index < length) { + if ((done = + callback(iteratee[index], String(index), object) === false)) { + break; + } + } + } + if (!done && forShadowed) { + // Because IE < 9 can't set the `[[Enumerable]]` attribute of an existing + // property and the `constructor` property of a prototype defaults to + // non-enumerable, we manually skip the `constructor` property when we + // think we are iterating over a `prototype` object. + ctor = object.constructor; + skipCtor = ctor && ctor.prototype && ctor.prototype.constructor === ctor; + for (index = 0; index < 7; index++) { + key = shadowed[index]; + if (!(skipCtor && key == 'constructor') && + hasKey(object, key) && + callback(object[key], key, object) === false) { + break; + } + } + } + } + return result; + }; + return forProps.apply(null, arguments); + } + + /** + * Gets the name of the first argument from a function's source. + * + * @private + * @param {Function} fn The function. + * @returns {String} The argument name. + */ + function getFirstArgument(fn) { + return (!hasKey(fn, 'toString') && + (/^[\s(]*function[^(]*\(([^\s,)]+)/.exec(fn) || 0)[1]) || ''; + } + + /** + * Computes the arithmetic mean of a sample. + * + * @private + * @param {Array} sample The sample. + * @returns {Number} The mean. + */ + function getMean(sample) { + return reduce(sample, function(sum, x) { + return sum + x; + }) / sample.length || 0; + } + + /** + * Gets the source code of a function. + * + * @private + * @param {Function} fn The function. + * @param {String} altSource A string used when a function's source code is unretrievable. + * @returns {String} The function's source code. + */ + function getSource(fn, altSource) { + var result = altSource; + if (isStringable(fn)) { + result = String(fn); + } else if (support.decompilation) { + // escape the `{` for Firefox 1 + result = (/^[^{]+\{([\s\S]*)}\s*$/.exec(fn) || 0)[1]; + } + // trim string + result = (result || '').replace(/^\s+|\s+$/g, ''); + + // detect strings containing only the "use strict" directive + return /^(?:\/\*+[\w|\W]*?\*\/|\/\/.*?[\n\r\u2028\u2029]|\s)*(["'])use strict\1;?$/.test(result) + ? '' + : result; + } + + /** + * Checks if a value is an `arguments` object. + * + * @private + * @param {Mixed} value The value to check. + * @returns {Boolean} Returns `true` if the value is an `arguments` object, else `false`. + */ + function isArguments() { + // lazy define + isArguments = function(value) { + return toString.call(value) == '[object Arguments]'; + }; + if (noArgumentsClass) { + isArguments = function(value) { + return hasKey(value, 'callee') && + !(propertyIsEnumerable && propertyIsEnumerable.call(value, 'callee')); + }; + } + return isArguments(arguments[0]); + } + + /** + * Checks if an object is of the specified class. + * + * @private + * @param {Mixed} value The value to check. + * @param {String} name The name of the class. + * @returns {Boolean} Returns `true` if the value is of the specified class, else `false`. + */ + function isClassOf(value, name) { + return value != null && toString.call(value) == '[object ' + name + ']'; + } + + /** + * Host objects can return type values that are different from their actual + * data type. The objects we are concerned with usually return non-primitive + * types of object, function, or unknown. + * + * @private + * @param {Mixed} object The owner of the property. + * @param {String} property The property to check. + * @returns {Boolean} Returns `true` if the property value is a non-primitive, else `false`. + */ + function isHostType(object, property) { + var type = object != null ? typeof object[property] : 'number'; + return !/^(?:boolean|number|string|undefined)$/.test(type) && + (type == 'object' ? !!object[property] : true); + } + + /** + * Checks if a given `value` is an object created by the `Object` constructor + * assuming objects created by the `Object` constructor have no inherited + * enumerable properties and that there are no `Object.prototype` extensions. + * + * @private + * @param {Mixed} value The value to check. + * @returns {Boolean} Returns `true` if the `value` is a plain `Object` object, else `false`. + */ + function isPlainObject(value) { + // avoid non-objects and false positives for `arguments` objects in IE < 9 + var result = false; + if (!(value && typeof value == 'object') || (noArgumentsClass && isArguments(value))) { + return result; + } + // IE < 9 presents DOM nodes as `Object` objects except they have `toString` + // methods that are `typeof` "string" and still can coerce nodes to strings. + // Also check that the constructor is `Object` (i.e. `Object instanceof Object`) + var ctor = value.constructor; + if ((support.nodeClass || !(typeof value.toString != 'function' && typeof (value + '') == 'string')) && + (!isClassOf(ctor, 'Function') || ctor instanceof ctor)) { + // In most environments an object's own properties are iterated before + // its inherited properties. If the last iterated property is an object's + // own property then there are no inherited enumerable properties. + if (support.iteratesOwnFirst) { + forProps(value, function(subValue, subKey) { + result = subKey; + }); + return result === false || hasKey(value, result); + } + // IE < 9 iterates inherited properties before own properties. If the first + // iterated property is an object's own property then there are no inherited + // enumerable properties. + forProps(value, function(subValue, subKey) { + result = !hasKey(value, subKey); + return false; + }); + return result === false; + } + return result; + } + + /** + * Checks if a value can be safely coerced to a string. + * + * @private + * @param {Mixed} value The value to check. + * @returns {Boolean} Returns `true` if the value can be coerced, else `false`. + */ + function isStringable(value) { + return hasKey(value, 'toString') || isClassOf(value, 'String'); + } + + /** + * Wraps a function and passes `this` to the original function as the + * first argument. + * + * @private + * @param {Function} fn The function to be wrapped. + * @returns {Function} The new function. + */ + function methodize(fn) { + return function() { + var args = [this]; + args.push.apply(args, arguments); + return fn.apply(null, args); + }; + } + + /** + * A no-operation function. + * + * @private + */ + function noop() { + // no operation performed + } + + /** + * A wrapper around require() to suppress `module missing` errors. + * + * @private + * @param {String} id The module id. + * @returns {Mixed} The exported module or `null`. + */ + function req(id) { + try { + var result = freeExports && freeRequire(id); + } catch(e) { } + return result || null; + } + + /** + * Runs a snippet of JavaScript via script injection. + * + * @private + * @param {String} code The code to run. + */ + function runScript(code) { + var anchor = freeDefine ? define.amd : Benchmark, + script = doc.createElement('script'), + sibling = doc.getElementsByTagName('script')[0], + parent = sibling.parentNode, + prop = uid + 'runScript', + prefix = '(' + (freeDefine ? 'define.amd.' : 'Benchmark.') + prop + '||function(){})();'; + + // Firefox 2.0.0.2 cannot use script injection as intended because it executes + // asynchronously, but that's OK because script injection is only used to avoid + // the previously commented JaegerMonkey bug. + try { + // remove the inserted script *before* running the code to avoid differences + // in the expected script element count/order of the document. + script.appendChild(doc.createTextNode(prefix + code)); + anchor[prop] = function() { destroyElement(script); }; + } catch(e) { + parent = parent.cloneNode(false); + sibling = null; + script.text = code; + } + parent.insertBefore(script, sibling); + delete anchor[prop]; + } + + /** + * A helper function for setting options/event handlers. + * + * @private + * @param {Object} bench The benchmark instance. + * @param {Object} [options={}] Options object. + */ + function setOptions(bench, options) { + options = extend({}, bench.constructor.options, options); + bench.options = forOwn(options, function(value, key) { + if (value != null) { + // add event listeners + if (/^on[A-Z]/.test(key)) { + forEach(key.split(' '), function(key) { + bench.on(key.slice(2).toLowerCase(), value); + }); + } else if (!hasKey(bench, key)) { + bench[key] = deepClone(value); + } + } + }); + } + + /*--------------------------------------------------------------------------*/ + + /** + * Handles cycling/completing the deferred benchmark. + * + * @memberOf Benchmark.Deferred + */ + function resolve() { + var me = this, + clone = me.benchmark, + bench = clone._original; + + if (bench.aborted) { + // cycle() -> clone cycle/complete event -> compute()'s invoked bench.run() cycle/complete + me.teardown(); + clone.running = false; + cycle(me); + } + else if (++me.cycles < clone.count) { + // continue the test loop + if (support.timeout) { + // use setTimeout to avoid a call stack overflow if called recursively + setTimeout(function() { clone.compiled.call(me, timer); }, 0); + } else { + clone.compiled.call(me, timer); + } + } + else { + timer.stop(me); + me.teardown(); + delay(clone, function() { cycle(me); }); + } + } + + /*--------------------------------------------------------------------------*/ + + /** + * A deep clone utility. + * + * @static + * @memberOf Benchmark + * @param {Mixed} value The value to clone. + * @returns {Mixed} The cloned value. + */ + function deepClone(value) { + var accessor, + circular, + clone, + ctor, + descriptor, + extensible, + key, + length, + markerKey, + parent, + result, + source, + subIndex, + data = { 'value': value }, + index = 0, + marked = [], + queue = { 'length': 0 }, + unmarked = []; + + /** + * An easily detectable decorator for cloned values. + */ + function Marker(object) { + this.raw = object; + } + + /** + * The callback used by `forProps()`. + */ + function forPropsCallback(subValue, subKey) { + // exit early to avoid cloning the marker + if (subValue && subValue.constructor == Marker) { + return; + } + // add objects to the queue + if (subValue === Object(subValue)) { + queue[queue.length++] = { 'key': subKey, 'parent': clone, 'source': value }; + } + // assign non-objects + else { + try { + // will throw an error in strict mode if the property is read-only + clone[subKey] = subValue; + } catch(e) { } + } + } + + /** + * Gets an available marker key for the given object. + */ + function getMarkerKey(object) { + // avoid collisions with existing keys + var result = uid; + while (object[result] && object[result].constructor != Marker) { + result += 1; + } + return result; + } + + do { + key = data.key; + parent = data.parent; + source = data.source; + clone = value = source ? source[key] : data.value; + accessor = circular = descriptor = false; + + // create a basic clone to filter out functions, DOM elements, and + // other non `Object` objects + if (value === Object(value)) { + // use custom deep clone function if available + if (isClassOf(value.deepClone, 'Function')) { + clone = value.deepClone(); + } else { + ctor = value.constructor; + switch (toString.call(value)) { + case '[object Array]': + clone = new ctor(value.length); + break; + + case '[object Boolean]': + clone = new ctor(value == true); + break; + + case '[object Date]': + clone = new ctor(+value); + break; + + case '[object Object]': + isPlainObject(value) && (clone = {}); + break; + + case '[object Number]': + case '[object String]': + clone = new ctor(value); + break; + + case '[object RegExp]': + clone = ctor(value.source, + (value.global ? 'g' : '') + + (value.ignoreCase ? 'i' : '') + + (value.multiline ? 'm' : '')); + } + } + // continue clone if `value` doesn't have an accessor descriptor + // http://es5.github.com/#x8.10.1 + if (clone && clone != value && + !(descriptor = source && support.descriptors && getDescriptor(source, key), + accessor = descriptor && (descriptor.get || descriptor.set))) { + // use an existing clone (circular reference) + if ((extensible = isExtensible(value))) { + markerKey = getMarkerKey(value); + if (value[markerKey]) { + circular = clone = value[markerKey].raw; + } + } else { + // for frozen/sealed objects + for (subIndex = 0, length = unmarked.length; subIndex < length; subIndex++) { + data = unmarked[subIndex]; + if (data.object === value) { + circular = clone = data.clone; + break; + } + } + } + if (!circular) { + // mark object to allow quickly detecting circular references and tie it to its clone + if (extensible) { + value[markerKey] = new Marker(clone); + marked.push({ 'key': markerKey, 'object': value }); + } else { + // for frozen/sealed objects + unmarked.push({ 'clone': clone, 'object': value }); + } + // iterate over object properties + forProps(value, forPropsCallback, { 'which': 'all' }); + } + } + } + if (parent) { + // for custom property descriptors + if (accessor || (descriptor && !(descriptor.configurable && descriptor.enumerable && descriptor.writable))) { + if ('value' in descriptor) { + descriptor.value = clone; + } + setDescriptor(parent, key, descriptor); + } + // for default property descriptors + else { + parent[key] = clone; + } + } else { + result = clone; + } + } while ((data = queue[index++])); + + // remove markers + for (index = 0, length = marked.length; index < length; index++) { + data = marked[index]; + delete data.object[data.key]; + } + return result; + } + + /** + * An iteration utility for arrays and objects. + * Callbacks may terminate the loop by explicitly returning `false`. + * + * @static + * @memberOf Benchmark + * @param {Array|Object} object The object to iterate over. + * @param {Function} callback The function called per iteration. + * @param {Mixed} thisArg The `this` binding for the callback. + * @returns {Array|Object} Returns the object iterated over. + */ + function each(object, callback, thisArg) { + var result = object; + object = Object(object); + + var fn = callback, + index = -1, + length = object.length, + isSnapshot = !!(object.snapshotItem && (length = object.snapshotLength)), + isSplittable = (noCharByIndex || noCharByOwnIndex) && isClassOf(object, 'String'), + isConvertable = isSnapshot || isSplittable || 'item' in object, + origObject = object; + + // in Opera < 10.5 `hasKey(object, 'length')` returns `false` for NodeLists + if (length === length >>> 0) { + if (isConvertable) { + // the third argument of the callback is the original non-array object + callback = function(value, index) { + return fn.call(this, value, index, origObject); + }; + // in IE < 9 strings don't support accessing characters by index + if (isSplittable) { + object = object.split(''); + } else { + object = []; + while (++index < length) { + // in Safari 2 `index in object` is always `false` for NodeLists + object[index] = isSnapshot ? result.snapshotItem(index) : result[index]; + } + } + } + forEach(object, callback, thisArg); + } else { + forOwn(object, callback, thisArg); + } + return result; + } + + /** + * Copies enumerable properties from the source(s) object to the destination object. + * + * @static + * @memberOf Benchmark + * @param {Object} destination The destination object. + * @param {Object} [source={}] The source object. + * @returns {Object} The destination object. + */ + function extend(destination, source) { + // Chrome < 14 incorrectly sets `destination` to `undefined` when we `delete arguments[0]` + // http://code.google.com/p/v8/issues/detail?id=839 + var result = destination; + delete arguments[0]; + + forEach(arguments, function(source) { + forProps(source, function(value, key) { + result[key] = value; + }); + }); + return result; + } + + /** + * A generic `Array#filter` like method. + * + * @static + * @memberOf Benchmark + * @param {Array} array The array to iterate over. + * @param {Function|String} callback The function/alias called per iteration. + * @param {Mixed} thisArg The `this` binding for the callback. + * @returns {Array} A new array of values that passed callback filter. + * @example + * + * // get odd numbers + * Benchmark.filter([1, 2, 3, 4, 5], function(n) { + * return n % 2; + * }); // -> [1, 3, 5]; + * + * // get fastest benchmarks + * Benchmark.filter(benches, 'fastest'); + * + * // get slowest benchmarks + * Benchmark.filter(benches, 'slowest'); + * + * // get benchmarks that completed without erroring + * Benchmark.filter(benches, 'successful'); + */ + function filter(array, callback, thisArg) { + var result; + + if (callback == 'successful') { + // callback to exclude those that are errored, unrun, or have hz of Infinity + callback = function(bench) { return bench.cycles && isFinite(bench.hz); }; + } + else if (callback == 'fastest' || callback == 'slowest') { + // get successful, sort by period + margin of error, and filter fastest/slowest + result = filter(array, 'successful').sort(function(a, b) { + a = a.stats; b = b.stats; + return (a.mean + a.moe > b.mean + b.moe ? 1 : -1) * (callback == 'fastest' ? 1 : -1); + }); + result = filter(result, function(bench) { + return result[0].compare(bench) == 0; + }); + } + return result || reduce(array, function(result, value, index) { + return callback.call(thisArg, value, index, array) ? (result.push(value), result) : result; + }, []); + } + + /** + * A generic `Array#forEach` like method. + * Callbacks may terminate the loop by explicitly returning `false`. + * + * @static + * @memberOf Benchmark + * @param {Array} array The array to iterate over. + * @param {Function} callback The function called per iteration. + * @param {Mixed} thisArg The `this` binding for the callback. + * @returns {Array} Returns the array iterated over. + */ + function forEach(array, callback, thisArg) { + var index = -1, + length = (array = Object(array)).length >>> 0; + + if (thisArg !== undefined) { + callback = bind(callback, thisArg); + } + while (++index < length) { + if (index in array && + callback(array[index], index, array) === false) { + break; + } + } + return array; + } + + /** + * Iterates over an object's own properties, executing the `callback` for each. + * Callbacks may terminate the loop by explicitly returning `false`. + * + * @static + * @memberOf Benchmark + * @param {Object} object The object to iterate over. + * @param {Function} callback The function executed per own property. + * @param {Mixed} thisArg The `this` binding for the callback. + * @returns {Object} Returns the object iterated over. + */ + function forOwn(object, callback, thisArg) { + return forProps(object, callback, { 'bind': thisArg, 'which': 'own' }); + } + + /** + * Converts a number to a more readable comma-separated string representation. + * + * @static + * @memberOf Benchmark + * @param {Number} number The number to convert. + * @returns {String} The more readable string representation. + */ + function formatNumber(number) { + number = String(number).split('.'); + return number[0].replace(/(?=(?:\d{3})+$)(?!\b)/g, ',') + + (number[1] ? '.' + number[1] : ''); + } + + /** + * Checks if an object has the specified key as a direct property. + * + * @static + * @memberOf Benchmark + * @param {Object} object The object to check. + * @param {String} key The key to check for. + * @returns {Boolean} Returns `true` if key is a direct property, else `false`. + */ + function hasKey() { + // lazy define for worst case fallback (not as accurate) + hasKey = function(object, key) { + var parent = object != null && (object.constructor || Object).prototype; + return !!parent && key in Object(object) && !(key in parent && object[key] === parent[key]); + }; + // for modern browsers + if (isClassOf(hasOwnProperty, 'Function')) { + hasKey = function(object, key) { + return object != null && hasOwnProperty.call(object, key); + }; + } + // for Safari 2 + else if ({}.__proto__ == Object.prototype) { + hasKey = function(object, key) { + var result = false; + if (object != null) { + object = Object(object); + object.__proto__ = [object.__proto__, object.__proto__ = null, result = key in object][0]; + } + return result; + }; + } + return hasKey.apply(this, arguments); + } + + /** + * A generic `Array#indexOf` like method. + * + * @static + * @memberOf Benchmark + * @param {Array} array The array to iterate over. + * @param {Mixed} value The value to search for. + * @param {Number} [fromIndex=0] The index to start searching from. + * @returns {Number} The index of the matched value or `-1`. + */ + function indexOf(array, value, fromIndex) { + var index = toInteger(fromIndex), + length = (array = Object(array)).length >>> 0; + + index = (index < 0 ? max(0, length + index) : index) - 1; + while (++index < length) { + if (index in array && value === array[index]) { + return index; + } + } + return -1; + } + + /** + * Modify a string by replacing named tokens with matching object property values. + * + * @static + * @memberOf Benchmark + * @param {String} string The string to modify. + * @param {Object} object The template object. + * @returns {String} The modified string. + */ + function interpolate(string, object) { + forOwn(object, function(value, key) { + // escape regexp special characters in `key` + string = string.replace(RegExp('#\\{' + key.replace(/([.*+?^=!:${}()|[\]\/\\])/g, '\\$1') + '\\}', 'g'), value); + }); + return string; + } + + /** + * Invokes a method on all items in an array. + * + * @static + * @memberOf Benchmark + * @param {Array} benches Array of benchmarks to iterate over. + * @param {String|Object} name The name of the method to invoke OR options object. + * @param {Mixed} [arg1, arg2, ...] Arguments to invoke the method with. + * @returns {Array} A new array of values returned from each method invoked. + * @example + * + * // invoke `reset` on all benchmarks + * Benchmark.invoke(benches, 'reset'); + * + * // invoke `emit` with arguments + * Benchmark.invoke(benches, 'emit', 'complete', listener); + * + * // invoke `run(true)`, treat benchmarks as a queue, and register invoke callbacks + * Benchmark.invoke(benches, { + * + * // invoke the `run` method + * 'name': 'run', + * + * // pass a single argument + * 'args': true, + * + * // treat as queue, removing benchmarks from front of `benches` until empty + * 'queued': true, + * + * // called before any benchmarks have been invoked. + * 'onStart': onStart, + * + * // called between invoking benchmarks + * 'onCycle': onCycle, + * + * // called after all benchmarks have been invoked. + * 'onComplete': onComplete + * }); + */ + function invoke(benches, name) { + var args, + bench, + queued, + index = -1, + eventProps = { 'currentTarget': benches }, + options = { 'onStart': noop, 'onCycle': noop, 'onComplete': noop }, + result = map(benches, function(bench) { return bench; }); + + /** + * Invokes the method of the current object and if synchronous, fetches the next. + */ + function execute() { + var listeners, + async = isAsync(bench); + + if (async) { + // use `getNext` as the first listener + bench.on('complete', getNext); + listeners = bench.events.complete; + listeners.splice(0, 0, listeners.pop()); + } + // execute method + result[index] = isClassOf(bench && bench[name], 'Function') ? bench[name].apply(bench, args) : undefined; + // if synchronous return true until finished + return !async && getNext(); + } + + /** + * Fetches the next bench or executes `onComplete` callback. + */ + function getNext(event) { + var cycleEvent, + last = bench, + async = isAsync(last); + + if (async) { + last.off('complete', getNext); + last.emit('complete'); + } + // emit "cycle" event + eventProps.type = 'cycle'; + eventProps.target = last; + cycleEvent = Event(eventProps); + options.onCycle.call(benches, cycleEvent); + + // choose next benchmark if not exiting early + if (!cycleEvent.aborted && raiseIndex() !== false) { + bench = queued ? benches[0] : result[index]; + if (isAsync(bench)) { + delay(bench, execute); + } + else if (async) { + // resume execution if previously asynchronous but now synchronous + while (execute()) { } + } + else { + // continue synchronous execution + return true; + } + } else { + // emit "complete" event + eventProps.type = 'complete'; + options.onComplete.call(benches, Event(eventProps)); + } + // When used as a listener `event.aborted = true` will cancel the rest of + // the "complete" listeners because they were already called above and when + // used as part of `getNext` the `return false` will exit the execution while-loop. + if (event) { + event.aborted = true; + } else { + return false; + } + } + + /** + * Checks if invoking `Benchmark#run` with asynchronous cycles. + */ + function isAsync(object) { + // avoid using `instanceof` here because of IE memory leak issues with host objects + var async = args[0] && args[0].async; + return Object(object).constructor == Benchmark && name == 'run' && + ((async == null ? object.options.async : async) && support.timeout || object.defer); + } + + /** + * Raises `index` to the next defined index or returns `false`. + */ + function raiseIndex() { + var length = result.length; + if (queued) { + // if queued remove the previous bench and subsequent skipped non-entries + do { + ++index > 0 && shift.call(benches); + } while ((length = benches.length) && !('0' in benches)); + } + else { + while (++index < length && !(index in result)) { } + } + // if we reached the last index then return `false` + return (queued ? length : index < length) ? index : (index = false); + } + + // juggle arguments + if (isClassOf(name, 'String')) { + // 2 arguments (array, name) + args = slice.call(arguments, 2); + } else { + // 2 arguments (array, options) + options = extend(options, name); + name = options.name; + args = isClassOf(args = 'args' in options ? options.args : [], 'Array') ? args : [args]; + queued = options.queued; + } + + // start iterating over the array + if (raiseIndex() !== false) { + // emit "start" event + bench = result[index]; + eventProps.type = 'start'; + eventProps.target = bench; + options.onStart.call(benches, Event(eventProps)); + + // end early if the suite was aborted in an "onStart" listener + if (benches.aborted && benches.constructor == Suite && name == 'run') { + // emit "cycle" event + eventProps.type = 'cycle'; + options.onCycle.call(benches, Event(eventProps)); + // emit "complete" event + eventProps.type = 'complete'; + options.onComplete.call(benches, Event(eventProps)); + } + // else start + else { + if (isAsync(bench)) { + delay(bench, execute); + } else { + while (execute()) { } + } + } + } + return result; + } + + /** + * Creates a string of joined array values or object key-value pairs. + * + * @static + * @memberOf Benchmark + * @param {Array|Object} object The object to operate on. + * @param {String} [separator1=','] The separator used between key-value pairs. + * @param {String} [separator2=': '] The separator used between keys and values. + * @returns {String} The joined result. + */ + function join(object, separator1, separator2) { + var result = [], + length = (object = Object(object)).length, + arrayLike = length === length >>> 0; + + separator2 || (separator2 = ': '); + each(object, function(value, key) { + result.push(arrayLike ? value : key + separator2 + value); + }); + return result.join(separator1 || ','); + } + + /** + * A generic `Array#map` like method. + * + * @static + * @memberOf Benchmark + * @param {Array} array The array to iterate over. + * @param {Function} callback The function called per iteration. + * @param {Mixed} thisArg The `this` binding for the callback. + * @returns {Array} A new array of values returned by the callback. + */ + function map(array, callback, thisArg) { + return reduce(array, function(result, value, index) { + result[index] = callback.call(thisArg, value, index, array); + return result; + }, Array(Object(array).length >>> 0)); + } + + /** + * Retrieves the value of a specified property from all items in an array. + * + * @static + * @memberOf Benchmark + * @param {Array} array The array to iterate over. + * @param {String} property The property to pluck. + * @returns {Array} A new array of property values. + */ + function pluck(array, property) { + return map(array, function(object) { + return object == null ? undefined : object[property]; + }); + } + + /** + * A generic `Array#reduce` like method. + * + * @static + * @memberOf Benchmark + * @param {Array} array The array to iterate over. + * @param {Function} callback The function called per iteration. + * @param {Mixed} accumulator Initial value of the accumulator. + * @returns {Mixed} The accumulator. + */ + function reduce(array, callback, accumulator) { + var noaccum = arguments.length < 3; + forEach(array, function(value, index) { + accumulator = noaccum ? (noaccum = false, value) : callback(accumulator, value, index, array); + }); + return accumulator; + } + + /*--------------------------------------------------------------------------*/ + + /** + * Aborts all benchmarks in the suite. + * + * @name abort + * @memberOf Benchmark.Suite + * @returns {Object} The suite instance. + */ + function abortSuite() { + var event, + me = this, + resetting = calledBy.resetSuite; + + if (me.running) { + event = Event('abort'); + me.emit(event); + if (!event.cancelled || resetting) { + // avoid infinite recursion + calledBy.abortSuite = true; + me.reset(); + delete calledBy.abortSuite; + + if (!resetting) { + me.aborted = true; + invoke(me, 'abort'); + } + } + } + return me; + } + + /** + * Adds a test to the benchmark suite. + * + * @memberOf Benchmark.Suite + * @param {String} name A name to identify the benchmark. + * @param {Function|String} fn The test to benchmark. + * @param {Object} [options={}] Options object. + * @returns {Object} The benchmark instance. + * @example + * + * // basic usage + * suite.add(fn); + * + * // or using a name first + * suite.add('foo', fn); + * + * // or with options + * suite.add('foo', fn, { + * 'onCycle': onCycle, + * 'onComplete': onComplete + * }); + * + * // or name and options + * suite.add('foo', { + * 'fn': fn, + * 'onCycle': onCycle, + * 'onComplete': onComplete + * }); + * + * // or options only + * suite.add({ + * 'name': 'foo', + * 'fn': fn, + * 'onCycle': onCycle, + * 'onComplete': onComplete + * }); + */ + function add(name, fn, options) { + var me = this, + bench = Benchmark(name, fn, options), + event = Event({ 'type': 'add', 'target': bench }); + + if (me.emit(event), !event.cancelled) { + me.push(bench); + } + return me; + } + + /** + * Creates a new suite with cloned benchmarks. + * + * @name clone + * @memberOf Benchmark.Suite + * @param {Object} options Options object to overwrite cloned options. + * @returns {Object} The new suite instance. + */ + function cloneSuite(options) { + var me = this, + result = new me.constructor(extend({}, me.options, options)); + + // copy own properties + forOwn(me, function(value, key) { + if (!hasKey(result, key)) { + result[key] = value && isClassOf(value.clone, 'Function') + ? value.clone() + : deepClone(value); + } + }); + return result; + } + + /** + * An `Array#filter` like method. + * + * @name filter + * @memberOf Benchmark.Suite + * @param {Function|String} callback The function/alias called per iteration. + * @returns {Object} A new suite of benchmarks that passed callback filter. + */ + function filterSuite(callback) { + var me = this, + result = new me.constructor; + + result.push.apply(result, filter(me, callback)); + return result; + } + + /** + * Resets all benchmarks in the suite. + * + * @name reset + * @memberOf Benchmark.Suite + * @returns {Object} The suite instance. + */ + function resetSuite() { + var event, + me = this, + aborting = calledBy.abortSuite; + + if (me.running && !aborting) { + // no worries, `resetSuite()` is called within `abortSuite()` + calledBy.resetSuite = true; + me.abort(); + delete calledBy.resetSuite; + } + // reset if the state has changed + else if ((me.aborted || me.running) && + (me.emit(event = Event('reset')), !event.cancelled)) { + me.running = false; + if (!aborting) { + invoke(me, 'reset'); + } + } + return me; + } + + /** + * Runs the suite. + * + * @name run + * @memberOf Benchmark.Suite + * @param {Object} [options={}] Options object. + * @returns {Object} The suite instance. + * @example + * + * // basic usage + * suite.run(); + * + * // or with options + * suite.run({ 'async': true, 'queued': true }); + */ + function runSuite(options) { + var me = this; + + me.reset(); + me.running = true; + options || (options = {}); + + invoke(me, { + 'name': 'run', + 'args': options, + 'queued': options.queued, + 'onStart': function(event) { + me.emit(event); + }, + 'onCycle': function(event) { + var bench = event.target; + if (bench.error) { + me.emit({ 'type': 'error', 'target': bench }); + } + me.emit(event); + event.aborted = me.aborted; + }, + 'onComplete': function(event) { + me.running = false; + me.emit(event); + } + }); + return me; + } + + /*--------------------------------------------------------------------------*/ + + /** + * Executes all registered listeners of the specified event type. + * + * @memberOf Benchmark, Benchmark.Suite + * @param {String|Object} type The event type or object. + * @returns {Mixed} Returns the return value of the last listener executed. + */ + function emit(type) { + var listeners, + me = this, + event = Event(type), + events = me.events, + args = (arguments[0] = event, arguments); + + event.currentTarget || (event.currentTarget = me); + event.target || (event.target = me); + delete event.result; + + if (events && (listeners = hasKey(events, event.type) && events[event.type])) { + forEach(listeners.slice(), function(listener) { + if ((event.result = listener.apply(me, args)) === false) { + event.cancelled = true; + } + return !event.aborted; + }); + } + return event.result; + } + + /** + * Returns an array of event listeners for a given type that can be manipulated + * to add or remove listeners. + * + * @memberOf Benchmark, Benchmark.Suite + * @param {String} type The event type. + * @returns {Array} The listeners array. + */ + function listeners(type) { + var me = this, + events = me.events || (me.events = {}); + + return hasKey(events, type) ? events[type] : (events[type] = []); + } + + /** + * Unregisters a listener for the specified event type(s), + * or unregisters all listeners for the specified event type(s), + * or unregisters all listeners for all event types. + * + * @memberOf Benchmark, Benchmark.Suite + * @param {String} [type] The event type. + * @param {Function} [listener] The function to unregister. + * @returns {Object} The benchmark instance. + * @example + * + * // unregister a listener for an event type + * bench.off('cycle', listener); + * + * // unregister a listener for multiple event types + * bench.off('start cycle', listener); + * + * // unregister all listeners for an event type + * bench.off('cycle'); + * + * // unregister all listeners for multiple event types + * bench.off('start cycle complete'); + * + * // unregister all listeners for all event types + * bench.off(); + */ + function off(type, listener) { + var me = this, + events = me.events; + + events && each(type ? type.split(' ') : events, function(listeners, type) { + var index; + if (typeof listeners == 'string') { + type = listeners; + listeners = hasKey(events, type) && events[type]; + } + if (listeners) { + if (listener) { + index = indexOf(listeners, listener); + if (index > -1) { + listeners.splice(index, 1); + } + } else { + listeners.length = 0; + } + } + }); + return me; + } + + /** + * Registers a listener for the specified event type(s). + * + * @memberOf Benchmark, Benchmark.Suite + * @param {String} type The event type. + * @param {Function} listener The function to register. + * @returns {Object} The benchmark instance. + * @example + * + * // register a listener for an event type + * bench.on('cycle', listener); + * + * // register a listener for multiple event types + * bench.on('start cycle', listener); + */ + function on(type, listener) { + var me = this, + events = me.events || (me.events = {}); + + forEach(type.split(' '), function(type) { + (hasKey(events, type) + ? events[type] + : (events[type] = []) + ).push(listener); + }); + return me; + } + + /*--------------------------------------------------------------------------*/ + + /** + * Aborts the benchmark without recording times. + * + * @memberOf Benchmark + * @returns {Object} The benchmark instance. + */ + function abort() { + var event, + me = this, + resetting = calledBy.reset; + + if (me.running) { + event = Event('abort'); + me.emit(event); + if (!event.cancelled || resetting) { + // avoid infinite recursion + calledBy.abort = true; + me.reset(); + delete calledBy.abort; + + if (support.timeout) { + clearTimeout(me._timerId); + delete me._timerId; + } + if (!resetting) { + me.aborted = true; + me.running = false; + } + } + } + return me; + } + + /** + * Creates a new benchmark using the same test and options. + * + * @memberOf Benchmark + * @param {Object} options Options object to overwrite cloned options. + * @returns {Object} The new benchmark instance. + * @example + * + * var bizarro = bench.clone({ + * 'name': 'doppelganger' + * }); + */ + function clone(options) { + var me = this, + result = new me.constructor(extend({}, me, options)); + + // correct the `options` object + result.options = extend({}, me.options, options); + + // copy own custom properties + forOwn(me, function(value, key) { + if (!hasKey(result, key)) { + result[key] = deepClone(value); + } + }); + return result; + } + + /** + * Determines if a benchmark is faster than another. + * + * @memberOf Benchmark + * @param {Object} other The benchmark to compare. + * @returns {Number} Returns `-1` if slower, `1` if faster, and `0` if indeterminate. + */ + function compare(other) { + var critical, + zStat, + me = this, + sample1 = me.stats.sample, + sample2 = other.stats.sample, + size1 = sample1.length, + size2 = sample2.length, + maxSize = max(size1, size2), + minSize = min(size1, size2), + u1 = getU(sample1, sample2), + u2 = getU(sample2, sample1), + u = min(u1, u2); + + function getScore(xA, sampleB) { + return reduce(sampleB, function(total, xB) { + return total + (xB > xA ? 0 : xB < xA ? 1 : 0.5); + }, 0); + } + + function getU(sampleA, sampleB) { + return reduce(sampleA, function(total, xA) { + return total + getScore(xA, sampleB); + }, 0); + } + + function getZ(u) { + return (u - ((size1 * size2) / 2)) / sqrt((size1 * size2 * (size1 + size2 + 1)) / 12); + } + + // exit early if comparing the same benchmark + if (me == other) { + return 0; + } + // reject the null hyphothesis the two samples come from the + // same population (i.e. have the same median) if... + if (size1 + size2 > 30) { + // ...the z-stat is greater than 1.96 or less than -1.96 + // http://www.statisticslectures.com/topics/mannwhitneyu/ + zStat = getZ(u); + return abs(zStat) > 1.96 ? (zStat > 0 ? -1 : 1) : 0; + } + // ...the U value is less than or equal the critical U value + // http://www.geoib.com/mann-whitney-u-test.html + critical = maxSize < 5 || minSize < 3 ? 0 : uTable[maxSize][minSize - 3]; + return u <= critical ? (u == u1 ? 1 : -1) : 0; + } + + /** + * Reset properties and abort if running. + * + * @memberOf Benchmark + * @returns {Object} The benchmark instance. + */ + function reset() { + var data, + event, + me = this, + index = 0, + changes = { 'length': 0 }, + queue = { 'length': 0 }; + + if (me.running && !calledBy.abort) { + // no worries, `reset()` is called within `abort()` + calledBy.reset = true; + me.abort(); + delete calledBy.reset; + } + else { + // a non-recursive solution to check if properties have changed + // http://www.jslab.dk/articles/non.recursive.preorder.traversal.part4 + data = { 'destination': me, 'source': extend({}, me.constructor.prototype, me.options) }; + do { + forOwn(data.source, function(value, key) { + var changed, + destination = data.destination, + currValue = destination[key]; + + if (value && typeof value == 'object') { + if (isClassOf(value, 'Array')) { + // check if an array value has changed to a non-array value + if (!isClassOf(currValue, 'Array')) { + changed = currValue = []; + } + // or has changed its length + if (currValue.length != value.length) { + changed = currValue = currValue.slice(0, value.length); + currValue.length = value.length; + } + } + // check if an object has changed to a non-object value + else if (!currValue || typeof currValue != 'object') { + changed = currValue = {}; + } + // register a changed object + if (changed) { + changes[changes.length++] = { 'destination': destination, 'key': key, 'value': currValue }; + } + queue[queue.length++] = { 'destination': currValue, 'source': value }; + } + // register a changed primitive + else if (value !== currValue && !(value == null || isClassOf(value, 'Function'))) { + changes[changes.length++] = { 'destination': destination, 'key': key, 'value': value }; + } + }); + } + while ((data = queue[index++])); + + // if changed emit the `reset` event and if it isn't cancelled reset the benchmark + if (changes.length && (me.emit(event = Event('reset')), !event.cancelled)) { + forEach(changes, function(data) { + data.destination[data.key] = data.value; + }); + } + } + return me; + } + + /** + * Displays relevant benchmark information when coerced to a string. + * + * @name toString + * @memberOf Benchmark + * @returns {String} A string representation of the benchmark instance. + */ + function toStringBench() { + var me = this, + error = me.error, + hz = me.hz, + id = me.id, + stats = me.stats, + size = stats.sample.length, + pm = support.java ? '+/-' : '\xb1', + result = me.name || (isNaN(id) ? id : ''); + + if (error) { + result += ': ' + join(error); + } else { + result += ' x ' + formatNumber(hz.toFixed(hz < 100 ? 2 : 0)) + ' ops/sec ' + pm + + stats.rme.toFixed(2) + '% (' + size + ' run' + (size == 1 ? '' : 's') + ' sampled)'; + } + return result; + } + + /*--------------------------------------------------------------------------*/ + + /** + * Clocks the time taken to execute a test per cycle (secs). + * + * @private + * @param {Object} bench The benchmark instance. + * @returns {Number} The time taken. + */ + function clock() { + var applet, + options = Benchmark.options, + template = { 'begin': 's$=new n$', 'end': 'r$=(new n$-s$)/1e3', 'uid': uid }, + timers = [{ 'ns': timer.ns, 'res': max(0.0015, getRes('ms')), 'unit': 'ms' }]; + + // lazy define for hi-res timers + clock = function(clone) { + var deferred; + if (clone instanceof Deferred) { + deferred = clone; + clone = deferred.benchmark; + } + + var bench = clone._original, + fn = bench.fn, + fnArg = deferred ? getFirstArgument(fn) || 'deferred' : '', + stringable = isStringable(fn); + + var source = { + 'setup': getSource(bench.setup, preprocess('m$.setup()')), + 'fn': getSource(fn, preprocess('m$.fn(' + fnArg + ')')), + 'fnArg': fnArg, + 'teardown': getSource(bench.teardown, preprocess('m$.teardown()')) + }; + + var count = bench.count = clone.count, + decompilable = support.decompilation || stringable, + id = bench.id, + isEmpty = !(source.fn || stringable), + name = bench.name || (typeof id == 'number' ? '' : id), + ns = timer.ns, + result = 0; + + // init `minTime` if needed + clone.minTime = bench.minTime || (bench.minTime = bench.options.minTime = options.minTime); + + // repair nanosecond timer + // (some Chrome builds erase the `ns` variable after millions of executions) + if (applet) { + try { + ns.nanoTime(); + } catch(e) { + // use non-element to avoid issues with libs that augment them + ns = timer.ns = new applet.Packages.nano; + } + } + + // Compile in setup/teardown functions and the test loop. + // Create a new compiled test, instead of using the cached `bench.compiled`, + // to avoid potential engine optimizations enabled over the life of the test. + var compiled = bench.compiled = createFunction(preprocess('t$'), interpolate( + preprocess(deferred + ? 'var d$=this,#{fnArg}=d$,m$=d$.benchmark._original,f$=m$.fn,su$=m$.setup,td$=m$.teardown;' + + // when `deferred.cycles` is `0` then... + 'if(!d$.cycles){' + + // set `deferred.fn` + 'd$.fn=function(){var #{fnArg}=d$;if(typeof f$=="function"){try{#{fn}\n}catch(e$){f$(d$)}}else{#{fn}\n}};' + + // set `deferred.teardown` + 'd$.teardown=function(){d$.cycles=0;if(typeof td$=="function"){try{#{teardown}\n}catch(e$){td$()}}else{#{teardown}\n}};' + + // execute the benchmark's `setup` + 'if(typeof su$=="function"){try{#{setup}\n}catch(e$){su$()}}else{#{setup}\n};' + + // start timer + 't$.start(d$);' + + // execute `deferred.fn` and return a dummy object + '}d$.fn();return{}' + + : 'var r$,s$,m$=this,f$=m$.fn,i$=m$.count,n$=t$.ns;#{setup}\n#{begin};' + + 'while(i$--){#{fn}\n}#{end};#{teardown}\nreturn{elapsed:r$,uid:"#{uid}"}'), + source + )); + + try { + if (isEmpty) { + // Firefox may remove dead code from Function#toString results + // http://bugzil.la/536085 + throw new Error('The test "' + name + '" is empty. This may be the result of dead code removal.'); + } + else if (!deferred) { + // pretest to determine if compiled code is exits early, usually by a + // rogue `return` statement, by checking for a return object with the uid + bench.count = 1; + compiled = (compiled.call(bench, timer) || {}).uid == uid && compiled; + bench.count = count; + } + } catch(e) { + compiled = null; + clone.error = e || new Error(String(e)); + bench.count = count; + } + // fallback when a test exits early or errors during pretest + if (decompilable && !compiled && !deferred && !isEmpty) { + compiled = createFunction(preprocess('t$'), interpolate( + preprocess( + (clone.error && !stringable + ? 'var r$,s$,m$=this,f$=m$.fn,i$=m$.count' + : 'function f$(){#{fn}\n}var r$,s$,m$=this,i$=m$.count' + ) + + ',n$=t$.ns;#{setup}\n#{begin};m$.f$=f$;while(i$--){m$.f$()}#{end};' + + 'delete m$.f$;#{teardown}\nreturn{elapsed:r$}' + ), + source + )); + + try { + // pretest one more time to check for errors + bench.count = 1; + compiled.call(bench, timer); + bench.compiled = compiled; + bench.count = count; + delete clone.error; + } + catch(e) { + bench.count = count; + if (clone.error) { + compiled = null; + } else { + bench.compiled = compiled; + clone.error = e || new Error(String(e)); + } + } + } + // assign `compiled` to `clone` before calling in case a deferred benchmark + // immediately calls `deferred.resolve()` + clone.compiled = compiled; + // if no errors run the full test loop + if (!clone.error) { + result = compiled.call(deferred || bench, timer).elapsed; + } + return result; + }; + + /*------------------------------------------------------------------------*/ + + /** + * Gets the current timer's minimum resolution (secs). + */ + function getRes(unit) { + var measured, + begin, + count = 30, + divisor = 1e3, + ns = timer.ns, + sample = []; + + // get average smallest measurable time + while (count--) { + if (unit == 'us') { + divisor = 1e6; + if (ns.stop) { + ns.start(); + while (!(measured = ns.microseconds())) { } + } else if (ns[perfName]) { + divisor = 1e3; + measured = Function('n', 'var r,s=n.' + perfName + '();while(!(r=n.' + perfName + '()-s)){};return r')(ns); + } else { + begin = ns(); + while (!(measured = ns() - begin)) { } + } + } + else if (unit == 'ns') { + divisor = 1e9; + if (ns.nanoTime) { + begin = ns.nanoTime(); + while (!(measured = ns.nanoTime() - begin)) { } + } else { + begin = (begin = ns())[0] + (begin[1] / divisor); + while (!(measured = ((measured = ns())[0] + (measured[1] / divisor)) - begin)) { } + divisor = 1; + } + } + else { + begin = new ns; + while (!(measured = new ns - begin)) { } + } + // check for broken timers (nanoTime may have issues) + // http://alivebutsleepy.srnet.cz/unreliable-system-nanotime/ + if (measured > 0) { + sample.push(measured); + } else { + sample.push(Infinity); + break; + } + } + // convert to seconds + return getMean(sample) / divisor; + } + + /** + * Replaces all occurrences of `$` with a unique number and + * template tokens with content. + */ + function preprocess(code) { + return interpolate(code, template).replace(/\$/g, /\d+/.exec(uid)); + } + + /*------------------------------------------------------------------------*/ + + // detect nanosecond support from a Java applet + each(doc && doc.applets || [], function(element) { + return !(timer.ns = applet = 'nanoTime' in element && element); + }); + + // check type in case Safari returns an object instead of a number + try { + if (typeof timer.ns.nanoTime() == 'number') { + timers.push({ 'ns': timer.ns, 'res': getRes('ns'), 'unit': 'ns' }); + } + } catch(e) { } + + // detect Chrome's microsecond timer: + // enable benchmarking via the --enable-benchmarking command + // line switch in at least Chrome 7 to use chrome.Interval + try { + if ((timer.ns = new (window.chrome || window.chromium).Interval)) { + timers.push({ 'ns': timer.ns, 'res': getRes('us'), 'unit': 'us' }); + } + } catch(e) { } + + // detect `performance.now` microsecond resolution timer + if ((timer.ns = perfName && perfObject)) { + timers.push({ 'ns': timer.ns, 'res': getRes('us'), 'unit': 'us' }); + } + + // detect Node's nanosecond resolution timer available in Node >= 0.8 + if (processObject && typeof (timer.ns = processObject.hrtime) == 'function') { + timers.push({ 'ns': timer.ns, 'res': getRes('ns'), 'unit': 'ns' }); + } + + // detect Wade Simmons' Node microtime module + if (microtimeObject && typeof (timer.ns = microtimeObject.now) == 'function') { + timers.push({ 'ns': timer.ns, 'res': getRes('us'), 'unit': 'us' }); + } + + // pick timer with highest resolution + timer = reduce(timers, function(timer, other) { + return other.res < timer.res ? other : timer; + }); + + // remove unused applet + if (timer.unit != 'ns' && applet) { + applet = destroyElement(applet); + } + // error if there are no working timers + if (timer.res == Infinity) { + throw new Error('Benchmark.js was unable to find a working timer.'); + } + // use API of chosen timer + if (timer.unit == 'ns') { + if (timer.ns.nanoTime) { + extend(template, { + 'begin': 's$=n$.nanoTime()', + 'end': 'r$=(n$.nanoTime()-s$)/1e9' + }); + } else { + extend(template, { + 'begin': 's$=n$()', + 'end': 'r$=n$(s$);r$=r$[0]+(r$[1]/1e9)' + }); + } + } + else if (timer.unit == 'us') { + if (timer.ns.stop) { + extend(template, { + 'begin': 's$=n$.start()', + 'end': 'r$=n$.microseconds()/1e6' + }); + } else if (perfName) { + extend(template, { + 'begin': 's$=n$.' + perfName + '()', + 'end': 'r$=(n$.' + perfName + '()-s$)/1e3' + }); + } else { + extend(template, { + 'begin': 's$=n$()', + 'end': 'r$=(n$()-s$)/1e6' + }); + } + } + + // define `timer` methods + timer.start = createFunction(preprocess('o$'), + preprocess('var n$=this.ns,#{begin};o$.elapsed=0;o$.timeStamp=s$')); + + timer.stop = createFunction(preprocess('o$'), + preprocess('var n$=this.ns,s$=o$.timeStamp,#{end};o$.elapsed=r$')); + + // resolve time span required to achieve a percent uncertainty of at most 1% + // http://spiff.rit.edu/classes/phys273/uncert/uncert.html + options.minTime || (options.minTime = max(timer.res / 2 / 0.01, 0.05)); + return clock.apply(null, arguments); + } + + /*--------------------------------------------------------------------------*/ + + /** + * Computes stats on benchmark results. + * + * @private + * @param {Object} bench The benchmark instance. + * @param {Object} options The options object. + */ + function compute(bench, options) { + options || (options = {}); + + var async = options.async, + elapsed = 0, + initCount = bench.initCount, + minSamples = bench.minSamples, + queue = [], + sample = bench.stats.sample; + + /** + * Adds a clone to the queue. + */ + function enqueue() { + queue.push(bench.clone({ + '_original': bench, + 'events': { + 'abort': [update], + 'cycle': [update], + 'error': [update], + 'start': [update] + } + })); + } + + /** + * Updates the clone/original benchmarks to keep their data in sync. + */ + function update(event) { + var clone = this, + type = event.type; + + if (bench.running) { + if (type == 'start') { + // Note: `clone.minTime` prop is inited in `clock()` + clone.count = bench.initCount; + } + else { + if (type == 'error') { + bench.error = clone.error; + } + if (type == 'abort') { + bench.abort(); + bench.emit('cycle'); + } else { + event.currentTarget = event.target = bench; + bench.emit(event); + } + } + } else if (bench.aborted) { + // clear abort listeners to avoid triggering bench's abort/cycle again + clone.events.abort.length = 0; + clone.abort(); + } + } + + /** + * Determines if more clones should be queued or if cycling should stop. + */ + function evaluate(event) { + var critical, + df, + mean, + moe, + rme, + sd, + sem, + variance, + clone = event.target, + done = bench.aborted, + now = +new Date, + size = sample.push(clone.times.period), + maxedOut = size >= minSamples && (elapsed += now - clone.times.timeStamp) / 1e3 > bench.maxTime, + times = bench.times, + varOf = function(sum, x) { return sum + pow(x - mean, 2); }; + + // exit early for aborted or unclockable tests + if (done || clone.hz == Infinity) { + maxedOut = !(size = sample.length = queue.length = 0); + } + + if (!done) { + // sample mean (estimate of the population mean) + mean = getMean(sample); + // sample variance (estimate of the population variance) + variance = reduce(sample, varOf, 0) / (size - 1) || 0; + // sample standard deviation (estimate of the population standard deviation) + sd = sqrt(variance); + // standard error of the mean (a.k.a. the standard deviation of the sampling distribution of the sample mean) + sem = sd / sqrt(size); + // degrees of freedom + df = size - 1; + // critical value + critical = tTable[Math.round(df) || 1] || tTable.infinity; + // margin of error + moe = sem * critical; + // relative margin of error + rme = (moe / mean) * 100 || 0; + + extend(bench.stats, { + 'deviation': sd, + 'mean': mean, + 'moe': moe, + 'rme': rme, + 'sem': sem, + 'variance': variance + }); + + // Abort the cycle loop when the minimum sample size has been collected + // and the elapsed time exceeds the maximum time allowed per benchmark. + // We don't count cycle delays toward the max time because delays may be + // increased by browsers that clamp timeouts for inactive tabs. + // https://developer.mozilla.org/en/window.setTimeout#Inactive_tabs + if (maxedOut) { + // reset the `initCount` in case the benchmark is rerun + bench.initCount = initCount; + bench.running = false; + done = true; + times.elapsed = (now - times.timeStamp) / 1e3; + } + if (bench.hz != Infinity) { + bench.hz = 1 / mean; + times.cycle = mean * bench.count; + times.period = mean; + } + } + // if time permits, increase sample size to reduce the margin of error + if (queue.length < 2 && !maxedOut) { + enqueue(); + } + // abort the invoke cycle when done + event.aborted = done; + } + + // init queue and begin + enqueue(); + invoke(queue, { + 'name': 'run', + 'args': { 'async': async }, + 'queued': true, + 'onCycle': evaluate, + 'onComplete': function() { bench.emit('complete'); } + }); + } + + /*--------------------------------------------------------------------------*/ + + /** + * Cycles a benchmark until a run `count` can be established. + * + * @private + * @param {Object} clone The cloned benchmark instance. + * @param {Object} options The options object. + */ + function cycle(clone, options) { + options || (options = {}); + + var deferred; + if (clone instanceof Deferred) { + deferred = clone; + clone = clone.benchmark; + } + + var clocked, + cycles, + divisor, + event, + minTime, + period, + async = options.async, + bench = clone._original, + count = clone.count, + times = clone.times; + + // continue, if not aborted between cycles + if (clone.running) { + // `minTime` is set to `Benchmark.options.minTime` in `clock()` + cycles = ++clone.cycles; + clocked = deferred ? deferred.elapsed : clock(clone); + minTime = clone.minTime; + + if (cycles > bench.cycles) { + bench.cycles = cycles; + } + if (clone.error) { + event = Event('error'); + event.message = clone.error; + clone.emit(event); + if (!event.cancelled) { + clone.abort(); + } + } + } + + // continue, if not errored + if (clone.running) { + // time taken to complete last test cycle + bench.times.cycle = times.cycle = clocked; + // seconds per operation + period = bench.times.period = times.period = clocked / count; + // ops per second + bench.hz = clone.hz = 1 / period; + // avoid working our way up to this next time + bench.initCount = clone.initCount = count; + // do we need to do another cycle? + clone.running = clocked < minTime; + + if (clone.running) { + // tests may clock at `0` when `initCount` is a small number, + // to avoid that we set its count to something a bit higher + if (!clocked && (divisor = divisors[clone.cycles]) != null) { + count = floor(4e6 / divisor); + } + // calculate how many more iterations it will take to achive the `minTime` + if (count <= clone.count) { + count += Math.ceil((minTime - clocked) / period); + } + clone.running = count != Infinity; + } + } + // should we exit early? + event = Event('cycle'); + clone.emit(event); + if (event.aborted) { + clone.abort(); + } + // figure out what to do next + if (clone.running) { + // start a new cycle + clone.count = count; + if (deferred) { + clone.compiled.call(deferred, timer); + } else if (async) { + delay(clone, function() { cycle(clone, options); }); + } else { + cycle(clone); + } + } + else { + // fix TraceMonkey bug associated with clock fallbacks + // http://bugzil.la/509069 + if (support.browser) { + runScript(uid + '=1;delete ' + uid); + } + // done + clone.emit('complete'); + } + } + + /*--------------------------------------------------------------------------*/ + + /** + * Runs the benchmark. + * + * @memberOf Benchmark + * @param {Object} [options={}] Options object. + * @returns {Object} The benchmark instance. + * @example + * + * // basic usage + * bench.run(); + * + * // or with options + * bench.run({ 'async': true }); + */ + function run(options) { + var me = this, + event = Event('start'); + + // set `running` to `false` so `reset()` won't call `abort()` + me.running = false; + me.reset(); + me.running = true; + + me.count = me.initCount; + me.times.timeStamp = +new Date; + me.emit(event); + + if (!event.cancelled) { + options = { 'async': ((options = options && options.async) == null ? me.async : options) && support.timeout }; + + // for clones created within `compute()` + if (me._original) { + if (me.defer) { + Deferred(me); + } else { + cycle(me, options); + } + } + // for original benchmarks + else { + compute(me, options); + } + } + return me; + } + + /*--------------------------------------------------------------------------*/ + + // Firefox 1 erroneously defines variable and argument names of functions on + // the function itself as non-configurable properties with `undefined` values. + // The bugginess continues as the `Benchmark` constructor has an argument + // named `options` and Firefox 1 will not assign a value to `Benchmark.options`, + // making it non-writable in the process, unless it is the first property + // assigned by for-in loop of `extend()`. + extend(Benchmark, { + + /** + * The default options copied by benchmark instances. + * + * @static + * @memberOf Benchmark + * @type Object + */ + 'options': { + + /** + * A flag to indicate that benchmark cycles will execute asynchronously + * by default. + * + * @memberOf Benchmark.options + * @type Boolean + */ + 'async': false, + + /** + * A flag to indicate that the benchmark clock is deferred. + * + * @memberOf Benchmark.options + * @type Boolean + */ + 'defer': false, + + /** + * The delay between test cycles (secs). + * @memberOf Benchmark.options + * @type Number + */ + 'delay': 0.005, + + /** + * Displayed by Benchmark#toString when a `name` is not available + * (auto-generated if absent). + * + * @memberOf Benchmark.options + * @type String + */ + 'id': undefined, + + /** + * The default number of times to execute a test on a benchmark's first cycle. + * + * @memberOf Benchmark.options + * @type Number + */ + 'initCount': 1, + + /** + * The maximum time a benchmark is allowed to run before finishing (secs). + * Note: Cycle delays aren't counted toward the maximum time. + * + * @memberOf Benchmark.options + * @type Number + */ + 'maxTime': 5, + + /** + * The minimum sample size required to perform statistical analysis. + * + * @memberOf Benchmark.options + * @type Number + */ + 'minSamples': 5, + + /** + * The time needed to reduce the percent uncertainty of measurement to 1% (secs). + * + * @memberOf Benchmark.options + * @type Number + */ + 'minTime': 0, + + /** + * The name of the benchmark. + * + * @memberOf Benchmark.options + * @type String + */ + 'name': undefined, + + /** + * An event listener called when the benchmark is aborted. + * + * @memberOf Benchmark.options + * @type Function + */ + 'onAbort': undefined, + + /** + * An event listener called when the benchmark completes running. + * + * @memberOf Benchmark.options + * @type Function + */ + 'onComplete': undefined, + + /** + * An event listener called after each run cycle. + * + * @memberOf Benchmark.options + * @type Function + */ + 'onCycle': undefined, + + /** + * An event listener called when a test errors. + * + * @memberOf Benchmark.options + * @type Function + */ + 'onError': undefined, + + /** + * An event listener called when the benchmark is reset. + * + * @memberOf Benchmark.options + * @type Function + */ + 'onReset': undefined, + + /** + * An event listener called when the benchmark starts running. + * + * @memberOf Benchmark.options + * @type Function + */ + 'onStart': undefined + }, + + /** + * Platform object with properties describing things like browser name, + * version, and operating system. + * + * @static + * @memberOf Benchmark + * @type Object + */ + 'platform': req('platform') || window.platform || { + + /** + * The platform description. + * + * @memberOf Benchmark.platform + * @type String + */ + 'description': window.navigator && navigator.userAgent || null, + + /** + * The name of the browser layout engine. + * + * @memberOf Benchmark.platform + * @type String|Null + */ + 'layout': null, + + /** + * The name of the product hosting the browser. + * + * @memberOf Benchmark.platform + * @type String|Null + */ + 'product': null, + + /** + * The name of the browser/environment. + * + * @memberOf Benchmark.platform + * @type String|Null + */ + 'name': null, + + /** + * The name of the product's manufacturer. + * + * @memberOf Benchmark.platform + * @type String|Null + */ + 'manufacturer': null, + + /** + * The name of the operating system. + * + * @memberOf Benchmark.platform + * @type String|Null + */ + 'os': null, + + /** + * The alpha/beta release indicator. + * + * @memberOf Benchmark.platform + * @type String|Null + */ + 'prerelease': null, + + /** + * The browser/environment version. + * + * @memberOf Benchmark.platform + * @type String|Null + */ + 'version': null, + + /** + * Return platform description when the platform object is coerced to a string. + * + * @memberOf Benchmark.platform + * @type Function + * @returns {String} The platform description. + */ + 'toString': function() { + return this.description || ''; + } + }, + + /** + * The semantic version number. + * + * @static + * @memberOf Benchmark + * @type String + */ + 'version': '1.0.0', + + // an object of environment/feature detection flags + 'support': support, + + // clone objects + 'deepClone': deepClone, + + // iteration utility + 'each': each, + + // augment objects + 'extend': extend, + + // generic Array#filter + 'filter': filter, + + // generic Array#forEach + 'forEach': forEach, + + // generic own property iteration utility + 'forOwn': forOwn, + + // converts a number to a comma-separated string + 'formatNumber': formatNumber, + + // generic Object#hasOwnProperty + // (trigger hasKey's lazy define before assigning it to Benchmark) + 'hasKey': (hasKey(Benchmark, ''), hasKey), + + // generic Array#indexOf + 'indexOf': indexOf, + + // template utility + 'interpolate': interpolate, + + // invokes a method on each item in an array + 'invoke': invoke, + + // generic Array#join for arrays and objects + 'join': join, + + // generic Array#map + 'map': map, + + // retrieves a property value from each item in an array + 'pluck': pluck, + + // generic Array#reduce + 'reduce': reduce + }); + + /*--------------------------------------------------------------------------*/ + + extend(Benchmark.prototype, { + + /** + * The number of times a test was executed. + * + * @memberOf Benchmark + * @type Number + */ + 'count': 0, + + /** + * The number of cycles performed while benchmarking. + * + * @memberOf Benchmark + * @type Number + */ + 'cycles': 0, + + /** + * The number of executions per second. + * + * @memberOf Benchmark + * @type Number + */ + 'hz': 0, + + /** + * The compiled test function. + * + * @memberOf Benchmark + * @type Function|String + */ + 'compiled': undefined, + + /** + * The error object if the test failed. + * + * @memberOf Benchmark + * @type Object + */ + 'error': undefined, + + /** + * The test to benchmark. + * + * @memberOf Benchmark + * @type Function|String + */ + 'fn': undefined, + + /** + * A flag to indicate if the benchmark is aborted. + * + * @memberOf Benchmark + * @type Boolean + */ + 'aborted': false, + + /** + * A flag to indicate if the benchmark is running. + * + * @memberOf Benchmark + * @type Boolean + */ + 'running': false, + + /** + * Compiled into the test and executed immediately **before** the test loop. + * + * @memberOf Benchmark + * @type Function|String + * @example + * + * // basic usage + * var bench = Benchmark({ + * 'setup': function() { + * var c = this.count, + * element = document.getElementById('container'); + * while (c--) { + * element.appendChild(document.createElement('div')); + * } + * }, + * 'fn': function() { + * element.removeChild(element.lastChild); + * } + * }); + * + * // compiles to something like: + * var c = this.count, + * element = document.getElementById('container'); + * while (c--) { + * element.appendChild(document.createElement('div')); + * } + * var start = new Date; + * while (count--) { + * element.removeChild(element.lastChild); + * } + * var end = new Date - start; + * + * // or using strings + * var bench = Benchmark({ + * 'setup': '\ + * var a = 0;\n\ + * (function() {\n\ + * (function() {\n\ + * (function() {', + * 'fn': 'a += 1;', + * 'teardown': '\ + * }())\n\ + * }())\n\ + * }())' + * }); + * + * // compiles to something like: + * var a = 0; + * (function() { + * (function() { + * (function() { + * var start = new Date; + * while (count--) { + * a += 1; + * } + * var end = new Date - start; + * }()) + * }()) + * }()) + */ + 'setup': noop, + + /** + * Compiled into the test and executed immediately **after** the test loop. + * + * @memberOf Benchmark + * @type Function|String + */ + 'teardown': noop, + + /** + * An object of stats including mean, margin or error, and standard deviation. + * + * @memberOf Benchmark + * @type Object + */ + 'stats': { + + /** + * The margin of error. + * + * @memberOf Benchmark#stats + * @type Number + */ + 'moe': 0, + + /** + * The relative margin of error (expressed as a percentage of the mean). + * + * @memberOf Benchmark#stats + * @type Number + */ + 'rme': 0, + + /** + * The standard error of the mean. + * + * @memberOf Benchmark#stats + * @type Number + */ + 'sem': 0, + + /** + * The sample standard deviation. + * + * @memberOf Benchmark#stats + * @type Number + */ + 'deviation': 0, + + /** + * The sample arithmetic mean. + * + * @memberOf Benchmark#stats + * @type Number + */ + 'mean': 0, + + /** + * The array of sampled periods. + * + * @memberOf Benchmark#stats + * @type Array + */ + 'sample': [], + + /** + * The sample variance. + * + * @memberOf Benchmark#stats + * @type Number + */ + 'variance': 0 + }, + + /** + * An object of timing data including cycle, elapsed, period, start, and stop. + * + * @memberOf Benchmark + * @type Object + */ + 'times': { + + /** + * The time taken to complete the last cycle (secs). + * + * @memberOf Benchmark#times + * @type Number + */ + 'cycle': 0, + + /** + * The time taken to complete the benchmark (secs). + * + * @memberOf Benchmark#times + * @type Number + */ + 'elapsed': 0, + + /** + * The time taken to execute the test once (secs). + * + * @memberOf Benchmark#times + * @type Number + */ + 'period': 0, + + /** + * A timestamp of when the benchmark started (ms). + * + * @memberOf Benchmark#times + * @type Number + */ + 'timeStamp': 0 + }, + + // aborts benchmark (does not record times) + 'abort': abort, + + // creates a new benchmark using the same test and options + 'clone': clone, + + // compares benchmark's hertz with another + 'compare': compare, + + // executes listeners + 'emit': emit, + + // get listeners + 'listeners': listeners, + + // unregister listeners + 'off': off, + + // register listeners + 'on': on, + + // reset benchmark properties + 'reset': reset, + + // runs the benchmark + 'run': run, + + // pretty print benchmark info + 'toString': toStringBench + }); + + /*--------------------------------------------------------------------------*/ + + extend(Deferred.prototype, { + + /** + * The deferred benchmark instance. + * + * @memberOf Benchmark.Deferred + * @type Object + */ + 'benchmark': null, + + /** + * The number of deferred cycles performed while benchmarking. + * + * @memberOf Benchmark.Deferred + * @type Number + */ + 'cycles': 0, + + /** + * The time taken to complete the deferred benchmark (secs). + * + * @memberOf Benchmark.Deferred + * @type Number + */ + 'elapsed': 0, + + /** + * A timestamp of when the deferred benchmark started (ms). + * + * @memberOf Benchmark.Deferred + * @type Number + */ + 'timeStamp': 0, + + // cycles/completes the deferred benchmark + 'resolve': resolve + }); + + /*--------------------------------------------------------------------------*/ + + extend(Event.prototype, { + + /** + * A flag to indicate if the emitters listener iteration is aborted. + * + * @memberOf Benchmark.Event + * @type Boolean + */ + 'aborted': false, + + /** + * A flag to indicate if the default action is cancelled. + * + * @memberOf Benchmark.Event + * @type Boolean + */ + 'cancelled': false, + + /** + * The object whose listeners are currently being processed. + * + * @memberOf Benchmark.Event + * @type Object + */ + 'currentTarget': undefined, + + /** + * The return value of the last executed listener. + * + * @memberOf Benchmark.Event + * @type Mixed + */ + 'result': undefined, + + /** + * The object to which the event was originally emitted. + * + * @memberOf Benchmark.Event + * @type Object + */ + 'target': undefined, + + /** + * A timestamp of when the event was created (ms). + * + * @memberOf Benchmark.Event + * @type Number + */ + 'timeStamp': 0, + + /** + * The event type. + * + * @memberOf Benchmark.Event + * @type String + */ + 'type': '' + }); + + /*--------------------------------------------------------------------------*/ + + /** + * The default options copied by suite instances. + * + * @static + * @memberOf Benchmark.Suite + * @type Object + */ + Suite.options = { + + /** + * The name of the suite. + * + * @memberOf Benchmark.Suite.options + * @type String + */ + 'name': undefined + }; + + /*--------------------------------------------------------------------------*/ + + extend(Suite.prototype, { + + /** + * The number of benchmarks in the suite. + * + * @memberOf Benchmark.Suite + * @type Number + */ + 'length': 0, + + /** + * A flag to indicate if the suite is aborted. + * + * @memberOf Benchmark.Suite + * @type Boolean + */ + 'aborted': false, + + /** + * A flag to indicate if the suite is running. + * + * @memberOf Benchmark.Suite + * @type Boolean + */ + 'running': false, + + /** + * An `Array#forEach` like method. + * Callbacks may terminate the loop by explicitly returning `false`. + * + * @memberOf Benchmark.Suite + * @param {Function} callback The function called per iteration. + * @returns {Object} The suite iterated over. + */ + 'forEach': methodize(forEach), + + /** + * An `Array#indexOf` like method. + * + * @memberOf Benchmark.Suite + * @param {Mixed} value The value to search for. + * @returns {Number} The index of the matched value or `-1`. + */ + 'indexOf': methodize(indexOf), + + /** + * Invokes a method on all benchmarks in the suite. + * + * @memberOf Benchmark.Suite + * @param {String|Object} name The name of the method to invoke OR options object. + * @param {Mixed} [arg1, arg2, ...] Arguments to invoke the method with. + * @returns {Array} A new array of values returned from each method invoked. + */ + 'invoke': methodize(invoke), + + /** + * Converts the suite of benchmarks to a string. + * + * @memberOf Benchmark.Suite + * @param {String} [separator=','] A string to separate each element of the array. + * @returns {String} The string. + */ + 'join': [].join, + + /** + * An `Array#map` like method. + * + * @memberOf Benchmark.Suite + * @param {Function} callback The function called per iteration. + * @returns {Array} A new array of values returned by the callback. + */ + 'map': methodize(map), + + /** + * Retrieves the value of a specified property from all benchmarks in the suite. + * + * @memberOf Benchmark.Suite + * @param {String} property The property to pluck. + * @returns {Array} A new array of property values. + */ + 'pluck': methodize(pluck), + + /** + * Removes the last benchmark from the suite and returns it. + * + * @memberOf Benchmark.Suite + * @returns {Mixed} The removed benchmark. + */ + 'pop': [].pop, + + /** + * Appends benchmarks to the suite. + * + * @memberOf Benchmark.Suite + * @returns {Number} The suite's new length. + */ + 'push': [].push, + + /** + * Sorts the benchmarks of the suite. + * + * @memberOf Benchmark.Suite + * @param {Function} [compareFn=null] A function that defines the sort order. + * @returns {Object} The sorted suite. + */ + 'sort': [].sort, + + /** + * An `Array#reduce` like method. + * + * @memberOf Benchmark.Suite + * @param {Function} callback The function called per iteration. + * @param {Mixed} accumulator Initial value of the accumulator. + * @returns {Mixed} The accumulator. + */ + 'reduce': methodize(reduce), + + // aborts all benchmarks in the suite + 'abort': abortSuite, + + // adds a benchmark to the suite + 'add': add, + + // creates a new suite with cloned benchmarks + 'clone': cloneSuite, + + // executes listeners of a specified type + 'emit': emit, + + // creates a new suite of filtered benchmarks + 'filter': filterSuite, + + // get listeners + 'listeners': listeners, + + // unregister listeners + 'off': off, + + // register listeners + 'on': on, + + // resets all benchmarks in the suite + 'reset': resetSuite, + + // runs all benchmarks in the suite + 'run': runSuite, + + // array methods + 'concat': concat, + + 'reverse': reverse, + + 'shift': shift, + + 'slice': slice, + + 'splice': splice, + + 'unshift': unshift + }); + + /*--------------------------------------------------------------------------*/ + + // expose Deferred, Event and Suite + extend(Benchmark, { + 'Deferred': Deferred, + 'Event': Event, + 'Suite': Suite + }); + + // expose Benchmark + // some AMD build optimizers, like r.js, check for specific condition patterns like the following: + if (typeof define == 'function' && typeof define.amd == 'object' && define.amd) { + // define as an anonymous module so, through path mapping, it can be aliased + define(function() { + return Benchmark; + }); + } + // check for `exports` after `define` in case a build optimizer adds an `exports` object + else if (freeExports) { + // in Node.js or RingoJS v0.8.0+ + if (typeof module == 'object' && module && module.exports == freeExports) { + (module.exports = Benchmark).Benchmark = Benchmark; + } + // in Narwhal or RingoJS v0.7.0- + else { + freeExports.Benchmark = Benchmark; + } + } + // in a browser or Rhino + else { + // use square bracket notation so Closure Compiler won't munge `Benchmark` + // http://code.google.com/closure/compiler/docs/api-tutorial3.html#export + window['Benchmark'] = Benchmark; + } + + // trigger clock's lazy define early to avoid a security error + if (support.air) { + clock({ '_original': { 'fn': noop, 'count': 1, 'options': {} } }); + } +}(this)); diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/benchmark/doc/README.md b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/benchmark/doc/README.md new file mode 100644 index 0000000..5b8960a --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/benchmark/doc/README.md @@ -0,0 +1,2629 @@ +# Benchmark.js v1.0.0 + + + + + + +## `Benchmark` +* [`Benchmark`](#benchmarkname-fn--options) +* [`Benchmark.version`](#benchmarkversion) +* [`Benchmark.deepClone`](#benchmarkdeepclonevalue) +* [`Benchmark.each`](#benchmarkeachobject-callback-thisarg) +* [`Benchmark.extend`](#benchmarkextenddestination--source) +* [`Benchmark.filter`](#benchmarkfilterarray-callback-thisarg) +* [`Benchmark.forEach`](#benchmarkforeacharray-callback-thisarg) +* [`Benchmark.formatNumber`](#benchmarkformatnumbernumber) +* [`Benchmark.forOwn`](#benchmarkforownobject-callback-thisarg) +* [`Benchmark.hasKey`](#benchmarkhaskeyobject-key) +* [`Benchmark.indexOf`](#benchmarkindexofarray-value--fromindex0) +* [`Benchmark.interpolate`](#benchmarkinterpolatestring-object) +* [`Benchmark.invoke`](#benchmarkinvokebenches-name--arg1-arg2-) +* [`Benchmark.join`](#benchmarkjoinobject--separator1--separator2:) +* [`Benchmark.map`](#benchmarkmaparray-callback-thisarg) +* [`Benchmark.pluck`](#benchmarkpluckarray-property) +* [`Benchmark.reduce`](#benchmarkreducearray-callback-accumulator) + + + + + + +## `Benchmark.prototype` +* [`Benchmark.prototype.aborted`](#benchmarkprototypeaborted) +* [`Benchmark.prototype.compiled`](#benchmarkprototypecompiled) +* [`Benchmark.prototype.count`](#benchmarkprototypecount) +* [`Benchmark.prototype.cycles`](#benchmarkprototypecycles) +* [`Benchmark.prototype.fn`](#benchmarkprototypefn) +* [`Benchmark.prototype.hz`](#benchmarkprototypehz) +* [`Benchmark.prototype.running`](#benchmarkprototyperunning) +* [`Benchmark.prototype.setup`](#benchmarkprototypesetup) +* [`Benchmark.prototype.teardown`](#benchmarkprototypeteardown) +* [`Benchmark.prototype.abort`](#benchmarkprototypeabort) +* [`Benchmark.prototype.clone`](#benchmarkprototypecloneoptions) +* [`Benchmark.prototype.compare`](#benchmarkprototypecompareother) +* [`Benchmark.prototype.emit`](#benchmarkprototypeemittype) +* [`Benchmark.prototype.listeners`](#benchmarkprototypelistenerstype) +* [`Benchmark.prototype.off`](#benchmarkprototypeofftype-listener) +* [`Benchmark.prototype.on`](#benchmarkprototypeontype-listener) +* [`Benchmark.prototype.reset`](#benchmarkprototypereset) +* [`Benchmark.prototype.run`](#benchmarkprototyperunoptions) +* [`Benchmark.prototype.toString`](#benchmarkprototypetostring) + + + + + + +## `Benchmark.options` +* [`Benchmark.options`](#benchmarkoptions) +* [`Benchmark.options.async`](#benchmarkoptionsasync) +* [`Benchmark.options.defer`](#benchmarkoptionsdefer) +* [`Benchmark.options.delay`](#benchmarkoptionsdelay) +* [`Benchmark.options.id`](#benchmarkoptionsid) +* [`Benchmark.options.initCount`](#benchmarkoptionsinitcount) +* [`Benchmark.options.maxTime`](#benchmarkoptionsmaxtime) +* [`Benchmark.options.minSamples`](#benchmarkoptionsminsamples) +* [`Benchmark.options.minTime`](#benchmarkoptionsmintime) +* [`Benchmark.options.name`](#benchmarkoptionsname) +* [`Benchmark.options.onAbort`](#benchmarkoptionsonabort) +* [`Benchmark.options.onComplete`](#benchmarkoptionsoncomplete) +* [`Benchmark.options.onCycle`](#benchmarkoptionsoncycle) +* [`Benchmark.options.onError`](#benchmarkoptionsonerror) +* [`Benchmark.options.onReset`](#benchmarkoptionsonreset) +* [`Benchmark.options.onStart`](#benchmarkoptionsonstart) + + + + + + +## `Benchmark.platform` +* [`Benchmark.platform`](#benchmarkplatform) +* [`Benchmark.platform.description`](#benchmarkplatformdescription) +* [`Benchmark.platform.layout`](#benchmarkplatformlayout) +* [`Benchmark.platform.manufacturer`](#benchmarkplatformmanufacturer) +* [`Benchmark.platform.name`](#benchmarkplatformname) +* [`Benchmark.platform.os`](#benchmarkplatformos) +* [`Benchmark.platform.prerelease`](#benchmarkplatformprerelease) +* [`Benchmark.platform.product`](#benchmarkplatformproduct) +* [`Benchmark.platform.version`](#benchmarkplatformversion) +* [`Benchmark.platform.toString`](#benchmarkplatformtostring) + + + + + + +## `Benchmark.support` +* [`Benchmark.support`](#benchmarksupport) +* [`Benchmark.support.air`](#benchmarksupportair) +* [`Benchmark.support.argumentsClass`](#benchmarksupportargumentsclass) +* [`Benchmark.support.browser`](#benchmarksupportbrowser) +* [`Benchmark.support.charByIndex`](#benchmarksupportcharbyindex) +* [`Benchmark.support.charByOwnIndex`](#benchmarksupportcharbyownindex) +* [`Benchmark.support.decompilation`](#benchmarksupportdecompilation) +* [`Benchmark.support.descriptors`](#benchmarksupportdescriptors) +* [`Benchmark.support.getAllKeys`](#benchmarksupportgetallkeys) +* [`Benchmark.support.iteratesOwnLast`](#benchmarksupportiteratesownfirst) +* [`Benchmark.support.java`](#benchmarksupportjava) +* [`Benchmark.support.nodeClass`](#benchmarksupportnodeclass) +* [`Benchmark.support.timeout`](#benchmarksupporttimeout) + + + + + + +## `Benchmark.prototype.error` +* [`Benchmark.prototype.error`](#benchmarkprototypeerror) + + + + + + +## `Benchmark.prototype.stats` +* [`Benchmark.prototype.stats`](#benchmarkprototypestats) +* [`Benchmark.prototype.stats.deviation`](#benchmark-statsdeviation) +* [`Benchmark.prototype.stats.mean`](#benchmark-statsmean) +* [`Benchmark.prototype.stats.moe`](#benchmark-statsmoe) +* [`Benchmark.prototype.stats.rme`](#benchmark-statsrme) +* [`Benchmark.prototype.stats.sample`](#benchmark-statssample) +* [`Benchmark.prototype.stats.sem`](#benchmark-statssem) +* [`Benchmark.prototype.stats.variance`](#benchmark-statsvariance) + + + + + + +## `Benchmark.prototype.times` +* [`Benchmark.prototype.times`](#benchmarkprototypetimes) +* [`Benchmark.prototype.times.cycle`](#benchmark-timescycle) +* [`Benchmark.prototype.times.elapsed`](#benchmark-timeselapsed) +* [`Benchmark.prototype.times.period`](#benchmark-timesperiod) +* [`Benchmark.prototype.times.timeStamp`](#benchmark-timestimestamp) + + + + + + +## `Benchmark.Deferred` +* [`Benchmark.Deferred`](#benchmarkdeferredclone) + + + + + + +## `Benchmark.Deferred.prototype` +* [`Benchmark.Deferred.prototype.benchmark`](#benchmarkdeferredprototypebenchmark) +* [`Benchmark.Deferred.prototype.cycles`](#benchmarkdeferredprototypecycles) +* [`Benchmark.Deferred.prototype.elapsed`](#benchmarkdeferredprototypeelapsed) +* [`Benchmark.Deferred.prototype.resolve`](#benchmarkdeferredprototyperesolve) +* [`Benchmark.Deferred.prototype.timeStamp`](#benchmarkdeferredprototypetimestamp) + + + + + + +## `Benchmark.Event` +* [`Benchmark.Event`](#benchmarkeventtype) + + + + + + +## `Benchmark.Event.prototype` +* [`Benchmark.Event.prototype.aborted`](#benchmarkeventprototypeaborted) +* [`Benchmark.Event.prototype.cancelled`](#benchmarkeventprototypecancelled) +* [`Benchmark.Event.prototype.result`](#benchmarkeventprototyperesult) +* [`Benchmark.Event.prototype.timeStamp`](#benchmarkeventprototypetimestamp) +* [`Benchmark.Event.prototype.type`](#benchmarkeventprototypetype) + + + + + + +## `Benchmark.Event.prototype.currentTarget` +* [`Benchmark.Event.prototype.currentTarget`](#benchmarkeventprototypecurrenttarget) + + + + + + +## `Benchmark.Event.prototype.target` +* [`Benchmark.Event.prototype.target`](#benchmarkeventprototypetarget) + + + + + + +## `Benchmark.Suite` +* [`Benchmark.Suite`](#benchmarksuitename--options) + + + + + + +## `Benchmark.Suite.prototype` +* [`Benchmark.Suite.prototype.aborted`](#benchmarksuiteprototypeaborted) +* [`Benchmark.Suite.prototype.length`](#benchmarksuiteprototypelength) +* [`Benchmark.Suite.prototype.running`](#benchmarksuiteprototyperunning) +* [`Benchmark.Suite.prototype.abort`](#benchmarksuiteprototypeabort) +* [`Benchmark.Suite.prototype.add`](#benchmarksuiteprototypeaddname-fn--options) +* [`Benchmark.Suite.prototype.clone`](#benchmarksuiteprototypecloneoptions) +* [`Benchmark.Suite.prototype.emit`](#benchmarkprototypeemittype) +* [`Benchmark.Suite.prototype.filter`](#benchmarksuiteprototypefiltercallback) +* [`Benchmark.Suite.prototype.forEach`](#benchmarksuiteprototypeforeachcallback) +* [`Benchmark.Suite.prototype.indexOf`](#benchmarksuiteprototypeindexofvalue) +* [`Benchmark.Suite.prototype.invoke`](#benchmarksuiteprototypeinvokename--arg1-arg2-) +* [`Benchmark.Suite.prototype.join`](#benchmarksuiteprototypejoinseparator-) +* [`Benchmark.Suite.prototype.listeners`](#benchmarkprototypelistenerstype) +* [`Benchmark.Suite.prototype.map`](#benchmarksuiteprototypemapcallback) +* [`Benchmark.Suite.prototype.off`](#benchmarkprototypeofftype-listener) +* [`Benchmark.Suite.prototype.on`](#benchmarkprototypeontype-listener) +* [`Benchmark.Suite.prototype.pluck`](#benchmarksuiteprototypepluckproperty) +* [`Benchmark.Suite.prototype.pop`](#benchmarksuiteprototypepop) +* [`Benchmark.Suite.prototype.push`](#benchmarksuiteprototypepush) +* [`Benchmark.Suite.prototype.reduce`](#benchmarksuiteprototypereducecallback-accumulator) +* [`Benchmark.Suite.prototype.reset`](#benchmarksuiteprototypereset) +* [`Benchmark.Suite.prototype.reverse`](#benchmarksuiteprototypereverse) +* [`Benchmark.Suite.prototype.run`](#benchmarksuiteprototyperunoptions) +* [`Benchmark.Suite.prototype.shift`](#benchmarksuiteprototypeshift) +* [`Benchmark.Suite.prototype.slice`](#benchmarksuiteprototypeslicestart-end) +* [`Benchmark.Suite.prototype.sort`](#benchmarksuiteprototypesortcomparefnnull) +* [`Benchmark.Suite.prototype.splice`](#benchmarksuiteprototypesplicestart-deletecount--val1-val2-) +* [`Benchmark.Suite.prototype.unshift`](#benchmarksuiteprototypeunshift) + + + + + + +## `Benchmark.Suite.options` +* [`Benchmark.Suite.options`](#benchmarksuiteoptions) +* [`Benchmark.Suite.options.name`](#benchmarksuiteoptionsname) + + + + + + + + + + + + +## `Benchmark` + + + +### `Benchmark(name, fn [, options={}])` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L404 "View in source") [Ⓣ][1] + +The Benchmark constructor. + +#### Arguments +1. `name` *(String)*: A name to identify the benchmark. +2. `fn` *(Function|String)*: The test to benchmark. +3. `[options={}]` *(Object)*: Options object. + +#### Example +~~~ js +// basic usage (the `new` operator is optional) +var bench = new Benchmark(fn); + +// or using a name first +var bench = new Benchmark('foo', fn); + +// or with options +var bench = new Benchmark('foo', fn, { + + // displayed by Benchmark#toString if `name` is not available + 'id': 'xyz', + + // called when the benchmark starts running + 'onStart': onStart, + + // called after each run cycle + 'onCycle': onCycle, + + // called when aborted + 'onAbort': onAbort, + + // called when a test errors + 'onError': onError, + + // called when reset + 'onReset': onReset, + + // called when the benchmark completes running + 'onComplete': onComplete, + + // compiled/called before the test loop + 'setup': setup, + + // compiled/called after the test loop + 'teardown': teardown +}); + +// or name and options +var bench = new Benchmark('foo', { + + // a flag to indicate the benchmark is deferred + 'defer': true, + + // benchmark test function + 'fn': function(deferred) { + // call resolve() when the deferred test is finished + deferred.resolve(); + } +}); + +// or options only +var bench = new Benchmark({ + + // benchmark name + 'name': 'foo', + + // benchmark test as a string + 'fn': '[1,2,3,4].sort()' +}); + +// a test's `this` binding is set to the benchmark instance +var bench = new Benchmark('foo', function() { + 'My name is '.concat(this.name); // My name is foo +}); +~~~ + +* * * + + + + + + +### `Benchmark.version` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3267 "View in source") [Ⓣ][1] + +*(String)*: The semantic version number. + +* * * + + + + + + +### `Benchmark.deepClone(value)` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L1225 "View in source") [Ⓣ][1] + +A deep clone utility. + +#### Arguments +1. `value` *(Mixed)*: The value to clone. + +#### Returns +*(Mixed)*: The cloned value. + +* * * + + + + + + +### `Benchmark.each(object, callback, thisArg)` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L1400 "View in source") [Ⓣ][1] + +An iteration utility for arrays and objects. Callbacks may terminate the loop by explicitly returning `false`. + +#### Arguments +1. `object` *(Array|Object)*: The object to iterate over. +2. `callback` *(Function)*: The function called per iteration. +3. `thisArg` *(Mixed)*: The `this` binding for the callback. + +#### Returns +*(Array, Object)*: Returns the object iterated over. + +* * * + + + + + + +### `Benchmark.extend(destination [, source={}])` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L1446 "View in source") [Ⓣ][1] + +Copies enumerable properties from the source(s) object to the destination object. + +#### Arguments +1. `destination` *(Object)*: The destination object. +2. `[source={}]` *(Object)*: The source object. + +#### Returns +*(Object)*: The destination object. + +* * * + + + + + + +### `Benchmark.filter(array, callback, thisArg)` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L1485 "View in source") [Ⓣ][1] + +A generic `Array#filter` like method. + +#### Arguments +1. `array` *(Array)*: The array to iterate over. +2. `callback` *(Function|String)*: The function/alias called per iteration. +3. `thisArg` *(Mixed)*: The `this` binding for the callback. + +#### Returns +*(Array)*: A new array of values that passed callback filter. + +#### Example +~~~ js +// get odd numbers +Benchmark.filter([1, 2, 3, 4, 5], function(n) { + return n % 2; +}); // -> [1, 3, 5]; + +// get fastest benchmarks +Benchmark.filter(benches, 'fastest'); + +// get slowest benchmarks +Benchmark.filter(benches, 'slowest'); + +// get benchmarks that completed without erroring +Benchmark.filter(benches, 'successful'); +~~~ + +* * * + + + + + + +### `Benchmark.forEach(array, callback, thisArg)` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L1518 "View in source") [Ⓣ][1] + +A generic `Array#forEach` like method. Callbacks may terminate the loop by explicitly returning `false`. + +#### Arguments +1. `array` *(Array)*: The array to iterate over. +2. `callback` *(Function)*: The function called per iteration. +3. `thisArg` *(Mixed)*: The `this` binding for the callback. + +#### Returns +*(Array)*: Returns the array iterated over. + +* * * + + + + + + +### `Benchmark.formatNumber(number)` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L1557 "View in source") [Ⓣ][1] + +Converts a number to a more readable comma-separated string representation. + +#### Arguments +1. `number` *(Number)*: The number to convert. + +#### Returns +*(String)*: The more readable string representation. + +* * * + + + + + + +### `Benchmark.forOwn(object, callback, thisArg)` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L1545 "View in source") [Ⓣ][1] + +Iterates over an object's own properties, executing the `callback` for each. Callbacks may terminate the loop by explicitly returning `false`. + +#### Arguments +1. `object` *(Object)*: The object to iterate over. +2. `callback` *(Function)*: The function executed per own property. +3. `thisArg` *(Mixed)*: The `this` binding for the callback. + +#### Returns +*(Object)*: Returns the object iterated over. + +* * * + + + + + + +### `Benchmark.hasKey(object, key)` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L1572 "View in source") [Ⓣ][1] + +Checks if an object has the specified key as a direct property. + +#### Arguments +1. `object` *(Object)*: The object to check. +2. `key` *(String)*: The key to check for. + +#### Returns +*(Boolean)*: Returns `true` if key is a direct property, else `false`. + +* * * + + + + + + +### `Benchmark.indexOf(array, value [, fromIndex=0])` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L1608 "View in source") [Ⓣ][1] + +A generic `Array#indexOf` like method. + +#### Arguments +1. `array` *(Array)*: The array to iterate over. +2. `value` *(Mixed)*: The value to search for. +3. `[fromIndex=0]` *(Number)*: The index to start searching from. + +#### Returns +*(Number)*: The index of the matched value or `-1`. + +* * * + + + + + + +### `Benchmark.interpolate(string, object)` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L1630 "View in source") [Ⓣ][1] + +Modify a string by replacing named tokens with matching object property values. + +#### Arguments +1. `string` *(String)*: The string to modify. +2. `object` *(Object)*: The template object. + +#### Returns +*(String)*: The modified string. + +* * * + + + + + + +### `Benchmark.invoke(benches, name [, arg1, arg2, ...])` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L1677 "View in source") [Ⓣ][1] + +Invokes a method on all items in an array. + +#### Arguments +1. `benches` *(Array)*: Array of benchmarks to iterate over. +2. `name` *(String|Object)*: The name of the method to invoke OR options object. +3. `[arg1, arg2, ...]` *(Mixed)*: Arguments to invoke the method with. + +#### Returns +*(Array)*: A new array of values returned from each method invoked. + +#### Example +~~~ js +// invoke `reset` on all benchmarks +Benchmark.invoke(benches, 'reset'); + +// invoke `emit` with arguments +Benchmark.invoke(benches, 'emit', 'complete', listener); + +// invoke `run(true)`, treat benchmarks as a queue, and register invoke callbacks +Benchmark.invoke(benches, { + + // invoke the `run` method + 'name': 'run', + + // pass a single argument + 'args': true, + + // treat as queue, removing benchmarks from front of `benches` until empty + 'queued': true, + + // called before any benchmarks have been invoked. + 'onStart': onStart, + + // called between invoking benchmarks + 'onCycle': onCycle, + + // called after all benchmarks have been invoked. + 'onComplete': onComplete +}); +~~~ + +* * * + + + + + + +### `Benchmark.join(object [, separator1=',', separator2=': '])` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L1831 "View in source") [Ⓣ][1] + +Creates a string of joined array values or object key-value pairs. + +#### Arguments +1. `object` *(Array|Object)*: The object to operate on. +2. `[separator1=',']` *(String)*: The separator used between key-value pairs. +3. `[separator2=': ']` *(String)*: The separator used between keys and values. + +#### Returns +*(String)*: The joined result. + +* * * + + + + + + +### `Benchmark.map(array, callback, thisArg)` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L1853 "View in source") [Ⓣ][1] + +A generic `Array#map` like method. + +#### Arguments +1. `array` *(Array)*: The array to iterate over. +2. `callback` *(Function)*: The function called per iteration. +3. `thisArg` *(Mixed)*: The `this` binding for the callback. + +#### Returns +*(Array)*: A new array of values returned by the callback. + +* * * + + + + + + +### `Benchmark.pluck(array, property)` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L1869 "View in source") [Ⓣ][1] + +Retrieves the value of a specified property from all items in an array. + +#### Arguments +1. `array` *(Array)*: The array to iterate over. +2. `property` *(String)*: The property to pluck. + +#### Returns +*(Array)*: A new array of property values. + +* * * + + + + + + +### `Benchmark.reduce(array, callback, accumulator)` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L1885 "View in source") [Ⓣ][1] + +A generic `Array#reduce` like method. + +#### Arguments +1. `array` *(Array)*: The array to iterate over. +2. `callback` *(Function)*: The function called per iteration. +3. `accumulator` *(Mixed)*: Initial value of the accumulator. + +#### Returns +*(Mixed)*: The accumulator. + +* * * + + + + + + + + + +## `Benchmark.prototype` + + + +### `Benchmark.prototype.aborted` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3377 "View in source") [Ⓣ][1] + +*(Boolean)*: A flag to indicate if the benchmark is aborted. + +* * * + + + + + + +### `Benchmark.prototype.compiled` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3353 "View in source") [Ⓣ][1] + +*(Function, String)*: The compiled test function. + +* * * + + + + + + +### `Benchmark.prototype.count` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3329 "View in source") [Ⓣ][1] + +*(Number)*: The number of times a test was executed. + +* * * + + + + + + +### `Benchmark.prototype.cycles` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3337 "View in source") [Ⓣ][1] + +*(Number)*: The number of cycles performed while benchmarking. + +* * * + + + + + + +### `Benchmark.prototype.fn` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3369 "View in source") [Ⓣ][1] + +*(Function, String)*: The test to benchmark. + +* * * + + + + + + +### `Benchmark.prototype.hz` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3345 "View in source") [Ⓣ][1] + +*(Number)*: The number of executions per second. + +* * * + + + + + + +### `Benchmark.prototype.running` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3385 "View in source") [Ⓣ][1] + +*(Boolean)*: A flag to indicate if the benchmark is running. + +* * * + + + + + + +### `Benchmark.prototype.setup` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3448 "View in source") [Ⓣ][1] + +*(Function, String)*: Compiled into the test and executed immediately **before** the test loop. + +#### Example +~~~ js +// basic usage +var bench = Benchmark({ + 'setup': function() { + var c = this.count, + element = document.getElementById('container'); + while (c--) { + element.appendChild(document.createElement('div')); + } + }, + 'fn': function() { + element.removeChild(element.lastChild); + } +}); + +// compiles to something like: +var c = this.count, + element = document.getElementById('container'); +while (c--) { + element.appendChild(document.createElement('div')); +} +var start = new Date; +while (count--) { + element.removeChild(element.lastChild); +} +var end = new Date - start; + +// or using strings +var bench = Benchmark({ + 'setup': '\ + var a = 0;\n\ + (function() {\n\ + (function() {\n\ + (function() {', + 'fn': 'a += 1;', + 'teardown': '\ + }())\n\ + }())\n\ + }())' +}); + +// compiles to something like: +var a = 0; +(function() { + (function() { + (function() { + var start = new Date; + while (count--) { + a += 1; + } + var end = new Date - start; + }()) + }()) +}()) +~~~ + +* * * + + + + + + +### `Benchmark.prototype.teardown` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3456 "View in source") [Ⓣ][1] + +*(Function, String)*: Compiled into the test and executed immediately **after** the test loop. + +* * * + + + + + + +### `Benchmark.prototype.abort()` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L2218 "View in source") [Ⓣ][1] + +Aborts the benchmark without recording times. + +#### Returns +*(Object)*: The benchmark instance. + +* * * + + + + + + +### `Benchmark.prototype.clone(options)` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L2257 "View in source") [Ⓣ][1] + +Creates a new benchmark using the same test and options. + +#### Arguments +1. `options` *(Object)*: Options object to overwrite cloned options. + +#### Returns +*(Object)*: The new benchmark instance. + +#### Example +~~~ js +var bizarro = bench.clone({ + 'name': 'doppelganger' +}); +~~~ + +* * * + + + + + + +### `Benchmark.prototype.compare(other)` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L2280 "View in source") [Ⓣ][1] + +Determines if a benchmark is faster than another. + +#### Arguments +1. `other` *(Object)*: The benchmark to compare. + +#### Returns +*(Number)*: Returns `-1` if slower, `1` if faster, and `0` if indeterminate. + +* * * + + + + + + +### `Benchmark.Suite.prototype.emit(type)` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L2095 "View in source") [Ⓣ][1] + +Executes all registered listeners of the specified event type. + +#### Arguments +1. `type` *(String|Object)*: The event type or object. + +#### Returns +*(Mixed)*: Returns the return value of the last listener executed. + +* * * + + + + + + +### `Benchmark.Suite.prototype.listeners(type)` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L2125 "View in source") [Ⓣ][1] + +Returns an array of event listeners for a given type that can be manipulated to add or remove listeners. + +#### Arguments +1. `type` *(String)*: The event type. + +#### Returns +*(Array)*: The listeners array. + +* * * + + + + + + +### `Benchmark.Suite.prototype.off([type, listener])` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L2158 "View in source") [Ⓣ][1] + +Unregisters a listener for the specified event type(s), or unregisters all listeners for the specified event type(s), or unregisters all listeners for all event types. + +#### Arguments +1. `[type]` *(String)*: The event type. +2. `[listener]` *(Function)*: The function to unregister. + +#### Returns +*(Object)*: The benchmark instance. + +#### Example +~~~ js +// unregister a listener for an event type +bench.off('cycle', listener); + +// unregister a listener for multiple event types +bench.off('start cycle', listener); + +// unregister all listeners for an event type +bench.off('cycle'); + +// unregister all listeners for multiple event types +bench.off('start cycle complete'); + +// unregister all listeners for all event types +bench.off(); +~~~ + +* * * + + + + + + +### `Benchmark.Suite.prototype.on(type, listener)` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L2197 "View in source") [Ⓣ][1] + +Registers a listener for the specified event type(s). + +#### Arguments +1. `type` *(String)*: The event type. +2. `listener` *(Function)*: The function to register. + +#### Returns +*(Object)*: The benchmark instance. + +#### Example +~~~ js +// register a listener for an event type +bench.on('cycle', listener); + +// register a listener for multiple event types +bench.on('start cycle', listener); +~~~ + +* * * + + + + + + +### `Benchmark.prototype.reset()` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L2334 "View in source") [Ⓣ][1] + +Reset properties and abort if running. + +#### Returns +*(Object)*: The benchmark instance. + +* * * + + + + + + +### `Benchmark.prototype.run([options={}])` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3000 "View in source") [Ⓣ][1] + +Runs the benchmark. + +#### Arguments +1. `[options={}]` *(Object)*: Options object. + +#### Returns +*(Object)*: The benchmark instance. + +#### Example +~~~ js +// basic usage +bench.run(); + +// or with options +bench.run({ 'async': true }); +~~~ + +* * * + + + + + + +### `Benchmark.prototype.toString()` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L2405 "View in source") [Ⓣ][1] + +Displays relevant benchmark information when coerced to a string. + +#### Returns +*(String)*: A string representation of the benchmark instance. + +* * * + + + + + + + + + +## `Benchmark.options` + + + +### `Benchmark.options` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3049 "View in source") [Ⓣ][1] + +*(Object)*: The default options copied by benchmark instances. + +* * * + + + + + + +### `Benchmark.options.async` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3058 "View in source") [Ⓣ][1] + +*(Boolean)*: A flag to indicate that benchmark cycles will execute asynchronously by default. + +* * * + + + + + + +### `Benchmark.options.defer` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3066 "View in source") [Ⓣ][1] + +*(Boolean)*: A flag to indicate that the benchmark clock is deferred. + +* * * + + + + + + +### `Benchmark.options.delay` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3073 "View in source") [Ⓣ][1] + +*(Number)*: The delay between test cycles *(secs)*. + +* * * + + + + + + +### `Benchmark.options.id` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3082 "View in source") [Ⓣ][1] + +*(String)*: Displayed by Benchmark#toString when a `name` is not available *(auto-generated if absent)*. + +* * * + + + + + + +### `Benchmark.options.initCount` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3090 "View in source") [Ⓣ][1] + +*(Number)*: The default number of times to execute a test on a benchmark's first cycle. + +* * * + + + + + + +### `Benchmark.options.maxTime` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3099 "View in source") [Ⓣ][1] + +*(Number)*: The maximum time a benchmark is allowed to run before finishing *(secs)*. Note: Cycle delays aren't counted toward the maximum time. + +* * * + + + + + + +### `Benchmark.options.minSamples` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3107 "View in source") [Ⓣ][1] + +*(Number)*: The minimum sample size required to perform statistical analysis. + +* * * + + + + + + +### `Benchmark.options.minTime` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3115 "View in source") [Ⓣ][1] + +*(Number)*: The time needed to reduce the percent uncertainty of measurement to `1`% *(secs)*. + +* * * + + + + + + +### `Benchmark.options.name` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3123 "View in source") [Ⓣ][1] + +*(String)*: The name of the benchmark. + +* * * + + + + + + +### `Benchmark.options.onAbort` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3131 "View in source") [Ⓣ][1] + +An event listener called when the benchmark is aborted. + +* * * + + + + + + +### `Benchmark.options.onComplete` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3139 "View in source") [Ⓣ][1] + +An event listener called when the benchmark completes running. + +* * * + + + + + + +### `Benchmark.options.onCycle` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3147 "View in source") [Ⓣ][1] + +An event listener called after each run cycle. + +* * * + + + + + + +### `Benchmark.options.onError` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3155 "View in source") [Ⓣ][1] + +An event listener called when a test errors. + +* * * + + + + + + +### `Benchmark.options.onReset` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3163 "View in source") [Ⓣ][1] + +An event listener called when the benchmark is reset. + +* * * + + + + + + +### `Benchmark.options.onStart` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3171 "View in source") [Ⓣ][1] + +An event listener called when the benchmark starts running. + +* * * + + + + + + + + + +## `Benchmark.platform` + + + +### `Benchmark.platform` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3182 "View in source") [Ⓣ][1] + +*(Object)*: Platform object with properties describing things like browser name, version, and operating system. + +* * * + + + + + + +### `Benchmark.platform.description` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3190 "View in source") [Ⓣ][1] + +*(String)*: The platform description. + +* * * + + + + + + +### `Benchmark.platform.layout` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3198 "View in source") [Ⓣ][1] + +*(String, Null)*: The name of the browser layout engine. + +* * * + + + + + + +### `Benchmark.platform.manufacturer` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3222 "View in source") [Ⓣ][1] + +*(String, Null)*: The name of the product's manufacturer. + +* * * + + + + + + +### `Benchmark.platform.name` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3214 "View in source") [Ⓣ][1] + +*(String, Null)*: The name of the browser/environment. + +* * * + + + + + + +### `Benchmark.platform.os` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3230 "View in source") [Ⓣ][1] + +*(String, Null)*: The name of the operating system. + +* * * + + + + + + +### `Benchmark.platform.prerelease` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3238 "View in source") [Ⓣ][1] + +*(String, Null)*: The alpha/beta release indicator. + +* * * + + + + + + +### `Benchmark.platform.product` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3206 "View in source") [Ⓣ][1] + +*(String, Null)*: The name of the product hosting the browser. + +* * * + + + + + + +### `Benchmark.platform.version` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3246 "View in source") [Ⓣ][1] + +*(String, Null)*: The browser/environment version. + +* * * + + + + + + +### `Benchmark.platform.toString()` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3255 "View in source") [Ⓣ][1] + +Return platform description when the platform object is coerced to a string. + +#### Returns +*(String)*: The platform description. + +* * * + + + + + + + + + +## `Benchmark.support` + + + +### `Benchmark.support` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L135 "View in source") [Ⓣ][1] + +*(Object)*: An object used to flag environments/features. + +* * * + + + + + + +### `Benchmark.support.air` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L145 "View in source") [Ⓣ][1] + +*(Boolean)*: Detect Adobe AIR. + +* * * + + + + + + +### `Benchmark.support.argumentsClass` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L153 "View in source") [Ⓣ][1] + +*(Boolean)*: Detect if `arguments` objects have the correct internal [[Class]] value. + +* * * + + + + + + +### `Benchmark.support.browser` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L161 "View in source") [Ⓣ][1] + +*(Boolean)*: Detect if in a browser environment. + +* * * + + + + + + +### `Benchmark.support.charByIndex` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L169 "View in source") [Ⓣ][1] + +*(Boolean)*: Detect if strings support accessing characters by index. + +* * * + + + + + + +### `Benchmark.support.charByOwnIndex` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L179 "View in source") [Ⓣ][1] + +*(Boolean)*: Detect if strings have indexes as own properties. + +* * * + + + + + + +### `Benchmark.support.decompilation` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L207 "View in source") [Ⓣ][1] + +*(Boolean)*: Detect if functions support decompilation. + +* * * + + + + + + +### `Benchmark.support.descriptors` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L228 "View in source") [Ⓣ][1] + +*(Boolean)*: Detect ES5+ property descriptor API. + +* * * + + + + + + +### `Benchmark.support.getAllKeys` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L242 "View in source") [Ⓣ][1] + +*(Boolean)*: Detect ES5+ Object.getOwnPropertyNames(). + +* * * + + + + + + +### `Benchmark.support.iteratesOwnFirst` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L255 "View in source") [Ⓣ][1] + +*(Boolean)*: Detect if own properties are iterated before inherited properties *(all but IE < `9`)*. + +* * * + + + + + + +### `Benchmark.support.java` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L190 "View in source") [Ⓣ][1] + +*(Boolean)*: Detect if Java is enabled/exposed. + +* * * + + + + + + +### `Benchmark.support.nodeClass` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L272 "View in source") [Ⓣ][1] + +*(Boolean)*: Detect if a node's [[Class]] is resolvable *(all but IE < `9`)* and that the JS engine errors when attempting to coerce an object to a string without a `toString` property value of `typeof` "function". + +* * * + + + + + + +### `Benchmark.support.timeout` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L198 "View in source") [Ⓣ][1] + +*(Boolean)*: Detect if the Timers API exists. + +* * * + + + + + + + + + +## `Benchmark.prototype.error` + + + +### `Benchmark.prototype.error` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3361 "View in source") [Ⓣ][1] + +*(Object)*: The error object if the test failed. + +* * * + + + + + + + + + +## `Benchmark.prototype.stats` + + + +### `Benchmark.prototype.stats` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3464 "View in source") [Ⓣ][1] + +*(Object)*: An object of stats including mean, margin or error, and standard deviation. + +* * * + + + + + + +### `Benchmark.prototype.stats.deviation` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3496 "View in source") [Ⓣ][1] + +*(Number)*: The sample standard deviation. + +* * * + + + + + + +### `Benchmark.prototype.stats.mean` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3504 "View in source") [Ⓣ][1] + +*(Number)*: The sample arithmetic mean. + +* * * + + + + + + +### `Benchmark.prototype.stats.moe` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3472 "View in source") [Ⓣ][1] + +*(Number)*: The margin of error. + +* * * + + + + + + +### `Benchmark.prototype.stats.rme` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3480 "View in source") [Ⓣ][1] + +*(Number)*: The relative margin of error *(expressed as a percentage of the mean)*. + +* * * + + + + + + +### `Benchmark.prototype.stats.sample` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3512 "View in source") [Ⓣ][1] + +*(Array)*: The array of sampled periods. + +* * * + + + + + + +### `Benchmark.prototype.stats.sem` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3488 "View in source") [Ⓣ][1] + +*(Number)*: The standard error of the mean. + +* * * + + + + + + +### `Benchmark.prototype.stats.variance` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3520 "View in source") [Ⓣ][1] + +*(Number)*: The sample variance. + +* * * + + + + + + + + + +## `Benchmark.prototype.times` + + + +### `Benchmark.prototype.times` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3529 "View in source") [Ⓣ][1] + +*(Object)*: An object of timing data including cycle, elapsed, period, start, and stop. + +* * * + + + + + + +### `Benchmark.prototype.times.cycle` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3537 "View in source") [Ⓣ][1] + +*(Number)*: The time taken to complete the last cycle *(secs)*. + +* * * + + + + + + +### `Benchmark.prototype.times.elapsed` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3545 "View in source") [Ⓣ][1] + +*(Number)*: The time taken to complete the benchmark *(secs)*. + +* * * + + + + + + +### `Benchmark.prototype.times.period` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3553 "View in source") [Ⓣ][1] + +*(Number)*: The time taken to execute the test once *(secs)*. + +* * * + + + + + + +### `Benchmark.prototype.times.timeStamp` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3561 "View in source") [Ⓣ][1] + +*(Number)*: A timestamp of when the benchmark started *(ms)*. + +* * * + + + + + + + + + +## `Benchmark.Deferred` + + + +### `Benchmark.Deferred(clone)` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L445 "View in source") [Ⓣ][1] + +The Deferred constructor. + +#### Arguments +1. `clone` *(Object)*: The cloned benchmark instance. + +* * * + + + + + + + + + +## `Benchmark.Deferred.prototype` + + + +### `Benchmark.Deferred.prototype.benchmark` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3605 "View in source") [Ⓣ][1] + +*(Object)*: The deferred benchmark instance. + +* * * + + + + + + +### `Benchmark.Deferred.prototype.cycles` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3613 "View in source") [Ⓣ][1] + +*(Number)*: The number of deferred cycles performed while benchmarking. + +* * * + + + + + + +### `Benchmark.Deferred.prototype.elapsed` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3621 "View in source") [Ⓣ][1] + +*(Number)*: The time taken to complete the deferred benchmark *(secs)*. + +* * * + + + + + + +### `Benchmark.Deferred.prototype.resolve` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L1188 "View in source") [Ⓣ][1] + +*(Unknown)*: Handles cycling/completing the deferred benchmark. + +* * * + + + + + + +### `Benchmark.Deferred.prototype.timeStamp` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3629 "View in source") [Ⓣ][1] + +*(Number)*: A timestamp of when the deferred benchmark started *(ms)*. + +* * * + + + + + + + + + +## `Benchmark.Event` + + + +### `Benchmark.Event(type)` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L461 "View in source") [Ⓣ][1] + +The Event constructor. + +#### Arguments +1. `type` *(String|Object)*: The event type. + +* * * + + + + + + + + + +## `Benchmark.Event.prototype` + + + +### `Benchmark.Event.prototype.aborted` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3645 "View in source") [Ⓣ][1] + +*(Boolean)*: A flag to indicate if the emitters listener iteration is aborted. + +* * * + + + + + + +### `Benchmark.Event.prototype.cancelled` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3653 "View in source") [Ⓣ][1] + +*(Boolean)*: A flag to indicate if the default action is cancelled. + +* * * + + + + + + +### `Benchmark.Event.prototype.result` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3669 "View in source") [Ⓣ][1] + +*(Mixed)*: The return value of the last executed listener. + +* * * + + + + + + +### `Benchmark.Event.prototype.timeStamp` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3685 "View in source") [Ⓣ][1] + +*(Number)*: A timestamp of when the event was created *(ms)*. + +* * * + + + + + + +### `Benchmark.Event.prototype.type` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3693 "View in source") [Ⓣ][1] + +*(String)*: The event type. + +* * * + + + + + + + + + +## `Benchmark.Event.prototype.currentTarget` + + + +### `Benchmark.Event.prototype.currentTarget` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3661 "View in source") [Ⓣ][1] + +*(Object)*: The object whose listeners are currently being processed. + +* * * + + + + + + + + + +## `Benchmark.Event.prototype.target` + + + +### `Benchmark.Event.prototype.target` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3677 "View in source") [Ⓣ][1] + +*(Object)*: The object to which the event was originally emitted. + +* * * + + + + + + + + + +## `Benchmark.Suite` + + + +### `Benchmark.Suite(name [, options={}])` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L507 "View in source") [Ⓣ][1] + +The Suite constructor. + +#### Arguments +1. `name` *(String)*: A name to identify the suite. +2. `[options={}]` *(Object)*: Options object. + +#### Example +~~~ js +// basic usage (the `new` operator is optional) +var suite = new Benchmark.Suite; + +// or using a name first +var suite = new Benchmark.Suite('foo'); + +// or with options +var suite = new Benchmark.Suite('foo', { + + // called when the suite starts running + 'onStart': onStart, + + // called between running benchmarks + 'onCycle': onCycle, + + // called when aborted + 'onAbort': onAbort, + + // called when a test errors + 'onError': onError, + + // called when reset + 'onReset': onReset, + + // called when the suite completes running + 'onComplete': onComplete +}); +~~~ + +* * * + + + + + + + + + +## `Benchmark.Suite.prototype` + + + +### `Benchmark.Suite.prototype.aborted` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3734 "View in source") [Ⓣ][1] + +*(Boolean)*: A flag to indicate if the suite is aborted. + +* * * + + + + + + +### `Benchmark.Suite.prototype.length` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3726 "View in source") [Ⓣ][1] + +*(Number)*: The number of benchmarks in the suite. + +* * * + + + + + + +### `Benchmark.Suite.prototype.running` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3742 "View in source") [Ⓣ][1] + +*(Boolean)*: A flag to indicate if the suite is running. + +* * * + + + + + + +### `Benchmark.Suite.prototype.abort()` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L1902 "View in source") [Ⓣ][1] + +Aborts all benchmarks in the suite. + +#### Returns +*(Object)*: The suite instance. + +* * * + + + + + + +### `Benchmark.Suite.prototype.add(name, fn [, options={}])` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L1962 "View in source") [Ⓣ][1] + +Adds a test to the benchmark suite. + +#### Arguments +1. `name` *(String)*: A name to identify the benchmark. +2. `fn` *(Function|String)*: The test to benchmark. +3. `[options={}]` *(Object)*: Options object. + +#### Returns +*(Object)*: The benchmark instance. + +#### Example +~~~ js +// basic usage +suite.add(fn); + +// or using a name first +suite.add('foo', fn); + +// or with options +suite.add('foo', fn, { + 'onCycle': onCycle, + 'onComplete': onComplete +}); + +// or name and options +suite.add('foo', { + 'fn': fn, + 'onCycle': onCycle, + 'onComplete': onComplete +}); + +// or options only +suite.add({ + 'name': 'foo', + 'fn': fn, + 'onCycle': onCycle, + 'onComplete': onComplete +}); +~~~ + +* * * + + + + + + +### `Benchmark.Suite.prototype.clone(options)` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L1981 "View in source") [Ⓣ][1] + +Creates a new suite with cloned benchmarks. + +#### Arguments +1. `options` *(Object)*: Options object to overwrite cloned options. + +#### Returns +*(Object)*: The new suite instance. + +* * * + + + + + + +### `Benchmark.Suite.prototype.emit(type)` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L2095 "View in source") [Ⓣ][1] + +Executes all registered listeners of the specified event type. + +#### Arguments +1. `type` *(String|Object)*: The event type or object. + +#### Returns +*(Mixed)*: Returns the return value of the last listener executed. + +* * * + + + + + + +### `Benchmark.Suite.prototype.filter(callback)` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L2004 "View in source") [Ⓣ][1] + +An `Array#filter` like method. + +#### Arguments +1. `callback` *(Function|String)*: The function/alias called per iteration. + +#### Returns +*(Object)*: A new suite of benchmarks that passed callback filter. + +* * * + + + + + + +### `Benchmark.Suite.prototype.forEach(callback)` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3752 "View in source") [Ⓣ][1] + +An `Array#forEach` like method. Callbacks may terminate the loop by explicitly returning `false`. + +#### Arguments +1. `callback` *(Function)*: The function called per iteration. + +#### Returns +*(Object)*: The suite iterated over. + +* * * + + + + + + +### `Benchmark.Suite.prototype.indexOf(value)` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3761 "View in source") [Ⓣ][1] + +An `Array#indexOf` like method. + +#### Arguments +1. `value` *(Mixed)*: The value to search for. + +#### Returns +*(Number)*: The index of the matched value or `-1`. + +* * * + + + + + + +### `Benchmark.Suite.prototype.invoke(name [, arg1, arg2, ...])` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3771 "View in source") [Ⓣ][1] + +Invokes a method on all benchmarks in the suite. + +#### Arguments +1. `name` *(String|Object)*: The name of the method to invoke OR options object. +2. `[arg1, arg2, ...]` *(Mixed)*: Arguments to invoke the method with. + +#### Returns +*(Array)*: A new array of values returned from each method invoked. + +* * * + + + + + + +### `Benchmark.Suite.prototype.join([separator=','])` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3780 "View in source") [Ⓣ][1] + +Converts the suite of benchmarks to a string. + +#### Arguments +1. `[separator=',']` *(String)*: A string to separate each element of the array. + +#### Returns +*(String)*: The string. + +* * * + + + + + + +### `Benchmark.Suite.prototype.listeners(type)` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L2125 "View in source") [Ⓣ][1] + +Returns an array of event listeners for a given type that can be manipulated to add or remove listeners. + +#### Arguments +1. `type` *(String)*: The event type. + +#### Returns +*(Array)*: The listeners array. + +* * * + + + + + + +### `Benchmark.Suite.prototype.map(callback)` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3789 "View in source") [Ⓣ][1] + +An `Array#map` like method. + +#### Arguments +1. `callback` *(Function)*: The function called per iteration. + +#### Returns +*(Array)*: A new array of values returned by the callback. + +* * * + + + + + + +### `Benchmark.Suite.prototype.off([type, listener])` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L2158 "View in source") [Ⓣ][1] + +Unregisters a listener for the specified event type(s), or unregisters all listeners for the specified event type(s), or unregisters all listeners for all event types. + +#### Arguments +1. `[type]` *(String)*: The event type. +2. `[listener]` *(Function)*: The function to unregister. + +#### Returns +*(Object)*: The benchmark instance. + +#### Example +~~~ js +// unregister a listener for an event type +bench.off('cycle', listener); + +// unregister a listener for multiple event types +bench.off('start cycle', listener); + +// unregister all listeners for an event type +bench.off('cycle'); + +// unregister all listeners for multiple event types +bench.off('start cycle complete'); + +// unregister all listeners for all event types +bench.off(); +~~~ + +* * * + + + + + + +### `Benchmark.Suite.prototype.on(type, listener)` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L2197 "View in source") [Ⓣ][1] + +Registers a listener for the specified event type(s). + +#### Arguments +1. `type` *(String)*: The event type. +2. `listener` *(Function)*: The function to register. + +#### Returns +*(Object)*: The benchmark instance. + +#### Example +~~~ js +// register a listener for an event type +bench.on('cycle', listener); + +// register a listener for multiple event types +bench.on('start cycle', listener); +~~~ + +* * * + + + + + + +### `Benchmark.Suite.prototype.pluck(property)` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3798 "View in source") [Ⓣ][1] + +Retrieves the value of a specified property from all benchmarks in the suite. + +#### Arguments +1. `property` *(String)*: The property to pluck. + +#### Returns +*(Array)*: A new array of property values. + +* * * + + + + + + +### `Benchmark.Suite.prototype.pop()` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3806 "View in source") [Ⓣ][1] + +Removes the last benchmark from the suite and returns it. + +#### Returns +*(Mixed)*: The removed benchmark. + +* * * + + + + + + +### `Benchmark.Suite.prototype.push()` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3814 "View in source") [Ⓣ][1] + +Appends benchmarks to the suite. + +#### Returns +*(Number)*: The suite's new length. + +* * * + + + + + + +### `Benchmark.Suite.prototype.reduce(callback, accumulator)` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3833 "View in source") [Ⓣ][1] + +An `Array#reduce` like method. + +#### Arguments +1. `callback` *(Function)*: The function called per iteration. +2. `accumulator` *(Mixed)*: Initial value of the accumulator. + +#### Returns +*(Mixed)*: The accumulator. + +* * * + + + + + + +### `Benchmark.Suite.prototype.reset()` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L2019 "View in source") [Ⓣ][1] + +Resets all benchmarks in the suite. + +#### Returns +*(Object)*: The suite instance. + +* * * + + + + + + +### `Benchmark.Suite.prototype.reverse()` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L638 "View in source") [Ⓣ][1] + +Rearrange the host array's elements in reverse order. + +#### Returns +*(Array)*: The reversed array. + +* * * + + + + + + +### `Benchmark.Suite.prototype.run([options={}])` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L2056 "View in source") [Ⓣ][1] + +Runs the suite. + +#### Arguments +1. `[options={}]` *(Object)*: Options object. + +#### Returns +*(Object)*: The suite instance. + +#### Example +~~~ js +// basic usage +suite.run(); + +// or with options +suite.run({ 'async': true, 'queued': true }); +~~~ + +* * * + + + + + + +### `Benchmark.Suite.prototype.shift()` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L671 "View in source") [Ⓣ][1] + +Removes the first element of the host array and returns it. + +#### Returns +*(Mixed)*: The first element of the array. + +* * * + + + + + + +### `Benchmark.Suite.prototype.slice(start, end)` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L684 "View in source") [Ⓣ][1] + +Creates an array of the host array's elements from the start index up to, but not including, the end index. + +#### Arguments +1. `start` *(Number)*: The starting index. +2. `end` *(Number)*: The end index. + +#### Returns +*(Array)*: The new array. + +* * * + + + + + + +### `Benchmark.Suite.prototype.sort([compareFn=null])` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3823 "View in source") [Ⓣ][1] + +Sorts the benchmarks of the suite. + +#### Arguments +1. `[compareFn=null]` *(Function)*: A function that defines the sort order. + +#### Returns +*(Object)*: The sorted suite. + +* * * + + + + + + +### `Benchmark.Suite.prototype.splice(start, deleteCount [, val1, val2, ...])` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L714 "View in source") [Ⓣ][1] + +Allows removing a range of elements and/or inserting elements into the host array. + +#### Arguments +1. `start` *(Number)*: The start index. +2. `deleteCount` *(Number)*: The number of elements to delete. +3. `[val1, val2, ...]` *(Mixed)*: values to insert at the `start` index. + +#### Returns +*(Array)*: An array of removed elements. + +* * * + + + + + + +### `Benchmark.Suite.prototype.unshift()` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L749 "View in source") [Ⓣ][1] + +Appends arguments to the host array. + +#### Returns +*(Number)*: The new length. + +* * * + + + + + + + + + +## `Benchmark.Suite.options` + + + +### `Benchmark.Suite.options` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3705 "View in source") [Ⓣ][1] + +*(Object)*: The default options copied by suite instances. + +* * * + + + + + + +### `Benchmark.Suite.options.name` +# [Ⓢ](https://github.com/bestiejs/benchmark.js/blob/master/benchmark.js#L3713 "View in source") [Ⓣ][1] + +*(String)*: The name of the suite. + +* * * + + + + + + + + + + + [1]: #Benchmark "Jump back to the TOC." \ No newline at end of file diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/benchmark/package.json b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/benchmark/package.json new file mode 100644 index 0000000..6509f1a --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/benchmark/package.json @@ -0,0 +1,61 @@ +{ + "name": "benchmark", + "version": "1.0.0", + "description": "A benchmarking library that works on nearly all JavaScript platforms, supports high-resolution timers, and returns statistically significant results.", + "homepage": "http://benchmarkjs.com/", + "main": "benchmark", + "keywords": [ + "benchmark", + "narwhal", + "node", + "performance", + "ringo", + "speed" + ], + "licenses": [ + { + "type": "MIT", + "url": "http://mths.be/mit" + } + ], + "author": { + "name": "Mathias Bynens", + "email": "mathias@benchmarkjs.com", + "url": "http://mathiasbynens.be/" + }, + "maintainers": [ + { + "name": "jdalton", + "email": "john@fusejs.com" + }, + { + "name": "mathias", + "email": "mathias@qiwi.be" + } + ], + "bugs": { + "url": "https://github.com/bestiejs/benchmark.js/issues", + "email": "bugs@benchmarkjs.com" + }, + "repository": { + "type": "git", + "url": "git+https://github.com/bestiejs/benchmark.js.git" + }, + "engines": [ + "node", + "rhino" + ], + "directories": { + "doc": "./doc", + "test": "./test" + }, + "_id": "benchmark@1.0.0", + "dist": { + "shasum": "2f1e2fa4c359f11122aa183082218e957e390c73", + "tarball": "https://registry.npmjs.org/benchmark/-/benchmark-1.0.0.tgz" + }, + "_shasum": "2f1e2fa4c359f11122aa183082218e957e390c73", + "_resolved": "http://registry.npmjs.org/benchmark/-/benchmark-1.0.0.tgz", + "_from": "benchmark@1.0.0", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/benchmark/test/run-test.sh b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/benchmark/test/run-test.sh new file mode 100644 index 0000000..43424e4 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/benchmark/test/run-test.sh @@ -0,0 +1,9 @@ +cd "$(dirname "$0")" +for cmd in rhino ringo narwhal node; do + echo "" + echo "Testing in $cmd..." + $cmd test.js +done +echo "" +echo "Testing in a browser..." +open index.html diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/benchmark/test/test.js b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/benchmark/test/test.js new file mode 100644 index 0000000..d694494 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/benchmark/test/test.js @@ -0,0 +1,2074 @@ +;(function(window, undefined) { + 'use strict'; + + /** Use a single load function */ + var load = typeof require == 'function' ? require : window.load; + + /** The `platform` object to check */ + var platform = + window.platform || + load('../vendor/platform.js/platform.js') || + window.platform; + + /** The unit testing framework */ + var QUnit = + window.QUnit || ( + window.setTimeout || (window.addEventListener = window.setTimeout = / /), + window.QUnit = load('../vendor/qunit/qunit/qunit' + (platform.name == 'Narwhal' ? '-1.8.0' : '') + '.js') || window.QUnit, + load('../vendor/qunit-clib/qunit-clib.js'), + (window.addEventListener || 0).test && delete window.addEventListener, + window.QUnit + ); + + /** The `Benchmark` constructor to test */ + var Benchmark = + window.Benchmark || ( + Benchmark = load('../benchmark.js') || window.Benchmark, + Benchmark.Benchmark || Benchmark + ); + + /** API shortcut */ + var forOwn = Benchmark.forOwn; + + /** Used to get property descriptors */ + var getDescriptor = Object.getOwnPropertyDescriptor; + + /** Used to set property descriptors */ + var setDescriptor = Object.defineProperty; + + /** Shortcut used to convert array-like objects to arrays */ + var slice = [].slice; + + /** Used to resolve a value's internal [[Class]] */ + var toString = {}.toString; + + /** Used to check problem JScript properties (a.k.a. the [[DontEnum]] bug) */ + var shadowed = { + 'constructor': 1, + 'hasOwnProperty': 2, + 'isPrototypeOf': 3, + 'propertyIsEnumerable': 4, + 'toLocaleString': 5, + 'toString': 6, + 'valueOf': 7 + }; + + /** Used to flag environments/features */ + var support = { + 'descriptors': !!function() { + try { + var o = {}; + return (setDescriptor(o, o, o), 'value' in getDescriptor(o, o)); + } catch(e) { } + }() + }; + + /*--------------------------------------------------------------------------*/ + + /** + * Skips a given number of tests with a passing result. + * + * @private + * @param {Number} [count=1] The number of tests to skip. + */ + function skipTest(count) { + count || (count = 1); + while (count--) { + ok(true, 'test skipped'); + } + } + + /*--------------------------------------------------------------------------*/ + + // init Benchmark.options.minTime + Benchmark(function() { throw 0; }).run(); + + // set a shorter max time + Benchmark.options.maxTime = Benchmark.options.minTime * 5; + + // explicitly call `QUnit.module()` instead of `module()` + // in case we are in a CLI environment + QUnit.module('Benchmark'); + + (function() { + test('has the default `Benchmark.platform` value', function() { + if (window.document) { + equal(String(Benchmark.platform), navigator.userAgent); + } else { + skipTest(1) + } + }); + + test('supports loading Benchmark.js as a module', function() { + if (window.document && window.require) { + equal((Benchmark2 || {}).version, Benchmark.version); + } else { + skipTest(1) + } + }); + + test('supports loading Platform.js as a module', function() { + if (window.document && window.require) { + var platform = (Benchmark2 || {}).platform || {}; + equal(typeof platform.name, 'string'); + } else { + skipTest(1) + } + }); + }()); + + /*--------------------------------------------------------------------------*/ + + QUnit.module('Benchmark constructor'); + + (function() { + test('creates a new instance when called without the `new` operator', function() { + ok(Benchmark() instanceof Benchmark); + }); + + test('supports passing an options object', function() { + var bench = Benchmark({ 'name': 'foo', 'fn': function() { } }); + ok(bench.fn && bench.name == 'foo'); + }); + + test('supports passing a "name" and "fn" argument', function() { + var bench = Benchmark('foo', function() { }); + ok(bench.fn && bench.name == 'foo'); + }); + + test('supports passing a "name" argument and an options object', function() { + var bench = Benchmark('foo', { 'fn': function() { } }); + ok(bench.fn && bench.name == 'foo'); + }); + + test('supports passing a "name" argument and an options object', function() { + var bench = Benchmark('foo', function() { }, { 'id': 'bar' }); + ok(bench.fn && bench.name == 'foo' && bench.id == 'bar'); + }); + + test('supports passing an empy string for the "fn" options property', function() { + var bench = Benchmark({ 'fn': '' }).run(); + ok(!bench.error); + }); + + test('detects dead code', function() { + var bench = Benchmark(function() { }).run(); + ok(/setup\(\)/.test(bench.compiled) ? !bench.error : bench.error); + }); + }()); + + /*--------------------------------------------------------------------------*/ + + QUnit.module('Benchmark compilation'); + + (function() { + test('compiles using the default `Function#toString`', function() { + var bench = Benchmark({ + 'setup': function() { var a = 1; }, + 'fn': function() { throw a; }, + 'teardown': function() { a = 2; } + }).run(); + + var compiled = bench.compiled; + if (/setup\(\)/.test(compiled)) { + skipTest(); + } + else { + ok(/var a\s*=\s*1/.test(compiled) && /throw a/.test(compiled) && /a\s*=\s*2/.test(compiled)); + } + }); + + test('compiles using a custom "toString" method', function() { + var bench = Benchmark({ + 'setup': function() { }, + 'fn': function() { }, + 'teardown': function() { } + }); + + bench.setup.toString = function() { return 'var a = 1;' }; + bench.fn.toString = function() { return 'throw a;' }; + bench.teardown.toString = function() { return 'a = 2;' }; + bench.run(); + + var compiled = bench.compiled; + if (/setup\(\)/.test(compiled)) { + skipTest(); + } + else { + ok(/var a\s*=\s*1/.test(compiled) && /throw a/.test(compiled) && /a\s*=\s*2/.test(compiled)); + } + }); + + test('compiles using a string value', function() { + var bench = Benchmark({ + 'setup': 'var a = 1;', + 'fn': 'throw a;', + 'teardown': 'a = 2;' + }).run(); + + var compiled = bench.compiled; + if (/setup\(\)/.test(compiled)) { + skipTest(); + } + else { + ok(/var a\s*=\s*1/.test(compiled) && /throw a/.test(compiled) && /a\s*=\s*2/.test(compiled)); + } + }); + }()); + + /*--------------------------------------------------------------------------*/ + + QUnit.module('Benchmark test binding'); + + (function() { + var count = 0; + + var tests = { + 'inlined "setup", "fn", and "teardown"': ( + 'if(/ops/.test(this))this._fn=true;' + ), + 'called "fn" and inlined "setup"/"teardown" reached by error': function() { + count++; + if (/ops/.test(this)) { + this._fn = true; + } + }, + 'called "fn" and inlined "setup"/"teardown" reached by `return` statement': function() { + if (/ops/.test(this)) { + this._fn = true; + } + return; + } + }; + + forOwn(tests, function(fn, title) { + test('has correct binding for ' + title, function() { + var bench = Benchmark({ + 'setup': 'if(/ops/.test(this))this._setup=true;', + 'fn': fn, + 'teardown': 'if(/ops/.test(this))this._teardown=true;', + 'onCycle': function() { this.abort(); } + }).run(); + + var compiled = bench.compiled; + if (/setup\(\)/.test(compiled)) { + skipTest(3); + } + else { + ok(bench._setup, 'correct binding for "setup"'); + ok(bench._fn, 'correct binding for "fn"'); + ok(bench._teardown, 'correct binding for "teardown"'); + } + }); + }); + }()); + + /*--------------------------------------------------------------------------*/ + + QUnit.module('Benchmark.deepClone'); + + (function() { + function createCircularObject() { + var result = { + 'foo': { 'b': { 'foo': { 'c': { } } } }, + 'bar': { } + }; + + result.foo.b.foo.c.foo = result; + result.bar.b = result.foo.b; + return result; + } + + function Klass() { + this.a = 1; + } + + Klass.prototype = { 'b': 1 }; + + var notCloneable = { + 'an arguments object': arguments, + 'an element': window.document && document.body, + 'a function': Klass, + 'a Klass instance': new Klass + }; + + var objects = { + 'an array': ['a', 'b', 'c', ''], + 'an array-like-object': { '0': 'a', '1': 'b', '2': 'c', '3': '', 'length': 5 }, + 'boolean': false, + 'boolean object': Object(false), + 'an object': { 'a': 0, 'b': 1, 'c': 3 }, + 'an object with object values': { 'a': /a/, 'b': ['B'], 'c': { 'C': 1 } }, + 'null': null, + 'a number': 3, + 'a number object': Object(3), + 'a regexp': /x/gim, + 'a string': 'x', + 'a string object': Object('x'), + 'undefined': undefined + }; + + objects['an array'].length = 5; + + forOwn(objects, function(object, key) { + test('clones ' + key + ' correctly', function() { + var kind = toString.call(object), + clone = Benchmark.deepClone(object); + + if (object == null) { + equal(clone, object); + } else { + deepEqual(clone.valueOf(), object.valueOf()); + } + if (object === Object(object)) { + ok(clone !== object); + } else { + skipTest(); + } + }); + }); + + forOwn(notCloneable, function(object, key) { + test('does not clone ' + key, function() { + ok(Benchmark.deepClone(object) === object); + }); + }); + + test('clones using Klass#deepClone', function() { + var object = new Klass; + Klass.prototype.deepClone = function() { return new Klass; }; + + var clone = Benchmark.deepClone(object); + ok(clone !== object && clone instanceof Klass); + + delete Klass.prototype.clone; + }); + + test('clones problem JScript properties', function() { + var clone = Benchmark.deepClone(shadowed); + deepEqual(clone, shadowed); + }); + + test('clones string object with custom property', function() { + var object = new String('x'); + object.x = 1; + + var clone = Benchmark.deepClone(object); + ok(clone == 'x' && typeof clone == 'object' && clone.x === 1 && toString.call(clone) == '[object String]'); + }); + + test('clones objects with circular references', function() { + var object = createCircularObject(), + clone = Benchmark.deepClone(object); + + ok(clone.bar.b === clone.foo.b && clone === clone.foo.b.foo.c.foo && clone !== object); + }); + + test('clones non-extensible objects with circular references', function() { + if (Object.preventExtensions) { + var object = Object.preventExtensions(createCircularObject()); + Object.preventExtensions(object.bar.b); + + var clone = Benchmark.deepClone(object); + ok(clone.bar.b === clone.foo.b && clone === clone.foo.b.foo.c.foo && clone !== object); + } else { + skipTest(1) + } + }); + + test('clones sealed objects with circular references', function() { + if (Object.seal) { + var object = Object.seal(createCircularObject()); + Object.seal(object.bar.b); + + var clone = Benchmark.deepClone(object); + ok(clone.bar.b === clone.foo.b && clone === clone.foo.b.foo.c.foo && clone !== object); + } else { + skipTest(1) + } + }); + + test('clones frozen objects with circular references', function() { + if (Object.freeze) { + var object = Object.freeze(createCircularObject()); + Object.freeze(object.bar.b); + + var clone = Benchmark.deepClone(object); + ok(clone.bar.b === clone.foo.b && clone === clone.foo.b.foo.c.foo && clone !== object); + } else { + skipTest(1) + } + }); + + test('clones objects with custom descriptors and circular references', function() { + var accessor, + descriptor; + + if (support.descriptors) { + var object = setDescriptor({}, 'foo', { + 'configurable': true, + 'value': setDescriptor({}, 'b', { + 'writable': true, + 'value': setDescriptor({}, 'foo', { + 'get': function() { return accessor; }, + 'set': function(value) { accessor = value; } + }) + }) + }); + + setDescriptor(object, 'bar', { 'value': {} }); + object.foo.b.foo = { 'c': object }; + object.bar.b = object.foo.b; + + var clone = Benchmark.deepClone(object); + ok(clone !== object && + clone.bar.b === clone.foo.b && + clone !== clone.foo.b.foo.c.foo && + (descriptor = getDescriptor(clone, 'foo')) && + descriptor.configurable && !(descriptor.enumerable && descriptor.writable) && + (descriptor = getDescriptor(clone.foo, 'b')) && + descriptor.writable && !(descriptor.configurable && descriptor.enumerable) && + (descriptor = getDescriptor(clone.foo.b, 'foo')) && + descriptor.get && descriptor.set && + (descriptor = getDescriptor(clone.foo.b, 'foo')) && + !(descriptor.configurable && descriptor.enumerable && descriptor.writable) && + (descriptor = getDescriptor(clone, 'bar')) && + !(descriptor.configurable && descriptor.enumerable && descriptor.writable)); + } + else { + skipTest(1) + } + }); + }()); + + /*--------------------------------------------------------------------------*/ + + QUnit.module('Benchmark.each'); + + (function() { + var xpathResult; + + var objects = { + 'array': ['a', 'b', 'c', ''], + 'array-like-object': { '0': 'a', '1': 'b', '2': 'c', '3': '', 'length': 5 }, + 'xpath snapshot': null + }; + + if (window.document && document.evaluate) { + xpathResult = [document.documentElement, document.getElementsByTagName('head')[0], document.body]; + objects['xpath snapshot'] = document.evaluate('//*[self::html or self::head or self::body]', document, null, 7, null); + } + + objects.array.length = 5; + + forOwn(objects, function(object, key) { + test('passes the correct arguments when passing an ' + key, function() { + if (object) { + var args + Benchmark.each(object, function() { + args || (args = slice.call(arguments)); + }); + + if (key == 'xpath snapshot') { + ok(args[0] === xpathResult[0]); + } else { + equal(args[0], 'a'); + } + equal(args[1], 0); + ok(args[2] === object); + } + else { + skipTest(3); + } + }); + + test('returns the passed object when passing an ' + key, function() { + if (object) { + var actual = Benchmark.each(object, function() { }); + ok(actual === object); + } + else { + skipTest(); + } + }); + + test('iterates over all indexes when passing an ' + key, function() { + if (object) { + var values = []; + Benchmark.each(object, function(value) { + values.push(value); + }); + + deepEqual(values, key == 'xpath snapshot' ? xpathResult : ['a', 'b', 'c', '']); + } + else { + skipTest(); + } + }); + + test('exits early when returning `false` when passing an ' + key, function() { + if (object) { + var values = []; + Benchmark.each(object, function(value) { + values.push(value); + return values.length < 2; + }); + + deepEqual(values, key == 'xpath snapshot' ? xpathResult.slice(0, 2) : ['a', 'b']); + } + else { + skipTest(); + } + }); + }); + + test('passes the third callback argument as an object', function() { + var thirdArg; + Benchmark.each('hello', function(value, index, object) { + thirdArg = object; + }); + + ok(thirdArg && typeof thirdArg == 'object'); + }); + + test('iterates over strings by index', function() { + var values = []; + Benchmark.each('hello', function(value) { + values.push(value) + }); + + deepEqual(values, ['h', 'e', 'l', 'l', 'o']); + }); + }()); + + /*--------------------------------------------------------------------------*/ + + QUnit.module('Benchmark.extend'); + + (function() { + test('allows no source argument', function() { + var object = {}; + equal(Benchmark.extend(object), object); + }); + + test('allows a single source argument', function() { + var source = { 'x': 1, 'y': 1 }, + actual = Benchmark.extend({}, source); + + deepEqual(Benchmark.extend({}, source), { 'x': 1, 'y': 1 }); + }); + + test('allows multiple source arguments', function() { + var source1 = { 'x': 1, 'y': 1 }, + source2 = { 'y': 2, 'z': 2 }, + actual = Benchmark.extend({}, source1, source2); + + deepEqual(actual, { 'x': 1, 'y': 2, 'z': 2 }); + }); + + test('will add inherited source properties', function() { + function Source() { } + Source.prototype.x = 1; + deepEqual(Benchmark.extend({}, new Source), { 'x': 1 }); + }); + + test('will add problem JScript properties', function() { + deepEqual(Benchmark.extend({}, shadowed), shadowed); + }); + }()); + + /*--------------------------------------------------------------------------*/ + + QUnit.module('Benchmark.filter'); + + (function() { + var objects = { + 'array': ['a', 'b', 'c', ''], + 'array-like-object': { '0': 'a', '1': 'b', '2': 'c', '3': '', 'length': 5 } + }; + + objects.array.length = 5; + + forOwn(objects, function(object, key) { + test('passes the correct arguments when passing an ' + key, function() { + var args; + Benchmark.filter(object, function() { + args || (args = slice.call(arguments)); + }); + + deepEqual(args, ['a', 0, object]); + }); + + test('produces the correct result when passing an ' + key, function() { + var actual = Benchmark.filter(object, function(value, index) { + return index > 0; + }); + + deepEqual(actual, ['b', 'c', '']); + }); + + test('iterates over sparse ' + key + 's correctly', function() { + var actual = Benchmark.filter(object, function(value) { + return value === undefined; + }); + + deepEqual(actual, []); + }); + }); + }()); + + /*--------------------------------------------------------------------------*/ + + QUnit.module('Benchmark.forOwn'); + + (function() { + function fn() { + // no-op + } + + function KlassA() { + this.a = 1; + this.b = 2; + this.c = 3; + } + + function KlassB() { + this.a = 1; + this.constructor = 2; + this.hasOwnProperty = 3; + this.isPrototypeOf = 4; + this.propertyIsEnumerable = 5; + this.toLocaleString = 6; + this.toString = 7; + this.valueOf = 8; + } + + function KlassC() { + // no-op + } + + fn.a = 1; + fn.b = 2; + fn.c = 3; + + KlassC.prototype.a = 1; + KlassC.prototype.b = 2; + KlassC.prototype.c = 3; + + var objects = { + 'an arguments object': arguments, + 'a function': fn, + 'an object': new KlassA, + 'an object shadowing properties on Object.prototype': new KlassB, + 'a prototype object': KlassC.prototype, + 'a string': 'abc' + }; + + forOwn(objects, function(object, key) { + test('passes the correct arguments when passing ' + key, function() { + var args; + Benchmark.forOwn(object, function() { + args || (args = slice.call(arguments)); + }); + + equal(typeof args[0], key == 'a string' ? 'string' : 'number'); + equal(typeof args[1], 'string'); + equal(args[2] && typeof args[2], key == 'a function' ? 'function' : 'object'); + }); + + test('returns the passed object when passing ' + key, function() { + var actual = Benchmark.forOwn(object, function() { }); + deepEqual(actual, object); + }); + + test('iterates over own properties when passing ' + key, function() { + var values = []; + Benchmark.forOwn(object, function(value) { + values.push(value); + }); + + if (object instanceof KlassB) { + deepEqual(values.sort(), [1, 2, 3, 4, 5, 6, 7, 8]); + } else if (key == 'a string') { + deepEqual(values, ['a', 'b', 'c']); + } else { + deepEqual(values.sort(), [1, 2, 3]); + } + }); + + test('exits early when returning `false` when passing ' + key, function() { + var values = []; + Benchmark.forOwn(object, function(value) { + values.push(value); + return false; + }); + + equal(values.length, 1); + }); + + if (object instanceof KlassB) { + test('exits correctly when transitioning to the JScript [[DontEnum]] fix', function() { + var values = []; + Benchmark.forOwn(object, function(value) { + values.push(value); + return values.length < 2; + }); + + equal(values.length, 2); + }); + } + }); + }(1, 2, 3)); + + /*--------------------------------------------------------------------------*/ + + QUnit.module('Benchmark.formatNumber'); + + (function() { + test('formats a million correctly', function() { + equal(Benchmark.formatNumber(1e6), '1,000,000'); + }); + + test('formats less than 100 correctly', function() { + equal(Benchmark.formatNumber(23), '23'); + }); + + test('formats numbers with decimal values correctly', function() { + equal(Benchmark.formatNumber(1234.56), '1,234.56'); + }); + + test('formats negative numbers correctly', function() { + equal(Benchmark.formatNumber(-1234.56), '-1,234.56'); + }); + }()); + + /*--------------------------------------------------------------------------*/ + + QUnit.module('Benchmark.hasKey'); + + (function() { + test('returns `true` for own properties', function() { + var object = { 'x': 1 }; + equal(Benchmark.hasKey(object, 'x'), true); + }); + + test('returns `false` for inherited properties', function() { + equal(Benchmark.hasKey({}, 'toString'), false); + }); + + test('doesn\'t use an object\'s `hasOwnProperty` method', function() { + var object = { 'hasOwnProperty': function() { return true; } }; + equal(Benchmark.hasKey(object, 'x'), false); + }); + }()); + + /*--------------------------------------------------------------------------*/ + + QUnit.module('Benchmark.indexOf'); + + (function() { + var objects = { + 'array': ['a', 'b', 'c', ''], + 'array-like-object': { '0': 'a', '1': 'b', '2': 'c', '3': '', 'length': 5 } + }; + + objects.array.length = 5; + + forOwn(objects, function(object, key) { + test('produces the correct result when passing an ' + key, function() { + equal(Benchmark.indexOf(object, 'b'), 1); + }); + + test('matches values by strict equality when passing an ' + key, function() { + equal(Benchmark.indexOf(object, new String('b')), -1); + }); + + test('iterates over sparse ' + key + 's correctly', function() { + equal(Benchmark.indexOf(object, undefined), -1); + }); + }); + + test('searches from the given `fromIndex`', function() { + var array = ['a', 'b', 'c', 'a']; + equal(Benchmark.indexOf(array, 'a', 1), 3); + }); + + test('handles extreme negative `fromIndex` values correctly', function() { + var array = ['a']; + array['-1'] = 'z'; + equal(Benchmark.indexOf(array, 'z', -2), -1); + }); + + test('handles extreme positive `fromIndex` values correctly', function() { + var object = { '0': 'a', '1': 'b', '2': 'c', 'length': 2 }; + equal(Benchmark.indexOf(object, 'c', 2), -1); + }); + }()); + + /*--------------------------------------------------------------------------*/ + + QUnit.module('Benchmark.interpolate'); + + (function() { + test('replaces tokens correctly', function() { + var actual = Benchmark.interpolate('#{greeting} #{location}.', { + 'greeting': 'Hello', + 'location': 'world' + }); + + equal(actual, 'Hello world.'); + }); + + test('ignores inherited object properties', function() { + var actual = Benchmark.interpolate('x#{toString}', {}); + equal(actual, 'x#{toString}'); + }); + + test('allows for no template object', function() { + var actual = Benchmark.interpolate('x'); + equal(actual, 'x'); + }); + + test('replaces duplicate tokens', function() { + var actual = Benchmark.interpolate('#{x}#{x}#{x}', { 'x': 'a' }); + equal(actual, 'aaa'); + }); + + test('handles keys containing RegExp special characters', function() { + var actual = Benchmark.interpolate('#{.*+?^=!:${}()|[]\\/}', { '.*+?^=!:${}()|[]\\/': 'x' }); + equal(actual, 'x'); + }); + }()); + + /*--------------------------------------------------------------------------*/ + + QUnit.module('Benchmark.invoke'); + + (function() { + var objects = { + 'array': ['a', ['b'], 'c', null], + 'array-like-object': { '0': 'a', '1': ['b'], '2': 'c', '3': null, 'length': 5 } + }; + + objects.array.length = 5; + + forOwn(objects, function(object, key) { + test('produces the correct result when passing an ' + key, function() { + var actual = Benchmark.invoke(object, 'concat'); + deepEqual(actual, ['a', ['b'], 'c', undefined, undefined]); + equal('4' in actual, false); + }); + + test('passes the correct arguments to the invoked method when passing an ' + key, function() { + var actual = Benchmark.invoke(object, 'concat', 'x', 'y', 'z'); + deepEqual(actual, ['axyz', ['b', 'x', 'y', 'z'], 'cxyz', undefined, undefined]); + equal('4' in actual, false); + }); + + test('handles options object with callbacks correctly when passing an ' + key, function() { + function callback() { + callbacks.push(slice.call(arguments)); + } + + var callbacks = []; + var actual = Benchmark.invoke(object, { + 'name': 'concat', + 'args': ['x', 'y', 'z'], + 'onStart': callback, + 'onCycle': callback, + 'onComplete': callback + }); + + deepEqual(actual, ['axyz', ['b', 'x', 'y', 'z'], 'cxyz', undefined, undefined]); + equal('4' in actual, false); + + equal(callbacks[0].length, 1); + equal(callbacks[0][0].target, 'a'); + deepEqual(callbacks[0][0].currentTarget, object); + equal(callbacks[0][0].type, 'start'); + equal(callbacks[1][0].type, 'cycle'); + equal(callbacks[5][0].type, 'complete'); + }); + + test('supports queuing when passing an ' + key, function() { + var lengths = []; + var actual = Benchmark.invoke(object, { + 'name': 'concat', + 'queued': true, + 'args': 'x', + 'onCycle': function() { + lengths.push(object.length); + } + }); + + deepEqual(lengths, [5, 4, 3, 2]); + deepEqual(actual, ['ax', ['b', 'x'], 'cx', undefined, undefined]); + }); + }); + }()); + + /*--------------------------------------------------------------------------*/ + + QUnit.module('Benchmark.join'); + + (function() { + var objects = { + 'array': ['a', 'b', ''], + 'array-like-object': { '0': 'a', '1': 'b', '2': '', 'length': 4 }, + 'object': { 'a': '0', 'b': '1', '': '2' } + }; + + objects.array.length = 4; + + forOwn(objects, function(object, key) { + test('joins correctly using the default separator when passing an ' + key, function() { + equal(Benchmark.join(object), key == 'object' ? 'a: 0,b: 1,: 2' : 'a,b,'); + }); + + test('joins correctly using a custom separator when passing an ' + key, function() { + equal(Benchmark.join(object, '+', '@'), key == 'object' ? 'a@0+b@1+@2' : 'a+b+'); + }); + }); + }()); + + /*--------------------------------------------------------------------------*/ + + QUnit.module('Benchmark.map'); + + (function() { + var objects = { + 'array': ['a', 'b', 'c', ''], + 'array-like-object': { '0': 'a', '1': 'b', '2': 'c', '3': '', 'length': 5 } + }; + + objects.array.length = 5; + + forOwn(objects, function(object, key) { + test('passes the correct arguments when passing an ' + key, function() { + var args; + Benchmark.map(object, function() { + args || (args = slice.call(arguments)); + }); + + deepEqual(args, ['a', 0, object]); + }); + + test('produces the correct result when passing an ' + key, function() { + var actual = Benchmark.map(object, function(value, index) { + return value + index; + }); + + deepEqual(actual, ['a0', 'b1', 'c2', '3', undefined]); + equal('4' in actual, false); + }); + + test('produces an array of the correct length for sparse ' + key + 's', function() { + equal(Benchmark.map(object, function() { }).length, 5); + }); + }); + }()); + + /*--------------------------------------------------------------------------*/ + + QUnit.module('Benchmark.pluck'); + + (function() { + var objects = { + 'array': [{ '_': 'a' }, { '_': 'b' }, { '_': 'c' }, null], + 'array-like-object': { '0': { '_': 'a' }, '1': { '_': 'b' }, '2': { '_': 'c' }, '3': null, 'length': 5 } + }; + + objects.array.length = 5; + + forOwn(objects, function(object, key) { + test('produces the correct result when passing an ' + key, function() { + var actual = Benchmark.pluck(object, '_'); + deepEqual(actual, ['a', 'b', 'c', undefined, undefined]); + equal('4' in actual, false); + }); + + test('produces the correct result for non-existent keys when passing an ' + key, function() { + var actual = Benchmark.pluck(object, 'non-existent'); + deepEqual(actual, [undefined, undefined, undefined, undefined, undefined]); + equal('4' in actual, false); + }); + }); + }()); + + /*--------------------------------------------------------------------------*/ + + QUnit.module('Benchmark.reduce'); + + (function() { + var objects = { + 'array': ['b', 'c', ''], + 'array-like-object': { '0': 'b', '1': 'c', '2': '', 'length': 4 } + }; + + objects.array.length = 4; + + forOwn(objects, function(object, key) { + test('passes the correct arguments when passing an ' + key, function() { + var args; + Benchmark.reduce(object, function() { + args || (args = slice.call(arguments)); + }, 'a'); + + deepEqual(args, ['a', 'b', 0, object]); + }); + + test('accumulates correctly when passing an ' + key, function() { + var actual = Benchmark.reduce(object, function(string, value) { + return string + value; + }, 'a'); + + equal(actual, 'abc'); + }); + + test('handles arguments with no initial value correctly when passing an ' + key, function() { + var args; + Benchmark.reduce(object, function() { + args || (args = slice.call(arguments)); + }); + + deepEqual(args, ['b', 'c', 1, object]); + }); + }); + }()); + + /*--------------------------------------------------------------------------*/ + + QUnit.module('Benchmark#clone'); + + (function() { + var bench = Benchmark(function() { this.count += 0; }).run(); + + test('produces the correct result passing no arguments', function() { + var clone = bench.clone(); + deepEqual(clone, bench); + ok(clone.stats != bench.stats && clone.times != bench.times && clone.options != bench.options); + }); + + test('produces the correct result passing a data object', function() { + var clone = bench.clone({ 'fn': '', 'name': 'foo' }); + ok(clone.fn === '' && clone.options.fn === ''); + ok(clone.name == 'foo' && clone.options.name == 'foo'); + }); + }()); + + /*--------------------------------------------------------------------------*/ + + QUnit.module('Benchmark#run'); + + (function() { + var data = { 'onComplete': 0, 'onCycle': 0, 'onStart': 0 }; + + var bench = Benchmark({ + 'fn': function() { + this.count += 0; + }, + 'onStart': function() { + data.onStart++; + }, + 'onComplete': function() { + data.onComplete++; + } + }) + .run(); + + test('onXYZ callbacks should not be triggered by internal benchmark clones', function() { + equal(data.onStart, 1); + equal(data.onComplete, 1); + }); + }()); + + /*--------------------------------------------------------------------------*/ + + forOwn({ + 'Benchmark': Benchmark, + 'Benchmark.Suite': Benchmark.Suite + }, + function(Constructor, namespace) { + + QUnit.module(namespace + '#emit'); + + (function() { + test('emits passed arguments', function() { + var args, + object = Constructor(); + + object.on('args', function() { args = slice.call(arguments, 1); }); + object.emit('args', 'a', 'b', 'c'); + deepEqual(args, ['a', 'b', 'c']); + }); + + test('emits with no listeners', function() { + var event = Benchmark.Event('empty'), + object = Constructor(); + + object.emit(event); + equal(event.cancelled, false); + }); + + test('emits with an event type of "toString"', function() { + var event = Benchmark.Event('toString'), + object = Constructor(); + + object.emit(event); + equal(event.cancelled, false); + }); + + test('returns the last listeners returned value', function() { + var event = Benchmark.Event('result'), + object = Constructor(); + + object.on('result', function() { return 'x'; }); + object.on('result', function() { return 'y'; }); + equal(object.emit(event), 'y'); + }); + + test('aborts the emitters listener iteration when `event.aborted` is `true`', function() { + var event = Benchmark.Event('aborted'), + object = Constructor(); + + object.on('aborted', function(event) { + event.aborted = true; + return false; + }); + + object.on('aborted', function(event) { + // should not get here + event.aborted = false; + return true; + }); + + equal(object.emit(event), false); + equal(event.aborted, true); + }); + + test('cancels the event if a listener explicitly returns `false`', function() { + var event = Benchmark.Event('cancel'), + object = Constructor(); + + object.on('cancel', function() { return false; }); + object.on('cancel', function() { return true; }); + object.emit(event); + equal(event.cancelled, true); + }); + + test('uses a shallow clone of the listeners when emitting', function() { + var event, + listener2 = function(eventObject) { eventObject.listener2 = true }, + object = Constructor(); + + object.on('shallowclone', function(eventObject) { + event = eventObject; + object.off(event.type, listener2); + }) + .on('shallowclone', listener2) + .emit('shallowclone'); + + ok(event.listener2); + }); + + test('emits a custom event object', function() { + var event = Benchmark.Event('custom'), + object = Constructor(); + + object.on('custom', function(eventObject) { eventObject.touched = true; }); + object.emit(event); + ok(event.touched); + }); + + test('sets `event.result` correctly', function() { + var event = Benchmark.Event('result'), + object = Constructor(); + + object.on('result', function() { return 'x'; }); + object.emit(event); + equal(event.result, 'x'); + }); + + test('sets `event.type` correctly', function() { + var event, + object = Constructor(); + + object.on('type', function(eventObj) { + event = eventObj; + }); + + object.emit('type'); + equal(event.type, 'type'); + }); + }()); + + /*------------------------------------------------------------------------*/ + + QUnit.module(namespace + '#listeners'); + + (function() { + test('returns the correct listeners', function() { + var listener = function() { }, + object = Constructor(); + + object.on('x', listener); + deepEqual(object.listeners('x'), [listener]); + }); + + test('returns an array and initializes previously uninitialized listeners', function() { + var object = Constructor(); + deepEqual(object.listeners('x'), []); + deepEqual(object.events, { 'x': [] }); + }); + }()); + + /*------------------------------------------------------------------------*/ + + QUnit.module(namespace + '#off'); + + (function() { + test('returns the benchmark', function() { + var listener = function() { }, + object = Constructor(); + + object.on('x', listener); + equal(object.off('x', listener), object); + }); + + test('will ignore inherited properties of the event cache', function() { + var Dummy = function() { }, + listener = function() { }, + object = Constructor(); + + Dummy.prototype.x = [listener]; + object.events = new Dummy; + + object.off('x', listener); + deepEqual(object.events.x, [listener]); + }); + + test('handles an event type and listener', function() { + var listener = function() { }, + object = Constructor(); + + object.on('x', listener); + object.off('x', listener); + deepEqual(object.events.x, []); + }); + + test('handles unregistering duplicate listeners', function() { + var listener = function() { }, + object = Constructor(); + + object.on('x', listener); + object.on('x', listener); + + var events = object.events; + object.off('x', listener); + deepEqual(events.x, [listener]); + + object.off('x', listener); + deepEqual(events.x, []); + }); + + test('handles a non-registered listener', function() { + var object = Constructor(); + object.off('x', function() { }); + equal(object.events, undefined); + }); + + test('handles space separated event type and listener', function() { + var listener = function() { }, + object = Constructor(); + + object.on('x', listener); + object.on('y', listener); + + var events = object.events; + object.off('x y', listener); + deepEqual(events.x, []); + deepEqual(events.y, []); + }); + + test('handles space separated event type and no listener', function() { + var listener1 = function() { }, + listener2 = function() { }, + object = Constructor(); + + object.on('x', listener1); + object.on('y', listener2); + + var events = object.events; + object.off('x y'); + deepEqual(events.x, []); + deepEqual(events.y, []); + }); + + test('handles no arguments', function() { + var listener1 = function() { }, + listener2 = function() { }, + listener3 = function() { }, + object = Constructor(); + + object.on('x', listener1); + object.on('y', listener2); + object.on('z', listener3); + + var events = object.events; + object.off(); + deepEqual(events.x, []); + deepEqual(events.y, []); + deepEqual(events.z, []); + }); + }()); + + /*------------------------------------------------------------------------*/ + + QUnit.module(namespace + '#on'); + + (function() { + test('returns the benchmark', function() { + var listener = function() { }, + object = Constructor(); + + equal(object.on('x', listener), object); + }); + + test('will ignore inherited properties of the event cache', function() { + var Dummy = function() { }, + listener1 = function() { }, + listener2 = function() { }, + object = Constructor(); + + Dummy.prototype.x = [listener1]; + object.events = new Dummy; + + object.on('x', listener2); + deepEqual(object.events.x, [listener2]); + }); + + test('handles an event type and listener', function() { + var listener = function() { }, + object = Constructor(); + + object.on('x', listener); + deepEqual(object.events.x, [listener]); + }); + + test('handles registering duplicate listeners', function() { + var listener = function() { }, + object = Constructor(); + + object.on('x', listener); + object.on('x', listener); + deepEqual(object.events.x, [listener, listener]); + }); + + test('handles space separated event type and listener', function() { + var listener = function() { }, + object = Constructor(); + + object.on('x y', listener); + + var events = object.events; + deepEqual(events.x, [listener]); + deepEqual(events.y, [listener]); + }); + }()); + }); + + /*--------------------------------------------------------------------------*/ + + QUnit.module('Benchmark.Suite#abort'); + + (function() { + test('igores abort calls when the suite isn\'t running', function() { + var fired = false; + var suite = Benchmark.Suite('suite', { + 'onAbort': function() { fired = true; } + }); + + suite.add('foo', function() { }); + suite.abort(); + equal(fired, false); + }); + + test('ignores abort calls from `Benchmark.Suite#reset` when the suite isn\'t running', function() { + var fired = false; + var suite = Benchmark.Suite('suite', { + 'onAbort': function() { fired = true; } + }); + + suite.add('foo', function() { }); + suite.reset(); + equal(fired, false); + }); + + asyncTest('emits an abort event when running', function() { + var fired = false; + + Benchmark.Suite({ + 'onAbort': function() { fired = true; } + }) + .on('start', function() { + this.abort(); + }) + .on('complete', function() { + ok(fired); + QUnit.start(); + }) + .add(function(){ }) + .run({ 'async': true }); + }); + + asyncTest('emits an abort event after calling `Benchmark.Suite#reset`', function() { + var fired = false; + + Benchmark.Suite({ + 'onAbort': function() { fired = true; } + }) + .on('start', function() { + this.reset(); + }) + .on('complete', function() { + ok(fired); + QUnit.start(); + }) + .add(function(){ }) + .run({ 'async': true }); + }); + + asyncTest('should abort deferred benchmark', function() { + var fired = false, + suite = Benchmark.Suite(); + + suite.on('complete', function() { + equal(fired, false); + QUnit.start(); + }) + .add('a', { + 'defer': true, + 'fn': function(deferred) { + // avoid test inlining + suite.name; + // delay resolve + setTimeout(function() { + deferred.resolve(); + suite.abort(); + }, 10); + } + }) + .add('b', { + 'defer': true, + 'fn': function(deferred) { + // avoid test inlining + suite.name; + // delay resolve + setTimeout(function() { + deferred.resolve(); + fired = true; + }, 10); + } + }) + .run(); + }); + }()); + + /*--------------------------------------------------------------------------*/ + + QUnit.module('Benchmark.Suite#concat'); + + (function() { + var args = arguments; + + test('doesn\'t treat an arguments object like an array', function() { + var suite = Benchmark.Suite(); + deepEqual(suite.concat(args), [args]); + }); + + test('flattens array arguments', function() { + var suite = Benchmark.Suite(); + deepEqual(suite.concat([1, 2], 3, [4, 5]), [1, 2, 3, 4, 5]); + }); + + test('supports concating sparse arrays', function() { + var suite = Benchmark.Suite(); + suite[0] = 0; + suite[2] = 2; + suite.length = 3; + + var actual = suite.concat(3); + deepEqual(actual, [0, undefined, 2, 3]); + equal('1' in actual, false); + }); + + test('supports sparse arrays as arguments', function() { + var suite = Benchmark.Suite(), + sparse = []; + + sparse[0] = 0; + sparse[2] = 2; + sparse.length = 3; + + var actual = suite.concat(sparse); + deepEqual(actual, [0, undefined, 2]); + equal('1' in actual, false); + }); + + test('creates a new array', function() { + var suite = Benchmark.Suite(); + ok(suite.concat(1) !== suite); + }); + }(1, 2, 3)); + + /*--------------------------------------------------------------------------*/ + + QUnit.module('Benchmark.Suite#reverse'); + + (function() { + test('reverses the element order', function() { + var suite = Benchmark.Suite(); + suite[0] = 0; + suite[1] = 1; + suite.length = 2; + + var actual = suite.reverse(); + equal(actual, suite); + deepEqual(slice.call(actual), [1, 0]); + }); + + test('supports reversing sparse arrays', function() { + var suite = Benchmark.Suite(); + suite[0] = 0; + suite[2] = 2; + suite.length = 3; + + var actual = suite.reverse(); + equal(actual, suite); + deepEqual(slice.call(actual), [2, undefined, 0]); + equal('1' in actual, false); + }); + }()); + + /*--------------------------------------------------------------------------*/ + + QUnit.module('Benchmark.Suite#shift'); + + (function() { + test('removes the first element', function() { + var suite = Benchmark.Suite(); + suite[0] = 0; + suite[1] = 1; + suite.length = 2; + + var actual = suite.shift(); + equal(actual, 0); + deepEqual(slice.call(suite), [1]); + }); + + test('shifts an object with no elements', function() { + var suite = Benchmark.Suite(), + actual = suite.shift(); + + equal(actual, undefined); + deepEqual(slice.call(suite), []); + }); + + test('should have no elements when length is 0 after shift', function() { + var suite = Benchmark.Suite(); + suite[0] = 0; + suite.length = 1; + suite.shift(); + + // ensure element is removed + equal('0' in suite, false); + equal(suite.length, 0); + }); + + test('supports shifting sparse arrays', function() { + var suite = Benchmark.Suite(); + suite[1] = 1; + suite[3] = 3; + suite.length = 4; + + var actual = suite.shift(); + equal(actual, undefined); + deepEqual(slice.call(suite), [1, undefined, 3]); + equal('1' in suite, false); + }); + }()); + + /*--------------------------------------------------------------------------*/ + + QUnit.module('Benchmark.Suite#slice'); + + (function() { + var suite = Benchmark.Suite(); + suite[0] = 0; + suite[1] = 1; + suite[2] = 2; + suite[3] = 3; + suite.length = 4; + + test('works with no arguments', function() { + var actual = suite.slice(); + deepEqual(actual, [0, 1, 2, 3]); + ok(suite !== actual); + }); + + test('works with positive `start` argument', function() { + var actual = suite.slice(2); + deepEqual(actual, [2, 3]); + ok(suite !== actual); + }); + + test('works with positive `start` and `end` arguments', function() { + var actual = suite.slice(1, 3); + deepEqual(actual, [1, 2]); + ok(suite !== actual); + }); + + test('works with `end` values exceeding length', function() { + var actual = suite.slice(1, 10); + deepEqual(actual, [1, 2, 3]); + ok(suite !== actual); + }); + + test('works with negative `start` and `end` arguments', function() { + var actual = suite.slice(-3, -1); + deepEqual(actual, [1, 2]); + ok(suite !== actual); + }); + + test('works with an extreme negative `end` value', function() { + var actual = suite.slice(1, -10); + deepEqual(actual, []); + equal('-1' in actual, false); + ok(suite !== actual); + }); + + test('supports slicing sparse arrays', function() { + var sparse = Benchmark.Suite(); + sparse[1] = 1; + sparse[3] = 3; + sparse.length = 4; + + var actual = sparse.slice(0, 2); + deepEqual(actual, [undefined, 1]); + equal('0' in actual, false); + + actual = sparse.slice(1); + deepEqual(actual, [1, undefined, 3]); + equal('1' in actual, false); + }); + }()); + + /*--------------------------------------------------------------------------*/ + + QUnit.module('Benchmark.Suite#splice'); + + (function() { + test('works with no arguments', function() { + var suite = Benchmark.Suite(); + suite[0] = 0; + suite.length = 1; + + var actual = suite.splice(); + deepEqual(actual, []); + deepEqual(slice.call(suite), [0]); + }); + + test('works with only the `start` argument', function() { + var suite = Benchmark.Suite(); + suite[0] = 0; + suite[1] = 1; + suite.length = 2; + + var actual = suite.splice(1); + deepEqual(actual, [1]); + deepEqual(slice.call(suite), [0]); + }); + + test('should have no elements when length is 0 after splice', function() { + var suite = Benchmark.Suite(); + suite[0] = 0; + suite.length = 1 + suite.splice(0, 1); + + // ensure element is removed + equal('0' in suite, false); + equal(suite.length, 0); + }); + + test('works with positive `start` argument', function() { + var suite = Benchmark.Suite(); + suite[0] = 0; + suite[1] = 3; + suite.length = 2; + + var actual = suite.splice(1, 0, 1, 2); + deepEqual(actual, []); + deepEqual(slice.call(suite), [0, 1, 2, 3]); + }); + + test('works with positive `start` and `deleteCount` arguments', function() { + var suite = Benchmark.Suite(); + suite[0] = 0; + suite[1] = 3; + suite.length = 2; + + var actual = suite.splice(1, 1, 1, 2); + deepEqual(actual, [3]); + deepEqual(slice.call(suite), [0, 1, 2]); + }); + + test('works with `deleteCount` values exceeding length', function() { + var suite = Benchmark.Suite(); + suite[0] = 0; + suite[1] = 3; + suite.length = 2; + + var actual = suite.splice(1, 10, 1, 2); + deepEqual(actual, [3]); + deepEqual(slice.call(suite), [0, 1, 2]); + }); + + test('works with negative `start` and `deleteCount` arguments', function() { + var suite = Benchmark.Suite(); + suite[0] = 0; + suite[1] = 3; + suite.length = 2; + + var actual = suite.splice(-1, -1, 1, 2); + deepEqual(actual, []); + deepEqual(slice.call(suite), [0, 1, 2, 3]); + }); + + test('works with an extreme negative `deleteCount` value', function() { + var suite = Benchmark.Suite(); + suite[0] = 0; + suite[1] = 3; + suite.length = 2; + + var actual = suite.splice(0, -10, 1, 2); + deepEqual(actual, []); + deepEqual(slice.call(suite), [1, 2, 0, 3]); + }); + + test('supports splicing sparse arrays', function() { + var suite = Benchmark.Suite(); + suite[1] = 1; + suite[3] = 3; + suite.length = 4; + + var actual = suite.splice(1, 2, 1, 2); + deepEqual(actual, [1, undefined]); + equal(actual.length, 2); + deepEqual(slice.call(suite), [undefined, 1, 2, 3]); + equal('0' in suite, false); + }); + }()); + + /*--------------------------------------------------------------------------*/ + + QUnit.module('Benchmark.Suite#unshift'); + + (function() { + test('adds a first element', function() { + var suite = Benchmark.Suite(); + suite[0] = 1; + suite.length = 1; + + var actual = suite.unshift(0); + equal(actual, 2); + deepEqual(slice.call(suite), [0, 1]); + }); + + test('adds multiple elements to the front', function() { + var suite = Benchmark.Suite(); + suite[0] = 3; + suite.length = 1; + + var actual = suite.unshift(0, 1, 2); + equal(actual, 4); + deepEqual(slice.call(suite), [0, 1, 2, 3]); + }); + + test('supports unshifting sparse arrays', function() { + var suite = Benchmark.Suite(); + suite[1] = 2; + suite.length = 2; + + var actual = suite.unshift(0); + equal(actual, 3); + deepEqual(slice.call(suite), [0, undefined, 2]); + equal('1' in suite, false); + }); + }()); + + /*--------------------------------------------------------------------------*/ + + QUnit.module('Benchmark.Suite filtered results onComplete'); + + (function() { + var count = 0, + suite = Benchmark.Suite(); + + suite.add('a', function() { + count++; + }) + .add('b', function() { + for (var i = 0; i < 1e6; i++) { + count++; + } + }) + .add('c', function() { + throw new TypeError; + }); + + asyncTest('should filter by fastest', function() { + suite.on('complete', function() { + suite.off(); + deepEqual(this.filter('fastest').pluck('name'), ['a']); + QUnit.start(); + }) + .run({ 'async': true }); + }); + + asyncTest('should filter by slowest', function() { + suite.on('complete', function() { + suite.off(); + deepEqual(this.filter('slowest').pluck('name'), ['b']); + QUnit.start(); + }) + .run({ 'async': true }); + }); + + asyncTest('should filter by successful', function() { + suite.on('complete', function() { + suite.off(); + deepEqual(this.filter('successful').pluck('name'), ['a', 'b']); + QUnit.start(); + }) + .run({ 'async': true }); + }); + }()); + + /*--------------------------------------------------------------------------*/ + + QUnit.module('Benchmark.Suite event flow'); + + (function() { + var events = [], + callback = function(event) { events.push(event); }; + + var suite = Benchmark.Suite('suite', { + 'onAdd': callback, + 'onAbort': callback, + 'onClone': callback, + 'onError': callback, + 'onStart': callback, + 'onCycle': callback, + 'onComplete': callback, + 'onReset': callback + }) + .add('bench', function() { + throw null; + }, { + 'onAbort': callback, + 'onClone': callback, + 'onError': callback, + 'onStart': callback, + 'onCycle': callback, + 'onComplete': callback, + 'onReset': callback + }) + .run({ 'async': false }); + + // first Suite#onAdd + test('should emit the suite "add" event first', function() { + var event = events[0]; + ok(event.type == 'add' && event.currentTarget.name == 'suite' && event.target.name == 'bench'); + }); + + // next we start the Suite because no reset was needed + test('should emit the suite "start" event', function() { + var event = events[1]; + ok(event.type == 'start' && event.currentTarget.name == 'suite' && event.target.name == 'bench'); + }); + + // and so start the first benchmark + test('should emit the benchmark "start" event', function() { + var event = events[2]; + ok(event.type == 'start' && event.currentTarget.name == 'bench'); + }); + + // oh no! we abort because of an error + test('should emit the benchmark "error" event', function() { + var event = events[3]; + ok(event.type == 'error' && event.currentTarget.name == 'bench'); + }); + + // benchmark error triggered + test('should emit the benchmark "abort" event', function() { + var event = events[4]; + ok(event.type == 'abort' && event.currentTarget.name == 'bench'); + }); + + // we reset the benchmark as part of the abort + test('should emit the benchmark "reset" event', function() { + var event = events[5]; + ok(event.type == 'reset' && event.currentTarget.name == 'bench'); + }); + + // benchmark is cycle is finished + test('should emit the benchmark "cycle" event', function() { + var event = events[6]; + ok(event.type == 'cycle' && event.currentTarget.name == 'bench'); + }); + + // benchmark is complete + test('should emit the benchmark "complete" event', function() { + var event = events[7]; + ok(event.type == 'complete' && event.currentTarget.name == 'bench'); + }); + + // the benchmark error triggers a Suite error + test('should emit the suite "error" event', function() { + var event = events[8]; + ok(event.type == 'error' && event.currentTarget.name == 'suite' && event.target.name == 'bench'); + }); + + // the Suite cycle finishes + test('should emit the suite "cycle" event', function() { + var event = events[9]; + ok(event.type == 'cycle' && event.currentTarget.name == 'suite' && event.target.name == 'bench'); + }); + + // the Suite completes + test('finally it should emit the suite "complete" event', function() { + var event = events[10]; + ok(event.type == 'complete' && event.currentTarget.name == 'suite' && event.target.name == 'bench'); + }); + + test('emitted all expected events', function() { + ok(events.length == 11); + }); + }()); + + /*--------------------------------------------------------------------------*/ + + QUnit.module('Deferred benchmarks'); + + (function() { + asyncTest('should run a deferred benchmark correctly', function() { + Benchmark(function(deferred) { + setTimeout(function() { deferred.resolve(); }, 1e3); + }, { + 'defer': true, + 'onComplete': function() { + equal(this.hz.toFixed(0), 1); + QUnit.start(); + } + }) + .run(); + }); + + asyncTest('should run with string values for "fn", "setup", and "teardown"', function() { + Benchmark({ + 'defer': true, + 'setup': 'var x = [3, 2, 1];', + 'fn': 'setTimeout(function() { x.sort(); deferred.resolve(); }, 10);', + 'teardown': 'x.length = 0;', + 'onComplete': function() { + ok(true); + QUnit.start(); + } + }) + .run(); + }); + + asyncTest('should run recursively', function() { + Benchmark({ + 'defer': true, + 'setup': 'var x = [3, 2, 1];', + 'fn': 'for (var i = 0; i < 100; i++) x[ i % 2 ? "sort" : "reverse" ](); deferred.resolve();', + 'teardown': 'x.length = 0;', + 'onComplete': function() { + ok(true); + QUnit.start(); + } + }) + .run(); + }); + + asyncTest('should execute "setup", "fn", and "teardown" in correct order', function() { + var fired = []; + + Benchmark({ + 'defer': true, + 'setup': function() { + fired.push('setup'); + }, + 'fn': function(deferred) { + fired.push('fn'); + setTimeout(function() { deferred.resolve(); }, 10); + }, + 'teardown': function() { + fired.push('teardown'); + }, + 'onComplete': function() { + var actual = fired.join().replace(/(fn,)+/g, '$1').replace(/(setup,fn,teardown(?:,|$))+/, '$1'); + equal(actual, 'setup,fn,teardown'); + QUnit.start(); + } + }) + .run(); + }); + }()); + + /*--------------------------------------------------------------------------*/ + + QUnit.module('Benchmark.deepClone'); + + (function() { + asyncTest('avoids call stack limits', function() { + var result, + count = 0, + object = {}, + recurse = function() { count++; recurse(); }; + + setTimeout(function() { + ok(result, 'avoids call stack limits (stack limit is ' + (count - 1) + ')'); + QUnit.start(); + }, 15); + + if (toString.call(window.java) == '[object JavaPackage]') { + // Java throws uncatchable errors on call stack overflows, so to avoid + // them I chose a number higher than Rhino's call stack limit without + // dynamically testing for the actual limit + count = 3e3; + } else { + try { recurse(); } catch(e) { } + } + + // exceed limit + count++; + for (var i = 0, sub = object; i <= count; i++) { + sub = sub[i] = {}; + } + + try { + for (var i = 0, sub = Benchmark.deepClone(object); sub = sub[i]; i++) { } + result = --i == count; + } catch(e) { } + }); + }()); + + /*--------------------------------------------------------------------------*/ + + // explicitly call `QUnit.start()` for Narwhal, Rhino, and RingoJS + if (!window.document) { + QUnit.start(); + } +}(typeof global == 'object' && global || this)); diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/component-emitter/.npmignore b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/component-emitter/.npmignore new file mode 100644 index 0000000..f05b1f2 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/component-emitter/.npmignore @@ -0,0 +1,2 @@ +node_modules +test diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/component-emitter/.travis.yml b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/component-emitter/.travis.yml new file mode 100644 index 0000000..8750e3b --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/component-emitter/.travis.yml @@ -0,0 +1,4 @@ +node_js: +- "0.8" +- "0.10" +language: node_js \ No newline at end of file diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/component-emitter/History.md b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/component-emitter/History.md new file mode 100644 index 0000000..b898ca6 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/component-emitter/History.md @@ -0,0 +1,52 @@ + +1.1.2 / 2014-02-10 +================== + + * package: rename to "component-emitter" + * package: update "main" and "component" fields + * Add license to Readme (same format as the other components) + * created .npmignore + * travis stuff + +1.1.1 / 2013-12-01 +================== + + * fix .once adding .on to the listener + * docs: Emitter#off() + * component: add `.repo` prop + +1.1.0 / 2013-10-20 +================== + + * add `.addEventListener()` and `.removeEventListener()` aliases + +1.0.1 / 2013-06-27 +================== + + * add support for legacy ie + +1.0.0 / 2013-02-26 +================== + + * add `.off()` support for removing all listeners + +0.0.6 / 2012-10-08 +================== + + * add `this._callbacks` initialization to prevent funky gotcha + +0.0.5 / 2012-09-07 +================== + + * fix `Emitter.call(this)` usage + +0.0.3 / 2012-07-11 +================== + + * add `.listeners()` + * rename `.has()` to `.hasListeners()` + +0.0.2 / 2012-06-28 +================== + + * fix `.off()` with `.once()`-registered callbacks diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/component-emitter/Makefile b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/component-emitter/Makefile new file mode 100644 index 0000000..4e9c8d3 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/component-emitter/Makefile @@ -0,0 +1,7 @@ + +test: + @./node_modules/.bin/mocha \ + --require should \ + --reporter spec + +.PHONY: test \ No newline at end of file diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/component-emitter/Readme.md b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/component-emitter/Readme.md new file mode 100644 index 0000000..0f3f9b9 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/component-emitter/Readme.md @@ -0,0 +1,74 @@ +# Emitter [![Build Status](https://travis-ci.org/component/emitter.png)](https://travis-ci.org/component/emitter) + + Event emitter component. + +## Installation + +``` +$ component install component/emitter +``` + +## API + +### Emitter(obj) + + The `Emitter` may also be used as a mixin. For example + a "plain" object may become an emitter, or you may + extend an existing prototype. + + As an `Emitter` instance: + +```js +var Emitter = require('emitter'); +var emitter = new Emitter; +emitter.emit('something'); +``` + + As a mixin: + +```js +var Emitter = require('emitter'); +var user = { name: 'tobi' }; +Emitter(user); + +user.emit('im a user'); +``` + + As a prototype mixin: + +```js +var Emitter = require('emitter'); +Emitter(User.prototype); +``` + +### Emitter#on(event, fn) + + Register an `event` handler `fn`. + +### Emitter#once(event, fn) + + Register a single-shot `event` handler `fn`, + removed immediately after it is invoked the + first time. + +### Emitter#off(event, fn) + + * Pass `event` and `fn` to remove a listener. + * Pass `event` to remove all listeners on that event. + * Pass nothing to remove all listeners on all events. + +### Emitter#emit(event, ...) + + Emit an `event` with variable option args. + +### Emitter#listeners(event) + + Return an array of callbacks, or an empty array. + +### Emitter#hasListeners(event) + + Check if this emitter has `event` handlers. + +## License + +MIT diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/component-emitter/bower.json b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/component-emitter/bower.json new file mode 100644 index 0000000..c618d41 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/component-emitter/bower.json @@ -0,0 +1,21 @@ +{ + "name": "emitter", + "description": "Event emitter", + "keywords": [ + "emitter", + "events" + ], + "version": "1.1.2", + "license": "MIT", + "main": "index.js", + "homepage": "https://github.com/component/emitter", + "ignore": [ + "**/.*", + "node_modules", + "bower_components", + "test", + "Makefile", + "package.json", + "component.json" + ] +} diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/component-emitter/component.json b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/component-emitter/component.json new file mode 100644 index 0000000..68ba0b1 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/component-emitter/component.json @@ -0,0 +1,14 @@ +{ + "name": "emitter", + "repo": "component/emitter", + "description": "Event emitter", + "keywords": [ + "emitter", + "events" + ], + "version": "1.1.2", + "scripts": [ + "index.js" + ], + "license": "MIT" +} diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/component-emitter/index.js b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/component-emitter/index.js new file mode 100644 index 0000000..ad71163 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/component-emitter/index.js @@ -0,0 +1,164 @@ + +/** + * Expose `Emitter`. + */ + +module.exports = Emitter; + +/** + * Initialize a new `Emitter`. + * + * @api public + */ + +function Emitter(obj) { + if (obj) return mixin(obj); +}; + +/** + * Mixin the emitter properties. + * + * @param {Object} obj + * @return {Object} + * @api private + */ + +function mixin(obj) { + for (var key in Emitter.prototype) { + obj[key] = Emitter.prototype[key]; + } + return obj; +} + +/** + * Listen on the given `event` with `fn`. + * + * @param {String} event + * @param {Function} fn + * @return {Emitter} + * @api public + */ + +Emitter.prototype.on = +Emitter.prototype.addEventListener = function(event, fn){ + this._callbacks = this._callbacks || {}; + (this._callbacks[event] = this._callbacks[event] || []) + .push(fn); + return this; +}; + +/** + * Adds an `event` listener that will be invoked a single + * time then automatically removed. + * + * @param {String} event + * @param {Function} fn + * @return {Emitter} + * @api public + */ + +Emitter.prototype.once = function(event, fn){ + var self = this; + this._callbacks = this._callbacks || {}; + + function on() { + self.off(event, on); + fn.apply(this, arguments); + } + + on.fn = fn; + this.on(event, on); + return this; +}; + +/** + * Remove the given callback for `event` or all + * registered callbacks. + * + * @param {String} event + * @param {Function} fn + * @return {Emitter} + * @api public + */ + +Emitter.prototype.off = +Emitter.prototype.removeListener = +Emitter.prototype.removeAllListeners = +Emitter.prototype.removeEventListener = function(event, fn){ + this._callbacks = this._callbacks || {}; + + // all + if (0 == arguments.length) { + this._callbacks = {}; + return this; + } + + // specific event + var callbacks = this._callbacks[event]; + if (!callbacks) return this; + + // remove all handlers + if (1 == arguments.length) { + delete this._callbacks[event]; + return this; + } + + // remove specific handler + var cb; + for (var i = 0; i < callbacks.length; i++) { + cb = callbacks[i]; + if (cb === fn || cb.fn === fn) { + callbacks.splice(i, 1); + break; + } + } + return this; +}; + +/** + * Emit `event` with the given args. + * + * @param {String} event + * @param {Mixed} ... + * @return {Emitter} + */ + +Emitter.prototype.emit = function(event){ + this._callbacks = this._callbacks || {}; + var args = [].slice.call(arguments, 1) + , callbacks = this._callbacks[event]; + + if (callbacks) { + callbacks = callbacks.slice(0); + for (var i = 0, len = callbacks.length; i < len; ++i) { + callbacks[i].apply(this, args); + } + } + + return this; +}; + +/** + * Return array of callbacks for `event`. + * + * @param {String} event + * @return {Array} + * @api public + */ + +Emitter.prototype.listeners = function(event){ + this._callbacks = this._callbacks || {}; + return this._callbacks[event] || []; +}; + +/** + * Check if this emitter has `event` handlers. + * + * @param {String} event + * @return {Boolean} + * @api public + */ + +Emitter.prototype.hasListeners = function(event){ + return !! this.listeners(event).length; +}; diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/component-emitter/package.json b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/component-emitter/package.json new file mode 100644 index 0000000..ee66014 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/component-emitter/package.json @@ -0,0 +1,47 @@ +{ + "name": "component-emitter", + "description": "Event emitter", + "version": "1.1.2", + "devDependencies": { + "mocha": "*", + "should": "*" + }, + "component": { + "scripts": { + "emitter/index.js": "index.js" + } + }, + "main": "index.js", + "repository": { + "type": "git", + "url": "git+https://github.com/component/emitter.git" + }, + "scripts": { + "test": "make test" + }, + "bugs": { + "url": "https://github.com/component/emitter/issues" + }, + "homepage": "https://github.com/component/emitter", + "_id": "component-emitter@1.1.2", + "dist": { + "shasum": "296594f2753daa63996d2af08d15a95116c9aec3", + "tarball": "https://registry.npmjs.org/component-emitter/-/component-emitter-1.1.2.tgz" + }, + "_from": "component-emitter@1.1.2", + "_npmVersion": "1.3.24", + "_npmUser": { + "name": "tootallnate", + "email": "nathan@tootallnate.net" + }, + "maintainers": [ + { + "name": "tootallnate", + "email": "nathan@tootallnate.net" + } + ], + "directories": {}, + "_shasum": "296594f2753daa63996d2af08d15a95116c9aec3", + "_resolved": "http://registry.npmjs.org/component-emitter/-/component-emitter-1.1.2.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/debug/Readme.md b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/debug/Readme.md new file mode 100644 index 0000000..c5a34e8 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/debug/Readme.md @@ -0,0 +1,115 @@ +# debug + + tiny node.js debugging utility modelled after node core's debugging technique. + +## Installation + +``` +$ npm install debug +``` + +## Usage + + With `debug` you simply invoke the exported function to generate your debug function, passing it a name which will determine if a noop function is returned, or a decorated `console.error`, so all of the `console` format string goodies you're used to work fine. A unique color is selected per-function for visibility. + +Example _app.js_: + +```js +var debug = require('debug')('http') + , http = require('http') + , name = 'My App'; + +// fake app + +debug('booting %s', name); + +http.createServer(function(req, res){ + debug(req.method + ' ' + req.url); + res.end('hello\n'); +}).listen(3000, function(){ + debug('listening'); +}); + +// fake worker of some kind + +require('./worker'); +``` + +Example _worker.js_: + +```js +var debug = require('debug')('worker'); + +setInterval(function(){ + debug('doing some work'); +}, 1000); +``` + + The __DEBUG__ environment variable is then used to enable these based on space or comma-delimited names. Here are some examples: + + ![debug http and worker](http://f.cl.ly/items/18471z1H402O24072r1J/Screenshot.png) + + ![debug worker](http://f.cl.ly/items/1X413v1a3M0d3C2c1E0i/Screenshot.png) + +## Millisecond diff + + When actively developing an application it can be useful to see when the time spent between one `debug()` call and the next. Suppose for example you invoke `debug()` before requesting a resource, and after as well, the "+NNNms" will show you how much time was spent between calls. + + ![](http://f.cl.ly/items/2i3h1d3t121M2Z1A3Q0N/Screenshot.png) + + When stderr is not a TTY, `Date#toUTCString()` is used, making it more useful for logging the debug information as shown below: + _(NOTE: Debug now uses stderr instead of stdout, so the correct shell command for this example is actually `DEBUG=* node example/worker 2> out &`)_ + + ![](http://f.cl.ly/items/112H3i0e0o0P0a2Q2r11/Screenshot.png) + +## Conventions + + If you're using this in one or more of your libraries, you _should_ use the name of your library so that developers may toggle debugging as desired without guessing names. If you have more than one debuggers you _should_ prefix them with your library name and use ":" to separate features. For example "bodyParser" from Connect would then be "connect:bodyParser". + +## Wildcards + + The "*" character may be used as a wildcard. Suppose for example your library has debuggers named "connect:bodyParser", "connect:compress", "connect:session", instead of listing all three with `DEBUG=connect:bodyParser,connect.compress,connect:session`, you may simply do `DEBUG=connect:*`, or to run everything using this module simply use `DEBUG=*`. + + You can also exclude specific debuggers by prefixing them with a "-" character. For example, `DEBUG=* -connect:*` would include all debuggers except those starting with "connect:". + +## Browser support + + Debug works in the browser as well, currently persisted by `localStorage`. For example if you have `worker:a` and `worker:b` as shown below, and wish to debug both type `debug.enable('worker:*')` in the console and refresh the page, this will remain until you disable with `debug.disable()`. + +```js +a = debug('worker:a'); +b = debug('worker:b'); + +setInterval(function(){ + a('doing some work'); +}, 1000); + +setInterval(function(){ + a('doing some work'); +}, 1200); +``` + +## License + +(The MIT License) + +Copyright (c) 2011 TJ Holowaychuk <tj@vision-media.ca> + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/debug/debug.js b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/debug/debug.js new file mode 100644 index 0000000..509dc0d --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/debug/debug.js @@ -0,0 +1,137 @@ + +/** + * Expose `debug()` as the module. + */ + +module.exports = debug; + +/** + * Create a debugger with the given `name`. + * + * @param {String} name + * @return {Type} + * @api public + */ + +function debug(name) { + if (!debug.enabled(name)) return function(){}; + + return function(fmt){ + fmt = coerce(fmt); + + var curr = new Date; + var ms = curr - (debug[name] || curr); + debug[name] = curr; + + fmt = name + + ' ' + + fmt + + ' +' + debug.humanize(ms); + + // This hackery is required for IE8 + // where `console.log` doesn't have 'apply' + window.console + && console.log + && Function.prototype.apply.call(console.log, console, arguments); + } +} + +/** + * The currently active debug mode names. + */ + +debug.names = []; +debug.skips = []; + +/** + * Enables a debug mode by name. This can include modes + * separated by a colon and wildcards. + * + * @param {String} name + * @api public + */ + +debug.enable = function(name) { + try { + localStorage.debug = name; + } catch(e){} + + var split = (name || '').split(/[\s,]+/) + , len = split.length; + + for (var i = 0; i < len; i++) { + name = split[i].replace('*', '.*?'); + if (name[0] === '-') { + debug.skips.push(new RegExp('^' + name.substr(1) + '$')); + } + else { + debug.names.push(new RegExp('^' + name + '$')); + } + } +}; + +/** + * Disable debug output. + * + * @api public + */ + +debug.disable = function(){ + debug.enable(''); +}; + +/** + * Humanize the given `ms`. + * + * @param {Number} m + * @return {String} + * @api private + */ + +debug.humanize = function(ms) { + var sec = 1000 + , min = 60 * 1000 + , hour = 60 * min; + + if (ms >= hour) return (ms / hour).toFixed(1) + 'h'; + if (ms >= min) return (ms / min).toFixed(1) + 'm'; + if (ms >= sec) return (ms / sec | 0) + 's'; + return ms + 'ms'; +}; + +/** + * Returns true if the given mode name is enabled, false otherwise. + * + * @param {String} name + * @return {Boolean} + * @api public + */ + +debug.enabled = function(name) { + for (var i = 0, len = debug.skips.length; i < len; i++) { + if (debug.skips[i].test(name)) { + return false; + } + } + for (var i = 0, len = debug.names.length; i < len; i++) { + if (debug.names[i].test(name)) { + return true; + } + } + return false; +}; + +/** + * Coerce `val`. + */ + +function coerce(val) { + if (val instanceof Error) return val.stack || val.message; + return val; +} + +// persist + +try { + if (window.localStorage) debug.enable(localStorage.debug); +} catch(e){} diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/debug/index.js b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/debug/index.js new file mode 100644 index 0000000..e02c13b --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/debug/index.js @@ -0,0 +1,5 @@ +if ('undefined' == typeof window) { + module.exports = require('./lib/debug'); +} else { + module.exports = require('./debug'); +} diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/debug/lib/debug.js b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/debug/lib/debug.js new file mode 100644 index 0000000..3b0a918 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/debug/lib/debug.js @@ -0,0 +1,147 @@ +/** + * Module dependencies. + */ + +var tty = require('tty'); + +/** + * Expose `debug()` as the module. + */ + +module.exports = debug; + +/** + * Enabled debuggers. + */ + +var names = [] + , skips = []; + +(process.env.DEBUG || '') + .split(/[\s,]+/) + .forEach(function(name){ + name = name.replace('*', '.*?'); + if (name[0] === '-') { + skips.push(new RegExp('^' + name.substr(1) + '$')); + } else { + names.push(new RegExp('^' + name + '$')); + } + }); + +/** + * Colors. + */ + +var colors = [6, 2, 3, 4, 5, 1]; + +/** + * Previous debug() call. + */ + +var prev = {}; + +/** + * Previously assigned color. + */ + +var prevColor = 0; + +/** + * Is stdout a TTY? Colored output is disabled when `true`. + */ + +var isatty = tty.isatty(2); + +/** + * Select a color. + * + * @return {Number} + * @api private + */ + +function color() { + return colors[prevColor++ % colors.length]; +} + +/** + * Humanize the given `ms`. + * + * @param {Number} m + * @return {String} + * @api private + */ + +function humanize(ms) { + var sec = 1000 + , min = 60 * 1000 + , hour = 60 * min; + + if (ms >= hour) return (ms / hour).toFixed(1) + 'h'; + if (ms >= min) return (ms / min).toFixed(1) + 'm'; + if (ms >= sec) return (ms / sec | 0) + 's'; + return ms + 'ms'; +} + +/** + * Create a debugger with the given `name`. + * + * @param {String} name + * @return {Type} + * @api public + */ + +function debug(name) { + function disabled(){} + disabled.enabled = false; + + var match = skips.some(function(re){ + return re.test(name); + }); + + if (match) return disabled; + + match = names.some(function(re){ + return re.test(name); + }); + + if (!match) return disabled; + var c = color(); + + function colored(fmt) { + fmt = coerce(fmt); + + var curr = new Date; + var ms = curr - (prev[name] || curr); + prev[name] = curr; + + fmt = ' \u001b[9' + c + 'm' + name + ' ' + + '\u001b[3' + c + 'm\u001b[90m' + + fmt + '\u001b[3' + c + 'm' + + ' +' + humanize(ms) + '\u001b[0m'; + + console.error.apply(this, arguments); + } + + function plain(fmt) { + fmt = coerce(fmt); + + fmt = new Date().toUTCString() + + ' ' + name + ' ' + fmt; + console.error.apply(this, arguments); + } + + colored.enabled = plain.enabled = true; + + return isatty || process.env.DEBUG_COLORS + ? colored + : plain; +} + +/** + * Coerce `val`. + */ + +function coerce(val) { + if (val instanceof Error) return val.stack || val.message; + return val; +} diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/debug/package.json b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/debug/package.json new file mode 100644 index 0000000..ac09b9c --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/debug/package.json @@ -0,0 +1,63 @@ +{ + "name": "debug", + "version": "0.7.4", + "repository": { + "type": "git", + "url": "git://github.com/visionmedia/debug.git" + }, + "description": "small debugging utility", + "keywords": [ + "debug", + "log", + "debugger" + ], + "author": { + "name": "TJ Holowaychuk", + "email": "tj@vision-media.ca" + }, + "dependencies": {}, + "devDependencies": { + "mocha": "*" + }, + "main": "lib/debug.js", + "browser": "./debug.js", + "engines": { + "node": "*" + }, + "files": [ + "lib/debug.js", + "debug.js", + "index.js" + ], + "component": { + "scripts": { + "debug/index.js": "index.js", + "debug/debug.js": "debug.js" + } + }, + "bugs": { + "url": "https://github.com/visionmedia/debug/issues" + }, + "homepage": "https://github.com/visionmedia/debug", + "_id": "debug@0.7.4", + "dist": { + "shasum": "06e1ea8082c2cb14e39806e22e2f6f757f92af39", + "tarball": "https://registry.npmjs.org/debug/-/debug-0.7.4.tgz" + }, + "_from": "debug@0.7.4", + "_npmVersion": "1.3.13", + "_npmUser": { + "name": "tjholowaychuk", + "email": "tj@vision-media.ca" + }, + "maintainers": [ + { + "name": "tjholowaychuk", + "email": "tj@vision-media.ca" + } + ], + "directories": {}, + "_shasum": "06e1ea8082c2cb14e39806e22e2f6f757f92af39", + "_resolved": "http://registry.npmjs.org/debug/-/debug-0.7.4.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/isarray/README.md b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/isarray/README.md new file mode 100644 index 0000000..052a62b --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/isarray/README.md @@ -0,0 +1,54 @@ + +# isarray + +`Array#isArray` for older browsers. + +## Usage + +```js +var isArray = require('isarray'); + +console.log(isArray([])); // => true +console.log(isArray({})); // => false +``` + +## Installation + +With [npm](http://npmjs.org) do + +```bash +$ npm install isarray +``` + +Then bundle for the browser with +[browserify](https://github.com/substack/browserify). + +With [component](http://component.io) do + +```bash +$ component install juliangruber/isarray +``` + +## License + +(MIT) + +Copyright (c) 2013 Julian Gruber <julian@juliangruber.com> + +Permission is hereby granted, free of charge, to any person obtaining a copy of +this software and associated documentation files (the "Software"), to deal in +the Software without restriction, including without limitation the rights to +use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies +of the Software, and to permit persons to whom the Software is furnished to do +so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/isarray/build/build.js b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/isarray/build/build.js new file mode 100644 index 0000000..ec58596 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/isarray/build/build.js @@ -0,0 +1,209 @@ + +/** + * Require the given path. + * + * @param {String} path + * @return {Object} exports + * @api public + */ + +function require(path, parent, orig) { + var resolved = require.resolve(path); + + // lookup failed + if (null == resolved) { + orig = orig || path; + parent = parent || 'root'; + var err = new Error('Failed to require "' + orig + '" from "' + parent + '"'); + err.path = orig; + err.parent = parent; + err.require = true; + throw err; + } + + var module = require.modules[resolved]; + + // perform real require() + // by invoking the module's + // registered function + if (!module.exports) { + module.exports = {}; + module.client = module.component = true; + module.call(this, module.exports, require.relative(resolved), module); + } + + return module.exports; +} + +/** + * Registered modules. + */ + +require.modules = {}; + +/** + * Registered aliases. + */ + +require.aliases = {}; + +/** + * Resolve `path`. + * + * Lookup: + * + * - PATH/index.js + * - PATH.js + * - PATH + * + * @param {String} path + * @return {String} path or null + * @api private + */ + +require.resolve = function(path) { + if (path.charAt(0) === '/') path = path.slice(1); + var index = path + '/index.js'; + + var paths = [ + path, + path + '.js', + path + '.json', + path + '/index.js', + path + '/index.json' + ]; + + for (var i = 0; i < paths.length; i++) { + var path = paths[i]; + if (require.modules.hasOwnProperty(path)) return path; + } + + if (require.aliases.hasOwnProperty(index)) { + return require.aliases[index]; + } +}; + +/** + * Normalize `path` relative to the current path. + * + * @param {String} curr + * @param {String} path + * @return {String} + * @api private + */ + +require.normalize = function(curr, path) { + var segs = []; + + if ('.' != path.charAt(0)) return path; + + curr = curr.split('/'); + path = path.split('/'); + + for (var i = 0; i < path.length; ++i) { + if ('..' == path[i]) { + curr.pop(); + } else if ('.' != path[i] && '' != path[i]) { + segs.push(path[i]); + } + } + + return curr.concat(segs).join('/'); +}; + +/** + * Register module at `path` with callback `definition`. + * + * @param {String} path + * @param {Function} definition + * @api private + */ + +require.register = function(path, definition) { + require.modules[path] = definition; +}; + +/** + * Alias a module definition. + * + * @param {String} from + * @param {String} to + * @api private + */ + +require.alias = function(from, to) { + if (!require.modules.hasOwnProperty(from)) { + throw new Error('Failed to alias "' + from + '", it does not exist'); + } + require.aliases[to] = from; +}; + +/** + * Return a require function relative to the `parent` path. + * + * @param {String} parent + * @return {Function} + * @api private + */ + +require.relative = function(parent) { + var p = require.normalize(parent, '..'); + + /** + * lastIndexOf helper. + */ + + function lastIndexOf(arr, obj) { + var i = arr.length; + while (i--) { + if (arr[i] === obj) return i; + } + return -1; + } + + /** + * The relative require() itself. + */ + + function localRequire(path) { + var resolved = localRequire.resolve(path); + return require(resolved, parent, path); + } + + /** + * Resolve relative to the parent. + */ + + localRequire.resolve = function(path) { + var c = path.charAt(0); + if ('/' == c) return path.slice(1); + if ('.' == c) return require.normalize(p, path); + + // resolve deps by returning + // the dep in the nearest "deps" + // directory + var segs = parent.split('/'); + var i = lastIndexOf(segs, 'deps') + 1; + if (!i) i = 0; + path = segs.slice(0, i + 1).join('/') + '/deps/' + path; + return path; + }; + + /** + * Check if module is defined at `path`. + */ + + localRequire.exists = function(path) { + return require.modules.hasOwnProperty(localRequire.resolve(path)); + }; + + return localRequire; +}; +require.register("isarray/index.js", function(exports, require, module){ +module.exports = Array.isArray || function (arr) { + return Object.prototype.toString.call(arr) == '[object Array]'; +}; + +}); +require.alias("isarray/index.js", "isarray/index.js"); + diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/isarray/component.json b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/isarray/component.json new file mode 100644 index 0000000..9e31b68 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/isarray/component.json @@ -0,0 +1,19 @@ +{ + "name" : "isarray", + "description" : "Array#isArray for older browsers", + "version" : "0.0.1", + "repository" : "juliangruber/isarray", + "homepage": "https://github.com/juliangruber/isarray", + "main" : "index.js", + "scripts" : [ + "index.js" + ], + "dependencies" : {}, + "keywords": ["browser","isarray","array"], + "author": { + "name": "Julian Gruber", + "email": "mail@juliangruber.com", + "url": "http://juliangruber.com" + }, + "license": "MIT" +} diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/isarray/index.js b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/isarray/index.js new file mode 100644 index 0000000..5f5ad45 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/isarray/index.js @@ -0,0 +1,3 @@ +module.exports = Array.isArray || function (arr) { + return Object.prototype.toString.call(arr) == '[object Array]'; +}; diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/isarray/package.json b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/isarray/package.json new file mode 100644 index 0000000..a5886f3 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/isarray/package.json @@ -0,0 +1,53 @@ +{ + "name": "isarray", + "description": "Array#isArray for older browsers", + "version": "0.0.1", + "repository": { + "type": "git", + "url": "git://github.com/juliangruber/isarray.git" + }, + "homepage": "https://github.com/juliangruber/isarray", + "main": "index.js", + "scripts": { + "test": "tap test/*.js" + }, + "dependencies": {}, + "devDependencies": { + "tap": "*" + }, + "keywords": [ + "browser", + "isarray", + "array" + ], + "author": { + "name": "Julian Gruber", + "email": "mail@juliangruber.com", + "url": "http://juliangruber.com" + }, + "license": "MIT", + "_id": "isarray@0.0.1", + "dist": { + "shasum": "8a18acfca9a8f4177e09abfc6038939b05d1eedf", + "tarball": "https://registry.npmjs.org/isarray/-/isarray-0.0.1.tgz" + }, + "_from": "isarray@0.0.1", + "_npmVersion": "1.2.18", + "_npmUser": { + "name": "juliangruber", + "email": "julian@juliangruber.com" + }, + "maintainers": [ + { + "name": "juliangruber", + "email": "julian@juliangruber.com" + } + ], + "directories": {}, + "_shasum": "8a18acfca9a8f4177e09abfc6038939b05d1eedf", + "_resolved": "http://registry.npmjs.org/isarray/-/isarray-0.0.1.tgz", + "bugs": { + "url": "https://github.com/juliangruber/isarray/issues" + }, + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/.gitmodules b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/.gitmodules new file mode 100644 index 0000000..dc5a174 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/.gitmodules @@ -0,0 +1,6 @@ +[submodule "vendor/spec"] + path = vendor/spec + url = git://github.com/kitcambridge/spec.git +[submodule "vendor/marked"] + path = vendor/marked + url = git://github.com/chjj/marked.git diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/.jamignore b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/.jamignore new file mode 100644 index 0000000..ab53ee0 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/.jamignore @@ -0,0 +1,10 @@ +.* +build.js +index.html +component.json +bower.json +index.js +benchmark +page +test +vendor diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/.npmignore b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/.npmignore new file mode 100644 index 0000000..6b67b55 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/.npmignore @@ -0,0 +1,11 @@ +bower.json +component.json +build.js +index.html +index.js +.jshintrc + +benchmark +page +test +vendor diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/.travis.yml b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/.travis.yml new file mode 100644 index 0000000..d8e3ae7 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/.travis.yml @@ -0,0 +1,33 @@ +language: node_js +node_js: + - "0.6" + - "0.8" + - "0.10" +env: + matrix: + - BIN="node" + - BIN="phantomjs" +matrix: + include: + - node_js: "0.10" + env: BIN="narwhal" + - node_js: "0.10" + env: BIN="rhino" + - node_js: "0.10" + env: BIN="ringo" +git: + depth: 10 +branches: + only: + - gh-pages +before_install: + - "[ $BIN == 'istanbul' ] && npm i -g istanbul@\"~0.1.0\" || true" + - "[ $BIN == 'narwhal' ] && wget https://github.com/280north/narwhal/archive/v0.3.2.zip && sudo unzip v0.3.2 -d /opt/ && rm v0.3.2.zip || true" + - "[ $BIN == 'narwhal' ] && sudo ln -s /opt/narwhal-0.3.2/bin/narwhal /usr/local/bin/narwhal && sudo chmod +x /usr/local/bin/narwhal || true" + - "[ $BIN == 'rhino' ] && sudo mkdir /opt/rhino-1.7R5 && sudo wget -O /opt/rhino-1.7R5/js.jar https://oss.sonatype.org/content/repositories/snapshots/org/mozilla/rhino/1.7R5-SNAPSHOT/rhino-1.7R5-20120629.144839-4.jar || true" + - "[ $BIN == 'rhino' ] && echo -e '#!/bin/sh\\njava -jar /opt/rhino-1.7R5/js.jar $@' | sudo tee /usr/local/bin/rhino && sudo chmod +x /usr/local/bin/rhino || true" + - "[ $BIN == 'ringo' ] && wget http://ringojs.org/downloads/ringojs-0.9.zip && sudo unzip ringojs-0.9 -d /opt && rm ringojs-0.9.zip || true" + - "[ $BIN == 'ringo' ] && sudo ln -s /opt/ringojs-0.9/bin/ringo /usr/local/bin/ringo && sudo chmod +x /usr/local/bin/ringo || true" +install: true +script: + - "[ $BIN == 'istanbul' ] && $BIN cover ./test/test_json3.js || cd test && $BIN ./test_json3.js" diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/LICENSE b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/LICENSE new file mode 100644 index 0000000..6d42c54 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/LICENSE @@ -0,0 +1,20 @@ +Copyright (c) 2012-2013 Kit Cambridge. +http://kitcambridge.be/ + +Permission is hereby granted, free of charge, to any person obtaining a copy of +this software and associated documentation files (the "Software"), to deal in +the Software without restriction, including without limitation the rights to +use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies +of the Software, and to permit persons to whom the Software is furnished to do +so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. \ No newline at end of file diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/README.md b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/README.md new file mode 100644 index 0000000..bcb807a --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/README.md @@ -0,0 +1,126 @@ +# JSON 3 # + +![JSON 3 Logo](http://bestiejs.github.io/json3/page/logo.png) + +**JSON 3** is a modern JSON implementation compatible with a variety of JavaScript platforms, including Internet Explorer 6, Opera 7, Safari 2, and Netscape 6. The current version is **3.2.6**. + +- [Development Version](https://raw.github.com/bestiejs/json3/v3.2.6/lib/json3.js) *(40 KB; uncompressed with comments)* +- [Production Version](https://raw.github.com/bestiejs/json3/v3.2.6/lib/json3.min.js) *(3.3 KB; compressed and `gzip`-ped)* + +CDN copies are also available at [cdnjs](http://cdnjs.com/libraries/json3/) & [jsDelivr](http://www.jsdelivr.com/#!json3). + +[JSON](http://json.org/) is a language-independent data interchange format based on a loose subset of the JavaScript grammar. Originally popularized by [Douglas Crockford](http://www.crockford.com/), the format was standardized in the [fifth edition](http://es5.github.com/) of the ECMAScript specification. The 5.1 edition, ratified in June 2011, incorporates several modifications to the grammar pertaining to the serialization of dates. + +JSON 3 exposes two functions: `stringify()` for [serializing](https://developer.mozilla.org/en/JavaScript/Reference/Global_Objects/JSON/stringify) a JavaScript value to JSON, and `parse()` for [producing](https://developer.mozilla.org/en/JavaScript/Reference/Global_Objects/JSON/parse) a JavaScript value from a JSON source string. It is a **drop-in replacement** for [JSON 2](http://json.org/js). The functions behave exactly as described in the ECMAScript spec, **except** for the date serialization discrepancy noted below. + +The JSON 3 parser does **not** use `eval` or regular expressions. This provides security and performance benefits in obsolete and mobile environments, where the margin is particularly significant. The complete [benchmark suite](http://jsperf.com/json3) is available on [jsPerf](http://jsperf.com/). + +The project is [hosted on GitHub](http://git.io/json3), along with the [unit tests](http://bestiejs.github.io/json3/test/test_browser.html). It is part of the [BestieJS](https://github.com/bestiejs) family, a collection of best-in-class JavaScript libraries that promote cross-platform support, specification precedents, unit testing, and plenty of documentation. + +# Changes from JSON 2 # + +JSON 3... + +* Correctly serializes primitive wrapper objects. +* Throws a `TypeError` when serializing cyclic structures (JSON 2 recurses until the call stack overflows). +* Utilizes **feature tests** to detect broken or incomplete *native* JSON implementations (JSON 2 only checks for the presence of the native functions). The tests are only executed once at runtime, so there is no additional performance cost when parsing or serializing values. + +**As of v3.2.3**, JSON 3 is compatible with [Prototype](http://prototypejs.org) 1.6.1 and older. + +In contrast to JSON 2, JSON 3 **does not**... + +* Add `toJSON()` methods to the `Boolean`, `Number`, and `String` prototypes. These are not part of any standard, and are made redundant by the design of the `stringify()` implementation. +* Add `toJSON()` or `toISOString()` methods to `Date.prototype`. See the note about date serialization below. + +## Date Serialization + +**JSON 3 deviates from the specification in one important way**: it does not define `Date#toISOString()` or `Date#toJSON()`. This preserves CommonJS compatibility and avoids polluting native prototypes. Instead, date serialization is performed internally by the `stringify()` implementation: if a date object does not define a custom `toJSON()` method, it is serialized as a [simplified ISO 8601 date-time string](http://es5.github.com/#x15.9.1.15). + +**Several native `Date#toJSON()` implementations produce date time strings that do *not* conform to the grammar outlined in the spec**. For instance, all versions of Safari 4, as well as JSON 2, fail to serialize extended years correctly. Furthermore, JSON 2 and older implementations omit the milliseconds from the date-time string (optional in ES 5, but required in 5.1). Finally, in all versions of Safari 4 and 5, serializing an invalid date will produce the string `"Invalid Date"`, rather than `null`. Because these environments exhibit other serialization bugs, however, JSON 3 will override the native `stringify()` implementation. + +Portions of the date serialization code are adapted from the [`date-shim`](https://github.com/Yaffle/date-shim) project. + +# Usage # + +## Web Browsers + + + + +## CommonJS Environments + + var JSON3 = require("./path/to/json3"); + JSON3.parse("[1, 2, 3]"); + // => [1, 2, 3] + +## JavaScript Engines + + load("path/to/json3.js"); + JSON.stringify({"Hello": 123, "Good-bye": 456}, ["Hello"], "\t"); + // => '{\n\t"Hello": 123\n}' + +# Compatibility # + +JSON 3 has been **tested** with the following web browsers, CommonJS environments, and JavaScript engines. + +## Web Browsers + +- Windows [Internet Explorer](http://www.microsoft.com/windows/internet-explorer), version 6.0 and higher +- Mozilla [Firefox](http://www.mozilla.com/firefox), version 1.0 and higher +- Apple [Safari](http://www.apple.com/safari), version 2.0 and higher +- [Opera](http://www.opera.com) 7.02 and higher +- [Mozilla](http://sillydog.org/narchive/gecko.php) 1.0, [Netscape](http://sillydog.org/narchive/) 6.2.3, and [SeaMonkey](http://www.seamonkey-project.org/) 1.0 and higher + +## CommonJS Environments + +- [Node](http://nodejs.org/) 0.2.6 and higher +- [RingoJS](http://ringojs.org/) 0.4 and higher +- [Narwhal](http://narwhaljs.org/) 0.3.2 and higher + +## JavaScript Engines + +- Mozilla [Rhino](http://www.mozilla.org/rhino) 1.5R5 and higher +- WebKit [JSC](https://trac.webkit.org/wiki/JSC) +- Google [V8](http://code.google.com/p/v8) + +## Known Incompatibilities + +* Attempting to serialize the `arguments` object may produce inconsistent results across environments due to specification version differences. As a workaround, please convert the `arguments` object to an array first: `JSON.stringify([].slice.call(arguments, 0))`. + +## Required Native Methods + +JSON 3 assumes that the following methods exist and function as described in the ECMAScript specification: + +- The `Number`, `String`, `Array`, `Object`, `Date`, `SyntaxError`, and `TypeError` constructors. +- `String.fromCharCode` +- `Object#toString` +- `Function#call` +- `Math.floor` +- `Number#toString` +- `Date#valueOf` +- `String.prototype`: `indexOf`, `charCodeAt`, `charAt`, `slice`. +- `Array.prototype`: `push`, `pop`, `join`. + +# Contribute # + +Check out a working copy of the JSON 3 source code with [Git](http://git-scm.com/): + + $ git clone git://github.com/bestiejs/json3.git + $ cd json3 + $ git submodule update --init + +If you'd like to contribute a feature or bug fix, you can [fork](http://help.github.com/fork-a-repo/) JSON 3, commit your changes, and [send a pull request](http://help.github.com/send-pull-requests/). Please make sure to update the unit tests in the `test` directory as well. + +Alternatively, you can use the [GitHub issue tracker](https://github.com/bestiejs/json3/issues) to submit bug reports, feature requests, and questions, or send tweets to [@kitcambridge](http://twitter.com/kitcambridge). + +JSON 3 is released under the [MIT License](http://kit.mit-license.org/). \ No newline at end of file diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/coverage/coverage.json b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/coverage/coverage.json new file mode 100644 index 0000000..07b9920 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/coverage/coverage.json @@ -0,0 +1 @@ +{"/Users/kit/Dropbox/Projects/json3/vendor/spec/lib/spec.js":{"path":"/Users/kit/Dropbox/Projects/json3/vendor/spec/lib/spec.js","s":{"1":1,"2":1,"3":0,"4":1,"5":1,"6":0,"7":0,"8":0,"9":0,"10":1,"11":1,"12":1,"13":1,"14":1,"15":1,"16":1,"17":5538,"18":0,"19":5538,"20":0,"21":0,"22":0,"23":0,"24":0,"25":0,"26":0,"27":0,"28":0,"29":0,"30":0,"31":0,"32":0,"33":0,"34":1,"35":1,"36":1,"37":1,"38":1,"39":1,"40":1,"41":1,"42":1,"43":1,"44":1,"45":0,"46":0,"47":0,"48":0,"49":0,"50":0,"51":0,"52":0,"53":0,"54":0,"55":0,"56":0,"57":0,"58":0,"59":1,"60":0,"61":0,"62":0,"63":0,"64":0,"65":0,"66":0,"67":0,"68":0,"69":0,"70":1,"71":26,"72":26,"73":0,"74":26,"75":26,"76":30,"77":0,"78":26,"79":0,"80":1,"81":1,"82":102,"83":102,"84":72,"85":30,"86":0,"87":30,"88":30,"89":0,"90":30,"91":0,"92":0,"93":0,"94":0,"95":0,"96":0,"97":30,"98":0,"99":30,"100":22,"101":0,"102":30,"103":30,"104":30,"105":17,"106":17,"107":17,"108":17,"109":36,"110":0,"111":13,"112":13,"113":13,"114":15,"115":15,"116":13,"117":13,"118":15,"119":0,"120":13,"121":30,"122":30,"123":1,"124":51,"125":51,"126":0,"127":51,"128":1,"129":49,"130":49,"131":0,"132":49,"133":114,"134":0,"135":49,"136":1,"137":1,"138":1,"139":1,"140":0,"141":0,"142":0,"143":0,"144":1,"145":0,"146":0,"147":0,"148":0,"149":0,"150":1,"151":0,"152":0,"153":0,"154":0,"155":0,"156":0,"157":0,"158":1,"159":1,"160":11,"161":1,"162":1,"163":0,"164":0,"165":1,"166":1,"167":14,"168":1,"169":1,"170":34,"171":34,"172":34,"173":34,"174":34,"175":34,"176":34,"177":34,"178":1,"179":1,"180":11,"181":0,"182":11,"183":11,"184":11,"185":11,"186":11,"187":11,"188":11,"189":11,"190":22,"191":11,"192":11,"193":1,"194":1,"195":594,"196":594,"197":13,"198":594,"199":594,"200":298,"201":594,"202":594,"203":0,"204":0,"205":0,"206":0,"207":0,"208":594,"209":594,"210":594,"211":890,"212":890,"213":0,"214":594,"215":1,"216":1,"217":1,"218":1,"219":1,"220":1,"221":1,"222":1,"223":1,"224":1,"225":1,"226":8,"227":1,"228":1,"229":1,"230":11,"231":11,"232":11,"233":11,"234":1,"235":1,"236":1,"237":11,"238":11,"239":1,"240":1,"241":12,"242":12,"243":12,"244":0,"245":12,"246":11,"247":11,"248":11,"249":1,"250":1,"251":1,"252":296,"253":296,"254":296,"255":274,"256":274,"257":0,"258":0,"259":11,"260":11,"261":10,"262":10,"263":1,"264":1,"265":1,"266":1,"267":1,"268":1,"269":1,"270":1,"271":1,"272":0,"273":1,"274":1,"275":1,"276":11,"277":11,"278":0,"279":0,"280":11,"281":11,"282":11,"283":11,"284":1,"285":1,"286":1,"287":1,"288":1,"289":296,"290":296,"291":11,"292":11,"293":274,"294":274,"295":0,"296":0,"297":11,"298":11,"299":0,"300":1,"301":1,"302":1,"303":117,"304":6,"305":1,"306":1,"307":11,"308":11,"309":11,"310":1,"311":1,"312":274,"313":157,"314":274,"315":274,"316":1,"317":1,"318":0,"319":1,"320":1,"321":15,"322":1,"323":1,"324":0,"325":1,"326":1,"327":51,"328":1,"329":1,"330":0,"331":1,"332":1,"333":1,"334":0,"335":1,"336":1,"337":156,"338":156,"339":0,"340":0,"341":156,"342":156,"343":156,"344":156,"345":1,"346":1,"347":0,"348":0,"349":0,"350":0,"351":0,"352":1,"353":1,"354":11,"355":1},"b":{"1":[0,1],"2":[1,0],"3":[1,1,0],"4":[1,1,1],"5":[1,0,0,0],"6":[1,0],"7":[0,5538],"8":[0,0],"9":[0,0],"10":[0,0],"11":[0,0],"12":[0,0],"13":[0,0],"14":[1,0],"15":[0,1],"16":[0,0],"17":[0,0],"18":[0,0,0],"19":[0,0],"20":[0,0],"21":[0,0],"22":[0,1],"23":[0,0],"24":[0,0],"25":[0,0,0,0,0],"26":[0,0],"27":[0,26],"28":[0,30],"29":[30,30,30,30],"30":[30,0],"31":[0,26],"32":[26,26],"33":[72,30],"34":[72,15],"35":[0,30],"36":[0,30],"37":[0,0,0,0,0],"38":[0,0],"39":[0,0],"40":[0,0,0,0,0],"41":[0,30],"42":[30,30],"43":[0,22],"44":[17,13],"45":[17,0],"46":[0,36],"47":[36,36],"48":[15,15],"49":[13,0],"50":[0,15],"51":[0,51],"52":[0,49],"53":[0,114],"54":[1,0],"55":[0,0],"56":[0,0],"57":[1,0],"58":[1,1],"59":[34,0],"60":[34,34],"61":[34,11],"62":[11,23],"63":[11,23],"64":[0,11],"65":[11,0],"66":[11,11],"67":[11,0],"68":[11,0],"69":[11,11],"70":[33,33],"71":[11,11],"72":[22,22,11,11,11],"73":[13,581],"74":[594,581],"75":[594,594],"76":[298,296],"77":[594,594,594],"78":[0,594],"79":[594,0],"80":[0,0],"81":[0,0],"82":[0,0,0],"83":[594,0],"84":[594,594],"85":[1484,1484],"86":[890,890,298],"87":[1,0],"88":[12,1],"89":[0,12],"90":[11,11],"91":[11,0],"92":[11,11,11],"93":[274,0,11],"94":[10,1],"95":[1,0],"96":[0,11],"97":[11,11],"98":[11,0],"99":[11,274,0,11],"100":[0,11],"101":[11,0,11],"102":[0,117],"103":[157,117],"104":[0,157],"105":[274,0],"106":[0,0],"107":[0,156],"108":[156,0],"109":[156,156,156],"110":[0,156],"111":[0,0]},"f":{"1":1,"2":0,"3":0,"4":1,"5":1,"6":5538,"7":0,"8":0,"9":1,"10":1,"11":0,"12":0,"13":26,"14":1,"15":102,"16":15,"17":15,"18":51,"19":49,"20":1,"21":0,"22":0,"23":0,"24":0,"25":0,"26":0,"27":0,"28":11,"29":0,"30":0,"31":14,"32":34,"33":34,"34":11,"35":11,"36":594,"37":1,"38":1,"39":1,"40":11,"41":12,"42":296,"43":1,"44":11,"45":296,"46":6,"47":117,"48":11,"49":274,"50":0,"51":15,"52":0,"53":51,"54":0,"55":0,"56":156,"57":0,"58":11},"fnMap":{"1":{"name":"(anonymous_1)","line":11,"loc":{"start":{"line":11,"column":2},"end":{"line":11,"column":24}}},"2":{"name":"(anonymous_2)","line":20,"loc":{"start":{"line":20,"column":21},"end":{"line":20,"column":41}}},"3":{"name":"noConflict","line":21,"loc":{"start":{"line":21,"column":8},"end":{"line":21,"column":30}}},"4":{"name":"(anonymous_4)","line":31,"loc":{"start":{"line":31,"column":9},"end":{"line":31,"column":28}}},"5":{"name":"(anonymous_5)","line":70,"loc":{"start":{"line":70,"column":29},"end":{"line":70,"column":41}}},"6":{"name":"hasKey","line":78,"loc":{"start":{"line":78,"column":15},"end":{"line":78,"column":49}}},"7":{"name":"hasKey","line":86,"loc":{"start":{"line":86,"column":15},"end":{"line":86,"column":49}}},"8":{"name":"hasKey","line":102,"loc":{"start":{"line":102,"column":15},"end":{"line":102,"column":49}}},"9":{"name":"(anonymous_9)","line":117,"loc":{"start":{"line":117,"column":29},"end":{"line":117,"column":41}}},"10":{"name":"Properties","line":123,"loc":{"start":{"line":123,"column":4},"end":{"line":123,"column":26}}},"11":{"name":"forOwn","line":145,"loc":{"start":{"line":145,"column":15},"end":{"line":145,"column":58}}},"12":{"name":"forOwn","line":169,"loc":{"start":{"line":169,"column":15},"end":{"line":169,"column":58}}},"13":{"name":"forOwn","line":188,"loc":{"start":{"line":188,"column":15},"end":{"line":188,"column":58}}},"14":{"name":"(anonymous_14)","line":210,"loc":{"start":{"line":210,"column":29},"end":{"line":210,"column":41}}},"15":{"name":"eq","line":213,"loc":{"start":{"line":213,"column":4},"end":{"line":213,"column":36}}},"16":{"name":"(anonymous_16)","line":289,"loc":{"start":{"line":289,"column":21},"end":{"line":289,"column":43}}},"17":{"name":"(anonymous_17)","line":297,"loc":{"start":{"line":297,"column":24},"end":{"line":297,"column":36}}},"18":{"name":"equals","line":311,"loc":{"start":{"line":311,"column":4},"end":{"line":311,"column":22}}},"19":{"name":"forEach","line":328,"loc":{"start":{"line":328,"column":30},"end":{"line":328,"column":72}}},"20":{"name":"(anonymous_20)","line":343,"loc":{"start":{"line":343,"column":27},"end":{"line":343,"column":38}}},"21":{"name":"defer","line":347,"loc":{"start":{"line":347,"column":14},"end":{"line":347,"column":48}}},"22":{"name":"run","line":354,"loc":{"start":{"line":354,"column":8},"end":{"line":354,"column":23}}},"23":{"name":"defer","line":361,"loc":{"start":{"line":361,"column":14},"end":{"line":361,"column":48}}},"24":{"name":"run","line":362,"loc":{"start":{"line":362,"column":8},"end":{"line":362,"column":23}}},"25":{"name":"defer","line":370,"loc":{"start":{"line":370,"column":14},"end":{"line":370,"column":48}}},"26":{"name":"run","line":372,"loc":{"start":{"line":372,"column":8},"end":{"line":372,"column":23}}},"27":{"name":"(anonymous_27)","line":387,"loc":{"start":{"line":387,"column":14},"end":{"line":387,"column":25}}},"28":{"name":"defer","line":395,"loc":{"start":{"line":395,"column":14},"end":{"line":395,"column":48}}},"29":{"name":"rethrow","line":404,"loc":{"start":{"line":404,"column":2},"end":{"line":404,"column":30}}},"30":{"name":"(anonymous_30)","line":405,"loc":{"start":{"line":405,"column":10},"end":{"line":405,"column":22}}},"31":{"name":"Events","line":418,"loc":{"start":{"line":418,"column":2},"end":{"line":418,"column":20}}},"32":{"name":"addListener","line":429,"loc":{"start":{"line":429,"column":2},"end":{"line":429,"column":49}}},"33":{"name":"(anonymous_33)","line":431,"loc":{"start":{"line":431,"column":32},"end":{"line":431,"column":49}}},"34":{"name":"removeListener","line":454,"loc":{"start":{"line":454,"column":2},"end":{"line":454,"column":52}}},"35":{"name":"(anonymous_35)","line":459,"loc":{"start":{"line":459,"column":32},"end":{"line":459,"column":49}}},"36":{"name":"emit","line":483,"loc":{"start":{"line":483,"column":2},"end":{"line":483,"column":23}}},"37":{"name":"Suite","line":531,"loc":{"start":{"line":531,"column":2},"end":{"line":531,"column":23}}},"38":{"name":"(anonymous_38)","line":547,"loc":{"start":{"line":547,"column":3},"end":{"line":547,"column":33}}},"39":{"name":"shuffle","line":555,"loc":{"start":{"line":555,"column":2},"end":{"line":555,"column":21}}},"40":{"name":"addTest","line":567,"loc":{"start":{"line":567,"column":2},"end":{"line":567,"column":31}}},"41":{"name":"index","line":575,"loc":{"start":{"line":575,"column":2},"end":{"line":575,"column":27}}},"42":{"name":"onSuiteEvent","line":594,"loc":{"start":{"line":594,"column":2},"end":{"line":594,"column":31}}},"43":{"name":"runSuite","line":622,"loc":{"start":{"line":622,"column":2},"end":{"line":622,"column":22}}},"44":{"name":"Test","line":645,"loc":{"start":{"line":645,"column":2},"end":{"line":645,"column":28}}},"45":{"name":"onTestEvent","line":668,"loc":{"start":{"line":668,"column":2},"end":{"line":668,"column":30}}},"46":{"name":"assert","line":697,"loc":{"start":{"line":697,"column":2},"end":{"line":697,"column":34}}},"47":{"name":"assertion","line":698,"loc":{"start":{"line":698,"column":4},"end":{"line":698,"column":50}}},"48":{"name":"runTest","line":710,"loc":{"start":{"line":710,"column":2},"end":{"line":710,"column":21}}},"49":{"name":"ok","line":720,"loc":{"start":{"line":720,"column":2},"end":{"line":720,"column":33}}},"50":{"name":"notOk","line":735,"loc":{"start":{"line":735,"column":2},"end":{"line":735,"column":38}}},"51":{"name":"assertEqual","line":742,"loc":{"start":{"line":742,"column":2},"end":{"line":742,"column":41}}},"52":{"name":"assertNotEqual","line":748,"loc":{"start":{"line":748,"column":2},"end":{"line":748,"column":44}}},"53":{"name":"assertStrictEqual","line":754,"loc":{"start":{"line":754,"column":2},"end":{"line":754,"column":47}}},"54":{"name":"assertStrictNotEqual","line":760,"loc":{"start":{"line":760,"column":2},"end":{"line":760,"column":50}}},"55":{"name":"assertNotDeepEqual","line":770,"loc":{"start":{"line":770,"column":2},"end":{"line":770,"column":48}}},"56":{"name":"assertError","line":776,"loc":{"start":{"line":776,"column":2},"end":{"line":776,"column":52}}},"57":{"name":"assertNoError","line":793,"loc":{"start":{"line":793,"column":2},"end":{"line":793,"column":44}}},"58":{"name":"done","line":806,"loc":{"start":{"line":806,"column":2},"end":{"line":806,"column":28}}}},"statementMap":{"1":{"start":{"line":11,"column":1},"end":{"line":813,"column":3}},"2":{"start":{"line":12,"column":2},"end":{"line":30,"column":3}},"3":{"start":{"line":14,"column":4},"end":{"line":14,"column":38}},"4":{"start":{"line":17,"column":4},"end":{"line":29,"column":8}},"5":{"start":{"line":21,"column":8},"end":{"line":26,"column":9}},"6":{"start":{"line":22,"column":10},"end":{"line":22,"column":31}},"7":{"start":{"line":24,"column":10},"end":{"line":24,"column":33}},"8":{"start":{"line":25,"column":10},"end":{"line":25,"column":22}},"9":{"start":{"line":27,"column":8},"end":{"line":27,"column":26}},"10":{"start":{"line":35,"column":2},"end":{"line":35,"column":28}},"11":{"start":{"line":41,"column":2},"end":{"line":400,"column":7}},"12":{"start":{"line":71,"column":4},"end":{"line":71,"column":64}},"13":{"start":{"line":73,"column":4},"end":{"line":73,"column":96}},"14":{"start":{"line":74,"column":4},"end":{"line":74,"column":16}},"15":{"start":{"line":76,"column":4},"end":{"line":109,"column":5}},"16":{"start":{"line":78,"column":6},"end":{"line":83,"column":8}},"17":{"start":{"line":79,"column":8},"end":{"line":81,"column":9}},"18":{"start":{"line":80,"column":10},"end":{"line":80,"column":47}},"19":{"start":{"line":82,"column":8},"end":{"line":82,"column":59}},"20":{"start":{"line":84,"column":11},"end":{"line":109,"column":5}},"21":{"start":{"line":86,"column":6},"end":{"line":98,"column":8}},"22":{"start":{"line":87,"column":8},"end":{"line":87,"column":29}},"23":{"start":{"line":88,"column":8},"end":{"line":90,"column":9}},"24":{"start":{"line":89,"column":10},"end":{"line":89,"column":47}},"25":{"start":{"line":93,"column":8},"end":{"line":93,"column":36}},"26":{"start":{"line":94,"column":8},"end":{"line":94,"column":63}},"27":{"start":{"line":96,"column":8},"end":{"line":96,"column":36}},"28":{"start":{"line":97,"column":8},"end":{"line":97,"column":22}},"29":{"start":{"line":102,"column":6},"end":{"line":108,"column":8}},"30":{"start":{"line":103,"column":8},"end":{"line":105,"column":9}},"31":{"start":{"line":104,"column":10},"end":{"line":104,"column":47}},"32":{"start":{"line":106,"column":8},"end":{"line":106,"column":62}},"33":{"start":{"line":107,"column":8},"end":{"line":107,"column":100}},"34":{"start":{"line":110,"column":4},"end":{"line":110,"column":18}},"35":{"start":{"line":118,"column":4},"end":{"line":118,"column":44}},"36":{"start":{"line":123,"column":4},"end":{"line":125,"column":5}},"37":{"start":{"line":124,"column":6},"end":{"line":124,"column":23}},"38":{"start":{"line":126,"column":4},"end":{"line":126,"column":37}},"39":{"start":{"line":129,"column":4},"end":{"line":129,"column":31}},"40":{"start":{"line":130,"column":4},"end":{"line":135,"column":5}},"41":{"start":{"line":132,"column":6},"end":{"line":134,"column":7}},"42":{"start":{"line":133,"column":8},"end":{"line":133,"column":18}},"43":{"start":{"line":136,"column":4},"end":{"line":136,"column":19}},"44":{"start":{"line":139,"column":4},"end":{"line":205,"column":5}},"45":{"start":{"line":141,"column":6},"end":{"line":141,"column":132}},"46":{"start":{"line":144,"column":6},"end":{"line":144,"column":34}},"47":{"start":{"line":145,"column":6},"end":{"line":165,"column":8}},"48":{"start":{"line":146,"column":8},"end":{"line":146,"column":41}},"49":{"start":{"line":147,"column":8},"end":{"line":149,"column":9}},"50":{"start":{"line":148,"column":10},"end":{"line":148,"column":47}},"51":{"start":{"line":150,"column":8},"end":{"line":150,"column":66}},"52":{"start":{"line":151,"column":8},"end":{"line":157,"column":9}},"53":{"start":{"line":154,"column":10},"end":{"line":156,"column":11}},"54":{"start":{"line":155,"column":12},"end":{"line":155,"column":19}},"55":{"start":{"line":159,"column":8},"end":{"line":164,"column":9}},"56":{"start":{"line":160,"column":10},"end":{"line":160,"column":37}},"57":{"start":{"line":161,"column":10},"end":{"line":163,"column":11}},"58":{"start":{"line":162,"column":12},"end":{"line":162,"column":18}},"59":{"start":{"line":166,"column":11},"end":{"line":205,"column":5}},"60":{"start":{"line":168,"column":6},"end":{"line":168,"column":36}},"61":{"start":{"line":169,"column":6},"end":{"line":185,"column":8}},"62":{"start":{"line":170,"column":8},"end":{"line":170,"column":42}},"63":{"start":{"line":171,"column":8},"end":{"line":173,"column":9}},"64":{"start":{"line":172,"column":10},"end":{"line":172,"column":47}},"65":{"start":{"line":175,"column":8},"end":{"line":175,"column":21}},"66":{"start":{"line":176,"column":8},"end":{"line":176,"column":66}},"67":{"start":{"line":177,"column":8},"end":{"line":184,"column":9}},"68":{"start":{"line":181,"column":10},"end":{"line":183,"column":11}},"69":{"start":{"line":182,"column":12},"end":{"line":182,"column":18}},"70":{"start":{"line":188,"column":6},"end":{"line":204,"column":8}},"71":{"start":{"line":189,"column":8},"end":{"line":189,"column":48}},"72":{"start":{"line":190,"column":8},"end":{"line":192,"column":9}},"73":{"start":{"line":191,"column":10},"end":{"line":191,"column":47}},"74":{"start":{"line":193,"column":8},"end":{"line":193,"column":66}},"75":{"start":{"line":194,"column":8},"end":{"line":198,"column":9}},"76":{"start":{"line":195,"column":10},"end":{"line":197,"column":11}},"77":{"start":{"line":196,"column":12},"end":{"line":196,"column":19}},"78":{"start":{"line":201,"column":8},"end":{"line":203,"column":9}},"79":{"start":{"line":202,"column":10},"end":{"line":202,"column":82}},"80":{"start":{"line":206,"column":4},"end":{"line":206,"column":18}},"81":{"start":{"line":213,"column":4},"end":{"line":308,"column":5}},"82":{"start":{"line":214,"column":6},"end":{"line":214,"column":34}},"83":{"start":{"line":216,"column":6},"end":{"line":220,"column":7}},"84":{"start":{"line":219,"column":8},"end":{"line":219,"column":52}},"85":{"start":{"line":222,"column":6},"end":{"line":224,"column":7}},"86":{"start":{"line":223,"column":8},"end":{"line":223,"column":30}},"87":{"start":{"line":225,"column":6},"end":{"line":225,"column":38}},"88":{"start":{"line":226,"column":6},"end":{"line":228,"column":7}},"89":{"start":{"line":227,"column":8},"end":{"line":227,"column":21}},"90":{"start":{"line":229,"column":6},"end":{"line":255,"column":7}},"91":{"start":{"line":234,"column":10},"end":{"line":234,"column":47}},"92":{"start":{"line":236,"column":10},"end":{"line":236,"column":23}},"93":{"start":{"line":237,"column":10},"end":{"line":237,"column":25}},"94":{"start":{"line":240,"column":10},"end":{"line":240,"column":98}},"95":{"start":{"line":246,"column":10},"end":{"line":246,"column":33}},"96":{"start":{"line":250,"column":10},"end":{"line":254,"column":51}},"97":{"start":{"line":256,"column":6},"end":{"line":258,"column":7}},"98":{"start":{"line":257,"column":8},"end":{"line":257,"column":21}},"99":{"start":{"line":263,"column":6},"end":{"line":267,"column":7}},"100":{"start":{"line":264,"column":8},"end":{"line":266,"column":9}},"101":{"start":{"line":265,"column":10},"end":{"line":265,"column":22}},"102":{"start":{"line":269,"column":6},"end":{"line":269,"column":23}},"103":{"start":{"line":270,"column":6},"end":{"line":270,"column":20}},"104":{"start":{"line":272,"column":6},"end":{"line":304,"column":7}},"105":{"start":{"line":274,"column":8},"end":{"line":274,"column":27}},"106":{"start":{"line":275,"column":8},"end":{"line":275,"column":38}},"107":{"start":{"line":276,"column":8},"end":{"line":284,"column":9}},"108":{"start":{"line":278,"column":10},"end":{"line":283,"column":11}},"109":{"start":{"line":280,"column":12},"end":{"line":282,"column":13}},"110":{"start":{"line":281,"column":14},"end":{"line":281,"column":20}},"111":{"start":{"line":286,"column":8},"end":{"line":286,"column":17}},"112":{"start":{"line":288,"column":8},"end":{"line":288,"column":22}},"113":{"start":{"line":289,"column":8},"end":{"line":294,"column":11}},"114":{"start":{"line":291,"column":10},"end":{"line":291,"column":20}},"115":{"start":{"line":293,"column":10},"end":{"line":293,"column":77}},"116":{"start":{"line":296,"column":8},"end":{"line":303,"column":9}},"117":{"start":{"line":297,"column":10},"end":{"line":301,"column":13}},"118":{"start":{"line":298,"column":12},"end":{"line":300,"column":13}},"119":{"start":{"line":299,"column":14},"end":{"line":299,"column":27}},"120":{"start":{"line":302,"column":10},"end":{"line":302,"column":25}},"121":{"start":{"line":306,"column":6},"end":{"line":306,"column":18}},"122":{"start":{"line":307,"column":6},"end":{"line":307,"column":20}},"123":{"start":{"line":311,"column":4},"end":{"line":320,"column":5}},"124":{"start":{"line":312,"column":6},"end":{"line":318,"column":7}},"125":{"start":{"line":315,"column":8},"end":{"line":317,"column":9}},"126":{"start":{"line":316,"column":10},"end":{"line":316,"column":23}},"127":{"start":{"line":319,"column":6},"end":{"line":319,"column":18}},"128":{"start":{"line":322,"column":4},"end":{"line":322,"column":18}},"129":{"start":{"line":329,"column":4},"end":{"line":329,"column":22}},"130":{"start":{"line":330,"column":4},"end":{"line":332,"column":5}},"131":{"start":{"line":331,"column":6},"end":{"line":331,"column":43}},"132":{"start":{"line":333,"column":4},"end":{"line":337,"column":5}},"133":{"start":{"line":334,"column":6},"end":{"line":336,"column":7}},"134":{"start":{"line":335,"column":8},"end":{"line":335,"column":14}},"135":{"start":{"line":338,"column":4},"end":{"line":338,"column":16}},"136":{"start":{"line":344,"column":4},"end":{"line":344,"column":21}},"137":{"start":{"line":346,"column":4},"end":{"line":392,"column":5}},"138":{"start":{"line":347,"column":6},"end":{"line":358,"column":8}},"139":{"start":{"line":354,"column":8},"end":{"line":356,"column":9}},"140":{"start":{"line":355,"column":10},"end":{"line":355,"column":39}},"141":{"start":{"line":357,"column":8},"end":{"line":357,"column":30}},"142":{"start":{"line":360,"column":11},"end":{"line":392,"column":5}},"143":{"start":{"line":361,"column":6},"end":{"line":366,"column":8}},"144":{"start":{"line":362,"column":8},"end":{"line":364,"column":9}},"145":{"start":{"line":363,"column":10},"end":{"line":363,"column":39}},"146":{"start":{"line":365,"column":8},"end":{"line":365,"column":27}},"147":{"start":{"line":369,"column":11},"end":{"line":392,"column":5}},"148":{"start":{"line":370,"column":6},"end":{"line":383,"column":8}},"149":{"start":{"line":371,"column":8},"end":{"line":371,"column":38}},"150":{"start":{"line":372,"column":8},"end":{"line":378,"column":9}},"151":{"start":{"line":376,"column":10},"end":{"line":376,"column":25}},"152":{"start":{"line":377,"column":10},"end":{"line":377,"column":39}},"153":{"start":{"line":382,"column":8},"end":{"line":382,"column":80}},"154":{"start":{"line":386,"column":6},"end":{"line":391,"column":7}},"155":{"start":{"line":387,"column":8},"end":{"line":387,"column":29}},"156":{"start":{"line":388,"column":8},"end":{"line":388,"column":39}},"157":{"start":{"line":390,"column":8},"end":{"line":390,"column":23}},"158":{"start":{"line":394,"column":4},"end":{"line":398,"column":5}},"159":{"start":{"line":395,"column":6},"end":{"line":397,"column":8}},"160":{"start":{"line":396,"column":8},"end":{"line":396,"column":37}},"161":{"start":{"line":399,"column":4},"end":{"line":399,"column":17}},"162":{"start":{"line":404,"column":2},"end":{"line":408,"column":3}},"163":{"start":{"line":405,"column":4},"end":{"line":407,"column":7}},"164":{"start":{"line":406,"column":6},"end":{"line":406,"column":22}},"165":{"start":{"line":417,"column":2},"end":{"line":417,"column":26}},"166":{"start":{"line":418,"column":2},"end":{"line":420,"column":3}},"167":{"start":{"line":419,"column":4},"end":{"line":419,"column":21}},"168":{"start":{"line":428,"column":2},"end":{"line":428,"column":67}},"169":{"start":{"line":429,"column":2},"end":{"line":445,"column":3}},"170":{"start":{"line":430,"column":4},"end":{"line":443,"column":5}},"171":{"start":{"line":431,"column":6},"end":{"line":442,"column":15}},"172":{"start":{"line":432,"column":8},"end":{"line":432,"column":129}},"173":{"start":{"line":433,"column":8},"end":{"line":433,"column":36}},"174":{"start":{"line":435,"column":8},"end":{"line":435,"column":35}},"175":{"start":{"line":436,"column":8},"end":{"line":436,"column":33}},"176":{"start":{"line":438,"column":8},"end":{"line":441,"column":10}},"177":{"start":{"line":444,"column":4},"end":{"line":444,"column":16}},"178":{"start":{"line":453,"column":2},"end":{"line":453,"column":51}},"179":{"start":{"line":454,"column":2},"end":{"line":477,"column":3}},"180":{"start":{"line":455,"column":4},"end":{"line":475,"column":5}},"181":{"start":{"line":457,"column":6},"end":{"line":457,"column":23}},"182":{"start":{"line":458,"column":11},"end":{"line":475,"column":5}},"183":{"start":{"line":459,"column":6},"end":{"line":474,"column":15}},"184":{"start":{"line":460,"column":8},"end":{"line":460,"column":80}},"185":{"start":{"line":461,"column":8},"end":{"line":473,"column":9}},"186":{"start":{"line":463,"column":10},"end":{"line":463,"column":36}},"187":{"start":{"line":464,"column":10},"end":{"line":472,"column":11}},"188":{"start":{"line":466,"column":12},"end":{"line":466,"column":69}},"189":{"start":{"line":467,"column":12},"end":{"line":471,"column":13}},"190":{"start":{"line":468,"column":14},"end":{"line":470,"column":15}},"191":{"start":{"line":469,"column":16},"end":{"line":469,"column":64}},"192":{"start":{"line":476,"column":4},"end":{"line":476,"column":16}},"193":{"start":{"line":482,"column":2},"end":{"line":482,"column":31}},"194":{"start":{"line":483,"column":2},"end":{"line":519,"column":3}},"195":{"start":{"line":484,"column":4},"end":{"line":484,"column":43}},"196":{"start":{"line":486,"column":4},"end":{"line":488,"column":5}},"197":{"start":{"line":487,"column":6},"end":{"line":487,"column":32}},"198":{"start":{"line":489,"column":4},"end":{"line":489,"column":47}},"199":{"start":{"line":491,"column":4},"end":{"line":493,"column":5}},"200":{"start":{"line":492,"column":6},"end":{"line":492,"column":26}},"201":{"start":{"line":495,"column":4},"end":{"line":495,"column":73}},"202":{"start":{"line":496,"column":4},"end":{"line":506,"column":5}},"203":{"start":{"line":497,"column":6},"end":{"line":497,"column":63}},"204":{"start":{"line":498,"column":6},"end":{"line":505,"column":7}},"205":{"start":{"line":500,"column":8},"end":{"line":504,"column":9}},"206":{"start":{"line":501,"column":10},"end":{"line":501,"column":97}},"207":{"start":{"line":503,"column":10},"end":{"line":503,"column":29}},"208":{"start":{"line":508,"column":4},"end":{"line":517,"column":5}},"209":{"start":{"line":509,"column":6},"end":{"line":509,"column":57}},"210":{"start":{"line":510,"column":6},"end":{"line":516,"column":7}},"211":{"start":{"line":511,"column":8},"end":{"line":515,"column":9}},"212":{"start":{"line":512,"column":10},"end":{"line":512,"column":88}},"213":{"start":{"line":514,"column":10},"end":{"line":514,"column":29}},"214":{"start":{"line":518,"column":4},"end":{"line":518,"column":16}},"215":{"start":{"line":528,"column":2},"end":{"line":528,"column":24}},"216":{"start":{"line":531,"column":2},"end":{"line":537,"column":3}},"217":{"start":{"line":532,"column":4},"end":{"line":532,"column":22}},"218":{"start":{"line":533,"column":4},"end":{"line":535,"column":5}},"219":{"start":{"line":534,"column":6},"end":{"line":534,"column":23}},"220":{"start":{"line":536,"column":4},"end":{"line":536,"column":20}},"221":{"start":{"line":540,"column":2},"end":{"line":540,"column":43}},"222":{"start":{"line":543,"column":2},"end":{"line":543,"column":33}},"223":{"start":{"line":544,"column":2},"end":{"line":544,"column":38}},"224":{"start":{"line":547,"column":2},"end":{"line":551,"column":96}},"225":{"start":{"line":548,"column":4},"end":{"line":550,"column":5}},"226":{"start":{"line":549,"column":6},"end":{"line":549,"column":42}},"227":{"start":{"line":554,"column":2},"end":{"line":554,"column":36}},"228":{"start":{"line":555,"column":2},"end":{"line":563,"column":3}},"229":{"start":{"line":556,"column":4},"end":{"line":561,"column":5}},"230":{"start":{"line":557,"column":6},"end":{"line":557,"column":49}},"231":{"start":{"line":558,"column":6},"end":{"line":558,"column":29}},"232":{"start":{"line":559,"column":6},"end":{"line":559,"column":33}},"233":{"start":{"line":560,"column":6},"end":{"line":560,"column":26}},"234":{"start":{"line":562,"column":4},"end":{"line":562,"column":16}},"235":{"start":{"line":566,"column":2},"end":{"line":566,"column":36}},"236":{"start":{"line":567,"column":2},"end":{"line":570,"column":3}},"237":{"start":{"line":568,"column":4},"end":{"line":568,"column":36}},"238":{"start":{"line":569,"column":4},"end":{"line":569,"column":16}},"239":{"start":{"line":574,"column":2},"end":{"line":574,"column":32}},"240":{"start":{"line":575,"column":2},"end":{"line":588,"column":3}},"241":{"start":{"line":576,"column":4},"end":{"line":576,"column":41}},"242":{"start":{"line":577,"column":4},"end":{"line":577,"column":31}},"243":{"start":{"line":578,"column":4},"end":{"line":580,"column":5}},"244":{"start":{"line":579,"column":6},"end":{"line":579,"column":35}},"245":{"start":{"line":581,"column":4},"end":{"line":586,"column":5}},"246":{"start":{"line":582,"column":6},"end":{"line":582,"column":48}},"247":{"start":{"line":583,"column":6},"end":{"line":585,"column":7}},"248":{"start":{"line":584,"column":8},"end":{"line":584,"column":24}},"249":{"start":{"line":587,"column":4},"end":{"line":587,"column":16}},"250":{"start":{"line":593,"column":2},"end":{"line":593,"column":41}},"251":{"start":{"line":594,"column":2},"end":{"line":618,"column":3}},"252":{"start":{"line":595,"column":4},"end":{"line":595,"column":30}},"253":{"start":{"line":597,"column":4},"end":{"line":597,"column":21}},"254":{"start":{"line":598,"column":4},"end":{"line":617,"column":5}},"255":{"start":{"line":601,"column":8},"end":{"line":601,"column":29}},"256":{"start":{"line":602,"column":8},"end":{"line":602,"column":14}},"257":{"start":{"line":604,"column":8},"end":{"line":604,"column":27}},"258":{"start":{"line":605,"column":8},"end":{"line":605,"column":14}},"259":{"start":{"line":608,"column":8},"end":{"line":608,"column":57}},"260":{"start":{"line":609,"column":8},"end":{"line":616,"column":9}},"261":{"start":{"line":610,"column":10},"end":{"line":610,"column":39}},"262":{"start":{"line":612,"column":10},"end":{"line":612,"column":66}},"263":{"start":{"line":615,"column":10},"end":{"line":615,"column":32}},"264":{"start":{"line":621,"column":2},"end":{"line":621,"column":33}},"265":{"start":{"line":622,"column":2},"end":{"line":638,"column":3}},"266":{"start":{"line":624,"column":4},"end":{"line":624,"column":15}},"267":{"start":{"line":625,"column":4},"end":{"line":625,"column":56}},"268":{"start":{"line":627,"column":4},"end":{"line":627,"column":23}},"269":{"start":{"line":629,"column":4},"end":{"line":636,"column":5}},"270":{"start":{"line":630,"column":6},"end":{"line":630,"column":35}},"271":{"start":{"line":632,"column":6},"end":{"line":632,"column":62}},"272":{"start":{"line":635,"column":6},"end":{"line":635,"column":28}},"273":{"start":{"line":637,"column":4},"end":{"line":637,"column":16}},"274":{"start":{"line":644,"column":2},"end":{"line":644,"column":22}},"275":{"start":{"line":645,"column":2},"end":{"line":657,"column":3}},"276":{"start":{"line":646,"column":4},"end":{"line":646,"column":22}},"277":{"start":{"line":647,"column":4},"end":{"line":650,"column":5}},"278":{"start":{"line":648,"column":6},"end":{"line":648,"column":18}},"279":{"start":{"line":649,"column":6},"end":{"line":649,"column":18}},"280":{"start":{"line":651,"column":4},"end":{"line":653,"column":5}},"281":{"start":{"line":652,"column":6},"end":{"line":652,"column":23}},"282":{"start":{"line":654,"column":4},"end":{"line":654,"column":21}},"283":{"start":{"line":656,"column":4},"end":{"line":656,"column":39}},"284":{"start":{"line":660,"column":2},"end":{"line":660,"column":32}},"285":{"start":{"line":661,"column":2},"end":{"line":661,"column":36}},"286":{"start":{"line":664,"column":2},"end":{"line":664,"column":41}},"287":{"start":{"line":667,"column":2},"end":{"line":667,"column":39}},"288":{"start":{"line":668,"column":2},"end":{"line":692,"column":3}},"289":{"start":{"line":669,"column":4},"end":{"line":669,"column":17}},"290":{"start":{"line":670,"column":4},"end":{"line":691,"column":5}},"291":{"start":{"line":672,"column":8},"end":{"line":672,"column":44}},"292":{"start":{"line":673,"column":8},"end":{"line":673,"column":14}},"293":{"start":{"line":675,"column":8},"end":{"line":675,"column":29}},"294":{"start":{"line":676,"column":8},"end":{"line":676,"column":14}},"295":{"start":{"line":678,"column":8},"end":{"line":678,"column":27}},"296":{"start":{"line":679,"column":8},"end":{"line":679,"column":14}},"297":{"start":{"line":681,"column":8},"end":{"line":681,"column":34}},"298":{"start":{"line":683,"column":8},"end":{"line":690,"column":9}},"299":{"start":{"line":684,"column":10},"end":{"line":689,"column":13}},"300":{"start":{"line":696,"column":2},"end":{"line":696,"column":23}},"301":{"start":{"line":697,"column":2},"end":{"line":706,"column":3}},"302":{"start":{"line":698,"column":4},"end":{"line":704,"column":5}},"303":{"start":{"line":699,"column":6},"end":{"line":703,"column":9}},"304":{"start":{"line":705,"column":4},"end":{"line":705,"column":21}},"305":{"start":{"line":709,"column":2},"end":{"line":709,"column":31}},"306":{"start":{"line":710,"column":2},"end":{"line":715,"column":3}},"307":{"start":{"line":711,"column":4},"end":{"line":711,"column":23}},"308":{"start":{"line":713,"column":4},"end":{"line":713,"column":20}},"309":{"start":{"line":714,"column":4},"end":{"line":714,"column":16}},"310":{"start":{"line":719,"column":2},"end":{"line":719,"column":25}},"311":{"start":{"line":720,"column":2},"end":{"line":731,"column":3}},"312":{"start":{"line":721,"column":4},"end":{"line":727,"column":5}},"313":{"start":{"line":722,"column":6},"end":{"line":726,"column":8}},"314":{"start":{"line":729,"column":4},"end":{"line":729,"column":54}},"315":{"start":{"line":730,"column":4},"end":{"line":730,"column":28}},"316":{"start":{"line":734,"column":2},"end":{"line":734,"column":31}},"317":{"start":{"line":735,"column":2},"end":{"line":737,"column":3}},"318":{"start":{"line":736,"column":4},"end":{"line":736,"column":69}},"319":{"start":{"line":741,"column":2},"end":{"line":741,"column":54}},"320":{"start":{"line":742,"column":2},"end":{"line":744,"column":3}},"321":{"start":{"line":743,"column":4},"end":{"line":743,"column":30}},"322":{"start":{"line":747,"column":2},"end":{"line":747,"column":63}},"323":{"start":{"line":748,"column":2},"end":{"line":750,"column":3}},"324":{"start":{"line":749,"column":4},"end":{"line":749,"column":30}},"325":{"start":{"line":753,"column":2},"end":{"line":753,"column":72}},"326":{"start":{"line":754,"column":2},"end":{"line":756,"column":3}},"327":{"start":{"line":755,"column":4},"end":{"line":755,"column":31}},"328":{"start":{"line":759,"column":2},"end":{"line":759,"column":81}},"329":{"start":{"line":760,"column":2},"end":{"line":762,"column":3}},"330":{"start":{"line":761,"column":4},"end":{"line":761,"column":31}},"331":{"start":{"line":766,"column":2},"end":{"line":766,"column":57}},"332":{"start":{"line":769,"column":2},"end":{"line":769,"column":75}},"333":{"start":{"line":770,"column":2},"end":{"line":772,"column":3}},"334":{"start":{"line":771,"column":4},"end":{"line":771,"column":37}},"335":{"start":{"line":775,"column":2},"end":{"line":775,"column":37}},"336":{"start":{"line":776,"column":2},"end":{"line":789,"column":3}},"337":{"start":{"line":777,"column":4},"end":{"line":777,"column":63}},"338":{"start":{"line":779,"column":4},"end":{"line":782,"column":5}},"339":{"start":{"line":780,"column":6},"end":{"line":780,"column":25}},"340":{"start":{"line":781,"column":6},"end":{"line":781,"column":22}},"341":{"start":{"line":783,"column":4},"end":{"line":787,"column":5}},"342":{"start":{"line":784,"column":6},"end":{"line":784,"column":17}},"343":{"start":{"line":786,"column":6},"end":{"line":786,"column":90}},"344":{"start":{"line":788,"column":4},"end":{"line":788,"column":60}},"345":{"start":{"line":792,"column":2},"end":{"line":792,"column":41}},"346":{"start":{"line":793,"column":2},"end":{"line":801,"column":3}},"347":{"start":{"line":794,"column":4},"end":{"line":794,"column":18}},"348":{"start":{"line":795,"column":4},"end":{"line":799,"column":5}},"349":{"start":{"line":796,"column":6},"end":{"line":796,"column":17}},"350":{"start":{"line":798,"column":6},"end":{"line":798,"column":17}},"351":{"start":{"line":800,"column":4},"end":{"line":800,"column":62}},"352":{"start":{"line":805,"column":2},"end":{"line":805,"column":29}},"353":{"start":{"line":806,"column":2},"end":{"line":811,"column":3}},"354":{"start":{"line":807,"column":4},"end":{"line":810,"column":7}},"355":{"start":{"line":812,"column":2},"end":{"line":812,"column":17}}},"branchMap":{"1":{"line":12,"type":"if","locations":[{"start":{"line":12,"column":2},"end":{"line":12,"column":2}},{"start":{"line":12,"column":2},"end":{"line":12,"column":2}}]},"2":{"line":12,"type":"binary-expr","locations":[{"start":{"line":12,"column":6},"end":{"line":12,"column":33}},{"start":{"line":12,"column":37},"end":{"line":12,"column":47}}]},"3":{"line":17,"type":"binary-expr","locations":[{"start":{"line":17,"column":16},"end":{"line":17,"column":42}},{"start":{"line":17,"column":46},"end":{"line":17,"column":53}},{"start":{"line":17,"column":58},"end":{"line":29,"column":5}}]},"4":{"line":59,"type":"binary-expr","locations":[{"start":{"line":59,"column":16},"end":{"line":59,"column":42}},{"start":{"line":59,"column":46},"end":{"line":59,"column":61}},{"start":{"line":59,"column":65},"end":{"line":59,"column":102}}]},"5":{"line":63,"type":"binary-expr","locations":[{"start":{"line":63,"column":12},"end":{"line":63,"column":38}},{"start":{"line":63,"column":42},"end":{"line":63,"column":54}},{"start":{"line":63,"column":58},"end":{"line":63,"column":103}},{"start":{"line":63,"column":107},"end":{"line":63,"column":139}}]},"6":{"line":76,"type":"if","locations":[{"start":{"line":76,"column":4},"end":{"line":76,"column":4}},{"start":{"line":76,"column":4},"end":{"line":76,"column":4}}]},"7":{"line":79,"type":"if","locations":[{"start":{"line":79,"column":8},"end":{"line":79,"column":8}},{"start":{"line":79,"column":8},"end":{"line":79,"column":8}}]},"8":{"line":84,"type":"if","locations":[{"start":{"line":84,"column":11},"end":{"line":84,"column":11}},{"start":{"line":84,"column":11},"end":{"line":84,"column":11}}]},"9":{"line":88,"type":"if","locations":[{"start":{"line":88,"column":8},"end":{"line":88,"column":8}},{"start":{"line":88,"column":8},"end":{"line":88,"column":8}}]},"10":{"line":103,"type":"if","locations":[{"start":{"line":103,"column":8},"end":{"line":103,"column":8}},{"start":{"line":103,"column":8},"end":{"line":103,"column":8}}]},"11":{"line":106,"type":"binary-expr","locations":[{"start":{"line":106,"column":22},"end":{"line":106,"column":40}},{"start":{"line":106,"column":44},"end":{"line":106,"column":50}}]},"12":{"line":107,"type":"binary-expr","locations":[{"start":{"line":107,"column":15},"end":{"line":107,"column":33}},{"start":{"line":107,"column":37},"end":{"line":107,"column":99}}]},"13":{"line":107,"type":"binary-expr","locations":[{"start":{"line":107,"column":39},"end":{"line":107,"column":57}},{"start":{"line":107,"column":61},"end":{"line":107,"column":98}}]},"14":{"line":132,"type":"if","locations":[{"start":{"line":132,"column":6},"end":{"line":132,"column":6}},{"start":{"line":132,"column":6},"end":{"line":132,"column":6}}]},"15":{"line":139,"type":"if","locations":[{"start":{"line":139,"column":4},"end":{"line":139,"column":4}},{"start":{"line":139,"column":4},"end":{"line":139,"column":4}}]},"16":{"line":147,"type":"if","locations":[{"start":{"line":147,"column":8},"end":{"line":147,"column":8}},{"start":{"line":147,"column":8},"end":{"line":147,"column":8}}]},"17":{"line":154,"type":"if","locations":[{"start":{"line":154,"column":10},"end":{"line":154,"column":10}},{"start":{"line":154,"column":10},"end":{"line":154,"column":10}}]},"18":{"line":154,"type":"binary-expr","locations":[{"start":{"line":154,"column":14},"end":{"line":154,"column":54}},{"start":{"line":154,"column":58},"end":{"line":154,"column":82}},{"start":{"line":154,"column":86},"end":{"line":154,"column":160}}]},"19":{"line":154,"type":"binary-expr","locations":[{"start":{"line":154,"column":16},"end":{"line":154,"column":26}},{"start":{"line":154,"column":30},"end":{"line":154,"column":53}}]},"20":{"line":161,"type":"if","locations":[{"start":{"line":161,"column":10},"end":{"line":161,"column":10}},{"start":{"line":161,"column":10},"end":{"line":161,"column":10}}]},"21":{"line":161,"type":"binary-expr","locations":[{"start":{"line":161,"column":14},"end":{"line":161,"column":38}},{"start":{"line":161,"column":42},"end":{"line":161,"column":116}}]},"22":{"line":166,"type":"if","locations":[{"start":{"line":166,"column":11},"end":{"line":166,"column":11}},{"start":{"line":166,"column":11},"end":{"line":166,"column":11}}]},"23":{"line":171,"type":"if","locations":[{"start":{"line":171,"column":8},"end":{"line":171,"column":8}},{"start":{"line":171,"column":8},"end":{"line":171,"column":8}}]},"24":{"line":181,"type":"if","locations":[{"start":{"line":181,"column":10},"end":{"line":181,"column":10}},{"start":{"line":181,"column":10},"end":{"line":181,"column":10}}]},"25":{"line":181,"type":"binary-expr","locations":[{"start":{"line":181,"column":14},"end":{"line":181,"column":54}},{"start":{"line":181,"column":58},"end":{"line":181,"column":84}},{"start":{"line":181,"column":89},"end":{"line":181,"column":110}},{"start":{"line":181,"column":115},"end":{"line":181,"column":139}},{"start":{"line":181,"column":143},"end":{"line":181,"column":217}}]},"26":{"line":181,"type":"binary-expr","locations":[{"start":{"line":181,"column":16},"end":{"line":181,"column":26}},{"start":{"line":181,"column":30},"end":{"line":181,"column":53}}]},"27":{"line":190,"type":"if","locations":[{"start":{"line":190,"column":8},"end":{"line":190,"column":8}},{"start":{"line":190,"column":8},"end":{"line":190,"column":8}}]},"28":{"line":195,"type":"if","locations":[{"start":{"line":195,"column":10},"end":{"line":195,"column":10}},{"start":{"line":195,"column":10},"end":{"line":195,"column":10}}]},"29":{"line":195,"type":"binary-expr","locations":[{"start":{"line":195,"column":14},"end":{"line":195,"column":54}},{"start":{"line":195,"column":58},"end":{"line":195,"column":82}},{"start":{"line":195,"column":86},"end":{"line":195,"column":131}},{"start":{"line":195,"column":135},"end":{"line":195,"column":209}}]},"30":{"line":195,"type":"binary-expr","locations":[{"start":{"line":195,"column":16},"end":{"line":195,"column":26}},{"start":{"line":195,"column":30},"end":{"line":195,"column":53}}]},"31":{"line":201,"type":"if","locations":[{"start":{"line":201,"column":8},"end":{"line":201,"column":8}},{"start":{"line":201,"column":8},"end":{"line":201,"column":8}}]},"32":{"line":201,"type":"binary-expr","locations":[{"start":{"line":201,"column":12},"end":{"line":201,"column":25}},{"start":{"line":201,"column":29},"end":{"line":201,"column":58}}]},"33":{"line":216,"type":"if","locations":[{"start":{"line":216,"column":6},"end":{"line":216,"column":6}},{"start":{"line":216,"column":6},"end":{"line":216,"column":6}}]},"34":{"line":219,"type":"binary-expr","locations":[{"start":{"line":219,"column":15},"end":{"line":219,"column":24}},{"start":{"line":219,"column":29},"end":{"line":219,"column":50}}]},"35":{"line":222,"type":"if","locations":[{"start":{"line":222,"column":6},"end":{"line":222,"column":6}},{"start":{"line":222,"column":6},"end":{"line":222,"column":6}}]},"36":{"line":226,"type":"if","locations":[{"start":{"line":226,"column":6},"end":{"line":226,"column":6}},{"start":{"line":226,"column":6},"end":{"line":226,"column":6}}]},"37":{"line":229,"type":"switch","locations":[{"start":{"line":233,"column":8},"end":{"line":234,"column":47}},{"start":{"line":235,"column":8},"end":{"line":240,"column":98}},{"start":{"line":244,"column":8},"end":{"line":244,"column":29}},{"start":{"line":245,"column":8},"end":{"line":246,"column":33}},{"start":{"line":249,"column":8},"end":{"line":254,"column":51}}]},"38":{"line":240,"type":"cond-expr","locations":[{"start":{"line":240,"column":32},"end":{"line":240,"column":46}},{"start":{"line":240,"column":50},"end":{"line":240,"column":96}}]},"39":{"line":240,"type":"cond-expr","locations":[{"start":{"line":240,"column":57},"end":{"line":240,"column":70}},{"start":{"line":240,"column":74},"end":{"line":240,"column":95}}]},"40":{"line":250,"type":"binary-expr","locations":[{"start":{"line":250,"column":17},"end":{"line":250,"column":44}},{"start":{"line":251,"column":17},"end":{"line":251,"column":44}},{"start":{"line":252,"column":17},"end":{"line":252,"column":50}},{"start":{"line":253,"column":17},"end":{"line":253,"column":52}},{"start":{"line":254,"column":17},"end":{"line":254,"column":50}}]},"41":{"line":256,"type":"if","locations":[{"start":{"line":256,"column":6},"end":{"line":256,"column":6}},{"start":{"line":256,"column":6},"end":{"line":256,"column":6}}]},"42":{"line":256,"type":"binary-expr","locations":[{"start":{"line":256,"column":10},"end":{"line":256,"column":33}},{"start":{"line":256,"column":37},"end":{"line":256,"column":61}}]},"43":{"line":264,"type":"if","locations":[{"start":{"line":264,"column":8},"end":{"line":264,"column":8}},{"start":{"line":264,"column":8},"end":{"line":264,"column":8}}]},"44":{"line":272,"type":"if","locations":[{"start":{"line":272,"column":6},"end":{"line":272,"column":6}},{"start":{"line":272,"column":6},"end":{"line":272,"column":6}}]},"45":{"line":276,"type":"if","locations":[{"start":{"line":276,"column":8},"end":{"line":276,"column":8}},{"start":{"line":276,"column":8},"end":{"line":276,"column":8}}]},"46":{"line":280,"type":"if","locations":[{"start":{"line":280,"column":12},"end":{"line":280,"column":12}},{"start":{"line":280,"column":12},"end":{"line":280,"column":12}}]},"47":{"line":280,"type":"binary-expr","locations":[{"start":{"line":280,"column":28},"end":{"line":280,"column":57}},{"start":{"line":280,"column":62},"end":{"line":280,"column":96}}]},"48":{"line":293,"type":"binary-expr","locations":[{"start":{"line":293,"column":26},"end":{"line":293,"column":44}},{"start":{"line":293,"column":48},"end":{"line":293,"column":76}}]},"49":{"line":296,"type":"if","locations":[{"start":{"line":296,"column":8},"end":{"line":296,"column":8}},{"start":{"line":296,"column":8},"end":{"line":296,"column":8}}]},"50":{"line":298,"type":"if","locations":[{"start":{"line":298,"column":12},"end":{"line":298,"column":12}},{"start":{"line":298,"column":12},"end":{"line":298,"column":12}}]},"51":{"line":315,"type":"if","locations":[{"start":{"line":315,"column":8},"end":{"line":315,"column":8}},{"start":{"line":315,"column":8},"end":{"line":315,"column":8}}]},"52":{"line":330,"type":"if","locations":[{"start":{"line":330,"column":4},"end":{"line":330,"column":4}},{"start":{"line":330,"column":4},"end":{"line":330,"column":4}}]},"53":{"line":334,"type":"if","locations":[{"start":{"line":334,"column":6},"end":{"line":334,"column":6}},{"start":{"line":334,"column":6},"end":{"line":334,"column":6}}]},"54":{"line":346,"type":"if","locations":[{"start":{"line":346,"column":4},"end":{"line":346,"column":4}},{"start":{"line":346,"column":4},"end":{"line":346,"column":4}}]},"55":{"line":360,"type":"if","locations":[{"start":{"line":360,"column":11},"end":{"line":360,"column":11}},{"start":{"line":360,"column":11},"end":{"line":360,"column":11}}]},"56":{"line":369,"type":"if","locations":[{"start":{"line":369,"column":11},"end":{"line":369,"column":11}},{"start":{"line":369,"column":11},"end":{"line":369,"column":11}}]},"57":{"line":394,"type":"if","locations":[{"start":{"line":394,"column":4},"end":{"line":394,"column":4}},{"start":{"line":394,"column":4},"end":{"line":394,"column":4}}]},"58":{"line":394,"type":"binary-expr","locations":[{"start":{"line":394,"column":8},"end":{"line":394,"column":14}},{"start":{"line":394,"column":18},"end":{"line":394,"column":42}}]},"59":{"line":430,"type":"if","locations":[{"start":{"line":430,"column":4},"end":{"line":430,"column":4}},{"start":{"line":430,"column":4},"end":{"line":430,"column":4}}]},"60":{"line":430,"type":"binary-expr","locations":[{"start":{"line":430,"column":8},"end":{"line":430,"column":13}},{"start":{"line":430,"column":17},"end":{"line":430,"column":25}}]},"61":{"line":432,"type":"binary-expr","locations":[{"start":{"line":432,"column":24},"end":{"line":432,"column":50}},{"start":{"line":432,"column":54},"end":{"line":432,"column":72}}]},"62":{"line":432,"type":"cond-expr","locations":[{"start":{"line":432,"column":95},"end":{"line":432,"column":113}},{"start":{"line":432,"column":116},"end":{"line":432,"column":118}}]},"63":{"line":440,"type":"cond-expr","locations":[{"start":{"line":440,"column":30},"end":{"line":440,"column":44}},{"start":{"line":440,"column":47},"end":{"line":440,"column":53}}]},"64":{"line":455,"type":"if","locations":[{"start":{"line":455,"column":4},"end":{"line":455,"column":4}},{"start":{"line":455,"column":4},"end":{"line":455,"column":4}}]},"65":{"line":458,"type":"if","locations":[{"start":{"line":458,"column":11},"end":{"line":458,"column":11}},{"start":{"line":458,"column":11},"end":{"line":458,"column":11}}]},"66":{"line":460,"type":"binary-expr","locations":[{"start":{"line":460,"column":21},"end":{"line":460,"column":47}},{"start":{"line":460,"column":51},"end":{"line":460,"column":69}}]},"67":{"line":461,"type":"if","locations":[{"start":{"line":461,"column":8},"end":{"line":461,"column":8}},{"start":{"line":461,"column":8},"end":{"line":461,"column":8}}]},"68":{"line":464,"type":"if","locations":[{"start":{"line":464,"column":10},"end":{"line":464,"column":10}},{"start":{"line":464,"column":10},"end":{"line":464,"column":10}}]},"69":{"line":466,"type":"binary-expr","locations":[{"start":{"line":466,"column":23},"end":{"line":466,"column":49}},{"start":{"line":466,"column":53},"end":{"line":466,"column":68}}]},"70":{"line":467,"type":"binary-expr","locations":[{"start":{"line":467,"column":29},"end":{"line":467,"column":51}},{"start":{"line":467,"column":55},"end":{"line":467,"column":66}}]},"71":{"line":468,"type":"if","locations":[{"start":{"line":468,"column":14},"end":{"line":468,"column":14}},{"start":{"line":468,"column":14},"end":{"line":468,"column":14}}]},"72":{"line":468,"type":"binary-expr","locations":[{"start":{"line":468,"column":18},"end":{"line":468,"column":44}},{"start":{"line":468,"column":48},"end":{"line":468,"column":75}},{"start":{"line":468,"column":80},"end":{"line":468,"column":87}},{"start":{"line":468,"column":92},"end":{"line":468,"column":117}},{"start":{"line":468,"column":121},"end":{"line":468,"column":146}}]},"73":{"line":486,"type":"if","locations":[{"start":{"line":486,"column":4},"end":{"line":486,"column":4}},{"start":{"line":486,"column":4},"end":{"line":486,"column":4}}]},"74":{"line":486,"type":"binary-expr","locations":[{"start":{"line":486,"column":8},"end":{"line":486,"column":32}},{"start":{"line":486,"column":36},"end":{"line":486,"column":77}}]},"75":{"line":489,"type":"binary-expr","locations":[{"start":{"line":489,"column":11},"end":{"line":489,"column":32}},{"start":{"line":489,"column":36},"end":{"line":489,"column":46}}]},"76":{"line":491,"type":"if","locations":[{"start":{"line":491,"column":4},"end":{"line":491,"column":4}},{"start":{"line":491,"column":4},"end":{"line":491,"column":4}}]},"77":{"line":495,"type":"binary-expr","locations":[{"start":{"line":495,"column":10},"end":{"line":495,"column":23}},{"start":{"line":495,"column":27},"end":{"line":495,"column":53}},{"start":{"line":495,"column":57},"end":{"line":495,"column":72}}]},"78":{"line":496,"type":"if","locations":[{"start":{"line":496,"column":4},"end":{"line":496,"column":4}},{"start":{"line":496,"column":4},"end":{"line":496,"column":4}}]},"79":{"line":496,"type":"binary-expr","locations":[{"start":{"line":496,"column":18},"end":{"line":496,"column":43}},{"start":{"line":496,"column":47},"end":{"line":496,"column":64}}]},"80":{"line":497,"type":"binary-expr","locations":[{"start":{"line":497,"column":17},"end":{"line":497,"column":43}},{"start":{"line":497,"column":47},"end":{"line":497,"column":62}}]},"81":{"line":498,"type":"binary-expr","locations":[{"start":{"line":498,"column":23},"end":{"line":498,"column":45}},{"start":{"line":498,"column":49},"end":{"line":498,"column":60}}]},"82":{"line":501,"type":"binary-expr","locations":[{"start":{"line":501,"column":37},"end":{"line":501,"column":62}},{"start":{"line":501,"column":66},"end":{"line":501,"column":80}},{"start":{"line":501,"column":84},"end":{"line":501,"column":88}}]},"83":{"line":508,"type":"if","locations":[{"start":{"line":508,"column":4},"end":{"line":508,"column":4}},{"start":{"line":508,"column":4},"end":{"line":508,"column":4}}]},"84":{"line":509,"type":"binary-expr","locations":[{"start":{"line":509,"column":17},"end":{"line":509,"column":40}},{"start":{"line":509,"column":44},"end":{"line":509,"column":56}}]},"85":{"line":510,"type":"binary-expr","locations":[{"start":{"line":510,"column":20},"end":{"line":510,"column":39}},{"start":{"line":510,"column":43},"end":{"line":510,"column":51}}]},"86":{"line":512,"type":"binary-expr","locations":[{"start":{"line":512,"column":34},"end":{"line":512,"column":56}},{"start":{"line":512,"column":60},"end":{"line":512,"column":71}},{"start":{"line":512,"column":75},"end":{"line":512,"column":79}}]},"87":{"line":533,"type":"if","locations":[{"start":{"line":533,"column":4},"end":{"line":533,"column":4}},{"start":{"line":533,"column":4},"end":{"line":533,"column":4}}]},"88":{"line":577,"type":"binary-expr","locations":[{"start":{"line":577,"column":4},"end":{"line":577,"column":12}},{"start":{"line":577,"column":17},"end":{"line":577,"column":29}}]},"89":{"line":578,"type":"if","locations":[{"start":{"line":578,"column":4},"end":{"line":578,"column":4}},{"start":{"line":578,"column":4},"end":{"line":578,"column":4}}]},"90":{"line":582,"type":"binary-expr","locations":[{"start":{"line":582,"column":13},"end":{"line":582,"column":29}},{"start":{"line":582,"column":33},"end":{"line":582,"column":47}}]},"91":{"line":583,"type":"if","locations":[{"start":{"line":583,"column":6},"end":{"line":583,"column":6}},{"start":{"line":583,"column":6},"end":{"line":583,"column":6}}]},"92":{"line":583,"type":"binary-expr","locations":[{"start":{"line":583,"column":10},"end":{"line":583,"column":14}},{"start":{"line":583,"column":18},"end":{"line":583,"column":55}},{"start":{"line":583,"column":59},"end":{"line":583,"column":79}}]},"93":{"line":598,"type":"switch","locations":[{"start":{"line":600,"column":6},"end":{"line":602,"column":14}},{"start":{"line":603,"column":6},"end":{"line":605,"column":14}},{"start":{"line":606,"column":6},"end":{"line":616,"column":9}}]},"94":{"line":609,"type":"if","locations":[{"start":{"line":609,"column":8},"end":{"line":609,"column":8}},{"start":{"line":609,"column":8},"end":{"line":609,"column":8}}]},"95":{"line":629,"type":"if","locations":[{"start":{"line":629,"column":4},"end":{"line":629,"column":4}},{"start":{"line":629,"column":4},"end":{"line":629,"column":4}}]},"96":{"line":647,"type":"if","locations":[{"start":{"line":647,"column":4},"end":{"line":647,"column":4}},{"start":{"line":647,"column":4},"end":{"line":647,"column":4}}]},"97":{"line":647,"type":"binary-expr","locations":[{"start":{"line":647,"column":8},"end":{"line":647,"column":12}},{"start":{"line":647,"column":16},"end":{"line":647,"column":28}}]},"98":{"line":651,"type":"if","locations":[{"start":{"line":651,"column":4},"end":{"line":651,"column":4}},{"start":{"line":651,"column":4},"end":{"line":651,"column":4}}]},"99":{"line":670,"type":"switch","locations":[{"start":{"line":671,"column":6},"end":{"line":673,"column":14}},{"start":{"line":674,"column":6},"end":{"line":676,"column":14}},{"start":{"line":677,"column":6},"end":{"line":679,"column":14}},{"start":{"line":680,"column":6},"end":{"line":690,"column":9}}]},"100":{"line":683,"type":"if","locations":[{"start":{"line":683,"column":8},"end":{"line":683,"column":8}},{"start":{"line":683,"column":8},"end":{"line":683,"column":8}}]},"101":{"line":683,"type":"binary-expr","locations":[{"start":{"line":683,"column":13},"end":{"line":683,"column":40}},{"start":{"line":683,"column":44},"end":{"line":683,"column":88}},{"start":{"line":683,"column":93},"end":{"line":683,"column":120}}]},"102":{"line":702,"type":"cond-expr","locations":[{"start":{"line":702,"column":37},"end":{"line":702,"column":41}},{"start":{"line":702,"column":44},"end":{"line":702,"column":51}}]},"103":{"line":721,"type":"if","locations":[{"start":{"line":721,"column":4},"end":{"line":721,"column":4}},{"start":{"line":721,"column":4},"end":{"line":721,"column":4}}]},"104":{"line":725,"type":"cond-expr","locations":[{"start":{"line":725,"column":35},"end":{"line":725,"column":39}},{"start":{"line":725,"column":42},"end":{"line":725,"column":47}}]},"105":{"line":729,"type":"cond-expr","locations":[{"start":{"line":729,"column":30},"end":{"line":729,"column":41}},{"start":{"line":729,"column":44},"end":{"line":729,"column":53}}]},"106":{"line":736,"type":"cond-expr","locations":[{"start":{"line":736,"column":50},"end":{"line":736,"column":57}},{"start":{"line":736,"column":60},"end":{"line":736,"column":67}}]},"107":{"line":779,"type":"if","locations":[{"start":{"line":779,"column":4},"end":{"line":779,"column":4}},{"start":{"line":779,"column":4},"end":{"line":779,"column":4}}]},"108":{"line":779,"type":"binary-expr","locations":[{"start":{"line":779,"column":8},"end":{"line":779,"column":19}},{"start":{"line":779,"column":23},"end":{"line":779,"column":38}}]},"109":{"line":786,"type":"binary-expr","locations":[{"start":{"line":786,"column":11},"end":{"line":786,"column":27}},{"start":{"line":786,"column":32},"end":{"line":786,"column":42}},{"start":{"line":786,"column":46},"end":{"line":786,"column":88}}]},"110":{"line":788,"type":"cond-expr","locations":[{"start":{"line":788,"column":41},"end":{"line":788,"column":48}},{"start":{"line":788,"column":51},"end":{"line":788,"column":58}}]},"111":{"line":800,"type":"cond-expr","locations":[{"start":{"line":800,"column":41},"end":{"line":800,"column":50}},{"start":{"line":800,"column":53},"end":{"line":800,"column":60}}]}}},"/Users/kit/Dropbox/Projects/json3/vendor/spec/lib/newton.js":{"path":"/Users/kit/Dropbox/Projects/json3/vendor/spec/lib/newton.js","s":{"1":1,"2":1,"3":1,"4":0,"5":0,"6":1,"7":1,"8":1,"9":1,"10":0,"11":0,"12":0,"13":1,"14":0,"15":0,"16":0,"17":0,"18":1,"19":1,"20":0,"21":1,"22":0,"23":1,"24":1,"25":0,"26":0,"27":0,"28":0,"29":1,"30":0,"31":0,"32":0,"33":0,"34":0,"35":0,"36":0,"37":0,"38":0,"39":0,"40":0,"41":0,"42":0,"43":0,"44":0,"45":0,"46":0,"47":0,"48":0,"49":0,"50":0,"51":0,"52":0,"53":0,"54":0,"55":0,"56":0,"57":0,"58":1,"59":0,"60":0,"61":0,"62":0,"63":0,"64":0,"65":0,"66":0,"67":0,"68":0,"69":0,"70":0,"71":0,"72":0,"73":0,"74":0,"75":0,"76":0,"77":0,"78":0,"79":0,"80":0,"81":0,"82":0,"83":0,"84":0,"85":0,"86":0,"87":0,"88":0,"89":0,"90":0,"91":0,"92":0,"93":0,"94":0,"95":0,"96":0,"97":0,"98":0,"99":0,"100":0,"101":0,"102":0,"103":0,"104":0,"105":0,"106":0,"107":298,"108":298,"109":298,"110":0,"111":298,"112":4294,"113":4294,"114":322,"115":322,"116":0,"117":322,"118":322,"119":24,"120":24,"121":0,"122":0,"123":0,"124":0,"125":298,"126":0,"127":322,"128":322,"129":3972,"130":298,"131":1,"132":298,"133":1,"134":1,"135":11,"136":11,"137":274,"138":274,"139":0,"140":0,"141":11,"142":11,"143":1,"144":1,"145":0,"146":1,"147":0,"148":1,"149":0,"150":0,"151":0,"152":0,"153":0,"154":0,"155":0,"156":0,"157":0,"158":0,"159":0,"160":0,"161":0,"162":1,"163":0,"164":0,"165":0,"166":0,"167":0,"168":0,"169":0,"170":0,"171":0,"172":0,"173":0,"174":0,"175":0,"176":0,"177":0,"178":0,"179":0,"180":0,"181":0,"182":0,"183":0,"184":0,"185":0,"186":0,"187":0,"188":0,"189":0,"190":0,"191":0,"192":0,"193":0,"194":0,"195":0,"196":0,"197":0,"198":0,"199":0,"200":0,"201":0,"202":0,"203":0,"204":0,"205":0,"206":0,"207":0,"208":0,"209":1,"210":0,"211":0,"212":0,"213":0,"214":0,"215":0,"216":0,"217":0,"218":0,"219":0,"220":0,"221":0,"222":0,"223":0,"224":0,"225":0,"226":0,"227":0,"228":0,"229":0,"230":0,"231":0,"232":0,"233":1,"234":1},"b":{"1":[1,0],"2":[1,1,1,1],"3":[1,0,0],"4":[1,1,0],"5":[0,1],"6":[1,0],"7":[1,0],"8":[0,0],"9":[0,0],"10":[0,0],"11":[0,0],"12":[0,0],"13":[0,0,0,0,0],"14":[0,0],"15":[0,0],"16":[0,0],"17":[0,0],"18":[0,0],"19":[0,0],"20":[0,0],"21":[0,0],"22":[0,0],"23":[0,0],"24":[0,0,0],"25":[0,0],"26":[0,0],"27":[0,0],"28":[0,0],"29":[0,0],"30":[0,0],"31":[0,0,0],"32":[0,0],"33":[0,0],"34":[0,0],"35":[0,0],"36":[0,0],"37":[0,0],"38":[0,0],"39":[0,0],"40":[0,0],"41":[0,0],"42":[0,0,0,0,0,0,0,0],"43":[0,0],"44":[0,298],"45":[298,298],"46":[322,3972],"47":[0,322],"48":[322,0],"49":[0,24,0,0,298],"50":[24,12],"51":[0,0],"52":[1,11,274,0,11,1],"53":[0,0,0],"54":[0,1],"55":[0,0],"56":[0,0],"57":[0,0],"58":[0,0],"59":[0,0],"60":[0,0],"61":[0,0],"62":[0,0],"63":[0,0],"64":[0,0],"65":[0,0],"66":[0,0],"67":[0,0],"68":[0,0],"69":[0,0],"70":[0,0],"71":[0,0],"72":[0,0,0,0,0,0],"73":[0,0],"74":[0,0],"75":[0,0],"76":[0,0]},"f":{"1":1,"2":0,"3":0,"4":0,"5":1,"6":1,"7":0,"8":0,"9":0,"10":0,"11":0,"12":0,"13":0,"14":0,"15":0,"16":0,"17":0,"18":0,"19":0,"20":0,"21":298,"22":1,"23":298,"24":0,"25":0,"26":0,"27":0,"28":0,"29":0,"30":0,"31":0,"32":0,"33":0,"34":0,"35":0,"36":0,"37":0},"fnMap":{"1":{"name":"(anonymous_1)","line":8,"loc":{"start":{"line":8,"column":2},"end":{"line":8,"column":30}}},"2":{"name":"(anonymous_2)","line":26,"loc":{"start":{"line":26,"column":32},"end":{"line":26,"column":57}}},"3":{"name":"(anonymous_3)","line":42,"loc":{"start":{"line":42,"column":21},"end":{"line":42,"column":41}}},"4":{"name":"noConflict","line":43,"loc":{"start":{"line":43,"column":8},"end":{"line":43,"column":30}}},"5":{"name":"(anonymous_5)","line":52,"loc":{"start":{"line":52,"column":9},"end":{"line":52,"column":47}}},"6":{"name":"(anonymous_6)","line":61,"loc":{"start":{"line":61,"column":35},"end":{"line":61,"column":47}}},"7":{"name":"stringify","line":62,"loc":{"start":{"line":62,"column":4},"end":{"line":62,"column":31}}},"8":{"name":"toPaddedString","line":68,"loc":{"start":{"line":68,"column":4},"end":{"line":68,"column":42}}},"9":{"name":"quote","line":85,"loc":{"start":{"line":85,"column":4},"end":{"line":85,"column":26}}},"10":{"name":"serialize","line":99,"loc":{"start":{"line":99,"column":4},"end":{"line":99,"column":37}}},"11":{"name":"(anonymous_11)","line":155,"loc":{"start":{"line":155,"column":29},"end":{"line":155,"column":51}}},"12":{"name":"all","line":172,"loc":{"start":{"line":172,"column":22},"end":{"line":172,"column":62}}},"13":{"name":"(anonymous_13)","line":174,"loc":{"start":{"line":174,"column":24},"end":{"line":174,"column":54}}},"14":{"name":"toQueryPair","line":181,"loc":{"start":{"line":181,"column":16},"end":{"line":181,"column":55}}},"15":{"name":"serializeQuery","line":200,"loc":{"start":{"line":200,"column":44},"end":{"line":200,"column":84}}},"16":{"name":"(anonymous_16)","line":202,"loc":{"start":{"line":202,"column":21},"end":{"line":202,"column":49}}},"17":{"name":"(anonymous_17)","line":204,"loc":{"start":{"line":204,"column":28},"end":{"line":204,"column":45}}},"18":{"name":"parseQuery","line":223,"loc":{"start":{"line":223,"column":36},"end":{"line":223,"column":75}}},"19":{"name":"isEmpty","line":256,"loc":{"start":{"line":256,"column":30},"end":{"line":256,"column":54}}},"20":{"name":"(anonymous_20)","line":275,"loc":{"start":{"line":275,"column":19},"end":{"line":275,"column":31}}},"21":{"name":"substitute","line":283,"loc":{"start":{"line":283,"column":36},"end":{"line":283,"column":63}}},"22":{"name":"createConsole","line":333,"loc":{"start":{"line":333,"column":42},"end":{"line":333,"column":72}}},"23":{"name":"onEvent","line":334,"loc":{"start":{"line":334,"column":4},"end":{"line":334,"column":28}}},"24":{"name":"createTAP","line":359,"loc":{"start":{"line":359,"column":34},"end":{"line":359,"column":60}}},"25":{"name":"description","line":362,"loc":{"start":{"line":362,"column":4},"end":{"line":362,"column":38}}},"26":{"name":"onEvent","line":365,"loc":{"start":{"line":365,"column":4},"end":{"line":365,"column":28}}},"27":{"name":"onClick","line":391,"loc":{"start":{"line":391,"column":14},"end":{"line":391,"column":33}}},"28":{"name":"(anonymous_28)","line":401,"loc":{"start":{"line":401,"column":37},"end":{"line":401,"column":49}}},"29":{"name":"(anonymous_29)","line":405,"loc":{"start":{"line":405,"column":43},"end":{"line":405,"column":55}}},"30":{"name":"serializeAttribute","line":427,"loc":{"start":{"line":427,"column":27},"end":{"line":427,"column":68}}},"31":{"name":"buildNode","line":433,"loc":{"start":{"line":433,"column":18},"end":{"line":433,"column":68}}},"32":{"name":"(anonymous_32)","line":458,"loc":{"start":{"line":458,"column":42},"end":{"line":458,"column":69}}},"33":{"name":"(anonymous_33)","line":464,"loc":{"start":{"line":464,"column":34},"end":{"line":464,"column":61}}},"34":{"name":"(anonymous_34)","line":470,"loc":{"start":{"line":470,"column":33},"end":{"line":470,"column":50}}},"35":{"name":"clearElement","line":480,"loc":{"start":{"line":480,"column":19},"end":{"line":480,"column":50}}},"36":{"name":"createReport","line":489,"loc":{"start":{"line":489,"column":42},"end":{"line":489,"column":73}}},"37":{"name":"onEvent","line":490,"loc":{"start":{"line":490,"column":6},"end":{"line":490,"column":30}}}},"statementMap":{"1":{"start":{"line":8,"column":1},"end":{"line":577,"column":3}},"2":{"start":{"line":10,"column":2},"end":{"line":22,"column":18}},"3":{"start":{"line":24,"column":2},"end":{"line":51,"column":3}},"4":{"start":{"line":26,"column":4},"end":{"line":28,"column":7}},"5":{"start":{"line":27,"column":6},"end":{"line":27,"column":52}},"6":{"start":{"line":29,"column":9},"end":{"line":51,"column":3}},"7":{"start":{"line":31,"column":4},"end":{"line":34,"column":26}},"8":{"start":{"line":33,"column":6},"end":{"line":33,"column":31}},"9":{"start":{"line":35,"column":4},"end":{"line":35,"column":49}},"10":{"start":{"line":38,"column":4},"end":{"line":40,"column":5}},"11":{"start":{"line":39,"column":6},"end":{"line":39,"column":43}},"12":{"start":{"line":41,"column":4},"end":{"line":50,"column":25}},"13":{"start":{"line":43,"column":8},"end":{"line":47,"column":9}},"14":{"start":{"line":44,"column":10},"end":{"line":44,"column":33}},"15":{"start":{"line":45,"column":10},"end":{"line":45,"column":35}},"16":{"start":{"line":46,"column":10},"end":{"line":46,"column":24}},"17":{"start":{"line":48,"column":8},"end":{"line":48,"column":26}},"18":{"start":{"line":56,"column":2},"end":{"line":387,"column":49}},"19":{"start":{"line":62,"column":4},"end":{"line":64,"column":5}},"20":{"start":{"line":63,"column":6},"end":{"line":63,"column":35}},"21":{"start":{"line":68,"column":4},"end":{"line":70,"column":5}},"22":{"start":{"line":69,"column":6},"end":{"line":69,"column":46}},"23":{"start":{"line":73,"column":4},"end":{"line":81,"column":6}},"24":{"start":{"line":85,"column":4},"end":{"line":96,"column":5}},"25":{"start":{"line":86,"column":6},"end":{"line":86,"column":42}},"26":{"start":{"line":87,"column":6},"end":{"line":94,"column":7}},"27":{"start":{"line":90,"column":8},"end":{"line":93,"column":95}},"28":{"start":{"line":95,"column":6},"end":{"line":95,"column":26}},"29":{"start":{"line":99,"column":4},"end":{"line":165,"column":5}},"30":{"start":{"line":100,"column":6},"end":{"line":100,"column":51}},"31":{"start":{"line":101,"column":6},"end":{"line":103,"column":7}},"32":{"start":{"line":102,"column":8},"end":{"line":102,"column":22}},"33":{"start":{"line":104,"column":6},"end":{"line":104,"column":39}},"34":{"start":{"line":105,"column":6},"end":{"line":132,"column":7}},"35":{"start":{"line":110,"column":10},"end":{"line":110,"column":54}},"36":{"start":{"line":113,"column":10},"end":{"line":113,"column":30}},"37":{"start":{"line":115,"column":10},"end":{"line":117,"column":11}},"38":{"start":{"line":116,"column":12},"end":{"line":116,"column":26}},"39":{"start":{"line":121,"column":10},"end":{"line":121,"column":40}},"40":{"start":{"line":123,"column":10},"end":{"line":129,"column":71}},"41":{"start":{"line":131,"column":10},"end":{"line":131,"column":165}},"42":{"start":{"line":134,"column":6},"end":{"line":163,"column":7}},"43":{"start":{"line":138,"column":8},"end":{"line":142,"column":9}},"44":{"start":{"line":139,"column":10},"end":{"line":141,"column":11}},"45":{"start":{"line":140,"column":12},"end":{"line":140,"column":26}},"46":{"start":{"line":144,"column":8},"end":{"line":144,"column":26}},"47":{"start":{"line":145,"column":8},"end":{"line":145,"column":20}},"48":{"start":{"line":146,"column":8},"end":{"line":160,"column":9}},"49":{"start":{"line":148,"column":10},"end":{"line":152,"column":11}},"50":{"start":{"line":149,"column":12},"end":{"line":151,"column":13}},"51":{"start":{"line":150,"column":14},"end":{"line":150,"column":63}},"52":{"start":{"line":153,"column":10},"end":{"line":153,"column":47}},"53":{"start":{"line":155,"column":10},"end":{"line":158,"column":13}},"54":{"start":{"line":157,"column":12},"end":{"line":157,"column":69}},"55":{"start":{"line":159,"column":10},"end":{"line":159,"column":47}},"56":{"start":{"line":162,"column":8},"end":{"line":162,"column":20}},"57":{"start":{"line":164,"column":6},"end":{"line":164,"column":20}},"58":{"start":{"line":167,"column":4},"end":{"line":167,"column":21}},"59":{"start":{"line":173,"column":4},"end":{"line":173,"column":22}},"60":{"start":{"line":174,"column":4},"end":{"line":176,"column":7}},"61":{"start":{"line":175,"column":6},"end":{"line":175,"column":67}},"62":{"start":{"line":177,"column":4},"end":{"line":177,"column":18}},"63":{"start":{"line":182,"column":4},"end":{"line":182,"column":46}},"64":{"start":{"line":183,"column":4},"end":{"line":185,"column":5}},"65":{"start":{"line":184,"column":6},"end":{"line":184,"column":23}},"66":{"start":{"line":186,"column":4},"end":{"line":191,"column":5}},"67":{"start":{"line":190,"column":8},"end":{"line":190,"column":59}},"68":{"start":{"line":201,"column":4},"end":{"line":201,"column":28}},"69":{"start":{"line":202,"column":4},"end":{"line":213,"column":7}},"70":{"start":{"line":203,"column":6},"end":{"line":212,"column":7}},"71":{"start":{"line":204,"column":8},"end":{"line":209,"column":11}},"72":{"start":{"line":205,"column":10},"end":{"line":205,"column":53}},"73":{"start":{"line":206,"column":10},"end":{"line":208,"column":11}},"74":{"start":{"line":207,"column":12},"end":{"line":207,"column":32}},"75":{"start":{"line":210,"column":13},"end":{"line":212,"column":7}},"76":{"start":{"line":211,"column":8},"end":{"line":211,"column":28}},"77":{"start":{"line":214,"column":4},"end":{"line":214,"column":41}},"78":{"start":{"line":224,"column":4},"end":{"line":224,"column":115}},"79":{"start":{"line":226,"column":4},"end":{"line":228,"column":5}},"80":{"start":{"line":227,"column":6},"end":{"line":227,"column":21}},"81":{"start":{"line":229,"column":4},"end":{"line":229,"column":44}},"82":{"start":{"line":230,"column":4},"end":{"line":251,"column":5}},"83":{"start":{"line":231,"column":6},"end":{"line":231,"column":19}},"84":{"start":{"line":232,"column":6},"end":{"line":232,"column":56}},"85":{"start":{"line":233,"column":6},"end":{"line":250,"column":7}},"86":{"start":{"line":234,"column":8},"end":{"line":241,"column":9}},"87":{"start":{"line":235,"column":10},"end":{"line":235,"column":68}},"88":{"start":{"line":236,"column":10},"end":{"line":238,"column":11}},"89":{"start":{"line":237,"column":12},"end":{"line":237,"column":46}},"90":{"start":{"line":240,"column":10},"end":{"line":240,"column":29}},"91":{"start":{"line":242,"column":8},"end":{"line":249,"column":9}},"92":{"start":{"line":243,"column":10},"end":{"line":245,"column":11}},"93":{"start":{"line":244,"column":12},"end":{"line":244,"column":54}},"94":{"start":{"line":246,"column":10},"end":{"line":246,"column":41}},"95":{"start":{"line":248,"column":10},"end":{"line":248,"column":37}},"96":{"start":{"line":252,"column":4},"end":{"line":252,"column":19}},"97":{"start":{"line":257,"column":4},"end":{"line":257,"column":15}},"98":{"start":{"line":258,"column":4},"end":{"line":260,"column":5}},"99":{"start":{"line":259,"column":6},"end":{"line":259,"column":18}},"100":{"start":{"line":261,"column":4},"end":{"line":278,"column":5}},"101":{"start":{"line":265,"column":8},"end":{"line":265,"column":23}},"102":{"start":{"line":266,"column":8},"end":{"line":266,"column":39}},"103":{"start":{"line":270,"column":8},"end":{"line":270,"column":21}},"104":{"start":{"line":273,"column":8},"end":{"line":273,"column":29}},"105":{"start":{"line":275,"column":8},"end":{"line":277,"column":18}},"106":{"start":{"line":276,"column":10},"end":{"line":276,"column":23}},"107":{"start":{"line":284,"column":4},"end":{"line":284,"column":59}},"108":{"start":{"line":285,"column":4},"end":{"line":285,"column":23}},"109":{"start":{"line":286,"column":4},"end":{"line":288,"column":5}},"110":{"start":{"line":287,"column":6},"end":{"line":287,"column":19}},"111":{"start":{"line":289,"column":4},"end":{"line":328,"column":5}},"112":{"start":{"line":290,"column":6},"end":{"line":290,"column":35}},"113":{"start":{"line":291,"column":6},"end":{"line":327,"column":7}},"114":{"start":{"line":292,"column":8},"end":{"line":292,"column":44}},"115":{"start":{"line":293,"column":8},"end":{"line":323,"column":9}},"116":{"start":{"line":295,"column":10},"end":{"line":295,"column":30}},"117":{"start":{"line":297,"column":10},"end":{"line":320,"column":11}},"118":{"start":{"line":299,"column":12},"end":{"line":316,"column":13}},"119":{"start":{"line":303,"column":16},"end":{"line":303,"column":63}},"120":{"start":{"line":304,"column":16},"end":{"line":304,"column":22}},"121":{"start":{"line":307,"column":16},"end":{"line":307,"column":52}},"122":{"start":{"line":308,"column":16},"end":{"line":308,"column":22}},"123":{"start":{"line":311,"column":16},"end":{"line":311,"column":57}},"124":{"start":{"line":312,"column":16},"end":{"line":312,"column":22}},"125":{"start":{"line":315,"column":16},"end":{"line":315,"column":46}},"126":{"start":{"line":319,"column":12},"end":{"line":319,"column":41}},"127":{"start":{"line":322,"column":10},"end":{"line":322,"column":24}},"128":{"start":{"line":324,"column":8},"end":{"line":324,"column":19}},"129":{"start":{"line":326,"column":8},"end":{"line":326,"column":25}},"130":{"start":{"line":329,"column":4},"end":{"line":329,"column":18}},"131":{"start":{"line":334,"column":4},"end":{"line":354,"column":5}},"132":{"start":{"line":335,"column":6},"end":{"line":353,"column":7}},"133":{"start":{"line":337,"column":10},"end":{"line":337,"column":61}},"134":{"start":{"line":338,"column":10},"end":{"line":338,"column":16}},"135":{"start":{"line":340,"column":10},"end":{"line":340,"column":69}},"136":{"start":{"line":341,"column":10},"end":{"line":341,"column":16}},"137":{"start":{"line":343,"column":10},"end":{"line":343,"column":61}},"138":{"start":{"line":344,"column":10},"end":{"line":344,"column":16}},"139":{"start":{"line":346,"column":10},"end":{"line":346,"column":115}},"140":{"start":{"line":347,"column":10},"end":{"line":347,"column":16}},"141":{"start":{"line":349,"column":10},"end":{"line":349,"column":146}},"142":{"start":{"line":350,"column":10},"end":{"line":350,"column":16}},"143":{"start":{"line":352,"column":10},"end":{"line":352,"column":122}},"144":{"start":{"line":355,"column":4},"end":{"line":355,"column":19}},"145":{"start":{"line":360,"column":4},"end":{"line":360,"column":23}},"146":{"start":{"line":362,"column":4},"end":{"line":364,"column":5}},"147":{"start":{"line":363,"column":6},"end":{"line":363,"column":43}},"148":{"start":{"line":365,"column":4},"end":{"line":382,"column":5}},"149":{"start":{"line":366,"column":6},"end":{"line":381,"column":7}},"150":{"start":{"line":368,"column":10},"end":{"line":368,"column":82}},"151":{"start":{"line":369,"column":10},"end":{"line":369,"column":16}},"152":{"start":{"line":371,"column":10},"end":{"line":371,"column":86}},"153":{"start":{"line":372,"column":10},"end":{"line":372,"column":64}},"154":{"start":{"line":373,"column":10},"end":{"line":373,"column":61}},"155":{"start":{"line":374,"column":10},"end":{"line":374,"column":16}},"156":{"start":{"line":376,"column":10},"end":{"line":376,"column":54}},"157":{"start":{"line":377,"column":10},"end":{"line":377,"column":58}},"158":{"start":{"line":378,"column":10},"end":{"line":378,"column":56}},"159":{"start":{"line":379,"column":10},"end":{"line":379,"column":74}},"160":{"start":{"line":380,"column":10},"end":{"line":380,"column":16}},"161":{"start":{"line":383,"column":4},"end":{"line":383,"column":19}},"162":{"start":{"line":389,"column":2},"end":{"line":571,"column":3}},"163":{"start":{"line":391,"column":4},"end":{"line":397,"column":6}},"164":{"start":{"line":393,"column":6},"end":{"line":393,"column":68}},"165":{"start":{"line":394,"column":6},"end":{"line":396,"column":7}},"166":{"start":{"line":395,"column":8},"end":{"line":395,"column":76}},"167":{"start":{"line":401,"column":4},"end":{"line":477,"column":9}},"168":{"start":{"line":405,"column":6},"end":{"line":475,"column":8}},"169":{"start":{"line":406,"column":8},"end":{"line":406,"column":36}},"170":{"start":{"line":407,"column":8},"end":{"line":410,"column":30}},"171":{"start":{"line":408,"column":10},"end":{"line":408,"column":68}},"172":{"start":{"line":409,"column":10},"end":{"line":409,"column":62}},"173":{"start":{"line":411,"column":8},"end":{"line":411,"column":23}},"174":{"start":{"line":412,"column":8},"end":{"line":412,"column":22}},"175":{"start":{"line":428,"column":8},"end":{"line":428,"column":35}},"176":{"start":{"line":429,"column":8},"end":{"line":429,"column":81}},"177":{"start":{"line":434,"column":8},"end":{"line":434,"column":60}},"178":{"start":{"line":435,"column":8},"end":{"line":440,"column":9}},"179":{"start":{"line":436,"column":10},"end":{"line":436,"column":32}},"180":{"start":{"line":437,"column":10},"end":{"line":437,"column":28}},"181":{"start":{"line":439,"column":10},"end":{"line":439,"column":60}},"182":{"start":{"line":442,"column":8},"end":{"line":453,"column":9}},"183":{"start":{"line":443,"column":10},"end":{"line":443,"column":34}},"184":{"start":{"line":444,"column":10},"end":{"line":447,"column":11}},"185":{"start":{"line":445,"column":12},"end":{"line":445,"column":73}},"186":{"start":{"line":446,"column":12},"end":{"line":446,"column":35}},"187":{"start":{"line":448,"column":10},"end":{"line":451,"column":11}},"188":{"start":{"line":449,"column":12},"end":{"line":449,"column":73}},"189":{"start":{"line":450,"column":12},"end":{"line":450,"column":35}},"190":{"start":{"line":452,"column":10},"end":{"line":452,"column":25}},"191":{"start":{"line":454,"column":8},"end":{"line":454,"column":50}},"192":{"start":{"line":456,"column":8},"end":{"line":467,"column":9}},"193":{"start":{"line":457,"column":10},"end":{"line":463,"column":11}},"194":{"start":{"line":458,"column":12},"end":{"line":461,"column":15}},"195":{"start":{"line":460,"column":14},"end":{"line":460,"column":100}},"196":{"start":{"line":462,"column":12},"end":{"line":462,"column":36}},"197":{"start":{"line":464,"column":10},"end":{"line":466,"column":13}},"198":{"start":{"line":465,"column":12},"end":{"line":465,"column":38}},"199":{"start":{"line":469,"column":8},"end":{"line":473,"column":9}},"200":{"start":{"line":470,"column":10},"end":{"line":472,"column":13}},"201":{"start":{"line":471,"column":12},"end":{"line":471,"column":39}},"202":{"start":{"line":474,"column":8},"end":{"line":474,"column":23}},"203":{"start":{"line":476,"column":6},"end":{"line":476,"column":23}},"204":{"start":{"line":480,"column":4},"end":{"line":485,"column":6}},"205":{"start":{"line":481,"column":6},"end":{"line":483,"column":7}},"206":{"start":{"line":482,"column":8},"end":{"line":482,"column":48}},"207":{"start":{"line":484,"column":6},"end":{"line":484,"column":21}},"208":{"start":{"line":489,"column":4},"end":{"line":570,"column":6}},"209":{"start":{"line":490,"column":6},"end":{"line":568,"column":7}},"210":{"start":{"line":491,"column":8},"end":{"line":491,"column":72}},"211":{"start":{"line":492,"column":8},"end":{"line":494,"column":9}},"212":{"start":{"line":493,"column":10},"end":{"line":493,"column":53}},"213":{"start":{"line":495,"column":8},"end":{"line":497,"column":9}},"214":{"start":{"line":496,"column":10},"end":{"line":496,"column":80}},"215":{"start":{"line":498,"column":8},"end":{"line":567,"column":9}},"216":{"start":{"line":502,"column":12},"end":{"line":502,"column":34}},"217":{"start":{"line":504,"column":12},"end":{"line":512,"column":14}},"218":{"start":{"line":513,"column":12},"end":{"line":513,"column":18}},"219":{"start":{"line":517,"column":12},"end":{"line":519,"column":16}},"220":{"start":{"line":520,"column":12},"end":{"line":520,"column":18}},"221":{"start":{"line":523,"column":12},"end":{"line":523,"column":138}},"222":{"start":{"line":524,"column":12},"end":{"line":524,"column":18}},"223":{"start":{"line":528,"column":12},"end":{"line":528,"column":117}},"224":{"start":{"line":530,"column":12},"end":{"line":530,"column":162}},"225":{"start":{"line":532,"column":12},"end":{"line":532,"column":33}},"226":{"start":{"line":533,"column":12},"end":{"line":533,"column":18}},"227":{"start":{"line":537,"column":12},"end":{"line":541,"column":13}},"228":{"start":{"line":539,"column":14},"end":{"line":539,"column":107}},"229":{"start":{"line":540,"column":14},"end":{"line":540,"column":84}},"230":{"start":{"line":543,"column":12},"end":{"line":564,"column":17}},"231":{"start":{"line":566,"column":12},"end":{"line":566,"column":42}},"232":{"start":{"line":569,"column":6},"end":{"line":569,"column":21}},"233":{"start":{"line":574,"column":2},"end":{"line":574,"column":36}},"234":{"start":{"line":576,"column":2},"end":{"line":576,"column":17}}},"branchMap":{"1":{"line":10,"type":"binary-expr","locations":[{"start":{"line":10,"column":17},"end":{"line":10,"column":44}},{"start":{"line":10,"column":48},"end":{"line":10,"column":60}}]},"2":{"line":11,"type":"binary-expr","locations":[{"start":{"line":11,"column":13},"end":{"line":11,"column":41}},{"start":{"line":11,"column":45},"end":{"line":11,"column":71}},{"start":{"line":11,"column":75},"end":{"line":11,"column":82}},{"start":{"line":11,"column":86},"end":{"line":11,"column":95}}]},"3":{"line":14,"type":"binary-expr","locations":[{"start":{"line":14,"column":14},"end":{"line":14,"column":30}},{"start":{"line":14,"column":34},"end":{"line":14,"column":53}},{"start":{"line":14,"column":57},"end":{"line":14,"column":93}}]},"4":{"line":15,"type":"binary-expr","locations":[{"start":{"line":15,"column":13},"end":{"line":15,"column":23}},{"start":{"line":15,"column":27},"end":{"line":15,"column":36}},{"start":{"line":15,"column":40},"end":{"line":15,"column":70}}]},"5":{"line":24,"type":"if","locations":[{"start":{"line":24,"column":2},"end":{"line":24,"column":2}},{"start":{"line":24,"column":2},"end":{"line":24,"column":2}}]},"6":{"line":29,"type":"if","locations":[{"start":{"line":29,"column":9},"end":{"line":29,"column":9}},{"start":{"line":29,"column":9},"end":{"line":29,"column":9}}]},"7":{"line":35,"type":"binary-expr","locations":[{"start":{"line":35,"column":37},"end":{"line":35,"column":41}},{"start":{"line":35,"column":45},"end":{"line":35,"column":47}}]},"8":{"line":38,"type":"if","locations":[{"start":{"line":38,"column":4},"end":{"line":38,"column":4}},{"start":{"line":38,"column":4},"end":{"line":38,"column":4}}]},"9":{"line":50,"type":"binary-expr","locations":[{"start":{"line":50,"column":8},"end":{"line":50,"column":17}},{"start":{"line":50,"column":21},"end":{"line":50,"column":23}}]},"10":{"line":90,"type":"cond-expr","locations":[{"start":{"line":90,"column":57},"end":{"line":90,"column":72}},{"start":{"line":93,"column":10},"end":{"line":93,"column":94}}]},"11":{"line":93,"type":"cond-expr","locations":[{"start":{"line":93,"column":25},"end":{"line":93,"column":85}},{"start":{"line":93,"column":88},"end":{"line":93,"column":94}}]},"12":{"line":101,"type":"if","locations":[{"start":{"line":101,"column":6},"end":{"line":101,"column":6}},{"start":{"line":101,"column":6},"end":{"line":101,"column":6}}]},"13":{"line":105,"type":"switch","locations":[{"start":{"line":106,"column":8},"end":{"line":106,"column":31}},{"start":{"line":107,"column":8},"end":{"line":110,"column":54}},{"start":{"line":111,"column":8},"end":{"line":113,"column":30}},{"start":{"line":114,"column":8},"end":{"line":129,"column":71}},{"start":{"line":130,"column":8},"end":{"line":131,"column":165}}]},"14":{"line":110,"type":"cond-expr","locations":[{"start":{"line":110,"column":34},"end":{"line":110,"column":40}},{"start":{"line":110,"column":43},"end":{"line":110,"column":53}}]},"15":{"line":115,"type":"if","locations":[{"start":{"line":115,"column":10},"end":{"line":115,"column":10}},{"start":{"line":115,"column":10},"end":{"line":115,"column":10}}]},"16":{"line":123,"type":"cond-expr","locations":[{"start":{"line":123,"column":51},"end":{"line":123,"column":109}},{"start":{"line":123,"column":112},"end":{"line":123,"column":135}}]},"17":{"line":123,"type":"binary-expr","locations":[{"start":{"line":123,"column":24},"end":{"line":123,"column":33}},{"start":{"line":123,"column":37},"end":{"line":123,"column":48}}]},"18":{"line":123,"type":"cond-expr","locations":[{"start":{"line":123,"column":63},"end":{"line":123,"column":66}},{"start":{"line":123,"column":69},"end":{"line":123,"column":72}}]},"19":{"line":134,"type":"if","locations":[{"start":{"line":134,"column":6},"end":{"line":134,"column":6}},{"start":{"line":134,"column":6},"end":{"line":134,"column":6}}]},"20":{"line":139,"type":"if","locations":[{"start":{"line":139,"column":10},"end":{"line":139,"column":10}},{"start":{"line":139,"column":10},"end":{"line":139,"column":10}}]},"21":{"line":146,"type":"if","locations":[{"start":{"line":146,"column":8},"end":{"line":146,"column":8}},{"start":{"line":146,"column":8},"end":{"line":146,"column":8}}]},"22":{"line":149,"type":"if","locations":[{"start":{"line":149,"column":12},"end":{"line":149,"column":12}},{"start":{"line":149,"column":12},"end":{"line":149,"column":12}}]},"23":{"line":183,"type":"if","locations":[{"start":{"line":183,"column":4},"end":{"line":183,"column":4}},{"start":{"line":183,"column":4},"end":{"line":183,"column":4}}]},"24":{"line":186,"type":"switch","locations":[{"start":{"line":187,"column":6},"end":{"line":187,"column":29}},{"start":{"line":188,"column":6},"end":{"line":188,"column":29}},{"start":{"line":189,"column":6},"end":{"line":190,"column":59}}]},"25":{"line":203,"type":"if","locations":[{"start":{"line":203,"column":6},"end":{"line":203,"column":6}},{"start":{"line":203,"column":6},"end":{"line":203,"column":6}}]},"26":{"line":203,"type":"binary-expr","locations":[{"start":{"line":203,"column":10},"end":{"line":203,"column":15}},{"start":{"line":203,"column":19},"end":{"line":203,"column":59}}]},"27":{"line":206,"type":"if","locations":[{"start":{"line":206,"column":10},"end":{"line":206,"column":10}},{"start":{"line":206,"column":10},"end":{"line":206,"column":10}}]},"28":{"line":210,"type":"if","locations":[{"start":{"line":210,"column":13},"end":{"line":210,"column":13}},{"start":{"line":210,"column":13},"end":{"line":210,"column":13}}]},"29":{"line":214,"type":"binary-expr","locations":[{"start":{"line":214,"column":23},"end":{"line":214,"column":32}},{"start":{"line":214,"column":36},"end":{"line":214,"column":39}}]},"30":{"line":226,"type":"if","locations":[{"start":{"line":226,"column":4},"end":{"line":226,"column":4}},{"start":{"line":226,"column":4},"end":{"line":226,"column":4}}]},"31":{"line":226,"type":"binary-expr","locations":[{"start":{"line":226,"column":8},"end":{"line":226,"column":24}},{"start":{"line":226,"column":28},"end":{"line":226,"column":37}},{"start":{"line":226,"column":41},"end":{"line":226,"column":133}}]},"32":{"line":226,"type":"binary-expr","locations":[{"start":{"line":226,"column":45},"end":{"line":226,"column":94}},{"start":{"line":226,"column":101},"end":{"line":226,"column":131}}]},"33":{"line":226,"type":"binary-expr","locations":[{"start":{"line":226,"column":62},"end":{"line":226,"column":70}},{"start":{"line":226,"column":74},"end":{"line":226,"column":82}}]},"34":{"line":229,"type":"binary-expr","locations":[{"start":{"line":229,"column":26},"end":{"line":229,"column":35}},{"start":{"line":229,"column":39},"end":{"line":229,"column":42}}]},"35":{"line":233,"type":"if","locations":[{"start":{"line":233,"column":6},"end":{"line":233,"column":6}},{"start":{"line":233,"column":6},"end":{"line":233,"column":6}}]},"36":{"line":233,"type":"binary-expr","locations":[{"start":{"line":233,"column":10},"end":{"line":233,"column":16}},{"start":{"line":233,"column":20},"end":{"line":233,"column":28}}]},"37":{"line":234,"type":"if","locations":[{"start":{"line":234,"column":8},"end":{"line":234,"column":8}},{"start":{"line":234,"column":8},"end":{"line":234,"column":8}}]},"38":{"line":236,"type":"if","locations":[{"start":{"line":236,"column":10},"end":{"line":236,"column":10}},{"start":{"line":236,"column":10},"end":{"line":236,"column":10}}]},"39":{"line":242,"type":"if","locations":[{"start":{"line":242,"column":8},"end":{"line":242,"column":8}},{"start":{"line":242,"column":8},"end":{"line":242,"column":8}}]},"40":{"line":243,"type":"if","locations":[{"start":{"line":243,"column":10},"end":{"line":243,"column":10}},{"start":{"line":243,"column":10},"end":{"line":243,"column":10}}]},"41":{"line":258,"type":"if","locations":[{"start":{"line":258,"column":4},"end":{"line":258,"column":4}},{"start":{"line":258,"column":4},"end":{"line":258,"column":4}}]},"42":{"line":261,"type":"switch","locations":[{"start":{"line":262,"column":6},"end":{"line":262,"column":29}},{"start":{"line":263,"column":6},"end":{"line":266,"column":39}},{"start":{"line":267,"column":6},"end":{"line":267,"column":30}},{"start":{"line":268,"column":6},"end":{"line":268,"column":31}},{"start":{"line":269,"column":6},"end":{"line":270,"column":21}},{"start":{"line":271,"column":6},"end":{"line":271,"column":29}},{"start":{"line":272,"column":6},"end":{"line":273,"column":29}},{"start":{"line":274,"column":6},"end":{"line":277,"column":18}}]},"43":{"line":266,"type":"binary-expr","locations":[{"start":{"line":266,"column":15},"end":{"line":266,"column":29}},{"start":{"line":266,"column":33},"end":{"line":266,"column":38}}]},"44":{"line":286,"type":"if","locations":[{"start":{"line":286,"column":4},"end":{"line":286,"column":4}},{"start":{"line":286,"column":4},"end":{"line":286,"column":4}}]},"45":{"line":286,"type":"binary-expr","locations":[{"start":{"line":286,"column":8},"end":{"line":286,"column":30}},{"start":{"line":286,"column":34},"end":{"line":286,"column":54}}]},"46":{"line":291,"type":"if","locations":[{"start":{"line":291,"column":6},"end":{"line":291,"column":6}},{"start":{"line":291,"column":6},"end":{"line":291,"column":6}}]},"47":{"line":293,"type":"if","locations":[{"start":{"line":293,"column":8},"end":{"line":293,"column":8}},{"start":{"line":293,"column":8},"end":{"line":293,"column":8}}]},"48":{"line":297,"type":"if","locations":[{"start":{"line":297,"column":10},"end":{"line":297,"column":10}},{"start":{"line":297,"column":10},"end":{"line":297,"column":10}}]},"49":{"line":299,"type":"switch","locations":[{"start":{"line":301,"column":14},"end":{"line":301,"column":23}},{"start":{"line":302,"column":14},"end":{"line":304,"column":22}},{"start":{"line":306,"column":14},"end":{"line":308,"column":22}},{"start":{"line":310,"column":14},"end":{"line":312,"column":22}},{"start":{"line":314,"column":14},"end":{"line":315,"column":46}}]},"50":{"line":303,"type":"binary-expr","locations":[{"start":{"line":303,"column":26},"end":{"line":303,"column":57}},{"start":{"line":303,"column":61},"end":{"line":303,"column":62}}]},"51":{"line":307,"type":"binary-expr","locations":[{"start":{"line":307,"column":26},"end":{"line":307,"column":46}},{"start":{"line":307,"column":50},"end":{"line":307,"column":51}}]},"52":{"line":335,"type":"switch","locations":[{"start":{"line":336,"column":8},"end":{"line":338,"column":16}},{"start":{"line":339,"column":8},"end":{"line":341,"column":16}},{"start":{"line":342,"column":8},"end":{"line":344,"column":16}},{"start":{"line":345,"column":8},"end":{"line":347,"column":16}},{"start":{"line":348,"column":8},"end":{"line":350,"column":16}},{"start":{"line":351,"column":8},"end":{"line":352,"column":122}}]},"53":{"line":366,"type":"switch","locations":[{"start":{"line":367,"column":8},"end":{"line":369,"column":16}},{"start":{"line":370,"column":8},"end":{"line":374,"column":16}},{"start":{"line":375,"column":8},"end":{"line":380,"column":16}}]},"54":{"line":389,"type":"if","locations":[{"start":{"line":389,"column":2},"end":{"line":389,"column":2}},{"start":{"line":389,"column":2},"end":{"line":389,"column":2}}]},"55":{"line":393,"type":"binary-expr","locations":[{"start":{"line":393,"column":19},"end":{"line":393,"column":34}},{"start":{"line":393,"column":38},"end":{"line":393,"column":67}}]},"56":{"line":394,"type":"if","locations":[{"start":{"line":394,"column":6},"end":{"line":394,"column":6}},{"start":{"line":394,"column":6},"end":{"line":394,"column":6}}]},"57":{"line":395,"type":"cond-expr","locations":[{"start":{"line":395,"column":64},"end":{"line":395,"column":66}},{"start":{"line":395,"column":69},"end":{"line":395,"column":75}}]},"58":{"line":409,"type":"binary-expr","locations":[{"start":{"line":409,"column":19},"end":{"line":409,"column":38}},{"start":{"line":409,"column":42},"end":{"line":409,"column":61}}]},"59":{"line":418,"type":"cond-expr","locations":[{"start":{"line":418,"column":71},"end":{"line":418,"column":83}},{"start":{"line":418,"column":86},"end":{"line":418,"column":96}}]},"60":{"line":435,"type":"if","locations":[{"start":{"line":435,"column":8},"end":{"line":435,"column":8}},{"start":{"line":435,"column":8},"end":{"line":435,"column":8}}]},"61":{"line":435,"type":"binary-expr","locations":[{"start":{"line":435,"column":12},"end":{"line":435,"column":22}},{"start":{"line":435,"column":26},"end":{"line":435,"column":71}}]},"62":{"line":442,"type":"if","locations":[{"start":{"line":442,"column":8},"end":{"line":442,"column":8}},{"start":{"line":442,"column":8},"end":{"line":442,"column":8}}]},"63":{"line":442,"type":"binary-expr","locations":[{"start":{"line":442,"column":12},"end":{"line":442,"column":25}},{"start":{"line":442,"column":29},"end":{"line":442,"column":58}}]},"64":{"line":444,"type":"if","locations":[{"start":{"line":444,"column":10},"end":{"line":444,"column":10}},{"start":{"line":444,"column":10},"end":{"line":444,"column":10}}]},"65":{"line":448,"type":"if","locations":[{"start":{"line":448,"column":10},"end":{"line":448,"column":10}},{"start":{"line":448,"column":10},"end":{"line":448,"column":10}}]},"66":{"line":456,"type":"if","locations":[{"start":{"line":456,"column":8},"end":{"line":456,"column":8}},{"start":{"line":456,"column":8},"end":{"line":456,"column":8}}]},"67":{"line":457,"type":"if","locations":[{"start":{"line":457,"column":10},"end":{"line":457,"column":10}},{"start":{"line":457,"column":10},"end":{"line":457,"column":10}}]},"68":{"line":460,"type":"cond-expr","locations":[{"start":{"line":460,"column":71},"end":{"line":460,"column":79}},{"start":{"line":460,"column":82},"end":{"line":460,"column":90}}]},"69":{"line":469,"type":"if","locations":[{"start":{"line":469,"column":8},"end":{"line":469,"column":8}},{"start":{"line":469,"column":8},"end":{"line":469,"column":8}}]},"70":{"line":492,"type":"if","locations":[{"start":{"line":492,"column":8},"end":{"line":492,"column":8}},{"start":{"line":492,"column":8},"end":{"line":492,"column":8}}]},"71":{"line":495,"type":"if","locations":[{"start":{"line":495,"column":8},"end":{"line":495,"column":8}},{"start":{"line":495,"column":8},"end":{"line":495,"column":8}}]},"72":{"line":498,"type":"switch","locations":[{"start":{"line":500,"column":10},"end":{"line":513,"column":18}},{"start":{"line":515,"column":10},"end":{"line":520,"column":18}},{"start":{"line":522,"column":10},"end":{"line":524,"column":18}},{"start":{"line":526,"column":10},"end":{"line":533,"column":18}},{"start":{"line":534,"column":10},"end":{"line":534,"column":27}},{"start":{"line":535,"column":10},"end":{"line":566,"column":42}}]},"73":{"line":523,"type":"cond-expr","locations":[{"start":{"line":523,"column":90},"end":{"line":523,"column":112}},{"start":{"line":523,"column":115},"end":{"line":523,"column":137}}]},"74":{"line":528,"type":"cond-expr","locations":[{"start":{"line":528,"column":63},"end":{"line":528,"column":88}},{"start":{"line":528,"column":91},"end":{"line":528,"column":116}}]},"75":{"line":537,"type":"if","locations":[{"start":{"line":537,"column":12},"end":{"line":537,"column":12}},{"start":{"line":537,"column":12},"end":{"line":537,"column":12}}]},"76":{"line":543,"type":"cond-expr","locations":[{"start":{"line":545,"column":14},"end":{"line":547,"column":16}},{"start":{"line":549,"column":14},"end":{"line":564,"column":16}}]}}},"/Users/kit/Dropbox/Projects/json3/lib/json3.js":{"path":"/Users/kit/Dropbox/Projects/json3/lib/json3.js","s":{"1":1,"2":1,"3":1,"4":1,"5":1,"6":1,"7":1,"8":1,"9":0,"10":1,"11":1,"12":1,"13":1,"14":3,"15":0,"16":3,"17":3,"18":0,"19":3,"20":1,"21":2,"22":2,"23":1,"24":1,"25":1,"26":4,"27":1,"28":1,"29":0,"30":1,"31":2,"32":1,"33":1,"34":1,"35":1,"36":1,"37":1,"38":1,"39":1,"40":1,"41":1,"42":1,"43":1,"44":1,"45":1,"46":1,"47":0,"48":1,"49":3,"50":1,"51":1,"52":1,"53":1,"54":1,"55":0,"56":0,"57":0,"58":0,"59":0,"60":0,"61":0,"62":0,"63":0,"64":0,"65":0,"66":0,"67":0,"68":0,"69":0,"70":0,"71":0,"72":0,"73":0,"74":0,"75":0,"76":0,"77":0,"78":0,"79":0,"80":0,"81":0,"82":0,"83":0,"84":0,"85":0,"86":0,"87":0,"88":0,"89":0,"90":0,"91":0,"92":0,"93":0,"94":0,"95":0,"96":0,"97":0,"98":0,"99":0,"100":0,"101":0,"102":0,"103":0,"104":0,"105":0,"106":0,"107":0,"108":0,"109":0,"110":0,"111":0,"112":0,"113":0,"114":0,"115":0,"116":0,"117":0,"118":0,"119":0,"120":0,"121":0,"122":0,"123":0,"124":0,"125":0,"126":0,"127":0,"128":0,"129":0,"130":0,"131":0,"132":0,"133":0,"134":0,"135":0,"136":0,"137":0,"138":0,"139":0,"140":0,"141":0,"142":0,"143":0,"144":0,"145":0,"146":0,"147":0,"148":0,"149":0,"150":0,"151":0,"152":0,"153":0,"154":0,"155":0,"156":0,"157":0,"158":0,"159":0,"160":0,"161":0,"162":0,"163":0,"164":0,"165":0,"166":0,"167":0,"168":0,"169":0,"170":0,"171":0,"172":0,"173":0,"174":0,"175":0,"176":0,"177":0,"178":0,"179":0,"180":0,"181":0,"182":0,"183":0,"184":0,"185":0,"186":0,"187":0,"188":0,"189":0,"190":0,"191":0,"192":0,"193":0,"194":0,"195":0,"196":0,"197":0,"198":0,"199":0,"200":0,"201":0,"202":0,"203":0,"204":0,"205":0,"206":0,"207":0,"208":0,"209":0,"210":0,"211":0,"212":0,"213":0,"214":0,"215":0,"216":0,"217":0,"218":0,"219":0,"220":0,"221":0,"222":0,"223":0,"224":0,"225":0,"226":0,"227":0,"228":0,"229":0,"230":0,"231":0,"232":0,"233":0,"234":0,"235":0,"236":0,"237":0,"238":0,"239":0,"240":0,"241":0,"242":0,"243":0,"244":0,"245":0,"246":0,"247":0,"248":0,"249":0,"250":0,"251":0,"252":0,"253":0,"254":0,"255":0,"256":0,"257":0,"258":0,"259":0,"260":0,"261":0,"262":0,"263":0,"264":0,"265":0,"266":0,"267":0,"268":0,"269":0,"270":0,"271":0,"272":0,"273":0,"274":0,"275":0,"276":0,"277":0,"278":0,"279":0,"280":0,"281":0,"282":0,"283":0,"284":0,"285":0,"286":0,"287":0,"288":0,"289":0,"290":0,"291":0,"292":0,"293":0,"294":0,"295":0,"296":0,"297":0,"298":0,"299":0,"300":0,"301":0,"302":0,"303":0,"304":0,"305":0,"306":0,"307":0,"308":0,"309":0,"310":0,"311":0,"312":0,"313":0,"314":0,"315":0,"316":0,"317":0,"318":0,"319":0,"320":0,"321":0,"322":0,"323":0,"324":0,"325":0,"326":0,"327":0,"328":0,"329":0,"330":0,"331":0,"332":0,"333":0,"334":0,"335":0,"336":0,"337":0,"338":0,"339":0,"340":0,"341":0,"342":0,"343":0,"344":0,"345":0,"346":0,"347":0,"348":0,"349":0,"350":0,"351":0,"352":0,"353":0,"354":0,"355":0,"356":0,"357":0,"358":0,"359":0,"360":0,"361":1,"362":0,"363":0},"b":{"1":[1,0],"2":[1,1],"3":[1,1,1,1],"4":[1,0],"5":[1,1],"6":[0,0],"7":[1,1,1,1,1,1,1],"8":[0,3],"9":[0,3],"10":[1,2],"11":[1,1],"12":[1,1],"13":[1,1],"14":[1,0],"15":[1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1],"16":[1,1],"17":[1,0],"18":[1,0],"19":[1,1],"20":[1,1],"21":[1,0],"22":[1,0],"23":[1,0],"24":[0,1],"25":[0,0],"26":[0,0],"27":[0,0],"28":[0,0],"29":[0,0],"30":[0,0],"31":[0,0],"32":[0,0],"33":[0,0],"34":[0,0],"35":[0,0,0],"36":[0,0],"37":[0,0],"38":[0,0],"39":[0,0],"40":[0,0],"41":[0,0],"42":[0,0,0,0],"43":[0,0],"44":[0,0],"45":[0,0,0],"46":[0,0],"47":[0,0],"48":[0,0],"49":[0,0],"50":[0,0],"51":[0,0],"52":[0,0],"53":[0,0,0,0,0,0,0,0],"54":[0,0],"55":[0,0],"56":[0,0],"57":[0,0],"58":[0,0],"59":[0,0],"60":[0,0],"61":[0,0],"62":[0,0],"63":[0,0],"64":[0,0],"65":[0,0],"66":[0,0],"67":[0,0],"68":[0,0],"69":[0,0,0,0,0],"70":[0,0],"71":[0,0],"72":[0,0],"73":[0,0],"74":[0,0],"75":[0,0],"76":[0,0],"77":[0,0],"78":[0,0],"79":[0,0],"80":[0,0],"81":[0,0],"82":[0,0],"83":[0,0],"84":[0,0],"85":[0,0],"86":[0,0],"87":[0,0],"88":[0,0],"89":[0,0],"90":[0,0],"91":[0,0,0],"92":[0,0],"93":[0,0],"94":[0,0,0],"95":[0,0],"96":[0,0],"97":[0,0],"98":[0,0],"99":[0,0],"100":[0,0],"101":[0,0,0,0,0,0,0,0,0,0,0,0],"102":[0,0],"103":[0,0],"104":[0,0],"105":[0,0,0,0,0,0,0,0,0,0],"106":[0,0],"107":[0,0,0,0,0,0],"108":[0,0],"109":[0,0,0],"110":[0,0],"111":[0,0],"112":[0,0],"113":[0,0],"114":[0,0],"115":[0,0],"116":[0,0],"117":[0,0],"118":[0,0],"119":[0,0],"120":[0,0],"121":[0,0],"122":[0,0],"123":[0,0],"124":[0,0],"125":[0,0],"126":[0,0],"127":[0,0],"128":[0,0],"129":[0,0],"130":[0,0],"131":[0,0],"132":[0,0],"133":[0,0],"134":[0,0],"135":[0,0],"136":[0,0],"137":[0,0],"138":[0,0],"139":[0,0],"140":[0,0],"141":[0,0],"142":[0,0],"143":[0,0],"144":[0,0],"145":[0,0],"146":[0,0],"147":[0,0],"148":[0,0],"149":[0,0],"150":[0,0],"151":[0,0],"152":[0,0,0,0],"153":[0,0],"154":[0,0],"155":[0,0],"156":[0,0],"157":[0,0],"158":[0,0],"159":[0,0],"160":[0,0],"161":[0,1]},"f":{"1":1,"2":3,"3":4,"4":0,"5":0,"6":0,"7":0,"8":0,"9":0,"10":0,"11":0,"12":0,"13":0,"14":0,"15":0,"16":0,"17":0,"18":0,"19":0,"20":0,"21":0,"22":0,"23":0,"24":0,"25":0,"26":0},"fnMap":{"1":{"name":"(anonymous_1)","line":2,"loc":{"start":{"line":2,"column":2},"end":{"line":2,"column":20}}},"2":{"name":"has","line":42,"loc":{"start":{"line":42,"column":2},"end":{"line":42,"column":21}}},"3":{"name":"(anonymous_3)","line":64,"loc":{"start":{"line":64,"column":19},"end":{"line":64,"column":31}}},"4":{"name":"(anonymous_4)","line":196,"loc":{"start":{"line":196,"column":19},"end":{"line":196,"column":42}}},"5":{"name":"(anonymous_5)","line":204,"loc":{"start":{"line":204,"column":19},"end":{"line":204,"column":39}}},"6":{"name":"(anonymous_6)","line":213,"loc":{"start":{"line":213,"column":23},"end":{"line":213,"column":43}}},"7":{"name":"(anonymous_7)","line":227,"loc":{"start":{"line":227,"column":23},"end":{"line":227,"column":43}}},"8":{"name":"(anonymous_8)","line":247,"loc":{"start":{"line":247,"column":21},"end":{"line":247,"column":49}}},"9":{"name":"(anonymous_9)","line":254,"loc":{"start":{"line":254,"column":14},"end":{"line":254,"column":42}}},"10":{"name":"(anonymous_10)","line":260,"loc":{"start":{"line":260,"column":20},"end":{"line":260,"column":32}}},"11":{"name":"(anonymous_11)","line":280,"loc":{"start":{"line":280,"column":18},"end":{"line":280,"column":46}}},"12":{"name":"(anonymous_12)","line":295,"loc":{"start":{"line":295,"column":18},"end":{"line":295,"column":46}}},"13":{"name":"(anonymous_13)","line":309,"loc":{"start":{"line":309,"column":18},"end":{"line":309,"column":46}}},"14":{"name":"(anonymous_14)","line":347,"loc":{"start":{"line":347,"column":27},"end":{"line":347,"column":51}}},"15":{"name":"(anonymous_15)","line":358,"loc":{"start":{"line":358,"column":18},"end":{"line":358,"column":35}}},"16":{"name":"(anonymous_16)","line":384,"loc":{"start":{"line":384,"column":22},"end":{"line":384,"column":104}}},"17":{"name":"(anonymous_17)","line":491,"loc":{"start":{"line":491,"column":41},"end":{"line":491,"column":61}}},"18":{"name":"(anonymous_18)","line":513,"loc":{"start":{"line":513,"column":24},"end":{"line":513,"column":57}}},"19":{"name":"(anonymous_19)","line":563,"loc":{"start":{"line":563,"column":18},"end":{"line":563,"column":29}}},"20":{"name":"(anonymous_20)","line":571,"loc":{"start":{"line":571,"column":16},"end":{"line":571,"column":28}}},"21":{"name":"(anonymous_21)","line":729,"loc":{"start":{"line":729,"column":16},"end":{"line":729,"column":33}}},"22":{"name":"(anonymous_22)","line":812,"loc":{"start":{"line":812,"column":19},"end":{"line":812,"column":56}}},"23":{"name":"(anonymous_23)","line":824,"loc":{"start":{"line":824,"column":17},"end":{"line":824,"column":55}}},"24":{"name":"(anonymous_24)","line":835,"loc":{"start":{"line":835,"column":27},"end":{"line":835,"column":47}}},"25":{"name":"(anonymous_25)","line":844,"loc":{"start":{"line":844,"column":20},"end":{"line":844,"column":48}}},"26":{"name":"(anonymous_26)","line":862,"loc":{"start":{"line":862,"column":11},"end":{"line":862,"column":23}}}},"statementMap":{"1":{"start":{"line":2,"column":1},"end":{"line":866,"column":9}},"2":{"start":{"line":4,"column":2},"end":{"line":4,"column":57}},"3":{"start":{"line":8,"column":2},"end":{"line":8,"column":60}},"4":{"start":{"line":11,"column":2},"end":{"line":11,"column":51}},"5":{"start":{"line":15,"column":2},"end":{"line":15,"column":84}},"6":{"start":{"line":17,"column":2},"end":{"line":26,"column":3}},"7":{"start":{"line":20,"column":4},"end":{"line":20,"column":43}},"8":{"start":{"line":21,"column":4},"end":{"line":21,"column":35}},"9":{"start":{"line":25,"column":4},"end":{"line":25,"column":43}},"10":{"start":{"line":29,"column":2},"end":{"line":29,"column":47}},"11":{"start":{"line":30,"column":2},"end":{"line":38,"column":24}},"12":{"start":{"line":33,"column":4},"end":{"line":37,"column":150}},"13":{"start":{"line":42,"column":2},"end":{"line":170,"column":3}},"14":{"start":{"line":43,"column":4},"end":{"line":46,"column":5}},"15":{"start":{"line":45,"column":6},"end":{"line":45,"column":23}},"16":{"start":{"line":48,"column":4},"end":{"line":48,"column":20}},"17":{"start":{"line":49,"column":4},"end":{"line":168,"column":5}},"18":{"start":{"line":52,"column":6},"end":{"line":52,"column":34}},"19":{"start":{"line":53,"column":11},"end":{"line":168,"column":5}},"20":{"start":{"line":56,"column":6},"end":{"line":56,"column":63}},"21":{"start":{"line":58,"column":6},"end":{"line":58,"column":83}},"22":{"start":{"line":60,"column":6},"end":{"line":126,"column":7}},"23":{"start":{"line":61,"column":8},"end":{"line":61,"column":107}},"24":{"start":{"line":62,"column":8},"end":{"line":124,"column":9}},"25":{"start":{"line":64,"column":10},"end":{"line":66,"column":28}},"26":{"start":{"line":65,"column":12},"end":{"line":65,"column":21}},"27":{"start":{"line":67,"column":10},"end":{"line":123,"column":11}},"28":{"start":{"line":68,"column":12},"end":{"line":120,"column":70}},"29":{"start":{"line":122,"column":12},"end":{"line":122,"column":39}},"30":{"start":{"line":125,"column":8},"end":{"line":125,"column":41}},"31":{"start":{"line":128,"column":6},"end":{"line":167,"column":7}},"32":{"start":{"line":129,"column":8},"end":{"line":129,"column":32}},"33":{"start":{"line":130,"column":8},"end":{"line":165,"column":9}},"34":{"start":{"line":131,"column":10},"end":{"line":164,"column":11}},"35":{"start":{"line":135,"column":12},"end":{"line":161,"column":13}},"36":{"start":{"line":137,"column":14},"end":{"line":137,"column":40}},"37":{"start":{"line":138,"column":14},"end":{"line":138,"column":81}},"38":{"start":{"line":139,"column":14},"end":{"line":160,"column":15}},"39":{"start":{"line":140,"column":16},"end":{"line":143,"column":38}},"40":{"start":{"line":142,"column":18},"end":{"line":142,"column":50}},"41":{"start":{"line":144,"column":16},"end":{"line":151,"column":17}},"42":{"start":{"line":145,"column":18},"end":{"line":150,"column":40}},"43":{"start":{"line":149,"column":20},"end":{"line":149,"column":55}},"44":{"start":{"line":152,"column":16},"end":{"line":159,"column":17}},"45":{"start":{"line":153,"column":18},"end":{"line":158,"column":40}},"46":{"start":{"line":157,"column":20},"end":{"line":157,"column":55}},"47":{"start":{"line":163,"column":12},"end":{"line":163,"column":35}},"48":{"start":{"line":166,"column":8},"end":{"line":166,"column":37}},"49":{"start":{"line":169,"column":4},"end":{"line":169,"column":37}},"50":{"start":{"line":171,"column":2},"end":{"line":171,"column":38}},"51":{"start":{"line":172,"column":2},"end":{"line":172,"column":21}},"52":{"start":{"line":173,"column":2},"end":{"line":173,"column":31}},"53":{"start":{"line":174,"column":2},"end":{"line":174,"column":27}},"54":{"start":{"line":176,"column":2},"end":{"line":858,"column":3}},"55":{"start":{"line":178,"column":4},"end":{"line":178,"column":44}},"56":{"start":{"line":179,"column":4},"end":{"line":179,"column":36}},"57":{"start":{"line":180,"column":4},"end":{"line":180,"column":40}},"58":{"start":{"line":181,"column":4},"end":{"line":181,"column":40}},"59":{"start":{"line":182,"column":4},"end":{"line":182,"column":38}},"60":{"start":{"line":183,"column":4},"end":{"line":183,"column":42}},"61":{"start":{"line":186,"column":4},"end":{"line":186,"column":54}},"62":{"start":{"line":189,"column":4},"end":{"line":199,"column":5}},"63":{"start":{"line":190,"column":6},"end":{"line":190,"column":29}},"64":{"start":{"line":193,"column":6},"end":{"line":193,"column":75}},"65":{"start":{"line":196,"column":6},"end":{"line":198,"column":8}},"66":{"start":{"line":197,"column":8},"end":{"line":197,"column":177}},"67":{"start":{"line":203,"column":4},"end":{"line":235,"column":5}},"68":{"start":{"line":204,"column":6},"end":{"line":234,"column":8}},"69":{"start":{"line":205,"column":8},"end":{"line":205,"column":38}},"70":{"start":{"line":206,"column":8},"end":{"line":231,"column":9}},"71":{"start":{"line":213,"column":10},"end":{"line":221,"column":12}},"72":{"start":{"line":217,"column":12},"end":{"line":217,"column":94}},"73":{"start":{"line":219,"column":12},"end":{"line":219,"column":38}},"74":{"start":{"line":220,"column":12},"end":{"line":220,"column":26}},"75":{"start":{"line":224,"column":10},"end":{"line":224,"column":44}},"76":{"start":{"line":227,"column":10},"end":{"line":230,"column":12}},"77":{"start":{"line":228,"column":12},"end":{"line":228,"column":69}},"78":{"start":{"line":229,"column":12},"end":{"line":229,"column":100}},"79":{"start":{"line":232,"column":8},"end":{"line":232,"column":23}},"80":{"start":{"line":233,"column":8},"end":{"line":233,"column":47}},"81":{"start":{"line":238,"column":4},"end":{"line":243,"column":6}},"82":{"start":{"line":247,"column":4},"end":{"line":250,"column":6}},"83":{"start":{"line":248,"column":6},"end":{"line":248,"column":41}},"84":{"start":{"line":249,"column":6},"end":{"line":249,"column":75}},"85":{"start":{"line":254,"column":4},"end":{"line":324,"column":6}},"86":{"start":{"line":255,"column":6},"end":{"line":255,"column":50}},"87":{"start":{"line":260,"column":6},"end":{"line":262,"column":31}},"88":{"start":{"line":261,"column":8},"end":{"line":261,"column":25}},"89":{"start":{"line":265,"column":6},"end":{"line":265,"column":33}},"90":{"start":{"line":266,"column":6},"end":{"line":271,"column":7}},"91":{"start":{"line":268,"column":8},"end":{"line":270,"column":9}},"92":{"start":{"line":269,"column":10},"end":{"line":269,"column":17}},"93":{"start":{"line":272,"column":6},"end":{"line":272,"column":34}},"94":{"start":{"line":275,"column":6},"end":{"line":322,"column":7}},"95":{"start":{"line":277,"column":8},"end":{"line":277,"column":134}},"96":{"start":{"line":280,"column":8},"end":{"line":292,"column":10}},"97":{"start":{"line":281,"column":10},"end":{"line":281,"column":84}},"98":{"start":{"line":282,"column":10},"end":{"line":282,"column":160}},"99":{"start":{"line":283,"column":10},"end":{"line":289,"column":11}},"100":{"start":{"line":286,"column":12},"end":{"line":288,"column":13}},"101":{"start":{"line":287,"column":14},"end":{"line":287,"column":33}},"102":{"start":{"line":291,"column":10},"end":{"line":291,"column":128}},"103":{"start":{"line":293,"column":13},"end":{"line":322,"column":7}},"104":{"start":{"line":295,"column":8},"end":{"line":306,"column":10}},"105":{"start":{"line":297,"column":10},"end":{"line":297,"column":90}},"106":{"start":{"line":298,"column":10},"end":{"line":305,"column":11}},"107":{"start":{"line":302,"column":12},"end":{"line":304,"column":13}},"108":{"start":{"line":303,"column":14},"end":{"line":303,"column":33}},"109":{"start":{"line":309,"column":8},"end":{"line":321,"column":10}},"110":{"start":{"line":310,"column":10},"end":{"line":310,"column":91}},"111":{"start":{"line":311,"column":10},"end":{"line":315,"column":11}},"112":{"start":{"line":312,"column":12},"end":{"line":314,"column":13}},"113":{"start":{"line":313,"column":14},"end":{"line":313,"column":33}},"114":{"start":{"line":318,"column":10},"end":{"line":320,"column":11}},"115":{"start":{"line":319,"column":12},"end":{"line":319,"column":31}},"116":{"start":{"line":323,"column":6},"end":{"line":323,"column":39}},"117":{"start":{"line":332,"column":4},"end":{"line":540,"column":5}},"118":{"start":{"line":334,"column":6},"end":{"line":342,"column":8}},"119":{"start":{"line":346,"column":6},"end":{"line":346,"column":35}},"120":{"start":{"line":347,"column":6},"end":{"line":351,"column":8}},"121":{"start":{"line":350,"column":8},"end":{"line":350,"column":60}},"122":{"start":{"line":357,"column":6},"end":{"line":357,"column":34}},"123":{"start":{"line":358,"column":6},"end":{"line":380,"column":8}},"124":{"start":{"line":359,"column":8},"end":{"line":359,"column":109}},"125":{"start":{"line":360,"column":8},"end":{"line":362,"column":9}},"126":{"start":{"line":361,"column":10},"end":{"line":361,"column":36}},"127":{"start":{"line":363,"column":8},"end":{"line":378,"column":9}},"128":{"start":{"line":364,"column":10},"end":{"line":364,"column":49}},"129":{"start":{"line":367,"column":10},"end":{"line":377,"column":11}},"130":{"start":{"line":369,"column":14},"end":{"line":369,"column":42}},"131":{"start":{"line":370,"column":14},"end":{"line":370,"column":20}},"132":{"start":{"line":372,"column":14},"end":{"line":375,"column":15}},"133":{"start":{"line":373,"column":16},"end":{"line":373,"column":83}},"134":{"start":{"line":374,"column":16},"end":{"line":374,"column":22}},"135":{"start":{"line":376,"column":14},"end":{"line":376,"column":103}},"136":{"start":{"line":379,"column":8},"end":{"line":379,"column":28}},"137":{"start":{"line":384,"column":6},"end":{"line":510,"column":8}},"138":{"start":{"line":385,"column":8},"end":{"line":385,"column":154}},"139":{"start":{"line":386,"column":8},"end":{"line":389,"column":30}},"140":{"start":{"line":388,"column":10},"end":{"line":388,"column":35}},"141":{"start":{"line":390,"column":8},"end":{"line":443,"column":9}},"142":{"start":{"line":391,"column":10},"end":{"line":391,"column":43}},"143":{"start":{"line":392,"column":10},"end":{"line":442,"column":11}},"144":{"start":{"line":393,"column":12},"end":{"line":435,"column":13}},"145":{"start":{"line":397,"column":14},"end":{"line":424,"column":15}},"146":{"start":{"line":401,"column":16},"end":{"line":401,"column":44}},"147":{"start":{"line":402,"column":16},"end":{"line":402,"column":100}},"148":{"start":{"line":403,"column":16},"end":{"line":403,"column":112}},"149":{"start":{"line":404,"column":16},"end":{"line":404,"column":54}},"150":{"start":{"line":409,"column":16},"end":{"line":409,"column":55}},"151":{"start":{"line":412,"column":16},"end":{"line":412,"column":48}},"152":{"start":{"line":413,"column":16},"end":{"line":413,"column":49}},"153":{"start":{"line":414,"column":16},"end":{"line":414,"column":49}},"154":{"start":{"line":415,"column":16},"end":{"line":415,"column":42}},"155":{"start":{"line":417,"column":16},"end":{"line":417,"column":46}},"156":{"start":{"line":418,"column":16},"end":{"line":418,"column":44}},"157":{"start":{"line":419,"column":16},"end":{"line":419,"column":42}},"158":{"start":{"line":420,"column":16},"end":{"line":420,"column":44}},"159":{"start":{"line":421,"column":16},"end":{"line":421,"column":48}},"160":{"start":{"line":422,"column":16},"end":{"line":422,"column":48}},"161":{"start":{"line":423,"column":16},"end":{"line":423,"column":58}},"162":{"start":{"line":426,"column":14},"end":{"line":432,"column":60}},"163":{"start":{"line":434,"column":14},"end":{"line":434,"column":27}},"164":{"start":{"line":436,"column":17},"end":{"line":442,"column":11}},"165":{"start":{"line":441,"column":12},"end":{"line":441,"column":43}},"166":{"start":{"line":444,"column":8},"end":{"line":448,"column":9}},"167":{"start":{"line":447,"column":10},"end":{"line":447,"column":57}},"168":{"start":{"line":449,"column":8},"end":{"line":451,"column":9}},"169":{"start":{"line":450,"column":10},"end":{"line":450,"column":24}},"170":{"start":{"line":452,"column":8},"end":{"line":452,"column":41}},"171":{"start":{"line":453,"column":8},"end":{"line":463,"column":9}},"172":{"start":{"line":455,"column":10},"end":{"line":455,"column":28}},"173":{"start":{"line":456,"column":15},"end":{"line":463,"column":9}},"174":{"start":{"line":459,"column":10},"end":{"line":459,"column":71}},"175":{"start":{"line":460,"column":15},"end":{"line":463,"column":9}},"176":{"start":{"line":462,"column":10},"end":{"line":462,"column":35}},"177":{"start":{"line":465,"column":8},"end":{"line":509,"column":9}},"178":{"start":{"line":468,"column":10},"end":{"line":473,"column":11}},"179":{"start":{"line":469,"column":12},"end":{"line":472,"column":13}},"180":{"start":{"line":471,"column":14},"end":{"line":471,"column":32}},"181":{"start":{"line":475,"column":10},"end":{"line":475,"column":28}},"182":{"start":{"line":476,"column":10},"end":{"line":476,"column":23}},"183":{"start":{"line":478,"column":10},"end":{"line":478,"column":31}},"184":{"start":{"line":479,"column":10},"end":{"line":479,"column":36}},"185":{"start":{"line":480,"column":10},"end":{"line":505,"column":11}},"186":{"start":{"line":482,"column":12},"end":{"line":485,"column":13}},"187":{"start":{"line":483,"column":14},"end":{"line":483,"column":102}},"188":{"start":{"line":484,"column":14},"end":{"line":484,"column":65}},"189":{"start":{"line":486,"column":12},"end":{"line":486,"column":168}},"190":{"start":{"line":491,"column":12},"end":{"line":503,"column":15}},"191":{"start":{"line":492,"column":14},"end":{"line":492,"column":109}},"192":{"start":{"line":493,"column":14},"end":{"line":501,"column":15}},"193":{"start":{"line":500,"column":16},"end":{"line":500,"column":88}},"194":{"start":{"line":502,"column":14},"end":{"line":502,"column":48}},"195":{"start":{"line":504,"column":12},"end":{"line":504,"column":168}},"196":{"start":{"line":507,"column":10},"end":{"line":507,"column":22}},"197":{"start":{"line":508,"column":10},"end":{"line":508,"column":24}},"198":{"start":{"line":513,"column":6},"end":{"line":539,"column":8}},"199":{"start":{"line":514,"column":8},"end":{"line":514,"column":56}},"200":{"start":{"line":515,"column":8},"end":{"line":523,"column":9}},"201":{"start":{"line":516,"column":10},"end":{"line":522,"column":11}},"202":{"start":{"line":517,"column":12},"end":{"line":517,"column":30}},"203":{"start":{"line":518,"column":17},"end":{"line":522,"column":11}},"204":{"start":{"line":520,"column":12},"end":{"line":520,"column":28}},"205":{"start":{"line":521,"column":12},"end":{"line":521,"column":211}},"206":{"start":{"line":524,"column":8},"end":{"line":534,"column":9}},"207":{"start":{"line":525,"column":10},"end":{"line":533,"column":11}},"208":{"start":{"line":528,"column":12},"end":{"line":530,"column":13}},"209":{"start":{"line":529,"column":14},"end":{"line":529,"column":110}},"210":{"start":{"line":531,"column":17},"end":{"line":533,"column":11}},"211":{"start":{"line":532,"column":12},"end":{"line":532,"column":73}},"212":{"start":{"line":538,"column":8},"end":{"line":538,"column":112}},"213":{"start":{"line":543,"column":4},"end":{"line":857,"column":5}},"214":{"start":{"line":544,"column":6},"end":{"line":544,"column":45}},"215":{"start":{"line":548,"column":6},"end":{"line":557,"column":8}},"216":{"start":{"line":560,"column":6},"end":{"line":560,"column":24}},"217":{"start":{"line":563,"column":6},"end":{"line":566,"column":8}},"218":{"start":{"line":564,"column":8},"end":{"line":564,"column":30}},"219":{"start":{"line":565,"column":8},"end":{"line":565,"column":28}},"220":{"start":{"line":571,"column":6},"end":{"line":726,"column":8}},"221":{"start":{"line":572,"column":8},"end":{"line":572,"column":96}},"222":{"start":{"line":573,"column":8},"end":{"line":722,"column":9}},"223":{"start":{"line":574,"column":10},"end":{"line":574,"column":46}},"224":{"start":{"line":575,"column":10},"end":{"line":721,"column":11}},"225":{"start":{"line":579,"column":14},"end":{"line":579,"column":22}},"226":{"start":{"line":580,"column":14},"end":{"line":580,"column":20}},"227":{"start":{"line":584,"column":14},"end":{"line":584,"column":76}},"228":{"start":{"line":585,"column":14},"end":{"line":585,"column":22}},"229":{"start":{"line":586,"column":14},"end":{"line":586,"column":27}},"230":{"start":{"line":592,"column":14},"end":{"line":645,"column":15}},"231":{"start":{"line":593,"column":16},"end":{"line":593,"column":52}},"232":{"start":{"line":594,"column":16},"end":{"line":644,"column":17}},"233":{"start":{"line":597,"column":18},"end":{"line":597,"column":26}},"234":{"start":{"line":598,"column":23},"end":{"line":644,"column":17}},"235":{"start":{"line":602,"column":18},"end":{"line":602,"column":56}},"236":{"start":{"line":603,"column":18},"end":{"line":629,"column":19}},"237":{"start":{"line":606,"column":22},"end":{"line":606,"column":51}},"238":{"start":{"line":607,"column":22},"end":{"line":607,"column":30}},"239":{"start":{"line":608,"column":22},"end":{"line":608,"column":28}},"240":{"start":{"line":613,"column":22},"end":{"line":613,"column":38}},"241":{"start":{"line":614,"column":22},"end":{"line":622,"column":23}},"242":{"start":{"line":615,"column":24},"end":{"line":615,"column":60}},"243":{"start":{"line":618,"column":24},"end":{"line":621,"column":25}},"244":{"start":{"line":620,"column":26},"end":{"line":620,"column":34}},"245":{"start":{"line":624,"column":22},"end":{"line":624,"column":79}},"246":{"start":{"line":625,"column":22},"end":{"line":625,"column":28}},"247":{"start":{"line":628,"column":22},"end":{"line":628,"column":30}},"248":{"start":{"line":631,"column":18},"end":{"line":635,"column":19}},"249":{"start":{"line":634,"column":20},"end":{"line":634,"column":26}},"250":{"start":{"line":636,"column":18},"end":{"line":636,"column":54}},"251":{"start":{"line":637,"column":18},"end":{"line":637,"column":32}},"252":{"start":{"line":639,"column":18},"end":{"line":641,"column":19}},"253":{"start":{"line":640,"column":20},"end":{"line":640,"column":58}},"254":{"start":{"line":643,"column":18},"end":{"line":643,"column":54}},"255":{"start":{"line":646,"column":14},"end":{"line":650,"column":15}},"256":{"start":{"line":648,"column":16},"end":{"line":648,"column":24}},"257":{"start":{"line":649,"column":16},"end":{"line":649,"column":29}},"258":{"start":{"line":652,"column":14},"end":{"line":652,"column":22}},"259":{"start":{"line":655,"column":14},"end":{"line":655,"column":28}},"260":{"start":{"line":657,"column":14},"end":{"line":660,"column":15}},"261":{"start":{"line":658,"column":16},"end":{"line":658,"column":32}},"262":{"start":{"line":659,"column":16},"end":{"line":659,"column":54}},"263":{"start":{"line":662,"column":14},"end":{"line":703,"column":15}},"264":{"start":{"line":664,"column":16},"end":{"line":667,"column":17}},"265":{"start":{"line":666,"column":18},"end":{"line":666,"column":26}},"266":{"start":{"line":668,"column":16},"end":{"line":668,"column":33}},"267":{"start":{"line":670,"column":16},"end":{"line":670,"column":125}},"268":{"start":{"line":673,"column":16},"end":{"line":682,"column":17}},"269":{"start":{"line":674,"column":18},"end":{"line":674,"column":37}},"270":{"start":{"line":676,"column":18},"end":{"line":676,"column":136}},"271":{"start":{"line":677,"column":18},"end":{"line":680,"column":19}},"272":{"start":{"line":679,"column":20},"end":{"line":679,"column":28}},"273":{"start":{"line":681,"column":18},"end":{"line":681,"column":35}},"274":{"start":{"line":685,"column":16},"end":{"line":685,"column":52}},"275":{"start":{"line":686,"column":16},"end":{"line":700,"column":17}},"276":{"start":{"line":687,"column":18},"end":{"line":687,"column":56}},"277":{"start":{"line":690,"column":18},"end":{"line":692,"column":19}},"278":{"start":{"line":691,"column":20},"end":{"line":691,"column":28}},"279":{"start":{"line":694,"column":18},"end":{"line":694,"column":152}},"280":{"start":{"line":695,"column":18},"end":{"line":698,"column":19}},"281":{"start":{"line":697,"column":20},"end":{"line":697,"column":28}},"282":{"start":{"line":699,"column":18},"end":{"line":699,"column":35}},"283":{"start":{"line":702,"column":16},"end":{"line":702,"column":51}},"284":{"start":{"line":705,"column":14},"end":{"line":707,"column":15}},"285":{"start":{"line":706,"column":16},"end":{"line":706,"column":24}},"286":{"start":{"line":709,"column":14},"end":{"line":718,"column":15}},"287":{"start":{"line":710,"column":16},"end":{"line":710,"column":27}},"288":{"start":{"line":711,"column":16},"end":{"line":711,"column":28}},"289":{"start":{"line":712,"column":21},"end":{"line":718,"column":15}},"290":{"start":{"line":713,"column":16},"end":{"line":713,"column":27}},"291":{"start":{"line":714,"column":16},"end":{"line":714,"column":29}},"292":{"start":{"line":715,"column":21},"end":{"line":718,"column":15}},"293":{"start":{"line":716,"column":16},"end":{"line":716,"column":27}},"294":{"start":{"line":717,"column":16},"end":{"line":717,"column":28}},"295":{"start":{"line":720,"column":14},"end":{"line":720,"column":22}},"296":{"start":{"line":725,"column":8},"end":{"line":725,"column":19}},"297":{"start":{"line":729,"column":6},"end":{"line":809,"column":8}},"298":{"start":{"line":730,"column":8},"end":{"line":730,"column":32}},"299":{"start":{"line":731,"column":8},"end":{"line":734,"column":9}},"300":{"start":{"line":733,"column":10},"end":{"line":733,"column":18}},"301":{"start":{"line":735,"column":8},"end":{"line":807,"column":9}},"302":{"start":{"line":736,"column":10},"end":{"line":739,"column":11}},"303":{"start":{"line":738,"column":12},"end":{"line":738,"column":34}},"304":{"start":{"line":741,"column":10},"end":{"line":804,"column":11}},"305":{"start":{"line":743,"column":12},"end":{"line":743,"column":25}},"306":{"start":{"line":744,"column":12},"end":{"line":770,"column":13}},"307":{"start":{"line":745,"column":14},"end":{"line":745,"column":28}},"308":{"start":{"line":747,"column":14},"end":{"line":749,"column":15}},"309":{"start":{"line":748,"column":16},"end":{"line":748,"column":22}},"310":{"start":{"line":753,"column":14},"end":{"line":764,"column":15}},"311":{"start":{"line":754,"column":16},"end":{"line":763,"column":17}},"312":{"start":{"line":755,"column":18},"end":{"line":755,"column":32}},"313":{"start":{"line":756,"column":18},"end":{"line":759,"column":19}},"314":{"start":{"line":758,"column":20},"end":{"line":758,"column":28}},"315":{"start":{"line":762,"column":18},"end":{"line":762,"column":26}},"316":{"start":{"line":766,"column":14},"end":{"line":768,"column":15}},"317":{"start":{"line":767,"column":16},"end":{"line":767,"column":24}},"318":{"start":{"line":769,"column":14},"end":{"line":769,"column":39}},"319":{"start":{"line":771,"column":12},"end":{"line":771,"column":27}},"320":{"start":{"line":772,"column":17},"end":{"line":804,"column":11}},"321":{"start":{"line":774,"column":12},"end":{"line":774,"column":25}},"322":{"start":{"line":775,"column":12},"end":{"line":802,"column":13}},"323":{"start":{"line":776,"column":14},"end":{"line":776,"column":28}},"324":{"start":{"line":778,"column":14},"end":{"line":780,"column":15}},"325":{"start":{"line":779,"column":16},"end":{"line":779,"column":22}},"326":{"start":{"line":783,"column":14},"end":{"line":794,"column":15}},"327":{"start":{"line":784,"column":16},"end":{"line":793,"column":17}},"328":{"start":{"line":785,"column":18},"end":{"line":785,"column":32}},"329":{"start":{"line":786,"column":18},"end":{"line":789,"column":19}},"330":{"start":{"line":788,"column":20},"end":{"line":788,"column":28}},"331":{"start":{"line":792,"column":18},"end":{"line":792,"column":26}},"332":{"start":{"line":798,"column":14},"end":{"line":800,"column":15}},"333":{"start":{"line":799,"column":16},"end":{"line":799,"column":24}},"334":{"start":{"line":801,"column":14},"end":{"line":801,"column":51}},"335":{"start":{"line":803,"column":12},"end":{"line":803,"column":27}},"336":{"start":{"line":806,"column":10},"end":{"line":806,"column":18}},"337":{"start":{"line":808,"column":8},"end":{"line":808,"column":21}},"338":{"start":{"line":812,"column":6},"end":{"line":819,"column":8}},"339":{"start":{"line":813,"column":8},"end":{"line":813,"column":55}},"340":{"start":{"line":814,"column":8},"end":{"line":818,"column":9}},"341":{"start":{"line":815,"column":10},"end":{"line":815,"column":34}},"342":{"start":{"line":817,"column":10},"end":{"line":817,"column":37}},"343":{"start":{"line":824,"column":6},"end":{"line":841,"column":8}},"344":{"start":{"line":825,"column":8},"end":{"line":825,"column":45}},"345":{"start":{"line":826,"column":8},"end":{"line":839,"column":9}},"346":{"start":{"line":830,"column":10},"end":{"line":838,"column":11}},"347":{"start":{"line":831,"column":12},"end":{"line":833,"column":13}},"348":{"start":{"line":832,"column":14},"end":{"line":832,"column":46}},"349":{"start":{"line":835,"column":12},"end":{"line":837,"column":15}},"350":{"start":{"line":836,"column":14},"end":{"line":836,"column":48}},"351":{"start":{"line":840,"column":8},"end":{"line":840,"column":54}},"352":{"start":{"line":844,"column":6},"end":{"line":856,"column":8}},"353":{"start":{"line":845,"column":8},"end":{"line":845,"column":26}},"354":{"start":{"line":846,"column":8},"end":{"line":846,"column":18}},"355":{"start":{"line":847,"column":8},"end":{"line":847,"column":29}},"356":{"start":{"line":848,"column":8},"end":{"line":848,"column":28}},"357":{"start":{"line":850,"column":8},"end":{"line":852,"column":9}},"358":{"start":{"line":851,"column":10},"end":{"line":851,"column":18}},"359":{"start":{"line":854,"column":8},"end":{"line":854,"column":30}},"360":{"start":{"line":855,"column":8},"end":{"line":855,"column":139}},"361":{"start":{"line":861,"column":2},"end":{"line":865,"column":3}},"362":{"start":{"line":862,"column":4},"end":{"line":864,"column":7}},"363":{"start":{"line":863,"column":6},"end":{"line":863,"column":19}}},"branchMap":{"1":{"line":8,"type":"binary-expr","locations":[{"start":{"line":8,"column":17},"end":{"line":8,"column":45}},{"start":{"line":8,"column":49},"end":{"line":8,"column":59}}]},"2":{"line":11,"type":"binary-expr","locations":[{"start":{"line":11,"column":19},"end":{"line":11,"column":42}},{"start":{"line":11,"column":46},"end":{"line":11,"column":50}}]},"3":{"line":15,"type":"binary-expr","locations":[{"start":{"line":15,"column":14},"end":{"line":15,"column":40}},{"start":{"line":15,"column":44},"end":{"line":15,"column":51}},{"start":{"line":15,"column":55},"end":{"line":15,"column":72}},{"start":{"line":15,"column":76},"end":{"line":15,"column":83}}]},"4":{"line":17,"type":"if","locations":[{"start":{"line":17,"column":2},"end":{"line":17,"column":2}},{"start":{"line":17,"column":2},"end":{"line":17,"column":2}}]},"5":{"line":17,"type":"binary-expr","locations":[{"start":{"line":17,"column":6},"end":{"line":17,"column":11}},{"start":{"line":17,"column":15},"end":{"line":17,"column":25}}]},"6":{"line":25,"type":"binary-expr","locations":[{"start":{"line":25,"column":26},"end":{"line":25,"column":36}},{"start":{"line":25,"column":40},"end":{"line":25,"column":42}}]},"7":{"line":33,"type":"binary-expr","locations":[{"start":{"line":33,"column":17},"end":{"line":33,"column":55}},{"start":{"line":33,"column":59},"end":{"line":33,"column":89}},{"start":{"line":33,"column":93},"end":{"line":33,"column":122}},{"start":{"line":37,"column":6},"end":{"line":37,"column":36}},{"start":{"line":37,"column":40},"end":{"line":37,"column":72}},{"start":{"line":37,"column":76},"end":{"line":37,"column":107}},{"start":{"line":37,"column":111},"end":{"line":37,"column":149}}]},"8":{"line":43,"type":"if","locations":[{"start":{"line":43,"column":4},"end":{"line":43,"column":4}},{"start":{"line":43,"column":4},"end":{"line":43,"column":4}}]},"9":{"line":49,"type":"if","locations":[{"start":{"line":49,"column":4},"end":{"line":49,"column":4}},{"start":{"line":49,"column":4},"end":{"line":49,"column":4}}]},"10":{"line":53,"type":"if","locations":[{"start":{"line":53,"column":11},"end":{"line":53,"column":11}},{"start":{"line":53,"column":11},"end":{"line":53,"column":11}}]},"11":{"line":56,"type":"binary-expr","locations":[{"start":{"line":56,"column":20},"end":{"line":56,"column":41}},{"start":{"line":56,"column":45},"end":{"line":56,"column":62}}]},"12":{"line":60,"type":"if","locations":[{"start":{"line":60,"column":6},"end":{"line":60,"column":6}},{"start":{"line":60,"column":6},"end":{"line":60,"column":6}}]},"13":{"line":61,"type":"binary-expr","locations":[{"start":{"line":61,"column":62},"end":{"line":61,"column":92}},{"start":{"line":61,"column":96},"end":{"line":61,"column":106}}]},"14":{"line":62,"type":"if","locations":[{"start":{"line":62,"column":8},"end":{"line":62,"column":8}},{"start":{"line":62,"column":8},"end":{"line":62,"column":8}}]},"15":{"line":71,"type":"binary-expr","locations":[{"start":{"line":71,"column":14},"end":{"line":71,"column":34}},{"start":{"line":74,"column":14},"end":{"line":74,"column":45}},{"start":{"line":75,"column":14},"end":{"line":75,"column":45}},{"start":{"line":80,"column":14},"end":{"line":80,"column":43}},{"start":{"line":83,"column":14},"end":{"line":83,"column":40}},{"start":{"line":86,"column":14},"end":{"line":86,"column":35}},{"start":{"line":92,"column":14},"end":{"line":92,"column":38}},{"start":{"line":93,"column":14},"end":{"line":93,"column":41}},{"start":{"line":96,"column":14},"end":{"line":96,"column":44}},{"start":{"line":98,"column":14},"end":{"line":98,"column":39}},{"start":{"line":103,"column":14},"end":{"line":103,"column":70}},{"start":{"line":106,"column":14},"end":{"line":106,"column":92}},{"start":{"line":108,"column":14},"end":{"line":108,"column":44}},{"start":{"line":109,"column":14},"end":{"line":109,"column":59}},{"start":{"line":112,"column":14},"end":{"line":112,"column":78}},{"start":{"line":114,"column":14},"end":{"line":114,"column":77}},{"start":{"line":117,"column":14},"end":{"line":117,"column":82}},{"start":{"line":120,"column":14},"end":{"line":120,"column":69}}]},"16":{"line":128,"type":"if","locations":[{"start":{"line":128,"column":6},"end":{"line":128,"column":6}},{"start":{"line":128,"column":6},"end":{"line":128,"column":6}}]},"17":{"line":130,"type":"if","locations":[{"start":{"line":130,"column":8},"end":{"line":130,"column":8}},{"start":{"line":130,"column":8},"end":{"line":130,"column":8}}]},"18":{"line":135,"type":"if","locations":[{"start":{"line":135,"column":12},"end":{"line":135,"column":12}},{"start":{"line":135,"column":12},"end":{"line":135,"column":12}}]},"19":{"line":135,"type":"binary-expr","locations":[{"start":{"line":135,"column":16},"end":{"line":135,"column":32}},{"start":{"line":135,"column":36},"end":{"line":135,"column":49}}]},"20":{"line":138,"type":"binary-expr","locations":[{"start":{"line":138,"column":35},"end":{"line":138,"column":57}},{"start":{"line":138,"column":61},"end":{"line":138,"column":80}}]},"21":{"line":139,"type":"if","locations":[{"start":{"line":139,"column":14},"end":{"line":139,"column":14}},{"start":{"line":139,"column":14},"end":{"line":139,"column":14}}]},"22":{"line":144,"type":"if","locations":[{"start":{"line":144,"column":16},"end":{"line":144,"column":16}},{"start":{"line":144,"column":16},"end":{"line":144,"column":16}}]},"23":{"line":152,"type":"if","locations":[{"start":{"line":152,"column":16},"end":{"line":152,"column":16}},{"start":{"line":152,"column":16},"end":{"line":152,"column":16}}]},"24":{"line":176,"type":"if","locations":[{"start":{"line":176,"column":2},"end":{"line":176,"column":2}},{"start":{"line":176,"column":2},"end":{"line":176,"column":2}}]},"25":{"line":189,"type":"if","locations":[{"start":{"line":189,"column":4},"end":{"line":189,"column":4}},{"start":{"line":189,"column":4},"end":{"line":189,"column":4}}]},"26":{"line":203,"type":"if","locations":[{"start":{"line":203,"column":4},"end":{"line":203,"column":4}},{"start":{"line":203,"column":4},"end":{"line":203,"column":4}}]},"27":{"line":206,"type":"if","locations":[{"start":{"line":206,"column":8},"end":{"line":206,"column":8}},{"start":{"line":206,"column":8},"end":{"line":206,"column":8}}]},"28":{"line":228,"type":"binary-expr","locations":[{"start":{"line":228,"column":26},"end":{"line":228,"column":42}},{"start":{"line":228,"column":46},"end":{"line":228,"column":57}}]},"29":{"line":229,"type":"binary-expr","locations":[{"start":{"line":229,"column":19},"end":{"line":229,"column":35}},{"start":{"line":229,"column":39},"end":{"line":229,"column":99}}]},"30":{"line":229,"type":"binary-expr","locations":[{"start":{"line":229,"column":41},"end":{"line":229,"column":59}},{"start":{"line":229,"column":63},"end":{"line":229,"column":98}}]},"31":{"line":249,"type":"cond-expr","locations":[{"start":{"line":249,"column":32},"end":{"line":249,"column":50}},{"start":{"line":249,"column":53},"end":{"line":249,"column":74}}]},"32":{"line":268,"type":"if","locations":[{"start":{"line":268,"column":8},"end":{"line":268,"column":8}},{"start":{"line":268,"column":8},"end":{"line":268,"column":8}}]},"33":{"line":275,"type":"if","locations":[{"start":{"line":275,"column":6},"end":{"line":275,"column":6}},{"start":{"line":275,"column":6},"end":{"line":275,"column":6}}]},"34":{"line":282,"type":"cond-expr","locations":[{"start":{"line":282,"column":125},"end":{"line":282,"column":146}},{"start":{"line":282,"column":149},"end":{"line":282,"column":159}}]},"35":{"line":282,"type":"binary-expr","locations":[{"start":{"line":282,"column":28},"end":{"line":282,"column":39}},{"start":{"line":282,"column":43},"end":{"line":282,"column":82}},{"start":{"line":282,"column":86},"end":{"line":282,"column":122}}]},"36":{"line":286,"type":"if","locations":[{"start":{"line":286,"column":12},"end":{"line":286,"column":12}},{"start":{"line":286,"column":12},"end":{"line":286,"column":12}}]},"37":{"line":286,"type":"binary-expr","locations":[{"start":{"line":286,"column":16},"end":{"line":286,"column":56}},{"start":{"line":286,"column":60},"end":{"line":286,"column":94}}]},"38":{"line":286,"type":"binary-expr","locations":[{"start":{"line":286,"column":18},"end":{"line":286,"column":28}},{"start":{"line":286,"column":32},"end":{"line":286,"column":55}}]},"39":{"line":291,"type":"binary-expr","locations":[{"start":{"line":291,"column":70},"end":{"line":291,"column":104}},{"start":{"line":291,"column":108},"end":{"line":291,"column":126}}]},"40":{"line":293,"type":"if","locations":[{"start":{"line":293,"column":13},"end":{"line":293,"column":13}},{"start":{"line":293,"column":13},"end":{"line":293,"column":13}}]},"41":{"line":302,"type":"if","locations":[{"start":{"line":302,"column":12},"end":{"line":302,"column":12}},{"start":{"line":302,"column":12},"end":{"line":302,"column":12}}]},"42":{"line":302,"type":"binary-expr","locations":[{"start":{"line":302,"column":16},"end":{"line":302,"column":56}},{"start":{"line":302,"column":60},"end":{"line":302,"column":95}},{"start":{"line":302,"column":100},"end":{"line":302,"column":121}},{"start":{"line":302,"column":126},"end":{"line":302,"column":159}}]},"43":{"line":302,"type":"binary-expr","locations":[{"start":{"line":302,"column":18},"end":{"line":302,"column":28}},{"start":{"line":302,"column":32},"end":{"line":302,"column":55}}]},"44":{"line":312,"type":"if","locations":[{"start":{"line":312,"column":12},"end":{"line":312,"column":12}},{"start":{"line":312,"column":12},"end":{"line":312,"column":12}}]},"45":{"line":312,"type":"binary-expr","locations":[{"start":{"line":312,"column":16},"end":{"line":312,"column":56}},{"start":{"line":312,"column":60},"end":{"line":312,"column":93}},{"start":{"line":312,"column":97},"end":{"line":312,"column":142}}]},"46":{"line":312,"type":"binary-expr","locations":[{"start":{"line":312,"column":18},"end":{"line":312,"column":28}},{"start":{"line":312,"column":32},"end":{"line":312,"column":55}}]},"47":{"line":318,"type":"if","locations":[{"start":{"line":318,"column":10},"end":{"line":318,"column":10}},{"start":{"line":318,"column":10},"end":{"line":318,"column":10}}]},"48":{"line":318,"type":"binary-expr","locations":[{"start":{"line":318,"column":14},"end":{"line":318,"column":27}},{"start":{"line":318,"column":31},"end":{"line":318,"column":82}}]},"49":{"line":332,"type":"if","locations":[{"start":{"line":332,"column":4},"end":{"line":332,"column":4}},{"start":{"line":332,"column":4},"end":{"line":332,"column":4}}]},"50":{"line":350,"type":"binary-expr","locations":[{"start":{"line":350,"column":33},"end":{"line":350,"column":38}},{"start":{"line":350,"column":42},"end":{"line":350,"column":43}}]},"51":{"line":359,"type":"binary-expr","locations":[{"start":{"line":359,"column":70},"end":{"line":359,"column":81}},{"start":{"line":359,"column":85},"end":{"line":359,"column":99}}]},"52":{"line":360,"type":"if","locations":[{"start":{"line":360,"column":8},"end":{"line":360,"column":8}},{"start":{"line":360,"column":8},"end":{"line":360,"column":8}}]},"53":{"line":367,"type":"switch","locations":[{"start":{"line":368,"column":12},"end":{"line":368,"column":19}},{"start":{"line":368,"column":20},"end":{"line":368,"column":27}},{"start":{"line":368,"column":28},"end":{"line":368,"column":36}},{"start":{"line":368,"column":37},"end":{"line":368,"column":45}},{"start":{"line":368,"column":46},"end":{"line":368,"column":54}},{"start":{"line":368,"column":55},"end":{"line":368,"column":63}},{"start":{"line":368,"column":64},"end":{"line":370,"column":20}},{"start":{"line":371,"column":12},"end":{"line":376,"column":103}}]},"54":{"line":372,"type":"if","locations":[{"start":{"line":372,"column":14},"end":{"line":372,"column":14}},{"start":{"line":372,"column":14},"end":{"line":372,"column":14}}]},"55":{"line":376,"type":"cond-expr","locations":[{"start":{"line":376,"column":34},"end":{"line":376,"column":48}},{"start":{"line":376,"column":51},"end":{"line":376,"column":102}}]},"56":{"line":376,"type":"cond-expr","locations":[{"start":{"line":376,"column":68},"end":{"line":376,"column":87}},{"start":{"line":376,"column":90},"end":{"line":376,"column":102}}]},"57":{"line":390,"type":"if","locations":[{"start":{"line":390,"column":8},"end":{"line":390,"column":8}},{"start":{"line":390,"column":8},"end":{"line":390,"column":8}}]},"58":{"line":390,"type":"binary-expr","locations":[{"start":{"line":390,"column":12},"end":{"line":390,"column":36}},{"start":{"line":390,"column":40},"end":{"line":390,"column":45}}]},"59":{"line":392,"type":"if","locations":[{"start":{"line":392,"column":10},"end":{"line":392,"column":10}},{"start":{"line":392,"column":10},"end":{"line":392,"column":10}}]},"60":{"line":392,"type":"binary-expr","locations":[{"start":{"line":392,"column":14},"end":{"line":392,"column":36}},{"start":{"line":392,"column":40},"end":{"line":392,"column":73}}]},"61":{"line":393,"type":"if","locations":[{"start":{"line":393,"column":12},"end":{"line":393,"column":12}},{"start":{"line":393,"column":12},"end":{"line":393,"column":12}}]},"62":{"line":393,"type":"binary-expr","locations":[{"start":{"line":393,"column":16},"end":{"line":393,"column":30}},{"start":{"line":393,"column":34},"end":{"line":393,"column":47}}]},"63":{"line":397,"type":"if","locations":[{"start":{"line":397,"column":14},"end":{"line":397,"column":14}},{"start":{"line":397,"column":14},"end":{"line":397,"column":14}}]},"64":{"line":426,"type":"cond-expr","locations":[{"start":{"line":426,"column":50},"end":{"line":426,"column":117}},{"start":{"line":426,"column":120},"end":{"line":426,"column":143}}]},"65":{"line":426,"type":"binary-expr","locations":[{"start":{"line":426,"column":23},"end":{"line":426,"column":32}},{"start":{"line":426,"column":36},"end":{"line":426,"column":47}}]},"66":{"line":426,"type":"cond-expr","locations":[{"start":{"line":426,"column":62},"end":{"line":426,"column":65}},{"start":{"line":426,"column":68},"end":{"line":426,"column":71}}]},"67":{"line":426,"type":"cond-expr","locations":[{"start":{"line":426,"column":104},"end":{"line":426,"column":109}},{"start":{"line":426,"column":112},"end":{"line":426,"column":116}}]},"68":{"line":436,"type":"if","locations":[{"start":{"line":436,"column":17},"end":{"line":436,"column":17}},{"start":{"line":436,"column":17},"end":{"line":436,"column":17}}]},"69":{"line":436,"type":"binary-expr","locations":[{"start":{"line":436,"column":21},"end":{"line":436,"column":54}},{"start":{"line":436,"column":60},"end":{"line":436,"column":84}},{"start":{"line":436,"column":88},"end":{"line":436,"column":112}},{"start":{"line":436,"column":116},"end":{"line":436,"column":139}},{"start":{"line":436,"column":144},"end":{"line":436,"column":176}}]},"70":{"line":444,"type":"if","locations":[{"start":{"line":444,"column":8},"end":{"line":444,"column":8}},{"start":{"line":444,"column":8},"end":{"line":444,"column":8}}]},"71":{"line":449,"type":"if","locations":[{"start":{"line":449,"column":8},"end":{"line":449,"column":8}},{"start":{"line":449,"column":8},"end":{"line":449,"column":8}}]},"72":{"line":453,"type":"if","locations":[{"start":{"line":453,"column":8},"end":{"line":453,"column":8}},{"start":{"line":453,"column":8},"end":{"line":453,"column":8}}]},"73":{"line":456,"type":"if","locations":[{"start":{"line":456,"column":15},"end":{"line":456,"column":15}},{"start":{"line":456,"column":15},"end":{"line":456,"column":15}}]},"74":{"line":459,"type":"cond-expr","locations":[{"start":{"line":459,"column":51},"end":{"line":459,"column":61}},{"start":{"line":459,"column":64},"end":{"line":459,"column":70}}]},"75":{"line":459,"type":"binary-expr","locations":[{"start":{"line":459,"column":17},"end":{"line":459,"column":31}},{"start":{"line":459,"column":35},"end":{"line":459,"column":48}}]},"76":{"line":460,"type":"if","locations":[{"start":{"line":460,"column":15},"end":{"line":460,"column":15}},{"start":{"line":460,"column":15},"end":{"line":460,"column":15}}]},"77":{"line":465,"type":"if","locations":[{"start":{"line":465,"column":8},"end":{"line":465,"column":8}},{"start":{"line":465,"column":8},"end":{"line":465,"column":8}}]},"78":{"line":469,"type":"if","locations":[{"start":{"line":469,"column":12},"end":{"line":469,"column":12}},{"start":{"line":469,"column":12},"end":{"line":469,"column":12}}]},"79":{"line":480,"type":"if","locations":[{"start":{"line":480,"column":10},"end":{"line":480,"column":10}},{"start":{"line":480,"column":10},"end":{"line":480,"column":10}}]},"80":{"line":482,"type":"binary-expr","locations":[{"start":{"line":482,"column":67},"end":{"line":482,"column":77}},{"start":{"line":482,"column":82},"end":{"line":482,"column":99}}]},"81":{"line":484,"type":"cond-expr","locations":[{"start":{"line":484,"column":47},"end":{"line":484,"column":53}},{"start":{"line":484,"column":56},"end":{"line":484,"column":63}}]},"82":{"line":486,"type":"cond-expr","locations":[{"start":{"line":486,"column":35},"end":{"line":486,"column":159}},{"start":{"line":486,"column":163},"end":{"line":486,"column":167}}]},"83":{"line":486,"type":"cond-expr","locations":[{"start":{"line":486,"column":48},"end":{"line":486,"column":125}},{"start":{"line":486,"column":129},"end":{"line":486,"column":158}}]},"84":{"line":491,"type":"binary-expr","locations":[{"start":{"line":491,"column":20},"end":{"line":491,"column":30}},{"start":{"line":491,"column":34},"end":{"line":491,"column":39}}]},"85":{"line":493,"type":"if","locations":[{"start":{"line":493,"column":14},"end":{"line":493,"column":14}},{"start":{"line":493,"column":14},"end":{"line":493,"column":14}}]},"86":{"line":500,"type":"cond-expr","locations":[{"start":{"line":500,"column":67},"end":{"line":500,"column":70}},{"start":{"line":500,"column":73},"end":{"line":500,"column":75}}]},"87":{"line":502,"type":"binary-expr","locations":[{"start":{"line":502,"column":14},"end":{"line":502,"column":24}},{"start":{"line":502,"column":29},"end":{"line":502,"column":46}}]},"88":{"line":504,"type":"cond-expr","locations":[{"start":{"line":504,"column":35},"end":{"line":504,"column":159}},{"start":{"line":504,"column":163},"end":{"line":504,"column":167}}]},"89":{"line":504,"type":"cond-expr","locations":[{"start":{"line":504,"column":48},"end":{"line":504,"column":125}},{"start":{"line":504,"column":129},"end":{"line":504,"column":158}}]},"90":{"line":515,"type":"if","locations":[{"start":{"line":515,"column":8},"end":{"line":515,"column":8}},{"start":{"line":515,"column":8},"end":{"line":515,"column":8}}]},"91":{"line":515,"type":"binary-expr","locations":[{"start":{"line":515,"column":12},"end":{"line":515,"column":39}},{"start":{"line":515,"column":43},"end":{"line":515,"column":68}},{"start":{"line":515,"column":72},"end":{"line":515,"column":78}}]},"92":{"line":516,"type":"if","locations":[{"start":{"line":516,"column":10},"end":{"line":516,"column":10}},{"start":{"line":516,"column":10},"end":{"line":516,"column":10}}]},"93":{"line":518,"type":"if","locations":[{"start":{"line":518,"column":17},"end":{"line":518,"column":17}},{"start":{"line":518,"column":17},"end":{"line":518,"column":17}}]},"94":{"line":521,"type":"binary-expr","locations":[{"start":{"line":521,"column":106},"end":{"line":521,"column":141}},{"start":{"line":521,"column":145},"end":{"line":521,"column":180}},{"start":{"line":521,"column":186},"end":{"line":521,"column":207}}]},"95":{"line":524,"type":"if","locations":[{"start":{"line":524,"column":8},"end":{"line":524,"column":8}},{"start":{"line":524,"column":8},"end":{"line":524,"column":8}}]},"96":{"line":525,"type":"if","locations":[{"start":{"line":525,"column":10},"end":{"line":525,"column":10}},{"start":{"line":525,"column":10},"end":{"line":525,"column":10}}]},"97":{"line":528,"type":"if","locations":[{"start":{"line":528,"column":12},"end":{"line":528,"column":12}},{"start":{"line":528,"column":12},"end":{"line":528,"column":12}}]},"98":{"line":531,"type":"if","locations":[{"start":{"line":531,"column":17},"end":{"line":531,"column":17}},{"start":{"line":531,"column":17},"end":{"line":531,"column":17}}]},"99":{"line":532,"type":"cond-expr","locations":[{"start":{"line":532,"column":46},"end":{"line":532,"column":51}},{"start":{"line":532,"column":54},"end":{"line":532,"column":72}}]},"100":{"line":543,"type":"if","locations":[{"start":{"line":543,"column":4},"end":{"line":543,"column":4}},{"start":{"line":543,"column":4},"end":{"line":543,"column":4}}]},"101":{"line":575,"type":"switch","locations":[{"start":{"line":576,"column":12},"end":{"line":576,"column":19}},{"start":{"line":576,"column":20},"end":{"line":576,"column":28}},{"start":{"line":576,"column":29},"end":{"line":576,"column":37}},{"start":{"line":576,"column":38},"end":{"line":580,"column":20}},{"start":{"line":581,"column":12},"end":{"line":581,"column":21}},{"start":{"line":581,"column":22},"end":{"line":581,"column":31}},{"start":{"line":581,"column":32},"end":{"line":581,"column":40}},{"start":{"line":581,"column":41},"end":{"line":581,"column":49}},{"start":{"line":581,"column":50},"end":{"line":581,"column":58}},{"start":{"line":581,"column":59},"end":{"line":586,"column":27}},{"start":{"line":587,"column":12},"end":{"line":652,"column":22}},{"start":{"line":653,"column":12},"end":{"line":720,"column":22}}]},"102":{"line":584,"type":"cond-expr","locations":[{"start":{"line":584,"column":39},"end":{"line":584,"column":59}},{"start":{"line":584,"column":62},"end":{"line":584,"column":75}}]},"103":{"line":594,"type":"if","locations":[{"start":{"line":594,"column":16},"end":{"line":594,"column":16}},{"start":{"line":594,"column":16},"end":{"line":594,"column":16}}]},"104":{"line":598,"type":"if","locations":[{"start":{"line":598,"column":23},"end":{"line":598,"column":23}},{"start":{"line":598,"column":23},"end":{"line":598,"column":23}}]},"105":{"line":603,"type":"switch","locations":[{"start":{"line":604,"column":20},"end":{"line":604,"column":28}},{"start":{"line":604,"column":29},"end":{"line":604,"column":37}},{"start":{"line":604,"column":38},"end":{"line":604,"column":46}},{"start":{"line":604,"column":47},"end":{"line":604,"column":55}},{"start":{"line":604,"column":56},"end":{"line":604,"column":65}},{"start":{"line":604,"column":66},"end":{"line":604,"column":75}},{"start":{"line":604,"column":76},"end":{"line":604,"column":85}},{"start":{"line":604,"column":86},"end":{"line":608,"column":28}},{"start":{"line":609,"column":20},"end":{"line":625,"column":28}},{"start":{"line":626,"column":20},"end":{"line":628,"column":30}}]},"106":{"line":618,"type":"if","locations":[{"start":{"line":618,"column":24},"end":{"line":618,"column":24}},{"start":{"line":618,"column":24},"end":{"line":618,"column":24}}]},"107":{"line":618,"type":"binary-expr","locations":[{"start":{"line":618,"column":30},"end":{"line":618,"column":44}},{"start":{"line":618,"column":48},"end":{"line":618,"column":62}},{"start":{"line":618,"column":66},"end":{"line":618,"column":80}},{"start":{"line":618,"column":84},"end":{"line":618,"column":99}},{"start":{"line":618,"column":103},"end":{"line":618,"column":117}},{"start":{"line":618,"column":121},"end":{"line":618,"column":135}}]},"108":{"line":631,"type":"if","locations":[{"start":{"line":631,"column":18},"end":{"line":631,"column":18}},{"start":{"line":631,"column":18},"end":{"line":631,"column":18}}]},"109":{"line":639,"type":"binary-expr","locations":[{"start":{"line":639,"column":25},"end":{"line":639,"column":39}},{"start":{"line":639,"column":43},"end":{"line":639,"column":57}},{"start":{"line":639,"column":61},"end":{"line":639,"column":75}}]},"110":{"line":646,"type":"if","locations":[{"start":{"line":646,"column":14},"end":{"line":646,"column":14}},{"start":{"line":646,"column":14},"end":{"line":646,"column":14}}]},"111":{"line":657,"type":"if","locations":[{"start":{"line":657,"column":14},"end":{"line":657,"column":14}},{"start":{"line":657,"column":14},"end":{"line":657,"column":14}}]},"112":{"line":662,"type":"if","locations":[{"start":{"line":662,"column":14},"end":{"line":662,"column":14}},{"start":{"line":662,"column":14},"end":{"line":662,"column":14}}]},"113":{"line":662,"type":"binary-expr","locations":[{"start":{"line":662,"column":18},"end":{"line":662,"column":32}},{"start":{"line":662,"column":36},"end":{"line":662,"column":50}}]},"114":{"line":664,"type":"if","locations":[{"start":{"line":664,"column":16},"end":{"line":664,"column":16}},{"start":{"line":664,"column":16},"end":{"line":664,"column":16}}]},"115":{"line":664,"type":"binary-expr","locations":[{"start":{"line":664,"column":20},"end":{"line":664,"column":34}},{"start":{"line":664,"column":39},"end":{"line":664,"column":114}}]},"116":{"line":664,"type":"binary-expr","locations":[{"start":{"line":664,"column":82},"end":{"line":664,"column":96}},{"start":{"line":664,"column":100},"end":{"line":664,"column":114}}]},"117":{"line":670,"type":"binary-expr","locations":[{"start":{"line":670,"column":23},"end":{"line":670,"column":37}},{"start":{"line":670,"column":42},"end":{"line":670,"column":113}}]},"118":{"line":670,"type":"binary-expr","locations":[{"start":{"line":670,"column":81},"end":{"line":670,"column":95}},{"start":{"line":670,"column":99},"end":{"line":670,"column":113}}]},"119":{"line":673,"type":"if","locations":[{"start":{"line":673,"column":16},"end":{"line":673,"column":16}},{"start":{"line":673,"column":16},"end":{"line":673,"column":16}}]},"120":{"line":676,"type":"binary-expr","locations":[{"start":{"line":676,"column":25},"end":{"line":676,"column":42}},{"start":{"line":676,"column":47},"end":{"line":676,"column":121}}]},"121":{"line":676,"type":"binary-expr","locations":[{"start":{"line":676,"column":89},"end":{"line":676,"column":103}},{"start":{"line":676,"column":107},"end":{"line":676,"column":121}}]},"122":{"line":677,"type":"if","locations":[{"start":{"line":677,"column":18},"end":{"line":677,"column":18}},{"start":{"line":677,"column":18},"end":{"line":677,"column":18}}]},"123":{"line":686,"type":"if","locations":[{"start":{"line":686,"column":16},"end":{"line":686,"column":16}},{"start":{"line":686,"column":16},"end":{"line":686,"column":16}}]},"124":{"line":686,"type":"binary-expr","locations":[{"start":{"line":686,"column":20},"end":{"line":686,"column":35}},{"start":{"line":686,"column":39},"end":{"line":686,"column":53}}]},"125":{"line":690,"type":"if","locations":[{"start":{"line":690,"column":18},"end":{"line":690,"column":18}},{"start":{"line":690,"column":18},"end":{"line":690,"column":18}}]},"126":{"line":690,"type":"binary-expr","locations":[{"start":{"line":690,"column":22},"end":{"line":690,"column":36}},{"start":{"line":690,"column":40},"end":{"line":690,"column":54}}]},"127":{"line":694,"type":"binary-expr","locations":[{"start":{"line":694,"column":41},"end":{"line":694,"column":58}},{"start":{"line":694,"column":63},"end":{"line":694,"column":137}}]},"128":{"line":694,"type":"binary-expr","locations":[{"start":{"line":694,"column":105},"end":{"line":694,"column":119}},{"start":{"line":694,"column":123},"end":{"line":694,"column":137}}]},"129":{"line":695,"type":"if","locations":[{"start":{"line":695,"column":18},"end":{"line":695,"column":18}},{"start":{"line":695,"column":18},"end":{"line":695,"column":18}}]},"130":{"line":705,"type":"if","locations":[{"start":{"line":705,"column":14},"end":{"line":705,"column":14}},{"start":{"line":705,"column":14},"end":{"line":705,"column":14}}]},"131":{"line":709,"type":"if","locations":[{"start":{"line":709,"column":14},"end":{"line":709,"column":14}},{"start":{"line":709,"column":14},"end":{"line":709,"column":14}}]},"132":{"line":712,"type":"if","locations":[{"start":{"line":712,"column":21},"end":{"line":712,"column":21}},{"start":{"line":712,"column":21},"end":{"line":712,"column":21}}]},"133":{"line":715,"type":"if","locations":[{"start":{"line":715,"column":21},"end":{"line":715,"column":21}},{"start":{"line":715,"column":21},"end":{"line":715,"column":21}}]},"134":{"line":731,"type":"if","locations":[{"start":{"line":731,"column":8},"end":{"line":731,"column":8}},{"start":{"line":731,"column":8},"end":{"line":731,"column":8}}]},"135":{"line":735,"type":"if","locations":[{"start":{"line":735,"column":8},"end":{"line":735,"column":8}},{"start":{"line":735,"column":8},"end":{"line":735,"column":8}}]},"136":{"line":736,"type":"if","locations":[{"start":{"line":736,"column":10},"end":{"line":736,"column":10}},{"start":{"line":736,"column":10},"end":{"line":736,"column":10}}]},"137":{"line":736,"type":"cond-expr","locations":[{"start":{"line":736,"column":32},"end":{"line":736,"column":47}},{"start":{"line":736,"column":50},"end":{"line":736,"column":58}}]},"138":{"line":741,"type":"if","locations":[{"start":{"line":741,"column":10},"end":{"line":741,"column":10}},{"start":{"line":741,"column":10},"end":{"line":741,"column":10}}]},"139":{"line":744,"type":"binary-expr","locations":[{"start":{"line":744,"column":20},"end":{"line":744,"column":30}},{"start":{"line":744,"column":35},"end":{"line":744,"column":52}}]},"140":{"line":747,"type":"if","locations":[{"start":{"line":747,"column":14},"end":{"line":747,"column":14}},{"start":{"line":747,"column":14},"end":{"line":747,"column":14}}]},"141":{"line":753,"type":"if","locations":[{"start":{"line":753,"column":14},"end":{"line":753,"column":14}},{"start":{"line":753,"column":14},"end":{"line":753,"column":14}}]},"142":{"line":754,"type":"if","locations":[{"start":{"line":754,"column":16},"end":{"line":754,"column":16}},{"start":{"line":754,"column":16},"end":{"line":754,"column":16}}]},"143":{"line":756,"type":"if","locations":[{"start":{"line":756,"column":18},"end":{"line":756,"column":18}},{"start":{"line":756,"column":18},"end":{"line":756,"column":18}}]},"144":{"line":766,"type":"if","locations":[{"start":{"line":766,"column":14},"end":{"line":766,"column":14}},{"start":{"line":766,"column":14},"end":{"line":766,"column":14}}]},"145":{"line":772,"type":"if","locations":[{"start":{"line":772,"column":17},"end":{"line":772,"column":17}},{"start":{"line":772,"column":17},"end":{"line":772,"column":17}}]},"146":{"line":775,"type":"binary-expr","locations":[{"start":{"line":775,"column":20},"end":{"line":775,"column":30}},{"start":{"line":775,"column":35},"end":{"line":775,"column":52}}]},"147":{"line":778,"type":"if","locations":[{"start":{"line":778,"column":14},"end":{"line":778,"column":14}},{"start":{"line":778,"column":14},"end":{"line":778,"column":14}}]},"148":{"line":783,"type":"if","locations":[{"start":{"line":783,"column":14},"end":{"line":783,"column":14}},{"start":{"line":783,"column":14},"end":{"line":783,"column":14}}]},"149":{"line":784,"type":"if","locations":[{"start":{"line":784,"column":16},"end":{"line":784,"column":16}},{"start":{"line":784,"column":16},"end":{"line":784,"column":16}}]},"150":{"line":786,"type":"if","locations":[{"start":{"line":786,"column":18},"end":{"line":786,"column":18}},{"start":{"line":786,"column":18},"end":{"line":786,"column":18}}]},"151":{"line":798,"type":"if","locations":[{"start":{"line":798,"column":14},"end":{"line":798,"column":14}},{"start":{"line":798,"column":14},"end":{"line":798,"column":14}}]},"152":{"line":798,"type":"binary-expr","locations":[{"start":{"line":798,"column":18},"end":{"line":798,"column":30}},{"start":{"line":798,"column":34},"end":{"line":798,"column":58}},{"start":{"line":798,"column":62},"end":{"line":798,"column":114}},{"start":{"line":798,"column":118},"end":{"line":798,"column":130}}]},"153":{"line":798,"type":"cond-expr","locations":[{"start":{"line":798,"column":80},"end":{"line":798,"column":95}},{"start":{"line":798,"column":98},"end":{"line":798,"column":106}}]},"154":{"line":814,"type":"if","locations":[{"start":{"line":814,"column":8},"end":{"line":814,"column":8}},{"start":{"line":814,"column":8},"end":{"line":814,"column":8}}]},"155":{"line":826,"type":"if","locations":[{"start":{"line":826,"column":8},"end":{"line":826,"column":8}},{"start":{"line":826,"column":8},"end":{"line":826,"column":8}}]},"156":{"line":826,"type":"binary-expr","locations":[{"start":{"line":826,"column":12},"end":{"line":826,"column":36}},{"start":{"line":826,"column":40},"end":{"line":826,"column":45}}]},"157":{"line":830,"type":"if","locations":[{"start":{"line":830,"column":10},"end":{"line":830,"column":10}},{"start":{"line":830,"column":10},"end":{"line":830,"column":10}}]},"158":{"line":850,"type":"if","locations":[{"start":{"line":850,"column":8},"end":{"line":850,"column":8}},{"start":{"line":850,"column":8},"end":{"line":850,"column":8}}]},"159":{"line":855,"type":"cond-expr","locations":[{"start":{"line":855,"column":70},"end":{"line":855,"column":129}},{"start":{"line":855,"column":132},"end":{"line":855,"column":138}}]},"160":{"line":855,"type":"binary-expr","locations":[{"start":{"line":855,"column":15},"end":{"line":855,"column":23}},{"start":{"line":855,"column":27},"end":{"line":855,"column":67}}]},"161":{"line":861,"type":"if","locations":[{"start":{"line":861,"column":2},"end":{"line":861,"column":2}},{"start":{"line":861,"column":2},"end":{"line":861,"column":2}}]}}}} \ No newline at end of file diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/coverage/lcov-report/lib/json3.js.html b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/coverage/lcov-report/lib/json3.js.html new file mode 100644 index 0000000..11c49b4 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/coverage/lcov-report/lib/json3.js.html @@ -0,0 +1,2903 @@ + + + + Code coverage report for lib/json3.js + + + + + + + +
              +

              Code coverage report for lib/json3.js

              +

              + + Statements: 13.77% (50 / 363)      + + + Branches: 15.32% (59 / 385)      + + + Functions: 11.54% (3 / 26)      + + + Lines: 13.77% (50 / 363)      + +

              +
              All files » lib/ » json3.js
              +
              +
              +
              
              +
              +
              1 +2 +3 +4 +5 +6 +7 +8 +9 +10 +11 +12 +13 +14 +15 +16 +17 +18 +19 +20 +21 +22 +23 +24 +25 +26 +27 +28 +29 +30 +31 +32 +33 +34 +35 +36 +37 +38 +39 +40 +41 +42 +43 +44 +45 +46 +47 +48 +49 +50 +51 +52 +53 +54 +55 +56 +57 +58 +59 +60 +61 +62 +63 +64 +65 +66 +67 +68 +69 +70 +71 +72 +73 +74 +75 +76 +77 +78 +79 +80 +81 +82 +83 +84 +85 +86 +87 +88 +89 +90 +91 +92 +93 +94 +95 +96 +97 +98 +99 +100 +101 +102 +103 +104 +105 +106 +107 +108 +109 +110 +111 +112 +113 +114 +115 +116 +117 +118 +119 +120 +121 +122 +123 +124 +125 +126 +127 +128 +129 +130 +131 +132 +133 +134 +135 +136 +137 +138 +139 +140 +141 +142 +143 +144 +145 +146 +147 +148 +149 +150 +151 +152 +153 +154 +155 +156 +157 +158 +159 +160 +161 +162 +163 +164 +165 +166 +167 +168 +169 +170 +171 +172 +173 +174 +175 +176 +177 +178 +179 +180 +181 +182 +183 +184 +185 +186 +187 +188 +189 +190 +191 +192 +193 +194 +195 +196 +197 +198 +199 +200 +201 +202 +203 +204 +205 +206 +207 +208 +209 +210 +211 +212 +213 +214 +215 +216 +217 +218 +219 +220 +221 +222 +223 +224 +225 +226 +227 +228 +229 +230 +231 +232 +233 +234 +235 +236 +237 +238 +239 +240 +241 +242 +243 +244 +245 +246 +247 +248 +249 +250 +251 +252 +253 +254 +255 +256 +257 +258 +259 +260 +261 +262 +263 +264 +265 +266 +267 +268 +269 +270 +271 +272 +273 +274 +275 +276 +277 +278 +279 +280 +281 +282 +283 +284 +285 +286 +287 +288 +289 +290 +291 +292 +293 +294 +295 +296 +297 +298 +299 +300 +301 +302 +303 +304 +305 +306 +307 +308 +309 +310 +311 +312 +313 +314 +315 +316 +317 +318 +319 +320 +321 +322 +323 +324 +325 +326 +327 +328 +329 +330 +331 +332 +333 +334 +335 +336 +337 +338 +339 +340 +341 +342 +343 +344 +345 +346 +347 +348 +349 +350 +351 +352 +353 +354 +355 +356 +357 +358 +359 +360 +361 +362 +363 +364 +365 +366 +367 +368 +369 +370 +371 +372 +373 +374 +375 +376 +377 +378 +379 +380 +381 +382 +383 +384 +385 +386 +387 +388 +389 +390 +391 +392 +393 +394 +395 +396 +397 +398 +399 +400 +401 +402 +403 +404 +405 +406 +407 +408 +409 +410 +411 +412 +413 +414 +415 +416 +417 +418 +419 +420 +421 +422 +423 +424 +425 +426 +427 +428 +429 +430 +431 +432 +433 +434 +435 +436 +437 +438 +439 +440 +441 +442 +443 +444 +445 +446 +447 +448 +449 +450 +451 +452 +453 +454 +455 +456 +457 +458 +459 +460 +461 +462 +463 +464 +465 +466 +467 +468 +469 +470 +471 +472 +473 +474 +475 +476 +477 +478 +479 +480 +481 +482 +483 +484 +485 +486 +487 +488 +489 +490 +491 +492 +493 +494 +495 +496 +497 +498 +499 +500 +501 +502 +503 +504 +505 +506 +507 +508 +509 +510 +511 +512 +513 +514 +515 +516 +517 +518 +519 +520 +521 +522 +523 +524 +525 +526 +527 +528 +529 +530 +531 +532 +533 +534 +535 +536 +537 +538 +539 +540 +541 +542 +543 +544 +545 +546 +547 +548 +549 +550 +551 +552 +553 +554 +555 +556 +557 +558 +559 +560 +561 +562 +563 +564 +565 +566 +567 +568 +569 +570 +571 +572 +573 +574 +575 +576 +577 +578 +579 +580 +581 +582 +583 +584 +585 +586 +587 +588 +589 +590 +591 +592 +593 +594 +595 +596 +597 +598 +599 +600 +601 +602 +603 +604 +605 +606 +607 +608 +609 +610 +611 +612 +613 +614 +615 +616 +617 +618 +619 +620 +621 +622 +623 +624 +625 +626 +627 +628 +629 +630 +631 +632 +633 +634 +635 +636 +637 +638 +639 +640 +641 +642 +643 +644 +645 +646 +647 +648 +649 +650 +651 +652 +653 +654 +655 +656 +657 +658 +659 +660 +661 +662 +663 +664 +665 +666 +667 +668 +669 +670 +671 +672 +673 +674 +675 +676 +677 +678 +679 +680 +681 +682 +683 +684 +685 +686 +687 +688 +689 +690 +691 +692 +693 +694 +695 +696 +697 +698 +699 +700 +701 +702 +703 +704 +705 +706 +707 +708 +709 +710 +711 +712 +713 +714 +715 +716 +717 +718 +719 +720 +721 +722 +723 +724 +725 +726 +727 +728 +729 +730 +731 +732 +733 +734 +735 +736 +737 +738 +739 +740 +741 +742 +743 +744 +745 +746 +747 +748 +749 +750 +751 +752 +753 +754 +755 +756 +757 +758 +759 +760 +761 +762 +763 +764 +765 +766 +767 +768 +769 +770 +771 +772 +773 +774 +775 +776 +777 +778 +779 +780 +781 +782 +783 +784 +785 +786 +787 +788 +789 +790 +791 +792 +793 +794 +795 +796 +797 +798 +799 +800 +801 +802 +803 +804 +805 +806 +807 +808 +809 +810 +811 +812 +813 +814 +815 +816 +817 +818 +819 +820 +821 +822 +823 +824 +825 +826 +827 +828 +829 +830 +831 +832 +833 +834 +835 +836 +837 +838 +839 +840 +841 +842 +843 +844 +845 +846 +847 +848 +849 +850 +851 +852 +853 +854 +855 +856 +857 +858 +859 +860 +861 +862 +863 +864 +865 +866 +867  +1 +  +1 +  +  +  +1 +  +  +1 +  +  +  +1 +  +1 +  +  +1 +1 +  +  +  +  +  +  +  +1 +1 +  +  +1 +  +  +  +  +  +  +  +  +1 +3 +  +  +  +  +3 +3 +  +  +  +3 +  +  +1 +  +2 +  +2 +1 +1 +  +1 +4 +  +1 +1 +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +1 +  +  +2 +1 +1 +1 +  +  +  +1 +  +1 +1 +1 +1 +  +1 +  +1 +1 +  +  +  +1 +  +  +1 +1 +  +  +  +1 +  +  +  +  +  +  +  +  +1 +  +  +3 +  +1 +1 +1 +1 +  +1 +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +1 +  +  +  +  +  + 
              /*! JSON v3.2.5 | http://bestiejs.github.io/json3 | Copyright 2012-2013, Kit Cambridge | http://kit.mit-license.org */
              +;(function (window) {
              +  // Convenience aliases.
              +  var getClass = {}.toString, isProperty, forEach, undef;
              + 
              +  // Detect the `define` function exposed by asynchronous module loaders. The
              +  // strict `define` check is necessary for compatibility with `r.js`.
              +  var isLoader = typeof define === "function" && define.amd;
              + 
              +  // Detect native implementations.
              +  var nativeJSON = typeof JSON == "object" && JSON;
              + 
              +  // Set up the JSON 3 namespace, preferring the CommonJS `exports` object if
              +  // available.
              +  var JSON3 = typeof exports == "object" && exports && !exports.nodeType && exports;
              + 
              +  Eif (JSON3 && nativeJSON) {
              +    // Explicitly delegate to the native `stringify` and `parse`
              +    // implementations in CommonJS environments.
              +    JSON3.stringify = nativeJSON.stringify;
              +    JSON3.parse = nativeJSON.parse;
              +  } else {
              +    // Export for web browsers, JavaScript engines, and asynchronous module
              +    // loaders, using the global `JSON` object if available.
              +    JSON3 = window.JSON = nativeJSON || {};
              +  }
              + 
              +  // Test the `Date#getUTC*` methods. Based on work by @Yaffle.
              +  var isExtended = new Date(-3509827334573292);
              +  try {
              +    // The `getUTCFullYear`, `Month`, and `Date` methods return nonsensical
              +    // results for certain dates in Opera >= 10.53.
              +    isExtended = isExtended.getUTCFullYear() == -109252 && isExtended.getUTCMonth() === 0 && isExtended.getUTCDate() === 1 &&
              +      // Safari < 2.0.2 stores the internal millisecond time value correctly,
              +      // but clips the values returned by the date methods to the range of
              +      // signed 32-bit integers ([-2 ** 31, 2 ** 31 - 1]).
              +      isExtended.getUTCHours() == 10 && isExtended.getUTCMinutes() == 37 && isExtended.getUTCSeconds() == 6 && isExtended.getUTCMilliseconds() == 708;
              +  } catch (exception) {}
              + 
              +  // Internal: Determines whether the native `JSON.stringify` and `parse`
              +  // implementations are spec-compliant. Based on work by Ken Snyder.
              +  function has(name) {
              +    Iif (has[name] != null) {
              +      // Return cached feature test result.
              +      return has[name];
              +    }
              + 
              +    var isSupported;
              +    Iif (name == "bug-string-char-index") {
              +      // IE <= 7 doesn't support accessing string characters using square
              +      // bracket notation. IE 8 only supports this for primitives.
              +      isSupported = "a"[0] != "a";
              +    } else if (name == "json") {
              +      // Indicates whether both `JSON.stringify` and `JSON.parse` are
              +      // supported.
              +      isSupported = has("json-stringify") && has("json-parse");
              +    } else {
              +      var value, serialized = '{"a":[1,true,false,null,"\\u0000\\b\\n\\f\\r\\t"]}';
              +      // Test `JSON.stringify`.
              +      if (name == "json-stringify") {
              +        var stringify = JSON3.stringify, stringifySupported = typeof stringify == "function" && isExtended;
              +        Eif (stringifySupported) {
              +          // A test function object with a custom `toJSON` method.
              +          (value = function () {
              +            return 1;
              +          }).toJSON = value;
              +          try {
              +            stringifySupported =
              +              // Firefox 3.1b1 and b2 serialize string, number, and boolean
              +              // primitives as object literals.
              +              stringify(0) === "0" &&
              +              // FF 3.1b1, b2, and JSON 2 serialize wrapped primitives as object
              +              // literals.
              +              stringify(new Number()) === "0" &&
              +              stringify(new String()) == '""' &&
              +              // FF 3.1b1, 2 throw an error if the value is `null`, `undefined`, or
              +              // does not define a canonical JSON representation (this applies to
              +              // objects with `toJSON` properties as well, *unless* they are nested
              +              // within an object or array).
              +              stringify(getClass) === undef &&
              +              // IE 8 serializes `undefined` as `"undefined"`. Safari <= 5.1.7 and
              +              // FF 3.1b3 pass this test.
              +              stringify(undef) === undef &&
              +              // Safari <= 5.1.7 and FF 3.1b3 throw `Error`s and `TypeError`s,
              +              // respectively, if the value is omitted entirely.
              +              stringify() === undef &&
              +              // FF 3.1b1, 2 throw an error if the given value is not a number,
              +              // string, array, object, Boolean, or `null` literal. This applies to
              +              // objects with custom `toJSON` methods as well, unless they are nested
              +              // inside object or array literals. YUI 3.0.0b1 ignores custom `toJSON`
              +              // methods entirely.
              +              stringify(value) === "1" &&
              +              stringify([value]) == "[1]" &&
              +              // Prototype <= 1.6.1 serializes `[undefined]` as `"[]"` instead of
              +              // `"[null]"`.
              +              stringify([undef]) == "[null]" &&
              +              // YUI 3.0.0b1 fails to serialize `null` literals.
              +              stringify(null) == "null" &&
              +              // FF 3.1b1, 2 halts serialization if an array contains a function:
              +              // `[1, true, getClass, 1]` serializes as "[1,true,],". FF 3.1b3
              +              // elides non-JSON values from objects and arrays, unless they
              +              // define custom `toJSON` methods.
              +              stringify([undef, getClass, null]) == "[null,null,null]" &&
              +              // Simple serialization test. FF 3.1b1 uses Unicode escape sequences
              +              // where character escape codes are expected (e.g., `\b` => `\u0008`).
              +              stringify({ "a": [value, true, false, null, "\x00\b\n\f\r\t"] }) == serialized &&
              +              // FF 3.1b1 and b2 ignore the `filter` and `width` arguments.
              +              stringify(null, value) === "1" &&
              +              stringify([1, 2], null, 1) == "[\n 1,\n 2\n]" &&
              +              // JSON 2, Prototype <= 1.7, and older WebKit builds incorrectly
              +              // serialize extended years.
              +              stringify(new Date(-8.64e15)) == '"-271821-04-20T00:00:00.000Z"' &&
              +              // The milliseconds are optional in ES 5, but required in 5.1.
              +              stringify(new Date(8.64e15)) == '"+275760-09-13T00:00:00.000Z"' &&
              +              // Firefox <= 11.0 incorrectly serializes years prior to 0 as negative
              +              // four-digit years instead of six-digit years. Credits: @Yaffle.
              +              stringify(new Date(-621987552e5)) == '"-000001-01-01T00:00:00.000Z"' &&
              +              // Safari <= 5.1.5 and Opera >= 10.53 incorrectly serialize millisecond
              +              // values less than 1000. Credits: @Yaffle.
              +              stringify(new Date(-1)) == '"1969-12-31T23:59:59.999Z"';
              +          } catch (exception) {
              +            stringifySupported = false;
              +          }
              +        }
              +        isSupported = stringifySupported;
              +      }
              +      // Test `JSON.parse`.
              +      if (name == "json-parse") {
              +        var parse = JSON3.parse;
              +        Eif (typeof parse == "function") {
              +          try {
              +            // FF 3.1b1, b2 will throw an exception if a bare literal is provided.
              +            // Conforming implementations should also coerce the initial argument to
              +            // a string prior to parsing.
              +            Eif (parse("0") === 0 && !parse(false)) {
              +              // Simple parsing test.
              +              value = parse(serialized);
              +              var parseSupported = value["a"].length == 5 && value["a"][0] === 1;
              +              Eif (parseSupported) {
              +                try {
              +                  // Safari <= 5.1.2 and FF 3.1b1 allow unescaped tabs in strings.
              +                  parseSupported = !parse('"\t"');
              +                } catch (exception) {}
              +                Eif (parseSupported) {
              +                  try {
              +                    // FF 4.0 and 4.0.1 allow leading `+` signs and leading
              +                    // decimal points. FF 4.0, 4.0.1, and IE 9-10 also allow
              +                    // certain octal literals.
              +                    parseSupported = parse("01") !== 1;
              +                  } catch (exception) {}
              +                }
              +                Eif (parseSupported) {
              +                  try {
              +                    // FF 4.0, 4.0.1, and Rhino 1.7R3-R4 allow trailing decimal
              +                    // points. These environments, along with FF 3.1b1 and 2,
              +                    // also allow trailing commas in JSON objects and arrays.
              +                    parseSupported = parse("1.") !== 1;
              +                  } catch (exception) {}
              +                }
              +              }
              +            }
              +          } catch (exception) {
              +            parseSupported = false;
              +          }
              +        }
              +        isSupported = parseSupported;
              +      }
              +    }
              +    return has[name] = !!isSupported;
              +  }
              +  has["bug-string-char-index"] = null;
              +  has["json"] = null;
              +  has["json-stringify"] = null;
              +  has["json-parse"] = null;
              + 
              +  Iif (!has("json")) {
              +    // Common `[[Class]]` name aliases.
              +    var functionClass = "[object Function]";
              +    var dateClass = "[object Date]";
              +    var numberClass = "[object Number]";
              +    var stringClass = "[object String]";
              +    var arrayClass = "[object Array]";
              +    var booleanClass = "[object Boolean]";
              + 
              +    // Detect incomplete support for accessing string characters by index.
              +    var charIndexBuggy = has("bug-string-char-index");
              + 
              +    // Define additional utility methods if the `Date` methods are buggy.
              +    if (!isExtended) {
              +      var floor = Math.floor;
              +      // A mapping between the months of the year and the number of days between
              +      // January 1st and the first of the respective month.
              +      var Months = [0, 31, 59, 90, 120, 151, 181, 212, 243, 273, 304, 334];
              +      // Internal: Calculates the number of days between the Unix epoch and the
              +      // first day of the given month.
              +      var getDay = function (year, month) {
              +        return Months[month] + 365 * (year - 1970) + floor((year - 1969 + (month = +(month > 1))) / 4) - floor((year - 1901 + month) / 100) + floor((year - 1601 + month) / 400);
              +      };
              +    }
              + 
              +    // Internal: Determines if a property is a direct property of the given
              +    // object. Delegates to the native `Object#hasOwnProperty` method.
              +    if (!(isProperty = {}.hasOwnProperty)) {
              +      isProperty = function (property) {
              +        var members = {}, constructor;
              +        if ((members.__proto__ = null, members.__proto__ = {
              +          // The *proto* property cannot be set multiple times in recent
              +          // versions of Firefox and SeaMonkey.
              +          "toString": 1
              +        }, members).toString != getClass) {
              +          // Safari <= 2.0.3 doesn't implement `Object#hasOwnProperty`, but
              +          // supports the mutable *proto* property.
              +          isProperty = function (property) {
              +            // Capture and break the object's prototype chain (see section 8.6.2
              +            // of the ES 5.1 spec). The parenthesized expression prevents an
              +            // unsafe transformation by the Closure Compiler.
              +            var original = this.__proto__, result = property in (this.__proto__ = null, this);
              +            // Restore the original prototype chain.
              +            this.__proto__ = original;
              +            return result;
              +          };
              +        } else {
              +          // Capture a reference to the top-level `Object` constructor.
              +          constructor = members.constructor;
              +          // Use the `constructor` property to simulate `Object#hasOwnProperty` in
              +          // other environments.
              +          isProperty = function (property) {
              +            var parent = (this.constructor || constructor).prototype;
              +            return property in this && !(property in parent && this[property] === parent[property]);
              +          };
              +        }
              +        members = null;
              +        return isProperty.call(this, property);
              +      };
              +    }
              + 
              +    // Internal: A set of primitive types used by `isHostType`.
              +    var PrimitiveTypes = {
              +      'boolean': 1,
              +      'number': 1,
              +      'string': 1,
              +      'undefined': 1
              +    };
              + 
              +    // Internal: Determines if the given object `property` value is a
              +    // non-primitive.
              +    var isHostType = function (object, property) {
              +      var type = typeof object[property];
              +      return type == 'object' ? !!object[property] : !PrimitiveTypes[type];
              +    };
              + 
              +    // Internal: Normalizes the `for...in` iteration algorithm across
              +    // environments. Each enumerated key is yielded to a `callback` function.
              +    forEach = function (object, callback) {
              +      var size = 0, Properties, members, property;
              + 
              +      // Tests for bugs in the current environment's `for...in` algorithm. The
              +      // `valueOf` property inherits the non-enumerable flag from
              +      // `Object.prototype` in older versions of IE, Netscape, and Mozilla.
              +      (Properties = function () {
              +        this.valueOf = 0;
              +      }).prototype.valueOf = 0;
              + 
              +      // Iterate over a new instance of the `Properties` class.
              +      members = new Properties();
              +      for (property in members) {
              +        // Ignore all properties inherited from `Object.prototype`.
              +        if (isProperty.call(members, property)) {
              +          size++;
              +        }
              +      }
              +      Properties = members = null;
              + 
              +      // Normalize the iteration algorithm.
              +      if (!size) {
              +        // A list of non-enumerable properties inherited from `Object.prototype`.
              +        members = ["valueOf", "toString", "toLocaleString", "propertyIsEnumerable", "isPrototypeOf", "hasOwnProperty", "constructor"];
              +        // IE <= 8, Mozilla 1.0, and Netscape 6.2 ignore shadowed non-enumerable
              +        // properties.
              +        forEach = function (object, callback) {
              +          var isFunction = getClass.call(object) == functionClass, property, length;
              +          var hasProperty = !isFunction && typeof object.constructor != 'function' && isHostType(object, 'hasOwnProperty') ? object.hasOwnProperty : isProperty;
              +          for (property in object) {
              +            // Gecko <= 1.0 enumerates the `prototype` property of functions under
              +            // certain conditions; IE does not.
              +            if (!(isFunction && property == "prototype") && hasProperty.call(object, property)) {
              +              callback(property);
              +            }
              +          }
              +          // Manually invoke the callback for each non-enumerable property.
              +          for (length = members.length; property = members[--length]; hasProperty.call(object, property) && callback(property));
              +        };
              +      } else if (size == 2) {
              +        // Safari <= 2.0.4 enumerates shadowed properties twice.
              +        forEach = function (object, callback) {
              +          // Create a set of iterated properties.
              +          var members = {}, isFunction = getClass.call(object) == functionClass, property;
              +          for (property in object) {
              +            // Store each property name to prevent double enumeration. The
              +            // `prototype` property of functions is not enumerated due to cross-
              +            // environment inconsistencies.
              +            if (!(isFunction && property == "prototype") && !isProperty.call(members, property) && (members[property] = 1) && isProperty.call(object, property)) {
              +              callback(property);
              +            }
              +          }
              +        };
              +      } else {
              +        // No bugs detected; use the standard `for...in` algorithm.
              +        forEach = function (object, callback) {
              +          var isFunction = getClass.call(object) == functionClass, property, isConstructor;
              +          for (property in object) {
              +            if (!(isFunction && property == "prototype") && isProperty.call(object, property) && !(isConstructor = property === "constructor")) {
              +              callback(property);
              +            }
              +          }
              +          // Manually invoke the callback for the `constructor` property due to
              +          // cross-environment inconsistencies.
              +          if (isConstructor || isProperty.call(object, (property = "constructor"))) {
              +            callback(property);
              +          }
              +        };
              +      }
              +      return forEach(object, callback);
              +    };
              + 
              +    // Public: Serializes a JavaScript `value` as a JSON string. The optional
              +    // `filter` argument may specify either a function that alters how object and
              +    // array members are serialized, or an array of strings and numbers that
              +    // indicates which properties should be serialized. The optional `width`
              +    // argument may be either a string or number that specifies the indentation
              +    // level of the output.
              +    if (!has("json-stringify")) {
              +      // Internal: A map of control characters and their escaped equivalents.
              +      var Escapes = {
              +        92: "\\\\",
              +        34: '\\"',
              +        8: "\\b",
              +        12: "\\f",
              +        10: "\\n",
              +        13: "\\r",
              +        9: "\\t"
              +      };
              + 
              +      // Internal: Converts `value` into a zero-padded string such that its
              +      // length is at least equal to `width`. The `width` must be <= 6.
              +      var leadingZeroes = "000000";
              +      var toPaddedString = function (width, value) {
              +        // The `|| 0` expression is necessary to work around a bug in
              +        // Opera <= 7.54u2 where `0 == -0`, but `String(-0) !== "0"`.
              +        return (leadingZeroes + (value || 0)).slice(-width);
              +      };
              + 
              +      // Internal: Double-quotes a string `value`, replacing all ASCII control
              +      // characters (characters with code unit values between 0 and 31) with
              +      // their escaped equivalents. This is an implementation of the
              +      // `Quote(value)` operation defined in ES 5.1 section 15.12.3.
              +      var unicodePrefix = "\\u00";
              +      var quote = function (value) {
              +        var result = '"', index = 0, length = value.length, isLarge = length > 10 && charIndexBuggy, symbols;
              +        if (isLarge) {
              +          symbols = value.split("");
              +        }
              +        for (; index < length; index++) {
              +          var charCode = value.charCodeAt(index);
              +          // If the character is a control character, append its Unicode or
              +          // shorthand escape sequence; otherwise, append the character as-is.
              +          switch (charCode) {
              +            case 8: case 9: case 10: case 12: case 13: case 34: case 92:
              +              result += Escapes[charCode];
              +              break;
              +            default:
              +              if (charCode < 32) {
              +                result += unicodePrefix + toPaddedString(2, charCode.toString(16));
              +                break;
              +              }
              +              result += isLarge ? symbols[index] : charIndexBuggy ? value.charAt(index) : value[index];
              +          }
              +        }
              +        return result + '"';
              +      };
              + 
              +      // Internal: Recursively serializes an object. Implements the
              +      // `Str(key, holder)`, `JO(value)`, and `JA(value)` operations.
              +      var serialize = function (property, object, callback, properties, whitespace, indentation, stack) {
              +        var value, className, year, month, date, time, hours, minutes, seconds, milliseconds, results, element, index, length, prefix, hasMembers, result;
              +        try {
              +          // Necessary for host object support.
              +          value = object[property];
              +        } catch (exception) {}
              +        if (typeof value == "object" && value) {
              +          className = getClass.call(value);
              +          if (className == dateClass && !isProperty.call(value, "toJSON")) {
              +            if (value > -1 / 0 && value < 1 / 0) {
              +              // Dates are serialized according to the `Date#toJSON` method
              +              // specified in ES 5.1 section 15.9.5.44. See section 15.9.1.15
              +              // for the ISO 8601 date time string format.
              +              if (getDay) {
              +                // Manually compute the year, month, date, hours, minutes,
              +                // seconds, and milliseconds if the `getUTC*` methods are
              +                // buggy. Adapted from @Yaffle's `date-shim` project.
              +                date = floor(value / 864e5);
              +                for (year = floor(date / 365.2425) + 1970 - 1; getDay(year + 1, 0) <= date; year++);
              +                for (month = floor((date - getDay(year, 0)) / 30.42); getDay(year, month + 1) <= date; month++);
              +                date = 1 + date - getDay(year, month);
              +                // The `time` value specifies the time within the day (see ES
              +                // 5.1 section 15.9.1.2). The formula `(A % B + B) % B` is used
              +                // to compute `A modulo B`, as the `%` operator does not
              +                // correspond to the `modulo` operation for negative numbers.
              +                time = (value % 864e5 + 864e5) % 864e5;
              +                // The hours, minutes, seconds, and milliseconds are obtained by
              +                // decomposing the time within the day. See section 15.9.1.10.
              +                hours = floor(time / 36e5) % 24;
              +                minutes = floor(time / 6e4) % 60;
              +                seconds = floor(time / 1e3) % 60;
              +                milliseconds = time % 1e3;
              +              } else {
              +                year = value.getUTCFullYear();
              +                month = value.getUTCMonth();
              +                date = value.getUTCDate();
              +                hours = value.getUTCHours();
              +                minutes = value.getUTCMinutes();
              +                seconds = value.getUTCSeconds();
              +                milliseconds = value.getUTCMilliseconds();
              +              }
              +              // Serialize extended years correctly.
              +              value = (year <= 0 || year >= 1e4 ? (year < 0 ? "-" : "+") + toPaddedString(6, year < 0 ? -year : year) : toPaddedString(4, year)) +
              +                "-" + toPaddedString(2, month + 1) + "-" + toPaddedString(2, date) +
              +                // Months, dates, hours, minutes, and seconds should have two
              +                // digits; milliseconds should have three.
              +                "T" + toPaddedString(2, hours) + ":" + toPaddedString(2, minutes) + ":" + toPaddedString(2, seconds) +
              +                // Milliseconds are optional in ES 5.0, but required in 5.1.
              +                "." + toPaddedString(3, milliseconds) + "Z";
              +            } else {
              +              value = null;
              +            }
              +          } else if (typeof value.toJSON == "function" && ((className != numberClass && className != stringClass && className != arrayClass) || isProperty.call(value, "toJSON"))) {
              +            // Prototype <= 1.6.1 adds non-standard `toJSON` methods to the
              +            // `Number`, `String`, `Date`, and `Array` prototypes. JSON 3
              +            // ignores all `toJSON` methods on these objects unless they are
              +            // defined directly on an instance.
              +            value = value.toJSON(property);
              +          }
              +        }
              +        if (callback) {
              +          // If a replacement function was provided, call it to obtain the value
              +          // for serialization.
              +          value = callback.call(object, property, value);
              +        }
              +        if (value === null) {
              +          return "null";
              +        }
              +        className = getClass.call(value);
              +        if (className == booleanClass) {
              +          // Booleans are represented literally.
              +          return "" + value;
              +        } else if (className == numberClass) {
              +          // JSON numbers must be finite. `Infinity` and `NaN` are serialized as
              +          // `"null"`.
              +          return value > -1 / 0 && value < 1 / 0 ? "" + value : "null";
              +        } else if (className == stringClass) {
              +          // Strings are double-quoted and escaped.
              +          return quote("" + value);
              +        }
              +        // Recursively serialize objects and arrays.
              +        if (typeof value == "object") {
              +          // Check for cyclic structures. This is a linear search; performance
              +          // is inversely proportional to the number of unique nested objects.
              +          for (length = stack.length; length--;) {
              +            if (stack[length] === value) {
              +              // Cyclic structures cannot be serialized by `JSON.stringify`.
              +              throw TypeError();
              +            }
              +          }
              +          // Add the object to the stack of traversed objects.
              +          stack.push(value);
              +          results = [];
              +          // Save the current indentation level and indent one additional level.
              +          prefix = indentation;
              +          indentation += whitespace;
              +          if (className == arrayClass) {
              +            // Recursively serialize array elements.
              +            for (index = 0, length = value.length; index < length; hasMembers || (hasMembers = true), index++) {
              +              element = serialize(index, value, callback, properties, whitespace, indentation, stack);
              +              results.push(element === undef ? "null" : element);
              +            }
              +            result = hasMembers ? (whitespace ? "[\n" + indentation + results.join(",\n" + indentation) + "\n" + prefix + "]" : ("[" + results.join(",") + "]")) : "[]";
              +          } else {
              +            // Recursively serialize object members. Members are selected from
              +            // either a user-specified list of property names, or the object
              +            // itself.
              +            forEach(properties || value, function (property) {
              +              var element = serialize(property, value, callback, properties, whitespace, indentation, stack);
              +              if (element !== undef) {
              +                // According to ES 5.1 section 15.12.3: "If `gap` {whitespace}
              +                // is not the empty string, let `member` {quote(property) + ":"}
              +                // be the concatenation of `member` and the `space` character."
              +                // The "`space` character" refers to the literal space
              +                // character, not the `space` {width} argument provided to
              +                // `JSON.stringify`.
              +                results.push(quote(property) + ":" + (whitespace ? " " : "") + element);
              +              }
              +              hasMembers || (hasMembers = true);
              +            });
              +            result = hasMembers ? (whitespace ? "{\n" + indentation + results.join(",\n" + indentation) + "\n" + prefix + "}" : ("{" + results.join(",") + "}")) : "{}";
              +          }
              +          // Remove the object from the traversed object stack.
              +          stack.pop();
              +          return result;
              +        }
              +      };
              + 
              +      // Public: `JSON.stringify`. See ES 5.1 section 15.12.3.
              +      JSON3.stringify = function (source, filter, width) {
              +        var whitespace, callback, properties, className;
              +        if (typeof filter == "function" || typeof filter == "object" && filter) {
              +          if ((className = getClass.call(filter)) == functionClass) {
              +            callback = filter;
              +          } else if (className == arrayClass) {
              +            // Convert the property names array into a makeshift set.
              +            properties = {};
              +            for (var index = 0, length = filter.length, value; index < length; value = filter[index++], ((getClass.call(value) == stringClass || getClass.call(value) == numberClass) && (properties[value] = 1)));
              +          }
              +        }
              +        if (width) {
              +          if ((className = getClass.call(width)) == numberClass) {
              +            // Convert the `width` to an integer and create a string containing
              +            // `width` number of space characters.
              +            if ((width -= width % 1) > 0) {
              +              for (whitespace = "", width > 10 && (width = 10); whitespace.length < width; whitespace += " ");
              +            }
              +          } else if (className == stringClass) {
              +            whitespace = width.length <= 10 ? width : width.slice(0, 10);
              +          }
              +        }
              +        // Opera <= 7.54u2 discards the values associated with empty string keys
              +        // (`""`) only if they are used directly within an object member list
              +        // (e.g., `!("" in { "": 1})`).
              +        return serialize("", (value = {}, value[""] = source, value), callback, properties, whitespace, "", []);
              +      };
              +    }
              + 
              +    // Public: Parses a JSON source string.
              +    if (!has("json-parse")) {
              +      var fromCharCode = String.fromCharCode;
              + 
              +      // Internal: A map of escaped control characters and their unescaped
              +      // equivalents.
              +      var Unescapes = {
              +        92: "\\",
              +        34: '"',
              +        47: "/",
              +        98: "\b",
              +        116: "\t",
              +        110: "\n",
              +        102: "\f",
              +        114: "\r"
              +      };
              + 
              +      // Internal: Stores the parser state.
              +      var Index, Source;
              + 
              +      // Internal: Resets the parser state and throws a `SyntaxError`.
              +      var abort = function() {
              +        Index = Source = null;
              +        throw SyntaxError();
              +      };
              + 
              +      // Internal: Returns the next token, or `"$"` if the parser has reached
              +      // the end of the source string. A token may be a string, number, `null`
              +      // literal, or Boolean literal.
              +      var lex = function () {
              +        var source = Source, length = source.length, value, begin, position, isSigned, charCode;
              +        while (Index < length) {
              +          charCode = source.charCodeAt(Index);
              +          switch (charCode) {
              +            case 9: case 10: case 13: case 32:
              +              // Skip whitespace tokens, including tabs, carriage returns, line
              +              // feeds, and space characters.
              +              Index++;
              +              break;
              +            case 123: case 125: case 91: case 93: case 58: case 44:
              +              // Parse a punctuator token (`{`, `}`, `[`, `]`, `:`, or `,`) at
              +              // the current position.
              +              value = charIndexBuggy ? source.charAt(Index) : source[Index];
              +              Index++;
              +              return value;
              +            case 34:
              +              // `"` delimits a JSON string; advance to the next character and
              +              // begin parsing the string. String tokens are prefixed with the
              +              // sentinel `@` character to distinguish them from punctuators and
              +              // end-of-string tokens.
              +              for (value = "@", Index++; Index < length;) {
              +                charCode = source.charCodeAt(Index);
              +                if (charCode < 32) {
              +                  // Unescaped ASCII control characters (those with a code unit
              +                  // less than the space character) are not permitted.
              +                  abort();
              +                } else if (charCode == 92) {
              +                  // A reverse solidus (`\`) marks the beginning of an escaped
              +                  // control character (including `"`, `\`, and `/`) or Unicode
              +                  // escape sequence.
              +                  charCode = source.charCodeAt(++Index);
              +                  switch (charCode) {
              +                    case 92: case 34: case 47: case 98: case 116: case 110: case 102: case 114:
              +                      // Revive escaped control characters.
              +                      value += Unescapes[charCode];
              +                      Index++;
              +                      break;
              +                    case 117:
              +                      // `\u` marks the beginning of a Unicode escape sequence.
              +                      // Advance to the first character and validate the
              +                      // four-digit code point.
              +                      begin = ++Index;
              +                      for (position = Index + 4; Index < position; Index++) {
              +                        charCode = source.charCodeAt(Index);
              +                        // A valid sequence comprises four hexdigits (case-
              +                        // insensitive) that form a single hexadecimal value.
              +                        if (!(charCode >= 48 && charCode <= 57 || charCode >= 97 && charCode <= 102 || charCode >= 65 && charCode <= 70)) {
              +                          // Invalid Unicode escape sequence.
              +                          abort();
              +                        }
              +                      }
              +                      // Revive the escaped character.
              +                      value += fromCharCode("0x" + source.slice(begin, Index));
              +                      break;
              +                    default:
              +                      // Invalid escape sequence.
              +                      abort();
              +                  }
              +                } else {
              +                  if (charCode == 34) {
              +                    // An unescaped double-quote character marks the end of the
              +                    // string.
              +                    break;
              +                  }
              +                  charCode = source.charCodeAt(Index);
              +                  begin = Index;
              +                  // Optimize for the common case where a string is valid.
              +                  while (charCode >= 32 && charCode != 92 && charCode != 34) {
              +                    charCode = source.charCodeAt(++Index);
              +                  }
              +                  // Append the string as-is.
              +                  value += source.slice(begin, Index);
              +                }
              +              }
              +              if (source.charCodeAt(Index) == 34) {
              +                // Advance to the next character and return the revived string.
              +                Index++;
              +                return value;
              +              }
              +              // Unterminated string.
              +              abort();
              +            default:
              +              // Parse numbers and literals.
              +              begin = Index;
              +              // Advance past the negative sign, if one is specified.
              +              if (charCode == 45) {
              +                isSigned = true;
              +                charCode = source.charCodeAt(++Index);
              +              }
              +              // Parse an integer or floating-point value.
              +              if (charCode >= 48 && charCode <= 57) {
              +                // Leading zeroes are interpreted as octal literals.
              +                if (charCode == 48 && ((charCode = source.charCodeAt(Index + 1)), charCode >= 48 && charCode <= 57)) {
              +                  // Illegal octal literal.
              +                  abort();
              +                }
              +                isSigned = false;
              +                // Parse the integer component.
              +                for (; Index < length && ((charCode = source.charCodeAt(Index)), charCode >= 48 && charCode <= 57); Index++);
              +                // Floats cannot contain a leading decimal point; however, this
              +                // case is already accounted for by the parser.
              +                if (source.charCodeAt(Index) == 46) {
              +                  position = ++Index;
              +                  // Parse the decimal component.
              +                  for (; position < length && ((charCode = source.charCodeAt(position)), charCode >= 48 && charCode <= 57); position++);
              +                  if (position == Index) {
              +                    // Illegal trailing decimal.
              +                    abort();
              +                  }
              +                  Index = position;
              +                }
              +                // Parse exponents. The `e` denoting the exponent is
              +                // case-insensitive.
              +                charCode = source.charCodeAt(Index);
              +                if (charCode == 101 || charCode == 69) {
              +                  charCode = source.charCodeAt(++Index);
              +                  // Skip past the sign following the exponent, if one is
              +                  // specified.
              +                  if (charCode == 43 || charCode == 45) {
              +                    Index++;
              +                  }
              +                  // Parse the exponential component.
              +                  for (position = Index; position < length && ((charCode = source.charCodeAt(position)), charCode >= 48 && charCode <= 57); position++);
              +                  if (position == Index) {
              +                    // Illegal empty exponent.
              +                    abort();
              +                  }
              +                  Index = position;
              +                }
              +                // Coerce the parsed value to a JavaScript number.
              +                return +source.slice(begin, Index);
              +              }
              +              // A negative sign may only precede numbers.
              +              if (isSigned) {
              +                abort();
              +              }
              +              // `true`, `false`, and `null` literals.
              +              if (source.slice(Index, Index + 4) == "true") {
              +                Index += 4;
              +                return true;
              +              } else if (source.slice(Index, Index + 5) == "false") {
              +                Index += 5;
              +                return false;
              +              } else if (source.slice(Index, Index + 4) == "null") {
              +                Index += 4;
              +                return null;
              +              }
              +              // Unrecognized token.
              +              abort();
              +          }
              +        }
              +        // Return the sentinel `$` character if the parser has reached the end
              +        // of the source string.
              +        return "$";
              +      };
              + 
              +      // Internal: Parses a JSON `value` token.
              +      var get = function (value) {
              +        var results, hasMembers;
              +        if (value == "$") {
              +          // Unexpected end of input.
              +          abort();
              +        }
              +        if (typeof value == "string") {
              +          if ((charIndexBuggy ? value.charAt(0) : value[0]) == "@") {
              +            // Remove the sentinel `@` character.
              +            return value.slice(1);
              +          }
              +          // Parse object and array literals.
              +          if (value == "[") {
              +            // Parses a JSON array, returning a new JavaScript array.
              +            results = [];
              +            for (;; hasMembers || (hasMembers = true)) {
              +              value = lex();
              +              // A closing square bracket marks the end of the array literal.
              +              if (value == "]") {
              +                break;
              +              }
              +              // If the array literal contains elements, the current token
              +              // should be a comma separating the previous element from the
              +              // next.
              +              if (hasMembers) {
              +                if (value == ",") {
              +                  value = lex();
              +                  if (value == "]") {
              +                    // Unexpected trailing `,` in array literal.
              +                    abort();
              +                  }
              +                } else {
              +                  // A `,` must separate each array element.
              +                  abort();
              +                }
              +              }
              +              // Elisions and leading commas are not permitted.
              +              if (value == ",") {
              +                abort();
              +              }
              +              results.push(get(value));
              +            }
              +            return results;
              +          } else if (value == "{") {
              +            // Parses a JSON object, returning a new JavaScript object.
              +            results = {};
              +            for (;; hasMembers || (hasMembers = true)) {
              +              value = lex();
              +              // A closing curly brace marks the end of the object literal.
              +              if (value == "}") {
              +                break;
              +              }
              +              // If the object literal contains members, the current token
              +              // should be a comma separator.
              +              if (hasMembers) {
              +                if (value == ",") {
              +                  value = lex();
              +                  if (value == "}") {
              +                    // Unexpected trailing `,` in object literal.
              +                    abort();
              +                  }
              +                } else {
              +                  // A `,` must separate each object member.
              +                  abort();
              +                }
              +              }
              +              // Leading commas are not permitted, object property names must be
              +              // double-quoted strings, and a `:` must separate each property
              +              // name and value.
              +              if (value == "," || typeof value != "string" || (charIndexBuggy ? value.charAt(0) : value[0]) != "@" || lex() != ":") {
              +                abort();
              +              }
              +              results[value.slice(1)] = get(lex());
              +            }
              +            return results;
              +          }
              +          // Unexpected token encountered.
              +          abort();
              +        }
              +        return value;
              +      };
              + 
              +      // Internal: Updates a traversed object member.
              +      var update = function(source, property, callback) {
              +        var element = walk(source, property, callback);
              +        if (element === undef) {
              +          delete source[property];
              +        } else {
              +          source[property] = element;
              +        }
              +      };
              + 
              +      // Internal: Recursively traverses a parsed JSON object, invoking the
              +      // `callback` function for each value. This is an implementation of the
              +      // `Walk(holder, name)` operation defined in ES 5.1 section 15.12.2.
              +      var walk = function (source, property, callback) {
              +        var value = source[property], length;
              +        if (typeof value == "object" && value) {
              +          // `forEach` can't be used to traverse an array in Opera <= 8.54
              +          // because its `Object#hasOwnProperty` implementation returns `false`
              +          // for array indices (e.g., `![1, 2, 3].hasOwnProperty("0")`).
              +          if (getClass.call(value) == arrayClass) {
              +            for (length = value.length; length--;) {
              +              update(value, length, callback);
              +            }
              +          } else {
              +            forEach(value, function (property) {
              +              update(value, property, callback);
              +            });
              +          }
              +        }
              +        return callback.call(source, property, value);
              +      };
              + 
              +      // Public: `JSON.parse`. See ES 5.1 section 15.12.2.
              +      JSON3.parse = function (source, callback) {
              +        var result, value;
              +        Index = 0;
              +        Source = "" + source;
              +        result = get(lex());
              +        // If a JSON string contains multiple tokens, it is invalid.
              +        if (lex() != "$") {
              +          abort();
              +        }
              +        // Reset the parser state.
              +        Index = Source = null;
              +        return callback && getClass.call(callback) == functionClass ? walk((value = {}, value[""] = result, value), "", callback) : result;
              +      };
              +    }
              +  }
              + 
              +  // Export for asynchronous module loaders.
              +  Iif (isLoader) {
              +    define(function () {
              +      return JSON3;
              +    });
              +  }
              +}(this));
              + 
              + +
              + + + + + + + + diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/coverage/lcov-report/prettify.css b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/coverage/lcov-report/prettify.css new file mode 100644 index 0000000..b317a7c --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/coverage/lcov-report/prettify.css @@ -0,0 +1 @@ +.pln{color:#000}@media screen{.str{color:#080}.kwd{color:#008}.com{color:#800}.typ{color:#606}.lit{color:#066}.pun,.opn,.clo{color:#660}.tag{color:#008}.atn{color:#606}.atv{color:#080}.dec,.var{color:#606}.fun{color:red}}@media print,projection{.str{color:#060}.kwd{color:#006;font-weight:bold}.com{color:#600;font-style:italic}.typ{color:#404;font-weight:bold}.lit{color:#044}.pun,.opn,.clo{color:#440}.tag{color:#006;font-weight:bold}.atn{color:#404}.atv{color:#060}}pre.prettyprint{padding:2px;border:1px solid #888}ol.linenums{margin-top:0;margin-bottom:0}li.L0,li.L1,li.L2,li.L3,li.L5,li.L6,li.L7,li.L8{list-style-type:none}li.L1,li.L3,li.L5,li.L7,li.L9{background:#eee} diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/coverage/lcov-report/prettify.js b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/coverage/lcov-report/prettify.js new file mode 100644 index 0000000..ef51e03 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/coverage/lcov-report/prettify.js @@ -0,0 +1 @@ +window.PR_SHOULD_USE_CONTINUATION=true;(function(){var h=["break,continue,do,else,for,if,return,while"];var u=[h,"auto,case,char,const,default,double,enum,extern,float,goto,int,long,register,short,signed,sizeof,static,struct,switch,typedef,union,unsigned,void,volatile"];var p=[u,"catch,class,delete,false,import,new,operator,private,protected,public,this,throw,true,try,typeof"];var l=[p,"alignof,align_union,asm,axiom,bool,concept,concept_map,const_cast,constexpr,decltype,dynamic_cast,explicit,export,friend,inline,late_check,mutable,namespace,nullptr,reinterpret_cast,static_assert,static_cast,template,typeid,typename,using,virtual,where"];var x=[p,"abstract,boolean,byte,extends,final,finally,implements,import,instanceof,null,native,package,strictfp,super,synchronized,throws,transient"];var R=[x,"as,base,by,checked,decimal,delegate,descending,dynamic,event,fixed,foreach,from,group,implicit,in,interface,internal,into,is,lock,object,out,override,orderby,params,partial,readonly,ref,sbyte,sealed,stackalloc,string,select,uint,ulong,unchecked,unsafe,ushort,var"];var r="all,and,by,catch,class,else,extends,false,finally,for,if,in,is,isnt,loop,new,no,not,null,of,off,on,or,return,super,then,true,try,unless,until,when,while,yes";var w=[p,"debugger,eval,export,function,get,null,set,undefined,var,with,Infinity,NaN"];var s="caller,delete,die,do,dump,elsif,eval,exit,foreach,for,goto,if,import,last,local,my,next,no,our,print,package,redo,require,sub,undef,unless,until,use,wantarray,while,BEGIN,END";var I=[h,"and,as,assert,class,def,del,elif,except,exec,finally,from,global,import,in,is,lambda,nonlocal,not,or,pass,print,raise,try,with,yield,False,True,None"];var f=[h,"alias,and,begin,case,class,def,defined,elsif,end,ensure,false,in,module,next,nil,not,or,redo,rescue,retry,self,super,then,true,undef,unless,until,when,yield,BEGIN,END"];var H=[h,"case,done,elif,esac,eval,fi,function,in,local,set,then,until"];var A=[l,R,w,s+I,f,H];var e=/^(DIR|FILE|vector|(de|priority_)?queue|list|stack|(const_)?iterator|(multi)?(set|map)|bitset|u?(int|float)\d*)/;var C="str";var z="kwd";var j="com";var O="typ";var G="lit";var L="pun";var F="pln";var m="tag";var E="dec";var J="src";var P="atn";var n="atv";var N="nocode";var M="(?:^^\\.?|[+-]|\\!|\\!=|\\!==|\\#|\\%|\\%=|&|&&|&&=|&=|\\(|\\*|\\*=|\\+=|\\,|\\-=|\\->|\\/|\\/=|:|::|\\;|<|<<|<<=|<=|=|==|===|>|>=|>>|>>=|>>>|>>>=|\\?|\\@|\\[|\\^|\\^=|\\^\\^|\\^\\^=|\\{|\\||\\|=|\\|\\||\\|\\|=|\\~|break|case|continue|delete|do|else|finally|instanceof|return|throw|try|typeof)\\s*";function k(Z){var ad=0;var S=false;var ac=false;for(var V=0,U=Z.length;V122)){if(!(al<65||ag>90)){af.push([Math.max(65,ag)|32,Math.min(al,90)|32])}if(!(al<97||ag>122)){af.push([Math.max(97,ag)&~32,Math.min(al,122)&~32])}}}}af.sort(function(av,au){return(av[0]-au[0])||(au[1]-av[1])});var ai=[];var ap=[NaN,NaN];for(var ar=0;arat[0]){if(at[1]+1>at[0]){an.push("-")}an.push(T(at[1]))}}an.push("]");return an.join("")}function W(al){var aj=al.source.match(new RegExp("(?:\\[(?:[^\\x5C\\x5D]|\\\\[\\s\\S])*\\]|\\\\u[A-Fa-f0-9]{4}|\\\\x[A-Fa-f0-9]{2}|\\\\[0-9]+|\\\\[^ux0-9]|\\(\\?[:!=]|[\\(\\)\\^]|[^\\x5B\\x5C\\(\\)\\^]+)","g"));var ah=aj.length;var an=[];for(var ak=0,am=0;ak=2&&ai==="["){aj[ak]=X(ag)}else{if(ai!=="\\"){aj[ak]=ag.replace(/[a-zA-Z]/g,function(ao){var ap=ao.charCodeAt(0);return"["+String.fromCharCode(ap&~32,ap|32)+"]"})}}}}return aj.join("")}var aa=[];for(var V=0,U=Z.length;V=0;){S[ac.charAt(ae)]=Y}}var af=Y[1];var aa=""+af;if(!ag.hasOwnProperty(aa)){ah.push(af);ag[aa]=null}}ah.push(/[\0-\uffff]/);V=k(ah)})();var X=T.length;var W=function(ah){var Z=ah.sourceCode,Y=ah.basePos;var ad=[Y,F];var af=0;var an=Z.match(V)||[];var aj={};for(var ae=0,aq=an.length;ae=5&&"lang-"===ap.substring(0,5);if(am&&!(ai&&typeof ai[1]==="string")){am=false;ap=J}if(!am){aj[ag]=ap}}var ab=af;af+=ag.length;if(!am){ad.push(Y+ab,ap)}else{var al=ai[1];var ak=ag.indexOf(al);var ac=ak+al.length;if(ai[2]){ac=ag.length-ai[2].length;ak=ac-al.length}var ar=ap.substring(5);B(Y+ab,ag.substring(0,ak),W,ad);B(Y+ab+ak,al,q(ar,al),ad);B(Y+ab+ac,ag.substring(ac),W,ad)}}ah.decorations=ad};return W}function i(T){var W=[],S=[];if(T.tripleQuotedStrings){W.push([C,/^(?:\'\'\'(?:[^\'\\]|\\[\s\S]|\'{1,2}(?=[^\']))*(?:\'\'\'|$)|\"\"\"(?:[^\"\\]|\\[\s\S]|\"{1,2}(?=[^\"]))*(?:\"\"\"|$)|\'(?:[^\\\']|\\[\s\S])*(?:\'|$)|\"(?:[^\\\"]|\\[\s\S])*(?:\"|$))/,null,"'\""])}else{if(T.multiLineStrings){W.push([C,/^(?:\'(?:[^\\\']|\\[\s\S])*(?:\'|$)|\"(?:[^\\\"]|\\[\s\S])*(?:\"|$)|\`(?:[^\\\`]|\\[\s\S])*(?:\`|$))/,null,"'\"`"])}else{W.push([C,/^(?:\'(?:[^\\\'\r\n]|\\.)*(?:\'|$)|\"(?:[^\\\"\r\n]|\\.)*(?:\"|$))/,null,"\"'"])}}if(T.verbatimStrings){S.push([C,/^@\"(?:[^\"]|\"\")*(?:\"|$)/,null])}var Y=T.hashComments;if(Y){if(T.cStyleComments){if(Y>1){W.push([j,/^#(?:##(?:[^#]|#(?!##))*(?:###|$)|.*)/,null,"#"])}else{W.push([j,/^#(?:(?:define|elif|else|endif|error|ifdef|include|ifndef|line|pragma|undef|warning)\b|[^\r\n]*)/,null,"#"])}S.push([C,/^<(?:(?:(?:\.\.\/)*|\/?)(?:[\w-]+(?:\/[\w-]+)+)?[\w-]+\.h|[a-z]\w*)>/,null])}else{W.push([j,/^#[^\r\n]*/,null,"#"])}}if(T.cStyleComments){S.push([j,/^\/\/[^\r\n]*/,null]);S.push([j,/^\/\*[\s\S]*?(?:\*\/|$)/,null])}if(T.regexLiterals){var X=("/(?=[^/*])(?:[^/\\x5B\\x5C]|\\x5C[\\s\\S]|\\x5B(?:[^\\x5C\\x5D]|\\x5C[\\s\\S])*(?:\\x5D|$))+/");S.push(["lang-regex",new RegExp("^"+M+"("+X+")")])}var V=T.types;if(V){S.push([O,V])}var U=(""+T.keywords).replace(/^ | $/g,"");if(U.length){S.push([z,new RegExp("^(?:"+U.replace(/[\s,]+/g,"|")+")\\b"),null])}W.push([F,/^\s+/,null," \r\n\t\xA0"]);S.push([G,/^@[a-z_$][a-z_$@0-9]*/i,null],[O,/^(?:[@_]?[A-Z]+[a-z][A-Za-z_$@0-9]*|\w+_t\b)/,null],[F,/^[a-z_$][a-z_$@0-9]*/i,null],[G,new RegExp("^(?:0x[a-f0-9]+|(?:\\d(?:_\\d+)*\\d*(?:\\.\\d*)?|\\.\\d\\+)(?:e[+\\-]?\\d+)?)[a-z]*","i"),null,"0123456789"],[F,/^\\[\s\S]?/,null],[L,/^.[^\s\w\.$@\'\"\`\/\#\\]*/,null]);return g(W,S)}var K=i({keywords:A,hashComments:true,cStyleComments:true,multiLineStrings:true,regexLiterals:true});function Q(V,ag){var U=/(?:^|\s)nocode(?:\s|$)/;var ab=/\r\n?|\n/;var ac=V.ownerDocument;var S;if(V.currentStyle){S=V.currentStyle.whiteSpace}else{if(window.getComputedStyle){S=ac.defaultView.getComputedStyle(V,null).getPropertyValue("white-space")}}var Z=S&&"pre"===S.substring(0,3);var af=ac.createElement("LI");while(V.firstChild){af.appendChild(V.firstChild)}var W=[af];function ae(al){switch(al.nodeType){case 1:if(U.test(al.className)){break}if("BR"===al.nodeName){ad(al);if(al.parentNode){al.parentNode.removeChild(al)}}else{for(var an=al.firstChild;an;an=an.nextSibling){ae(an)}}break;case 3:case 4:if(Z){var am=al.nodeValue;var aj=am.match(ab);if(aj){var ai=am.substring(0,aj.index);al.nodeValue=ai;var ah=am.substring(aj.index+aj[0].length);if(ah){var ak=al.parentNode;ak.insertBefore(ac.createTextNode(ah),al.nextSibling)}ad(al);if(!ai){al.parentNode.removeChild(al)}}}break}}function ad(ak){while(!ak.nextSibling){ak=ak.parentNode;if(!ak){return}}function ai(al,ar){var aq=ar?al.cloneNode(false):al;var ao=al.parentNode;if(ao){var ap=ai(ao,1);var an=al.nextSibling;ap.appendChild(aq);for(var am=an;am;am=an){an=am.nextSibling;ap.appendChild(am)}}return aq}var ah=ai(ak.nextSibling,0);for(var aj;(aj=ah.parentNode)&&aj.nodeType===1;){ah=aj}W.push(ah)}for(var Y=0;Y=S){ah+=2}if(V>=ap){Z+=2}}}var t={};function c(U,V){for(var S=V.length;--S>=0;){var T=V[S];if(!t.hasOwnProperty(T)){t[T]=U}else{if(window.console){console.warn("cannot override language handler %s",T)}}}}function q(T,S){if(!(T&&t.hasOwnProperty(T))){T=/^\s*]*(?:>|$)/],[j,/^<\!--[\s\S]*?(?:-\->|$)/],["lang-",/^<\?([\s\S]+?)(?:\?>|$)/],["lang-",/^<%([\s\S]+?)(?:%>|$)/],[L,/^(?:<[%?]|[%?]>)/],["lang-",/^]*>([\s\S]+?)<\/xmp\b[^>]*>/i],["lang-js",/^]*>([\s\S]*?)(<\/script\b[^>]*>)/i],["lang-css",/^]*>([\s\S]*?)(<\/style\b[^>]*>)/i],["lang-in.tag",/^(<\/?[a-z][^<>]*>)/i]]),["default-markup","htm","html","mxml","xhtml","xml","xsl"]);c(g([[F,/^[\s]+/,null," \t\r\n"],[n,/^(?:\"[^\"]*\"?|\'[^\']*\'?)/,null,"\"'"]],[[m,/^^<\/?[a-z](?:[\w.:-]*\w)?|\/?>$/i],[P,/^(?!style[\s=]|on)[a-z](?:[\w:-]*\w)?/i],["lang-uq.val",/^=\s*([^>\'\"\s]*(?:[^>\'\"\s\/]|\/(?=\s)))/],[L,/^[=<>\/]+/],["lang-js",/^on\w+\s*=\s*\"([^\"]+)\"/i],["lang-js",/^on\w+\s*=\s*\'([^\']+)\'/i],["lang-js",/^on\w+\s*=\s*([^\"\'>\s]+)/i],["lang-css",/^style\s*=\s*\"([^\"]+)\"/i],["lang-css",/^style\s*=\s*\'([^\']+)\'/i],["lang-css",/^style\s*=\s*([^\"\'>\s]+)/i]]),["in.tag"]);c(g([],[[n,/^[\s\S]+/]]),["uq.val"]);c(i({keywords:l,hashComments:true,cStyleComments:true,types:e}),["c","cc","cpp","cxx","cyc","m"]);c(i({keywords:"null,true,false"}),["json"]);c(i({keywords:R,hashComments:true,cStyleComments:true,verbatimStrings:true,types:e}),["cs"]);c(i({keywords:x,cStyleComments:true}),["java"]);c(i({keywords:H,hashComments:true,multiLineStrings:true}),["bsh","csh","sh"]);c(i({keywords:I,hashComments:true,multiLineStrings:true,tripleQuotedStrings:true}),["cv","py"]);c(i({keywords:s,hashComments:true,multiLineStrings:true,regexLiterals:true}),["perl","pl","pm"]);c(i({keywords:f,hashComments:true,multiLineStrings:true,regexLiterals:true}),["rb"]);c(i({keywords:w,cStyleComments:true,regexLiterals:true}),["js"]);c(i({keywords:r,hashComments:3,cStyleComments:true,multilineStrings:true,tripleQuotedStrings:true,regexLiterals:true}),["coffee"]);c(g([],[[C,/^[\s\S]+/]]),["regex"]);function d(V){var U=V.langExtension;try{var S=a(V.sourceNode);var T=S.sourceCode;V.sourceCode=T;V.spans=S.spans;V.basePos=0;q(U,T)(V);D(V)}catch(W){if("console" in window){console.log(W&&W.stack?W.stack:W)}}}function y(W,V,U){var S=document.createElement("PRE");S.innerHTML=W;if(U){Q(S,U)}var T={langExtension:V,numberLines:U,sourceNode:S};d(T);return S.innerHTML}function b(ad){function Y(af){return document.getElementsByTagName(af)}var ac=[Y("pre"),Y("code"),Y("xmp")];var T=[];for(var aa=0;aa=0){var ah=ai.match(ab);var am;if(!ah&&(am=o(aj))&&"CODE"===am.tagName){ah=am.className.match(ab)}if(ah){ah=ah[1]}var al=false;for(var ak=aj.parentNode;ak;ak=ak.parentNode){if((ak.tagName==="pre"||ak.tagName==="code"||ak.tagName==="xmp")&&ak.className&&ak.className.indexOf("prettyprint")>=0){al=true;break}}if(!al){var af=aj.className.match(/\blinenums\b(?::(\d+))?/);af=af?af[1]&&af[1].length?+af[1]:true:false;if(af){Q(aj,af)}S={langExtension:ah,sourceNode:aj,numberLines:af};d(S)}}}if(X]*(?:>|$)/],[PR.PR_COMMENT,/^<\!--[\s\S]*?(?:-\->|$)/],[PR.PR_PUNCTUATION,/^(?:<[%?]|[%?]>)/],["lang-",/^<\?([\s\S]+?)(?:\?>|$)/],["lang-",/^<%([\s\S]+?)(?:%>|$)/],["lang-",/^]*>([\s\S]+?)<\/xmp\b[^>]*>/i],["lang-handlebars",/^]*type\s*=\s*['"]?text\/x-handlebars-template['"]?\b[^>]*>([\s\S]*?)(<\/script\b[^>]*>)/i],["lang-js",/^]*>([\s\S]*?)(<\/script\b[^>]*>)/i],["lang-css",/^]*>([\s\S]*?)(<\/style\b[^>]*>)/i],["lang-in.tag",/^(<\/?[a-z][^<>]*>)/i],[PR.PR_DECLARATION,/^{{[#^>/]?\s*[\w.][^}]*}}/],[PR.PR_DECLARATION,/^{{&?\s*[\w.][^}]*}}/],[PR.PR_DECLARATION,/^{{{>?\s*[\w.][^}]*}}}/],[PR.PR_COMMENT,/^{{![^}]*}}/]]),["handlebars","hbs"]);PR.registerLangHandler(PR.createSimpleLexer([[PR.PR_PLAIN,/^[ \t\r\n\f]+/,null," \t\r\n\f"]],[[PR.PR_STRING,/^\"(?:[^\n\r\f\\\"]|\\(?:\r\n?|\n|\f)|\\[\s\S])*\"/,null],[PR.PR_STRING,/^\'(?:[^\n\r\f\\\']|\\(?:\r\n?|\n|\f)|\\[\s\S])*\'/,null],["lang-css-str",/^url\(([^\)\"\']*)\)/i],[PR.PR_KEYWORD,/^(?:url|rgb|\!important|@import|@page|@media|@charset|inherit)(?=[^\-\w]|$)/i,null],["lang-css-kw",/^(-?(?:[_a-z]|(?:\\[0-9a-f]+ ?))(?:[_a-z0-9\-]|\\(?:\\[0-9a-f]+ ?))*)\s*:/i],[PR.PR_COMMENT,/^\/\*[^*]*\*+(?:[^\/*][^*]*\*+)*\//],[PR.PR_COMMENT,/^(?:)/],[PR.PR_LITERAL,/^(?:\d+|\d*\.\d+)(?:%|[a-z]+)?/i],[PR.PR_LITERAL,/^#(?:[0-9a-f]{3}){1,2}/i],[PR.PR_PLAIN,/^-?(?:[_a-z]|(?:\\[\da-f]+ ?))(?:[_a-z\d\-]|\\(?:\\[\da-f]+ ?))*/i],[PR.PR_PUNCTUATION,/^[^\s\w\'\"]+/]]),["css"]);PR.registerLangHandler(PR.createSimpleLexer([],[[PR.PR_KEYWORD,/^-?(?:[_a-z]|(?:\\[\da-f]+ ?))(?:[_a-z\d\-]|\\(?:\\[\da-f]+ ?))*/i]]),["css-kw"]);PR.registerLangHandler(PR.createSimpleLexer([],[[PR.PR_STRING,/^[^\)\"\']+/]]),["css-str"]); diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/coverage/lcov.info b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/coverage/lcov.info new file mode 100644 index 0000000..9a4d72d --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/coverage/lcov.info @@ -0,0 +1,2035 @@ +TN: +SF:/Users/kit/Dropbox/Projects/json3/vendor/spec/lib/spec.js +FN:11,(anonymous_1) +FN:20,(anonymous_2) +FN:21,noConflict +FN:31,(anonymous_4) +FN:70,(anonymous_5) +FN:78,hasKey +FN:86,hasKey +FN:102,hasKey +FN:117,(anonymous_9) +FN:123,Properties +FN:145,forOwn +FN:169,forOwn +FN:188,forOwn +FN:210,(anonymous_14) +FN:213,eq +FN:289,(anonymous_16) +FN:297,(anonymous_17) +FN:311,equals +FN:328,forEach +FN:343,(anonymous_20) +FN:347,defer +FN:354,run +FN:361,defer +FN:362,run +FN:370,defer +FN:372,run +FN:387,(anonymous_27) +FN:395,defer +FN:404,rethrow +FN:405,(anonymous_30) +FN:418,Events +FN:429,addListener +FN:431,(anonymous_33) +FN:454,removeListener +FN:459,(anonymous_35) +FN:483,emit +FN:531,Suite +FN:547,(anonymous_38) +FN:555,shuffle +FN:567,addTest +FN:575,index +FN:594,onSuiteEvent +FN:622,runSuite +FN:645,Test +FN:668,onTestEvent +FN:697,assert +FN:698,assertion +FN:710,runTest +FN:720,ok +FN:735,notOk +FN:742,assertEqual +FN:748,assertNotEqual +FN:754,assertStrictEqual +FN:760,assertStrictNotEqual +FN:770,assertNotDeepEqual +FN:776,assertError +FN:793,assertNoError +FN:806,done +FNF:58 +FNH:38 +FNDA:1,(anonymous_1) +FNDA:0,(anonymous_2) +FNDA:0,noConflict +FNDA:1,(anonymous_4) +FNDA:1,(anonymous_5) +FNDA:5538,hasKey +FNDA:0,hasKey +FNDA:0,hasKey +FNDA:1,(anonymous_9) +FNDA:1,Properties +FNDA:0,forOwn +FNDA:0,forOwn +FNDA:26,forOwn +FNDA:1,(anonymous_14) +FNDA:102,eq +FNDA:15,(anonymous_16) +FNDA:15,(anonymous_17) +FNDA:51,equals +FNDA:49,forEach +FNDA:1,(anonymous_20) +FNDA:0,defer +FNDA:0,run +FNDA:0,defer +FNDA:0,run +FNDA:0,defer +FNDA:0,run +FNDA:0,(anonymous_27) +FNDA:11,defer +FNDA:0,rethrow +FNDA:0,(anonymous_30) +FNDA:14,Events +FNDA:34,addListener +FNDA:34,(anonymous_33) +FNDA:11,removeListener +FNDA:11,(anonymous_35) +FNDA:594,emit +FNDA:1,Suite +FNDA:1,(anonymous_38) +FNDA:1,shuffle +FNDA:11,addTest +FNDA:12,index +FNDA:296,onSuiteEvent +FNDA:1,runSuite +FNDA:11,Test +FNDA:296,onTestEvent +FNDA:6,assert +FNDA:117,assertion +FNDA:11,runTest +FNDA:274,ok +FNDA:0,notOk +FNDA:15,assertEqual +FNDA:0,assertNotEqual +FNDA:51,assertStrictEqual +FNDA:0,assertStrictNotEqual +FNDA:0,assertNotDeepEqual +FNDA:156,assertError +FNDA:0,assertNoError +FNDA:11,done +DA:11,1 +DA:12,1 +DA:14,0 +DA:17,1 +DA:21,1 +DA:22,0 +DA:24,0 +DA:25,0 +DA:27,0 +DA:35,1 +DA:41,1 +DA:71,1 +DA:73,1 +DA:74,1 +DA:76,1 +DA:78,1 +DA:79,5538 +DA:80,0 +DA:82,5538 +DA:84,0 +DA:86,0 +DA:87,0 +DA:88,0 +DA:89,0 +DA:93,0 +DA:94,0 +DA:96,0 +DA:97,0 +DA:102,0 +DA:103,0 +DA:104,0 +DA:106,0 +DA:107,0 +DA:110,1 +DA:118,1 +DA:123,1 +DA:124,1 +DA:126,1 +DA:129,1 +DA:130,1 +DA:132,1 +DA:133,1 +DA:136,1 +DA:139,1 +DA:141,0 +DA:144,0 +DA:145,0 +DA:146,0 +DA:147,0 +DA:148,0 +DA:150,0 +DA:151,0 +DA:154,0 +DA:155,0 +DA:159,0 +DA:160,0 +DA:161,0 +DA:162,0 +DA:166,1 +DA:168,0 +DA:169,0 +DA:170,0 +DA:171,0 +DA:172,0 +DA:175,0 +DA:176,0 +DA:177,0 +DA:181,0 +DA:182,0 +DA:188,1 +DA:189,26 +DA:190,26 +DA:191,0 +DA:193,26 +DA:194,26 +DA:195,30 +DA:196,0 +DA:201,26 +DA:202,0 +DA:206,1 +DA:213,1 +DA:214,102 +DA:216,102 +DA:219,72 +DA:222,30 +DA:223,0 +DA:225,30 +DA:226,30 +DA:227,0 +DA:229,30 +DA:234,0 +DA:236,0 +DA:237,0 +DA:240,0 +DA:246,0 +DA:250,0 +DA:256,30 +DA:257,0 +DA:263,30 +DA:264,22 +DA:265,0 +DA:269,30 +DA:270,30 +DA:272,30 +DA:274,17 +DA:275,17 +DA:276,17 +DA:278,17 +DA:280,36 +DA:281,0 +DA:286,13 +DA:288,13 +DA:289,13 +DA:291,15 +DA:293,15 +DA:296,13 +DA:297,13 +DA:298,15 +DA:299,0 +DA:302,13 +DA:306,30 +DA:307,30 +DA:311,1 +DA:312,51 +DA:315,51 +DA:316,0 +DA:319,51 +DA:322,1 +DA:329,49 +DA:330,49 +DA:331,0 +DA:333,49 +DA:334,114 +DA:335,0 +DA:338,49 +DA:344,1 +DA:346,1 +DA:347,1 +DA:354,1 +DA:355,0 +DA:357,0 +DA:360,0 +DA:361,0 +DA:362,1 +DA:363,0 +DA:365,0 +DA:369,0 +DA:370,0 +DA:371,0 +DA:372,1 +DA:376,0 +DA:377,0 +DA:382,0 +DA:386,0 +DA:387,0 +DA:388,0 +DA:390,0 +DA:394,1 +DA:395,1 +DA:396,11 +DA:399,1 +DA:404,1 +DA:405,0 +DA:406,0 +DA:417,1 +DA:418,1 +DA:419,14 +DA:428,1 +DA:429,1 +DA:430,34 +DA:431,34 +DA:432,34 +DA:433,34 +DA:435,34 +DA:436,34 +DA:438,34 +DA:444,34 +DA:453,1 +DA:454,1 +DA:455,11 +DA:457,0 +DA:458,11 +DA:459,11 +DA:460,11 +DA:461,11 +DA:463,11 +DA:464,11 +DA:466,11 +DA:467,11 +DA:468,22 +DA:469,11 +DA:476,11 +DA:482,1 +DA:483,1 +DA:484,594 +DA:486,594 +DA:487,13 +DA:489,594 +DA:491,594 +DA:492,298 +DA:495,594 +DA:496,594 +DA:497,0 +DA:498,0 +DA:500,0 +DA:501,0 +DA:503,0 +DA:508,594 +DA:509,594 +DA:510,594 +DA:511,890 +DA:512,890 +DA:514,0 +DA:518,594 +DA:528,1 +DA:531,1 +DA:532,1 +DA:533,1 +DA:534,1 +DA:536,1 +DA:540,1 +DA:543,1 +DA:544,1 +DA:547,1 +DA:548,1 +DA:549,8 +DA:554,1 +DA:555,1 +DA:556,1 +DA:557,11 +DA:558,11 +DA:559,11 +DA:560,11 +DA:562,1 +DA:566,1 +DA:567,1 +DA:568,11 +DA:569,11 +DA:574,1 +DA:575,1 +DA:576,12 +DA:577,12 +DA:578,12 +DA:579,0 +DA:581,12 +DA:582,11 +DA:583,11 +DA:584,11 +DA:587,1 +DA:593,1 +DA:594,1 +DA:595,296 +DA:597,296 +DA:598,296 +DA:601,274 +DA:602,274 +DA:604,0 +DA:605,0 +DA:608,11 +DA:609,11 +DA:610,10 +DA:612,10 +DA:615,1 +DA:621,1 +DA:622,1 +DA:624,1 +DA:625,1 +DA:627,1 +DA:629,1 +DA:630,1 +DA:632,1 +DA:635,0 +DA:637,1 +DA:644,1 +DA:645,1 +DA:646,11 +DA:647,11 +DA:648,0 +DA:649,0 +DA:651,11 +DA:652,11 +DA:654,11 +DA:656,11 +DA:660,1 +DA:661,1 +DA:664,1 +DA:667,1 +DA:668,1 +DA:669,296 +DA:670,296 +DA:672,11 +DA:673,11 +DA:675,274 +DA:676,274 +DA:678,0 +DA:679,0 +DA:681,11 +DA:683,11 +DA:684,0 +DA:696,1 +DA:697,1 +DA:698,1 +DA:699,117 +DA:705,6 +DA:709,1 +DA:710,1 +DA:711,11 +DA:713,11 +DA:714,11 +DA:719,1 +DA:720,1 +DA:721,274 +DA:722,157 +DA:729,274 +DA:730,274 +DA:734,1 +DA:735,1 +DA:736,0 +DA:741,1 +DA:742,1 +DA:743,15 +DA:747,1 +DA:748,1 +DA:749,0 +DA:753,1 +DA:754,1 +DA:755,51 +DA:759,1 +DA:760,1 +DA:761,0 +DA:766,1 +DA:769,1 +DA:770,1 +DA:771,0 +DA:775,1 +DA:776,1 +DA:777,156 +DA:779,156 +DA:780,0 +DA:781,0 +DA:783,156 +DA:784,156 +DA:786,156 +DA:788,156 +DA:792,1 +DA:793,1 +DA:794,0 +DA:795,0 +DA:796,0 +DA:798,0 +DA:800,0 +DA:805,1 +DA:806,1 +DA:807,11 +DA:812,1 +LF:355 +LH:248 +BRDA:12,1,0,0 +BRDA:12,1,1,1 +BRDA:12,2,0,1 +BRDA:12,2,1,0 +BRDA:17,3,0,1 +BRDA:17,3,1,1 +BRDA:17,3,2,0 +BRDA:59,4,0,1 +BRDA:59,4,1,1 +BRDA:59,4,2,1 +BRDA:63,5,0,1 +BRDA:63,5,1,0 +BRDA:63,5,2,0 +BRDA:63,5,3,0 +BRDA:76,6,0,1 +BRDA:76,6,1,0 +BRDA:79,7,0,0 +BRDA:79,7,1,5538 +BRDA:84,8,0,0 +BRDA:84,8,1,0 +BRDA:88,9,0,0 +BRDA:88,9,1,0 +BRDA:103,10,0,0 +BRDA:103,10,1,0 +BRDA:106,11,0,0 +BRDA:106,11,1,0 +BRDA:107,12,0,0 +BRDA:107,12,1,0 +BRDA:107,13,0,0 +BRDA:107,13,1,0 +BRDA:132,14,0,1 +BRDA:132,14,1,0 +BRDA:139,15,0,0 +BRDA:139,15,1,1 +BRDA:147,16,0,0 +BRDA:147,16,1,0 +BRDA:154,17,0,0 +BRDA:154,17,1,0 +BRDA:154,18,0,0 +BRDA:154,18,1,0 +BRDA:154,18,2,0 +BRDA:154,19,0,0 +BRDA:154,19,1,0 +BRDA:161,20,0,0 +BRDA:161,20,1,0 +BRDA:161,21,0,0 +BRDA:161,21,1,0 +BRDA:166,22,0,0 +BRDA:166,22,1,1 +BRDA:171,23,0,0 +BRDA:171,23,1,0 +BRDA:181,24,0,0 +BRDA:181,24,1,0 +BRDA:181,25,0,0 +BRDA:181,25,1,0 +BRDA:181,25,2,0 +BRDA:181,25,3,0 +BRDA:181,25,4,0 +BRDA:181,26,0,0 +BRDA:181,26,1,0 +BRDA:190,27,0,0 +BRDA:190,27,1,26 +BRDA:195,28,0,0 +BRDA:195,28,1,30 +BRDA:195,29,0,30 +BRDA:195,29,1,30 +BRDA:195,29,2,30 +BRDA:195,29,3,30 +BRDA:195,30,0,30 +BRDA:195,30,1,0 +BRDA:201,31,0,0 +BRDA:201,31,1,26 +BRDA:201,32,0,26 +BRDA:201,32,1,26 +BRDA:216,33,0,72 +BRDA:216,33,1,30 +BRDA:219,34,0,72 +BRDA:219,34,1,15 +BRDA:222,35,0,0 +BRDA:222,35,1,30 +BRDA:226,36,0,0 +BRDA:226,36,1,30 +BRDA:229,37,0,0 +BRDA:229,37,1,0 +BRDA:229,37,2,0 +BRDA:229,37,3,0 +BRDA:229,37,4,0 +BRDA:240,38,0,0 +BRDA:240,38,1,0 +BRDA:240,39,0,0 +BRDA:240,39,1,0 +BRDA:250,40,0,0 +BRDA:250,40,1,0 +BRDA:250,40,2,0 +BRDA:250,40,3,0 +BRDA:250,40,4,0 +BRDA:256,41,0,0 +BRDA:256,41,1,30 +BRDA:256,42,0,30 +BRDA:256,42,1,30 +BRDA:264,43,0,0 +BRDA:264,43,1,22 +BRDA:272,44,0,17 +BRDA:272,44,1,13 +BRDA:276,45,0,17 +BRDA:276,45,1,0 +BRDA:280,46,0,0 +BRDA:280,46,1,36 +BRDA:280,47,0,36 +BRDA:280,47,1,36 +BRDA:293,48,0,15 +BRDA:293,48,1,15 +BRDA:296,49,0,13 +BRDA:296,49,1,0 +BRDA:298,50,0,0 +BRDA:298,50,1,15 +BRDA:315,51,0,0 +BRDA:315,51,1,51 +BRDA:330,52,0,0 +BRDA:330,52,1,49 +BRDA:334,53,0,0 +BRDA:334,53,1,114 +BRDA:346,54,0,1 +BRDA:346,54,1,0 +BRDA:360,55,0,0 +BRDA:360,55,1,0 +BRDA:369,56,0,0 +BRDA:369,56,1,0 +BRDA:394,57,0,1 +BRDA:394,57,1,0 +BRDA:394,58,0,1 +BRDA:394,58,1,1 +BRDA:430,59,0,34 +BRDA:430,59,1,0 +BRDA:430,60,0,34 +BRDA:430,60,1,34 +BRDA:432,61,0,34 +BRDA:432,61,1,11 +BRDA:432,62,0,11 +BRDA:432,62,1,23 +BRDA:440,63,0,11 +BRDA:440,63,1,23 +BRDA:455,64,0,0 +BRDA:455,64,1,11 +BRDA:458,65,0,11 +BRDA:458,65,1,0 +BRDA:460,66,0,11 +BRDA:460,66,1,11 +BRDA:461,67,0,11 +BRDA:461,67,1,0 +BRDA:464,68,0,11 +BRDA:464,68,1,0 +BRDA:466,69,0,11 +BRDA:466,69,1,11 +BRDA:467,70,0,33 +BRDA:467,70,1,33 +BRDA:468,71,0,11 +BRDA:468,71,1,11 +BRDA:468,72,0,22 +BRDA:468,72,1,22 +BRDA:468,72,2,11 +BRDA:468,72,3,11 +BRDA:468,72,4,11 +BRDA:486,73,0,13 +BRDA:486,73,1,581 +BRDA:486,74,0,594 +BRDA:486,74,1,581 +BRDA:489,75,0,594 +BRDA:489,75,1,594 +BRDA:491,76,0,298 +BRDA:491,76,1,296 +BRDA:495,77,0,594 +BRDA:495,77,1,594 +BRDA:495,77,2,594 +BRDA:496,78,0,0 +BRDA:496,78,1,594 +BRDA:496,79,0,594 +BRDA:496,79,1,0 +BRDA:497,80,0,0 +BRDA:497,80,1,0 +BRDA:498,81,0,0 +BRDA:498,81,1,0 +BRDA:501,82,0,0 +BRDA:501,82,1,0 +BRDA:501,82,2,0 +BRDA:508,83,0,594 +BRDA:508,83,1,0 +BRDA:509,84,0,594 +BRDA:509,84,1,594 +BRDA:510,85,0,1484 +BRDA:510,85,1,1484 +BRDA:512,86,0,890 +BRDA:512,86,1,890 +BRDA:512,86,2,298 +BRDA:533,87,0,1 +BRDA:533,87,1,0 +BRDA:577,88,0,12 +BRDA:577,88,1,1 +BRDA:578,89,0,0 +BRDA:578,89,1,12 +BRDA:582,90,0,11 +BRDA:582,90,1,11 +BRDA:583,91,0,11 +BRDA:583,91,1,0 +BRDA:583,92,0,11 +BRDA:583,92,1,11 +BRDA:583,92,2,11 +BRDA:598,93,0,274 +BRDA:598,93,1,0 +BRDA:598,93,2,11 +BRDA:609,94,0,10 +BRDA:609,94,1,1 +BRDA:629,95,0,1 +BRDA:629,95,1,0 +BRDA:647,96,0,0 +BRDA:647,96,1,11 +BRDA:647,97,0,11 +BRDA:647,97,1,11 +BRDA:651,98,0,11 +BRDA:651,98,1,0 +BRDA:670,99,0,11 +BRDA:670,99,1,274 +BRDA:670,99,2,0 +BRDA:670,99,3,11 +BRDA:683,100,0,0 +BRDA:683,100,1,11 +BRDA:683,101,0,11 +BRDA:683,101,1,0 +BRDA:683,101,2,11 +BRDA:702,102,0,0 +BRDA:702,102,1,117 +BRDA:721,103,0,157 +BRDA:721,103,1,117 +BRDA:725,104,0,0 +BRDA:725,104,1,157 +BRDA:729,105,0,274 +BRDA:729,105,1,0 +BRDA:736,106,0,0 +BRDA:736,106,1,0 +BRDA:779,107,0,0 +BRDA:779,107,1,156 +BRDA:779,108,0,156 +BRDA:779,108,1,0 +BRDA:786,109,0,156 +BRDA:786,109,1,156 +BRDA:786,109,2,156 +BRDA:788,110,0,0 +BRDA:788,110,1,156 +BRDA:800,111,0,0 +BRDA:800,111,1,0 +BRF:250 +BRH:133 +end_of_record +TN: +SF:/Users/kit/Dropbox/Projects/json3/vendor/spec/lib/newton.js +FN:8,(anonymous_1) +FN:26,(anonymous_2) +FN:42,(anonymous_3) +FN:43,noConflict +FN:52,(anonymous_5) +FN:61,(anonymous_6) +FN:62,stringify +FN:68,toPaddedString +FN:85,quote +FN:99,serialize +FN:155,(anonymous_11) +FN:172,all +FN:174,(anonymous_13) +FN:181,toQueryPair +FN:200,serializeQuery +FN:202,(anonymous_16) +FN:204,(anonymous_17) +FN:223,parseQuery +FN:256,isEmpty +FN:275,(anonymous_20) +FN:283,substitute +FN:333,createConsole +FN:334,onEvent +FN:359,createTAP +FN:362,description +FN:365,onEvent +FN:391,onClick +FN:401,(anonymous_28) +FN:405,(anonymous_29) +FN:427,serializeAttribute +FN:433,buildNode +FN:458,(anonymous_32) +FN:464,(anonymous_33) +FN:470,(anonymous_34) +FN:480,clearElement +FN:489,createReport +FN:490,onEvent +FNF:37 +FNH:6 +FNDA:1,(anonymous_1) +FNDA:0,(anonymous_2) +FNDA:0,(anonymous_3) +FNDA:0,noConflict +FNDA:1,(anonymous_5) +FNDA:1,(anonymous_6) +FNDA:0,stringify +FNDA:0,toPaddedString +FNDA:0,quote +FNDA:0,serialize +FNDA:0,(anonymous_11) +FNDA:0,all +FNDA:0,(anonymous_13) +FNDA:0,toQueryPair +FNDA:0,serializeQuery +FNDA:0,(anonymous_16) +FNDA:0,(anonymous_17) +FNDA:0,parseQuery +FNDA:0,isEmpty +FNDA:0,(anonymous_20) +FNDA:298,substitute +FNDA:1,createConsole +FNDA:298,onEvent +FNDA:0,createTAP +FNDA:0,description +FNDA:0,onEvent +FNDA:0,onClick +FNDA:0,(anonymous_28) +FNDA:0,(anonymous_29) +FNDA:0,serializeAttribute +FNDA:0,buildNode +FNDA:0,(anonymous_32) +FNDA:0,(anonymous_33) +FNDA:0,(anonymous_34) +FNDA:0,clearElement +FNDA:0,createReport +FNDA:0,onEvent +DA:8,1 +DA:10,1 +DA:24,1 +DA:26,0 +DA:27,0 +DA:29,1 +DA:31,1 +DA:33,1 +DA:35,1 +DA:38,0 +DA:39,0 +DA:41,0 +DA:43,1 +DA:44,0 +DA:45,0 +DA:46,0 +DA:48,0 +DA:56,1 +DA:62,1 +DA:63,0 +DA:68,1 +DA:69,0 +DA:73,1 +DA:85,1 +DA:86,0 +DA:87,0 +DA:90,0 +DA:95,0 +DA:99,1 +DA:100,0 +DA:101,0 +DA:102,0 +DA:104,0 +DA:105,0 +DA:110,0 +DA:113,0 +DA:115,0 +DA:116,0 +DA:121,0 +DA:123,0 +DA:131,0 +DA:134,0 +DA:138,0 +DA:139,0 +DA:140,0 +DA:144,0 +DA:145,0 +DA:146,0 +DA:148,0 +DA:149,0 +DA:150,0 +DA:153,0 +DA:155,0 +DA:157,0 +DA:159,0 +DA:162,0 +DA:164,0 +DA:167,1 +DA:173,0 +DA:174,0 +DA:175,0 +DA:177,0 +DA:182,0 +DA:183,0 +DA:184,0 +DA:186,0 +DA:190,0 +DA:201,0 +DA:202,0 +DA:203,0 +DA:204,0 +DA:205,0 +DA:206,0 +DA:207,0 +DA:210,0 +DA:211,0 +DA:214,0 +DA:224,0 +DA:226,0 +DA:227,0 +DA:229,0 +DA:230,0 +DA:231,0 +DA:232,0 +DA:233,0 +DA:234,0 +DA:235,0 +DA:236,0 +DA:237,0 +DA:240,0 +DA:242,0 +DA:243,0 +DA:244,0 +DA:246,0 +DA:248,0 +DA:252,0 +DA:257,0 +DA:258,0 +DA:259,0 +DA:261,0 +DA:265,0 +DA:266,0 +DA:270,0 +DA:273,0 +DA:275,0 +DA:276,0 +DA:284,298 +DA:285,298 +DA:286,298 +DA:287,0 +DA:289,298 +DA:290,4294 +DA:291,4294 +DA:292,322 +DA:293,322 +DA:295,0 +DA:297,322 +DA:299,322 +DA:303,24 +DA:304,24 +DA:307,0 +DA:308,0 +DA:311,0 +DA:312,0 +DA:315,298 +DA:319,0 +DA:322,322 +DA:324,322 +DA:326,3972 +DA:329,298 +DA:334,1 +DA:335,298 +DA:337,1 +DA:338,1 +DA:340,11 +DA:341,11 +DA:343,274 +DA:344,274 +DA:346,0 +DA:347,0 +DA:349,11 +DA:350,11 +DA:352,1 +DA:355,1 +DA:360,0 +DA:362,1 +DA:363,0 +DA:365,1 +DA:366,0 +DA:368,0 +DA:369,0 +DA:371,0 +DA:372,0 +DA:373,0 +DA:374,0 +DA:376,0 +DA:377,0 +DA:378,0 +DA:379,0 +DA:380,0 +DA:383,0 +DA:389,1 +DA:391,0 +DA:393,0 +DA:394,0 +DA:395,0 +DA:401,0 +DA:405,0 +DA:406,0 +DA:407,0 +DA:408,0 +DA:409,0 +DA:411,0 +DA:412,0 +DA:428,0 +DA:429,0 +DA:434,0 +DA:435,0 +DA:436,0 +DA:437,0 +DA:439,0 +DA:442,0 +DA:443,0 +DA:444,0 +DA:445,0 +DA:446,0 +DA:448,0 +DA:449,0 +DA:450,0 +DA:452,0 +DA:454,0 +DA:456,0 +DA:457,0 +DA:458,0 +DA:460,0 +DA:462,0 +DA:464,0 +DA:465,0 +DA:469,0 +DA:470,0 +DA:471,0 +DA:474,0 +DA:476,0 +DA:480,0 +DA:481,0 +DA:482,0 +DA:484,0 +DA:489,0 +DA:490,1 +DA:491,0 +DA:492,0 +DA:493,0 +DA:495,0 +DA:496,0 +DA:498,0 +DA:502,0 +DA:504,0 +DA:513,0 +DA:517,0 +DA:520,0 +DA:523,0 +DA:524,0 +DA:528,0 +DA:530,0 +DA:532,0 +DA:533,0 +DA:537,0 +DA:539,0 +DA:540,0 +DA:543,0 +DA:566,0 +DA:569,0 +DA:574,1 +DA:576,1 +LF:234 +LH:50 +BRDA:10,1,0,1 +BRDA:10,1,1,0 +BRDA:11,2,0,1 +BRDA:11,2,1,1 +BRDA:11,2,2,1 +BRDA:11,2,3,1 +BRDA:14,3,0,1 +BRDA:14,3,1,0 +BRDA:14,3,2,0 +BRDA:15,4,0,1 +BRDA:15,4,1,1 +BRDA:15,4,2,0 +BRDA:24,5,0,0 +BRDA:24,5,1,1 +BRDA:29,6,0,1 +BRDA:29,6,1,0 +BRDA:35,7,0,1 +BRDA:35,7,1,0 +BRDA:38,8,0,0 +BRDA:38,8,1,0 +BRDA:50,9,0,0 +BRDA:50,9,1,0 +BRDA:90,10,0,0 +BRDA:90,10,1,0 +BRDA:93,11,0,0 +BRDA:93,11,1,0 +BRDA:101,12,0,0 +BRDA:101,12,1,0 +BRDA:105,13,0,0 +BRDA:105,13,1,0 +BRDA:105,13,2,0 +BRDA:105,13,3,0 +BRDA:105,13,4,0 +BRDA:110,14,0,0 +BRDA:110,14,1,0 +BRDA:115,15,0,0 +BRDA:115,15,1,0 +BRDA:123,16,0,0 +BRDA:123,16,1,0 +BRDA:123,17,0,0 +BRDA:123,17,1,0 +BRDA:123,18,0,0 +BRDA:123,18,1,0 +BRDA:134,19,0,0 +BRDA:134,19,1,0 +BRDA:139,20,0,0 +BRDA:139,20,1,0 +BRDA:146,21,0,0 +BRDA:146,21,1,0 +BRDA:149,22,0,0 +BRDA:149,22,1,0 +BRDA:183,23,0,0 +BRDA:183,23,1,0 +BRDA:186,24,0,0 +BRDA:186,24,1,0 +BRDA:186,24,2,0 +BRDA:203,25,0,0 +BRDA:203,25,1,0 +BRDA:203,26,0,0 +BRDA:203,26,1,0 +BRDA:206,27,0,0 +BRDA:206,27,1,0 +BRDA:210,28,0,0 +BRDA:210,28,1,0 +BRDA:214,29,0,0 +BRDA:214,29,1,0 +BRDA:226,30,0,0 +BRDA:226,30,1,0 +BRDA:226,31,0,0 +BRDA:226,31,1,0 +BRDA:226,31,2,0 +BRDA:226,32,0,0 +BRDA:226,32,1,0 +BRDA:226,33,0,0 +BRDA:226,33,1,0 +BRDA:229,34,0,0 +BRDA:229,34,1,0 +BRDA:233,35,0,0 +BRDA:233,35,1,0 +BRDA:233,36,0,0 +BRDA:233,36,1,0 +BRDA:234,37,0,0 +BRDA:234,37,1,0 +BRDA:236,38,0,0 +BRDA:236,38,1,0 +BRDA:242,39,0,0 +BRDA:242,39,1,0 +BRDA:243,40,0,0 +BRDA:243,40,1,0 +BRDA:258,41,0,0 +BRDA:258,41,1,0 +BRDA:261,42,0,0 +BRDA:261,42,1,0 +BRDA:261,42,2,0 +BRDA:261,42,3,0 +BRDA:261,42,4,0 +BRDA:261,42,5,0 +BRDA:261,42,6,0 +BRDA:261,42,7,0 +BRDA:266,43,0,0 +BRDA:266,43,1,0 +BRDA:286,44,0,0 +BRDA:286,44,1,298 +BRDA:286,45,0,298 +BRDA:286,45,1,298 +BRDA:291,46,0,322 +BRDA:291,46,1,3972 +BRDA:293,47,0,0 +BRDA:293,47,1,322 +BRDA:297,48,0,322 +BRDA:297,48,1,0 +BRDA:299,49,0,0 +BRDA:299,49,1,24 +BRDA:299,49,2,0 +BRDA:299,49,3,0 +BRDA:299,49,4,298 +BRDA:303,50,0,24 +BRDA:303,50,1,12 +BRDA:307,51,0,0 +BRDA:307,51,1,0 +BRDA:335,52,0,1 +BRDA:335,52,1,11 +BRDA:335,52,2,274 +BRDA:335,52,3,0 +BRDA:335,52,4,11 +BRDA:335,52,5,1 +BRDA:366,53,0,0 +BRDA:366,53,1,0 +BRDA:366,53,2,0 +BRDA:389,54,0,0 +BRDA:389,54,1,1 +BRDA:393,55,0,0 +BRDA:393,55,1,0 +BRDA:394,56,0,0 +BRDA:394,56,1,0 +BRDA:395,57,0,0 +BRDA:395,57,1,0 +BRDA:409,58,0,0 +BRDA:409,58,1,0 +BRDA:418,59,0,0 +BRDA:418,59,1,0 +BRDA:435,60,0,0 +BRDA:435,60,1,0 +BRDA:435,61,0,0 +BRDA:435,61,1,0 +BRDA:442,62,0,0 +BRDA:442,62,1,0 +BRDA:442,63,0,0 +BRDA:442,63,1,0 +BRDA:444,64,0,0 +BRDA:444,64,1,0 +BRDA:448,65,0,0 +BRDA:448,65,1,0 +BRDA:456,66,0,0 +BRDA:456,66,1,0 +BRDA:457,67,0,0 +BRDA:457,67,1,0 +BRDA:460,68,0,0 +BRDA:460,68,1,0 +BRDA:469,69,0,0 +BRDA:469,69,1,0 +BRDA:492,70,0,0 +BRDA:492,70,1,0 +BRDA:495,71,0,0 +BRDA:495,71,1,0 +BRDA:498,72,0,0 +BRDA:498,72,1,0 +BRDA:498,72,2,0 +BRDA:498,72,3,0 +BRDA:498,72,4,0 +BRDA:498,72,5,0 +BRDA:523,73,0,0 +BRDA:523,73,1,0 +BRDA:528,74,0,0 +BRDA:528,74,1,0 +BRDA:537,75,0,0 +BRDA:537,75,1,0 +BRDA:543,76,0,0 +BRDA:543,76,1,0 +BRF:179 +BRH:28 +end_of_record +TN: +SF:/Users/kit/Dropbox/Projects/json3/lib/json3.js +FN:2,(anonymous_1) +FN:42,has +FN:64,(anonymous_3) +FN:196,(anonymous_4) +FN:204,(anonymous_5) +FN:213,(anonymous_6) +FN:227,(anonymous_7) +FN:247,(anonymous_8) +FN:254,(anonymous_9) +FN:260,(anonymous_10) +FN:280,(anonymous_11) +FN:295,(anonymous_12) +FN:309,(anonymous_13) +FN:347,(anonymous_14) +FN:358,(anonymous_15) +FN:384,(anonymous_16) +FN:491,(anonymous_17) +FN:513,(anonymous_18) +FN:563,(anonymous_19) +FN:571,(anonymous_20) +FN:729,(anonymous_21) +FN:812,(anonymous_22) +FN:824,(anonymous_23) +FN:835,(anonymous_24) +FN:844,(anonymous_25) +FN:862,(anonymous_26) +FNF:26 +FNH:3 +FNDA:1,(anonymous_1) +FNDA:3,has +FNDA:4,(anonymous_3) +FNDA:0,(anonymous_4) +FNDA:0,(anonymous_5) +FNDA:0,(anonymous_6) +FNDA:0,(anonymous_7) +FNDA:0,(anonymous_8) +FNDA:0,(anonymous_9) +FNDA:0,(anonymous_10) +FNDA:0,(anonymous_11) +FNDA:0,(anonymous_12) +FNDA:0,(anonymous_13) +FNDA:0,(anonymous_14) +FNDA:0,(anonymous_15) +FNDA:0,(anonymous_16) +FNDA:0,(anonymous_17) +FNDA:0,(anonymous_18) +FNDA:0,(anonymous_19) +FNDA:0,(anonymous_20) +FNDA:0,(anonymous_21) +FNDA:0,(anonymous_22) +FNDA:0,(anonymous_23) +FNDA:0,(anonymous_24) +FNDA:0,(anonymous_25) +FNDA:0,(anonymous_26) +DA:2,1 +DA:4,1 +DA:8,1 +DA:11,1 +DA:15,1 +DA:17,1 +DA:20,1 +DA:21,1 +DA:25,0 +DA:29,1 +DA:30,1 +DA:33,1 +DA:42,1 +DA:43,3 +DA:45,0 +DA:48,3 +DA:49,3 +DA:52,0 +DA:53,3 +DA:56,1 +DA:58,2 +DA:60,2 +DA:61,1 +DA:62,1 +DA:64,1 +DA:65,4 +DA:67,1 +DA:68,1 +DA:122,0 +DA:125,1 +DA:128,2 +DA:129,1 +DA:130,1 +DA:131,1 +DA:135,1 +DA:137,1 +DA:138,1 +DA:139,1 +DA:140,1 +DA:142,1 +DA:144,1 +DA:145,1 +DA:149,1 +DA:152,1 +DA:153,1 +DA:157,1 +DA:163,0 +DA:166,1 +DA:169,3 +DA:171,1 +DA:172,1 +DA:173,1 +DA:174,1 +DA:176,1 +DA:178,0 +DA:179,0 +DA:180,0 +DA:181,0 +DA:182,0 +DA:183,0 +DA:186,0 +DA:189,0 +DA:190,0 +DA:193,0 +DA:196,0 +DA:197,0 +DA:203,0 +DA:204,0 +DA:205,0 +DA:206,0 +DA:213,0 +DA:217,0 +DA:219,0 +DA:220,0 +DA:224,0 +DA:227,0 +DA:228,0 +DA:229,0 +DA:232,0 +DA:233,0 +DA:238,0 +DA:247,0 +DA:248,0 +DA:249,0 +DA:254,0 +DA:255,0 +DA:260,0 +DA:261,0 +DA:265,0 +DA:266,0 +DA:268,0 +DA:269,0 +DA:272,0 +DA:275,0 +DA:277,0 +DA:280,0 +DA:281,0 +DA:282,0 +DA:283,0 +DA:286,0 +DA:287,0 +DA:291,0 +DA:293,0 +DA:295,0 +DA:297,0 +DA:298,0 +DA:302,0 +DA:303,0 +DA:309,0 +DA:310,0 +DA:311,0 +DA:312,0 +DA:313,0 +DA:318,0 +DA:319,0 +DA:323,0 +DA:332,0 +DA:334,0 +DA:346,0 +DA:347,0 +DA:350,0 +DA:357,0 +DA:358,0 +DA:359,0 +DA:360,0 +DA:361,0 +DA:363,0 +DA:364,0 +DA:367,0 +DA:369,0 +DA:370,0 +DA:372,0 +DA:373,0 +DA:374,0 +DA:376,0 +DA:379,0 +DA:384,0 +DA:385,0 +DA:386,0 +DA:388,0 +DA:390,0 +DA:391,0 +DA:392,0 +DA:393,0 +DA:397,0 +DA:401,0 +DA:402,0 +DA:403,0 +DA:404,0 +DA:409,0 +DA:412,0 +DA:413,0 +DA:414,0 +DA:415,0 +DA:417,0 +DA:418,0 +DA:419,0 +DA:420,0 +DA:421,0 +DA:422,0 +DA:423,0 +DA:426,0 +DA:434,0 +DA:436,0 +DA:441,0 +DA:444,0 +DA:447,0 +DA:449,0 +DA:450,0 +DA:452,0 +DA:453,0 +DA:455,0 +DA:456,0 +DA:459,0 +DA:460,0 +DA:462,0 +DA:465,0 +DA:468,0 +DA:469,0 +DA:471,0 +DA:475,0 +DA:476,0 +DA:478,0 +DA:479,0 +DA:480,0 +DA:482,0 +DA:483,0 +DA:484,0 +DA:486,0 +DA:491,0 +DA:492,0 +DA:493,0 +DA:500,0 +DA:502,0 +DA:504,0 +DA:507,0 +DA:508,0 +DA:513,0 +DA:514,0 +DA:515,0 +DA:516,0 +DA:517,0 +DA:518,0 +DA:520,0 +DA:521,0 +DA:524,0 +DA:525,0 +DA:528,0 +DA:529,0 +DA:531,0 +DA:532,0 +DA:538,0 +DA:543,0 +DA:544,0 +DA:548,0 +DA:560,0 +DA:563,0 +DA:564,0 +DA:565,0 +DA:571,0 +DA:572,0 +DA:573,0 +DA:574,0 +DA:575,0 +DA:579,0 +DA:580,0 +DA:584,0 +DA:585,0 +DA:586,0 +DA:592,0 +DA:593,0 +DA:594,0 +DA:597,0 +DA:598,0 +DA:602,0 +DA:603,0 +DA:606,0 +DA:607,0 +DA:608,0 +DA:613,0 +DA:614,0 +DA:615,0 +DA:618,0 +DA:620,0 +DA:624,0 +DA:625,0 +DA:628,0 +DA:631,0 +DA:634,0 +DA:636,0 +DA:637,0 +DA:639,0 +DA:640,0 +DA:643,0 +DA:646,0 +DA:648,0 +DA:649,0 +DA:652,0 +DA:655,0 +DA:657,0 +DA:658,0 +DA:659,0 +DA:662,0 +DA:664,0 +DA:666,0 +DA:668,0 +DA:670,0 +DA:673,0 +DA:674,0 +DA:676,0 +DA:677,0 +DA:679,0 +DA:681,0 +DA:685,0 +DA:686,0 +DA:687,0 +DA:690,0 +DA:691,0 +DA:694,0 +DA:695,0 +DA:697,0 +DA:699,0 +DA:702,0 +DA:705,0 +DA:706,0 +DA:709,0 +DA:710,0 +DA:711,0 +DA:712,0 +DA:713,0 +DA:714,0 +DA:715,0 +DA:716,0 +DA:717,0 +DA:720,0 +DA:725,0 +DA:729,0 +DA:730,0 +DA:731,0 +DA:733,0 +DA:735,0 +DA:736,0 +DA:738,0 +DA:741,0 +DA:743,0 +DA:744,0 +DA:745,0 +DA:747,0 +DA:748,0 +DA:753,0 +DA:754,0 +DA:755,0 +DA:756,0 +DA:758,0 +DA:762,0 +DA:766,0 +DA:767,0 +DA:769,0 +DA:771,0 +DA:772,0 +DA:774,0 +DA:775,0 +DA:776,0 +DA:778,0 +DA:779,0 +DA:783,0 +DA:784,0 +DA:785,0 +DA:786,0 +DA:788,0 +DA:792,0 +DA:798,0 +DA:799,0 +DA:801,0 +DA:803,0 +DA:806,0 +DA:808,0 +DA:812,0 +DA:813,0 +DA:814,0 +DA:815,0 +DA:817,0 +DA:824,0 +DA:825,0 +DA:826,0 +DA:830,0 +DA:831,0 +DA:832,0 +DA:835,0 +DA:836,0 +DA:840,0 +DA:844,0 +DA:845,0 +DA:846,0 +DA:847,0 +DA:848,0 +DA:850,0 +DA:851,0 +DA:854,0 +DA:855,0 +DA:861,1 +DA:862,0 +DA:863,0 +LF:363 +LH:50 +BRDA:8,1,0,1 +BRDA:8,1,1,0 +BRDA:11,2,0,1 +BRDA:11,2,1,1 +BRDA:15,3,0,1 +BRDA:15,3,1,1 +BRDA:15,3,2,1 +BRDA:15,3,3,1 +BRDA:17,4,0,1 +BRDA:17,4,1,0 +BRDA:17,5,0,1 +BRDA:17,5,1,1 +BRDA:25,6,0,0 +BRDA:25,6,1,0 +BRDA:33,7,0,1 +BRDA:33,7,1,1 +BRDA:33,7,2,1 +BRDA:33,7,3,1 +BRDA:33,7,4,1 +BRDA:33,7,5,1 +BRDA:33,7,6,1 +BRDA:43,8,0,0 +BRDA:43,8,1,3 +BRDA:49,9,0,0 +BRDA:49,9,1,3 +BRDA:53,10,0,1 +BRDA:53,10,1,2 +BRDA:56,11,0,1 +BRDA:56,11,1,1 +BRDA:60,12,0,1 +BRDA:60,12,1,1 +BRDA:61,13,0,1 +BRDA:61,13,1,1 +BRDA:62,14,0,1 +BRDA:62,14,1,0 +BRDA:71,15,0,1 +BRDA:71,15,1,1 +BRDA:71,15,2,1 +BRDA:71,15,3,1 +BRDA:71,15,4,1 +BRDA:71,15,5,1 +BRDA:71,15,6,1 +BRDA:71,15,7,1 +BRDA:71,15,8,1 +BRDA:71,15,9,1 +BRDA:71,15,10,1 +BRDA:71,15,11,1 +BRDA:71,15,12,1 +BRDA:71,15,13,1 +BRDA:71,15,14,1 +BRDA:71,15,15,1 +BRDA:71,15,16,1 +BRDA:71,15,17,1 +BRDA:128,16,0,1 +BRDA:128,16,1,1 +BRDA:130,17,0,1 +BRDA:130,17,1,0 +BRDA:135,18,0,1 +BRDA:135,18,1,0 +BRDA:135,19,0,1 +BRDA:135,19,1,1 +BRDA:138,20,0,1 +BRDA:138,20,1,1 +BRDA:139,21,0,1 +BRDA:139,21,1,0 +BRDA:144,22,0,1 +BRDA:144,22,1,0 +BRDA:152,23,0,1 +BRDA:152,23,1,0 +BRDA:176,24,0,0 +BRDA:176,24,1,1 +BRDA:189,25,0,0 +BRDA:189,25,1,0 +BRDA:203,26,0,0 +BRDA:203,26,1,0 +BRDA:206,27,0,0 +BRDA:206,27,1,0 +BRDA:228,28,0,0 +BRDA:228,28,1,0 +BRDA:229,29,0,0 +BRDA:229,29,1,0 +BRDA:229,30,0,0 +BRDA:229,30,1,0 +BRDA:249,31,0,0 +BRDA:249,31,1,0 +BRDA:268,32,0,0 +BRDA:268,32,1,0 +BRDA:275,33,0,0 +BRDA:275,33,1,0 +BRDA:282,34,0,0 +BRDA:282,34,1,0 +BRDA:282,35,0,0 +BRDA:282,35,1,0 +BRDA:282,35,2,0 +BRDA:286,36,0,0 +BRDA:286,36,1,0 +BRDA:286,37,0,0 +BRDA:286,37,1,0 +BRDA:286,38,0,0 +BRDA:286,38,1,0 +BRDA:291,39,0,0 +BRDA:291,39,1,0 +BRDA:293,40,0,0 +BRDA:293,40,1,0 +BRDA:302,41,0,0 +BRDA:302,41,1,0 +BRDA:302,42,0,0 +BRDA:302,42,1,0 +BRDA:302,42,2,0 +BRDA:302,42,3,0 +BRDA:302,43,0,0 +BRDA:302,43,1,0 +BRDA:312,44,0,0 +BRDA:312,44,1,0 +BRDA:312,45,0,0 +BRDA:312,45,1,0 +BRDA:312,45,2,0 +BRDA:312,46,0,0 +BRDA:312,46,1,0 +BRDA:318,47,0,0 +BRDA:318,47,1,0 +BRDA:318,48,0,0 +BRDA:318,48,1,0 +BRDA:332,49,0,0 +BRDA:332,49,1,0 +BRDA:350,50,0,0 +BRDA:350,50,1,0 +BRDA:359,51,0,0 +BRDA:359,51,1,0 +BRDA:360,52,0,0 +BRDA:360,52,1,0 +BRDA:367,53,0,0 +BRDA:367,53,1,0 +BRDA:367,53,2,0 +BRDA:367,53,3,0 +BRDA:367,53,4,0 +BRDA:367,53,5,0 +BRDA:367,53,6,0 +BRDA:367,53,7,0 +BRDA:372,54,0,0 +BRDA:372,54,1,0 +BRDA:376,55,0,0 +BRDA:376,55,1,0 +BRDA:376,56,0,0 +BRDA:376,56,1,0 +BRDA:390,57,0,0 +BRDA:390,57,1,0 +BRDA:390,58,0,0 +BRDA:390,58,1,0 +BRDA:392,59,0,0 +BRDA:392,59,1,0 +BRDA:392,60,0,0 +BRDA:392,60,1,0 +BRDA:393,61,0,0 +BRDA:393,61,1,0 +BRDA:393,62,0,0 +BRDA:393,62,1,0 +BRDA:397,63,0,0 +BRDA:397,63,1,0 +BRDA:426,64,0,0 +BRDA:426,64,1,0 +BRDA:426,65,0,0 +BRDA:426,65,1,0 +BRDA:426,66,0,0 +BRDA:426,66,1,0 +BRDA:426,67,0,0 +BRDA:426,67,1,0 +BRDA:436,68,0,0 +BRDA:436,68,1,0 +BRDA:436,69,0,0 +BRDA:436,69,1,0 +BRDA:436,69,2,0 +BRDA:436,69,3,0 +BRDA:436,69,4,0 +BRDA:444,70,0,0 +BRDA:444,70,1,0 +BRDA:449,71,0,0 +BRDA:449,71,1,0 +BRDA:453,72,0,0 +BRDA:453,72,1,0 +BRDA:456,73,0,0 +BRDA:456,73,1,0 +BRDA:459,74,0,0 +BRDA:459,74,1,0 +BRDA:459,75,0,0 +BRDA:459,75,1,0 +BRDA:460,76,0,0 +BRDA:460,76,1,0 +BRDA:465,77,0,0 +BRDA:465,77,1,0 +BRDA:469,78,0,0 +BRDA:469,78,1,0 +BRDA:480,79,0,0 +BRDA:480,79,1,0 +BRDA:482,80,0,0 +BRDA:482,80,1,0 +BRDA:484,81,0,0 +BRDA:484,81,1,0 +BRDA:486,82,0,0 +BRDA:486,82,1,0 +BRDA:486,83,0,0 +BRDA:486,83,1,0 +BRDA:491,84,0,0 +BRDA:491,84,1,0 +BRDA:493,85,0,0 +BRDA:493,85,1,0 +BRDA:500,86,0,0 +BRDA:500,86,1,0 +BRDA:502,87,0,0 +BRDA:502,87,1,0 +BRDA:504,88,0,0 +BRDA:504,88,1,0 +BRDA:504,89,0,0 +BRDA:504,89,1,0 +BRDA:515,90,0,0 +BRDA:515,90,1,0 +BRDA:515,91,0,0 +BRDA:515,91,1,0 +BRDA:515,91,2,0 +BRDA:516,92,0,0 +BRDA:516,92,1,0 +BRDA:518,93,0,0 +BRDA:518,93,1,0 +BRDA:521,94,0,0 +BRDA:521,94,1,0 +BRDA:521,94,2,0 +BRDA:524,95,0,0 +BRDA:524,95,1,0 +BRDA:525,96,0,0 +BRDA:525,96,1,0 +BRDA:528,97,0,0 +BRDA:528,97,1,0 +BRDA:531,98,0,0 +BRDA:531,98,1,0 +BRDA:532,99,0,0 +BRDA:532,99,1,0 +BRDA:543,100,0,0 +BRDA:543,100,1,0 +BRDA:575,101,0,0 +BRDA:575,101,1,0 +BRDA:575,101,2,0 +BRDA:575,101,3,0 +BRDA:575,101,4,0 +BRDA:575,101,5,0 +BRDA:575,101,6,0 +BRDA:575,101,7,0 +BRDA:575,101,8,0 +BRDA:575,101,9,0 +BRDA:575,101,10,0 +BRDA:575,101,11,0 +BRDA:584,102,0,0 +BRDA:584,102,1,0 +BRDA:594,103,0,0 +BRDA:594,103,1,0 +BRDA:598,104,0,0 +BRDA:598,104,1,0 +BRDA:603,105,0,0 +BRDA:603,105,1,0 +BRDA:603,105,2,0 +BRDA:603,105,3,0 +BRDA:603,105,4,0 +BRDA:603,105,5,0 +BRDA:603,105,6,0 +BRDA:603,105,7,0 +BRDA:603,105,8,0 +BRDA:603,105,9,0 +BRDA:618,106,0,0 +BRDA:618,106,1,0 +BRDA:618,107,0,0 +BRDA:618,107,1,0 +BRDA:618,107,2,0 +BRDA:618,107,3,0 +BRDA:618,107,4,0 +BRDA:618,107,5,0 +BRDA:631,108,0,0 +BRDA:631,108,1,0 +BRDA:639,109,0,0 +BRDA:639,109,1,0 +BRDA:639,109,2,0 +BRDA:646,110,0,0 +BRDA:646,110,1,0 +BRDA:657,111,0,0 +BRDA:657,111,1,0 +BRDA:662,112,0,0 +BRDA:662,112,1,0 +BRDA:662,113,0,0 +BRDA:662,113,1,0 +BRDA:664,114,0,0 +BRDA:664,114,1,0 +BRDA:664,115,0,0 +BRDA:664,115,1,0 +BRDA:664,116,0,0 +BRDA:664,116,1,0 +BRDA:670,117,0,0 +BRDA:670,117,1,0 +BRDA:670,118,0,0 +BRDA:670,118,1,0 +BRDA:673,119,0,0 +BRDA:673,119,1,0 +BRDA:676,120,0,0 +BRDA:676,120,1,0 +BRDA:676,121,0,0 +BRDA:676,121,1,0 +BRDA:677,122,0,0 +BRDA:677,122,1,0 +BRDA:686,123,0,0 +BRDA:686,123,1,0 +BRDA:686,124,0,0 +BRDA:686,124,1,0 +BRDA:690,125,0,0 +BRDA:690,125,1,0 +BRDA:690,126,0,0 +BRDA:690,126,1,0 +BRDA:694,127,0,0 +BRDA:694,127,1,0 +BRDA:694,128,0,0 +BRDA:694,128,1,0 +BRDA:695,129,0,0 +BRDA:695,129,1,0 +BRDA:705,130,0,0 +BRDA:705,130,1,0 +BRDA:709,131,0,0 +BRDA:709,131,1,0 +BRDA:712,132,0,0 +BRDA:712,132,1,0 +BRDA:715,133,0,0 +BRDA:715,133,1,0 +BRDA:731,134,0,0 +BRDA:731,134,1,0 +BRDA:735,135,0,0 +BRDA:735,135,1,0 +BRDA:736,136,0,0 +BRDA:736,136,1,0 +BRDA:736,137,0,0 +BRDA:736,137,1,0 +BRDA:741,138,0,0 +BRDA:741,138,1,0 +BRDA:744,139,0,0 +BRDA:744,139,1,0 +BRDA:747,140,0,0 +BRDA:747,140,1,0 +BRDA:753,141,0,0 +BRDA:753,141,1,0 +BRDA:754,142,0,0 +BRDA:754,142,1,0 +BRDA:756,143,0,0 +BRDA:756,143,1,0 +BRDA:766,144,0,0 +BRDA:766,144,1,0 +BRDA:772,145,0,0 +BRDA:772,145,1,0 +BRDA:775,146,0,0 +BRDA:775,146,1,0 +BRDA:778,147,0,0 +BRDA:778,147,1,0 +BRDA:783,148,0,0 +BRDA:783,148,1,0 +BRDA:784,149,0,0 +BRDA:784,149,1,0 +BRDA:786,150,0,0 +BRDA:786,150,1,0 +BRDA:798,151,0,0 +BRDA:798,151,1,0 +BRDA:798,152,0,0 +BRDA:798,152,1,0 +BRDA:798,152,2,0 +BRDA:798,152,3,0 +BRDA:798,153,0,0 +BRDA:798,153,1,0 +BRDA:814,154,0,0 +BRDA:814,154,1,0 +BRDA:826,155,0,0 +BRDA:826,155,1,0 +BRDA:826,156,0,0 +BRDA:826,156,1,0 +BRDA:830,157,0,0 +BRDA:830,157,1,0 +BRDA:850,158,0,0 +BRDA:850,158,1,0 +BRDA:855,159,0,0 +BRDA:855,159,1,0 +BRDA:855,160,0,0 +BRDA:855,160,1,0 +BRDA:861,161,0,0 +BRDA:861,161,1,1 +BRF:385 +BRH:59 +end_of_record diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/lib/json3.js b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/lib/json3.js new file mode 100644 index 0000000..ea4a0ea --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/lib/json3.js @@ -0,0 +1,861 @@ +/*! JSON v3.2.6 | http://bestiejs.github.io/json3 | Copyright 2012-2013, Kit Cambridge | http://kit.mit-license.org */ +;(function (window) { + // Convenience aliases. + var getClass = {}.toString, isProperty, forEach, undef; + + // Detect the `define` function exposed by asynchronous module loaders. The + // strict `define` check is necessary for compatibility with `r.js`. + var isLoader = typeof define === "function" && define.amd; + + // Detect native implementations. + var nativeJSON = typeof JSON == "object" && JSON; + + // Set up the JSON 3 namespace, preferring the CommonJS `exports` object if + // available. + var JSON3 = typeof exports == "object" && exports && !exports.nodeType && exports; + + if (JSON3 && nativeJSON) { + // Explicitly delegate to the native `stringify` and `parse` + // implementations in CommonJS environments. + JSON3.stringify = nativeJSON.stringify; + JSON3.parse = nativeJSON.parse; + } else { + // Export for web browsers, JavaScript engines, and asynchronous module + // loaders, using the global `JSON` object if available. + JSON3 = window.JSON = nativeJSON || {}; + } + + // Test the `Date#getUTC*` methods. Based on work by @Yaffle. + var isExtended = new Date(-3509827334573292); + try { + // The `getUTCFullYear`, `Month`, and `Date` methods return nonsensical + // results for certain dates in Opera >= 10.53. + isExtended = isExtended.getUTCFullYear() == -109252 && isExtended.getUTCMonth() === 0 && isExtended.getUTCDate() === 1 && + // Safari < 2.0.2 stores the internal millisecond time value correctly, + // but clips the values returned by the date methods to the range of + // signed 32-bit integers ([-2 ** 31, 2 ** 31 - 1]). + isExtended.getUTCHours() == 10 && isExtended.getUTCMinutes() == 37 && isExtended.getUTCSeconds() == 6 && isExtended.getUTCMilliseconds() == 708; + } catch (exception) {} + + // Internal: Determines whether the native `JSON.stringify` and `parse` + // implementations are spec-compliant. Based on work by Ken Snyder. + function has(name) { + if (has[name] !== undef) { + // Return cached feature test result. + return has[name]; + } + + var isSupported; + if (name == "bug-string-char-index") { + // IE <= 7 doesn't support accessing string characters using square + // bracket notation. IE 8 only supports this for primitives. + isSupported = "a"[0] != "a"; + } else if (name == "json") { + // Indicates whether both `JSON.stringify` and `JSON.parse` are + // supported. + isSupported = has("json-stringify") && has("json-parse"); + } else { + var value, serialized = '{"a":[1,true,false,null,"\\u0000\\b\\n\\f\\r\\t"]}'; + // Test `JSON.stringify`. + if (name == "json-stringify") { + var stringify = JSON3.stringify, stringifySupported = typeof stringify == "function" && isExtended; + if (stringifySupported) { + // A test function object with a custom `toJSON` method. + (value = function () { + return 1; + }).toJSON = value; + try { + stringifySupported = + // Firefox 3.1b1 and b2 serialize string, number, and boolean + // primitives as object literals. + stringify(0) === "0" && + // FF 3.1b1, b2, and JSON 2 serialize wrapped primitives as object + // literals. + stringify(new Number()) === "0" && + stringify(new String()) == '""' && + // FF 3.1b1, 2 throw an error if the value is `null`, `undefined`, or + // does not define a canonical JSON representation (this applies to + // objects with `toJSON` properties as well, *unless* they are nested + // within an object or array). + stringify(getClass) === undef && + // IE 8 serializes `undefined` as `"undefined"`. Safari <= 5.1.7 and + // FF 3.1b3 pass this test. + stringify(undef) === undef && + // Safari <= 5.1.7 and FF 3.1b3 throw `Error`s and `TypeError`s, + // respectively, if the value is omitted entirely. + stringify() === undef && + // FF 3.1b1, 2 throw an error if the given value is not a number, + // string, array, object, Boolean, or `null` literal. This applies to + // objects with custom `toJSON` methods as well, unless they are nested + // inside object or array literals. YUI 3.0.0b1 ignores custom `toJSON` + // methods entirely. + stringify(value) === "1" && + stringify([value]) == "[1]" && + // Prototype <= 1.6.1 serializes `[undefined]` as `"[]"` instead of + // `"[null]"`. + stringify([undef]) == "[null]" && + // YUI 3.0.0b1 fails to serialize `null` literals. + stringify(null) == "null" && + // FF 3.1b1, 2 halts serialization if an array contains a function: + // `[1, true, getClass, 1]` serializes as "[1,true,],". FF 3.1b3 + // elides non-JSON values from objects and arrays, unless they + // define custom `toJSON` methods. + stringify([undef, getClass, null]) == "[null,null,null]" && + // Simple serialization test. FF 3.1b1 uses Unicode escape sequences + // where character escape codes are expected (e.g., `\b` => `\u0008`). + stringify({ "a": [value, true, false, null, "\x00\b\n\f\r\t"] }) == serialized && + // FF 3.1b1 and b2 ignore the `filter` and `width` arguments. + stringify(null, value) === "1" && + stringify([1, 2], null, 1) == "[\n 1,\n 2\n]" && + // JSON 2, Prototype <= 1.7, and older WebKit builds incorrectly + // serialize extended years. + stringify(new Date(-8.64e15)) == '"-271821-04-20T00:00:00.000Z"' && + // The milliseconds are optional in ES 5, but required in 5.1. + stringify(new Date(8.64e15)) == '"+275760-09-13T00:00:00.000Z"' && + // Firefox <= 11.0 incorrectly serializes years prior to 0 as negative + // four-digit years instead of six-digit years. Credits: @Yaffle. + stringify(new Date(-621987552e5)) == '"-000001-01-01T00:00:00.000Z"' && + // Safari <= 5.1.5 and Opera >= 10.53 incorrectly serialize millisecond + // values less than 1000. Credits: @Yaffle. + stringify(new Date(-1)) == '"1969-12-31T23:59:59.999Z"'; + } catch (exception) { + stringifySupported = false; + } + } + isSupported = stringifySupported; + } + // Test `JSON.parse`. + if (name == "json-parse") { + var parse = JSON3.parse; + if (typeof parse == "function") { + try { + // FF 3.1b1, b2 will throw an exception if a bare literal is provided. + // Conforming implementations should also coerce the initial argument to + // a string prior to parsing. + if (parse("0") === 0 && !parse(false)) { + // Simple parsing test. + value = parse(serialized); + var parseSupported = value["a"].length == 5 && value["a"][0] === 1; + if (parseSupported) { + try { + // Safari <= 5.1.2 and FF 3.1b1 allow unescaped tabs in strings. + parseSupported = !parse('"\t"'); + } catch (exception) {} + if (parseSupported) { + try { + // FF 4.0 and 4.0.1 allow leading `+` signs and leading + // decimal points. FF 4.0, 4.0.1, and IE 9-10 also allow + // certain octal literals. + parseSupported = parse("01") !== 1; + } catch (exception) {} + } + if (parseSupported) { + try { + // FF 4.0, 4.0.1, and Rhino 1.7R3-R4 allow trailing decimal + // points. These environments, along with FF 3.1b1 and 2, + // also allow trailing commas in JSON objects and arrays. + parseSupported = parse("1.") !== 1; + } catch (exception) {} + } + } + } + } catch (exception) { + parseSupported = false; + } + } + isSupported = parseSupported; + } + } + return has[name] = !!isSupported; + } + + if (!has("json")) { + // Common `[[Class]]` name aliases. + var functionClass = "[object Function]"; + var dateClass = "[object Date]"; + var numberClass = "[object Number]"; + var stringClass = "[object String]"; + var arrayClass = "[object Array]"; + var booleanClass = "[object Boolean]"; + + // Detect incomplete support for accessing string characters by index. + var charIndexBuggy = has("bug-string-char-index"); + + // Define additional utility methods if the `Date` methods are buggy. + if (!isExtended) { + var floor = Math.floor; + // A mapping between the months of the year and the number of days between + // January 1st and the first of the respective month. + var Months = [0, 31, 59, 90, 120, 151, 181, 212, 243, 273, 304, 334]; + // Internal: Calculates the number of days between the Unix epoch and the + // first day of the given month. + var getDay = function (year, month) { + return Months[month] + 365 * (year - 1970) + floor((year - 1969 + (month = +(month > 1))) / 4) - floor((year - 1901 + month) / 100) + floor((year - 1601 + month) / 400); + }; + } + + // Internal: Determines if a property is a direct property of the given + // object. Delegates to the native `Object#hasOwnProperty` method. + if (!(isProperty = {}.hasOwnProperty)) { + isProperty = function (property) { + var members = {}, constructor; + if ((members.__proto__ = null, members.__proto__ = { + // The *proto* property cannot be set multiple times in recent + // versions of Firefox and SeaMonkey. + "toString": 1 + }, members).toString != getClass) { + // Safari <= 2.0.3 doesn't implement `Object#hasOwnProperty`, but + // supports the mutable *proto* property. + isProperty = function (property) { + // Capture and break the object's prototype chain (see section 8.6.2 + // of the ES 5.1 spec). The parenthesized expression prevents an + // unsafe transformation by the Closure Compiler. + var original = this.__proto__, result = property in (this.__proto__ = null, this); + // Restore the original prototype chain. + this.__proto__ = original; + return result; + }; + } else { + // Capture a reference to the top-level `Object` constructor. + constructor = members.constructor; + // Use the `constructor` property to simulate `Object#hasOwnProperty` in + // other environments. + isProperty = function (property) { + var parent = (this.constructor || constructor).prototype; + return property in this && !(property in parent && this[property] === parent[property]); + }; + } + members = null; + return isProperty.call(this, property); + }; + } + + // Internal: A set of primitive types used by `isHostType`. + var PrimitiveTypes = { + 'boolean': 1, + 'number': 1, + 'string': 1, + 'undefined': 1 + }; + + // Internal: Determines if the given object `property` value is a + // non-primitive. + var isHostType = function (object, property) { + var type = typeof object[property]; + return type == 'object' ? !!object[property] : !PrimitiveTypes[type]; + }; + + // Internal: Normalizes the `for...in` iteration algorithm across + // environments. Each enumerated key is yielded to a `callback` function. + forEach = function (object, callback) { + var size = 0, Properties, members, property; + + // Tests for bugs in the current environment's `for...in` algorithm. The + // `valueOf` property inherits the non-enumerable flag from + // `Object.prototype` in older versions of IE, Netscape, and Mozilla. + (Properties = function () { + this.valueOf = 0; + }).prototype.valueOf = 0; + + // Iterate over a new instance of the `Properties` class. + members = new Properties(); + for (property in members) { + // Ignore all properties inherited from `Object.prototype`. + if (isProperty.call(members, property)) { + size++; + } + } + Properties = members = null; + + // Normalize the iteration algorithm. + if (!size) { + // A list of non-enumerable properties inherited from `Object.prototype`. + members = ["valueOf", "toString", "toLocaleString", "propertyIsEnumerable", "isPrototypeOf", "hasOwnProperty", "constructor"]; + // IE <= 8, Mozilla 1.0, and Netscape 6.2 ignore shadowed non-enumerable + // properties. + forEach = function (object, callback) { + var isFunction = getClass.call(object) == functionClass, property, length; + var hasProperty = !isFunction && typeof object.constructor != 'function' && isHostType(object, 'hasOwnProperty') ? object.hasOwnProperty : isProperty; + for (property in object) { + // Gecko <= 1.0 enumerates the `prototype` property of functions under + // certain conditions; IE does not. + if (!(isFunction && property == "prototype") && hasProperty.call(object, property)) { + callback(property); + } + } + // Manually invoke the callback for each non-enumerable property. + for (length = members.length; property = members[--length]; hasProperty.call(object, property) && callback(property)); + }; + } else if (size == 2) { + // Safari <= 2.0.4 enumerates shadowed properties twice. + forEach = function (object, callback) { + // Create a set of iterated properties. + var members = {}, isFunction = getClass.call(object) == functionClass, property; + for (property in object) { + // Store each property name to prevent double enumeration. The + // `prototype` property of functions is not enumerated due to cross- + // environment inconsistencies. + if (!(isFunction && property == "prototype") && !isProperty.call(members, property) && (members[property] = 1) && isProperty.call(object, property)) { + callback(property); + } + } + }; + } else { + // No bugs detected; use the standard `for...in` algorithm. + forEach = function (object, callback) { + var isFunction = getClass.call(object) == functionClass, property, isConstructor; + for (property in object) { + if (!(isFunction && property == "prototype") && isProperty.call(object, property) && !(isConstructor = property === "constructor")) { + callback(property); + } + } + // Manually invoke the callback for the `constructor` property due to + // cross-environment inconsistencies. + if (isConstructor || isProperty.call(object, (property = "constructor"))) { + callback(property); + } + }; + } + return forEach(object, callback); + }; + + // Public: Serializes a JavaScript `value` as a JSON string. The optional + // `filter` argument may specify either a function that alters how object and + // array members are serialized, or an array of strings and numbers that + // indicates which properties should be serialized. The optional `width` + // argument may be either a string or number that specifies the indentation + // level of the output. + if (!has("json-stringify")) { + // Internal: A map of control characters and their escaped equivalents. + var Escapes = { + 92: "\\\\", + 34: '\\"', + 8: "\\b", + 12: "\\f", + 10: "\\n", + 13: "\\r", + 9: "\\t" + }; + + // Internal: Converts `value` into a zero-padded string such that its + // length is at least equal to `width`. The `width` must be <= 6. + var leadingZeroes = "000000"; + var toPaddedString = function (width, value) { + // The `|| 0` expression is necessary to work around a bug in + // Opera <= 7.54u2 where `0 == -0`, but `String(-0) !== "0"`. + return (leadingZeroes + (value || 0)).slice(-width); + }; + + // Internal: Double-quotes a string `value`, replacing all ASCII control + // characters (characters with code unit values between 0 and 31) with + // their escaped equivalents. This is an implementation of the + // `Quote(value)` operation defined in ES 5.1 section 15.12.3. + var unicodePrefix = "\\u00"; + var quote = function (value) { + var result = '"', index = 0, length = value.length, isLarge = length > 10 && charIndexBuggy, symbols; + if (isLarge) { + symbols = value.split(""); + } + for (; index < length; index++) { + var charCode = value.charCodeAt(index); + // If the character is a control character, append its Unicode or + // shorthand escape sequence; otherwise, append the character as-is. + switch (charCode) { + case 8: case 9: case 10: case 12: case 13: case 34: case 92: + result += Escapes[charCode]; + break; + default: + if (charCode < 32) { + result += unicodePrefix + toPaddedString(2, charCode.toString(16)); + break; + } + result += isLarge ? symbols[index] : charIndexBuggy ? value.charAt(index) : value[index]; + } + } + return result + '"'; + }; + + // Internal: Recursively serializes an object. Implements the + // `Str(key, holder)`, `JO(value)`, and `JA(value)` operations. + var serialize = function (property, object, callback, properties, whitespace, indentation, stack) { + var value, className, year, month, date, time, hours, minutes, seconds, milliseconds, results, element, index, length, prefix, result; + try { + // Necessary for host object support. + value = object[property]; + } catch (exception) {} + if (typeof value == "object" && value) { + className = getClass.call(value); + if (className == dateClass && !isProperty.call(value, "toJSON")) { + if (value > -1 / 0 && value < 1 / 0) { + // Dates are serialized according to the `Date#toJSON` method + // specified in ES 5.1 section 15.9.5.44. See section 15.9.1.15 + // for the ISO 8601 date time string format. + if (getDay) { + // Manually compute the year, month, date, hours, minutes, + // seconds, and milliseconds if the `getUTC*` methods are + // buggy. Adapted from @Yaffle's `date-shim` project. + date = floor(value / 864e5); + for (year = floor(date / 365.2425) + 1970 - 1; getDay(year + 1, 0) <= date; year++); + for (month = floor((date - getDay(year, 0)) / 30.42); getDay(year, month + 1) <= date; month++); + date = 1 + date - getDay(year, month); + // The `time` value specifies the time within the day (see ES + // 5.1 section 15.9.1.2). The formula `(A % B + B) % B` is used + // to compute `A modulo B`, as the `%` operator does not + // correspond to the `modulo` operation for negative numbers. + time = (value % 864e5 + 864e5) % 864e5; + // The hours, minutes, seconds, and milliseconds are obtained by + // decomposing the time within the day. See section 15.9.1.10. + hours = floor(time / 36e5) % 24; + minutes = floor(time / 6e4) % 60; + seconds = floor(time / 1e3) % 60; + milliseconds = time % 1e3; + } else { + year = value.getUTCFullYear(); + month = value.getUTCMonth(); + date = value.getUTCDate(); + hours = value.getUTCHours(); + minutes = value.getUTCMinutes(); + seconds = value.getUTCSeconds(); + milliseconds = value.getUTCMilliseconds(); + } + // Serialize extended years correctly. + value = (year <= 0 || year >= 1e4 ? (year < 0 ? "-" : "+") + toPaddedString(6, year < 0 ? -year : year) : toPaddedString(4, year)) + + "-" + toPaddedString(2, month + 1) + "-" + toPaddedString(2, date) + + // Months, dates, hours, minutes, and seconds should have two + // digits; milliseconds should have three. + "T" + toPaddedString(2, hours) + ":" + toPaddedString(2, minutes) + ":" + toPaddedString(2, seconds) + + // Milliseconds are optional in ES 5.0, but required in 5.1. + "." + toPaddedString(3, milliseconds) + "Z"; + } else { + value = null; + } + } else if (typeof value.toJSON == "function" && ((className != numberClass && className != stringClass && className != arrayClass) || isProperty.call(value, "toJSON"))) { + // Prototype <= 1.6.1 adds non-standard `toJSON` methods to the + // `Number`, `String`, `Date`, and `Array` prototypes. JSON 3 + // ignores all `toJSON` methods on these objects unless they are + // defined directly on an instance. + value = value.toJSON(property); + } + } + if (callback) { + // If a replacement function was provided, call it to obtain the value + // for serialization. + value = callback.call(object, property, value); + } + if (value === null) { + return "null"; + } + className = getClass.call(value); + if (className == booleanClass) { + // Booleans are represented literally. + return "" + value; + } else if (className == numberClass) { + // JSON numbers must be finite. `Infinity` and `NaN` are serialized as + // `"null"`. + return value > -1 / 0 && value < 1 / 0 ? "" + value : "null"; + } else if (className == stringClass) { + // Strings are double-quoted and escaped. + return quote("" + value); + } + // Recursively serialize objects and arrays. + if (typeof value == "object") { + // Check for cyclic structures. This is a linear search; performance + // is inversely proportional to the number of unique nested objects. + for (length = stack.length; length--;) { + if (stack[length] === value) { + // Cyclic structures cannot be serialized by `JSON.stringify`. + throw TypeError(); + } + } + // Add the object to the stack of traversed objects. + stack.push(value); + results = []; + // Save the current indentation level and indent one additional level. + prefix = indentation; + indentation += whitespace; + if (className == arrayClass) { + // Recursively serialize array elements. + for (index = 0, length = value.length; index < length; index++) { + element = serialize(index, value, callback, properties, whitespace, indentation, stack); + results.push(element === undef ? "null" : element); + } + result = results.length ? (whitespace ? "[\n" + indentation + results.join(",\n" + indentation) + "\n" + prefix + "]" : ("[" + results.join(",") + "]")) : "[]"; + } else { + // Recursively serialize object members. Members are selected from + // either a user-specified list of property names, or the object + // itself. + forEach(properties || value, function (property) { + var element = serialize(property, value, callback, properties, whitespace, indentation, stack); + if (element !== undef) { + // According to ES 5.1 section 15.12.3: "If `gap` {whitespace} + // is not the empty string, let `member` {quote(property) + ":"} + // be the concatenation of `member` and the `space` character." + // The "`space` character" refers to the literal space + // character, not the `space` {width} argument provided to + // `JSON.stringify`. + results.push(quote(property) + ":" + (whitespace ? " " : "") + element); + } + }); + result = results.length ? (whitespace ? "{\n" + indentation + results.join(",\n" + indentation) + "\n" + prefix + "}" : ("{" + results.join(",") + "}")) : "{}"; + } + // Remove the object from the traversed object stack. + stack.pop(); + return result; + } + }; + + // Public: `JSON.stringify`. See ES 5.1 section 15.12.3. + JSON3.stringify = function (source, filter, width) { + var whitespace, callback, properties, className; + if (typeof filter == "function" || typeof filter == "object" && filter) { + if ((className = getClass.call(filter)) == functionClass) { + callback = filter; + } else if (className == arrayClass) { + // Convert the property names array into a makeshift set. + properties = {}; + for (var index = 0, length = filter.length, value; index < length; value = filter[index++], ((className = getClass.call(value)), className == stringClass || className == numberClass) && (properties[value] = 1)); + } + } + if (width) { + if ((className = getClass.call(width)) == numberClass) { + // Convert the `width` to an integer and create a string containing + // `width` number of space characters. + if ((width -= width % 1) > 0) { + for (whitespace = "", width > 10 && (width = 10); whitespace.length < width; whitespace += " "); + } + } else if (className == stringClass) { + whitespace = width.length <= 10 ? width : width.slice(0, 10); + } + } + // Opera <= 7.54u2 discards the values associated with empty string keys + // (`""`) only if they are used directly within an object member list + // (e.g., `!("" in { "": 1})`). + return serialize("", (value = {}, value[""] = source, value), callback, properties, whitespace, "", []); + }; + } + + // Public: Parses a JSON source string. + if (!has("json-parse")) { + var fromCharCode = String.fromCharCode; + + // Internal: A map of escaped control characters and their unescaped + // equivalents. + var Unescapes = { + 92: "\\", + 34: '"', + 47: "/", + 98: "\b", + 116: "\t", + 110: "\n", + 102: "\f", + 114: "\r" + }; + + // Internal: Stores the parser state. + var Index, Source; + + // Internal: Resets the parser state and throws a `SyntaxError`. + var abort = function() { + Index = Source = null; + throw SyntaxError(); + }; + + // Internal: Returns the next token, or `"$"` if the parser has reached + // the end of the source string. A token may be a string, number, `null` + // literal, or Boolean literal. + var lex = function () { + var source = Source, length = source.length, value, begin, position, isSigned, charCode; + while (Index < length) { + charCode = source.charCodeAt(Index); + switch (charCode) { + case 9: case 10: case 13: case 32: + // Skip whitespace tokens, including tabs, carriage returns, line + // feeds, and space characters. + Index++; + break; + case 123: case 125: case 91: case 93: case 58: case 44: + // Parse a punctuator token (`{`, `}`, `[`, `]`, `:`, or `,`) at + // the current position. + value = charIndexBuggy ? source.charAt(Index) : source[Index]; + Index++; + return value; + case 34: + // `"` delimits a JSON string; advance to the next character and + // begin parsing the string. String tokens are prefixed with the + // sentinel `@` character to distinguish them from punctuators and + // end-of-string tokens. + for (value = "@", Index++; Index < length;) { + charCode = source.charCodeAt(Index); + if (charCode < 32) { + // Unescaped ASCII control characters (those with a code unit + // less than the space character) are not permitted. + abort(); + } else if (charCode == 92) { + // A reverse solidus (`\`) marks the beginning of an escaped + // control character (including `"`, `\`, and `/`) or Unicode + // escape sequence. + charCode = source.charCodeAt(++Index); + switch (charCode) { + case 92: case 34: case 47: case 98: case 116: case 110: case 102: case 114: + // Revive escaped control characters. + value += Unescapes[charCode]; + Index++; + break; + case 117: + // `\u` marks the beginning of a Unicode escape sequence. + // Advance to the first character and validate the + // four-digit code point. + begin = ++Index; + for (position = Index + 4; Index < position; Index++) { + charCode = source.charCodeAt(Index); + // A valid sequence comprises four hexdigits (case- + // insensitive) that form a single hexadecimal value. + if (!(charCode >= 48 && charCode <= 57 || charCode >= 97 && charCode <= 102 || charCode >= 65 && charCode <= 70)) { + // Invalid Unicode escape sequence. + abort(); + } + } + // Revive the escaped character. + value += fromCharCode("0x" + source.slice(begin, Index)); + break; + default: + // Invalid escape sequence. + abort(); + } + } else { + if (charCode == 34) { + // An unescaped double-quote character marks the end of the + // string. + break; + } + charCode = source.charCodeAt(Index); + begin = Index; + // Optimize for the common case where a string is valid. + while (charCode >= 32 && charCode != 92 && charCode != 34) { + charCode = source.charCodeAt(++Index); + } + // Append the string as-is. + value += source.slice(begin, Index); + } + } + if (source.charCodeAt(Index) == 34) { + // Advance to the next character and return the revived string. + Index++; + return value; + } + // Unterminated string. + abort(); + default: + // Parse numbers and literals. + begin = Index; + // Advance past the negative sign, if one is specified. + if (charCode == 45) { + isSigned = true; + charCode = source.charCodeAt(++Index); + } + // Parse an integer or floating-point value. + if (charCode >= 48 && charCode <= 57) { + // Leading zeroes are interpreted as octal literals. + if (charCode == 48 && ((charCode = source.charCodeAt(Index + 1)), charCode >= 48 && charCode <= 57)) { + // Illegal octal literal. + abort(); + } + isSigned = false; + // Parse the integer component. + for (; Index < length && ((charCode = source.charCodeAt(Index)), charCode >= 48 && charCode <= 57); Index++); + // Floats cannot contain a leading decimal point; however, this + // case is already accounted for by the parser. + if (source.charCodeAt(Index) == 46) { + position = ++Index; + // Parse the decimal component. + for (; position < length && ((charCode = source.charCodeAt(position)), charCode >= 48 && charCode <= 57); position++); + if (position == Index) { + // Illegal trailing decimal. + abort(); + } + Index = position; + } + // Parse exponents. The `e` denoting the exponent is + // case-insensitive. + charCode = source.charCodeAt(Index); + if (charCode == 101 || charCode == 69) { + charCode = source.charCodeAt(++Index); + // Skip past the sign following the exponent, if one is + // specified. + if (charCode == 43 || charCode == 45) { + Index++; + } + // Parse the exponential component. + for (position = Index; position < length && ((charCode = source.charCodeAt(position)), charCode >= 48 && charCode <= 57); position++); + if (position == Index) { + // Illegal empty exponent. + abort(); + } + Index = position; + } + // Coerce the parsed value to a JavaScript number. + return +source.slice(begin, Index); + } + // A negative sign may only precede numbers. + if (isSigned) { + abort(); + } + // `true`, `false`, and `null` literals. + if (source.slice(Index, Index + 4) == "true") { + Index += 4; + return true; + } else if (source.slice(Index, Index + 5) == "false") { + Index += 5; + return false; + } else if (source.slice(Index, Index + 4) == "null") { + Index += 4; + return null; + } + // Unrecognized token. + abort(); + } + } + // Return the sentinel `$` character if the parser has reached the end + // of the source string. + return "$"; + }; + + // Internal: Parses a JSON `value` token. + var get = function (value) { + var results, hasMembers; + if (value == "$") { + // Unexpected end of input. + abort(); + } + if (typeof value == "string") { + if ((charIndexBuggy ? value.charAt(0) : value[0]) == "@") { + // Remove the sentinel `@` character. + return value.slice(1); + } + // Parse object and array literals. + if (value == "[") { + // Parses a JSON array, returning a new JavaScript array. + results = []; + for (;; hasMembers || (hasMembers = true)) { + value = lex(); + // A closing square bracket marks the end of the array literal. + if (value == "]") { + break; + } + // If the array literal contains elements, the current token + // should be a comma separating the previous element from the + // next. + if (hasMembers) { + if (value == ",") { + value = lex(); + if (value == "]") { + // Unexpected trailing `,` in array literal. + abort(); + } + } else { + // A `,` must separate each array element. + abort(); + } + } + // Elisions and leading commas are not permitted. + if (value == ",") { + abort(); + } + results.push(get(value)); + } + return results; + } else if (value == "{") { + // Parses a JSON object, returning a new JavaScript object. + results = {}; + for (;; hasMembers || (hasMembers = true)) { + value = lex(); + // A closing curly brace marks the end of the object literal. + if (value == "}") { + break; + } + // If the object literal contains members, the current token + // should be a comma separator. + if (hasMembers) { + if (value == ",") { + value = lex(); + if (value == "}") { + // Unexpected trailing `,` in object literal. + abort(); + } + } else { + // A `,` must separate each object member. + abort(); + } + } + // Leading commas are not permitted, object property names must be + // double-quoted strings, and a `:` must separate each property + // name and value. + if (value == "," || typeof value != "string" || (charIndexBuggy ? value.charAt(0) : value[0]) != "@" || lex() != ":") { + abort(); + } + results[value.slice(1)] = get(lex()); + } + return results; + } + // Unexpected token encountered. + abort(); + } + return value; + }; + + // Internal: Updates a traversed object member. + var update = function(source, property, callback) { + var element = walk(source, property, callback); + if (element === undef) { + delete source[property]; + } else { + source[property] = element; + } + }; + + // Internal: Recursively traverses a parsed JSON object, invoking the + // `callback` function for each value. This is an implementation of the + // `Walk(holder, name)` operation defined in ES 5.1 section 15.12.2. + var walk = function (source, property, callback) { + var value = source[property], length; + if (typeof value == "object" && value) { + // `forEach` can't be used to traverse an array in Opera <= 8.54 + // because its `Object#hasOwnProperty` implementation returns `false` + // for array indices (e.g., `![1, 2, 3].hasOwnProperty("0")`). + if (getClass.call(value) == arrayClass) { + for (length = value.length; length--;) { + update(value, length, callback); + } + } else { + forEach(value, function (property) { + update(value, property, callback); + }); + } + } + return callback.call(source, property, value); + }; + + // Public: `JSON.parse`. See ES 5.1 section 15.12.2. + JSON3.parse = function (source, callback) { + var result, value; + Index = 0; + Source = "" + source; + result = get(lex()); + // If a JSON string contains multiple tokens, it is invalid. + if (lex() != "$") { + abort(); + } + // Reset the parser state. + Index = Source = null; + return callback && getClass.call(callback) == functionClass ? walk((value = {}, value[""] = result, value), "", callback) : result; + }; + } + } + + // Export for asynchronous module loaders. + if (isLoader) { + define(function () { + return JSON3; + }); + } +}(this)); diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/lib/json3.min.js b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/lib/json3.min.js new file mode 100644 index 0000000..f9a45ce --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/lib/json3.min.js @@ -0,0 +1,18 @@ +/*! JSON v3.2.6 | http://bestiejs.github.io/json3 | Copyright 2012-2013, Kit Cambridge | http://kit.mit-license.org */ +;(function(){var n=null; +(function(G){function m(a){if(m[a]!==s)return m[a];var c;if("bug-string-char-index"==a)c="a"!="a"[0];else if("json"==a)c=m("json-stringify")&&m("json-parse");else{var e;if("json-stringify"==a){c=o.stringify;var b="function"==typeof c&&l;if(b){(e=function(){return 1}).toJSON=e;try{b="0"===c(0)&&"0"===c(new Number)&&'""'==c(new String)&&c(p)===s&&c(s)===s&&c()===s&&"1"===c(e)&&"[1]"==c([e])&&"[null]"==c([s])&&"null"==c(n)&&"[null,null,null]"==c([s,p,n])&&'{"a":[1,true,false,null,"\\u0000\\b\\n\\f\\r\\t"]}'==c({a:[e, +!0,!1,n,"\x00\u0008\n\u000c\r\t"]})&&"1"===c(n,e)&&"[\n 1,\n 2\n]"==c([1,2],n,1)&&'"-271821-04-20T00:00:00.000Z"'==c(new Date(-864E13))&&'"+275760-09-13T00:00:00.000Z"'==c(new Date(864E13))&&'"-000001-01-01T00:00:00.000Z"'==c(new Date(-621987552E5))&&'"1969-12-31T23:59:59.999Z"'==c(new Date(-1))}catch(f){b=!1}}c=b}if("json-parse"==a){c=o.parse;if("function"==typeof c)try{if(0===c("0")&&!c(!1)){e=c('{"a":[1,true,false,null,"\\u0000\\b\\n\\f\\r\\t"]}');var j=5==e.a.length&&1===e.a[0];if(j){try{j=!c('"\t"')}catch(d){}if(j)try{j= +1!==c("01")}catch(h){}if(j)try{j=1!==c("1.")}catch(k){}}}}catch(N){j=!1}c=j}}return m[a]=!!c}var p={}.toString,q,x,s,H=typeof define==="function"&&define.amd,y="object"==typeof JSON&&JSON,o="object"==typeof exports&&exports&&!exports.nodeType&&exports;o&&y?(o.stringify=y.stringify,o.parse=y.parse):o=G.JSON=y||{};var l=new Date(-3509827334573292);try{l=-109252==l.getUTCFullYear()&&0===l.getUTCMonth()&&1===l.getUTCDate()&&10==l.getUTCHours()&&37==l.getUTCMinutes()&&6==l.getUTCSeconds()&&708==l.getUTCMilliseconds()}catch(O){}if(!m("json")){var t= +m("bug-string-char-index");if(!l)var u=Math.floor,I=[0,31,59,90,120,151,181,212,243,273,304,334],z=function(a,c){return I[c]+365*(a-1970)+u((a-1969+(c=+(c>1)))/4)-u((a-1901+c)/100)+u((a-1601+c)/400)};if(!(q={}.hasOwnProperty))q=function(a){var c={},e;if((c.__proto__=n,c.__proto__={toString:1},c).toString!=p)q=function(a){var c=this.__proto__,a=a in(this.__proto__=n,this);this.__proto__=c;return a};else{e=c.constructor;q=function(a){var c=(this.constructor||e).prototype;return a in this&&!(a in c&& +this[a]===c[a])}}c=n;return q.call(this,a)};var J={"boolean":1,number:1,string:1,undefined:1};x=function(a,c){var e=0,b,f,j;(b=function(){this.valueOf=0}).prototype.valueOf=0;f=new b;for(j in f)q.call(f,j)&&e++;b=f=n;if(e)x=e==2?function(a,c){var e={},b=p.call(a)=="[object Function]",f;for(f in a)!(b&&f=="prototype")&&!q.call(e,f)&&(e[f]=1)&&q.call(a,f)&&c(f)}:function(a,c){var e=p.call(a)=="[object Function]",b,f;for(b in a)!(e&&b=="prototype")&&q.call(a,b)&&!(f=b==="constructor")&&c(b);(f||q.call(a, +b="constructor"))&&c(b)};else{f=["valueOf","toString","toLocaleString","propertyIsEnumerable","isPrototypeOf","hasOwnProperty","constructor"];x=function(a,c){var e=p.call(a)=="[object Function]",b,g;if(g=!e)if(g=typeof a.constructor!="function"){g=typeof a.hasOwnProperty;g=g=="object"?!!a.hasOwnProperty:!J[g]}g=g?a.hasOwnProperty:q;for(b in a)!(e&&b=="prototype")&&g.call(a,b)&&c(b);for(e=f.length;b=f[--e];g.call(a,b)&&c(b));}}return x(a,c)};if(!m("json-stringify")){var K={92:"\\\\",34:'\\"',8:"\\b", +12:"\\f",10:"\\n",13:"\\r",9:"\\t"},v=function(a,c){return("000000"+(c||0)).slice(-a)},D=function(a){var c='"',b=0,g=a.length,f=g>10&&t,j;for(f&&(j=a.split(""));b-1/0&&h<1/0){if(z){l=u(h/864E5);for(k=u(l/365.2425)+1970-1;z(k+1,0)<=l;k++);for(i=u((l-z(k,0))/30.42);z(k,i+1)<=l;i++);l=1+l-z(k,i);m=(h%864E5+864E5)%864E5;o=u(m/36E5)%24;r=u(m/6E4)%60;t=u(m/1E3)%60;m=m%1E3}else{k=h.getUTCFullYear();i=h.getUTCMonth();l=h.getUTCDate();o=h.getUTCHours();r=h.getUTCMinutes();t=h.getUTCSeconds();m=h.getUTCMilliseconds()}h=(k<=0||k>=1E4?(k<0?"-":"+")+v(6,k<0?-k:k):v(4,k))+"-"+v(2,i+1)+"-"+v(2,l)+"T"+v(2,o)+":"+v(2,r)+":"+v(2,t)+"."+v(3,m)+"Z"}else h= +n;else if(typeof h.toJSON=="function"&&(k!="[object Number]"&&k!="[object String]"&&k!="[object Array]"||q.call(h,"toJSON")))h=h.toJSON(a)}b&&(h=b.call(c,a,h));if(h===n)return"null";k=p.call(h);if(k=="[object Boolean]")return""+h;if(k=="[object Number]")return h>-1/0&&h<1/0?""+h:"null";if(k=="[object String]")return D(""+h);if(typeof h=="object"){for(a=d.length;a--;)if(d[a]===h)throw TypeError();d.push(h);w=[];c=j;j=j+f;if(k=="[object Array]"){i=0;for(a=h.length;i0){g="";for(b>10&&(b=10);g.length=48&&d<=57||d>=97&&d<=102||d>=65&&d<=70||i()}e=e+L("0x"+a.slice(g,b));break;default:i()}}else{if(d==34)break;d=a.charCodeAt(b);for(g=b;d>=32&&d!=92&&d!=34;)d=a.charCodeAt(++b); +e=e+a.slice(g,b)}}if(a.charCodeAt(b)==34){b++;return e}i();default:g=b;if(d==45){j=true;d=a.charCodeAt(++b)}if(d>=48&&d<=57){for(d==48&&(d=a.charCodeAt(b+1),d>=48&&d<=57)&&i();b=48&&d<=57);b++);if(a.charCodeAt(b)==46){for(f=++b;f=48&&d<=57);f++);f==b&&i();b=f}d=a.charCodeAt(b);if(d==101||d==69){d=a.charCodeAt(++b);(d==43||d==45)&&b++;for(f=b;f=48&&d<=57);f++);f==b&&i();b=f}return+a.slice(g,b)}j&&i();if(a.slice(b,b+4)=="true"){b= +b+4;return true}if(a.slice(b,b+5)=="false"){b=b+5;return false}if(a.slice(b,b+4)=="null"){b=b+4;return n}i()}}return"$"},C=function(a){var c,b;a=="$"&&i();if(typeof a=="string"){if((t?a.charAt(0):a[0])=="@")return a.slice(1);if(a=="["){for(c=[];;b||(b=true)){a=r();if(a=="]")break;if(b)if(a==","){a=r();a=="]"&&i()}else i();a==","&&i();c.push(C(a))}return c}if(a=="{"){for(c={};;b||(b=true)){a=r();if(a=="}")break;if(b)if(a==","){a=r();a=="}"&&i()}else i();(a==","||typeof a!="string"||(t?a.charAt(0): +a[0])!="@"||r()!=":")&&i();c[a.slice(1)]=C(r())}return c}i()}return a},F=function(a,b,e){e=E(a,b,e);e===s?delete a[b]:a[b]=e},E=function(a,b,e){var g=a[b],f;if(typeof g=="object"&&g)if(p.call(g)=="[object Array]")for(f=g.length;f--;)F(g,f,e);else x(g,function(a){F(g,a,e)});return e.call(a,b,g)};o.parse=function(a,c){var e,g;b=0;A=""+a;e=C(r());r()!="$"&&i();b=A=n;return c&&p.call(c)=="[object Function]"?E((g={},g[""]=e,g),"",c):e}}}H&&define(function(){return o})})(this); +}()); \ No newline at end of file diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/package.json b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/package.json new file mode 100644 index 0000000..b10ddb6 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/node_modules/json3/package.json @@ -0,0 +1,102 @@ +{ + "name": "json3", + "version": "3.2.6", + "description": "A modern JSON implementation compatible with nearly all JavaScript platforms.", + "homepage": "http://bestiejs.github.io/json3", + "main": "./lib/json3", + "keywords": [ + "json", + "spec", + "ecma", + "es5", + "lexer", + "parser", + "stringify" + ], + "licenses": [ + { + "type": "MIT", + "url": "http://kit.mit-license.org/" + } + ], + "author": { + "name": "Kit Cambridge", + "email": "github@kitcambridge.be", + "url": "http://kitcambridge.be/" + }, + "maintainers": [ + { + "name": "kitcambridge", + "email": "kitcambridge@me.com" + } + ], + "contributors": [ + { + "name": "Mangled Deutz", + "email": "olivier@webitup.fr", + "url": "http://tech.roxee.tv/" + }, + { + "name": "Øyvind Sean Kinsey", + "email": "oyvind@kinsey.no", + "url": "http://fb.me/ok" + }, + { + "name": "Oskar Schöldström", + "email": "public@oxy.fi", + "url": "http://oxy.fi/" + }, + { + "name": "Benjamin Tan", + "email": "demoneaux@gmail.com", + "url": "http://d10.github.io/" + }, + { + "name": "Kiryl Yermakou", + "email": "rma4ok@gmail.com", + "url": "https://github.com/rma4ok" + } + ], + "bugs": { + "url": "https://github.com/bestiejs/json3/issues" + }, + "scripts": { + "test": "node test/test_*.js" + }, + "repository": { + "type": "git", + "url": "git://github.com/bestiejs/json3.git" + }, + "jam": { + "main": "./lib/json3.js" + }, + "volo": { + "type": "directory", + "ignore": [ + ".*", + "build.js", + "index.html", + "component.json", + "bower.json", + "benchmark", + "page", + "test", + "vendor" + ] + }, + "_id": "json3@3.2.6", + "dist": { + "shasum": "f6efc93c06a04de9aec53053df2559bb19e2038b", + "tarball": "https://registry.npmjs.org/json3/-/json3-3.2.6.tgz" + }, + "_from": "json3@3.2.6", + "_npmVersion": "1.3.8", + "_npmUser": { + "name": "kitcambridge", + "email": "github@kitcambridge.be" + }, + "directories": {}, + "_shasum": "f6efc93c06a04de9aec53053df2559bb19e2038b", + "_resolved": "http://registry.npmjs.org/json3/-/json3-3.2.6.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/package.json b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/package.json new file mode 100644 index 0000000..4909062 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/node_modules/socket.io-parser/package.json @@ -0,0 +1,51 @@ +{ + "name": "socket.io-parser", + "version": "2.2.2", + "description": "socket.io protocol parser", + "repository": { + "type": "git", + "url": "git+https://github.com/Automattic/socket.io-parser.git" + }, + "dependencies": { + "debug": "0.7.4", + "json3": "3.2.6", + "component-emitter": "1.1.2", + "isarray": "0.0.1", + "benchmark": "1.0.0" + }, + "devDependencies": { + "mocha": "1.16.2", + "expect.js": "0.2.0", + "zuul": "1.6.3" + }, + "scripts": { + "test": "make test" + }, + "license": "MIT", + "gitHead": "83c68c7a715ac54e95c5dae6445f751b3a4dfe9f", + "bugs": { + "url": "https://github.com/Automattic/socket.io-parser/issues" + }, + "homepage": "https://github.com/Automattic/socket.io-parser", + "_id": "socket.io-parser@2.2.2", + "_shasum": "3d7af6b64497e956b7d9fe775f999716027f9417", + "_from": "socket.io-parser@2.2.2", + "_npmVersion": "1.4.25", + "_npmUser": { + "name": "rauchg", + "email": "rauchg@gmail.com" + }, + "maintainers": [ + { + "name": "rauchg", + "email": "rauchg@gmail.com" + } + ], + "dist": { + "shasum": "3d7af6b64497e956b7d9fe775f999716027f9417", + "tarball": "https://registry.npmjs.org/socket.io-parser/-/socket.io-parser-2.2.2.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/socket.io-parser/-/socket.io-parser-2.2.2.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/socket.io/node_modules/socket.io-adapter/package.json b/node_modules/socket.io/node_modules/socket.io-adapter/package.json new file mode 100644 index 0000000..adae2d7 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-adapter/package.json @@ -0,0 +1,42 @@ +{ + "name": "socket.io-adapter", + "version": "0.4.0", + "license": "MIT", + "repository": { + "type": "git", + "url": "git://github.com/Automattic/socket.io-adapter.git" + }, + "description": "Default socket.io in-memory adapter class.", + "dependencies": { + "debug": "2.2.0", + "socket.io-parser": "2.2.2" + }, + "gitHead": "efd6141dbd6947761ee9ce91fa729f3bec0aaab0", + "bugs": { + "url": "https://github.com/Automattic/socket.io-adapter/issues" + }, + "homepage": "https://github.com/Automattic/socket.io-adapter#readme", + "_id": "socket.io-adapter@0.4.0", + "scripts": {}, + "_shasum": "fb9f82ab1aa65290bf72c3657955b930a991a24f", + "_from": "socket.io-adapter@0.4.0", + "_npmVersion": "3.4.1", + "_nodeVersion": "4.2.2", + "_npmUser": { + "name": "rauchg", + "email": "rauchg@gmail.com" + }, + "maintainers": [ + { + "name": "rauchg", + "email": "rauchg@gmail.com" + } + ], + "dist": { + "shasum": "fb9f82ab1aa65290bf72c3657955b930a991a24f", + "tarball": "https://registry.npmjs.org/socket.io-adapter/-/socket.io-adapter-0.4.0.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/socket.io-adapter/-/socket.io-adapter-0.4.0.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/socket.io/node_modules/socket.io-client/History.md b/node_modules/socket.io/node_modules/socket.io-client/History.md new file mode 100644 index 0000000..7ca6fc2 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-client/History.md @@ -0,0 +1,485 @@ + +1.5.1 / 2016-10-24 +================== + + * [chore] Disable AMD for json3 (#1005) + * [chore] Bump socket.io-parser to 2.3.0 (#1009) + * [chore] Bump engine.io-client to 1.7.1 (#1010) + * [chore] Update zuul browser settings (#1011) + * [chore] Add Github issue and PR templates (#1013) + * [chore] Bump engine.io-client to 1.7.2 and socket.io-parser to 2.3.1 (#1015) + +1.5.0 / 2016-10-06 +================== + + * [fix] Fix query string management (#943) + * [chore] Add gulp & babel in the build process (#940) + * [chore] Add eslint (#951) + * [chore] bump zuul (#958) + * [chore] Remove jspm browser config (#957) + * [chore] Update zuul browser settings following EOL notices (#985) + * [chore] Bump zuul to 3.11.0 & zuul-ngrok to 4.0.0 (#997) + * [chore] reference build badge to master branch (#967) + * [chore] Bump engine.io-client to 1.7.0 (#996) + * [chore] Restrict files included in npm package (#998) + +1.4.8 / 2016-06-23 +================== + + * package: bump `engine.io-client` + +1.4.7 / 2016-06-23 +================== + + * bump engine.io-client + +1.4.6 / 2016-05-02 +================== + + * bump engine.io-client + +1.4.5 / 2016-01-26 +================== + + * fix `NativeScript` support + +1.4.4 / 2016-01-10 +================== + + * bump `engine.io-client` + +1.4.3 / 2016-01-08 +================== + + * remove `webpack.config.js` + +1.4.2 / 2016-01-07 +================== + + * exclude `ws` instead of `ignore`ing it from build [@lpinca] + * add global object as another fallback [@ligaz] + * bump `engine.io-client` + +1.4.1 / 2016-01-07 +================== + + * package: bump `engine.io-client` + +1.4.0 / 2015-11-28 +================== + + * package: bump `engine.io-client` + * manager: fix `Object.prototype` extensions + * package: bump `zuul` and `zuul-ngrok` + * package: bump `debug` + * package: bump `socket.io-parser` + * package: bump `has-binary` + * remove unnecessary `index.js` + * added support for `ping` and `pong` events + * proper handling of disconnection while in `opening` state + * instrumentation / style tweaks + * added tests for same-namespace new connection handling + * do not call apply if packet id is not in acks + * build sio client with make to autogenerate new socket.io.js + * bugfix/1956 don't reuse same-namespace connections #2 + * fix has-binary to work with all objects [gunta] + * bugfix/1956 don't reuse same-namespace connections + * add support for compression [nkzawa] + * fix: location.port was ignored + +1.3.7 / 2015-09-21 +================== + + * package: bump `socket.io` for node4 support + * package: bump `engine.io-client` for node4 compatibility + +1.3.6 / 2015-07-14 +================== + + * package: bump `engine.io-client` to fix build on windows + +1.3.5 / 2015-03-03 +================== + + * package: bump parser + +1.3.4 / 2015-02-14 +================== + + * build `socket.io.js` with `engine.io-client` `1.5.1` + +1.3.3 / 2015-02-03 +================== + + * package: bump parser + +1.3.2 / 2015-01-19 +================== + + * build `socket.io.js` + +1.3.1 / 2015-01-19 +================== + + * no change on this release + * package: bump `engine.io-client` to not depend on `git(1)` for a dep + +1.3.0 / 2015-01-19 +================== + + * package: bump `engine.io-client` + * added `socket.id` property pointing to session id [rase-] + * fix url parsing when uri string is undefined [defunctzombie] + * implemented `backo` for exponential backoff with randomization [mokesmokes] + * reset reconnection attempts state after a successul connection [mokesmokes] + +1.2.1 / 2014-11-21 +================== + + * package: bump `engine.io-client` + * README: fixes to prevent duplicate events [nkzawa] + * fix reconnection after reconnecting manually [nkzawa] + * make ACK callbacks idempotent [thexeos] + * package: bump `uglify-js` + +1.2.0 / 2014-10-27 +================== + + * bump `engine.io-client`. + * set `readyState` before engine.io close event + * fix reconnection after reconnecting manually + * enable to stop reconnecting + * downloads badge + * support no schema relative url + * enable to reconnect manually + +1.1.0 / 2014-09-04 +================== + + * socket: fix in `has-binary` + * package: bump `socket.io-parser` + * package: bump `engine.io-client` + * further increase test timeout. + * double to singly quotes in tests. + * extend timeout and remember to close everything in each test case + * fix travis + * add travis + zuul matrix + * use svg instead of png to get better image quality in readme + * make CI build faster + * removed unnecessary code from try block. Only decode packet is needed. + * package: bump `browserify` + * package: bump `engine.io-client` + * fix autoConnect option + * npmignore: ignore `.gitignore` + * package: update `browserify` + * don't fire an extra reconnect when we're not reconnecting + after a failed initial connect attempt + * package: bump `socket.io-parser` for `component-emitter` dep fix + * updated tests to reflect `autoConnect` option + * add `autoConnect` option to wait with connecting + +1.0.6 / 2014-06-19 +================== + + * test fixes on internet explorer + * fixes for duplicate event propagation from manager instance [Rase-] + +1.0.5 / 2014-06-16 +================== + + * package: bump `engine.io-client` for better deps and smaller build + * handle io.connect(null, opts) correctly [audreyt] + * url: fix incorrect ports in certain connections [holic] + * manager: propagate all reconnection events to sockets [Rase-] + * index: added BC for `force new connection` + * socket: fix event buffering while in disconnected state [kevin-roark] + * package: stop using tarballs in dependencies [reid] + * manager: relay `connect_error` and `connect_timeout` to sockets + +1.0.4 / 2014-06-02 +================== + + * update build + +1.0.3 / 2014-05-31 +================== + + * package; bump `socket.io-parser` for binary ACK fix + * package: bump `engine.io-client` for binary UTF8 fix + +1.0.2 / 2014-05-28 +================== + + * package: bump `socket.io-parser` for windows fix + +1.0.1 / 2014-05-28 +================== + + * override npm tag + +1.0.0 / 2014-05-28 +================== + + * stable release + +1.0.0-pre5 / 2014-05-22 +======================= + + * package: bump `engine.io-client` for parser fixes + +1.0.0-pre4 / 2014-05-19 +======================= + + * build + +1.0.0-pre3 / 2014-05-17 +======================= + + * package: bump parser + * package: bump engine.io-client + +1.0.0-pre2 / 2014-04-27 +======================= + + * package: bump `engine.io-client` + * package: bump `zuul` + * allows user-level query string parameters to be in socket.request + * package: bump `socket.io-parser` + * package: bump `engine.io-client` for android fix + * tidy up .gitignore + +1.0.0-pre / 2014-03-14 +====================== + + * implemented `engine.io-client` + * implemented `socket.io-parser` + * implemented `json3` to avoid env pollution + * implemented `debug` + * added binary support + * added `browserify` support + +0.9.11 / 2012-11-02 +=================== + + * Enable use of 'xhr' transport in Node.js + * Fix the problem with disconnecting xhr-polling users + * Add should to devDependencies + * Prefer XmlHttpRequest if CORS is available + * Make client compatible with AMD loaders. + +0.9.10 / 2012-08-10 +=================== + + * fix removeAllListeners to behave as expected. + * set withCredentials to true only if xdomain. + * socket: disable disconnect on unload by default. + +0.9.9 / 2012-08-01 +================== + + * socket: fixed disconnect xhr url and made it actually sync + * *: bump xmlhttprequest dep + +0.9.8 / 2012-07-24 +================== + + * Fixed build. + +0.9.7 / 2012-07-24 +================== + + * iOS websocket crash fix. + * Fixed potential `open` collision. + * Fixed disconnectSync. + +0.9.6 / 2012-04-17 +================== + + * Don't position the jsonp form off the screen (android fix). + +0.9.5 / 2012-04-05 +================== + + * Bumped version. + +0.9.4 / 2012-04-01 +================== + + * Fixes polling loop upon reconnect advice (fixes #438). + +0.9.3 / 2012-03-28 +================== + + * Fix XHR.check, which was throwing an error transparently and causing non-IE browsers to fall back to JSONP [mikito] + * Fixed forced disconnect on window close [zzzaaa] + +0.9.2 / 2012-03-13 +================== + + * Transport order set by "options" [zzzaaa] + +0.9.1-1 / 2012-03-02 +==================== + + * Fixed active-x-obfuscator NPM dependency. + +0.9.1 / 2012-03-02 +================== + + * Misc corrections. + * Added warning within Firefox about webworker test in test runner. + * Update ws dependency [einaros] + * Implemented client side heartbeat checks. [felixge] + * Improved Firewall support with ActiveX obfuscation. [felixge] + * Fixed error handling during connection process. [Outsideris] + +0.9.0 / 2012-02-26 +================== + + * Added DS_Store to gitignore. + * Updated depedencies. + * Bumped uglify + * Tweaking code so it doesn't throw an exception when used inside a WebWorker in Firefox + * Do not rely on Array.prototype.indexOf as it breaks with pages that use the Prototype.js library. + * Windows support landed + * Use @einaros ws module instead of the old crap one + * Fix for broken closeTimeout and 'IE + xhr' goes into infinite loop on disconnection + * Disabled reconnection on error if reconnect option is set to false + * Set withCredentials to true before xhr to fix authentication + * Clears the timeout from reconnection attempt when there is a successful or failed reconnection. + This fixes the issue of setTimeout's carrying over from previous reconnection + and changing (skipping) values of self.reconnectionDelay in the newer reconnection. + * Removed decoding of parameters when chunking the query string. + This was used later on to construct the url to post to the socket.io server + for connection and if we're adding custom parameters of our own to this url + (for example for OAuth authentication) they were being sent decoded, which is wrong. + +0.8.7 / 2011-11-05 +================== + + * Bumped client + +0.8.6 / 2011-10-27 +================== + + * Added WebWorker support. + * Fixed swfobject and web_socket.js to not assume window. + * Fixed CORS detection for webworker. + * Fix `defer` for webkit in a webworker. + * Fixed io.util.request to not rely on window. + * FIxed; use global instead of window and dont rely on document. + * Fixed; JSON-P handshake if CORS is not available. + * Made underlying Transport disconnection trigger immediate socket.io disconnect. + * Fixed warning when compressing with Google Closure Compiler. + * Fixed builder's uglify utf-8 support. + * Added workaround for loading indicator in FF jsonp-polling. [3rd-Eden] + * Fixed host discovery lookup. [holic] + * Fixed close timeout when disconnected/reconnecting. [jscharlach] + * Fixed jsonp-polling feature detection. + * Fixed jsonp-polling client POSTing of \n. + * Fixed test runner on IE6/7 + +0.8.5 / 2011-10-07 +================== + + * Bumped client + +0.8.4 / 2011-09-06 +================== + + * Corrected build + +0.8.3 / 2011-09-03 +================== + + * Fixed `\n` parsing for non-JSON packets. + * Fixed; make Socket.IO XHTML doctype compatible (fixes #460 from server) + * Fixed support for Node.JS running `socket.io-client`. + * Updated repository name in `package.json`. + * Added support for different policy file ports without having to port + forward 843 on the server side [3rd-Eden] + +0.8.2 / 2011-08-29 +================== + + * Fixed flashsocket detection. + +0.8.1 / 2011-08-29 +================== + + * Bump version. + +0.8.0 / 2011-08-28 +================== + + * Added MozWebSocket support (hybi-10 doesn't require API changes) [einaros]. + +0.7.11 / 2011-08-27 +=================== + + * Corrected previous release (missing build). + +0.7.10 / 2011-08-27 +=================== + + * Fix for failing fallback in websockets + +0.7.9 / 2011-08-12 +================== + + * Added check on `Socket#onConnect` to prevent double `connect` events on the main manager. + * Fixed socket namespace connect test. Remove broken alternative namespace connect test. + * Removed test handler for removed test. + * Bumped version to match `socket.io` server. + +0.7.5 / 2011-08-08 +================== + + * Added querystring support for `connect` [3rd-Eden] + * Added partial Node.JS transports support [3rd-Eden, josephg] + * Fixed builder test. + * Changed `util.inherit` to replicate Object.create / __proto__. + * Changed and cleaned up some acceptance tests. + * Fixed race condition with a test that could not be run multiple times. + * Added test for encoding a payload. + * Added the ability to override the transport to use in acceptance test [3rd-Eden] + * Fixed multiple connect packets [DanielBaulig] + * Fixed jsonp-polling over-buffering [3rd-Eden] + * Fixed ascii preservation in minified socket.io client [3rd-Eden] + * Fixed socket.io in situations where the page is not served through utf8. + * Fixed namespaces not reconnecting after disconnect [3rd-Eden] + * Fixed default port for secure connections. + +0.7.4 / 2011-07-12 +================== + + * Added `SocketNamespace#of` shortcut. [3rd-Eden] + * Fixed a IE payload decoding bug. [3rd-Eden] + * Honor document protocol, unless overriden. [dvv] + * Fixed new builder dependencies. [3rd-Eden] + +0.7.3 / 2011-06-30 +================== + + * Fixed; acks don't depend on arity. They're automatic for `.send` and + callback based for `.emit`. [dvv] + * Added support for sub-sockets authorization. [3rd-Eden] + * Added BC support for `new io.connect`. [fat] + * Fixed double `connect` events. [3rd-Eden] + * Fixed reconnection with jsonp-polling maintaining old sessionid. [franck34] + +0.7.2 / 2011-06-22 +================== + + * Added `noop` message type. + +0.7.1 / 2011-06-21 +================== + + * Bumped socket.io dependency version for acceptance tests. + +0.7.0 / 2011-06-21 +================== + + * http://socket.io/announcement.html + diff --git a/node_modules/socket.io/node_modules/socket.io-client/LICENSE b/node_modules/socket.io/node_modules/socket.io-client/LICENSE new file mode 100644 index 0000000..9338df1 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-client/LICENSE @@ -0,0 +1,22 @@ +The MIT License (MIT) + +Copyright (c) 2014 Guillermo Rauch + + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. \ No newline at end of file diff --git a/node_modules/socket.io/node_modules/socket.io-client/README.md b/node_modules/socket.io/node_modules/socket.io-client/README.md new file mode 100644 index 0000000..e7bc2a1 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-client/README.md @@ -0,0 +1,188 @@ + +# socket.io-client + +[![Build Status](https://secure.travis-ci.org/socketio/socket.io-client.svg?branch=master)](http://travis-ci.org/socketio/socket.io-client) +[![Dependency Status](https://david-dm.org/socketio/socket.io-client.svg)](https://david-dm.org/socketio/socket.io-client) +[![devDependency Status](https://david-dm.org/socketio/socket.io-client/dev-status.svg)](https://david-dm.org/socketio/socket.io-client#info=devDependencies) +![NPM version](https://badge.fury.io/js/socket.io-client.svg) +![Downloads](http://img.shields.io/npm/dm/socket.io-client.svg?style=flat) +[![](http://slack.socket.io/badge.svg?)](http://slack.socket.io) + +## How to use + +A standalone build of `socket.io-client` is exposed automatically by the +socket.io server as `/socket.io/socket.io.js`. Alternatively you can +serve the file `socket.io.js` found at the root of this repository. + +```html + + +``` + +Socket.IO is compatible with [browserify](http://browserify.org/). + +### Node.JS (server-side usage) + + Add `socket.io-client` to your `package.json` and then: + + ```js + var socket = require('socket.io-client')('http://localhost'); + socket.on('connect', function(){}); + socket.on('event', function(data){}); + socket.on('disconnect', function(){}); + ``` + +## API + +### IO(url:String, opts:Object):Socket + + Exposed as the `io` namespace in the standalone build, or the result + of calling `require('socket.io-client')`. + + When called, it creates a new `Manager` for the given URL, and attempts + to reuse an existing `Manager` for subsequent calls, unless the + `multiplex` option is passed with `false`. + + The rest of the options are passed to the `Manager` constructor (see below + for details). + + A `Socket` instance is returned for the namespace specified by the + pathname in the URL, defaulting to `/`. For example, if the `url` is + `http://localhost/users`, a transport connection will be established to + `http://localhost` and a Socket.IO connection will be established to + `/users`. + +### IO#protocol + + Socket.io protocol revision number this client works with. + +### IO#Socket + + Reference to the `Socket` constructor. + +### IO#Manager + + Reference to the `Manager` constructor. + +### IO#Emitter + + Reference to the `Emitter` constructor. + +### Manager(url:String, opts:Object) + + A `Manager` represents a connection to a given Socket.IO server. One or + more `Socket` instances are associated with the manager. The manager + can be accessed through the `io` property of each `Socket` instance. + + The `opts` are also passed to `engine.io` upon initialization of the + underlying `Socket`. + + Options: + - `reconnection` whether to reconnect automatically (`true`) + - `reconnectionAttempts` (`Infinity`) before giving up + - `reconnectionDelay` how long to initially wait before attempting a new + reconnection (`1000`). Affected by +/- `randomizationFactor`, + for example the default initial delay will be between 500 to 1500ms. + - `reconnectionDelayMax` maximum amount of time to wait between + reconnections (`5000`). Each attempt increases the reconnection delay by 2x + along with a randomization as above + - `randomizationFactor` (`0.5`), 0 <= randomizationFactor <= 1 + - `timeout` connection timeout before a `connect_error` + and `connect_timeout` events are emitted (`20000`) + - `autoConnect` by setting this false, you have to call `manager.open` + whenever you decide it's appropriate + +#### Events + + - `connect_error`. Fired upon a connection error. + Parameters: + - `Object` error object + - `connect_timeout`. Fired upon a connection timeout. + - `reconnect`. Fired upon a successful reconnection. + Parameters: + - `Number` reconnection attempt number + - `reconnect_attempt`. Fired upon an attempt to reconnect. + - `reconnecting`. Fired upon an attempt to reconnect. + Parameters: + - `Number` reconnection attempt number + - `reconnect_error`. Fired upon a reconnection attempt error. + Parameters: + - `Object` error object + - `reconnect_failed`. Fired when couldn't reconnect within `reconnectionAttempts` + - `ping`. Fired when a ping packet is written out to the server. + - `pong`. Fired when a pong is received from the server. + Parameters: + - `Number` number of ms elapsed since `ping` packet (i.e.: latency). + +The events above are also emitted on the individual sockets that +reconnect that depend on this `Manager`. + +### Manager#reconnection(v:Boolean):Manager + + Sets the `reconnection` option, or returns it if no parameters + are passed. + +### Manager#reconnectionAttempts(v:Boolean):Manager + + Sets the `reconnectionAttempts` option, or returns it if no parameters + are passed. + +### Manager#reconnectionDelay(v:Boolean):Manager + + Sets the `reconectionDelay` option, or returns it if no parameters + are passed. + +### Manager#reconnectionDelayMax(v:Boolean):Manager + + Sets the `reconectionDelayMax` option, or returns it if no parameters + are passed. + +### Manager#timeout(v:Boolean):Manager + + Sets the `timeout` option, or returns it if no parameters + are passed. + +### Socket + +#### Socket#id:String + +A property on the `socket` instance that is equal to the underlying engine.io socket id. + +The property is present once the socket has connected, is removed when the socket disconnects and is updated if the socket reconnects. + +#### Socket#compress(v:Boolean):Socket + + Sets a modifier for a subsequent event emission that the event data will + only be _compressed_ if the value is `true`. Defaults to `true` when you don't call the method. + + ```js + socket.compress(false).emit('an event', { some: 'data' }); + ``` + +#### Events + + - `connect`. Fired upon a connection including a successful reconnection. + - `error`. Fired upon a connection error + Parameters: + - `Object` error data + - `disconnect`. Fired upon a disconnection. + - `reconnect`. Fired upon a successful reconnection. + Parameters: + - `Number` reconnection attempt number + - `reconnect_attempt`. Fired upon an attempt to reconnect. + - `reconnecting`. Fired upon an attempt to reconnect. + Parameters: + - `Number` reconnection attempt number + - `reconnect_error`. Fired upon a reconnection attempt error. + Parameters: + - `Object` error object + - `reconnect_failed`. Fired when couldn't reconnect within `reconnectionAttempts` + +## License + +[MIT](/LICENSE) diff --git a/node_modules/socket.io/node_modules/socket.io-client/lib/index.js b/node_modules/socket.io/node_modules/socket.io-client/lib/index.js new file mode 100644 index 0000000..7be6dbf --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-client/lib/index.js @@ -0,0 +1,109 @@ + +/** + * Module dependencies. + */ + +var url = require('./url'); +var parser = require('socket.io-parser'); +var Manager = require('./manager'); +var debug = require('debug')('socket.io-client'); + +/** + * Module exports. + */ + +module.exports = exports = lookup; + +/** + * Managers cache. + */ + +var cache = exports.managers = {}; + +/** + * Looks up an existing `Manager` for multiplexing. + * If the user summons: + * + * `io('http://localhost/a');` + * `io('http://localhost/b');` + * + * We reuse the existing instance based on same scheme/port/host, + * and we initialize sockets for each namespace. + * + * @api public + */ + +function lookup (uri, opts) { + if (typeof uri === 'object') { + opts = uri; + uri = undefined; + } + + opts = opts || {}; + + var parsed = url(uri); + var source = parsed.source; + var id = parsed.id; + var path = parsed.path; + var sameNamespace = cache[id] && path in cache[id].nsps; + var newConnection = opts.forceNew || opts['force new connection'] || + false === opts.multiplex || sameNamespace; + + var io; + + if (newConnection) { + debug('ignoring socket cache for %s', source); + io = Manager(source, opts); + } else { + if (!cache[id]) { + debug('new io instance for %s', source); + cache[id] = Manager(source, opts); + } + io = cache[id]; + } + if (parsed.query && !opts.query) { + opts.query = parsed.query; + } else if (opts && 'object' === typeof opts.query) { + opts.query = encodeQueryString(opts.query); + } + return io.socket(parsed.path, opts); +} +/** + * Helper method to parse query objects to string. + * @param {object} query + * @returns {string} + */ +function encodeQueryString (obj) { + var str = []; + for (var p in obj) { + if (obj.hasOwnProperty(p)) { + str.push(encodeURIComponent(p) + '=' + encodeURIComponent(obj[p])); + } + } + return str.join('&'); +} +/** + * Protocol version. + * + * @api public + */ + +exports.protocol = parser.protocol; + +/** + * `connect`. + * + * @param {String} uri + * @api public + */ + +exports.connect = lookup; + +/** + * Expose constructors for standalone build. + * + * @api public + */ + +exports.Manager = require('./manager'); +exports.Socket = require('./socket'); diff --git a/node_modules/socket.io/node_modules/socket.io-client/lib/manager.js b/node_modules/socket.io/node_modules/socket.io-client/lib/manager.js new file mode 100644 index 0000000..1ad3ead --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-client/lib/manager.js @@ -0,0 +1,560 @@ + +/** + * Module dependencies. + */ + +var eio = require('engine.io-client'); +var Socket = require('./socket'); +var Emitter = require('component-emitter'); +var parser = require('socket.io-parser'); +var on = require('./on'); +var bind = require('component-bind'); +var debug = require('debug')('socket.io-client:manager'); +var indexOf = require('indexof'); +var Backoff = require('backo2'); + +/** + * IE6+ hasOwnProperty + */ + +var has = Object.prototype.hasOwnProperty; + +/** + * Module exports + */ + +module.exports = Manager; + +/** + * `Manager` constructor. + * + * @param {String} engine instance or engine uri/opts + * @param {Object} options + * @api public + */ + +function Manager (uri, opts) { + if (!(this instanceof Manager)) return new Manager(uri, opts); + if (uri && ('object' === typeof uri)) { + opts = uri; + uri = undefined; + } + opts = opts || {}; + + opts.path = opts.path || '/socket.io'; + this.nsps = {}; + this.subs = []; + this.opts = opts; + this.reconnection(opts.reconnection !== false); + this.reconnectionAttempts(opts.reconnectionAttempts || Infinity); + this.reconnectionDelay(opts.reconnectionDelay || 1000); + this.reconnectionDelayMax(opts.reconnectionDelayMax || 5000); + this.randomizationFactor(opts.randomizationFactor || 0.5); + this.backoff = new Backoff({ + min: this.reconnectionDelay(), + max: this.reconnectionDelayMax(), + jitter: this.randomizationFactor() + }); + this.timeout(null == opts.timeout ? 20000 : opts.timeout); + this.readyState = 'closed'; + this.uri = uri; + this.connecting = []; + this.lastPing = null; + this.encoding = false; + this.packetBuffer = []; + this.encoder = new parser.Encoder(); + this.decoder = new parser.Decoder(); + this.autoConnect = opts.autoConnect !== false; + if (this.autoConnect) this.open(); +} + +/** + * Propagate given event to sockets and emit on `this` + * + * @api private + */ + +Manager.prototype.emitAll = function () { + this.emit.apply(this, arguments); + for (var nsp in this.nsps) { + if (has.call(this.nsps, nsp)) { + this.nsps[nsp].emit.apply(this.nsps[nsp], arguments); + } + } +}; + +/** + * Update `socket.id` of all sockets + * + * @api private + */ + +Manager.prototype.updateSocketIds = function () { + for (var nsp in this.nsps) { + if (has.call(this.nsps, nsp)) { + this.nsps[nsp].id = this.engine.id; + } + } +}; + +/** + * Mix in `Emitter`. + */ + +Emitter(Manager.prototype); + +/** + * Sets the `reconnection` config. + * + * @param {Boolean} true/false if it should automatically reconnect + * @return {Manager} self or value + * @api public + */ + +Manager.prototype.reconnection = function (v) { + if (!arguments.length) return this._reconnection; + this._reconnection = !!v; + return this; +}; + +/** + * Sets the reconnection attempts config. + * + * @param {Number} max reconnection attempts before giving up + * @return {Manager} self or value + * @api public + */ + +Manager.prototype.reconnectionAttempts = function (v) { + if (!arguments.length) return this._reconnectionAttempts; + this._reconnectionAttempts = v; + return this; +}; + +/** + * Sets the delay between reconnections. + * + * @param {Number} delay + * @return {Manager} self or value + * @api public + */ + +Manager.prototype.reconnectionDelay = function (v) { + if (!arguments.length) return this._reconnectionDelay; + this._reconnectionDelay = v; + this.backoff && this.backoff.setMin(v); + return this; +}; + +Manager.prototype.randomizationFactor = function (v) { + if (!arguments.length) return this._randomizationFactor; + this._randomizationFactor = v; + this.backoff && this.backoff.setJitter(v); + return this; +}; + +/** + * Sets the maximum delay between reconnections. + * + * @param {Number} delay + * @return {Manager} self or value + * @api public + */ + +Manager.prototype.reconnectionDelayMax = function (v) { + if (!arguments.length) return this._reconnectionDelayMax; + this._reconnectionDelayMax = v; + this.backoff && this.backoff.setMax(v); + return this; +}; + +/** + * Sets the connection timeout. `false` to disable + * + * @return {Manager} self or value + * @api public + */ + +Manager.prototype.timeout = function (v) { + if (!arguments.length) return this._timeout; + this._timeout = v; + return this; +}; + +/** + * Starts trying to reconnect if reconnection is enabled and we have not + * started reconnecting yet + * + * @api private + */ + +Manager.prototype.maybeReconnectOnOpen = function () { + // Only try to reconnect if it's the first time we're connecting + if (!this.reconnecting && this._reconnection && this.backoff.attempts === 0) { + // keeps reconnection from firing twice for the same reconnection loop + this.reconnect(); + } +}; + +/** + * Sets the current transport `socket`. + * + * @param {Function} optional, callback + * @return {Manager} self + * @api public + */ + +Manager.prototype.open = +Manager.prototype.connect = function (fn, opts) { + debug('readyState %s', this.readyState); + if (~this.readyState.indexOf('open')) return this; + + debug('opening %s', this.uri); + this.engine = eio(this.uri, this.opts); + var socket = this.engine; + var self = this; + this.readyState = 'opening'; + this.skipReconnect = false; + + // emit `open` + var openSub = on(socket, 'open', function () { + self.onopen(); + fn && fn(); + }); + + // emit `connect_error` + var errorSub = on(socket, 'error', function (data) { + debug('connect_error'); + self.cleanup(); + self.readyState = 'closed'; + self.emitAll('connect_error', data); + if (fn) { + var err = new Error('Connection error'); + err.data = data; + fn(err); + } else { + // Only do this if there is no fn to handle the error + self.maybeReconnectOnOpen(); + } + }); + + // emit `connect_timeout` + if (false !== this._timeout) { + var timeout = this._timeout; + debug('connect attempt will timeout after %d', timeout); + + // set timer + var timer = setTimeout(function () { + debug('connect attempt timed out after %d', timeout); + openSub.destroy(); + socket.close(); + socket.emit('error', 'timeout'); + self.emitAll('connect_timeout', timeout); + }, timeout); + + this.subs.push({ + destroy: function () { + clearTimeout(timer); + } + }); + } + + this.subs.push(openSub); + this.subs.push(errorSub); + + return this; +}; + +/** + * Called upon transport open. + * + * @api private + */ + +Manager.prototype.onopen = function () { + debug('open'); + + // clear old subs + this.cleanup(); + + // mark as open + this.readyState = 'open'; + this.emit('open'); + + // add new subs + var socket = this.engine; + this.subs.push(on(socket, 'data', bind(this, 'ondata'))); + this.subs.push(on(socket, 'ping', bind(this, 'onping'))); + this.subs.push(on(socket, 'pong', bind(this, 'onpong'))); + this.subs.push(on(socket, 'error', bind(this, 'onerror'))); + this.subs.push(on(socket, 'close', bind(this, 'onclose'))); + this.subs.push(on(this.decoder, 'decoded', bind(this, 'ondecoded'))); +}; + +/** + * Called upon a ping. + * + * @api private + */ + +Manager.prototype.onping = function () { + this.lastPing = new Date(); + this.emitAll('ping'); +}; + +/** + * Called upon a packet. + * + * @api private + */ + +Manager.prototype.onpong = function () { + this.emitAll('pong', new Date() - this.lastPing); +}; + +/** + * Called with data. + * + * @api private + */ + +Manager.prototype.ondata = function (data) { + this.decoder.add(data); +}; + +/** + * Called when parser fully decodes a packet. + * + * @api private + */ + +Manager.prototype.ondecoded = function (packet) { + this.emit('packet', packet); +}; + +/** + * Called upon socket error. + * + * @api private + */ + +Manager.prototype.onerror = function (err) { + debug('error', err); + this.emitAll('error', err); +}; + +/** + * Creates a new socket for the given `nsp`. + * + * @return {Socket} + * @api public + */ + +Manager.prototype.socket = function (nsp, opts) { + var socket = this.nsps[nsp]; + if (!socket) { + socket = new Socket(this, nsp, opts); + this.nsps[nsp] = socket; + var self = this; + socket.on('connecting', onConnecting); + socket.on('connect', function () { + socket.id = self.engine.id; + }); + + if (this.autoConnect) { + // manually call here since connecting evnet is fired before listening + onConnecting(); + } + } + + function onConnecting () { + if (!~indexOf(self.connecting, socket)) { + self.connecting.push(socket); + } + } + + return socket; +}; + +/** + * Called upon a socket close. + * + * @param {Socket} socket + */ + +Manager.prototype.destroy = function (socket) { + var index = indexOf(this.connecting, socket); + if (~index) this.connecting.splice(index, 1); + if (this.connecting.length) return; + + this.close(); +}; + +/** + * Writes a packet. + * + * @param {Object} packet + * @api private + */ + +Manager.prototype.packet = function (packet) { + debug('writing packet %j', packet); + var self = this; + if (packet.query && packet.type === 0) packet.nsp += '?' + packet.query; + + if (!self.encoding) { + // encode, then write to engine with result + self.encoding = true; + this.encoder.encode(packet, function (encodedPackets) { + for (var i = 0; i < encodedPackets.length; i++) { + self.engine.write(encodedPackets[i], packet.options); + } + self.encoding = false; + self.processPacketQueue(); + }); + } else { // add packet to the queue + self.packetBuffer.push(packet); + } +}; + +/** + * If packet buffer is non-empty, begins encoding the + * next packet in line. + * + * @api private + */ + +Manager.prototype.processPacketQueue = function () { + if (this.packetBuffer.length > 0 && !this.encoding) { + var pack = this.packetBuffer.shift(); + this.packet(pack); + } +}; + +/** + * Clean up transport subscriptions and packet buffer. + * + * @api private + */ + +Manager.prototype.cleanup = function () { + debug('cleanup'); + + var subsLength = this.subs.length; + for (var i = 0; i < subsLength; i++) { + var sub = this.subs.shift(); + sub.destroy(); + } + + this.packetBuffer = []; + this.encoding = false; + this.lastPing = null; + + this.decoder.destroy(); +}; + +/** + * Close the current socket. + * + * @api private + */ + +Manager.prototype.close = +Manager.prototype.disconnect = function () { + debug('disconnect'); + this.skipReconnect = true; + this.reconnecting = false; + if ('opening' === this.readyState) { + // `onclose` will not fire because + // an open event never happened + this.cleanup(); + } + this.backoff.reset(); + this.readyState = 'closed'; + if (this.engine) this.engine.close(); +}; + +/** + * Called upon engine close. + * + * @api private + */ + +Manager.prototype.onclose = function (reason) { + debug('onclose'); + + this.cleanup(); + this.backoff.reset(); + this.readyState = 'closed'; + this.emit('close', reason); + + if (this._reconnection && !this.skipReconnect) { + this.reconnect(); + } +}; + +/** + * Attempt a reconnection. + * + * @api private + */ + +Manager.prototype.reconnect = function () { + if (this.reconnecting || this.skipReconnect) return this; + + var self = this; + + if (this.backoff.attempts >= this._reconnectionAttempts) { + debug('reconnect failed'); + this.backoff.reset(); + this.emitAll('reconnect_failed'); + this.reconnecting = false; + } else { + var delay = this.backoff.duration(); + debug('will wait %dms before reconnect attempt', delay); + + this.reconnecting = true; + var timer = setTimeout(function () { + if (self.skipReconnect) return; + + debug('attempting reconnect'); + self.emitAll('reconnect_attempt', self.backoff.attempts); + self.emitAll('reconnecting', self.backoff.attempts); + + // check again for the case socket closed in above events + if (self.skipReconnect) return; + + self.open(function (err) { + if (err) { + debug('reconnect attempt error'); + self.reconnecting = false; + self.reconnect(); + self.emitAll('reconnect_error', err.data); + } else { + debug('reconnect success'); + self.onreconnect(); + } + }); + }, delay); + + this.subs.push({ + destroy: function () { + clearTimeout(timer); + } + }); + } +}; + +/** + * Called upon successful reconnect. + * + * @api private + */ + +Manager.prototype.onreconnect = function () { + var attempt = this.backoff.attempts; + this.reconnecting = false; + this.backoff.reset(); + this.updateSocketIds(); + this.emitAll('reconnect', attempt); +}; diff --git a/node_modules/socket.io/node_modules/socket.io-client/lib/on.js b/node_modules/socket.io/node_modules/socket.io-client/lib/on.js new file mode 100644 index 0000000..fad9264 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-client/lib/on.js @@ -0,0 +1,24 @@ + +/** + * Module exports. + */ + +module.exports = on; + +/** + * Helper for subscriptions. + * + * @param {Object|EventEmitter} obj with `Emitter` mixin or `EventEmitter` + * @param {String} event name + * @param {Function} callback + * @api public + */ + +function on (obj, ev, fn) { + obj.on(ev, fn); + return { + destroy: function () { + obj.removeListener(ev, fn); + } + }; +} diff --git a/node_modules/socket.io/node_modules/socket.io-client/lib/socket.js b/node_modules/socket.io/node_modules/socket.io-client/lib/socket.js new file mode 100644 index 0000000..c7e4d91 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-client/lib/socket.js @@ -0,0 +1,419 @@ + +/** + * Module dependencies. + */ + +var parser = require('socket.io-parser'); +var Emitter = require('component-emitter'); +var toArray = require('to-array'); +var on = require('./on'); +var bind = require('component-bind'); +var debug = require('debug')('socket.io-client:socket'); +var hasBin = require('has-binary'); + +/** + * Module exports. + */ + +module.exports = exports = Socket; + +/** + * Internal events (blacklisted). + * These events can't be emitted by the user. + * + * @api private + */ + +var events = { + connect: 1, + connect_error: 1, + connect_timeout: 1, + connecting: 1, + disconnect: 1, + error: 1, + reconnect: 1, + reconnect_attempt: 1, + reconnect_failed: 1, + reconnect_error: 1, + reconnecting: 1, + ping: 1, + pong: 1 +}; + +/** + * Shortcut to `Emitter#emit`. + */ + +var emit = Emitter.prototype.emit; + +/** + * `Socket` constructor. + * + * @api public + */ + +function Socket (io, nsp, opts) { + this.io = io; + this.nsp = nsp; + this.json = this; // compat + this.ids = 0; + this.acks = {}; + this.receiveBuffer = []; + this.sendBuffer = []; + this.connected = false; + this.disconnected = true; + if (opts && opts.query) { + this.query = opts.query; + } + if (this.io.autoConnect) this.open(); +} + +/** + * Mix in `Emitter`. + */ + +Emitter(Socket.prototype); + +/** + * Subscribe to open, close and packet events + * + * @api private + */ + +Socket.prototype.subEvents = function () { + if (this.subs) return; + + var io = this.io; + this.subs = [ + on(io, 'open', bind(this, 'onopen')), + on(io, 'packet', bind(this, 'onpacket')), + on(io, 'close', bind(this, 'onclose')) + ]; +}; + +/** + * "Opens" the socket. + * + * @api public + */ + +Socket.prototype.open = +Socket.prototype.connect = function () { + if (this.connected) return this; + + this.subEvents(); + this.io.open(); // ensure open + if ('open' === this.io.readyState) this.onopen(); + this.emit('connecting'); + return this; +}; + +/** + * Sends a `message` event. + * + * @return {Socket} self + * @api public + */ + +Socket.prototype.send = function () { + var args = toArray(arguments); + args.unshift('message'); + this.emit.apply(this, args); + return this; +}; + +/** + * Override `emit`. + * If the event is in `events`, it's emitted normally. + * + * @param {String} event name + * @return {Socket} self + * @api public + */ + +Socket.prototype.emit = function (ev) { + if (events.hasOwnProperty(ev)) { + emit.apply(this, arguments); + return this; + } + + var args = toArray(arguments); + var parserType = parser.EVENT; // default + if (hasBin(args)) { parserType = parser.BINARY_EVENT; } // binary + var packet = { type: parserType, data: args }; + + packet.options = {}; + packet.options.compress = !this.flags || false !== this.flags.compress; + + // event ack callback + if ('function' === typeof args[args.length - 1]) { + debug('emitting packet with ack id %d', this.ids); + this.acks[this.ids] = args.pop(); + packet.id = this.ids++; + } + + if (this.connected) { + this.packet(packet); + } else { + this.sendBuffer.push(packet); + } + + delete this.flags; + + return this; +}; + +/** + * Sends a packet. + * + * @param {Object} packet + * @api private + */ + +Socket.prototype.packet = function (packet) { + packet.nsp = this.nsp; + this.io.packet(packet); +}; + +/** + * Called upon engine `open`. + * + * @api private + */ + +Socket.prototype.onopen = function () { + debug('transport is open - connecting'); + + // write connect packet if necessary + if ('/' !== this.nsp) { + if (this.query) { + this.packet({type: parser.CONNECT, query: this.query}); + } else { + this.packet({type: parser.CONNECT}); + } + } +}; + +/** + * Called upon engine `close`. + * + * @param {String} reason + * @api private + */ + +Socket.prototype.onclose = function (reason) { + debug('close (%s)', reason); + this.connected = false; + this.disconnected = true; + delete this.id; + this.emit('disconnect', reason); +}; + +/** + * Called with socket packet. + * + * @param {Object} packet + * @api private + */ + +Socket.prototype.onpacket = function (packet) { + if (packet.nsp !== this.nsp) return; + + switch (packet.type) { + case parser.CONNECT: + this.onconnect(); + break; + + case parser.EVENT: + this.onevent(packet); + break; + + case parser.BINARY_EVENT: + this.onevent(packet); + break; + + case parser.ACK: + this.onack(packet); + break; + + case parser.BINARY_ACK: + this.onack(packet); + break; + + case parser.DISCONNECT: + this.ondisconnect(); + break; + + case parser.ERROR: + this.emit('error', packet.data); + break; + } +}; + +/** + * Called upon a server event. + * + * @param {Object} packet + * @api private + */ + +Socket.prototype.onevent = function (packet) { + var args = packet.data || []; + debug('emitting event %j', args); + + if (null != packet.id) { + debug('attaching ack callback to event'); + args.push(this.ack(packet.id)); + } + + if (this.connected) { + emit.apply(this, args); + } else { + this.receiveBuffer.push(args); + } +}; + +/** + * Produces an ack callback to emit with an event. + * + * @api private + */ + +Socket.prototype.ack = function (id) { + var self = this; + var sent = false; + return function () { + // prevent double callbacks + if (sent) return; + sent = true; + var args = toArray(arguments); + debug('sending ack %j', args); + + var type = hasBin(args) ? parser.BINARY_ACK : parser.ACK; + self.packet({ + type: type, + id: id, + data: args + }); + }; +}; + +/** + * Called upon a server acknowlegement. + * + * @param {Object} packet + * @api private + */ + +Socket.prototype.onack = function (packet) { + var ack = this.acks[packet.id]; + if ('function' === typeof ack) { + debug('calling ack %s with %j', packet.id, packet.data); + ack.apply(this, packet.data); + delete this.acks[packet.id]; + } else { + debug('bad ack %s', packet.id); + } +}; + +/** + * Called upon server connect. + * + * @api private + */ + +Socket.prototype.onconnect = function () { + this.connected = true; + this.disconnected = false; + this.emit('connect'); + this.emitBuffered(); +}; + +/** + * Emit buffered events (received and emitted). + * + * @api private + */ + +Socket.prototype.emitBuffered = function () { + var i; + for (i = 0; i < this.receiveBuffer.length; i++) { + emit.apply(this, this.receiveBuffer[i]); + } + this.receiveBuffer = []; + + for (i = 0; i < this.sendBuffer.length; i++) { + this.packet(this.sendBuffer[i]); + } + this.sendBuffer = []; +}; + +/** + * Called upon server disconnect. + * + * @api private + */ + +Socket.prototype.ondisconnect = function () { + debug('server disconnect (%s)', this.nsp); + this.destroy(); + this.onclose('io server disconnect'); +}; + +/** + * Called upon forced client/server side disconnections, + * this method ensures the manager stops tracking us and + * that reconnections don't get triggered for this. + * + * @api private. + */ + +Socket.prototype.destroy = function () { + if (this.subs) { + // clean subscriptions to avoid reconnections + for (var i = 0; i < this.subs.length; i++) { + this.subs[i].destroy(); + } + this.subs = null; + } + + this.io.destroy(this); +}; + +/** + * Disconnects the socket manually. + * + * @return {Socket} self + * @api public + */ + +Socket.prototype.close = +Socket.prototype.disconnect = function () { + if (this.connected) { + debug('performing disconnect (%s)', this.nsp); + this.packet({ type: parser.DISCONNECT }); + } + + // remove socket from pool + this.destroy(); + + if (this.connected) { + // fire events + this.onclose('io client disconnect'); + } + return this; +}; + +/** + * Sets the compress flag. + * + * @param {Boolean} if `true`, compresses the sending data + * @return {Socket} self + * @api public + */ + +Socket.prototype.compress = function (compress) { + this.flags = this.flags || {}; + this.flags.compress = compress; + return this; +}; diff --git a/node_modules/socket.io/node_modules/socket.io-client/lib/url.js b/node_modules/socket.io/node_modules/socket.io-client/lib/url.js new file mode 100644 index 0000000..8bac542 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-client/lib/url.js @@ -0,0 +1,75 @@ + +/** + * Module dependencies. + */ + +var parseuri = require('parseuri'); +var debug = require('debug')('socket.io-client:url'); + +/** + * Module exports. + */ + +module.exports = url; + +/** + * URL parser. + * + * @param {String} url + * @param {Object} An object meant to mimic window.location. + * Defaults to window.location. + * @api public + */ + +function url (uri, loc) { + var obj = uri; + + // default to window.location + loc = loc || global.location; + if (null == uri) uri = loc.protocol + '//' + loc.host; + + // relative path support + if ('string' === typeof uri) { + if ('/' === uri.charAt(0)) { + if ('/' === uri.charAt(1)) { + uri = loc.protocol + uri; + } else { + uri = loc.host + uri; + } + } + + if (!/^(https?|wss?):\/\//.test(uri)) { + debug('protocol-less url %s', uri); + if ('undefined' !== typeof loc) { + uri = loc.protocol + '//' + uri; + } else { + uri = 'https://' + uri; + } + } + + // parse + debug('parse %s', uri); + obj = parseuri(uri); + } + + // make sure we treat `localhost:80` and `localhost` equally + if (!obj.port) { + if (/^(http|ws)$/.test(obj.protocol)) { + obj.port = '80'; + } else if (/^(http|ws)s$/.test(obj.protocol)) { + obj.port = '443'; + } + } + + obj.path = obj.path || '/'; + + var ipv6 = obj.host.indexOf(':') !== -1; + var host = ipv6 ? '[' + obj.host + ']' : obj.host; + + // define unique id + obj.id = obj.protocol + '://' + host + ':' + obj.port; + // define href + obj.href = obj.protocol + '://' + host + (loc && loc.port === obj.port ? '' : (':' + obj.port)); + + return obj; +} diff --git a/node_modules/socket.io/node_modules/socket.io-client/node_modules/backo2/.npmignore b/node_modules/socket.io/node_modules/socket.io-client/node_modules/backo2/.npmignore new file mode 100644 index 0000000..c2658d7 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-client/node_modules/backo2/.npmignore @@ -0,0 +1 @@ +node_modules/ diff --git a/node_modules/socket.io/node_modules/socket.io-client/node_modules/backo2/History.md b/node_modules/socket.io/node_modules/socket.io-client/node_modules/backo2/History.md new file mode 100644 index 0000000..8eb28b8 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-client/node_modules/backo2/History.md @@ -0,0 +1,12 @@ + +1.0.1 / 2014-02-17 +================== + + * go away decimal point + * history + +1.0.0 / 2014-02-17 +================== + + * add jitter option + * Initial commit diff --git a/node_modules/socket.io/node_modules/socket.io-client/node_modules/backo2/Makefile b/node_modules/socket.io/node_modules/socket.io-client/node_modules/backo2/Makefile new file mode 100644 index 0000000..9987df8 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-client/node_modules/backo2/Makefile @@ -0,0 +1,8 @@ + +test: + @./node_modules/.bin/mocha \ + --require should \ + --reporter dot \ + --bail + +.PHONY: test \ No newline at end of file diff --git a/node_modules/socket.io/node_modules/socket.io-client/node_modules/backo2/Readme.md b/node_modules/socket.io/node_modules/socket.io-client/node_modules/backo2/Readme.md new file mode 100644 index 0000000..0df2a39 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-client/node_modules/backo2/Readme.md @@ -0,0 +1,34 @@ +# backo + + Simple exponential backoff because the others seem to have weird abstractions. + +## Installation + +``` +$ npm install backo +``` + +## Options + + - `min` initial timeout in milliseconds [100] + - `max` max timeout [10000] + - `jitter` [0] + - `factor` [2] + +## Example + +```js +var Backoff = require('backo'); +var backoff = new Backoff({ min: 100, max: 20000 }); + +setTimeout(function(){ + something.reconnect(); +}, backoff.duration()); + +// later when something works +backoff.reset() +``` + +# License + + MIT diff --git a/node_modules/socket.io/node_modules/socket.io-client/node_modules/backo2/component.json b/node_modules/socket.io/node_modules/socket.io-client/node_modules/backo2/component.json new file mode 100644 index 0000000..994845a --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-client/node_modules/backo2/component.json @@ -0,0 +1,11 @@ +{ + "name": "backo", + "repo": "segmentio/backo", + "dependencies": {}, + "version": "1.0.1", + "description": "simple backoff without the weird abstractions", + "keywords": ["backoff"], + "license": "MIT", + "scripts": ["index.js"], + "main": "index.js" +} diff --git a/node_modules/socket.io/node_modules/socket.io-client/node_modules/backo2/index.js b/node_modules/socket.io/node_modules/socket.io-client/node_modules/backo2/index.js new file mode 100644 index 0000000..fac4429 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-client/node_modules/backo2/index.js @@ -0,0 +1,85 @@ + +/** + * Expose `Backoff`. + */ + +module.exports = Backoff; + +/** + * Initialize backoff timer with `opts`. + * + * - `min` initial timeout in milliseconds [100] + * - `max` max timeout [10000] + * - `jitter` [0] + * - `factor` [2] + * + * @param {Object} opts + * @api public + */ + +function Backoff(opts) { + opts = opts || {}; + this.ms = opts.min || 100; + this.max = opts.max || 10000; + this.factor = opts.factor || 2; + this.jitter = opts.jitter > 0 && opts.jitter <= 1 ? opts.jitter : 0; + this.attempts = 0; +} + +/** + * Return the backoff duration. + * + * @return {Number} + * @api public + */ + +Backoff.prototype.duration = function(){ + var ms = this.ms * Math.pow(this.factor, this.attempts++); + if (this.jitter) { + var rand = Math.random(); + var deviation = Math.floor(rand * this.jitter * ms); + ms = (Math.floor(rand * 10) & 1) == 0 ? ms - deviation : ms + deviation; + } + return Math.min(ms, this.max) | 0; +}; + +/** + * Reset the number of attempts. + * + * @api public + */ + +Backoff.prototype.reset = function(){ + this.attempts = 0; +}; + +/** + * Set the minimum duration + * + * @api public + */ + +Backoff.prototype.setMin = function(min){ + this.ms = min; +}; + +/** + * Set the maximum duration + * + * @api public + */ + +Backoff.prototype.setMax = function(max){ + this.max = max; +}; + +/** + * Set the jitter + * + * @api public + */ + +Backoff.prototype.setJitter = function(jitter){ + this.jitter = jitter; +}; + diff --git a/node_modules/socket.io/node_modules/socket.io-client/node_modules/backo2/package.json b/node_modules/socket.io/node_modules/socket.io-client/node_modules/backo2/package.json new file mode 100644 index 0000000..ba5134e --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-client/node_modules/backo2/package.json @@ -0,0 +1,45 @@ +{ + "name": "backo2", + "version": "1.0.2", + "repository": { + "type": "git", + "url": "git+https://github.com/mokesmokes/backo.git" + }, + "description": "simple backoff based on segmentio/backo", + "keywords": [ + "backoff" + ], + "dependencies": {}, + "devDependencies": { + "mocha": "*", + "should": "*" + }, + "license": "MIT", + "gitHead": "3e695bade7756fef2295e8883bf3570a06e5d9ec", + "bugs": { + "url": "https://github.com/mokesmokes/backo/issues" + }, + "homepage": "https://github.com/mokesmokes/backo", + "_id": "backo2@1.0.2", + "scripts": {}, + "_shasum": "31ab1ac8b129363463e35b3ebb69f4dfcfba7947", + "_from": "backo2@1.0.2", + "_npmVersion": "1.4.28", + "_npmUser": { + "name": "mokesmokes", + "email": "mokesmokes@gmail.com" + }, + "maintainers": [ + { + "name": "mokesmokes", + "email": "mokesmokes@gmail.com" + } + ], + "dist": { + "shasum": "31ab1ac8b129363463e35b3ebb69f4dfcfba7947", + "tarball": "https://registry.npmjs.org/backo2/-/backo2-1.0.2.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/backo2/-/backo2-1.0.2.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/socket.io/node_modules/socket.io-client/node_modules/backo2/test/index.js b/node_modules/socket.io/node_modules/socket.io-client/node_modules/backo2/test/index.js new file mode 100644 index 0000000..ea1f6de --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-client/node_modules/backo2/test/index.js @@ -0,0 +1,18 @@ + +var Backoff = require('..'); +var assert = require('assert'); + +describe('.duration()', function(){ + it('should increase the backoff', function(){ + var b = new Backoff; + + assert(100 == b.duration()); + assert(200 == b.duration()); + assert(400 == b.duration()); + assert(800 == b.duration()); + + b.reset(); + assert(100 == b.duration()); + assert(200 == b.duration()); + }) +}) \ No newline at end of file diff --git a/node_modules/socket.io/node_modules/socket.io-client/node_modules/component-bind/.npmignore b/node_modules/socket.io/node_modules/socket.io-client/node_modules/component-bind/.npmignore new file mode 100644 index 0000000..f1250e5 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-client/node_modules/component-bind/.npmignore @@ -0,0 +1,4 @@ +support +test +examples +*.sock diff --git a/node_modules/socket.io/node_modules/socket.io-client/node_modules/component-bind/History.md b/node_modules/socket.io/node_modules/socket.io-client/node_modules/component-bind/History.md new file mode 100644 index 0000000..2795fdb --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-client/node_modules/component-bind/History.md @@ -0,0 +1,13 @@ + +1.0.0 / 2014-05-27 +================== + + * index: use slice ref (#7, @viatropos) + * package: rename package to "component-bind" + * package: add "repository" field (#6, @repoify) + * package: add "component" section + +0.0.1 / 2010-01-03 +================== + + * Initial release diff --git a/node_modules/socket.io/node_modules/socket.io-client/node_modules/component-bind/Makefile b/node_modules/socket.io/node_modules/socket.io-client/node_modules/component-bind/Makefile new file mode 100644 index 0000000..4e9c8d3 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-client/node_modules/component-bind/Makefile @@ -0,0 +1,7 @@ + +test: + @./node_modules/.bin/mocha \ + --require should \ + --reporter spec + +.PHONY: test \ No newline at end of file diff --git a/node_modules/socket.io/node_modules/socket.io-client/node_modules/component-bind/Readme.md b/node_modules/socket.io/node_modules/socket.io-client/node_modules/component-bind/Readme.md new file mode 100644 index 0000000..6a8febc --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-client/node_modules/component-bind/Readme.md @@ -0,0 +1,64 @@ +# bind + + Function binding utility. + +## Installation + +``` +$ component install component/bind +``` + +## API + + - [bind(obj, fn)](#bindobj-fn) + - [bind(obj, fn, ...)](#bindobj-fn-) + - [bind(obj, name)](#bindobj-name) + + + +### bind(obj, fn) +should bind the function to the given object. + +```js +var tobi = { name: 'tobi' }; + +function name() { + return this.name; +} + +var fn = bind(tobi, name); +fn().should.equal('tobi'); +``` + + +### bind(obj, fn, ...) +should curry the remaining arguments. + +```js +function add(a, b) { + return a + b; +} + +bind(null, add)(1, 2).should.equal(3); +bind(null, add, 1)(2).should.equal(3); +bind(null, add, 1, 2)().should.equal(3); +``` + + +### bind(obj, name) +should bind the method of the given name. + +```js +var tobi = { name: 'tobi' }; + +tobi.getName = function() { + return this.name; +}; + +var fn = bind(tobi, 'getName'); +fn().should.equal('tobi'); +``` + +## License + + MIT \ No newline at end of file diff --git a/node_modules/socket.io/node_modules/socket.io-client/node_modules/component-bind/component.json b/node_modules/socket.io/node_modules/socket.io-client/node_modules/component-bind/component.json new file mode 100644 index 0000000..4e1e93f --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-client/node_modules/component-bind/component.json @@ -0,0 +1,13 @@ +{ + "name": "bind", + "version": "1.0.0", + "description": "function binding utility", + "keywords": [ + "bind", + "utility" + ], + "dependencies": {}, + "scripts": [ + "index.js" + ] +} diff --git a/node_modules/socket.io/node_modules/socket.io-client/node_modules/component-bind/index.js b/node_modules/socket.io/node_modules/socket.io-client/node_modules/component-bind/index.js new file mode 100644 index 0000000..4eeb2c0 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-client/node_modules/component-bind/index.js @@ -0,0 +1,23 @@ +/** + * Slice reference. + */ + +var slice = [].slice; + +/** + * Bind `obj` to `fn`. + * + * @param {Object} obj + * @param {Function|String} fn or string + * @return {Function} + * @api public + */ + +module.exports = function(obj, fn){ + if ('string' == typeof fn) fn = obj[fn]; + if ('function' != typeof fn) throw new Error('bind() requires a function'); + var args = slice.call(arguments, 2); + return function(){ + return fn.apply(obj, args.concat(slice.call(arguments))); + } +}; diff --git a/node_modules/socket.io/node_modules/socket.io-client/node_modules/component-bind/package.json b/node_modules/socket.io/node_modules/socket.io-client/node_modules/component-bind/package.json new file mode 100644 index 0000000..b9e113b --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-client/node_modules/component-bind/package.json @@ -0,0 +1,47 @@ +{ + "name": "component-bind", + "version": "1.0.0", + "description": "function binding utility", + "keywords": [ + "bind", + "utility" + ], + "devDependencies": { + "mocha": "*", + "should": "*" + }, + "component": { + "scripts": { + "bind/index.js": "index.js" + } + }, + "repository": { + "type": "git", + "url": "git+https://github.com/component/bind.git" + }, + "bugs": { + "url": "https://github.com/component/bind/issues" + }, + "homepage": "https://github.com/component/bind", + "_id": "component-bind@1.0.0", + "_shasum": "00c608ab7dcd93897c0009651b1d3a8e1e73bbd1", + "_from": "component-bind@1.0.0", + "_npmVersion": "1.4.9", + "_npmUser": { + "name": "tootallnate", + "email": "nathan@tootallnate.net" + }, + "maintainers": [ + { + "name": "tootallnate", + "email": "nathan@tootallnate.net" + } + ], + "dist": { + "shasum": "00c608ab7dcd93897c0009651b1d3a8e1e73bbd1", + "tarball": "https://registry.npmjs.org/component-bind/-/component-bind-1.0.0.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/component-bind/-/component-bind-1.0.0.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/socket.io/node_modules/socket.io-client/node_modules/component-emitter/History.md b/node_modules/socket.io/node_modules/socket.io-client/node_modules/component-emitter/History.md new file mode 100644 index 0000000..2ab0779 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-client/node_modules/component-emitter/History.md @@ -0,0 +1,63 @@ + +1.2.0 / 2014-02-12 +================== + + * prefix events with `$` to support object prototype method names + +1.1.3 / 2014-06-20 +================== + + * republish for npm + * add LICENSE file + +1.1.2 / 2014-02-10 +================== + + * package: rename to "component-emitter" + * package: update "main" and "component" fields + * Add license to Readme (same format as the other components) + * created .npmignore + * travis stuff + +1.1.1 / 2013-12-01 +================== + + * fix .once adding .on to the listener + * docs: Emitter#off() + * component: add `.repo` prop + +1.1.0 / 2013-10-20 +================== + + * add `.addEventListener()` and `.removeEventListener()` aliases + +1.0.1 / 2013-06-27 +================== + + * add support for legacy ie + +1.0.0 / 2013-02-26 +================== + + * add `.off()` support for removing all listeners + +0.0.6 / 2012-10-08 +================== + + * add `this._callbacks` initialization to prevent funky gotcha + +0.0.5 / 2012-09-07 +================== + + * fix `Emitter.call(this)` usage + +0.0.3 / 2012-07-11 +================== + + * add `.listeners()` + * rename `.has()` to `.hasListeners()` + +0.0.2 / 2012-06-28 +================== + + * fix `.off()` with `.once()`-registered callbacks diff --git a/node_modules/socket.io/node_modules/socket.io-client/node_modules/component-emitter/LICENSE b/node_modules/socket.io/node_modules/socket.io-client/node_modules/component-emitter/LICENSE new file mode 100644 index 0000000..de51692 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-client/node_modules/component-emitter/LICENSE @@ -0,0 +1,24 @@ +(The MIT License) + +Copyright (c) 2014 Component contributors + +Permission is hereby granted, free of charge, to any person +obtaining a copy of this software and associated documentation +files (the "Software"), to deal in the Software without +restriction, including without limitation the rights to use, +copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the +Software is furnished to do so, subject to the following +conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES +OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND +NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT +HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, +WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING +FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR +OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/socket.io/node_modules/socket.io-client/node_modules/component-emitter/Readme.md b/node_modules/socket.io/node_modules/socket.io-client/node_modules/component-emitter/Readme.md new file mode 100644 index 0000000..0f3f9b9 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-client/node_modules/component-emitter/Readme.md @@ -0,0 +1,74 @@ +# Emitter [![Build Status](https://travis-ci.org/component/emitter.png)](https://travis-ci.org/component/emitter) + + Event emitter component. + +## Installation + +``` +$ component install component/emitter +``` + +## API + +### Emitter(obj) + + The `Emitter` may also be used as a mixin. For example + a "plain" object may become an emitter, or you may + extend an existing prototype. + + As an `Emitter` instance: + +```js +var Emitter = require('emitter'); +var emitter = new Emitter; +emitter.emit('something'); +``` + + As a mixin: + +```js +var Emitter = require('emitter'); +var user = { name: 'tobi' }; +Emitter(user); + +user.emit('im a user'); +``` + + As a prototype mixin: + +```js +var Emitter = require('emitter'); +Emitter(User.prototype); +``` + +### Emitter#on(event, fn) + + Register an `event` handler `fn`. + +### Emitter#once(event, fn) + + Register a single-shot `event` handler `fn`, + removed immediately after it is invoked the + first time. + +### Emitter#off(event, fn) + + * Pass `event` and `fn` to remove a listener. + * Pass `event` to remove all listeners on that event. + * Pass nothing to remove all listeners on all events. + +### Emitter#emit(event, ...) + + Emit an `event` with variable option args. + +### Emitter#listeners(event) + + Return an array of callbacks, or an empty array. + +### Emitter#hasListeners(event) + + Check if this emitter has `event` handlers. + +## License + +MIT diff --git a/node_modules/socket.io/node_modules/socket.io-client/node_modules/component-emitter/index.js b/node_modules/socket.io/node_modules/socket.io-client/node_modules/component-emitter/index.js new file mode 100644 index 0000000..1c78176 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-client/node_modules/component-emitter/index.js @@ -0,0 +1,161 @@ + +/** + * Expose `Emitter`. + */ + +module.exports = Emitter; + +/** + * Initialize a new `Emitter`. + * + * @api public + */ + +function Emitter(obj) { + if (obj) return mixin(obj); +}; + +/** + * Mixin the emitter properties. + * + * @param {Object} obj + * @return {Object} + * @api private + */ + +function mixin(obj) { + for (var key in Emitter.prototype) { + obj[key] = Emitter.prototype[key]; + } + return obj; +} + +/** + * Listen on the given `event` with `fn`. + * + * @param {String} event + * @param {Function} fn + * @return {Emitter} + * @api public + */ + +Emitter.prototype.on = +Emitter.prototype.addEventListener = function(event, fn){ + this._callbacks = this._callbacks || {}; + (this._callbacks['$' + event] = this._callbacks['$' + event] || []) + .push(fn); + return this; +}; + +/** + * Adds an `event` listener that will be invoked a single + * time then automatically removed. + * + * @param {String} event + * @param {Function} fn + * @return {Emitter} + * @api public + */ + +Emitter.prototype.once = function(event, fn){ + function on() { + this.off(event, on); + fn.apply(this, arguments); + } + + on.fn = fn; + this.on(event, on); + return this; +}; + +/** + * Remove the given callback for `event` or all + * registered callbacks. + * + * @param {String} event + * @param {Function} fn + * @return {Emitter} + * @api public + */ + +Emitter.prototype.off = +Emitter.prototype.removeListener = +Emitter.prototype.removeAllListeners = +Emitter.prototype.removeEventListener = function(event, fn){ + this._callbacks = this._callbacks || {}; + + // all + if (0 == arguments.length) { + this._callbacks = {}; + return this; + } + + // specific event + var callbacks = this._callbacks['$' + event]; + if (!callbacks) return this; + + // remove all handlers + if (1 == arguments.length) { + delete this._callbacks['$' + event]; + return this; + } + + // remove specific handler + var cb; + for (var i = 0; i < callbacks.length; i++) { + cb = callbacks[i]; + if (cb === fn || cb.fn === fn) { + callbacks.splice(i, 1); + break; + } + } + return this; +}; + +/** + * Emit `event` with the given args. + * + * @param {String} event + * @param {Mixed} ... + * @return {Emitter} + */ + +Emitter.prototype.emit = function(event){ + this._callbacks = this._callbacks || {}; + var args = [].slice.call(arguments, 1) + , callbacks = this._callbacks['$' + event]; + + if (callbacks) { + callbacks = callbacks.slice(0); + for (var i = 0, len = callbacks.length; i < len; ++i) { + callbacks[i].apply(this, args); + } + } + + return this; +}; + +/** + * Return array of callbacks for `event`. + * + * @param {String} event + * @return {Array} + * @api public + */ + +Emitter.prototype.listeners = function(event){ + this._callbacks = this._callbacks || {}; + return this._callbacks['$' + event] || []; +}; + +/** + * Check if this emitter has `event` handlers. + * + * @param {String} event + * @return {Boolean} + * @api public + */ + +Emitter.prototype.hasListeners = function(event){ + return !! this.listeners(event).length; +}; diff --git a/node_modules/socket.io/node_modules/socket.io-client/node_modules/component-emitter/package.json b/node_modules/socket.io/node_modules/socket.io-client/node_modules/component-emitter/package.json new file mode 100644 index 0000000..47f6283 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-client/node_modules/component-emitter/package.json @@ -0,0 +1,174 @@ +{ + "name": "component-emitter", + "description": "Event emitter", + "version": "1.2.0", + "license": "MIT", + "devDependencies": { + "mocha": "*", + "should": "*" + }, + "component": { + "scripts": { + "emitter/index.js": "index.js" + } + }, + "main": "index.js", + "repository": { + "type": "git", + "url": "git+https://github.com/component/emitter.git" + }, + "scripts": { + "test": "make test" + }, + "files": [ + "index.js", + "LICENSE" + ], + "gitHead": "4d18307a2cdd2cec16d1fadf9e04f02351a8d62e", + "bugs": { + "url": "https://github.com/component/emitter/issues" + }, + "homepage": "https://github.com/component/emitter", + "_id": "component-emitter@1.2.0", + "_shasum": "ccd113a86388d06482d03de3fc7df98526ba8efe", + "_from": "component-emitter@1.2.0", + "_npmVersion": "2.5.1", + "_nodeVersion": "1.2.0", + "_npmUser": { + "name": "jongleberry", + "email": "jonathanrichardong@gmail.com" + }, + "maintainers": [ + { + "name": "tootallnate", + "email": "nathan@tootallnate.net" + }, + { + "name": "tjholowaychuk", + "email": "tj@vision-media.ca" + }, + { + "name": "rauchg", + "email": "rauchg@gmail.com" + }, + { + "name": "retrofox", + "email": "rdsuarez@gmail.com" + }, + { + "name": "coreh", + "email": "thecoreh@gmail.com" + }, + { + "name": "forbeslindesay", + "email": "forbes@lindesay.co.uk" + }, + { + "name": "kelonye", + "email": "kelonyemitchel@gmail.com" + }, + { + "name": "mattmueller", + "email": "mattmuelle@gmail.com" + }, + { + "name": "yields", + "email": "yields@icloud.com" + }, + { + "name": "anthonyshort", + "email": "antshort@gmail.com" + }, + { + "name": "jongleberry", + "email": "jonathanrichardong@gmail.com" + }, + { + "name": "ianstormtaylor", + "email": "ian@ianstormtaylor.com" + }, + { + "name": "cristiandouce", + "email": "cristian@gravityonmars.com" + }, + { + "name": "swatinem", + "email": "arpad.borsos@googlemail.com" + }, + { + "name": "stagas", + "email": "gstagas@gmail.com" + }, + { + "name": "amasad", + "email": "amjad.masad@gmail.com" + }, + { + "name": "juliangruber", + "email": "julian@juliangruber.com" + }, + { + "name": "shtylman", + "email": "shtylman@gmail.com" + }, + { + "name": "calvinfo", + "email": "calvin@calv.info" + }, + { + "name": "dominicbarnes", + "email": "dominic@dbarnes.info" + }, + { + "name": "blakeembrey", + "email": "hello@blakeembrey.com" + }, + { + "name": "timoxley", + "email": "secoif@gmail.com" + }, + { + "name": "jonathanong", + "email": "jonathanrichardong@gmail.com" + }, + { + "name": "queckezz", + "email": "fabian.eichenberger@gmail.com" + }, + { + "name": "nami-doc", + "email": "vendethiel@hotmail.fr" + }, + { + "name": "clintwood", + "email": "clint@anotherway.co.za" + }, + { + "name": "thehydroimpulse", + "email": "dnfagnan@gmail.com" + }, + { + "name": "stephenmathieson", + "email": "me@stephenmathieson.com" + }, + { + "name": "trevorgerhardt", + "email": "trevorgerhardt@gmail.com" + }, + { + "name": "timaschew", + "email": "timaschew@gmail.com" + }, + { + "name": "hughsk", + "email": "hughskennedy@gmail.com" + } + ], + "dist": { + "shasum": "ccd113a86388d06482d03de3fc7df98526ba8efe", + "tarball": "https://registry.npmjs.org/component-emitter/-/component-emitter-1.2.0.tgz" + }, + "directories": {}, + "_resolved": "http://registry.npmjs.org/component-emitter/-/component-emitter-1.2.0.tgz", + "readme": "ERROR: No README data found!" +} diff --git a/node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/History.md b/node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/History.md new file mode 100644 index 0000000..7a232c7 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/History.md @@ -0,0 +1,605 @@ + +1.7.2 / 2016-10-24 +=================== + + * [fix] Set accept header to */* to support react app proxy (#508) + * [fix] remove a workaround for ios (#465) + * [fix] onPacket now emits data on 'closing' state as well (#484) + * [fix] Obfuscate `ActiveXObject` occurrences (#509) + * [docs] Add missing `onlyBinaryUpgrades` option in the docs (#510) + * [chore] Add Github issue and PR templates (#511) + +1.7.1 / 2016-10-20 +=================== + + * [fix] Define "requestsCount" var and "requests" hash unconditionally (#490) + * [perf] Add all properties to the socket in the constructor (#488) + * [chore] Update zuul browser settings (#504) + * [chore] Bump engine.io-parser to 1.3.1 (#505) + * [chore] Use more-specific imports for StealJS compatibility (#467) + +1.7.0 / 2016-10-05 +=================== + + * [fix] Revert "default `rejectUnauthorized` to `true`" (#496) + * [fix] Use xhr.responseText if xhr.response is not provided (#483) + * [fix] Fix issue with errors during WebSocket creation not being caught (#475) + * [style] Add missing semi-colon (#501) + * [chore] Add gulp & babel in the build process (#455) + * [chore] Add eslint (#458) + * [chore] Bump zuul (#464) + * [chore] Remove unused submodule (#466) + * [chore] Bumping ws to 1.1.1 (#478) + * [chore] Update zuul browser settings following EOL notices (#486) + * [chore] Bump engine.io-parser (#492) + * [chore] Make the build status badge point towards master (#497) + * [chore] Bump zuul to 3.11.0 & zuul-ngrok to 4.0.0 (#498) + * [chore] Restrict files included in npm package (#499) + +1.6.11 / 2016-06-23 +=================== + + * bump version + +1.6.10 / 2016-06-23 +=================== + + * bump version + +1.6.9 / 2016-05-02 +================== + + * default `rejectUnauthorized` to `true` + +1.6.8 / 2016-01-25 +================== + + * safely resolve `ws` module + +1.6.7 / 2016-01-10 +================== + + * prevent `ws` from being added to the bundle + * added jsonp fix for when no ` + +``` + +### With browserify + +Engine.IO is a commonjs module, which means you can include it by using +`require` on the browser and package using [browserify](http://browserify.org/): + +1. install the client package + + ```bash + $ npm install engine.io-client + ``` + +1. write your app code + + ```js + var socket = require('engine.io-client')('ws://localhost'); + socket.on('open', function(){ + socket.on('message', function(data){}); + socket.on('close', function(){}); + }); + ``` + +1. build your app bundle + + ```bash + $ browserify app.js > bundle.js + ``` + +1. include on your page + + ```html + + ``` + +### Sending and receiving binary + +```html + + +``` + +### Node.JS + +Add `engine.io-client` to your `package.json` and then: + +```js +var socket = require('engine.io-client')('ws://localhost'); +socket.on('open', function(){ + socket.on('message', function(data){}); + socket.on('close', function(){}); +}); +``` + +### Node.js with certificates +```js +var opts = { + key: fs.readFileSync('test/fixtures/client.key'), + cert: fs.readFileSync('test/fixtures/client.crt'), + ca: fs.readFileSync('test/fixtures/ca.crt') +}; + +var socket = require('engine.io-client')('ws://localhost', opts); +socket.on('open', function(){ + socket.on('message', function(data){}); + socket.on('close', function(){}); +}); +``` + +### Node.js with extraHeaders +```js +var opts = { + extraHeaders: { + 'X-Custom-Header-For-My-Project': 'my-secret-access-token', + 'Cookie': 'user_session=NI2JlCKF90aE0sJZD9ZzujtdsUqNYSBYxzlTsvdSUe35ZzdtVRGqYFr0kdGxbfc5gUOkR9RGp20GVKza; path=/; expires=Tue, 07-Apr-2015 18:18:08 GMT; secure; HttpOnly' + } +}; + +var socket = require('engine.io-client')('ws://localhost', opts); +socket.on('open', function(){ + socket.on('message', function(data){}); + socket.on('close', function(){}); +}); +``` + +## Features + +- Lightweight +- Runs on browser and node.js seamlessly +- Transports are independent of `Engine` + - Easy to debug + - Easy to unit test +- Runs inside HTML5 WebWorker +- Can send and receive binary data + - Receives as ArrayBuffer or Blob when in browser, and Buffer or ArrayBuffer + in Node + - When XHR2 or WebSockets are used, binary is emitted directly. Otherwise + binary is encoded into base64 strings, and decoded when binary types are + supported. + - With browsers that don't support ArrayBuffer, an object { base64: true, + data: dataAsBase64String } is emitted on the `message` event. + +## API + +### Socket + +The client class. Mixes in [Emitter](http://github.com/component/emitter). +Exposed as `eio` in the browser standalone build. + +#### Properties + +- `protocol` _(Number)_: protocol revision number +- `binaryType` _(String)_ : can be set to 'arraybuffer' or 'blob' in browsers, + and `buffer` or `arraybuffer` in Node. Blob is only used in browser if it's + supported. + +#### Events + +- `open` + - Fired upon successful connection. +- `message` + - Fired when data is received from the server. + - **Arguments** + - `String` | `ArrayBuffer`: utf-8 encoded data or ArrayBuffer containing + binary data +- `close` + - Fired upon disconnection. In compliance with the WebSocket API spec, this event may be + fired even if the `open` event does not occur (i.e. due to connection error or `close()`). +- `error` + - Fired when an error occurs. +- `flush` + - Fired upon completing a buffer flush +- `drain` + - Fired after `drain` event of transport if writeBuffer is empty +- `upgradeError` + - Fired if an error occurs with a transport we're trying to upgrade to. +- `upgrade` + - Fired upon upgrade success, after the new transport is set +- `ping` + - Fired upon _flushing_ a ping packet (ie: actual packet write out) +- `pong` + - Fired upon receiving a pong packet. + +#### Methods + +- **constructor** + - Initializes the client + - **Parameters** + - `String` uri + - `Object`: optional, options object + - **Options** + - `agent` (`http.Agent`): `http.Agent` to use, defaults to `false` (NodeJS only) + - `upgrade` (`Boolean`): defaults to true, whether the client should try + to upgrade the transport from long-polling to something better. + - `forceJSONP` (`Boolean`): forces JSONP for polling transport. + - `jsonp` (`Boolean`): determines whether to use JSONP when + necessary for polling. If disabled (by settings to false) an error will + be emitted (saying "No transports available") if no other transports + are available. If another transport is available for opening a + connection (e.g. WebSocket) that transport + will be used instead. + - `forceBase64` (`Boolean`): forces base 64 encoding for polling transport even when XHR2 responseType is available and WebSocket even if the used standard supports binary. + - `enablesXDR` (`Boolean`): enables XDomainRequest for IE8 to avoid loading bar flashing with click sound. default to `false` because XDomainRequest has a flaw of not sending cookie. + - `timestampRequests` (`Boolean`): whether to add the timestamp with each + transport request. Note: polling requests are always stamped unless this + option is explicitly set to `false` (`false`) + - `timestampParam` (`String`): timestamp parameter (`t`) + - `policyPort` (`Number`): port the policy server listens on (`843`) + - `path` (`String`): path to connect to, default is `/engine.io` + - `transports` (`Array`): a list of transports to try (in order). + Defaults to `['polling', 'websocket']`. `Engine` + always attempts to connect directly with the first one, provided the + feature detection test for it passes. + - `rememberUpgrade` (`Boolean`): defaults to false. + If true and if the previous websocket connection to the server succeeded, + the connection attempt will bypass the normal upgrade process and will initially + try websocket. A connection attempt following a transport error will use the + normal upgrade process. It is recommended you turn this on only when using + SSL/TLS connections, or if you know that your network does not block websockets. + - `pfx` (`String`): Certificate, Private key and CA certificates to use for SSL. Can be used in Node.js client environment to manually specify certificate information. + - `key` (`String`): Private key to use for SSL. Can be used in Node.js client environment to manually specify certificate information. + - `passphrase` (`String`): A string of passphrase for the private key or pfx. Can be used in Node.js client environment to manually specify certificate information. + - `cert` (`String`): Public x509 certificate to use. Can be used in Node.js client environment to manually specify certificate information. + - `ca` (`String`|`Array`): An authority certificate or array of authority certificates to check the remote host against.. Can be used in Node.js client environment to manually specify certificate information. + - `ciphers` (`String`): A string describing the ciphers to use or exclude. Consult the [cipher format list](http://www.openssl.org/docs/apps/ciphers.html#CIPHER_LIST_FORMAT) for details on the format. Can be used in Node.js client environment to manually specify certificate information. + - `rejectUnauthorized` (`Boolean`): If true, the server certificate is verified against the list of supplied CAs. An 'error' event is emitted if verification fails. Verification happens at the connection level, before the HTTP request is sent. Can be used in Node.js client environment to manually specify certificate information. + - `perMessageDeflate` (`Object|Boolean`): parameters of the WebSocket permessage-deflate extension + (see [ws module](https://github.com/einaros/ws) api docs). Set to `false` to disable. (`true`) + - `threshold` (`Number`): data is compressed only if the byte size is above this value. This option is ignored on the browser. (`1024`) + - `extraHeaders` (`Object`): Headers that will be passed for each request to the server (via xhr-polling and via websockets). These values then can be used during handshake or for special proxies. Can only be used in Node.js client environment. + - `onlyBinaryUpgrades` (`Boolean`): whether transport upgrades should be restricted to transports supporting binary data (`false`) +- `send` + - Sends a message to the server + - **Parameters** + - `String` | `ArrayBuffer` | `ArrayBufferView` | `Blob`: data to send + - `Object`: optional, options object + - `Function`: optional, callback upon `drain` + - **Options** + - `compress` (`Boolean`): whether to compress sending data. This option is ignored and forced to be `true` on the browser. (`true`) +- `close` + - Disconnects the client. + +### Transport + +The transport class. Private. _Inherits from EventEmitter_. + +#### Events + +- `poll`: emitted by polling transports upon starting a new request +- `pollComplete`: emitted by polling transports upon completing a request +- `drain`: emitted by polling transports upon a buffer drain + +## Tests + +`engine.io-client` is used to test +[engine](http://github.com/socketio/engine.io). Running the `engine.io` +test suite ensures the client works and vice-versa. + +Browser tests are run using [zuul](https://github.com/defunctzombie/zuul). You can +run the tests locally using the following command. + +``` +./node_modules/.bin/zuul --local 8080 -- test/index.js +``` + +Additionally, `engine.io-client` has a standalone test suite you can run +with `make test` which will run node.js and browser tests. You must have zuul setup with +a saucelabs account. + +## Support + +The support channels for `engine.io-client` are the same as `socket.io`: + - irc.freenode.net **#socket.io** + - [Google Groups](http://groups.google.com/group/socket_io) + - [Website](http://socket.io) + +## Development + +To contribute patches, run tests or benchmarks, make sure to clone the +repository: + +```bash +git clone git://github.com/socketio/engine.io-client.git +``` + +Then: + +```bash +cd engine.io-client +npm install +``` + +See the `Tests` section above for how to run tests before submitting any patches. + +## License + +MIT - Copyright (c) 2014 Automattic, Inc. + diff --git a/node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/engine.io.js b/node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/engine.io.js new file mode 100644 index 0000000..fb5e1b3 --- /dev/null +++ b/node_modules/socket.io/node_modules/socket.io-client/node_modules/engine.io-client/engine.io.js @@ -0,0 +1,4418 @@ +(function webpackUniversalModuleDefinition(root, factory) { + if(typeof exports === 'object' && typeof module === 'object') + module.exports = factory(); + else if(typeof define === 'function' && define.amd) + define([], factory); + else if(typeof exports === 'object') + exports["eio"] = factory(); + else + root["eio"] = factory(); +})(this, function() { +return /******/ (function(modules) { // webpackBootstrap +/******/ // The module cache +/******/ var installedModules = {}; + +/******/ // The require function +/******/ function __webpack_require__(moduleId) { + +/******/ // Check if module is in cache +/******/ if(installedModules[moduleId]) +/******/ return installedModules[moduleId].exports; + +/******/ // Create a new module (and put it into the cache) +/******/ var module = installedModules[moduleId] = { +/******/ exports: {}, +/******/ id: moduleId, +/******/ loaded: false +/******/ }; + +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); + +/******/ // Flag the module as loaded +/******/ module.loaded = true; + +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } + + +/******/ // expose the modules object (__webpack_modules__) +/******/ __webpack_require__.m = modules; + +/******/ // expose the module cache +/******/ __webpack_require__.c = installedModules; + +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = ""; + +/******/ // Load entry module and return exports +/******/ return __webpack_require__(0); +/******/ }) +/************************************************************************/ +/******/ ([ +/* 0 */ +/***/ function(module, exports, __webpack_require__) { + + 'use strict'; + + module.exports = __webpack_require__(1); + +/***/ }, +/* 1 */ +/***/ function(module, exports, __webpack_require__) { + + 'use strict'; + + module.exports = __webpack_require__(2); + + /** + * Exports parser + * + * @api public + * + */ + module.exports.parser = __webpack_require__(9); + +/***/ }, +/* 2 */ +/***/ function(module, exports, __webpack_require__) { + + /* WEBPACK VAR INJECTION */(function(global) {'use strict'; + + var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; + + /** + * Module dependencies. + */ + + var transports = __webpack_require__(3); + var Emitter = __webpack_require__(19); + var debug = __webpack_require__(23)('engine.io-client:socket'); + var index = __webpack_require__(29); + var parser = __webpack_require__(9); + var parseuri = __webpack_require__(30); + var parsejson = __webpack_require__(31); + var parseqs = __webpack_require__(20); + + /** + * Module exports. + */ + + module.exports = Socket; + + /** + * Socket constructor. + * + * @param {String|Object} uri or options + * @param {Object} options + * @api public + */ + + function Socket(uri, opts) { + if (!(this instanceof Socket)) return new Socket(uri, opts); + + opts = opts || {}; + + if (uri && 'object' === (typeof uri === 'undefined' ? 'undefined' : _typeof(uri))) { + opts = uri; + uri = null; + } + + if (uri) { + uri = parseuri(uri); + opts.hostname = uri.host; + opts.secure = uri.protocol === 'https' || uri.protocol === 'wss'; + opts.port = uri.port; + if (uri.query) opts.query = uri.query; + } else if (opts.host) { + opts.hostname = parseuri(opts.host).host; + } + + this.secure = null != opts.secure ? opts.secure : global.location && 'https:' === location.protocol; + + if (opts.hostname && !opts.port) { + // if no port is specified manually, use the protocol default + opts.port = this.secure ? '443' : '80'; + } + + this.agent = opts.agent || false; + this.hostname = opts.hostname || (global.location ? location.hostname : 'localhost'); + this.port = opts.port || (global.location && location.port ? location.port : this.secure ? 443 : 80); + this.query = opts.query || {}; + if ('string' === typeof this.query) this.query = parseqs.decode(this.query); + this.upgrade = false !== opts.upgrade; + this.path = (opts.path || '/engine.io').replace(/\/$/, '') + '/'; + this.forceJSONP = !!opts.forceJSONP; + this.jsonp = false !== opts.jsonp; + this.forceBase64 = !!opts.forceBase64; + this.enablesXDR = !!opts.enablesXDR; + this.timestampParam = opts.timestampParam || 't'; + this.timestampRequests = opts.timestampRequests; + this.transports = opts.transports || ['polling', 'websocket']; + this.readyState = ''; + this.writeBuffer = []; + this.prevBufferLen = 0; + this.policyPort = opts.policyPort || 843; + this.rememberUpgrade = opts.rememberUpgrade || false; + this.binaryType = null; + this.onlyBinaryUpgrades = opts.onlyBinaryUpgrades; + this.perMessageDeflate = false !== opts.perMessageDeflate ? opts.perMessageDeflate || {} : false; + + if (true === this.perMessageDeflate) this.perMessageDeflate = {}; + if (this.perMessageDeflate && null == this.perMessageDeflate.threshold) { + this.perMessageDeflate.threshold = 1024; + } + + // SSL options for Node.js client + this.pfx = opts.pfx || null; + this.key = opts.key || null; + this.passphrase = opts.passphrase || null; + this.cert = opts.cert || null; + this.ca = opts.ca || null; + this.ciphers = opts.ciphers || null; + this.rejectUnauthorized = opts.rejectUnauthorized === undefined ? null : opts.rejectUnauthorized; + + // other options for Node.js client + var freeGlobal = (typeof global === 'undefined' ? 'undefined' : _typeof(global)) === 'object' && global; + if (freeGlobal.global === freeGlobal) { + if (opts.extraHeaders && Object.keys(opts.extraHeaders).length > 0) { + this.extraHeaders = opts.extraHeaders; + } + } + + // set on handshake + this.id = null; + this.upgrades = null; + this.pingInterval = null; + this.pingTimeout = null; + + // set on heartbeat + this.pingIntervalTimer = null; + this.pingTimeoutTimer = null; + + this.open(); + } + + Socket.priorWebsocketSuccess = false; + + /** + * Mix in `Emitter`. + */ + + Emitter(Socket.prototype); + + /** + * Protocol version. + * + * @api public + */ + + Socket.protocol = parser.protocol; // this is an int + + /** + * Expose deps for legacy compatibility + * and standalone browser access. + */ + + Socket.Socket = Socket; + Socket.Transport = __webpack_require__(8); + Socket.transports = __webpack_require__(3); + Socket.parser = __webpack_require__(9); + + /** + * Creates transport of the given type. + * + * @param {String} transport name + * @return {Transport} + * @api private + */ + + Socket.prototype.createTransport = function (name) { + debug('creating transport "%s"', name); + var query = clone(this.query); + + // append engine.io protocol identifier + query.EIO = parser.protocol; + + // transport name + query.transport = name; + + // session id if we already have one + if (this.id) query.sid = this.id; + + var transport = new transports[name]({ + agent: this.agent, + hostname: this.hostname, + port: this.port, + secure: this.secure, + path: this.path, + query: query, + forceJSONP: this.forceJSONP, + jsonp: this.jsonp, + forceBase64: this.forceBase64, + enablesXDR: this.enablesXDR, + timestampRequests: this.timestampRequests, + timestampParam: this.timestampParam, + policyPort: this.policyPort, + socket: this, + pfx: this.pfx, + key: this.key, + passphrase: this.passphrase, + cert: this.cert, + ca: this.ca, + ciphers: this.ciphers, + rejectUnauthorized: this.rejectUnauthorized, + perMessageDeflate: this.perMessageDeflate, + extraHeaders: this.extraHeaders + }); + + return transport; + }; + + function clone(obj) { + var o = {}; + for (var i in obj) { + if (obj.hasOwnProperty(i)) { + o[i] = obj[i]; + } + } + return o; + } + + /** + * Initializes transport to use and starts probe. + * + * @api private + */ + Socket.prototype.open = function () { + var transport; + if (this.rememberUpgrade && Socket.priorWebsocketSuccess && this.transports.indexOf('websocket') !== -1) { + transport = 'websocket'; + } else if (0 === this.transports.length) { + // Emit error on next tick so it can be listened to + var self = this; + setTimeout(function () { + self.emit('error', 'No transports available'); + }, 0); + return; + } else { + transport = this.transports[0]; + } + this.readyState = 'opening'; + + // Retry with the next transport if the transport is disabled (jsonp: false) + try { + transport = this.createTransport(transport); + } catch (e) { + this.transports.shift(); + this.open(); + return; + } + + transport.open(); + this.setTransport(transport); + }; + + /** + * Sets the current transport. Disables the existing one (if any). + * + * @api private + */ + + Socket.prototype.setTransport = function (transport) { + debug('setting transport %s', transport.name); + var self = this; + + if (this.transport) { + debug('clearing existing transport %s', this.transport.name); + this.transport.removeAllListeners(); + } + + // set up transport + this.transport = transport; + + // set up transport listeners + transport.on('drain', function () { + self.onDrain(); + }).on('packet', function (packet) { + self.onPacket(packet); + }).on('error', function (e) { + self.onError(e); + }).on('close', function () { + self.onClose('transport close'); + }); + }; + + /** + * Probes a transport. + * + * @param {String} transport name + * @api private + */ + + Socket.prototype.probe = function (name) { + debug('probing transport "%s"', name); + var transport = this.createTransport(name, { probe: 1 }); + var failed = false; + var self = this; + + Socket.priorWebsocketSuccess = false; + + function onTransportOpen() { + if (self.onlyBinaryUpgrades) { + var upgradeLosesBinary = !this.supportsBinary && self.transport.supportsBinary; + failed = failed || upgradeLosesBinary; + } + if (failed) return; + + debug('probe transport "%s" opened', name); + transport.send([{ type: 'ping', data: 'probe' }]); + transport.once('packet', function (msg) { + if (failed) return; + if ('pong' === msg.type && 'probe' === msg.data) { + debug('probe transport "%s" pong', name); + self.upgrading = true; + self.emit('upgrading', transport); + if (!transport) return; + Socket.priorWebsocketSuccess = 'websocket' === transport.name; + + debug('pausing current transport "%s"', self.transport.name); + self.transport.pause(function () { + if (failed) return; + if ('closed' === self.readyState) return; + debug('changing transport and sending upgrade packet'); + + cleanup(); + + self.setTransport(transport); + transport.send([{ type: 'upgrade' }]); + self.emit('upgrade', transport); + transport = null; + self.upgrading = false; + self.flush(); + }); + } else { + debug('probe transport "%s" failed', name); + var err = new Error('probe error'); + err.transport = transport.name; + self.emit('upgradeError', err); + } + }); + } + + function freezeTransport() { + if (failed) return; + + // Any callback called by transport should be ignored since now + failed = true; + + cleanup(); + + transport.close(); + transport = null; + } + + // Handle any error that happens while probing + function onerror(err) { + var error = new Error('probe error: ' + err); + error.transport = transport.name; + + freezeTransport(); + + debug('probe transport "%s" failed because of error: %s', name, err); + + self.emit('upgradeError', error); + } + + function onTransportClose() { + onerror('transport closed'); + } + + // When the socket is closed while we're probing + function onclose() { + onerror('socket closed'); + } + + // When the socket is upgraded while we're probing + function onupgrade(to) { + if (transport && to.name !== transport.name) { + debug('"%s" works - aborting "%s"', to.name, transport.name); + freezeTransport(); + } + } + + // Remove all listeners on the transport and on self + function cleanup() { + transport.removeListener('open', onTransportOpen); + transport.removeListener('error', onerror); + transport.removeListener('close', onTransportClose); + self.removeListener('close', onclose); + self.removeListener('upgrading', onupgrade); + } + + transport.once('open', onTransportOpen); + transport.once('error', onerror); + transport.once('close', onTransportClose); + + this.once('close', onclose); + this.once('upgrading', onupgrade); + + transport.open(); + }; + + /** + * Called when connection is deemed open. + * + * @api public + */ + + Socket.prototype.onOpen = function () { + debug('socket open'); + this.readyState = 'open'; + Socket.priorWebsocketSuccess = 'websocket' === this.transport.name; + this.emit('open'); + this.flush(); + + // we check for `readyState` in case an `open` + // listener already closed the socket + if ('open' === this.readyState && this.upgrade && this.transport.pause) { + debug('starting upgrade probes'); + for (var i = 0, l = this.upgrades.length; i < l; i++) { + this.probe(this.upgrades[i]); + } + } + }; + + /** + * Handles a packet. + * + * @api private + */ + + Socket.prototype.onPacket = function (packet) { + if ('opening' === this.readyState || 'open' === this.readyState || 'closing' === this.readyState) { + debug('socket receive: type "%s", data "%s"', packet.type, packet.data); + + this.emit('packet', packet); + + // Socket is live - any packet counts + this.emit('heartbeat'); + + switch (packet.type) { + case 'open': + this.onHandshake(parsejson(packet.data)); + break; + + case 'pong': + this.setPing(); + this.emit('pong'); + break; + + case 'error': + var err = new Error('server error'); + err.code = packet.data; + this.onError(err); + break; + + case 'message': + this.emit('data', packet.data); + this.emit('message', packet.data); + break; + } + } else { + debug('packet received with socket readyState "%s"', this.readyState); + } + }; + + /** + * Called upon handshake completion. + * + * @param {Object} handshake obj + * @api private + */ + + Socket.prototype.onHandshake = function (data) { + this.emit('handshake', data); + this.id = data.sid; + this.transport.query.sid = data.sid; + this.upgrades = this.filterUpgrades(data.upgrades); + this.pingInterval = data.pingInterval; + this.pingTimeout = data.pingTimeout; + this.onOpen(); + // In case open handler closes socket + if ('closed' === this.readyState) return; + this.setPing(); + + // Prolong liveness of socket on heartbeat + this.removeListener('heartbeat', this.onHeartbeat); + this.on('heartbeat', this.onHeartbeat); + }; + + /** + * Resets ping timeout. + * + * @api private + */ + + Socket.prototype.onHeartbeat = function (timeout) { + clearTimeout(this.pingTimeoutTimer); + var self = this; + self.pingTimeoutTimer = setTimeout(function () { + if ('closed' === self.readyState) return; + self.onClose('ping timeout'); + }, timeout || self.pingInterval + self.pingTimeout); + }; + + /** + * Pings server every `this.pingInterval` and expects response + * within `this.pingTimeout` or closes connection. + * + * @api private + */ + + Socket.prototype.setPing = function () { + var self = this; + clearTimeout(self.pingIntervalTimer); + self.pingIntervalTimer = setTimeout(function () { + debug('writing ping packet - expecting pong within %sms', self.pingTimeout); + self.ping(); + self.onHeartbeat(self.pingTimeout); + }, self.pingInterval); + }; + + /** + * Sends a ping packet. + * + * @api private + */ + + Socket.prototype.ping = function () { + var self = this; + this.sendPacket('ping', function () { + self.emit('ping'); + }); + }; + + /** + * Called on `drain` event + * + * @api private + */ + + Socket.prototype.onDrain = function () { + this.writeBuffer.splice(0, this.prevBufferLen); + + // setting prevBufferLen = 0 is very important + // for example, when upgrading, upgrade packet is sent over, + // and a nonzero prevBufferLen could cause problems on `drain` + this.prevBufferLen = 0; + + if (0 === this.writeBuffer.length) { + this.emit('drain'); + } else { + this.flush(); + } + }; + + /** + * Flush write buffers. + * + * @api private + */ + + Socket.prototype.flush = function () { + if ('closed' !== this.readyState && this.transport.writable && !this.upgrading && this.writeBuffer.length) { + debug('flushing %d packets in socket', this.writeBuffer.length); + this.transport.send(this.writeBuffer); + // keep track of current length of writeBuffer + // splice writeBuffer and callbackBuffer on `drain` + this.prevBufferLen = this.writeBuffer.length; + this.emit('flush'); + } + }; + + /** + * Sends a message. + * + * @param {String} message. + * @param {Function} callback function. + * @param {Object} options. + * @return {Socket} for chaining. + * @api public + */ + + Socket.prototype.write = Socket.prototype.send = function (msg, options, fn) { + this.sendPacket('message', msg, options, fn); + return this; + }; + + /** + * Sends a packet. + * + * @param {String} packet type. + * @param {String} data. + * @param {Object} options. + * @param {Function} callback function. + * @api private + */ + + Socket.prototype.sendPacket = function (type, data, options, fn) { + if ('function' === typeof data) { + fn = data; + data = undefined; + } + + if ('function' === typeof options) { + fn = options; + options = null; + } + + if ('closing' === this.readyState || 'closed' === this.readyState) { + return; + } + + options = options || {}; + options.compress = false !== options.compress; + + var packet = { + type: type, + data: data, + options: options + }; + this.emit('packetCreate', packet); + this.writeBuffer.push(packet); + if (fn) this.once('flush', fn); + this.flush(); + }; + + /** + * Closes the connection. + * + * @api private + */ + + Socket.prototype.close = function () { + if ('opening' === this.readyState || 'open' === this.readyState) { + this.readyState = 'closing'; + + var self = this; + + if (this.writeBuffer.length) { + this.once('drain', function () { + if (this.upgrading) { + waitForUpgrade(); + } else { + close(); + } + }); + } else if (this.upgrading) { + waitForUpgrade(); + } else { + close(); + } + } + + function close() { + self.onClose('forced close'); + debug('socket closing - telling transport to close'); + self.transport.close(); + } + + function cleanupAndClose() { + self.removeListener('upgrade', cleanupAndClose); + self.removeListener('upgradeError', cleanupAndClose); + close(); + } + + function waitForUpgrade() { + // wait for upgrade to finish since we can't send packets while pausing a transport + self.once('upgrade', cleanupAndClose); + self.once('upgradeError', cleanupAndClose); + } + + return this; + }; + + /** + * Called upon transport error + * + * @api private + */ + + Socket.prototype.onError = function (err) { + debug('socket error %j', err); + Socket.priorWebsocketSuccess = false; + this.emit('error', err); + this.onClose('transport error', err); + }; + + /** + * Called upon transport close. + * + * @api private + */ + + Socket.prototype.onClose = function (reason, desc) { + if ('opening' === this.readyState || 'open' === this.readyState || 'closing' === this.readyState) { + debug('socket close with reason: "%s"', reason); + var self = this; + + // clear timers + clearTimeout(this.pingIntervalTimer); + clearTimeout(this.pingTimeoutTimer); + + // stop event from firing again for transport + this.transport.removeAllListeners('close'); + + // ensure transport won't stay open + this.transport.close(); + + // ignore further transport communication + this.transport.removeAllListeners(); + + // set ready state + this.readyState = 'closed'; + + // clear session id + this.id = null; + + // emit close event + this.emit('close', reason, desc); + + // clean buffers after, so users can still + // grab the buffers on `close` event + self.writeBuffer = []; + self.prevBufferLen = 0; + } + }; + + /** + * Filters upgrades, returning only those matching client transports. + * + * @param {Array} server upgrades + * @api private + * + */ + + Socket.prototype.filterUpgrades = function (upgrades) { + var filteredUpgrades = []; + for (var i = 0, j = upgrades.length; i < j; i++) { + if (~index(this.transports, upgrades[i])) filteredUpgrades.push(upgrades[i]); + } + return filteredUpgrades; + }; + /* WEBPACK VAR INJECTION */}.call(exports, (function() { return this; }()))) + +/***/ }, +/* 3 */ +/***/ function(module, exports, __webpack_require__) { + + /* WEBPACK VAR INJECTION */(function(global) {'use strict'; + + /** + * Module dependencies + */ + + var XMLHttpRequest = __webpack_require__(4); + var XHR = __webpack_require__(6); + var JSONP = __webpack_require__(26); + var websocket = __webpack_require__(27); + + /** + * Export transports. + */ + + exports.polling = polling; + exports.websocket = websocket; + + /** + * Polling transport polymorphic constructor. + * Decides on xhr vs jsonp based on feature detection. + * + * @api private + */ + + function polling(opts) { + var xhr; + var xd = false; + var xs = false; + var jsonp = false !== opts.jsonp; + + if (global.location) { + var isSSL = 'https:' === location.protocol; + var port = location.port; + + // some user agents have empty `location.port` + if (!port) { + port = isSSL ? 443 : 80; + } + + xd = opts.hostname !== location.hostname || port !== opts.port; + xs = opts.secure !== isSSL; + } + + opts.xdomain = xd; + opts.xscheme = xs; + xhr = new XMLHttpRequest(opts); + + if ('open' in xhr && !opts.forceJSONP) { + return new XHR(opts); + } else { + if (!jsonp) throw new Error('JSONP disabled'); + return new JSONP(opts); + } + } + /* WEBPACK VAR INJECTION */}.call(exports, (function() { return this; }()))) + +/***/ }, +/* 4 */ +/***/ function(module, exports, __webpack_require__) { + + /* WEBPACK VAR INJECTION */(function(global) {'use strict'; + + // browser shim for xmlhttprequest module + + var hasCORS = __webpack_require__(5); + + module.exports = function (opts) { + var xdomain = opts.xdomain; + + // scheme must be same when usign XDomainRequest + // http://blogs.msdn.com/b/ieinternals/archive/2010/05/13/xdomainrequest-restrictions-limitations-and-workarounds.aspx + var xscheme = opts.xscheme; + + // XDomainRequest has a flow of not sending cookie, therefore it should be disabled as a default. + // https://github.com/Automattic/engine.io-client/pull/217 + var enablesXDR = opts.enablesXDR; + + // XMLHttpRequest can be disabled on IE + try { + if ('undefined' !== typeof XMLHttpRequest && (!xdomain || hasCORS)) { + return new XMLHttpRequest(); + } + } catch (e) {} + + // Use XDomainRequest for IE8 if enablesXDR is true + // because loading bar keeps flashing when using jsonp-polling + // https://github.com/yujiosaka/socke.io-ie8-loading-example + try { + if ('undefined' !== typeof XDomainRequest && !xscheme && enablesXDR) { + return new XDomainRequest(); + } + } catch (e) {} + + if (!xdomain) { + try { + return new global[['Active'].concat('Object').join('X')]('Microsoft.XMLHTTP'); + } catch (e) {} + } + }; + /* WEBPACK VAR INJECTION */}.call(exports, (function() { return this; }()))) + +/***/ }, +/* 5 */ +/***/ function(module, exports) { + + + /** + * Module exports. + * + * Logic borrowed from Modernizr: + * + * - https://github.com/Modernizr/Modernizr/blob/master/feature-detects/cors.js + */ + + try { + module.exports = typeof XMLHttpRequest !== 'undefined' && + 'withCredentials' in new XMLHttpRequest(); + } catch (err) { + // if XMLHttp support is disabled in IE then it will throw + // when trying to create + module.exports = false; + } + + +/***/ }, +/* 6 */ +/***/ function(module, exports, __webpack_require__) { + + /* WEBPACK VAR INJECTION */(function(global) {'use strict'; + + /** + * Module requirements. + */ + + var XMLHttpRequest = __webpack_require__(4); + var Polling = __webpack_require__(7); + var Emitter = __webpack_require__(19); + var inherit = __webpack_require__(21); + var debug = __webpack_require__(23)('engine.io-client:polling-xhr'); + + /** + * Module exports. + */ + + module.exports = XHR; + module.exports.Request = Request; + + /** + * Empty function + */ + + function empty() {} + + /** + * XHR Polling constructor. + * + * @param {Object} opts + * @api public + */ + + function XHR(opts) { + Polling.call(this, opts); + + if (global.location) { + var isSSL = 'https:' === location.protocol; + var port = location.port; + + // some user agents have empty `location.port` + if (!port) { + port = isSSL ? 443 : 80; + } + + this.xd = opts.hostname !== global.location.hostname || port !== opts.port; + this.xs = opts.secure !== isSSL; + } else { + this.extraHeaders = opts.extraHeaders; + } + } + + /** + * Inherits from Polling. + */ + + inherit(XHR, Polling); + + /** + * XHR supports binary + */ + + XHR.prototype.supportsBinary = true; + + /** + * Creates a request. + * + * @param {String} method + * @api private + */ + + XHR.prototype.request = function (opts) { + opts = opts || {}; + opts.uri = this.uri(); + opts.xd = this.xd; + opts.xs = this.xs; + opts.agent = this.agent || false; + opts.supportsBinary = this.supportsBinary; + opts.enablesXDR = this.enablesXDR; + + // SSL options for Node.js client + opts.pfx = this.pfx; + opts.key = this.key; + opts.passphrase = this.passphrase; + opts.cert = this.cert; + opts.ca = this.ca; + opts.ciphers = this.ciphers; + opts.rejectUnauthorized = this.rejectUnauthorized; + + // other options for Node.js client + opts.extraHeaders = this.extraHeaders; + + return new Request(opts); + }; + + /** + * Sends data. + * + * @param {String} data to send. + * @param {Function} called upon flush. + * @api private + */ + + XHR.prototype.doWrite = function (data, fn) { + var isBinary = typeof data !== 'string' && data !== undefined; + var req = this.request({ method: 'POST', data: data, isBinary: isBinary }); + var self = this; + req.on('success', fn); + req.on('error', function (err) { + self.onError('xhr post error', err); + }); + this.sendXhr = req; + }; + + /** + * Starts a poll cycle. + * + * @api private + */ + + XHR.prototype.doPoll = function () { + debug('xhr poll'); + var req = this.request(); + var self = this; + req.on('data', function (data) { + self.onData(data); + }); + req.on('error', function (err) { + self.onError('xhr poll error', err); + }); + this.pollXhr = req; + }; + + /** + * Request constructor + * + * @param {Object} options + * @api public + */ + + function Request(opts) { + this.method = opts.method || 'GET'; + this.uri = opts.uri; + this.xd = !!opts.xd; + this.xs = !!opts.xs; + this.async = false !== opts.async; + this.data = undefined !== opts.data ? opts.data : null; + this.agent = opts.agent; + this.isBinary = opts.isBinary; + this.supportsBinary = opts.supportsBinary; + this.enablesXDR = opts.enablesXDR; + + // SSL options for Node.js client + this.pfx = opts.pfx; + this.key = opts.key; + this.passphrase = opts.passphrase; + this.cert = opts.cert; + this.ca = opts.ca; + this.ciphers = opts.ciphers; + this.rejectUnauthorized = opts.rejectUnauthorized; + + // other options for Node.js client + this.extraHeaders = opts.extraHeaders; + + this.create(); + } + + /** + * Mix in `Emitter`. + */ + + Emitter(Request.prototype); + + /** + * Creates the XHR object and sends the request. + * + * @api private + */ + + Request.prototype.create = function () { + var opts = { agent: this.agent, xdomain: this.xd, xscheme: this.xs, enablesXDR: this.enablesXDR }; + + // SSL options for Node.js client + opts.pfx = this.pfx; + opts.key = this.key; + opts.passphrase = this.passphrase; + opts.cert = this.cert; + opts.ca = this.ca; + opts.ciphers = this.ciphers; + opts.rejectUnauthorized = this.rejectUnauthorized; + + var xhr = this.xhr = new XMLHttpRequest(opts); + var self = this; + + try { + debug('xhr open %s: %s', this.method, this.uri); + xhr.open(this.method, this.uri, this.async); + try { + if (this.extraHeaders) { + xhr.setDisableHeaderCheck(true); + for (var i in this.extraHeaders) { + if (this.extraHeaders.hasOwnProperty(i)) { + xhr.setRequestHeader(i, this.extraHeaders[i]); + } + } + } + } catch (e) {} + if (this.supportsBinary) { + // This has to be done after open because Firefox is stupid + // http://stackoverflow.com/questions/13216903/get-binary-data-with-xmlhttprequest-in-a-firefox-extension + xhr.responseType = 'arraybuffer'; + } + + if ('POST' === this.method) { + try { + if (this.isBinary) { + xhr.setRequestHeader('Content-type', 'application/octet-stream'); + } else { + xhr.setRequestHeader('Content-type', 'text/plain;charset=UTF-8'); + } + } catch (e) {} + } + + try { + xhr.setRequestHeader('Accept', '*/*'); + } catch (e) {} + + // ie6 check + if ('withCredentials' in xhr) { + xhr.withCredentials = true; + } + + if (this.hasXDR()) { + xhr.onload = function () { + self.onLoad(); + }; + xhr.onerror = function () { + self.onError(xhr.responseText); + }; + } else { + xhr.onreadystatechange = function () { + if (4 !== xhr.readyState) return; + if (200 === xhr.status || 1223 === xhr.status) { + self.onLoad(); + } else { + // make sure the `error` event handler that's user-set + // does not throw in the same tick and gets caught here + setTimeout(function () { + self.onError(xhr.status); + }, 0); + } + }; + } + + debug('xhr data %s', this.data); + xhr.send(this.data); + } catch (e) { + // Need to defer since .create() is called directly fhrom the constructor + // and thus the 'error' event can only be only bound *after* this exception + // occurs. Therefore, also, we cannot throw here at all. + setTimeout(function () { + self.onError(e); + }, 0); + return; + } + + if (global.document) { + this.index = Request.requestsCount++; + Request.requests[this.index] = this; + } + }; + + /** + * Called upon successful response. + * + * @api private + */ + + Request.prototype.onSuccess = function () { + this.emit('success'); + this.cleanup(); + }; + + /** + * Called if we have data. + * + * @api private + */ + + Request.prototype.onData = function (data) { + this.emit('data', data); + this.onSuccess(); + }; + + /** + * Called upon error. + * + * @api private + */ + + Request.prototype.onError = function (err) { + this.emit('error', err); + this.cleanup(true); + }; + + /** + * Cleans up house. + * + * @api private + */ + + Request.prototype.cleanup = function (fromError) { + if ('undefined' === typeof this.xhr || null === this.xhr) { + return; + } + // xmlhttprequest + if (this.hasXDR()) { + this.xhr.onload = this.xhr.onerror = empty; + } else { + this.xhr.onreadystatechange = empty; + } + + if (fromError) { + try { + this.xhr.abort(); + } catch (e) {} + } + + if (global.document) { + delete Request.requests[this.index]; + } + + this.xhr = null; + }; + + /** + * Called upon load. + * + * @api private + */ + + Request.prototype.onLoad = function () { + var data; + try { + var contentType; + try { + contentType = this.xhr.getResponseHeader('Content-Type').split(';')[0]; + } catch (e) {} + if (contentType === 'application/octet-stream') { + data = this.xhr.response || this.xhr.responseText; + } else { + if (!this.supportsBinary) { + data = this.xhr.responseText; + } else { + try { + data = String.fromCharCode.apply(null, new Uint8Array(this.xhr.response)); + } catch (e) { + var ui8Arr = new Uint8Array(this.xhr.response); + var dataArray = []; + for (var idx = 0, length = ui8Arr.length; idx < length; idx++) { + dataArray.push(ui8Arr[idx]); + } + + data = String.fromCharCode.apply(null, dataArray); + } + } + } + } catch (e) { + this.onError(e); + } + if (null != data) { + this.onData(data); + } + }; + + /** + * Check if it has XDomainRequest. + * + * @api private + */ + + Request.prototype.hasXDR = function () { + return 'undefined' !== typeof global.XDomainRequest && !this.xs && this.enablesXDR; + }; + + /** + * Aborts the request. + * + * @api public + */ + + Request.prototype.abort = function () { + this.cleanup(); + }; + + /** + * Aborts pending requests when unloading the window. This is needed to prevent + * memory leaks (e.g. when using IE) and to ensure that no spurious error is + * emitted. + */ + + Request.requestsCount = 0; + Request.requests = {}; + + if (global.document) { + if (global.attachEvent) { + global.attachEvent('onunload', unloadHandler); + } else if (global.addEventListener) { + global.addEventListener('beforeunload', unloadHandler, false); + } + } + + function unloadHandler() { + for (var i in Request.requests) { + if (Request.requests.hasOwnProperty(i)) { + Request.requests[i].abort(); + } + } + } + /* WEBPACK VAR INJECTION */}.call(exports, (function() { return this; }()))) + +/***/ }, +/* 7 */ +/***/ function(module, exports, __webpack_require__) { + + 'use strict'; + + /** + * Module dependencies. + */ + + var Transport = __webpack_require__(8); + var parseqs = __webpack_require__(20); + var parser = __webpack_require__(9); + var inherit = __webpack_require__(21); + var yeast = __webpack_require__(22); + var debug = __webpack_require__(23)('engine.io-client:polling'); + + /** + * Module exports. + */ + + module.exports = Polling; + + /** + * Is XHR2 supported? + */ + + var hasXHR2 = function () { + var XMLHttpRequest = __webpack_require__(4); + var xhr = new XMLHttpRequest({ xdomain: false }); + return null != xhr.responseType; + }(); + + /** + * Polling interface. + * + * @param {Object} opts + * @api private + */ + + function Polling(opts) { + var forceBase64 = opts && opts.forceBase64; + if (!hasXHR2 || forceBase64) { + this.supportsBinary = false; + } + Transport.call(this, opts); + } + + /** + * Inherits from Transport. + */ + + inherit(Polling, Transport); + + /** + * Transport name. + */ + + Polling.prototype.name = 'polling'; + + /** + * Opens the socket (triggers polling). We write a PING message to determine + * when the transport is open. + * + * @api private + */ + + Polling.prototype.doOpen = function () { + this.poll(); + }; + + /** + * Pauses polling. + * + * @param {Function} callback upon buffers are flushed and transport is paused + * @api private + */ + + Polling.prototype.pause = function (onPause) { + var self = this; + + this.readyState = 'pausing'; + + function pause() { + debug('paused'); + self.readyState = 'paused'; + onPause(); + } + + if (this.polling || !this.writable) { + var total = 0; + + if (this.polling) { + debug('we are currently polling - waiting to pause'); + total++; + this.once('pollComplete', function () { + debug('pre-pause polling complete'); + --total || pause(); + }); + } + + if (!this.writable) { + debug('we are currently writing - waiting to pause'); + total++; + this.once('drain', function () { + debug('pre-pause writing complete'); + --total || pause(); + }); + } + } else { + pause(); + } + }; + + /** + * Starts polling cycle. + * + * @api public + */ + + Polling.prototype.poll = function () { + debug('polling'); + this.polling = true; + this.doPoll(); + this.emit('poll'); + }; + + /** + * Overloads onData to detect payloads. + * + * @api private + */ + + Polling.prototype.onData = function (data) { + var self = this; + debug('polling got data %s', data); + var callback = function callback(packet, index, total) { + // if its the first message we consider the transport open + if ('opening' === self.readyState) { + self.onOpen(); + } + + // if its a close packet, we close the ongoing requests + if ('close' === packet.type) { + self.onClose(); + return false; + } + + // otherwise bypass onData and handle the message + self.onPacket(packet); + }; + + // decode payload + parser.decodePayload(data, this.socket.binaryType, callback); + + // if an event did not trigger closing + if ('closed' !== this.readyState) { + // if we got data we're not polling + this.polling = false; + this.emit('pollComplete'); + + if ('open' === this.readyState) { + this.poll(); + } else { + debug('ignoring poll - transport state "%s"', this.readyState); + } + } + }; + + /** + * For polling, send a close packet. + * + * @api private + */ + + Polling.prototype.doClose = function () { + var self = this; + + function close() { + debug('writing close packet'); + self.write([{ type: 'close' }]); + } + + if ('open' === this.readyState) { + debug('transport open - closing'); + close(); + } else { + // in case we're trying to close while + // handshaking is in progress (GH-164) + debug('transport not open - deferring close'); + this.once('open', close); + } + }; + + /** + * Writes a packets payload. + * + * @param {Array} data packets + * @param {Function} drain callback + * @api private + */ + + Polling.prototype.write = function (packets) { + var self = this; + this.writable = false; + var callbackfn = function callbackfn() { + self.writable = true; + self.emit('drain'); + }; + + parser.encodePayload(packets, this.supportsBinary, function (data) { + self.doWrite(data, callbackfn); + }); + }; + + /** + * Generates uri for connection. + * + * @api private + */ + + Polling.prototype.uri = function () { + var query = this.query || {}; + var schema = this.secure ? 'https' : 'http'; + var port = ''; + + // cache busting is forced + if (false !== this.timestampRequests) { + query[this.timestampParam] = yeast(); + } + + if (!this.supportsBinary && !query.sid) { + query.b64 = 1; + } + + query = parseqs.encode(query); + + // avoid port if default for schema + if (this.port && ('https' === schema && this.port !== 443 || 'http' === schema && this.port !== 80)) { + port = ':' + this.port; + } + + // prepend ? to query + if (query.length) { + query = '?' + query; + } + + var ipv6 = this.hostname.indexOf(':') !== -1; + return schema + '://' + (ipv6 ? '[' + this.hostname + ']' : this.hostname) + port + this.path + query; + }; + +/***/ }, +/* 8 */ +/***/ function(module, exports, __webpack_require__) { + + 'use strict'; + + /** + * Module dependencies. + */ + + var parser = __webpack_require__(9); + var Emitter = __webpack_require__(19); + + /** + * Module exports. + */ + + module.exports = Transport; + + /** + * Transport abstract constructor. + * + * @param {Object} options. + * @api private + */ + + function Transport(opts) { + this.path = opts.path; + this.hostname = opts.hostname; + this.port = opts.port; + this.secure = opts.secure; + this.query = opts.query; + this.timestampParam = opts.timestampParam; + this.timestampRequests = opts.timestampRequests; + this.readyState = ''; + this.agent = opts.agent || false; + this.socket = opts.socket; + this.enablesXDR = opts.enablesXDR; + + // SSL options for Node.js client + this.pfx = opts.pfx; + this.key = opts.key; + this.passphrase = opts.passphrase; + this.cert = opts.cert; + this.ca = opts.ca; + this.ciphers = opts.ciphers; + this.rejectUnauthorized = opts.rejectUnauthorized; + + // other options for Node.js client + this.extraHeaders = opts.extraHeaders; + } + + /** + * Mix in `Emitter`. + */ + + Emitter(Transport.prototype); + + /** + * Emits an error. + * + * @param {String} str + * @return {Transport} for chaining + * @api public + */ + + Transport.prototype.onError = function (msg, desc) { + var err = new Error(msg); + err.type = 'TransportError'; + err.description = desc; + this.emit('error', err); + return this; + }; + + /** + * Opens the transport. + * + * @api public + */ + + Transport.prototype.open = function () { + if ('closed' === this.readyState || '' === this.readyState) { + this.readyState = 'opening'; + this.doOpen(); + } + + return this; + }; + + /** + * Closes the transport. + * + * @api private + */ + + Transport.prototype.close = function () { + if ('opening' === this.readyState || 'open' === this.readyState) { + this.doClose(); + this.onClose(); + } + + return this; + }; + + /** + * Sends multiple packets. + * + * @param {Array} packets + * @api private + */ + + Transport.prototype.send = function (packets) { + if ('open' === this.readyState) { + this.write(packets); + } else { + throw new Error('Transport not open'); + } + }; + + /** + * Called upon open + * + * @api private + */ + + Transport.prototype.onOpen = function () { + this.readyState = 'open'; + this.writable = true; + this.emit('open'); + }; + + /** + * Called with data. + * + * @param {String} data + * @api private + */ + + Transport.prototype.onData = function (data) { + var packet = parser.decodePacket(data, this.socket.binaryType); + this.onPacket(packet); + }; + + /** + * Called with a decoded packet. + */ + + Transport.prototype.onPacket = function (packet) { + this.emit('packet', packet); + }; + + /** + * Called upon close. + * + * @api private + */ + + Transport.prototype.onClose = function () { + this.readyState = 'closed'; + this.emit('close'); + }; + +/***/ }, +/* 9 */ +/***/ function(module, exports, __webpack_require__) { + + /* WEBPACK VAR INJECTION */(function(global) {/** + * Module dependencies. + */ + + var keys = __webpack_require__(10); + var hasBinary = __webpack_require__(11); + var sliceBuffer = __webpack_require__(13); + var after = __webpack_require__(14); + var utf8 = __webpack_require__(15); + + var base64encoder; + if (global.ArrayBuffer) { + base64encoder = __webpack_require__(17); + } + + /** + * Check if we are running an android browser. That requires us to use + * ArrayBuffer with polling transports... + * + * http://ghinda.net/jpeg-blob-ajax-android/ + */ + + var isAndroid = typeof navigator !== 'undefined' && /Android/i.test(navigator.userAgent); + + /** + * Check if we are running in PhantomJS. + * Uploading a Blob with PhantomJS does not work correctly, as reported here: + * https://github.com/ariya/phantomjs/issues/11395 + * @type boolean + */ + var isPhantomJS = typeof navigator !== 'undefined' && /PhantomJS/i.test(navigator.userAgent); + + /** + * When true, avoids using Blobs to encode payloads. + * @type boolean + */ + var dontSendBlobs = isAndroid || isPhantomJS; + + /** + * Current protocol version. + */ + + exports.protocol = 3; + + /** + * Packet types. + */ + + var packets = exports.packets = { + open: 0 // non-ws + , close: 1 // non-ws + , ping: 2 + , pong: 3 + , message: 4 + , upgrade: 5 + , noop: 6 + }; + + var packetslist = keys(packets); + + /** + * Premade error packet. + */ + + var err = { type: 'error', data: 'parser error' }; + + /** + * Create a blob api even for blob builder when vendor prefixes exist + */ + + var Blob = __webpack_require__(18); + + /** + * Encodes a packet. + * + * [ ] + * + * Example: + * + * 5hello world + * 3 + * 4 + * + * Binary is encoded in an identical principle + * + * @api private + */ + + exports.encodePacket = function (packet, supportsBinary, utf8encode, callback) { + if ('function' == typeof supportsBinary) { + callback = supportsBinary; + supportsBinary = false; + } + + if ('function' == typeof utf8encode) { + callback = utf8encode; + utf8encode = null; + } + + var data = (packet.data === undefined) + ? undefined + : packet.data.buffer || packet.data; + + if (global.ArrayBuffer && data instanceof ArrayBuffer) { + return encodeArrayBuffer(packet, supportsBinary, callback); + } else if (Blob && data instanceof global.Blob) { + return encodeBlob(packet, supportsBinary, callback); + } + + // might be an object with { base64: true, data: dataAsBase64String } + if (data && data.base64) { + return encodeBase64Object(packet, callback); + } + + // Sending data as a utf-8 string + var encoded = packets[packet.type]; + + // data fragment is optional + if (undefined !== packet.data) { + encoded += utf8encode ? utf8.encode(String(packet.data)) : String(packet.data); + } + + return callback('' + encoded); + + }; + + function encodeBase64Object(packet, callback) { + // packet data is an object { base64: true, data: dataAsBase64String } + var message = 'b' + exports.packets[packet.type] + packet.data.data; + return callback(message); + } + + /** + * Encode packet helpers for binary types + */ + + function encodeArrayBuffer(packet, supportsBinary, callback) { + if (!supportsBinary) { + return exports.encodeBase64Packet(packet, callback); + } + + var data = packet.data; + var contentArray = new Uint8Array(data); + var resultBuffer = new Uint8Array(1 + data.byteLength); + + resultBuffer[0] = packets[packet.type]; + for (var i = 0; i < contentArray.length; i++) { + resultBuffer[i+1] = contentArray[i]; + } + + return callback(resultBuffer.buffer); + } + + function encodeBlobAsArrayBuffer(packet, supportsBinary, callback) { + if (!supportsBinary) { + return exports.encodeBase64Packet(packet, callback); + } + + var fr = new FileReader(); + fr.onload = function() { + packet.data = fr.result; + exports.encodePacket(packet, supportsBinary, true, callback); + }; + return fr.readAsArrayBuffer(packet.data); + } + + function encodeBlob(packet, supportsBinary, callback) { + if (!supportsBinary) { + return exports.encodeBase64Packet(packet, callback); + } + + if (dontSendBlobs) { + return encodeBlobAsArrayBuffer(packet, supportsBinary, callback); + } + + var length = new Uint8Array(1); + length[0] = packets[packet.type]; + var blob = new Blob([length.buffer, packet.data]); + + return callback(blob); + } + + /** + * Encodes a packet with binary data in a base64 string + * + * @param {Object} packet, has `type` and `data` + * @return {String} base64 encoded message + */ + + exports.encodeBase64Packet = function(packet, callback) { + var message = 'b' + exports.packets[packet.type]; + if (Blob && packet.data instanceof global.Blob) { + var fr = new FileReader(); + fr.onload = function() { + var b64 = fr.result.split(',')[1]; + callback(message + b64); + }; + return fr.readAsDataURL(packet.data); + } + + var b64data; + try { + b64data = String.fromCharCode.apply(null, new Uint8Array(packet.data)); + } catch (e) { + // iPhone Safari doesn't let you apply with typed arrays + var typed = new Uint8Array(packet.data); + var basic = new Array(typed.length); + for (var i = 0; i < typed.length; i++) { + basic[i] = typed[i]; + } + b64data = String.fromCharCode.apply(null, basic); + } + message += global.btoa(b64data); + return callback(message); + }; + + /** + * Decodes a packet. Changes format to Blob if requested. + * + * @return {Object} with `type` and `data` (if any) + * @api private + */ + + exports.decodePacket = function (data, binaryType, utf8decode) { + // String data + if (typeof data == 'string' || data === undefined) { + if (data.charAt(0) == 'b') { + return exports.decodeBase64Packet(data.substr(1), binaryType); + } + + if (utf8decode) { + data = tryDecode(data); + if (data === false) { + return err; + } + } + var type = data.charAt(0); + + if (Number(type) != type || !packetslist[type]) { + return err; + } + + if (data.length > 1) { + return { type: packetslist[type], data: data.substring(1) }; + } else { + return { type: packetslist[type] }; + } + } + + var asArray = new Uint8Array(data); + var type = asArray[0]; + var rest = sliceBuffer(data, 1); + if (Blob && binaryType === 'blob') { + rest = new Blob([rest]); + } + return { type: packetslist[type], data: rest }; + }; + + function tryDecode(data) { + try { + data = utf8.decode(data); + } catch (e) { + return false; + } + return data; + } + + /** + * Decodes a packet encoded in a base64 string + * + * @param {String} base64 encoded message + * @return {Object} with `type` and `data` (if any) + */ + + exports.decodeBase64Packet = function(msg, binaryType) { + var type = packetslist[msg.charAt(0)]; + if (!base64encoder) { + return { type: type, data: { base64: true, data: msg.substr(1) } }; + } + + var data = base64encoder.decode(msg.substr(1)); + + if (binaryType === 'blob' && Blob) { + data = new Blob([data]); + } + + return { type: type, data: data }; + }; + + /** + * Encodes multiple messages (payload). + * + * :data + * + * Example: + * + * 11:hello world2:hi + * + * If any contents are binary, they will be encoded as base64 strings. Base64 + * encoded strings are marked with a b before the length specifier + * + * @param {Array} packets + * @api private + */ + + exports.encodePayload = function (packets, supportsBinary, callback) { + if (typeof supportsBinary == 'function') { + callback = supportsBinary; + supportsBinary = null; + } + + var isBinary = hasBinary(packets); + + if (supportsBinary && isBinary) { + if (Blob && !dontSendBlobs) { + return exports.encodePayloadAsBlob(packets, callback); + } + + return exports.encodePayloadAsArrayBuffer(packets, callback); + } + + if (!packets.length) { + return callback('0:'); + } + + function setLengthHeader(message) { + return message.length + ':' + message; + } + + function encodeOne(packet, doneCallback) { + exports.encodePacket(packet, !isBinary ? false : supportsBinary, true, function(message) { + doneCallback(null, setLengthHeader(message)); + }); + } + + map(packets, encodeOne, function(err, results) { + return callback(results.join('')); + }); + }; + + /** + * Async array map using after + */ + + function map(ary, each, done) { + var result = new Array(ary.length); + var next = after(ary.length, done); + + var eachWithIndex = function(i, el, cb) { + each(el, function(error, msg) { + result[i] = msg; + cb(error, result); + }); + }; + + for (var i = 0; i < ary.length; i++) { + eachWithIndex(i, ary[i], next); + } + } + + /* + * Decodes data when a payload is maybe expected. Possible binary contents are + * decoded from their base64 representation + * + * @param {String} data, callback method + * @api public + */ + + exports.decodePayload = function (data, binaryType, callback) { + if (typeof data != 'string') { + return exports.decodePayloadAsBinary(data, binaryType, callback); + } + + if (typeof binaryType === 'function') { + callback = binaryType; + binaryType = null; + } + + var packet; + if (data == '') { + // parser error - ignoring payload + return callback(err, 0, 1); + } + + var length = '' + , n, msg; + + for (var i = 0, l = data.length; i < l; i++) { + var chr = data.charAt(i); + + if (':' != chr) { + length += chr; + } else { + if ('' == length || (length != (n = Number(length)))) { + // parser error - ignoring payload + return callback(err, 0, 1); + } + + msg = data.substr(i + 1, n); + + if (length != msg.length) { + // parser error - ignoring payload + return callback(err, 0, 1); + } + + if (msg.length) { + packet = exports.decodePacket(msg, binaryType, true); + + if (err.type == packet.type && err.data == packet.data) { + // parser error in individual packet - ignoring payload + return callback(err, 0, 1); + } + + var ret = callback(packet, i + n, l); + if (false === ret) return; + } + + // advance cursor + i += n; + length = ''; + } + } + + if (length != '') { + // parser error - ignoring payload + return callback(err, 0, 1); + } + + }; + + /** + * Encodes multiple messages (payload) as binary. + * + * <1 = binary, 0 = string>[...] + * + * Example: + * 1 3 255 1 2 3, if the binary contents are interpreted as 8 bit integers + * + * @param {Array} packets + * @return {ArrayBuffer} encoded payload + * @api private + */ + + exports.encodePayloadAsArrayBuffer = function(packets, callback) { + if (!packets.length) { + return callback(new ArrayBuffer(0)); + } + + function encodeOne(packet, doneCallback) { + exports.encodePacket(packet, true, true, function(data) { + return doneCallback(null, data); + }); + } + + map(packets, encodeOne, function(err, encodedPackets) { + var totalLength = encodedPackets.reduce(function(acc, p) { + var len; + if (typeof p === 'string'){ + len = p.length; + } else { + len = p.byteLength; + } + return acc + len.toString().length + len + 2; // string/binary identifier + separator = 2 + }, 0); + + var resultArray = new Uint8Array(totalLength); + + var bufferIndex = 0; + encodedPackets.forEach(function(p) { + var isString = typeof p === 'string'; + var ab = p; + if (isString) { + var view = new Uint8Array(p.length); + for (var i = 0; i < p.length; i++) { + view[i] = p.charCodeAt(i); + } + ab = view.buffer; + } + + if (isString) { // not true binary + resultArray[bufferIndex++] = 0; + } else { // true binary + resultArray[bufferIndex++] = 1; + } + + var lenStr = ab.byteLength.toString(); + for (var i = 0; i < lenStr.length; i++) { + resultArray[bufferIndex++] = parseInt(lenStr[i]); + } + resultArray[bufferIndex++] = 255; + + var view = new Uint8Array(ab); + for (var i = 0; i < view.length; i++) { + resultArray[bufferIndex++] = view[i]; + } + }); + + return callback(resultArray.buffer); + }); + }; + + /** + * Encode as Blob + */ + + exports.encodePayloadAsBlob = function(packets, callback) { + function encodeOne(packet, doneCallback) { + exports.encodePacket(packet, true, true, function(encoded) { + var binaryIdentifier = new Uint8Array(1); + binaryIdentifier[0] = 1; + if (typeof encoded === 'string') { + var view = new Uint8Array(encoded.length); + for (var i = 0; i < encoded.length; i++) { + view[i] = encoded.charCodeAt(i); + } + encoded = view.buffer; + binaryIdentifier[0] = 0; + } + + var len = (encoded instanceof ArrayBuffer) + ? encoded.byteLength + : encoded.size; + + var lenStr = len.toString(); + var lengthAry = new Uint8Array(lenStr.length + 1); + for (var i = 0; i < lenStr.length; i++) { + lengthAry[i] = parseInt(lenStr[i]); + } + lengthAry[lenStr.length] = 255; + + if (Blob) { + var blob = new Blob([binaryIdentifier.buffer, lengthAry.buffer, encoded]); + doneCallback(null, blob); + } + }); + } + + map(packets, encodeOne, function(err, results) { + return callback(new Blob(results)); + }); + }; + + /* + * Decodes data when a payload is maybe expected. Strings are decoded by + * interpreting each byte as a key code for entries marked to start with 0. See + * description of encodePayloadAsBinary + * + * @param {ArrayBuffer} data, callback method + * @api public + */ + + exports.decodePayloadAsBinary = function (data, binaryType, callback) { + if (typeof binaryType === 'function') { + callback = binaryType; + binaryType = null; + } + + var bufferTail = data; + var buffers = []; + + var numberTooLong = false; + while (bufferTail.byteLength > 0) { + var tailArray = new Uint8Array(bufferTail); + var isString = tailArray[0] === 0; + var msgLength = ''; + + for (var i = 1; ; i++) { + if (tailArray[i] == 255) break; + + if (msgLength.length > 310) { + numberTooLong = true; + break; + } + + msgLength += tailArray[i]; + } + + if(numberTooLong) return callback(err, 0, 1); + + bufferTail = sliceBuffer(bufferTail, 2 + msgLength.length); + msgLength = parseInt(msgLength); + + var msg = sliceBuffer(bufferTail, 0, msgLength); + if (isString) { + try { + msg = String.fromCharCode.apply(null, new Uint8Array(msg)); + } catch (e) { + // iPhone Safari doesn't let you apply to typed arrays + var typed = new Uint8Array(msg); + msg = ''; + for (var i = 0; i < typed.length; i++) { + msg += String.fromCharCode(typed[i]); + } + } + } + + buffers.push(msg); + bufferTail = sliceBuffer(bufferTail, msgLength); + } + + var total = buffers.length; + buffers.forEach(function(buffer, i) { + callback(exports.decodePacket(buffer, binaryType, true), i, total); + }); + }; + + /* WEBPACK VAR INJECTION */}.call(exports, (function() { return this; }()))) + +/***/ }, +/* 10 */ +/***/ function(module, exports) { + + + /** + * Gets the keys for an object. + * + * @return {Array} keys + * @api private + */ + + module.exports = Object.keys || function keys (obj){ + var arr = []; + var has = Object.prototype.hasOwnProperty; + + for (var i in obj) { + if (has.call(obj, i)) { + arr.push(i); + } + } + return arr; + }; + + +/***/ }, +/* 11 */ +/***/ function(module, exports, __webpack_require__) { + + /* WEBPACK VAR INJECTION */(function(global) { + /* + * Module requirements. + */ + + var isArray = __webpack_require__(12); + + /** + * Module exports. + */ + + module.exports = hasBinary; + + /** + * Checks for binary data. + * + * Right now only Buffer and ArrayBuffer are supported.. + * + * @param {Object} anything + * @api public + */ + + function hasBinary(data) { + + function _hasBinary(obj) { + if (!obj) return false; + + if ( (global.Buffer && global.Buffer.isBuffer(obj)) || + (global.ArrayBuffer && obj instanceof ArrayBuffer) || + (global.Blob && obj instanceof Blob) || + (global.File && obj instanceof File) + ) { + return true; + } + + if (isArray(obj)) { + for (var i = 0; i < obj.length; i++) { + if (_hasBinary(obj[i])) { + return true; + } + } + } else if (obj && 'object' == typeof obj) { + if (obj.toJSON) { + obj = obj.toJSON(); + } + + for (var key in obj) { + if (Object.prototype.hasOwnProperty.call(obj, key) && _hasBinary(obj[key])) { + return true; + } + } + } + + return false; + } + + return _hasBinary(data); + } + + /* WEBPACK VAR INJECTION */}.call(exports, (function() { return this; }()))) + +/***/ }, +/* 12 */ +/***/ function(module, exports) { + + module.exports = Array.isArray || function (arr) { + return Object.prototype.toString.call(arr) == '[object Array]'; + }; + + +/***/ }, +/* 13 */ +/***/ function(module, exports) { + + /** + * An abstraction for slicing an arraybuffer even when + * ArrayBuffer.prototype.slice is not supported + * + * @api public + */ + + module.exports = function(arraybuffer, start, end) { + var bytes = arraybuffer.byteLength; + start = start || 0; + end = end || bytes; + + if (arraybuffer.slice) { return arraybuffer.slice(start, end); } + + if (start < 0) { start += bytes; } + if (end < 0) { end += bytes; } + if (end > bytes) { end = bytes; } + + if (start >= bytes || start >= end || bytes === 0) { + return new ArrayBuffer(0); + } + + var abv = new Uint8Array(arraybuffer); + var result = new Uint8Array(end - start); + for (var i = start, ii = 0; i < end; i++, ii++) { + result[ii] = abv[i]; + } + return result.buffer; + }; + + +/***/ }, +/* 14 */ +/***/ function(module, exports) { + + module.exports = after + + function after(count, callback, err_cb) { + var bail = false + err_cb = err_cb || noop + proxy.count = count + + return (count === 0) ? callback() : proxy + + function proxy(err, result) { + if (proxy.count <= 0) { + throw new Error('after called too many times') + } + --proxy.count + + // after first error, rest are passed to err_cb + if (err) { + bail = true + callback(err) + // future error callbacks will go to error handler + callback = err_cb + } else if (proxy.count === 0 && !bail) { + callback(null, result) + } + } + } + + function noop() {} + + +/***/ }, +/* 15 */ +/***/ function(module, exports, __webpack_require__) { + + var __WEBPACK_AMD_DEFINE_RESULT__;/* WEBPACK VAR INJECTION */(function(module, global) {/*! https://mths.be/wtf8 v1.0.0 by @mathias */ + ;(function(root) { + + // Detect free variables `exports` + var freeExports = typeof exports == 'object' && exports; + + // Detect free variable `module` + var freeModule = typeof module == 'object' && module && + module.exports == freeExports && module; + + // Detect free variable `global`, from Node.js or Browserified code, + // and use it as `root` + var freeGlobal = typeof global == 'object' && global; + if (freeGlobal.global === freeGlobal || freeGlobal.window === freeGlobal) { + root = freeGlobal; + } + + /*--------------------------------------------------------------------------*/ + + var stringFromCharCode = String.fromCharCode; + + // Taken from https://mths.be/punycode + function ucs2decode(string) { + var output = []; + var counter = 0; + var length = string.length; + var value; + var extra; + while (counter < length) { + value = string.charCodeAt(counter++); + if (value >= 0xD800 && value <= 0xDBFF && counter < length) { + // high surrogate, and there is a next character + extra = string.charCodeAt(counter++); + if ((extra & 0xFC00) == 0xDC00) { // low surrogate + output.push(((value & 0x3FF) << 10) + (extra & 0x3FF) + 0x10000); + } else { + // unmatched surrogate; only append this code unit, in case the next + // code unit is the high surrogate of a surrogate pair + output.push(value); + counter--; + } + } else { + output.push(value); + } + } + return output; + } + + // Taken from https://mths.be/punycode + function ucs2encode(array) { + var length = array.length; + var index = -1; + var value; + var output = ''; + while (++index < length) { + value = array[index]; + if (value > 0xFFFF) { + value -= 0x10000; + output += stringFromCharCode(value >>> 10 & 0x3FF | 0xD800); + value = 0xDC00 | value & 0x3FF; + } + output += stringFromCharCode(value); + } + return output; + } + + /*--------------------------------------------------------------------------*/ + + function createByte(codePoint, shift) { + return stringFromCharCode(((codePoint >> shift) & 0x3F) | 0x80); + } + + function encodeCodePoint(codePoint) { + if ((codePoint & 0xFFFFFF80) == 0) { // 1-byte sequence + return stringFromCharCode(codePoint); + } + var symbol = ''; + if ((codePoint & 0xFFFFF800) == 0) { // 2-byte sequence + symbol = stringFromCharCode(((codePoint >> 6) & 0x1F) | 0xC0); + } + else if ((codePoint & 0xFFFF0000) == 0) { // 3-byte sequence + symbol = stringFromCharCode(((codePoint >> 12) & 0x0F) | 0xE0); + symbol += createByte(codePoint, 6); + } + else if ((codePoint & 0xFFE00000) == 0) { // 4-byte sequence + symbol = stringFromCharCode(((codePoint >> 18) & 0x07) | 0xF0); + symbol += createByte(codePoint, 12); + symbol += createByte(codePoint, 6); + } + symbol += stringFromCharCode((codePoint & 0x3F) | 0x80); + return symbol; + } + + function wtf8encode(string) { + var codePoints = ucs2decode(string); + var length = codePoints.length; + var index = -1; + var codePoint; + var byteString = ''; + while (++index < length) { + codePoint = codePoints[index]; + byteString += encodeCodePoint(codePoint); + } + return byteString; + } + + /*--------------------------------------------------------------------------*/ + + function readContinuationByte() { + if (byteIndex >= byteCount) { + throw Error('Invalid byte index'); + } + + var continuationByte = byteArray[byteIndex] & 0xFF; + byteIndex++; + + if ((continuationByte & 0xC0) == 0x80) { + return continuationByte & 0x3F; + } + + // If we end up here, it’s not a continuation byte. + throw Error('Invalid continuation byte'); + } + + function decodeSymbol() { + var byte1; + var byte2; + var byte3; + var byte4; + var codePoint; + + if (byteIndex > byteCount) { + throw Error('Invalid byte index'); + } + + if (byteIndex == byteCount) { + return false; + } + + // Read the first byte. + byte1 = byteArray[byteIndex] & 0xFF; + byteIndex++; + + // 1-byte sequence (no continuation bytes) + if ((byte1 & 0x80) == 0) { + return byte1; + } + + // 2-byte sequence + if ((byte1 & 0xE0) == 0xC0) { + var byte2 = readContinuationByte(); + codePoint = ((byte1 & 0x1F) << 6) | byte2; + if (codePoint >= 0x80) { + return codePoint; + } else { + throw Error('Invalid continuation byte'); + } + } + + // 3-byte sequence (may include unpaired surrogates) + if ((byte1 & 0xF0) == 0xE0) { + byte2 = readContinuationByte(); + byte3 = readContinuationByte(); + codePoint = ((byte1 & 0x0F) << 12) | (byte2 << 6) | byte3; + if (codePoint >= 0x0800) { + return codePoint; + } else { + throw Error('Invalid continuation byte'); + } + } + + // 4-byte sequence + if ((byte1 & 0xF8) == 0xF0) { + byte2 = readContinuationByte(); + byte3 = readContinuationByte(); + byte4 = readContinuationByte(); + codePoint = ((byte1 & 0x0F) << 0x12) | (byte2 << 0x0C) | + (byte3 << 0x06) | byte4; + if (codePoint >= 0x010000 && codePoint <= 0x10FFFF) { + return codePoint; + } + } + + throw Error('Invalid WTF-8 detected'); + } + + var byteArray; + var byteCount; + var byteIndex; + function wtf8decode(byteString) { + byteArray = ucs2decode(byteString); + byteCount = byteArray.length; + byteIndex = 0; + var codePoints = []; + var tmp; + while ((tmp = decodeSymbol()) !== false) { + codePoints.push(tmp); + } + return ucs2encode(codePoints); + } + + /*--------------------------------------------------------------------------*/ + + var wtf8 = { + 'version': '1.0.0', + 'encode': wtf8encode, + 'decode': wtf8decode + }; + + // Some AMD build optimizers, like r.js, check for specific condition patterns + // like the following: + if ( + true + ) { + !(__WEBPACK_AMD_DEFINE_RESULT__ = function() { + return wtf8; + }.call(exports, __webpack_require__, exports, module), __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__)); + } else if (freeExports && !freeExports.nodeType) { + if (freeModule) { // in Node.js or RingoJS v0.8.0+ + freeModule.exports = wtf8; + } else { // in Narwhal or RingoJS v0.7.0- + var object = {}; + var hasOwnProperty = object.hasOwnProperty; + for (var key in wtf8) { + hasOwnProperty.call(wtf8, key) && (freeExports[key] = wtf8[key]); + } + } + } else { // in Rhino or a web browser + root.wtf8 = wtf8; + } + + }(this)); + + /* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(16)(module), (function() { return this; }()))) + +/***/ }, +/* 16 */ +/***/ function(module, exports) { + + module.exports = function(module) { + if(!module.webpackPolyfill) { + module.deprecate = function() {}; + module.paths = []; + // module.parent = undefined by default + module.children = []; + module.webpackPolyfill = 1; + } + return module; + } + + +/***/ }, +/* 17 */ +/***/ function(module, exports) { + + /* + * base64-arraybuffer + * https://github.com/niklasvh/base64-arraybuffer + * + * Copyright (c) 2012 Niklas von Hertzen + * Licensed under the MIT license. + */ + (function(){ + "use strict"; + + var chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"; + + // Use a lookup table to find the index. + var lookup = new Uint8Array(256); + for (var i = 0; i < chars.length; i++) { + lookup[chars.charCodeAt(i)] = i; + } + + exports.encode = function(arraybuffer) { + var bytes = new Uint8Array(arraybuffer), + i, len = bytes.length, base64 = ""; + + for (i = 0; i < len; i+=3) { + base64 += chars[bytes[i] >> 2]; + base64 += chars[((bytes[i] & 3) << 4) | (bytes[i + 1] >> 4)]; + base64 += chars[((bytes[i + 1] & 15) << 2) | (bytes[i + 2] >> 6)]; + base64 += chars[bytes[i + 2] & 63]; + } + + if ((len % 3) === 2) { + base64 = base64.substring(0, base64.length - 1) + "="; + } else if (len % 3 === 1) { + base64 = base64.substring(0, base64.length - 2) + "=="; + } + + return base64; + }; + + exports.decode = function(base64) { + var bufferLength = base64.length * 0.75, + len = base64.length, i, p = 0, + encoded1, encoded2, encoded3, encoded4; + + if (base64[base64.length - 1] === "=") { + bufferLength--; + if (base64[base64.length - 2] === "=") { + bufferLength--; + } + } + + var arraybuffer = new ArrayBuffer(bufferLength), + bytes = new Uint8Array(arraybuffer); + + for (i = 0; i < len; i+=4) { + encoded1 = lookup[base64.charCodeAt(i)]; + encoded2 = lookup[base64.charCodeAt(i+1)]; + encoded3 = lookup[base64.charCodeAt(i+2)]; + encoded4 = lookup[base64.charCodeAt(i+3)]; + + bytes[p++] = (encoded1 << 2) | (encoded2 >> 4); + bytes[p++] = ((encoded2 & 15) << 4) | (encoded3 >> 2); + bytes[p++] = ((encoded3 & 3) << 6) | (encoded4 & 63); + } + + return arraybuffer; + }; + })(); + + +/***/ }, +/* 18 */ +/***/ function(module, exports) { + + /* WEBPACK VAR INJECTION */(function(global) {/** + * Create a blob builder even when vendor prefixes exist + */ + + var BlobBuilder = global.BlobBuilder + || global.WebKitBlobBuilder + || global.MSBlobBuilder + || global.MozBlobBuilder; + + /** + * Check if Blob constructor is supported + */ + + var blobSupported = (function() { + try { + var a = new Blob(['hi']); + return a.size === 2; + } catch(e) { + return false; + } + })(); + + /** + * Check if Blob constructor supports ArrayBufferViews + * Fails in Safari 6, so we need to map to ArrayBuffers there. + */ + + var blobSupportsArrayBufferView = blobSupported && (function() { + try { + var b = new Blob([new Uint8Array([1,2])]); + return b.size === 2; + } catch(e) { + return false; + } + })(); + + /** + * Check if BlobBuilder is supported + */ + + var blobBuilderSupported = BlobBuilder + && BlobBuilder.prototype.append + && BlobBuilder.prototype.getBlob; + + /** + * Helper function that maps ArrayBufferViews to ArrayBuffers + * Used by BlobBuilder constructor and old browsers that didn't + * support it in the Blob constructor. + */ + + function mapArrayBufferViews(ary) { + for (var i = 0; i < ary.length; i++) { + var chunk = ary[i]; + if (chunk.buffer instanceof ArrayBuffer) { + var buf = chunk.buffer; + + // if this is a subarray, make a copy so we only + // include the subarray region from the underlying buffer + if (chunk.byteLength !== buf.byteLength) { + var copy = new Uint8Array(chunk.byteLength); + copy.set(new Uint8Array(buf, chunk.byteOffset, chunk.byteLength)); + buf = copy.buffer; + } + + ary[i] = buf; + } + } + } + + function BlobBuilderConstructor(ary, options) { + options = options || {}; + + var bb = new BlobBuilder(); + mapArrayBufferViews(ary); + + for (var i = 0; i < ary.length; i++) { + bb.append(ary[i]); + } + + return (options.type) ? bb.getBlob(options.type) : bb.getBlob(); + }; + + function BlobConstructor(ary, options) { + mapArrayBufferViews(ary); + return new Blob(ary, options || {}); + }; + + module.exports = (function() { + if (blobSupported) { + return blobSupportsArrayBufferView ? global.Blob : BlobConstructor; + } else if (blobBuilderSupported) { + return BlobBuilderConstructor; + } else { + return undefined; + } + })(); + + /* WEBPACK VAR INJECTION */}.call(exports, (function() { return this; }()))) + +/***/ }, +/* 19 */ +/***/ function(module, exports) { + + + /** + * Expose `Emitter`. + */ + + module.exports = Emitter; + + /** + * Initialize a new `Emitter`. + * + * @api public + */ + + function Emitter(obj) { + if (obj) return mixin(obj); + }; + + /** + * Mixin the emitter properties. + * + * @param {Object} obj + * @return {Object} + * @api private + */ + + function mixin(obj) { + for (var key in Emitter.prototype) { + obj[key] = Emitter.prototype[key]; + } + return obj; + } + + /** + * Listen on the given `event` with `fn`. + * + * @param {String} event + * @param {Function} fn + * @return {Emitter} + * @api public + */ + + Emitter.prototype.on = + Emitter.prototype.addEventListener = function(event, fn){ + this._callbacks = this._callbacks || {}; + (this._callbacks[event] = this._callbacks[event] || []) + .push(fn); + return this; + }; + + /** + * Adds an `event` listener that will be invoked a single + * time then automatically removed. + * + * @param {String} event + * @param {Function} fn + * @return {Emitter} + * @api public + */ + + Emitter.prototype.once = function(event, fn){ + var self = this; + this._callbacks = this._callbacks || {}; + + function on() { + self.off(event, on); + fn.apply(this, arguments); + } + + on.fn = fn; + this.on(event, on); + return this; + }; + + /** + * Remove the given callback for `event` or all + * registered callbacks. + * + * @param {String} event + * @param {Function} fn + * @return {Emitter} + * @api public + */ + + Emitter.prototype.off = + Emitter.prototype.removeListener = + Emitter.prototype.removeAllListeners = + Emitter.prototype.removeEventListener = function(event, fn){ + this._callbacks = this._callbacks || {}; + + // all + if (0 == arguments.length) { + this._callbacks = {}; + return this; + } + + // specific event + var callbacks = this._callbacks[event]; + if (!callbacks) return this; + + // remove all handlers + if (1 == arguments.length) { + delete this._callbacks[event]; + return this; + } + + // remove specific handler + var cb; + for (var i = 0; i < callbacks.length; i++) { + cb = callbacks[i]; + if (cb === fn || cb.fn === fn) { + callbacks.splice(i, 1); + break; + } + } + return this; + }; + + /** + * Emit `event` with the given args. + * + * @param {String} event + * @param {Mixed} ... + * @return {Emitter} + */ + + Emitter.prototype.emit = function(event){ + this._callbacks = this._callbacks || {}; + var args = [].slice.call(arguments, 1) + , callbacks = this._callbacks[event]; + + if (callbacks) { + callbacks = callbacks.slice(0); + for (var i = 0, len = callbacks.length; i < len; ++i) { + callbacks[i].apply(this, args); + } + } + + return this; + }; + + /** + * Return array of callbacks for `event`. + * + * @param {String} event + * @return {Array} + * @api public + */ + + Emitter.prototype.listeners = function(event){ + this._callbacks = this._callbacks || {}; + return this._callbacks[event] || []; + }; + + /** + * Check if this emitter has `event` handlers. + * + * @param {String} event + * @return {Boolean} + * @api public + */ + + Emitter.prototype.hasListeners = function(event){ + return !! this.listeners(event).length; + }; + + +/***/ }, +/* 20 */ +/***/ function(module, exports) { + + /** + * Compiles a querystring + * Returns string representation of the object + * + * @param {Object} + * @api private + */ + + exports.encode = function (obj) { + var str = ''; + + for (var i in obj) { + if (obj.hasOwnProperty(i)) { + if (str.length) str += '&'; + str += encodeURIComponent(i) + '=' + encodeURIComponent(obj[i]); + } + } + + return str; + }; + + /** + * Parses a simple querystring into an object + * + * @param {String} qs + * @api private + */ + + exports.decode = function(qs){ + var qry = {}; + var pairs = qs.split('&'); + for (var i = 0, l = pairs.length; i < l; i++) { + var pair = pairs[i].split('='); + qry[decodeURIComponent(pair[0])] = decodeURIComponent(pair[1]); + } + return qry; + }; + + +/***/ }, +/* 21 */ +/***/ function(module, exports) { + + + module.exports = function(a, b){ + var fn = function(){}; + fn.prototype = b.prototype; + a.prototype = new fn; + a.prototype.constructor = a; + }; + +/***/ }, +/* 22 */ +/***/ function(module, exports) { + + 'use strict'; + + var alphabet = '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz-_'.split('') + , length = 64 + , map = {} + , seed = 0 + , i = 0 + , prev; + + /** + * Return a string representing the specified number. + * + * @param {Number} num The number to convert. + * @returns {String} The string representation of the number. + * @api public + */ + function encode(num) { + var encoded = ''; + + do { + encoded = alphabet[num % length] + encoded; + num = Math.floor(num / length); + } while (num > 0); + + return encoded; + } + + /** + * Return the integer value specified by the given string. + * + * @param {String} str The string to convert. + * @returns {Number} The integer value represented by the string. + * @api public + */ + function decode(str) { + var decoded = 0; + + for (i = 0; i < str.length; i++) { + decoded = decoded * length + map[str.charAt(i)]; + } + + return decoded; + } + + /** + * Yeast: A tiny growing id generator. + * + * @returns {String} A unique id. + * @api public + */ + function yeast() { + var now = encode(+new Date()); + + if (now !== prev) return seed = 0, prev = now; + return now +'.'+ encode(seed++); + } + + // + // Map each character to its index. + // + for (; i < length; i++) map[alphabet[i]] = i; + + // + // Expose the `yeast`, `encode` and `decode` functions. + // + yeast.encode = encode; + yeast.decode = decode; + module.exports = yeast; + + +/***/ }, +/* 23 */ +/***/ function(module, exports, __webpack_require__) { + + + /** + * This is the web browser implementation of `debug()`. + * + * Expose `debug()` as the module. + */ + + exports = module.exports = __webpack_require__(24); + exports.log = log; + exports.formatArgs = formatArgs; + exports.save = save; + exports.load = load; + exports.useColors = useColors; + exports.storage = 'undefined' != typeof chrome + && 'undefined' != typeof chrome.storage + ? chrome.storage.local + : localstorage(); + + /** + * Colors. + */ + + exports.colors = [ + 'lightseagreen', + 'forestgreen', + 'goldenrod', + 'dodgerblue', + 'darkorchid', + 'crimson' + ]; + + /** + * Currently only WebKit-based Web Inspectors, Firefox >= v31, + * and the Firebug extension (any Firefox version) are known + * to support "%c" CSS customizations. + * + * TODO: add a `localStorage` variable to explicitly enable/disable colors + */ + + function useColors() { + // is webkit? http://stackoverflow.com/a/16459606/376773 + return ('WebkitAppearance' in document.documentElement.style) || + // is firebug? http://stackoverflow.com/a/398120/376773 + (window.console && (console.firebug || (console.exception && console.table))) || + // is firefox >= v31? + // https://developer.mozilla.org/en-US/docs/Tools/Web_Console#Styling_messages + (navigator.userAgent.toLowerCase().match(/firefox\/(\d+)/) && parseInt(RegExp.$1, 10) >= 31); + } + + /** + * Map %j to `JSON.stringify()`, since no Web Inspectors do that by default. + */ + + exports.formatters.j = function(v) { + return JSON.stringify(v); + }; + + + /** + * Colorize log arguments if enabled. + * + * @api public + */ + + function formatArgs() { + var args = arguments; + var useColors = this.useColors; + + args[0] = (useColors ? '%c' : '') + + this.namespace + + (useColors ? ' %c' : ' ') + + args[0] + + (useColors ? '%c ' : ' ') + + '+' + exports.humanize(this.diff); + + if (!useColors) return args; + + var c = 'color: ' + this.color; + args = [args[0], c, 'color: inherit'].concat(Array.prototype.slice.call(args, 1)); + + // the final "%c" is somewhat tricky, because there could be other + // arguments passed either before or after the %c, so we need to + // figure out the correct index to insert the CSS into + var index = 0; + var lastC = 0; + args[0].replace(/%[a-z%]/g, function(match) { + if ('%%' === match) return; + index++; + if ('%c' === match) { + // we only are interested in the *last* %c + // (the user may have provided their own) + lastC = index; + } + }); + + args.splice(lastC, 0, c); + return args; + } + + /** + * Invokes `console.log()` when available. + * No-op when `console.log` is not a "function". + * + * @api public + */ + + function log() { + // this hackery is required for IE8/9, where + // the `console.log` function doesn't have 'apply' + return 'object' === typeof console + && console.log + && Function.prototype.apply.call(console.log, console, arguments); + } + + /** + * Save `namespaces`. + * + * @param {String} namespaces + * @api private + */ + + function save(namespaces) { + try { + if (null == namespaces) { + exports.storage.removeItem('debug'); + } else { + exports.storage.debug = namespaces; + } + } catch(e) {} + } + + /** + * Load `namespaces`. + * + * @return {String} returns the previously persisted debug modes + * @api private + */ + + function load() { + var r; + try { + r = exports.storage.debug; + } catch(e) {} + return r; + } + + /** + * Enable namespaces listed in `localStorage.debug` initially. + */ + + exports.enable(load()); + + /** + * Localstorage attempts to return the localstorage. + * + * This is necessary because safari throws + * when a user disables cookies/localstorage + * and you attempt to access it. + * + * @return {LocalStorage} + * @api private + */ + + function localstorage(){ + try { + return window.localStorage; + } catch (e) {} + } + + +/***/ }, +/* 24 */ +/***/ function(module, exports, __webpack_require__) { + + + /** + * This is the common logic for both the Node.js and web browser + * implementations of `debug()`. + * + * Expose `debug()` as the module. + */ + + exports = module.exports = debug; + exports.coerce = coerce; + exports.disable = disable; + exports.enable = enable; + exports.enabled = enabled; + exports.humanize = __webpack_require__(25); + + /** + * The currently active debug mode names, and names to skip. + */ + + exports.names = []; + exports.skips = []; + + /** + * Map of special "%n" handling functions, for the debug "format" argument. + * + * Valid key names are a single, lowercased letter, i.e. "n". + */ + + exports.formatters = {}; + + /** + * Previously assigned color. + */ + + var prevColor = 0; + + /** + * Previous log timestamp. + */ + + var prevTime; + + /** + * Select a color. + * + * @return {Number} + * @api private + */ + + function selectColor() { + return exports.colors[prevColor++ % exports.colors.length]; + } + + /** + * Create a debugger with the given `namespace`. + * + * @param {String} namespace + * @return {Function} + * @api public + */ + + function debug(namespace) { + + // define the `disabled` version + function disabled() { + } + disabled.enabled = false; + + // define the `enabled` version + function enabled() { + + var self = enabled; + + // set `diff` timestamp + var curr = +new Date(); + var ms = curr - (prevTime || curr); + self.diff = ms; + self.prev = prevTime; + self.curr = curr; + prevTime = curr; + + // add the `color` if not set + if (null == self.useColors) self.useColors = exports.useColors(); + if (null == self.color && self.useColors) self.color = selectColor(); + + var args = Array.prototype.slice.call(arguments); + + args[0] = exports.coerce(args[0]); + + if ('string' !== typeof args[0]) { + // anything else let's inspect with %o + args = ['%o'].concat(args); + } + + // apply any `formatters` transformations + var index = 0; + args[0] = args[0].replace(/%([a-z%])/g, function(match, format) { + // if we encounter an escaped % then don't increase the array index + if (match === '%%') return match; + index++; + var formatter = exports.formatters[format]; + if ('function' === typeof formatter) { + var val = args[index]; + match = formatter.call(self, val); + + // now we need to remove `args[index]` since it's inlined in the `format` + args.splice(index, 1); + index--; + } + return match; + }); + + if ('function' === typeof exports.formatArgs) { + args = exports.formatArgs.apply(self, args); + } + var logFn = enabled.log || exports.log || console.log.bind(console); + logFn.apply(self, args); + } + enabled.enabled = true; + + var fn = exports.enabled(namespace) ? enabled : disabled; + + fn.namespace = namespace; + + return fn; + } + + /** + * Enables a debug mode by namespaces. This can include modes + * separated by a colon and wildcards. + * + * @param {String} namespaces + * @api public + */ + + function enable(namespaces) { + exports.save(namespaces); + + var split = (namespaces || '').split(/[\s,]+/); + var len = split.length; + + for (var i = 0; i < len; i++) { + if (!split[i]) continue; // ignore empty strings + namespaces = split[i].replace(/\*/g, '.*?'); + if (namespaces[0] === '-') { + exports.skips.push(new RegExp('^' + namespaces.substr(1) + '$')); + } else { + exports.names.push(new RegExp('^' + namespaces + '$')); + } + } + } + + /** + * Disable debug output. + * + * @api public + */ + + function disable() { + exports.enable(''); + } + + /** + * Returns true if the given mode name is enabled, false otherwise. + * + * @param {String} name + * @return {Boolean} + * @api public + */ + + function enabled(name) { + var i, len; + for (i = 0, len = exports.skips.length; i < len; i++) { + if (exports.skips[i].test(name)) { + return false; + } + } + for (i = 0, len = exports.names.length; i < len; i++) { + if (exports.names[i].test(name)) { + return true; + } + } + return false; + } + + /** + * Coerce `val`. + * + * @param {Mixed} val + * @return {Mixed} + * @api private + */ + + function coerce(val) { + if (val instanceof Error) return val.stack || val.message; + return val; + } + + +/***/ }, +/* 25 */ +/***/ function(module, exports) { + + /** + * Helpers. + */ + + var s = 1000; + var m = s * 60; + var h = m * 60; + var d = h * 24; + var y = d * 365.25; + + /** + * Parse or format the given `val`. + * + * Options: + * + * - `long` verbose formatting [false] + * + * @param {String|Number} val + * @param {Object} options + * @return {String|Number} + * @api public + */ + + module.exports = function(val, options){ + options = options || {}; + if ('string' == typeof val) return parse(val); + return options.long + ? long(val) + : short(val); + }; + + /** + * Parse the given `str` and return milliseconds. + * + * @param {String} str + * @return {Number} + * @api private + */ + + function parse(str) { + str = '' + str; + if (str.length > 10000) return; + var match = /^((?:\d+)?\.?\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|years?|yrs?|y)?$/i.exec(str); + if (!match) return; + var n = parseFloat(match[1]); + var type = (match[2] || 'ms').toLowerCase(); + switch (type) { + case 'years': + case 'year': + case 'yrs': + case 'yr': + case 'y': + return n * y; + case 'days': + case 'day': + case 'd': + return n * d; + case 'hours': + case 'hour': + case 'hrs': + case 'hr': + case 'h': + return n * h; + case 'minutes': + case 'minute': + case 'mins': + case 'min': + case 'm': + return n * m; + case 'seconds': + case 'second': + case 'secs': + case 'sec': + case 's': + return n * s; + case 'milliseconds': + case 'millisecond': + case 'msecs': + case 'msec': + case 'ms': + return n; + } + } + + /** + * Short format for `ms`. + * + * @param {Number} ms + * @return {String} + * @api private + */ + + function short(ms) { + if (ms >= d) return Math.round(ms / d) + 'd'; + if (ms >= h) return Math.round(ms / h) + 'h'; + if (ms >= m) return Math.round(ms / m) + 'm'; + if (ms >= s) return Math.round(ms / s) + 's'; + return ms + 'ms'; + } + + /** + * Long format for `ms`. + * + * @param {Number} ms + * @return {String} + * @api private + */ + + function long(ms) { + return plural(ms, d, 'day') + || plural(ms, h, 'hour') + || plural(ms, m, 'minute') + || plural(ms, s, 'second') + || ms + ' ms'; + } + + /** + * Pluralization helper. + */ + + function plural(ms, n, name) { + if (ms < n) return; + if (ms < n * 1.5) return Math.floor(ms / n) + ' ' + name; + return Math.ceil(ms / n) + ' ' + name + 's'; + } + + +/***/ }, +/* 26 */ +/***/ function(module, exports, __webpack_require__) { + + /* WEBPACK VAR INJECTION */(function(global) {'use strict'; + + /** + * Module requirements. + */ + + var Polling = __webpack_require__(7); + var inherit = __webpack_require__(21); + + /** + * Module exports. + */ + + module.exports = JSONPPolling; + + /** + * Cached regular expressions. + */ + + var rNewline = /\n/g; + var rEscapedNewline = /\\n/g; + + /** + * Global JSONP callbacks. + */ + + var callbacks; + + /** + * Noop. + */ + + function empty() {} + + /** + * JSONP Polling constructor. + * + * @param {Object} opts. + * @api public + */ + + function JSONPPolling(opts) { + Polling.call(this, opts); + + this.query = this.query || {}; + + // define global callbacks array if not present + // we do this here (lazily) to avoid unneeded global pollution + if (!callbacks) { + // we need to consider multiple engines in the same page + if (!global.___eio) global.___eio = []; + callbacks = global.___eio; + } + + // callback identifier + this.index = callbacks.length; + + // add callback to jsonp global + var self = this; + callbacks.push(function (msg) { + self.onData(msg); + }); + + // append to query string + this.query.j = this.index; + + // prevent spurious errors from being emitted when the window is unloaded + if (global.document && global.addEventListener) { + global.addEventListener('beforeunload', function () { + if (self.script) self.script.onerror = empty; + }, false); + } + } + + /** + * Inherits from Polling. + */ + + inherit(JSONPPolling, Polling); + + /* + * JSONP only supports binary as base64 encoded strings + */ + + JSONPPolling.prototype.supportsBinary = false; + + /** + * Closes the socket. + * + * @api private + */ + + JSONPPolling.prototype.doClose = function () { + if (this.script) { + this.script.parentNode.removeChild(this.script); + this.script = null; + } + + if (this.form) { + this.form.parentNode.removeChild(this.form); + this.form = null; + this.iframe = null; + } + + Polling.prototype.doClose.call(this); + }; + + /** + * Starts a poll cycle. + * + * @api private + */ + + JSONPPolling.prototype.doPoll = function () { + var self = this; + var script = document.createElement('script'); + + if (this.script) { + this.script.parentNode.removeChild(this.script); + this.script = null; + } + + script.async = true; + script.src = this.uri(); + script.onerror = function (e) { + self.onError('jsonp poll error', e); + }; + + var insertAt = document.getElementsByTagName('script')[0]; + if (insertAt) { + insertAt.parentNode.insertBefore(script, insertAt); + } else { + (document.head || document.body).appendChild(script); + } + this.script = script; + + var isUAgecko = 'undefined' !== typeof navigator && /gecko/i.test(navigator.userAgent); + + if (isUAgecko) { + setTimeout(function () { + var iframe = document.createElement('iframe'); + document.body.appendChild(iframe); + document.body.removeChild(iframe); + }, 100); + } + }; + + /** + * Writes with a hidden iframe. + * + * @param {String} data to send + * @param {Function} called upon flush. + * @api private + */ + + JSONPPolling.prototype.doWrite = function (data, fn) { + var self = this; + + if (!this.form) { + var form = document.createElement('form'); + var area = document.createElement('textarea'); + var id = this.iframeId = 'eio_iframe_' + this.index; + var iframe; + + form.className = 'socketio'; + form.style.position = 'absolute'; + form.style.top = '-1000px'; + form.style.left = '-1000px'; + form.target = id; + form.method = 'POST'; + form.setAttribute('accept-charset', 'utf-8'); + area.name = 'd'; + form.appendChild(area); + document.body.appendChild(form); + + this.form = form; + this.area = area; + } + + this.form.action = this.uri(); + + function complete() { + initIframe(); + fn(); + } + + function initIframe() { + if (self.iframe) { + try { + self.form.removeChild(self.iframe); + } catch (e) { + self.onError('jsonp polling iframe removal error', e); + } + } + + try { + // ie6 dynamic iframes with target="" support (thanks Chris Lambacher) + var html = '

              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 CM7ttHd>?=5NaJBpDhsj1sFEVT{?N9oeDuX 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%0Apv}qOR-$(bi9u4rFzaV6wh5kcXn15d1QvI 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 AbpQYW literal 0 HcmV?d00001 diff --git a/node_modules/toastr/package/package/toastr-icon.png b/node_modules/toastr/package/package/toastr-icon.png new file mode 100644 index 0000000000000000000000000000000000000000..040102adcf4c6af6200d4ba7fba296cef0524836 GIT binary patch literal 25510 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 div { + position: relative; + overflow: hidden; + margin: 0 0 6px; + padding: 15px 15px 15px 50px; + width: 300px; + -moz-border-radius: 3px 3px 3px 3px; + -webkit-border-radius: 3px 3px 3px 3px; + border-radius: 3px 3px 3px 3px; + background-position: 15px center; + background-repeat: no-repeat; + -moz-box-shadow: 0 0 12px #999999; + -webkit-box-shadow: 0 0 12px #999999; + box-shadow: 0 0 12px #999999; + color: #ffffff; + opacity: 0.8; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=80); + filter: alpha(opacity=80); +} +#toast-container > :hover { + -moz-box-shadow: 0 0 12px #000000; + -webkit-box-shadow: 0 0 12px #000000; + box-shadow: 0 0 12px #000000; + opacity: 1; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=100); + filter: alpha(opacity=100); + cursor: pointer; +} +#toast-container > .toast-info { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGwSURBVEhLtZa9SgNBEMc9sUxxRcoUKSzSWIhXpFMhhYWFhaBg4yPYiWCXZxBLERsLRS3EQkEfwCKdjWJAwSKCgoKCcudv4O5YLrt7EzgXhiU3/4+b2ckmwVjJSpKkQ6wAi4gwhT+z3wRBcEz0yjSseUTrcRyfsHsXmD0AmbHOC9Ii8VImnuXBPglHpQ5wwSVM7sNnTG7Za4JwDdCjxyAiH3nyA2mtaTJufiDZ5dCaqlItILh1NHatfN5skvjx9Z38m69CgzuXmZgVrPIGE763Jx9qKsRozWYw6xOHdER+nn2KkO+Bb+UV5CBN6WC6QtBgbRVozrahAbmm6HtUsgtPC19tFdxXZYBOfkbmFJ1VaHA1VAHjd0pp70oTZzvR+EVrx2Ygfdsq6eu55BHYR8hlcki+n+kERUFG8BrA0BwjeAv2M8WLQBtcy+SD6fNsmnB3AlBLrgTtVW1c2QN4bVWLATaIS60J2Du5y1TiJgjSBvFVZgTmwCU+dAZFoPxGEEs8nyHC9Bwe2GvEJv2WXZb0vjdyFT4Cxk3e/kIqlOGoVLwwPevpYHT+00T+hWwXDf4AJAOUqWcDhbwAAAAASUVORK5CYII=") !important; +} +#toast-container > .toast-error { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAHOSURBVEhLrZa/SgNBEMZzh0WKCClSCKaIYOED+AAKeQQLG8HWztLCImBrYadgIdY+gIKNYkBFSwu7CAoqCgkkoGBI/E28PdbLZmeDLgzZzcx83/zZ2SSXC1j9fr+I1Hq93g2yxH4iwM1vkoBWAdxCmpzTxfkN2RcyZNaHFIkSo10+8kgxkXIURV5HGxTmFuc75B2RfQkpxHG8aAgaAFa0tAHqYFfQ7Iwe2yhODk8+J4C7yAoRTWI3w/4klGRgR4lO7Rpn9+gvMyWp+uxFh8+H+ARlgN1nJuJuQAYvNkEnwGFck18Er4q3egEc/oO+mhLdKgRyhdNFiacC0rlOCbhNVz4H9FnAYgDBvU3QIioZlJFLJtsoHYRDfiZoUyIxqCtRpVlANq0EU4dApjrtgezPFad5S19Wgjkc0hNVnuF4HjVA6C7QrSIbylB+oZe3aHgBsqlNqKYH48jXyJKMuAbiyVJ8KzaB3eRc0pg9VwQ4niFryI68qiOi3AbjwdsfnAtk0bCjTLJKr6mrD9g8iq/S/B81hguOMlQTnVyG40wAcjnmgsCNESDrjme7wfftP4P7SP4N3CJZdvzoNyGq2c/HWOXJGsvVg+RA/k2MC/wN6I2YA2Pt8GkAAAAASUVORK5CYII=") !important; +} +#toast-container > .toast-success { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAADsSURBVEhLY2AYBfQMgf///3P8+/evAIgvA/FsIF+BavYDDWMBGroaSMMBiE8VC7AZDrIFaMFnii3AZTjUgsUUWUDA8OdAH6iQbQEhw4HyGsPEcKBXBIC4ARhex4G4BsjmweU1soIFaGg/WtoFZRIZdEvIMhxkCCjXIVsATV6gFGACs4Rsw0EGgIIH3QJYJgHSARQZDrWAB+jawzgs+Q2UO49D7jnRSRGoEFRILcdmEMWGI0cm0JJ2QpYA1RDvcmzJEWhABhD/pqrL0S0CWuABKgnRki9lLseS7g2AlqwHWQSKH4oKLrILpRGhEQCw2LiRUIa4lwAAAABJRU5ErkJggg==") !important; +} +#toast-container > .toast-warning { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGYSURBVEhL5ZSvTsNQFMbXZGICMYGYmJhAQIJAICYQPAACiSDB8AiICQQJT4CqQEwgJvYASAQCiZiYmJhAIBATCARJy+9rTsldd8sKu1M0+dLb057v6/lbq/2rK0mS/TRNj9cWNAKPYIJII7gIxCcQ51cvqID+GIEX8ASG4B1bK5gIZFeQfoJdEXOfgX4QAQg7kH2A65yQ87lyxb27sggkAzAuFhbbg1K2kgCkB1bVwyIR9m2L7PRPIhDUIXgGtyKw575yz3lTNs6X4JXnjV+LKM/m3MydnTbtOKIjtz6VhCBq4vSm3ncdrD2lk0VgUXSVKjVDJXJzijW1RQdsU7F77He8u68koNZTz8Oz5yGa6J3H3lZ0xYgXBK2QymlWWA+RWnYhskLBv2vmE+hBMCtbA7KX5drWyRT/2JsqZ2IvfB9Y4bWDNMFbJRFmC9E74SoS0CqulwjkC0+5bpcV1CZ8NMej4pjy0U+doDQsGyo1hzVJttIjhQ7GnBtRFN1UarUlH8F3xict+HY07rEzoUGPlWcjRFRr4/gChZgc3ZL2d8oAAAAASUVORK5CYII=") !important; +} +#toast-container.toast-top-center > div, +#toast-container.toast-bottom-center > div { + width: 300px; + margin: auto; +} +#toast-container.toast-top-full-width > div, +#toast-container.toast-bottom-full-width > div { + width: 96%; + margin: auto; +} +.toast { + background-color: #030303; +} +.toast-success { + background-color: #51a351; +} +.toast-error { + background-color: #bd362f; +} +.toast-info { + background-color: #2f96b4; +} +.toast-warning { + background-color: #f89406; +} +.toast-progress { + position: absolute; + left: 0; + bottom: 0; + height: 4px; + background-color: #000000; + opacity: 0.4; + -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=40); + filter: alpha(opacity=40); +} +/*Responsive Design*/ +@media all and (max-width: 240px) { + #toast-container > div { + padding: 8px 8px 8px 50px; + width: 11em; + } + #toast-container .toast-close-button { + right: -0.2em; + top: -0.2em; + } +} +@media all and (min-width: 241px) and (max-width: 480px) { + #toast-container > div { + padding: 8px 8px 8px 50px; + width: 18em; + } + #toast-container .toast-close-button { + right: -0.2em; + top: -0.2em; + } +} +@media all and (min-width: 481px) and (max-width: 768px) { + #toast-container > div { + padding: 15px 15px 15px 50px; + width: 25em; + } +} diff --git a/node_modules/toastr/package/package/toastr.js b/node_modules/toastr/package/package/toastr.js new file mode 100644 index 0000000..9be91ee --- /dev/null +++ b/node_modules/toastr/package/package/toastr.js @@ -0,0 +1,415 @@ +/* + * Toastr + * Copyright 2012-2015 + * Authors: John Papa, Hans Fjällemark, and Tim Ferrell. + * All Rights Reserved. + * Use, reproduction, distribution, and modification of this code is subject to the terms and + * conditions of the MIT license, available at http://www.opensource.org/licenses/mit-license.php + * + * ARIA Support: Greta Krafsig + * + * Project: https://github.com/CodeSeven/toastr + */ +/* global define */ +; (function (define) { + define(['jquery'], function ($) { + return (function () { + var $container; + var listener; + var toastId = 0; + var toastType = { + error: 'error', + info: 'info', + success: 'success', + warning: 'warning' + }; + + var toastr = { + clear: clear, + remove: remove, + error: error, + getContainer: getContainer, + info: info, + options: {}, + subscribe: subscribe, + success: success, + version: '2.1.1', + warning: warning + }; + + var previousToast; + + return toastr; + + //////////////// + + function error(message, title, optionsOverride) { + return notify({ + type: toastType.error, + iconClass: getOptions().iconClasses.error, + message: message, + optionsOverride: optionsOverride, + title: title + }); + } + + function getContainer(options, create) { + if (!options) { options = getOptions(); } + $container = $('#' + options.containerId); + if ($container.length) { + return $container; + } + if (create) { + $container = createContainer(options); + } + return $container; + } + + function info(message, title, optionsOverride) { + return notify({ + type: toastType.info, + iconClass: getOptions().iconClasses.info, + message: message, + optionsOverride: optionsOverride, + title: title + }); + } + + function subscribe(callback) { + listener = callback; + } + + function success(message, title, optionsOverride) { + return notify({ + type: toastType.success, + iconClass: getOptions().iconClasses.success, + message: message, + optionsOverride: optionsOverride, + title: title + }); + } + + function warning(message, title, optionsOverride) { + return notify({ + type: toastType.warning, + iconClass: getOptions().iconClasses.warning, + message: message, + optionsOverride: optionsOverride, + title: title + }); + } + + function clear($toastElement, clearOptions) { + var options = getOptions(); + if (!$container) { getContainer(options); } + if (!clearToast($toastElement, options, clearOptions)) { + clearContainer(options); + } + } + + function remove($toastElement) { + var options = getOptions(); + if (!$container) { getContainer(options); } + if ($toastElement && $(':focus', $toastElement).length === 0) { + removeToast($toastElement); + return; + } + if ($container.children().length) { + $container.remove(); + } + } + + // internal functions + + function clearContainer (options) { + var toastsToClear = $container.children(); + for (var i = toastsToClear.length - 1; i >= 0; i--) { + clearToast($(toastsToClear[i]), options); + } + } + + function clearToast ($toastElement, options, clearOptions) { + var force = clearOptions && clearOptions.force ? clearOptions.force : false; + if ($toastElement && (force || $(':focus', $toastElement).length === 0)) { + $toastElement[options.hideMethod]({ + duration: options.hideDuration, + easing: options.hideEasing, + complete: function () { removeToast($toastElement); } + }); + return true; + } + return false; + } + + function createContainer(options) { + $container = $('