RQteafactory-NodeJS/node_modules/express/lib/response.js
IrisVega ad08fb9cdd new file: .vscode/settings.json
new file:   node_modules/.bin/mime
	new file:   node_modules/.bin/mime.cmd
	new file:   node_modules/.bin/mime.ps1
	new file:   node_modules/.package-lock.json
	new file:   node_modules/accepts/HISTORY.md
	new file:   node_modules/accepts/LICENSE
	new file:   node_modules/accepts/README.md
	new file:   node_modules/accepts/index.js
	new file:   node_modules/accepts/package.json
	new file:   node_modules/array-flatten/LICENSE
	new file:   node_modules/array-flatten/README.md
	new file:   node_modules/array-flatten/array-flatten.js
	new file:   node_modules/array-flatten/package.json
	new file:   node_modules/bignumber.js/CHANGELOG.md
	new file:   node_modules/bignumber.js/LICENCE
	new file:   node_modules/bignumber.js/README.md
	new file:   node_modules/bignumber.js/bignumber.d.ts
	new file:   node_modules/bignumber.js/bignumber.js
	new file:   node_modules/bignumber.js/bignumber.min.js
	new file:   node_modules/bignumber.js/bignumber.min.js.map
	new file:   node_modules/bignumber.js/bignumber.mjs
	new file:   node_modules/bignumber.js/doc/API.html
	new file:   node_modules/bignumber.js/package.json
	new file:   node_modules/body-parser/HISTORY.md
	new file:   node_modules/body-parser/LICENSE
	new file:   node_modules/body-parser/README.md
	new file:   node_modules/body-parser/SECURITY.md
	new file:   node_modules/body-parser/index.js
	new file:   node_modules/body-parser/lib/read.js
	new file:   node_modules/body-parser/lib/types/json.js
	new file:   node_modules/body-parser/lib/types/raw.js
	new file:   node_modules/body-parser/lib/types/text.js
	new file:   node_modules/body-parser/lib/types/urlencoded.js
	new file:   node_modules/body-parser/package.json
	new file:   node_modules/bytes/History.md
	new file:   node_modules/bytes/LICENSE
	new file:   node_modules/bytes/Readme.md
	new file:   node_modules/bytes/index.js
	new file:   node_modules/bytes/package.json
	new file:   node_modules/call-bind/.eslintignore
	new file:   node_modules/call-bind/.eslintrc
	new file:   node_modules/call-bind/.github/FUNDING.yml
	new file:   node_modules/call-bind/.nycrc
	new file:   node_modules/call-bind/CHANGELOG.md
	new file:   node_modules/call-bind/LICENSE
	new file:   node_modules/call-bind/README.md
	new file:   node_modules/call-bind/callBound.js
	new file:   node_modules/call-bind/index.js
	new file:   node_modules/call-bind/package.json
	new file:   node_modules/call-bind/test/callBound.js
	new file:   node_modules/call-bind/test/index.js
	new file:   node_modules/content-disposition/HISTORY.md
	new file:   node_modules/content-disposition/LICENSE
	new file:   node_modules/content-disposition/README.md
	new file:   node_modules/content-disposition/index.js
	new file:   node_modules/content-disposition/package.json
	new file:   node_modules/content-type/HISTORY.md
	new file:   node_modules/content-type/LICENSE
	new file:   node_modules/content-type/README.md
	new file:   node_modules/content-type/index.js
	new file:   node_modules/content-type/package.json
	new file:   node_modules/cookie-signature/.npmignore
	new file:   node_modules/cookie-signature/History.md
	new file:   node_modules/cookie-signature/Readme.md
	new file:   node_modules/cookie-signature/index.js
	new file:   node_modules/cookie-signature/package.json
	new file:   node_modules/cookie/HISTORY.md
	new file:   node_modules/cookie/LICENSE
	new file:   node_modules/cookie/README.md
	new file:   node_modules/cookie/SECURITY.md
	new file:   node_modules/cookie/index.js
	new file:   node_modules/cookie/package.json
	new file:   node_modules/core-util-is/LICENSE
	new file:   node_modules/core-util-is/README.md
	new file:   node_modules/core-util-is/lib/util.js
	new file:   node_modules/core-util-is/package.json
	new file:   node_modules/cors/CONTRIBUTING.md
	new file:   node_modules/cors/HISTORY.md
	new file:   node_modules/cors/LICENSE
	new file:   node_modules/cors/README.md
	new file:   node_modules/cors/lib/index.js
	new file:   node_modules/cors/package.json
	new file:   node_modules/debug/.coveralls.yml
	new file:   node_modules/debug/.eslintrc
	new file:   node_modules/debug/.npmignore
	new file:   node_modules/debug/.travis.yml
	new file:   node_modules/debug/CHANGELOG.md
	new file:   node_modules/debug/LICENSE
	new file:   node_modules/debug/Makefile
	new file:   node_modules/debug/README.md
	new file:   node_modules/debug/component.json
	new file:   node_modules/debug/karma.conf.js
	new file:   node_modules/debug/node.js
	new file:   node_modules/debug/package.json
	new file:   node_modules/debug/src/browser.js
	new file:   node_modules/debug/src/debug.js
	new file:   node_modules/debug/src/index.js
	new file:   node_modules/debug/src/inspector-log.js
	new file:   node_modules/debug/src/node.js
	new file:   node_modules/define-data-property/.eslintrc
	new file:   node_modules/define-data-property/.github/FUNDING.yml
	new file:   node_modules/define-data-property/.nycrc
	new file:   node_modules/define-data-property/CHANGELOG.md
	new file:   node_modules/define-data-property/LICENSE
	new file:   node_modules/define-data-property/README.md
	new file:   node_modules/define-data-property/index.d.ts
	new file:   node_modules/define-data-property/index.js
	new file:   node_modules/define-data-property/package.json
	new file:   node_modules/define-data-property/test/index.js
	new file:   node_modules/define-data-property/tsconfig.json
	new file:   node_modules/depd/History.md
	new file:   node_modules/depd/LICENSE
	new file:   node_modules/depd/Readme.md
	new file:   node_modules/depd/index.js
	new file:   node_modules/depd/lib/browser/index.js
	new file:   node_modules/depd/package.json
	new file:   node_modules/destroy/LICENSE
	new file:   node_modules/destroy/README.md
	new file:   node_modules/destroy/index.js
	new file:   node_modules/destroy/package.json
	new file:   node_modules/ee-first/LICENSE
	new file:   node_modules/ee-first/README.md
	new file:   node_modules/ee-first/index.js
	new file:   node_modules/ee-first/package.json
	new file:   node_modules/encodeurl/HISTORY.md
	new file:   node_modules/encodeurl/LICENSE
	new file:   node_modules/encodeurl/README.md
	new file:   node_modules/encodeurl/index.js
	new file:   node_modules/encodeurl/package.json
	new file:   node_modules/es-define-property/.eslintrc
	new file:   node_modules/es-define-property/.github/FUNDING.yml
	new file:   node_modules/es-define-property/.nycrc
	new file:   node_modules/es-define-property/CHANGELOG.md
	new file:   node_modules/es-define-property/LICENSE
	new file:   node_modules/es-define-property/README.md
	new file:   node_modules/es-define-property/index.d.ts
	new file:   node_modules/es-define-property/index.js
	new file:   node_modules/es-define-property/package.json
	new file:   node_modules/es-define-property/test/index.js
	new file:   node_modules/es-define-property/tsconfig.json
	new file:   node_modules/es-errors/.eslintrc
	new file:   node_modules/es-errors/.github/FUNDING.yml
	new file:   node_modules/es-errors/CHANGELOG.md
	new file:   node_modules/es-errors/LICENSE
	new file:   node_modules/es-errors/README.md
	new file:   node_modules/es-errors/eval.d.ts
	new file:   node_modules/es-errors/eval.js
	new file:   node_modules/es-errors/index.d.ts
	new file:   node_modules/es-errors/index.js
	new file:   node_modules/es-errors/package.json
	new file:   node_modules/es-errors/range.d.ts
	new file:   node_modules/es-errors/range.js
	new file:   node_modules/es-errors/ref.d.ts
	new file:   node_modules/es-errors/ref.js
	new file:   node_modules/es-errors/syntax.d.ts
	new file:   node_modules/es-errors/syntax.js
	new file:   node_modules/es-errors/test/index.js
	new file:   node_modules/es-errors/tsconfig.json
	new file:   node_modules/es-errors/type.d.ts
	new file:   node_modules/es-errors/type.js
	new file:   node_modules/es-errors/uri.d.ts
	new file:   node_modules/es-errors/uri.js
	new file:   node_modules/escape-html/LICENSE
	new file:   node_modules/escape-html/Readme.md
	new file:   node_modules/escape-html/index.js
	new file:   node_modules/escape-html/package.json
	new file:   node_modules/etag/HISTORY.md
	new file:   node_modules/etag/LICENSE
	new file:   node_modules/etag/README.md
	new file:   node_modules/etag/index.js
	new file:   node_modules/etag/package.json
	new file:   node_modules/express/History.md
	new file:   node_modules/express/LICENSE
	new file:   node_modules/express/Readme.md
	new file:   node_modules/express/index.js
	new file:   node_modules/express/lib/application.js
	new file:   node_modules/express/lib/express.js
	new file:   node_modules/express/lib/middleware/init.js
	new file:   node_modules/express/lib/middleware/query.js
	new file:   node_modules/express/lib/request.js
	new file:   node_modules/express/lib/response.js
	new file:   node_modules/express/lib/router/index.js
	new file:   node_modules/express/lib/router/layer.js
	new file:   node_modules/express/lib/router/route.js
	new file:   node_modules/express/lib/utils.js
	new file:   node_modules/express/lib/view.js
	new file:   node_modules/express/package.json
	new file:   node_modules/finalhandler/HISTORY.md
	new file:   node_modules/finalhandler/LICENSE
	new file:   node_modules/finalhandler/README.md
	new file:   node_modules/finalhandler/SECURITY.md
	new file:   node_modules/finalhandler/index.js
	new file:   node_modules/finalhandler/package.json
	new file:   node_modules/forwarded/HISTORY.md
	new file:   node_modules/forwarded/LICENSE
	new file:   node_modules/forwarded/README.md
	new file:   node_modules/forwarded/index.js
	new file:   node_modules/forwarded/package.json
	new file:   node_modules/fresh/HISTORY.md
	new file:   node_modules/fresh/LICENSE
	new file:   node_modules/fresh/README.md
	new file:   node_modules/fresh/index.js
	new file:   node_modules/fresh/package.json
	new file:   node_modules/function-bind/.eslintrc
	new file:   node_modules/function-bind/.github/FUNDING.yml
	new file:   node_modules/function-bind/.github/SECURITY.md
	new file:   node_modules/function-bind/.nycrc
	new file:   node_modules/function-bind/CHANGELOG.md
	new file:   node_modules/function-bind/LICENSE
	new file:   node_modules/function-bind/README.md
	new file:   node_modules/function-bind/implementation.js
	new file:   node_modules/function-bind/index.js
	new file:   node_modules/function-bind/package.json
	new file:   node_modules/function-bind/test/.eslintrc
	new file:   node_modules/function-bind/test/index.js
	new file:   node_modules/get-intrinsic/.eslintrc
	new file:   node_modules/get-intrinsic/.github/FUNDING.yml
	new file:   node_modules/get-intrinsic/.nycrc
	new file:   node_modules/get-intrinsic/CHANGELOG.md
	new file:   node_modules/get-intrinsic/LICENSE
	new file:   node_modules/get-intrinsic/README.md
	new file:   node_modules/get-intrinsic/index.js
	new file:   node_modules/get-intrinsic/package.json
	new file:   node_modules/get-intrinsic/test/GetIntrinsic.js
	new file:   node_modules/gopd/.eslintrc
	new file:   node_modules/gopd/.github/FUNDING.yml
	new file:   node_modules/gopd/CHANGELOG.md
	new file:   node_modules/gopd/LICENSE
	new file:   node_modules/gopd/README.md
	new file:   node_modules/gopd/index.js
	new file:   node_modules/gopd/package.json
	new file:   node_modules/gopd/test/index.js
	new file:   node_modules/has-property-descriptors/.eslintrc
	new file:   node_modules/has-property-descriptors/.github/FUNDING.yml
	new file:   node_modules/has-property-descriptors/.nycrc
	new file:   node_modules/has-property-descriptors/CHANGELOG.md
	new file:   node_modules/has-property-descriptors/LICENSE
	new file:   node_modules/has-property-descriptors/README.md
	new file:   node_modules/has-property-descriptors/index.js
	new file:   node_modules/has-property-descriptors/package.json
	new file:   node_modules/has-property-descriptors/test/index.js
	new file:   node_modules/has-proto/.eslintrc
	new file:   node_modules/has-proto/.github/FUNDING.yml
	new file:   node_modules/has-proto/CHANGELOG.md
	new file:   node_modules/has-proto/LICENSE
	new file:   node_modules/has-proto/README.md
	new file:   node_modules/has-proto/index.d.ts
	new file:   node_modules/has-proto/index.js
	new file:   node_modules/has-proto/package.json
	new file:   node_modules/has-proto/test/index.js
	new file:   node_modules/has-proto/tsconfig.json
	new file:   node_modules/has-symbols/.eslintrc
	new file:   node_modules/has-symbols/.github/FUNDING.yml
	new file:   node_modules/has-symbols/.nycrc
	new file:   node_modules/has-symbols/CHANGELOG.md
	new file:   node_modules/has-symbols/LICENSE
	new file:   node_modules/has-symbols/README.md
	new file:   node_modules/has-symbols/index.js
	new file:   node_modules/has-symbols/package.json
	new file:   node_modules/has-symbols/shams.js
	new file:   node_modules/has-symbols/test/index.js
	new file:   node_modules/has-symbols/test/shams/core-js.js
	new file:   node_modules/has-symbols/test/shams/get-own-property-symbols.js
	new file:   node_modules/has-symbols/test/tests.js
	new file:   node_modules/hasown/.eslintrc
	new file:   node_modules/hasown/.github/FUNDING.yml
	new file:   node_modules/hasown/.nycrc
	new file:   node_modules/hasown/CHANGELOG.md
	new file:   node_modules/hasown/LICENSE
	new file:   node_modules/hasown/README.md
	new file:   node_modules/hasown/index.d.ts
	new file:   node_modules/hasown/index.js
	new file:   node_modules/hasown/package.json
	new file:   node_modules/hasown/tsconfig.json
	new file:   node_modules/http-errors/HISTORY.md
	new file:   node_modules/http-errors/LICENSE
	new file:   node_modules/http-errors/README.md
	new file:   node_modules/http-errors/index.js
	new file:   node_modules/http-errors/package.json
	new file:   node_modules/iconv-lite/Changelog.md
	new file:   node_modules/iconv-lite/LICENSE
	new file:   node_modules/iconv-lite/README.md
	new file:   node_modules/iconv-lite/encodings/dbcs-codec.js
	new file:   node_modules/iconv-lite/encodings/dbcs-data.js
	new file:   node_modules/iconv-lite/encodings/index.js
	new file:   node_modules/iconv-lite/encodings/internal.js
	new file:   node_modules/iconv-lite/encodings/sbcs-codec.js
	new file:   node_modules/iconv-lite/encodings/sbcs-data-generated.js
	new file:   node_modules/iconv-lite/encodings/sbcs-data.js
	new file:   node_modules/iconv-lite/encodings/tables/big5-added.json
	new file:   node_modules/iconv-lite/encodings/tables/cp936.json
	new file:   node_modules/iconv-lite/encodings/tables/cp949.json
	new file:   node_modules/iconv-lite/encodings/tables/cp950.json
	new file:   node_modules/iconv-lite/encodings/tables/eucjp.json
	new file:   node_modules/iconv-lite/encodings/tables/gb18030-ranges.json
	new file:   node_modules/iconv-lite/encodings/tables/gbk-added.json
	new file:   node_modules/iconv-lite/encodings/tables/shiftjis.json
	new file:   node_modules/iconv-lite/encodings/utf16.js
	new file:   node_modules/iconv-lite/encodings/utf7.js
	new file:   node_modules/iconv-lite/lib/bom-handling.js
	new file:   node_modules/iconv-lite/lib/extend-node.js
	new file:   node_modules/iconv-lite/lib/index.d.ts
	new file:   node_modules/iconv-lite/lib/index.js
	new file:   node_modules/iconv-lite/lib/streams.js
	new file:   node_modules/iconv-lite/package.json
	new file:   node_modules/inherits/LICENSE
	new file:   node_modules/inherits/README.md
	new file:   node_modules/inherits/inherits.js
	new file:   node_modules/inherits/inherits_browser.js
	new file:   node_modules/inherits/package.json
	new file:   node_modules/ipaddr.js/LICENSE
	new file:   node_modules/ipaddr.js/README.md
	new file:   node_modules/ipaddr.js/ipaddr.min.js
	new file:   node_modules/ipaddr.js/lib/ipaddr.js
	new file:   node_modules/ipaddr.js/lib/ipaddr.js.d.ts
	new file:   node_modules/ipaddr.js/package.json
	new file:   node_modules/isarray/.npmignore
	new file:   node_modules/isarray/.travis.yml
	new file:   node_modules/isarray/Makefile
	new file:   node_modules/isarray/README.md
	new file:   node_modules/isarray/component.json
	new file:   node_modules/isarray/index.js
	new file:   node_modules/isarray/package.json
	new file:   node_modules/isarray/test.js
	new file:   node_modules/media-typer/HISTORY.md
	new file:   node_modules/media-typer/LICENSE
	new file:   node_modules/media-typer/README.md
	new file:   node_modules/media-typer/index.js
	new file:   node_modules/media-typer/package.json
	new file:   node_modules/merge-descriptors/HISTORY.md
	new file:   node_modules/merge-descriptors/LICENSE
	new file:   node_modules/merge-descriptors/README.md
	new file:   node_modules/merge-descriptors/index.js
	new file:   node_modules/merge-descriptors/package.json
	new file:   node_modules/methods/HISTORY.md
	new file:   node_modules/methods/LICENSE
	new file:   node_modules/methods/README.md
	new file:   node_modules/methods/index.js
	new file:   node_modules/methods/package.json
	new file:   node_modules/mime-db/HISTORY.md
	new file:   node_modules/mime-db/LICENSE
	new file:   node_modules/mime-db/README.md
	new file:   node_modules/mime-db/db.json
	new file:   node_modules/mime-db/index.js
	new file:   node_modules/mime-db/package.json
	new file:   node_modules/mime-types/HISTORY.md
	new file:   node_modules/mime-types/LICENSE
	new file:   node_modules/mime-types/README.md
	new file:   node_modules/mime-types/index.js
	new file:   node_modules/mime-types/package.json
	new file:   node_modules/mime/.npmignore
	new file:   node_modules/mime/CHANGELOG.md
	new file:   node_modules/mime/LICENSE
	new file:   node_modules/mime/README.md
	new file:   node_modules/mime/cli.js
	new file:   node_modules/mime/mime.js
	new file:   node_modules/mime/package.json
	new file:   node_modules/mime/src/build.js
	new file:   node_modules/mime/src/test.js
	new file:   node_modules/mime/types.json
	new file:   node_modules/ms/index.js
	new file:   node_modules/ms/license.md
	new file:   node_modules/ms/package.json
	new file:   node_modules/ms/readme.md
	new file:   node_modules/mysql/Changes.md
	new file:   node_modules/mysql/License
	new file:   node_modules/mysql/Readme.md
	new file:   node_modules/mysql/index.js
	new file:   node_modules/mysql/lib/Connection.js
	new file:   node_modules/mysql/lib/ConnectionConfig.js
	new file:   node_modules/mysql/lib/Pool.js
	new file:   node_modules/mysql/lib/PoolCluster.js
	new file:   node_modules/mysql/lib/PoolConfig.js
	new file:   node_modules/mysql/lib/PoolConnection.js
	new file:   node_modules/mysql/lib/PoolNamespace.js
	new file:   node_modules/mysql/lib/PoolSelector.js
	new file:   node_modules/mysql/lib/protocol/Auth.js
	new file:   node_modules/mysql/lib/protocol/BufferList.js
	new file:   node_modules/mysql/lib/protocol/PacketHeader.js
	new file:   node_modules/mysql/lib/protocol/PacketWriter.js
	new file:   node_modules/mysql/lib/protocol/Parser.js
	new file:   node_modules/mysql/lib/protocol/Protocol.js
	new file:   node_modules/mysql/lib/protocol/ResultSet.js
	new file:   node_modules/mysql/lib/protocol/SqlString.js
	new file:   node_modules/mysql/lib/protocol/Timer.js
	new file:   node_modules/mysql/lib/protocol/constants/charsets.js
	new file:   node_modules/mysql/lib/protocol/constants/client.js
	new file:   node_modules/mysql/lib/protocol/constants/errors.js
	new file:   node_modules/mysql/lib/protocol/constants/field_flags.js
	new file:   node_modules/mysql/lib/protocol/constants/server_status.js
	new file:   node_modules/mysql/lib/protocol/constants/ssl_profiles.js
	new file:   node_modules/mysql/lib/protocol/constants/types.js
	new file:   node_modules/mysql/lib/protocol/packets/AuthSwitchRequestPacket.js
	new file:   node_modules/mysql/lib/protocol/packets/AuthSwitchResponsePacket.js
	new file:   node_modules/mysql/lib/protocol/packets/ClientAuthenticationPacket.js
	new file:   node_modules/mysql/lib/protocol/packets/ComChangeUserPacket.js
	new file:   node_modules/mysql/lib/protocol/packets/ComPingPacket.js
	new file:   node_modules/mysql/lib/protocol/packets/ComQueryPacket.js
	new file:   node_modules/mysql/lib/protocol/packets/ComQuitPacket.js
	new file:   node_modules/mysql/lib/protocol/packets/ComStatisticsPacket.js
	new file:   node_modules/mysql/lib/protocol/packets/EmptyPacket.js
	new file:   node_modules/mysql/lib/protocol/packets/EofPacket.js
	new file:   node_modules/mysql/lib/protocol/packets/ErrorPacket.js
	new file:   node_modules/mysql/lib/protocol/packets/Field.js
	new file:   node_modules/mysql/lib/protocol/packets/FieldPacket.js
	new file:   node_modules/mysql/lib/protocol/packets/HandshakeInitializationPacket.js
	new file:   node_modules/mysql/lib/protocol/packets/LocalDataFilePacket.js
	new file:   node_modules/mysql/lib/protocol/packets/LocalInfileRequestPacket.js
	new file:   node_modules/mysql/lib/protocol/packets/OkPacket.js
	new file:   node_modules/mysql/lib/protocol/packets/OldPasswordPacket.js
	new file:   node_modules/mysql/lib/protocol/packets/ResultSetHeaderPacket.js
	new file:   node_modules/mysql/lib/protocol/packets/RowDataPacket.js
	new file:   node_modules/mysql/lib/protocol/packets/SSLRequestPacket.js
	new file:   node_modules/mysql/lib/protocol/packets/StatisticsPacket.js
	new file:   node_modules/mysql/lib/protocol/packets/UseOldPasswordPacket.js
	new file:   node_modules/mysql/lib/protocol/packets/index.js
	new file:   node_modules/mysql/lib/protocol/sequences/ChangeUser.js
	new file:   node_modules/mysql/lib/protocol/sequences/Handshake.js
	new file:   node_modules/mysql/lib/protocol/sequences/Ping.js
	new file:   node_modules/mysql/lib/protocol/sequences/Query.js
	new file:   node_modules/mysql/lib/protocol/sequences/Quit.js
	new file:   node_modules/mysql/lib/protocol/sequences/Sequence.js
	new file:   node_modules/mysql/lib/protocol/sequences/Statistics.js
	new file:   node_modules/mysql/lib/protocol/sequences/index.js
	new file:   node_modules/mysql/node_modules/safe-buffer/LICENSE
	new file:   node_modules/mysql/node_modules/safe-buffer/README.md
	new file:   node_modules/mysql/node_modules/safe-buffer/index.d.ts
	new file:   node_modules/mysql/node_modules/safe-buffer/index.js
	new file:   node_modules/mysql/node_modules/safe-buffer/package.json
	new file:   node_modules/mysql/package.json
	new file:   node_modules/negotiator/HISTORY.md
	new file:   node_modules/negotiator/LICENSE
	new file:   node_modules/negotiator/README.md
	new file:   node_modules/negotiator/index.js
	new file:   node_modules/negotiator/lib/charset.js
	new file:   node_modules/negotiator/lib/encoding.js
	new file:   node_modules/negotiator/lib/language.js
	new file:   node_modules/negotiator/lib/mediaType.js
	new file:   node_modules/negotiator/package.json
	new file:   node_modules/object-assign/index.js
	new file:   node_modules/object-assign/license
	new file:   node_modules/object-assign/package.json
	new file:   node_modules/object-assign/readme.md
	new file:   node_modules/object-inspect/.eslintrc
	new file:   node_modules/object-inspect/.github/FUNDING.yml
	new file:   node_modules/object-inspect/.nycrc
	new file:   node_modules/object-inspect/CHANGELOG.md
	new file:   node_modules/object-inspect/LICENSE
	new file:   node_modules/object-inspect/example/all.js
	new file:   node_modules/object-inspect/example/circular.js
	new file:   node_modules/object-inspect/example/fn.js
	new file:   node_modules/object-inspect/example/inspect.js
	new file:   node_modules/object-inspect/index.js
	new file:   node_modules/object-inspect/package-support.json
	new file:   node_modules/object-inspect/package.json
	new file:   node_modules/object-inspect/readme.markdown
	new file:   node_modules/object-inspect/test-core-js.js
	new file:   node_modules/object-inspect/test/bigint.js
	new file:   node_modules/object-inspect/test/browser/dom.js
	new file:   node_modules/object-inspect/test/circular.js
	new file:   node_modules/object-inspect/test/deep.js
	new file:   node_modules/object-inspect/test/element.js
	new file:   node_modules/object-inspect/test/err.js
	new file:   node_modules/object-inspect/test/fakes.js
	new file:   node_modules/object-inspect/test/fn.js
	new file:   node_modules/object-inspect/test/global.js
	new file:   node_modules/object-inspect/test/has.js
	new file:   node_modules/object-inspect/test/holes.js
	new file:   node_modules/object-inspect/test/indent-option.js
	new file:   node_modules/object-inspect/test/inspect.js
	new file:   node_modules/object-inspect/test/lowbyte.js
	new file:   node_modules/object-inspect/test/number.js
	new file:   node_modules/object-inspect/test/quoteStyle.js
	new file:   node_modules/object-inspect/test/toStringTag.js
	new file:   node_modules/object-inspect/test/undef.js
	new file:   node_modules/object-inspect/test/values.js
	new file:   node_modules/object-inspect/util.inspect.js
	new file:   node_modules/on-finished/HISTORY.md
	new file:   node_modules/on-finished/LICENSE
	new file:   node_modules/on-finished/README.md
	new file:   node_modules/on-finished/index.js
	new file:   node_modules/on-finished/package.json
	new file:   node_modules/parseurl/HISTORY.md
	new file:   node_modules/parseurl/LICENSE
	new file:   node_modules/parseurl/README.md
	new file:   node_modules/parseurl/index.js
	new file:   node_modules/parseurl/package.json
	new file:   node_modules/path-to-regexp/History.md
	new file:   node_modules/path-to-regexp/LICENSE
	new file:   node_modules/path-to-regexp/Readme.md
	new file:   node_modules/path-to-regexp/index.js
	new file:   node_modules/path-to-regexp/package.json
	new file:   node_modules/process-nextick-args/index.js
	new file:   node_modules/process-nextick-args/license.md
	new file:   node_modules/process-nextick-args/package.json
	new file:   node_modules/process-nextick-args/readme.md
	new file:   node_modules/proxy-addr/HISTORY.md
	new file:   node_modules/proxy-addr/LICENSE
	new file:   node_modules/proxy-addr/README.md
	new file:   node_modules/proxy-addr/index.js
	new file:   node_modules/proxy-addr/package.json
	new file:   node_modules/qs/.editorconfig
	new file:   node_modules/qs/.eslintrc
	new file:   node_modules/qs/.github/FUNDING.yml
	new file:   node_modules/qs/.nycrc
	new file:   node_modules/qs/CHANGELOG.md
	new file:   node_modules/qs/LICENSE.md
	new file:   node_modules/qs/README.md
	new file:   node_modules/qs/dist/qs.js
	new file:   node_modules/qs/lib/formats.js
	new file:   node_modules/qs/lib/index.js
	new file:   node_modules/qs/lib/parse.js
	new file:   node_modules/qs/lib/stringify.js
	new file:   node_modules/qs/lib/utils.js
	new file:   node_modules/qs/package.json
	new file:   node_modules/qs/test/parse.js
	new file:   node_modules/qs/test/stringify.js
	new file:   node_modules/qs/test/utils.js
	new file:   node_modules/range-parser/HISTORY.md
	new file:   node_modules/range-parser/LICENSE
	new file:   node_modules/range-parser/README.md
	new file:   node_modules/range-parser/index.js
	new file:   node_modules/range-parser/package.json
	new file:   node_modules/raw-body/HISTORY.md
	new file:   node_modules/raw-body/LICENSE
	new file:   node_modules/raw-body/README.md
	new file:   node_modules/raw-body/SECURITY.md
	new file:   node_modules/raw-body/index.d.ts
	new file:   node_modules/raw-body/index.js
	new file:   node_modules/raw-body/package.json
	new file:   node_modules/readable-stream/.travis.yml
	new file:   node_modules/readable-stream/CONTRIBUTING.md
	new file:   node_modules/readable-stream/GOVERNANCE.md
	new file:   node_modules/readable-stream/LICENSE
	new file:   node_modules/readable-stream/README.md
	new file:   node_modules/readable-stream/doc/wg-meetings/2015-01-30.md
	new file:   node_modules/readable-stream/duplex-browser.js
	new file:   node_modules/readable-stream/duplex.js
	new file:   node_modules/readable-stream/lib/_stream_duplex.js
	new file:   node_modules/readable-stream/lib/_stream_passthrough.js
	new file:   node_modules/readable-stream/lib/_stream_readable.js
	new file:   node_modules/readable-stream/lib/_stream_transform.js
	new file:   node_modules/readable-stream/lib/_stream_writable.js
	new file:   node_modules/readable-stream/lib/internal/streams/BufferList.js
	new file:   node_modules/readable-stream/lib/internal/streams/destroy.js
	new file:   node_modules/readable-stream/lib/internal/streams/stream-browser.js
	new file:   node_modules/readable-stream/lib/internal/streams/stream.js
	new file:   node_modules/readable-stream/node_modules/safe-buffer/LICENSE
	new file:   node_modules/readable-stream/node_modules/safe-buffer/README.md
	new file:   node_modules/readable-stream/node_modules/safe-buffer/index.d.ts
	new file:   node_modules/readable-stream/node_modules/safe-buffer/index.js
	new file:   node_modules/readable-stream/node_modules/safe-buffer/package.json
	new file:   node_modules/readable-stream/package.json
	new file:   node_modules/readable-stream/passthrough.js
	new file:   node_modules/readable-stream/readable-browser.js
	new file:   node_modules/readable-stream/readable.js
	new file:   node_modules/readable-stream/transform.js
	new file:   node_modules/readable-stream/writable-browser.js
	new file:   node_modules/readable-stream/writable.js
	new file:   node_modules/safe-buffer/LICENSE
	new file:   node_modules/safe-buffer/README.md
	new file:   node_modules/safe-buffer/index.d.ts
	new file:   node_modules/safe-buffer/index.js
	new file:   node_modules/safe-buffer/package.json
	new file:   node_modules/safer-buffer/LICENSE
	new file:   node_modules/safer-buffer/Porting-Buffer.md
	new file:   node_modules/safer-buffer/Readme.md
	new file:   node_modules/safer-buffer/dangerous.js
	new file:   node_modules/safer-buffer/package.json
	new file:   node_modules/safer-buffer/safer.js
	new file:   node_modules/safer-buffer/tests.js
	new file:   node_modules/send/HISTORY.md
	new file:   node_modules/send/LICENSE
	new file:   node_modules/send/README.md
	new file:   node_modules/send/SECURITY.md
	new file:   node_modules/send/index.js
	new file:   node_modules/send/node_modules/ms/index.js
	new file:   node_modules/send/node_modules/ms/license.md
	new file:   node_modules/send/node_modules/ms/package.json
	new file:   node_modules/send/node_modules/ms/readme.md
	new file:   node_modules/send/package.json
	new file:   node_modules/serve-static/HISTORY.md
	new file:   node_modules/serve-static/LICENSE
	new file:   node_modules/serve-static/README.md
	new file:   node_modules/serve-static/index.js
	new file:   node_modules/serve-static/package.json
	new file:   node_modules/set-function-length/.eslintrc
	new file:   node_modules/set-function-length/.github/FUNDING.yml
	new file:   node_modules/set-function-length/.nycrc
	new file:   node_modules/set-function-length/CHANGELOG.md
	new file:   node_modules/set-function-length/LICENSE
	new file:   node_modules/set-function-length/README.md
	new file:   node_modules/set-function-length/env.d.ts
	new file:   node_modules/set-function-length/env.js
	new file:   node_modules/set-function-length/index.d.ts
	new file:   node_modules/set-function-length/index.js
	new file:   node_modules/set-function-length/package.json
	new file:   node_modules/set-function-length/tsconfig.json
	new file:   node_modules/setprototypeof/LICENSE
	new file:   node_modules/setprototypeof/README.md
	new file:   node_modules/setprototypeof/index.d.ts
	new file:   node_modules/setprototypeof/index.js
	new file:   node_modules/setprototypeof/package.json
	new file:   node_modules/setprototypeof/test/index.js
	new file:   node_modules/side-channel/.editorconfig
	new file:   node_modules/side-channel/.eslintrc
	new file:   node_modules/side-channel/.github/FUNDING.yml
	new file:   node_modules/side-channel/.nycrc
	new file:   node_modules/side-channel/CHANGELOG.md
	new file:   node_modules/side-channel/LICENSE
	new file:   node_modules/side-channel/README.md
	new file:   node_modules/side-channel/index.d.ts
	new file:   node_modules/side-channel/index.js
	new file:   node_modules/side-channel/package.json
	new file:   node_modules/side-channel/test/index.js
	new file:   node_modules/side-channel/tsconfig.json
	new file:   node_modules/sqlstring/HISTORY.md
	new file:   node_modules/sqlstring/LICENSE
	new file:   node_modules/sqlstring/README.md
	new file:   node_modules/sqlstring/index.js
	new file:   node_modules/sqlstring/lib/SqlString.js
	new file:   node_modules/sqlstring/package.json
	new file:   node_modules/statuses/HISTORY.md
	new file:   node_modules/statuses/LICENSE
	new file:   node_modules/statuses/README.md
	new file:   node_modules/statuses/codes.json
	new file:   node_modules/statuses/index.js
	new file:   node_modules/statuses/package.json
	new file:   node_modules/string_decoder/.travis.yml
	new file:   node_modules/string_decoder/LICENSE
	new file:   node_modules/string_decoder/README.md
	new file:   node_modules/string_decoder/lib/string_decoder.js
	new file:   node_modules/string_decoder/node_modules/safe-buffer/LICENSE
	new file:   node_modules/string_decoder/node_modules/safe-buffer/README.md
	new file:   node_modules/string_decoder/node_modules/safe-buffer/index.d.ts
	new file:   node_modules/string_decoder/node_modules/safe-buffer/index.js
	new file:   node_modules/string_decoder/node_modules/safe-buffer/package.json
	new file:   node_modules/string_decoder/package.json
	new file:   node_modules/toidentifier/HISTORY.md
	new file:   node_modules/toidentifier/LICENSE
	new file:   node_modules/toidentifier/README.md
	new file:   node_modules/toidentifier/index.js
	new file:   node_modules/toidentifier/package.json
	new file:   node_modules/type-is/HISTORY.md
	new file:   node_modules/type-is/LICENSE
	new file:   node_modules/type-is/README.md
	new file:   node_modules/type-is/index.js
	new file:   node_modules/type-is/package.json
	new file:   node_modules/unpipe/HISTORY.md
	new file:   node_modules/unpipe/LICENSE
	new file:   node_modules/unpipe/README.md
	new file:   node_modules/unpipe/index.js
	new file:   node_modules/unpipe/package.json
	new file:   node_modules/util-deprecate/History.md
	new file:   node_modules/util-deprecate/LICENSE
	new file:   node_modules/util-deprecate/README.md
	new file:   node_modules/util-deprecate/browser.js
	new file:   node_modules/util-deprecate/node.js
	new file:   node_modules/util-deprecate/package.json
	new file:   node_modules/utils-merge/.npmignore
	new file:   node_modules/utils-merge/LICENSE
	new file:   node_modules/utils-merge/README.md
	new file:   node_modules/utils-merge/index.js
	new file:   node_modules/utils-merge/package.json
	new file:   node_modules/vary/HISTORY.md
	new file:   node_modules/vary/LICENSE
	new file:   node_modules/vary/README.md
	new file:   node_modules/vary/index.js
	new file:   node_modules/vary/package.json
	new file:   package-lock.json
	new file:   package.json
	new file:   server.js
	new file:   static/css/main.css
	new file:   static/css/sensor-1.css
	new file:   static/css/sensor-2.css
	new file:   static/css/sensor-3.css
	new file:   static/css/sensor-4.css
	new file:   static/img/bg1.png
	new file:   static/img/bg2.png
	new file:   static/img/bg3.png
	new file:   static/img/bp-1.jpg
	new file:   static/img/bp-2.png
	new file:   static/img/bp-3.png
	new file:   static/img/jt.png
	new file:   static/img/line1.png
	new file:   static/img/line2.png
	new file:   static/img/tit1.png
	new file:   static/img/title.png
	new file:   static/js/main.js
	new file:   static/js/sensor-1.js
	new file:   static/js/sensor-2.js
	new file:   static/js/sensor-3.js
	new file:   static/js/sensor-4.js
	new file:   templates/main.html
	new file:   templates/sensor-1.html
	new file:   templates/sensor-2.html
	new file:   templates/sensor-3.html
	new file:   templates/sensor-4.html
