Firebase Update
This commit is contained in:
		
							
								
								
									
										4
									
								
								express-server/node_modules/express/lib/application.js
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								express-server/node_modules/express/lib/application.js
									
									
									
										generated
									
									
										vendored
									
									
								
							@@ -207,7 +207,7 @@ app.use = function use(fn) {
 | 
			
		||||
  var fns = flatten(slice.call(arguments, offset));
 | 
			
		||||
 | 
			
		||||
  if (fns.length === 0) {
 | 
			
		||||
    throw new TypeError('app.use() requires middleware functions');
 | 
			
		||||
    throw new TypeError('app.use() requires a middleware function')
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  // setup router
 | 
			
		||||
@@ -338,7 +338,7 @@ app.param = function param(name, fn) {
 | 
			
		||||
 * Assign `setting` to `val`, or return `setting`'s value.
 | 
			
		||||
 *
 | 
			
		||||
 *    app.set('foo', 'bar');
 | 
			
		||||
 *    app.get('foo');
 | 
			
		||||
 *    app.set('foo');
 | 
			
		||||
 *    // => "bar"
 | 
			
		||||
 *
 | 
			
		||||
 * Mounted servers inherit their parent server's settings.
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										13
									
								
								express-server/node_modules/express/lib/express.js
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										13
									
								
								express-server/node_modules/express/lib/express.js
									
									
									
										generated
									
									
										vendored
									
									
								
							@@ -12,6 +12,7 @@
 | 
			
		||||
 * Module dependencies.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
var bodyParser = require('body-parser')
 | 
			
		||||
var EventEmitter = require('events').EventEmitter;
 | 
			
		||||
var mixin = require('merge-descriptors');
 | 
			
		||||
var proto = require('./application');
 | 
			
		||||
@@ -74,16 +75,16 @@ exports.Router = Router;
 | 
			
		||||
 * Expose middleware
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
exports.json = bodyParser.json
 | 
			
		||||
exports.query = require('./middleware/query');
 | 
			
		||||
exports.static = require('serve-static');
 | 
			
		||||
exports.urlencoded = bodyParser.urlencoded
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Replace removed middleware with an appropriate error message.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
[
 | 
			
		||||
  'json',
 | 
			
		||||
  'urlencoded',
 | 
			
		||||
var removedMiddlewares = [
 | 
			
		||||
  'bodyParser',
 | 
			
		||||
  'compress',
 | 
			
		||||
  'cookieSession',
 | 
			
		||||
@@ -100,8 +101,10 @@ exports.static = require('serve-static');
 | 
			
		||||
  'directory',
 | 
			
		||||
  'limit',
 | 
			
		||||
  'multipart',
 | 
			
		||||
  'staticCache',
 | 
			
		||||
].forEach(function (name) {
 | 
			
		||||
  'staticCache'
 | 
			
		||||
]
 | 
			
		||||
 | 
			
		||||
removedMiddlewares.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.');
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										8
									
								
								express-server/node_modules/express/lib/request.js
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								express-server/node_modules/express/lib/request.js
									
									
									
										generated
									
									
										vendored
									
									
								
							@@ -315,8 +315,12 @@ defineGetter(req, 'protocol', function protocol(){
 | 
			
		||||
 | 
			
		||||
  // 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];
 | 
			
		||||
  var header = this.get('X-Forwarded-Proto') || proto
 | 
			
		||||
  var index = header.indexOf(',')
 | 
			
		||||
 | 
			
		||||
  return index !== -1
 | 
			
		||||
    ? header.substring(0, index).trim()
 | 
			
		||||
    : header.trim()
 | 
			
		||||
});
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										101
									
								
								express-server/node_modules/express/lib/response.js
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										101
									
								
								express-server/node_modules/express/lib/response.js
									
									
									
										generated
									
									
										vendored
									
									
								
							@@ -12,6 +12,7 @@
 | 
			
		||||
 * @private
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
var Buffer = require('safe-buffer').Buffer
 | 
			
		||||
var contentDisposition = require('content-disposition');
 | 
			
		||||
var deprecate = require('depd')('express');
 | 
			
		||||
var encodeUrl = require('encodeurl');
 | 
			
		||||
@@ -95,7 +96,7 @@ res.links = function(links){
 | 
			
		||||
 *
 | 
			
		||||
 * Examples:
 | 
			
		||||
 *
 | 
			
		||||
 *     res.send(new Buffer('wahoo'));
 | 
			
		||||
 *     res.send(Buffer.from('wahoo'));
 | 
			
		||||
 *     res.send({ some: 'json' });
 | 
			
		||||
 *     res.send('<p>some html</p>');
 | 
			
		||||
 *
 | 
			
		||||
@@ -106,7 +107,6 @@ res.links = function(links){
 | 
			
		||||
res.send = function send(body) {
 | 
			
		||||
  var chunk = body;
 | 
			
		||||
  var encoding;
 | 
			
		||||
  var len;
 | 
			
		||||
  var req = this.req;
 | 
			
		||||
  var type;
 | 
			
		||||
 | 
			
		||||
@@ -171,23 +171,33 @@ res.send = function send(body) {
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  // 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)) {
 | 
			
		||||
      // convert chunk to Buffer; saves later double conversions
 | 
			
		||||
      chunk = new Buffer(chunk, encoding);
 | 
			
		||||
    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
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    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))) {
 | 
			
		||||
  if (generateETag && len !== undefined) {
 | 
			
		||||
    if ((etag = etagFn(chunk, encoding))) {
 | 
			
		||||
      this.set('ETag', etag);
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
@@ -244,9 +254,10 @@ res.json = function json(obj) {
 | 
			
		||||
 | 
			
		||||
  // 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);
 | 
			
		||||
  var body = stringify(val, replacer, spaces, escape)
 | 
			
		||||
 | 
			
		||||
  // content-type
 | 
			
		||||
  if (!this.get('Content-Type')) {
 | 
			
		||||
@@ -286,9 +297,10 @@ res.jsonp = function jsonp(obj) {
 | 
			
		||||
 | 
			
		||||
  // 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);
 | 
			
		||||
  var body = stringify(val, replacer, spaces, escape)
 | 
			
		||||
  var callback = this.req.query[app.get('jsonp callback name')];
 | 
			
		||||
 | 
			
		||||
  // content-type
 | 
			
		||||
@@ -304,7 +316,6 @@ res.jsonp = function jsonp(obj) {
 | 
			
		||||
 | 
			
		||||
  // 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');
 | 
			
		||||
 | 
			
		||||
@@ -489,7 +500,7 @@ res.sendfile = function (path, options, callback) {
 | 
			
		||||
    if (err && err.code === 'EISDIR') return next();
 | 
			
		||||
 | 
			
		||||
    // next() all but write errors
 | 
			
		||||
    if (err && err.code !== 'ECONNABORT' && err.syscall !== 'write') {
 | 
			
		||||
    if (err && err.code !== 'ECONNABORTED' && err.syscall !== 'write') {
 | 
			
		||||
      next(err);
 | 
			
		||||
    }
 | 
			
		||||
  });
 | 
			
		||||
@@ -506,19 +517,29 @@ res.sendfile = deprecate.function(res.sendfile,
 | 
			
		||||
 * 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()`.
 | 
			
		||||
 * 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, callback) {
 | 
			
		||||
res.download = function download (path, filename, options, callback) {
 | 
			
		||||
  var done = callback;
 | 
			
		||||
  var name = filename;
 | 
			
		||||
  var opts = options || null
 | 
			
		||||
 | 
			
		||||
  // support function as second arg
 | 
			
		||||
  // 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
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  // set Content-Disposition when file is sent
 | 
			
		||||
@@ -526,10 +547,26 @@ res.download = function download(path, filename, callback) {
 | 
			
		||||
    '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 = resolve(path);
 | 
			
		||||
 | 
			
		||||
  return this.sendFile(fullPath, { headers: headers }, done);
 | 
			
		||||
  // send file
 | 
			
		||||
  return this.sendFile(fullPath, opts, done)
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
@@ -1063,14 +1100,38 @@ function sendfile(res, file, options, callback) {
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Stringify JSON, like JSON.stringify, but v8 optimized.
 | 
			
		||||
 * Stringify JSON, like JSON.stringify, but v8 optimized, with the
 | 
			
		||||
 * ability to escape characters that can trigger HTML sniffing.
 | 
			
		||||
 *
 | 
			
		||||
 * @param {*} value
 | 
			
		||||
 * @param {function} replaces
 | 
			
		||||
 * @param {number} spaces
 | 
			
		||||
 * @param {boolean} escape
 | 
			
		||||
 * @returns {string}
 | 
			
		||||
 * @private
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
function stringify(value, replacer, spaces) {
 | 
			
		||||
function stringify (value, replacer, spaces, escape) {
 | 
			
		||||
  // v8 checks arguments.length for optimizing simple call
 | 
			
		||||
  // https://bugs.chromium.org/p/v8/issues/detail?id=4730
 | 
			
		||||
  return replacer || spaces
 | 
			
		||||
  var json = replacer || spaces
 | 
			
		||||
    ? JSON.stringify(value, replacer, spaces)
 | 
			
		||||
    : JSON.stringify(value);
 | 
			
		||||
 | 
			
		||||
  if (escape) {
 | 
			
		||||
    json = json.replace(/[<>&]/g, function (c) {
 | 
			
		||||
      switch (c.charCodeAt(0)) {
 | 
			
		||||
        case 0x3c:
 | 
			
		||||
          return '\\u003c'
 | 
			
		||||
        case 0x3e:
 | 
			
		||||
          return '\\u003e'
 | 
			
		||||
        case 0x26:
 | 
			
		||||
          return '\\u0026'
 | 
			
		||||
        default:
 | 
			
		||||
          return c
 | 
			
		||||
      }
 | 
			
		||||
    })
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  return json
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										6
									
								
								express-server/node_modules/express/lib/router/index.js
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										6
									
								
								express-server/node_modules/express/lib/router/index.js
									
									
									
										generated
									
									
										vendored
									
									
								
							@@ -35,7 +35,7 @@ var toString = Object.prototype.toString;
 | 
			
		||||
/**
 | 
			
		||||
 * Initialize a new `Router` with the given `options`.
 | 
			
		||||
 *
 | 
			
		||||
 * @param {Object} options
 | 
			
		||||
 * @param {Object} [options]
 | 
			
		||||
 * @return {Router} which is an callable function
 | 
			
		||||
 * @public
 | 
			
		||||
 */
 | 
			
		||||
@@ -448,14 +448,14 @@ proto.use = function use(fn) {
 | 
			
		||||
  var callbacks = flatten(slice.call(arguments, offset));
 | 
			
		||||
 | 
			
		||||
  if (callbacks.length === 0) {
 | 
			
		||||
    throw new TypeError('Router.use() requires middleware functions');
 | 
			
		||||
    throw new TypeError('Router.use() requires a middleware function')
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  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));
 | 
			
		||||
      throw new TypeError('Router.use() requires a middleware function but got a ' + gettype(fn))
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    // add the middleware
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										4
									
								
								express-server/node_modules/express/lib/router/route.js
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								express-server/node_modules/express/lib/router/route.js
									
									
									
										generated
									
									
										vendored
									
									
								
							@@ -175,7 +175,7 @@ Route.prototype.all = function all() {
 | 
			
		||||
 | 
			
		||||
    if (typeof handle !== 'function') {
 | 
			
		||||
      var type = toString.call(handle);
 | 
			
		||||
      var msg = 'Route.all() requires callback functions but got a ' + type;
 | 
			
		||||
      var msg = 'Route.all() requires a callback function but got a ' + type
 | 
			
		||||
      throw new TypeError(msg);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
@@ -198,7 +198,7 @@ methods.forEach(function(method){
 | 
			
		||||
 | 
			
		||||
      if (typeof handle !== 'function') {
 | 
			
		||||
        var type = toString.call(handle);
 | 
			
		||||
        var msg = 'Route.' + method + '() requires callback functions but got a ' + type;
 | 
			
		||||
        var msg = 'Route.' + method + '() requires a callback function but got a ' + type
 | 
			
		||||
        throw new Error(msg);
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										36
									
								
								express-server/node_modules/express/lib/utils.js
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										36
									
								
								express-server/node_modules/express/lib/utils.js
									
									
									
										generated
									
									
										vendored
									
									
								
							@@ -12,6 +12,7 @@
 | 
			
		||||
 * @api private
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
var Buffer = require('safe-buffer').Buffer
 | 
			
		||||
var contentDisposition = require('content-disposition');
 | 
			
		||||
var contentType = require('content-type');
 | 
			
		||||
var deprecate = require('depd')('express');
 | 
			
		||||
@@ -31,13 +32,7 @@ var querystring = require('querystring');
 | 
			
		||||
 * @api private
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
exports.etag = function (body, encoding) {
 | 
			
		||||
  var buf = !Buffer.isBuffer(body)
 | 
			
		||||
    ? new Buffer(body, encoding)
 | 
			
		||||
    : body;
 | 
			
		||||
 | 
			
		||||
  return etag(buf, {weak: false});
 | 
			
		||||
};
 | 
			
		||||
exports.etag = createETagGenerator({ weak: false })
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Return weak ETag for `body`.
 | 
			
		||||
@@ -48,13 +43,7 @@ exports.etag = function (body, encoding) {
 | 
			
		||||
 * @api private
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
exports.wetag = function wetag(body, encoding){
 | 
			
		||||
  var buf = !Buffer.isBuffer(body)
 | 
			
		||||
    ? new Buffer(body, encoding)
 | 
			
		||||
    : body;
 | 
			
		||||
 | 
			
		||||
  return etag(buf, {weak: true});
 | 
			
		||||
};
 | 
			
		||||
exports.wetag = createETagGenerator({ weak: true })
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Check if `path` looks absolute.
 | 
			
		||||
@@ -273,6 +262,25 @@ exports.setCharset = function setCharset(type, charset) {
 | 
			
		||||
  return contentType.format(parsed);
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Create an ETag generator function, generating ETags with
 | 
			
		||||
 * the given options.
 | 
			
		||||
 *
 | 
			
		||||
 * @param {object} options
 | 
			
		||||
 * @return {function}
 | 
			
		||||
 * @private
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
function createETagGenerator (options) {
 | 
			
		||||
  return function generateETag (body, encoding) {
 | 
			
		||||
    var buf = !Buffer.isBuffer(body)
 | 
			
		||||
      ? Buffer.from(body, encoding)
 | 
			
		||||
      : body
 | 
			
		||||
 | 
			
		||||
    return etag(buf, options)
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Parse an extended query string with qs.
 | 
			
		||||
 *
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										10
									
								
								express-server/node_modules/express/lib/view.js
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										10
									
								
								express-server/node_modules/express/lib/view.js
									
									
									
										generated
									
									
										vendored
									
									
								
							@@ -76,7 +76,15 @@ function View(name, options) {
 | 
			
		||||
    // load engine
 | 
			
		||||
    var mod = this.ext.substr(1)
 | 
			
		||||
    debug('require "%s"', mod)
 | 
			
		||||
    opts.engines[this.ext] = require(mod).__express
 | 
			
		||||
 | 
			
		||||
    // default engine export
 | 
			
		||||
    var fn = require(mod).__express
 | 
			
		||||
 | 
			
		||||
    if (typeof fn !== 'function') {
 | 
			
		||||
      throw new Error('Module "' + mod + '" does not provide a view engine.')
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    opts.engines[this.ext] = fn
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  // store loaded engine
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user