2024-07-20 14:29:44 +08:00

1179 lines
28 KiB
JavaScript

/*!
* express
* Copyright(c) 2009-2013 TJ Holowaychuk
* Copyright(c) 2014-2015 Douglas Christopher Wilson
* MIT Licensed
*/
'use strict';
/**
* Module dependencies.
* @private
*/
var Buffer = require('safe-buffer').Buffer
var contentDisposition = require('content-disposition');
var createError = require('http-errors')
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 statuses = require('statuses')
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 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.
* @public
*/
var res = Object.create(http.ServerResponse.prototype)
/**
* Module exports.
* @public
*/
module.exports = res
/**
* Module variables.
* @private
*/
var charsetRegExp = /;\s*charset\s*=/;
var schemaAndHostRegExp = /^(?:[a-zA-Z][a-zA-Z0-9+.-]*:)?\/\/[^\\\/\?]+/;
/**
* Set status `code`.
*
* @param {Number} code
* @return {ServerResponse}
* @public
*/
res.status = function status(code) {
if ((typeof code === 'string' || Math.floor(code) !== code) && code > 99 && code < 1000) {
deprecate('res.status(' + JSON.stringify(code) + '): use res.status(' + Math.floor(code) + ') instead')
}
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(Buffer.from('wahoo'));
* res.send({ some: 'json' });
* res.send('<p>some html</p>');
*
* @param {string|number|boolean|object|Buffer} body
* @public
*/
res.send = function send(body) {
var chunk = body;
var encoding;
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 = statuses.message[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'));
}
}
// determine if ETag should be generated
var etagFn = app.get('etag fn')
var generateETag = !this.get('ETag') && typeof etagFn === 'function'
// populate Content-Length
var len
if (chunk !== undefined) {
if (Buffer.isBuffer(chunk)) {
// get length of Buffer
len = chunk.length
} else if (!generateETag && chunk.length < 1000) {
// just calculate length when no ETag + small chunk
len = Buffer.byteLength(chunk, encoding)
} else {
// convert chunk to Buffer and calculate
chunk = Buffer.from(chunk, encoding)
encoding = undefined;
len = chunk.length
}
this.set('Content-Length', len);
}
// populate ETag
var etag;
if (generateETag && len !== undefined) {
if ((etag = etagFn(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 = '';
}
// alter headers for 205
if (this.statusCode === 205) {
this.set('Content-Length', '0')
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 escape = app.get('json escape')
var replacer = app.get('json replacer');
var spaces = app.get('json spaces');
var body = stringify(val, replacer, spaces, escape)
// 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.jsonp(body, status) backwards compat
if (typeof arguments[1] === 'number') {
deprecate('res.jsonp(obj, status): Use res.status(status).jsonp(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 escape = app.get('json escape')
var replacer = app.get('json replacer');
var spaces = app.get('json spaces');
var body = stringify(val, replacer, spaces, escape)
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.set('X-Content-Type-Options', 'nosniff');
this.set('Content-Type', 'text/javascript');
// restrict callback charset
callback = callback.replace(/[^\[\]\w$.]/g, '');
if (body === undefined) {
// empty argument
body = ''
} else if (typeof body === 'string') {
// 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 = statuses.message[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.headersSent`
* 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');
}
if (typeof path !== 'string') {
throw new TypeError('path must be a string 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.headersSent`
* 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 !== 'ECONNABORTED' && 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
* occurred. Be sure to check `res.headersSent` if you plan to respond.
*
* Optionally providing an `options` object to use with `res.sendFile()`.
* This function will set the `Content-Disposition` header, overriding
* any `Content-Disposition` header passed as header options in order
* to set the attachment and filename.
*
* This method uses `res.sendFile()`.
*
* @public
*/
res.download = function download (path, filename, options, callback) {
var done = callback;
var name = filename;
var opts = options || null
// support function as second or third arg
if (typeof filename === 'function') {
done = filename;
name = null;
opts = null
} else if (typeof options === 'function') {
done = options
opts = null
}
// support optional filename, where options may be in it's place
if (typeof filename === 'object' &&
(typeof options === 'function' || options === undefined)) {
name = null
opts = filename
}
// set Content-Disposition when file is sent
var headers = {
'Content-Disposition': contentDisposition(name || path)
};
// merge user-provided headers
if (opts && opts.headers) {
var keys = Object.keys(opts.headers)
for (var i = 0; i < keys.length; i++) {
var key = keys[i]
if (key.toLowerCase() !== 'content-disposition') {
headers[key] = opts.headers[key]
}
}
}
// merge user-provided options
opts = Object.create(opts)
opts.headers = headers
// Resolve the full path for sendFile
var fullPath = !opts.root
? resolve(path)
: path
// send file
return this.sendFile(fullPath, opts, 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('<p>hey</p>');
* },
*
* 'application/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('<p>hey</p>');
* },
*
* 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 keys = Object.keys(obj)
.filter(function (v) { return v !== 'default' })
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 (obj.default) {
obj.default(req, this, next)
} else {
next(createError(406, {
types: normalizeTypes(keys).map(function (o) { return o.value })
}))
}
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', ['<http://localhost/>', '<http://localhost:3000/>']);
* 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') {
if (Array.isArray(value)) {
throw new TypeError('Content-Type cannot be set to an Array');
}
if (!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 });
*
* // same as above
* res.cookie('rememberme', '1', { maxAge: 900000, httpOnly: true })
*
* @param {String} name
* @param {String|Object} value
* @param {Object} [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 (opts.maxAge != null) {
var maxAge = opts.maxAge - 0
if (!isNaN(maxAge)) {
opts.expires = new Date(Date.now() + maxAge)
opts.maxAge = Math.floor(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;
// "back" is an alias for the referrer
if (url === 'back') {
loc = this.req.get('Referrer') || '/';
} else {
loc = String(url);
}
var m = schemaAndHostRegExp.exec(loc);
var pos = m ? m[0].length + 1 : 0;
// Only encode after host to avoid invalid encoding which can introduce
// vulnerabilities (e.g. `\\` to `%5C`).
loc = loc.slice(0, pos) + encodeUrl(loc.slice(pos));
return this.set('Location', 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 = statuses.message[status] + '. Redirecting to ' + address
},
html: function(){
var u = escapeHtml(address);
body = '<p>' + statuses.message[status] + '. Redirecting to <a href="' + u + '">' + u + '</a></p>'
},
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, with the
* ability to escape characters that can trigger HTML sniffing.
*
* @param {*} value
* @param {function} replacer
* @param {number} spaces
* @param {boolean} escape
* @returns {string}
* @private
*/
function stringify (value, replacer, spaces, escape) {
// v8 checks arguments.length for optimizing simple call
// https://bugs.chromium.org/p/v8/issues/detail?id=4730
var json = replacer || spaces
? JSON.stringify(value, replacer, spaces)
: JSON.stringify(value);
if (escape && typeof json === 'string') {
json = json.replace(/[<>&]/g, function (c) {
switch (c.charCodeAt(0)) {
case 0x3c:
return '\\u003c'
case 0x3e:
return '\\u003e'
case 0x26:
return '\\u0026'
/* istanbul ignore next: unreachable default */
default:
return c
}
})
}
return json
}