├── .gitignore ├── deploy ├── node_modules │ ├── mime │ │ ├── .npmignore │ │ ├── cli.js │ │ ├── build │ │ │ ├── build.js │ │ │ └── test.js │ │ ├── LICENSE │ │ └── README.md │ ├── .bin │ │ └── mime │ ├── qs │ │ ├── .eslintignore │ │ ├── .travis.yml │ │ ├── CONTRIBUTING.md │ │ ├── lib │ │ │ └── index.js │ │ ├── .npmignore │ │ ├── bower.json │ │ ├── test │ │ │ └── utils.js │ │ ├── LICENSE │ │ └── package.json │ ├── ipaddr.js │ │ ├── .npmignore │ │ ├── .travis.yml │ │ ├── bower.json │ │ ├── Cakefile │ │ ├── LICENSE │ │ └── package.json │ ├── debug │ │ ├── .jshintrc │ │ ├── .npmignore │ │ ├── component.json │ │ ├── bower.json │ │ └── Makefile │ ├── cookie-signature │ │ ├── .npmignore │ │ ├── History.md │ │ ├── index.js │ │ ├── Readme.md │ │ └── package.json │ ├── ms │ │ ├── .npmignore │ │ ├── README.md │ │ ├── LICENSE │ │ ├── History.md │ │ └── package.json │ ├── unpipe │ │ ├── HISTORY.md │ │ ├── LICENSE │ │ ├── README.md │ │ └── index.js │ ├── forwarded │ │ ├── HISTORY.md │ │ ├── index.js │ │ ├── LICENSE │ │ └── README.md │ ├── utils-merge │ │ ├── .travis.yml │ │ ├── index.js │ │ ├── README.md │ │ ├── LICENSE │ │ └── package.json │ ├── mime-db │ │ ├── index.js │ │ └── LICENSE │ ├── inherits │ │ ├── inherits.js │ │ ├── inherits_browser.js │ │ ├── LICENSE │ │ ├── README.md │ │ └── package.json │ ├── express │ │ ├── index.js │ │ ├── lib │ │ │ ├── middleware │ │ │ │ ├── init.js │ │ │ │ └── query.js │ │ │ └── express.js │ │ └── LICENSE │ ├── content-type │ │ ├── HISTORY.md │ │ └── LICENSE │ ├── depd │ │ ├── lib │ │ │ ├── compat │ │ │ │ ├── event-listener-count.js │ │ │ │ ├── buffer-concat.js │ │ │ │ ├── index.js │ │ │ │ └── callsite-tostring.js │ │ │ └── browser │ │ │ │ └── index.js │ │ ├── LICENSE │ │ └── History.md │ ├── merge-descriptors │ │ ├── HISTORY.md │ │ ├── LICENSE │ │ ├── README.md │ │ └── index.js │ ├── methods │ │ ├── HISTORY.md │ │ ├── LICENSE │ │ ├── index.js │ │ └── README.md │ ├── media-typer │ │ ├── HISTORY.md │ │ ├── LICENSE │ │ └── README.md │ ├── vary │ │ ├── HISTORY.md │ │ ├── LICENSE │ │ ├── README.md │ │ └── index.js │ ├── range-parser │ │ ├── HISTORY.md │ │ ├── LICENSE │ │ ├── index.js │ │ └── README.md │ ├── fresh │ │ ├── HISTORY.md │ │ ├── LICENSE │ │ ├── index.js │ │ └── README.md │ ├── path-to-regexp │ │ ├── History.md │ │ ├── LICENSE │ │ └── Readme.md │ ├── escape-html │ │ ├── Readme.md │ │ ├── LICENSE │ │ ├── index.js │ │ └── package.json │ ├── content-disposition │ │ ├── HISTORY.md │ │ └── LICENSE │ ├── parseurl │ │ ├── HISTORY.md │ │ └── LICENSE │ ├── etag │ │ ├── LICENSE │ │ └── HISTORY.md │ ├── proxy-addr │ │ ├── LICENSE │ │ └── HISTORY.md │ ├── destroy │ │ ├── LICENSE │ │ ├── index.js │ │ └── README.md │ ├── ee-first │ │ ├── LICENSE │ │ └── index.js │ ├── statuses │ │ ├── LICENSE │ │ ├── index.js │ │ └── codes.json │ ├── array-flatten │ │ ├── LICENSE │ │ ├── README.md │ │ └── array-flatten.js │ ├── http-errors │ │ ├── LICENSE │ │ ├── HISTORY.md │ │ └── README.md │ ├── finalhandler │ │ ├── LICENSE │ │ └── HISTORY.md │ ├── send │ │ └── LICENSE │ ├── serve-static │ │ ├── node_modules │ │ │ └── send │ │ │ │ └── LICENSE │ │ └── LICENSE │ ├── accepts │ │ └── LICENSE │ ├── mime-types │ │ └── LICENSE │ ├── on-finished │ │ ├── LICENSE │ │ └── HISTORY.md │ ├── type-is │ │ └── LICENSE │ ├── negotiator │ │ ├── LICENSE │ │ ├── HISTORY.md │ │ ├── index.js │ │ └── lib │ │ │ └── charset.js │ └── cookie │ │ ├── LICENSE │ │ ├── HISTORY.md │ │ └── README.md ├── src │ ├── index.js │ ├── initValue.js │ ├── debounce.js │ ├── createIFrame.js │ ├── style.css │ └── handleChange.js ├── public │ ├── src │ │ ├── index.js │ │ ├── initValue.js │ │ ├── debounce.js │ │ ├── createIFrame.js │ │ ├── style.css │ │ └── handleChange.js │ ├── index.html │ └── lib │ │ └── material.css ├── index.js ├── package.json ├── index.html └── lib │ └── material.css ├── src ├── index.js ├── initValue.js ├── debounce.js ├── createIFrame.js ├── style.css └── handleChange.js ├── screenshot ├── screen.gif └── screen.png ├── webpack.prod.js ├── webpack.config.js ├── package.json ├── index.html └── lib └── material.css /.gitignore: -------------------------------------------------------------------------------- 1 | node_modules/* -------------------------------------------------------------------------------- /deploy/node_modules/mime/.npmignore: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /deploy/node_modules/.bin/mime: -------------------------------------------------------------------------------- 1 | ../mime/cli.js -------------------------------------------------------------------------------- /deploy/node_modules/qs/.eslintignore: -------------------------------------------------------------------------------- 1 | dist 2 | -------------------------------------------------------------------------------- /deploy/node_modules/ipaddr.js/.npmignore: -------------------------------------------------------------------------------- 1 | .idea 2 | node_modules 3 | -------------------------------------------------------------------------------- /deploy/node_modules/debug/.jshintrc: -------------------------------------------------------------------------------- 1 | { 2 | "laxbreak": true 3 | } 4 | -------------------------------------------------------------------------------- /deploy/node_modules/cookie-signature/.npmignore: -------------------------------------------------------------------------------- 1 | support 2 | test 3 | examples 4 | *.sock 5 | -------------------------------------------------------------------------------- /deploy/node_modules/debug/.npmignore: -------------------------------------------------------------------------------- 1 | support 2 | test 3 | examples 4 | example 5 | *.sock 6 | dist 7 | -------------------------------------------------------------------------------- /deploy/node_modules/ms/.npmignore: -------------------------------------------------------------------------------- 1 | node_modules 2 | test 3 | History.md 4 | Makefile 5 | component.json 6 | -------------------------------------------------------------------------------- /src/index.js: -------------------------------------------------------------------------------- 1 | const {createEditor,renderPage} = require('./handleChange'); 2 | createEditor() 3 | renderPage() -------------------------------------------------------------------------------- /deploy/node_modules/qs/.travis.yml: -------------------------------------------------------------------------------- 1 | language: node_js 2 | 3 | node_js: 4 | - 0.10 5 | - 0.12 6 | - iojs 7 | -------------------------------------------------------------------------------- /deploy/node_modules/unpipe/HISTORY.md: -------------------------------------------------------------------------------- 1 | 1.0.0 / 2015-06-14 2 | ================== 3 | 4 | * Initial release 5 | -------------------------------------------------------------------------------- /screenshot/screen.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/swapnilmishra/jsbin-jsfiddle-clone/HEAD/screenshot/screen.gif -------------------------------------------------------------------------------- /screenshot/screen.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/swapnilmishra/jsbin-jsfiddle-clone/HEAD/screenshot/screen.png -------------------------------------------------------------------------------- /deploy/node_modules/forwarded/HISTORY.md: -------------------------------------------------------------------------------- 1 | 0.1.0 / 2014-09-21 2 | ================== 3 | 4 | * Initial release 5 | -------------------------------------------------------------------------------- /deploy/src/index.js: -------------------------------------------------------------------------------- 1 | const {createEditor,renderPage} = require('./handleChange'); 2 | createEditor() 3 | renderPage() -------------------------------------------------------------------------------- /deploy/public/src/index.js: -------------------------------------------------------------------------------- 1 | const {createEditor,renderPage} = require('./handleChange'); 2 | createEditor() 3 | renderPage() -------------------------------------------------------------------------------- /webpack.prod.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | entry: './src/index.js', 3 | output: { 4 | filename: './dist/bundle.js' 5 | } 6 | } -------------------------------------------------------------------------------- /deploy/node_modules/utils-merge/.travis.yml: -------------------------------------------------------------------------------- 1 | language: "node_js" 2 | node_js: 3 | - "0.4" 4 | - "0.6" 5 | - "0.8" 6 | - "0.10" 7 | -------------------------------------------------------------------------------- /deploy/node_modules/qs/CONTRIBUTING.md: -------------------------------------------------------------------------------- 1 | Please view our [hapijs contributing guide](https://github.com/hapijs/hapi/blob/master/CONTRIBUTING.md). 2 | -------------------------------------------------------------------------------- /deploy/index.js: -------------------------------------------------------------------------------- 1 | const path = require('path') 2 | const express = require('express') 3 | const app = express() 4 | 5 | app.use(express.static('public')) 6 | app.listen(3000); 7 | -------------------------------------------------------------------------------- /deploy/node_modules/ipaddr.js/.travis.yml: -------------------------------------------------------------------------------- 1 | language: node_js 2 | 3 | node_js: 4 | - "0.10" 5 | - "0.11" 6 | - "0.12" 7 | - "4.0" 8 | - "4.1" 9 | - "4.2" 10 | - "5" 11 | -------------------------------------------------------------------------------- /deploy/node_modules/mime/cli.js: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env node 2 | 3 | var mime = require('./mime.js'); 4 | var file = process.argv[2]; 5 | var type = mime.lookup(file); 6 | 7 | process.stdout.write(type + '\n'); 8 | 9 | -------------------------------------------------------------------------------- /deploy/node_modules/mime-db/index.js: -------------------------------------------------------------------------------- 1 | /*! 2 | * mime-db 3 | * Copyright(c) 2014 Jonathan Ong 4 | * MIT Licensed 5 | */ 6 | 7 | /** 8 | * Module exports. 9 | */ 10 | 11 | module.exports = require('./db.json') 12 | -------------------------------------------------------------------------------- /deploy/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "jsbin-clone", 3 | "version": "0.1.0", 4 | "dependencies": { 5 | "express": "4.13.4" 6 | }, 7 | "scripts": { 8 | "start": "node index.js" 9 | } 10 | } 11 | -------------------------------------------------------------------------------- /webpack.config.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | entry: './src/index.js', 3 | output: { 4 | filename: './dist/bundle.js' 5 | }, 6 | devServer : { 7 | inline: true 8 | }, 9 | devtool: "cheap-eval-source-map" 10 | } -------------------------------------------------------------------------------- /deploy/node_modules/inherits/inherits.js: -------------------------------------------------------------------------------- 1 | try { 2 | var util = require('util'); 3 | if (typeof util.inherits !== 'function') throw ''; 4 | module.exports = util.inherits; 5 | } catch (e) { 6 | module.exports = require('./inherits_browser.js'); 7 | } 8 | -------------------------------------------------------------------------------- /src/initValue.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | htmlValue : ` 3 | 4 | 5 | 6 |

Hello

7 | 8 | `, 9 | jsValue : `function hello(){ 10 | alert("Hello") 11 | }`, 12 | cssValue : `h1{ 13 | color : gray; 14 | }` 15 | } -------------------------------------------------------------------------------- /deploy/node_modules/qs/lib/index.js: -------------------------------------------------------------------------------- 1 | // Load modules 2 | 3 | var Stringify = require('./stringify'); 4 | var Parse = require('./parse'); 5 | 6 | 7 | // Declare internals 8 | 9 | var internals = {}; 10 | 11 | 12 | module.exports = { 13 | stringify: Stringify, 14 | parse: Parse 15 | }; 16 | -------------------------------------------------------------------------------- /deploy/node_modules/express/index.js: -------------------------------------------------------------------------------- 1 | /*! 2 | * express 3 | * Copyright(c) 2009-2013 TJ Holowaychuk 4 | * Copyright(c) 2013 Roman Shtylman 5 | * Copyright(c) 2014-2015 Douglas Christopher Wilson 6 | * MIT Licensed 7 | */ 8 | 9 | 'use strict'; 10 | 11 | module.exports = require('./lib/express'); 12 | -------------------------------------------------------------------------------- /deploy/src/initValue.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | htmlValue : ` 3 | 4 | 5 | 6 |

Hello

7 | 8 | `, 9 | jsValue : `function hello(){ 10 | alert("Hello") 11 | }`, 12 | cssValue : `h1{ 13 | color : gray; 14 | }` 15 | } -------------------------------------------------------------------------------- /deploy/public/src/initValue.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | htmlValue : ` 3 | 4 | 5 | 6 |

Hello

7 | 8 | `, 9 | jsValue : `function hello(){ 10 | alert("Hello") 11 | }`, 12 | cssValue : `h1{ 13 | color : gray; 14 | }` 15 | } -------------------------------------------------------------------------------- /deploy/node_modules/mime/build/build.js: -------------------------------------------------------------------------------- 1 | var db = require('mime-db'); 2 | 3 | var mapByType = {}; 4 | Object.keys(db).forEach(function(key) { 5 | var extensions = db[key].extensions; 6 | if (extensions) { 7 | mapByType[key] = extensions; 8 | } 9 | }); 10 | 11 | console.log(JSON.stringify(mapByType)); 12 | -------------------------------------------------------------------------------- /deploy/node_modules/qs/.npmignore: -------------------------------------------------------------------------------- 1 | .idea 2 | *.iml 3 | npm-debug.log 4 | dump.rdb 5 | node_modules 6 | results.tap 7 | results.xml 8 | npm-shrinkwrap.json 9 | config.json 10 | .DS_Store 11 | */.DS_Store 12 | */*/.DS_Store 13 | ._* 14 | */._* 15 | */*/._* 16 | coverage.* 17 | lib-cov 18 | complexity.md 19 | dist 20 | -------------------------------------------------------------------------------- /deploy/node_modules/content-type/HISTORY.md: -------------------------------------------------------------------------------- 1 | 1.0.2 / 2016-05-09 2 | ================== 3 | 4 | * perf: enable strict mode 5 | 6 | 1.0.1 / 2015-02-13 7 | ================== 8 | 9 | * Improve missing `Content-Type` header error message 10 | 11 | 1.0.0 / 2015-02-01 12 | ================== 13 | 14 | * Initial implementation, derived from `media-typer@0.3.0` 15 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "jsbin-jsfiddle", 3 | "version": "1.0.0", 4 | "description": "", 5 | "main": "index.js", 6 | "devDependencies": { 7 | "webpack": "^1.13.3", 8 | "webpack-dev-server": "^1.16.2" 9 | }, 10 | "scripts": { 11 | "start": "webpack-dev-server --open", 12 | "build": "webpack webpack.prod.js" 13 | }, 14 | "author": "", 15 | "license": "ISC" 16 | } 17 | -------------------------------------------------------------------------------- /src/debounce.js: -------------------------------------------------------------------------------- 1 | let debounce = (originalFunction,timeout) => { 2 | let debounced = false; 3 | return( function() { 4 | let args = arguments; 5 | if(!debounced){ 6 | debounced = true; 7 | setTimeout( () => { 8 | originalFunction.apply(undefined,args) 9 | debounced = false; 10 | },timeout) 11 | } 12 | }); 13 | } 14 | 15 | 16 | module.exports = { 17 | debounce 18 | } -------------------------------------------------------------------------------- /deploy/src/debounce.js: -------------------------------------------------------------------------------- 1 | let debounce = (originalFunction,timeout) => { 2 | let debounced = false; 3 | return( function() { 4 | let args = arguments; 5 | if(!debounced){ 6 | debounced = true; 7 | setTimeout( () => { 8 | originalFunction.apply(undefined,args) 9 | debounced = false; 10 | },timeout) 11 | } 12 | }); 13 | } 14 | 15 | 16 | module.exports = { 17 | debounce 18 | } -------------------------------------------------------------------------------- /deploy/node_modules/debug/component.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "debug", 3 | "repo": "visionmedia/debug", 4 | "description": "small debugging utility", 5 | "version": "2.2.0", 6 | "keywords": [ 7 | "debug", 8 | "log", 9 | "debugger" 10 | ], 11 | "main": "browser.js", 12 | "scripts": [ 13 | "browser.js", 14 | "debug.js" 15 | ], 16 | "dependencies": { 17 | "rauchg/ms.js": "0.7.1" 18 | } 19 | } 20 | -------------------------------------------------------------------------------- /deploy/public/src/debounce.js: -------------------------------------------------------------------------------- 1 | let debounce = (originalFunction,timeout) => { 2 | let debounced = false; 3 | return( function() { 4 | let args = arguments; 5 | if(!debounced){ 6 | debounced = true; 7 | setTimeout( () => { 8 | originalFunction.apply(undefined,args) 9 | debounced = false; 10 | },timeout) 11 | } 12 | }); 13 | } 14 | 15 | 16 | module.exports = { 17 | debounce 18 | } -------------------------------------------------------------------------------- /deploy/node_modules/depd/lib/compat/event-listener-count.js: -------------------------------------------------------------------------------- 1 | /*! 2 | * depd 3 | * Copyright(c) 2015 Douglas Christopher Wilson 4 | * MIT Licensed 5 | */ 6 | 7 | 'use strict' 8 | 9 | /** 10 | * Module exports. 11 | * @public 12 | */ 13 | 14 | module.exports = eventListenerCount 15 | 16 | /** 17 | * Get the count of listeners on an event emitter of a specific type. 18 | */ 19 | 20 | function eventListenerCount(emitter, type) { 21 | return emitter.listeners(type).length 22 | } 23 | -------------------------------------------------------------------------------- /deploy/node_modules/merge-descriptors/HISTORY.md: -------------------------------------------------------------------------------- 1 | 1.0.1 / 2016-01-17 2 | ================== 3 | 4 | * perf: enable strict mode 5 | 6 | 1.0.0 / 2015-03-01 7 | ================== 8 | 9 | * Add option to only add new descriptors 10 | * Add simple argument validation 11 | * Add jsdoc to source file 12 | 13 | 0.0.2 / 2013-12-14 14 | ================== 15 | 16 | * Move repository to `component` organization 17 | 18 | 0.0.1 / 2013-10-29 19 | ================== 20 | 21 | * Initial release 22 | -------------------------------------------------------------------------------- /deploy/node_modules/utils-merge/index.js: -------------------------------------------------------------------------------- 1 | /** 2 | * Merge object b with object a. 3 | * 4 | * var a = { foo: 'bar' } 5 | * , b = { bar: 'baz' }; 6 | * 7 | * merge(a, b); 8 | * // => { foo: 'bar', bar: 'baz' } 9 | * 10 | * @param {Object} a 11 | * @param {Object} b 12 | * @return {Object} 13 | * @api public 14 | */ 15 | 16 | exports = module.exports = function(a, b){ 17 | if (a && b) { 18 | for (var key in b) { 19 | a[key] = b[key]; 20 | } 21 | } 22 | return a; 23 | }; 24 | -------------------------------------------------------------------------------- /deploy/node_modules/qs/bower.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "qs", 3 | "main": "dist/qs.js", 4 | "version": "3.0.0", 5 | "homepage": "https://github.com/hapijs/qs", 6 | "authors": [ 7 | "Nathan LaFreniere " 8 | ], 9 | "description": "A querystring parser that supports nesting and arrays, with a depth limit", 10 | "keywords": [ 11 | "querystring", 12 | "qs" 13 | ], 14 | "license": "BSD-3-Clause", 15 | "ignore": [ 16 | "**/.*", 17 | "node_modules", 18 | "bower_components", 19 | "test", 20 | "tests" 21 | ] 22 | } 23 | -------------------------------------------------------------------------------- /deploy/node_modules/methods/HISTORY.md: -------------------------------------------------------------------------------- 1 | 1.1.2 / 2016-01-17 2 | ================== 3 | 4 | * perf: enable strict mode 5 | 6 | 1.1.1 / 2014-12-30 7 | ================== 8 | 9 | * Improve `browserify` support 10 | 11 | 1.1.0 / 2014-07-05 12 | ================== 13 | 14 | * Add `CONNECT` method 15 | 16 | 1.0.1 / 2014-06-02 17 | ================== 18 | 19 | * Fix module to work with harmony transform 20 | 21 | 1.0.0 / 2014-05-08 22 | ================== 23 | 24 | * Add `PURGE` method 25 | 26 | 0.1.0 / 2013-10-28 27 | ================== 28 | 29 | * Add `http.METHODS` support 30 | -------------------------------------------------------------------------------- /deploy/node_modules/media-typer/HISTORY.md: -------------------------------------------------------------------------------- 1 | 0.3.0 / 2014-09-07 2 | ================== 3 | 4 | * Support Node.js 0.6 5 | * Throw error when parameter format invalid on parse 6 | 7 | 0.2.0 / 2014-06-18 8 | ================== 9 | 10 | * Add `typer.format()` to format media types 11 | 12 | 0.1.0 / 2014-06-17 13 | ================== 14 | 15 | * Accept `req` as argument to `parse` 16 | * Accept `res` as argument to `parse` 17 | * Parse media type with extra LWS between type and first parameter 18 | 19 | 0.0.0 / 2014-06-13 20 | ================== 21 | 22 | * Initial implementation 23 | -------------------------------------------------------------------------------- /deploy/node_modules/vary/HISTORY.md: -------------------------------------------------------------------------------- 1 | 1.0.1 / 2015-07-08 2 | ================== 3 | 4 | * Fix setting empty header from empty `field` 5 | * perf: enable strict mode 6 | * perf: remove argument reassignments 7 | 8 | 1.0.0 / 2014-08-10 9 | ================== 10 | 11 | * Accept valid `Vary` header string as `field` 12 | * Add `vary.append` for low-level string manipulation 13 | * Move to `jshttp` orgainzation 14 | 15 | 0.1.0 / 2014-06-05 16 | ================== 17 | 18 | * Support array of fields to set 19 | 20 | 0.0.0 / 2014-06-04 21 | ================== 22 | 23 | * Initial release 24 | -------------------------------------------------------------------------------- /deploy/node_modules/debug/bower.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "visionmedia-debug", 3 | "main": "dist/debug.js", 4 | "version": "2.2.0", 5 | "homepage": "https://github.com/visionmedia/debug", 6 | "authors": [ 7 | "TJ Holowaychuk " 8 | ], 9 | "description": "visionmedia-debug", 10 | "moduleType": [ 11 | "amd", 12 | "es6", 13 | "globals", 14 | "node" 15 | ], 16 | "keywords": [ 17 | "visionmedia", 18 | "debug" 19 | ], 20 | "license": "MIT", 21 | "ignore": [ 22 | "**/.*", 23 | "node_modules", 24 | "bower_components", 25 | "test", 26 | "tests" 27 | ] 28 | } 29 | -------------------------------------------------------------------------------- /deploy/node_modules/qs/test/utils.js: -------------------------------------------------------------------------------- 1 | // Load modules 2 | 3 | var Code = require('code'); 4 | var Lab = require('lab'); 5 | var Utils = require('../lib/utils'); 6 | 7 | 8 | // Declare internals 9 | 10 | var internals = {}; 11 | 12 | 13 | // Test shortcuts 14 | 15 | var lab = exports.lab = Lab.script(); 16 | var expect = Code.expect; 17 | var describe = lab.experiment; 18 | var it = lab.test; 19 | 20 | 21 | describe('merge()', function () { 22 | 23 | it('can merge two objects with the same key', function (done) { 24 | 25 | expect(Utils.merge({ a: 'b' }, { a: 'c' })).to.deep.equal({ a: ['b', 'c'] }); 26 | done(); 27 | }); 28 | }); 29 | -------------------------------------------------------------------------------- /deploy/node_modules/ipaddr.js/bower.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "ipaddr.js", 3 | "version": "1.0.5", 4 | "homepage": "https://github.com/whitequark/ipaddr.js", 5 | "authors": [ 6 | "whitequark " 7 | ], 8 | "description": "IP address manipulation library in JavaScript (CoffeeScript, actually)", 9 | "main": "lib/ipaddr.js", 10 | "moduleType": [ 11 | "globals", 12 | "node" 13 | ], 14 | "keywords": [ 15 | "javscript", 16 | "ip", 17 | "address", 18 | "ipv4", 19 | "ipv6" 20 | ], 21 | "license": "MIT", 22 | "ignore": [ 23 | "**/.*", 24 | "node_modules", 25 | "bower_components", 26 | "test", 27 | "tests" 28 | ] 29 | } 30 | -------------------------------------------------------------------------------- /deploy/node_modules/depd/lib/compat/buffer-concat.js: -------------------------------------------------------------------------------- 1 | /*! 2 | * depd 3 | * Copyright(c) 2014 Douglas Christopher Wilson 4 | * MIT Licensed 5 | */ 6 | 7 | 'use strict' 8 | 9 | /** 10 | * Module exports. 11 | */ 12 | 13 | module.exports = bufferConcat 14 | 15 | /** 16 | * Concatenate an array of Buffers. 17 | */ 18 | 19 | function bufferConcat(bufs) { 20 | var length = 0 21 | 22 | for (var i = 0, len = bufs.length; i < len; i++) { 23 | length += bufs[i].length 24 | } 25 | 26 | var buf = new Buffer(length) 27 | var pos = 0 28 | 29 | for (var i = 0, len = bufs.length; i < len; i++) { 30 | bufs[i].copy(buf, pos) 31 | pos += bufs[i].length 32 | } 33 | 34 | return buf 35 | } 36 | -------------------------------------------------------------------------------- /deploy/node_modules/ipaddr.js/Cakefile: -------------------------------------------------------------------------------- 1 | fs = require 'fs' 2 | CoffeeScript = require 'coffee-script' 3 | nodeunit = require 'nodeunit' 4 | UglifyJS = require 'uglify-js' 5 | 6 | task 'build', 'build the JavaScript files from CoffeeScript source', build = (cb) -> 7 | source = fs.readFileSync 'src/ipaddr.coffee' 8 | fs.writeFileSync 'lib/ipaddr.js', CoffeeScript.compile source.toString() 9 | 10 | invoke 'test' 11 | invoke 'compress' 12 | 13 | task 'test', 'run the bundled tests', (cb) -> 14 | nodeunit.reporters.default.run ['test'] 15 | 16 | task 'compress', 'uglify the resulting javascript', (cb) -> 17 | result = UglifyJS.minify('lib/ipaddr.js') 18 | fs.writeFileSync('ipaddr.min.js', result.code) 19 | -------------------------------------------------------------------------------- /deploy/node_modules/range-parser/HISTORY.md: -------------------------------------------------------------------------------- 1 | unreleased 2 | ========== 3 | 4 | * perf: enable strict mode 5 | 6 | 1.0.2 / 2014-09-08 7 | ================== 8 | 9 | * Support Node.js 0.6 10 | 11 | 1.0.1 / 2014-09-07 12 | ================== 13 | 14 | * Move repository to jshttp 15 | 16 | 1.0.0 / 2013-12-11 17 | ================== 18 | 19 | * Add repository to package.json 20 | * Add MIT license 21 | 22 | 0.0.4 / 2012-06-17 23 | ================== 24 | 25 | * Change ret -1 for unsatisfiable and -2 when invalid 26 | 27 | 0.0.3 / 2012-06-17 28 | ================== 29 | 30 | * Fix last-byte-pos default to len - 1 31 | 32 | 0.0.2 / 2012-06-14 33 | ================== 34 | 35 | * Add `.type` 36 | 37 | 0.0.1 / 2012-06-11 38 | ================== 39 | 40 | * Initial release 41 | -------------------------------------------------------------------------------- /deploy/node_modules/fresh/HISTORY.md: -------------------------------------------------------------------------------- 1 | 0.3.0 / 2015-05-12 2 | ================== 3 | 4 | * Add weak `ETag` matching support 5 | 6 | 0.2.4 / 2014-09-07 7 | ================== 8 | 9 | * Support Node.js 0.6 10 | 11 | 0.2.3 / 2014-09-07 12 | ================== 13 | 14 | * Move repository to jshttp 15 | 16 | 0.2.2 / 2014-02-19 17 | ================== 18 | 19 | * Revert "Fix for blank page on Safari reload" 20 | 21 | 0.2.1 / 2014-01-29 22 | ================== 23 | 24 | * Fix for blank page on Safari reload 25 | 26 | 0.2.0 / 2013-08-11 27 | ================== 28 | 29 | * Return stale for `Cache-Control: no-cache` 30 | 31 | 0.1.0 / 2012-06-15 32 | ================== 33 | * Add `If-None-Match: *` support 34 | 35 | 0.0.1 / 2012-06-10 36 | ================== 37 | 38 | * Initial release 39 | -------------------------------------------------------------------------------- /deploy/node_modules/inherits/inherits_browser.js: -------------------------------------------------------------------------------- 1 | if (typeof Object.create === 'function') { 2 | // implementation from standard node.js 'util' module 3 | module.exports = function inherits(ctor, superCtor) { 4 | ctor.super_ = superCtor 5 | ctor.prototype = Object.create(superCtor.prototype, { 6 | constructor: { 7 | value: ctor, 8 | enumerable: false, 9 | writable: true, 10 | configurable: true 11 | } 12 | }); 13 | }; 14 | } else { 15 | // old school shim for old browsers 16 | module.exports = function inherits(ctor, superCtor) { 17 | ctor.super_ = superCtor 18 | var TempCtor = function () {} 19 | TempCtor.prototype = superCtor.prototype 20 | ctor.prototype = new TempCtor() 21 | ctor.prototype.constructor = ctor 22 | } 23 | } 24 | -------------------------------------------------------------------------------- /deploy/node_modules/utils-merge/README.md: -------------------------------------------------------------------------------- 1 | # utils-merge 2 | 3 | Merges the properties from a source object into a destination object. 4 | 5 | ## Install 6 | 7 | $ npm install utils-merge 8 | 9 | ## Usage 10 | 11 | ```javascript 12 | var a = { foo: 'bar' } 13 | , b = { bar: 'baz' }; 14 | 15 | merge(a, b); 16 | // => { foo: 'bar', bar: 'baz' } 17 | ``` 18 | 19 | ## Tests 20 | 21 | $ npm install 22 | $ npm test 23 | 24 | [![Build Status](https://secure.travis-ci.org/jaredhanson/utils-merge.png)](http://travis-ci.org/jaredhanson/utils-merge) 25 | 26 | ## Credits 27 | 28 | - [Jared Hanson](http://github.com/jaredhanson) 29 | 30 | ## License 31 | 32 | [The MIT License](http://opensource.org/licenses/MIT) 33 | 34 | Copyright (c) 2013 Jared Hanson <[http://jaredhanson.net/](http://jaredhanson.net/)> 35 | -------------------------------------------------------------------------------- /deploy/node_modules/forwarded/index.js: -------------------------------------------------------------------------------- 1 | /*! 2 | * forwarded 3 | * Copyright(c) 2014 Douglas Christopher Wilson 4 | * MIT Licensed 5 | */ 6 | 7 | /** 8 | * Module exports. 9 | */ 10 | 11 | module.exports = forwarded 12 | 13 | /** 14 | * Get all addresses in the request, using the `X-Forwarded-For` header. 15 | * 16 | * @param {Object} req 17 | * @api public 18 | */ 19 | 20 | function forwarded(req) { 21 | if (!req) { 22 | throw new TypeError('argument req is required') 23 | } 24 | 25 | // simple header parsing 26 | var proxyAddrs = (req.headers['x-forwarded-for'] || '') 27 | .split(/ *, */) 28 | .filter(Boolean) 29 | .reverse() 30 | var socketAddr = req.connection.remoteAddress 31 | var addrs = [socketAddr].concat(proxyAddrs) 32 | 33 | // return all addresses 34 | return addrs 35 | } 36 | -------------------------------------------------------------------------------- /deploy/node_modules/inherits/LICENSE: -------------------------------------------------------------------------------- 1 | The ISC License 2 | 3 | Copyright (c) Isaac Z. Schlueter 4 | 5 | Permission to use, copy, modify, and/or distribute this software for any 6 | purpose with or without fee is hereby granted, provided that the above 7 | copyright notice and this permission notice appear in all copies. 8 | 9 | THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH 10 | REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND 11 | FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, 12 | INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM 13 | LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR 14 | OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR 15 | PERFORMANCE OF THIS SOFTWARE. 16 | 17 | -------------------------------------------------------------------------------- /src/createIFrame.js: -------------------------------------------------------------------------------- 1 | let frameEl; 2 | let createFrame = ({html,js,css}) => { 3 | // memoize frame element 4 | if(frameEl){ 5 | frameEl.remove() 6 | } 7 | frameEl = document.createElement('iframe') 8 | const el = document.querySelector("#root") 9 | frameEl.setAttribute("id","iframe") 10 | frameEl.setAttribute("class","output") 11 | el.appendChild(frameEl) 12 | const doc = document.querySelector('#iframe').contentWindow.document 13 | const head = doc.querySelector("head") 14 | doc.body.innerHTML = html; 15 | head.appendChild(createEl('script',js)) 16 | head.appendChild(createEl('style',css)) 17 | } 18 | 19 | let createEl = (type,innerhtml) => { 20 | const el = document.createElement(type) 21 | el.innerHTML = innerhtml 22 | return el; 23 | } 24 | 25 | module.exports = { 26 | createFrame 27 | } -------------------------------------------------------------------------------- /deploy/src/createIFrame.js: -------------------------------------------------------------------------------- 1 | let frameEl; 2 | let createFrame = ({html,js,css}) => { 3 | // memoize frame element 4 | if(frameEl){ 5 | frameEl.remove() 6 | } 7 | frameEl = document.createElement('iframe') 8 | const el = document.querySelector("#root") 9 | frameEl.setAttribute("id","iframe") 10 | frameEl.setAttribute("class","output") 11 | el.appendChild(frameEl) 12 | const doc = document.querySelector('#iframe').contentWindow.document 13 | const head = doc.querySelector("head") 14 | doc.body.innerHTML = html; 15 | head.appendChild(createEl('script',js)) 16 | head.appendChild(createEl('style',css)) 17 | } 18 | 19 | let createEl = (type,innerhtml) => { 20 | const el = document.createElement(type) 21 | el.innerHTML = innerhtml 22 | return el; 23 | } 24 | 25 | module.exports = { 26 | createFrame 27 | } -------------------------------------------------------------------------------- /deploy/public/src/createIFrame.js: -------------------------------------------------------------------------------- 1 | let frameEl; 2 | let createFrame = ({html,js,css}) => { 3 | // memoize frame element 4 | if(frameEl){ 5 | frameEl.remove() 6 | } 7 | frameEl = document.createElement('iframe') 8 | const el = document.querySelector("#root") 9 | frameEl.setAttribute("id","iframe") 10 | frameEl.setAttribute("class","output") 11 | el.appendChild(frameEl) 12 | const doc = document.querySelector('#iframe').contentWindow.document 13 | const head = doc.querySelector("head") 14 | doc.body.innerHTML = html; 15 | head.appendChild(createEl('script',js)) 16 | head.appendChild(createEl('style',css)) 17 | } 18 | 19 | let createEl = (type,innerhtml) => { 20 | const el = document.createElement(type) 21 | el.innerHTML = innerhtml 22 | return el; 23 | } 24 | 25 | module.exports = { 26 | createFrame 27 | } -------------------------------------------------------------------------------- /deploy/node_modules/path-to-regexp/History.md: -------------------------------------------------------------------------------- 1 | 0.1.7 / 2015-07-28 2 | ================== 3 | 4 | * Fixed regression with escaped round brackets and matching groups. 5 | 6 | 0.1.6 / 2015-06-19 7 | ================== 8 | 9 | * Replace `index` feature by outputting all parameters, unnamed and named. 10 | 11 | 0.1.5 / 2015-05-08 12 | ================== 13 | 14 | * Add an index property for position in match result. 15 | 16 | 0.1.4 / 2015-03-05 17 | ================== 18 | 19 | * Add license information 20 | 21 | 0.1.3 / 2014-07-06 22 | ================== 23 | 24 | * Better array support 25 | * Improved support for trailing slash in non-ending mode 26 | 27 | 0.1.0 / 2014-03-06 28 | ================== 29 | 30 | * add options.end 31 | 32 | 0.0.2 / 2013-02-10 33 | ================== 34 | 35 | * Update to match current express 36 | * add .license property to component.json 37 | -------------------------------------------------------------------------------- /deploy/node_modules/cookie-signature/History.md: -------------------------------------------------------------------------------- 1 | 1.0.6 / 2015-02-03 2 | ================== 3 | 4 | * use `npm test` instead of `make test` to run tests 5 | * clearer assertion messages when checking input 6 | 7 | 8 | 1.0.5 / 2014-09-05 9 | ================== 10 | 11 | * add license to package.json 12 | 13 | 1.0.4 / 2014-06-25 14 | ================== 15 | 16 | * corrected avoidance of timing attacks (thanks @tenbits!) 17 | 18 | 1.0.3 / 2014-01-28 19 | ================== 20 | 21 | * [incorrect] fix for timing attacks 22 | 23 | 1.0.2 / 2014-01-28 24 | ================== 25 | 26 | * fix missing repository warning 27 | * fix typo in test 28 | 29 | 1.0.1 / 2013-04-15 30 | ================== 31 | 32 | * Revert "Changed underlying HMAC algo. to sha512." 33 | * Revert "Fix for timing attacks on MAC verification." 34 | 35 | 0.0.1 / 2010-01-03 36 | ================== 37 | 38 | * Initial release 39 | -------------------------------------------------------------------------------- /deploy/node_modules/debug/Makefile: -------------------------------------------------------------------------------- 1 | 2 | # get Makefile directory name: http://stackoverflow.com/a/5982798/376773 3 | THIS_MAKEFILE_PATH:=$(word $(words $(MAKEFILE_LIST)),$(MAKEFILE_LIST)) 4 | THIS_DIR:=$(shell cd $(dir $(THIS_MAKEFILE_PATH));pwd) 5 | 6 | # BIN directory 7 | BIN := $(THIS_DIR)/node_modules/.bin 8 | 9 | # applications 10 | NODE ?= $(shell which node) 11 | NPM ?= $(NODE) $(shell which npm) 12 | BROWSERIFY ?= $(NODE) $(BIN)/browserify 13 | 14 | all: dist/debug.js 15 | 16 | install: node_modules 17 | 18 | clean: 19 | @rm -rf dist 20 | 21 | dist: 22 | @mkdir -p $@ 23 | 24 | dist/debug.js: node_modules browser.js debug.js dist 25 | @$(BROWSERIFY) \ 26 | --standalone debug \ 27 | . > $@ 28 | 29 | distclean: clean 30 | @rm -rf node_modules 31 | 32 | node_modules: package.json 33 | @NODE_ENV= $(NPM) install 34 | @touch node_modules 35 | 36 | .PHONY: all install clean distclean 37 | -------------------------------------------------------------------------------- /deploy/node_modules/escape-html/Readme.md: -------------------------------------------------------------------------------- 1 | 2 | # escape-html 3 | 4 | Escape string for use in HTML 5 | 6 | ## Example 7 | 8 | ```js 9 | var escape = require('escape-html'); 10 | var html = escape('foo & bar'); 11 | // -> foo & bar 12 | ``` 13 | 14 | ## Benchmark 15 | 16 | ``` 17 | $ npm run-script bench 18 | 19 | > escape-html@1.0.3 bench nodejs-escape-html 20 | > node benchmark/index.js 21 | 22 | 23 | http_parser@1.0 24 | node@0.10.33 25 | v8@3.14.5.9 26 | ares@1.9.0-DEV 27 | uv@0.10.29 28 | zlib@1.2.3 29 | modules@11 30 | openssl@1.0.1j 31 | 32 | 1 test completed. 33 | 2 tests completed. 34 | 3 tests completed. 35 | 36 | no special characters x 19,435,271 ops/sec ±0.85% (187 runs sampled) 37 | single special character x 6,132,421 ops/sec ±0.67% (194 runs sampled) 38 | many special characters x 3,175,826 ops/sec ±0.65% (193 runs sampled) 39 | ``` 40 | 41 | ## License 42 | 43 | MIT -------------------------------------------------------------------------------- /deploy/node_modules/express/lib/middleware/init.js: -------------------------------------------------------------------------------- 1 | /*! 2 | * express 3 | * Copyright(c) 2009-2013 TJ Holowaychuk 4 | * Copyright(c) 2013 Roman Shtylman 5 | * Copyright(c) 2014-2015 Douglas Christopher Wilson 6 | * MIT Licensed 7 | */ 8 | 9 | 'use strict'; 10 | 11 | /** 12 | * Initialization middleware, exposing the 13 | * request and response to each other, as well 14 | * as defaulting the X-Powered-By header field. 15 | * 16 | * @param {Function} app 17 | * @return {Function} 18 | * @api private 19 | */ 20 | 21 | exports.init = function(app){ 22 | return function expressInit(req, res, next){ 23 | if (app.enabled('x-powered-by')) res.setHeader('X-Powered-By', 'Express'); 24 | req.res = res; 25 | res.req = req; 26 | req.next = next; 27 | 28 | req.__proto__ = app.request; 29 | res.__proto__ = app.response; 30 | 31 | res.locals = res.locals || Object.create(null); 32 | 33 | next(); 34 | }; 35 | }; 36 | 37 | -------------------------------------------------------------------------------- /deploy/node_modules/content-disposition/HISTORY.md: -------------------------------------------------------------------------------- 1 | 0.5.1 / 2016-01-17 2 | ================== 3 | 4 | * perf: enable strict mode 5 | 6 | 0.5.0 / 2014-10-11 7 | ================== 8 | 9 | * Add `parse` function 10 | 11 | 0.4.0 / 2014-09-21 12 | ================== 13 | 14 | * Expand non-Unicode `filename` to the full ISO-8859-1 charset 15 | 16 | 0.3.0 / 2014-09-20 17 | ================== 18 | 19 | * Add `fallback` option 20 | * Add `type` option 21 | 22 | 0.2.0 / 2014-09-19 23 | ================== 24 | 25 | * Reduce ambiguity of file names with hex escape in buggy browsers 26 | 27 | 0.1.2 / 2014-09-19 28 | ================== 29 | 30 | * Fix periodic invalid Unicode filename header 31 | 32 | 0.1.1 / 2014-09-19 33 | ================== 34 | 35 | * Fix invalid characters appearing in `filename*` parameter 36 | 37 | 0.1.0 / 2014-09-18 38 | ================== 39 | 40 | * Make the `filename` argument optional 41 | 42 | 0.0.0 / 2014-09-18 43 | ================== 44 | 45 | * Initial release 46 | -------------------------------------------------------------------------------- /deploy/node_modules/parseurl/HISTORY.md: -------------------------------------------------------------------------------- 1 | 1.3.1 / 2016-01-17 2 | ================== 3 | 4 | * perf: enable strict mode 5 | 6 | 1.3.0 / 2014-08-09 7 | ================== 8 | 9 | * Add `parseurl.original` for parsing `req.originalUrl` with fallback 10 | * Return `undefined` if `req.url` is `undefined` 11 | 12 | 1.2.0 / 2014-07-21 13 | ================== 14 | 15 | * Cache URLs based on original value 16 | * Remove no-longer-needed URL mis-parse work-around 17 | * Simplify the "fast-path" `RegExp` 18 | 19 | 1.1.3 / 2014-07-08 20 | ================== 21 | 22 | * Fix typo 23 | 24 | 1.1.2 / 2014-07-08 25 | ================== 26 | 27 | * Seriously fix Node.js 0.8 compatibility 28 | 29 | 1.1.1 / 2014-07-08 30 | ================== 31 | 32 | * Fix Node.js 0.8 compatibility 33 | 34 | 1.1.0 / 2014-07-08 35 | ================== 36 | 37 | * Incorporate URL href-only parse fast-path 38 | 39 | 1.0.1 / 2014-03-08 40 | ================== 41 | 42 | * Add missing `require` 43 | 44 | 1.0.0 / 2014-03-08 45 | ================== 46 | 47 | * Genesis from `connect` 48 | -------------------------------------------------------------------------------- /deploy/node_modules/ms/README.md: -------------------------------------------------------------------------------- 1 | # ms.js: miliseconds conversion utility 2 | 3 | ```js 4 | ms('2 days') // 172800000 5 | ms('1d') // 86400000 6 | ms('10h') // 36000000 7 | ms('2.5 hrs') // 9000000 8 | ms('2h') // 7200000 9 | ms('1m') // 60000 10 | ms('5s') // 5000 11 | ms('100') // 100 12 | ``` 13 | 14 | ```js 15 | ms(60000) // "1m" 16 | ms(2 * 60000) // "2m" 17 | ms(ms('10 hours')) // "10h" 18 | ``` 19 | 20 | ```js 21 | ms(60000, { long: true }) // "1 minute" 22 | ms(2 * 60000, { long: true }) // "2 minutes" 23 | ms(ms('10 hours'), { long: true }) // "10 hours" 24 | ``` 25 | 26 | - Node/Browser compatible. Published as [`ms`](https://www.npmjs.org/package/ms) in [NPM](http://nodejs.org/download). 27 | - If a number is supplied to `ms`, a string with a unit is returned. 28 | - If a string that contains the number is supplied, it returns it as 29 | a number (e.g: it returns `100` for `'100'`). 30 | - If you pass a string with a number and a valid unit, the number of 31 | equivalent ms is returned. 32 | 33 | ## License 34 | 35 | MIT 36 | -------------------------------------------------------------------------------- /deploy/node_modules/mime/LICENSE: -------------------------------------------------------------------------------- 1 | Copyright (c) 2010 Benjamin Thomas, Robert Kieffer 2 | 3 | Permission is hereby granted, free of charge, to any person obtaining a copy 4 | of this software and associated documentation files (the "Software"), to deal 5 | in the Software without restriction, including without limitation the rights 6 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 7 | copies of the Software, and to permit persons to whom the Software is 8 | furnished to do so, subject to the following conditions: 9 | 10 | The above copyright notice and this permission notice shall be included in 11 | all copies or substantial portions of the Software. 12 | 13 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 14 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 15 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 16 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 17 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 18 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN 19 | THE SOFTWARE. 20 | -------------------------------------------------------------------------------- /deploy/node_modules/ipaddr.js/LICENSE: -------------------------------------------------------------------------------- 1 | Copyright (C) 2011 Peter Zotov 2 | 3 | Permission is hereby granted, free of charge, to any person obtaining a copy 4 | of this software and associated documentation files (the "Software"), to deal 5 | in the Software without restriction, including without limitation the rights 6 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 7 | copies of the Software, and to permit persons to whom the Software is 8 | furnished to do so, subject to the following conditions: 9 | 10 | The above copyright notice and this permission notice shall be included in 11 | all copies or substantial portions of the Software. 12 | 13 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 14 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 15 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 16 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 17 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 18 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN 19 | THE SOFTWARE. -------------------------------------------------------------------------------- /deploy/node_modules/utils-merge/LICENSE: -------------------------------------------------------------------------------- 1 | (The MIT License) 2 | 3 | Copyright (c) 2013 Jared Hanson 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy of 6 | this software and associated documentation files (the "Software"), to deal in 7 | the Software without restriction, including without limitation the rights to 8 | use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of 9 | the Software, and to permit persons to whom the Software is furnished to do so, 10 | subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS 17 | FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR 18 | COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER 19 | IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN 20 | CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 21 | -------------------------------------------------------------------------------- /deploy/node_modules/ms/LICENSE: -------------------------------------------------------------------------------- 1 | (The MIT License) 2 | 3 | Copyright (c) 2014 Guillermo Rauch 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy of 6 | this software and associated documentation files (the "Software"), to deal in 7 | the Software without restriction, including without limitation the rights to 8 | use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of 9 | the Software, and to permit persons to whom the Software is furnished to do so, 10 | subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS 17 | FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR 18 | COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER 19 | IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN 20 | CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 21 | -------------------------------------------------------------------------------- /deploy/node_modules/express/lib/middleware/query.js: -------------------------------------------------------------------------------- 1 | /*! 2 | * express 3 | * Copyright(c) 2009-2013 TJ Holowaychuk 4 | * Copyright(c) 2013 Roman Shtylman 5 | * Copyright(c) 2014-2015 Douglas Christopher Wilson 6 | * MIT Licensed 7 | */ 8 | 9 | 'use strict'; 10 | 11 | /** 12 | * Module dependencies. 13 | */ 14 | 15 | var parseUrl = require('parseurl'); 16 | var qs = require('qs'); 17 | 18 | /** 19 | * @param {Object} options 20 | * @return {Function} 21 | * @api public 22 | */ 23 | 24 | module.exports = function query(options) { 25 | var opts = Object.create(options || null); 26 | var queryparse = qs.parse; 27 | 28 | if (typeof options === 'function') { 29 | queryparse = options; 30 | opts = undefined; 31 | } 32 | 33 | if (opts !== undefined) { 34 | if (opts.allowDots === undefined) { 35 | opts.allowDots = false; 36 | } 37 | 38 | if (opts.allowPrototypes === undefined) { 39 | opts.allowPrototypes = true; 40 | } 41 | } 42 | 43 | return function query(req, res, next){ 44 | if (!req.query) { 45 | var val = parseUrl(req).query; 46 | req.query = queryparse(val, opts); 47 | } 48 | 49 | next(); 50 | }; 51 | }; 52 | -------------------------------------------------------------------------------- /deploy/node_modules/depd/LICENSE: -------------------------------------------------------------------------------- 1 | (The MIT License) 2 | 3 | Copyright (c) 2014-2015 Douglas Christopher Wilson 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining 6 | a copy of this software and associated documentation files (the 7 | 'Software'), to deal in the Software without restriction, including 8 | without limitation the rights to use, copy, modify, merge, publish, 9 | distribute, sublicense, and/or sell copies of the Software, and to 10 | permit persons to whom the Software is furnished to do so, subject to 11 | the following conditions: 12 | 13 | The above copyright notice and this permission notice shall be 14 | included in all copies or substantial portions of the Software. 15 | 16 | THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, 17 | EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 18 | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. 19 | IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY 20 | CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, 21 | TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE 22 | SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 23 | -------------------------------------------------------------------------------- /deploy/node_modules/etag/LICENSE: -------------------------------------------------------------------------------- 1 | (The MIT License) 2 | 3 | Copyright (c) 2014-2015 Douglas Christopher Wilson 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining 6 | a copy of this software and associated documentation files (the 7 | 'Software'), to deal in the Software without restriction, including 8 | without limitation the rights to use, copy, modify, merge, publish, 9 | distribute, sublicense, and/or sell copies of the Software, and to 10 | permit persons to whom the Software is furnished to do so, subject to 11 | the following conditions: 12 | 13 | The above copyright notice and this permission notice shall be 14 | included in all copies or substantial portions of the Software. 15 | 16 | THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, 17 | EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 18 | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. 19 | IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY 20 | CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, 21 | TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE 22 | SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 23 | -------------------------------------------------------------------------------- /deploy/node_modules/forwarded/LICENSE: -------------------------------------------------------------------------------- 1 | (The MIT License) 2 | 3 | Copyright (c) 2014 Douglas Christopher Wilson 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining 6 | a copy of this software and associated documentation files (the 7 | 'Software'), to deal in the Software without restriction, including 8 | without limitation the rights to use, copy, modify, merge, publish, 9 | distribute, sublicense, and/or sell copies of the Software, and to 10 | permit persons to whom the Software is furnished to do so, subject to 11 | the following conditions: 12 | 13 | The above copyright notice and this permission notice shall be 14 | included in all copies or substantial portions of the Software. 15 | 16 | THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, 17 | EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 18 | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. 19 | IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY 20 | CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, 21 | TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE 22 | SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 23 | -------------------------------------------------------------------------------- /deploy/node_modules/proxy-addr/LICENSE: -------------------------------------------------------------------------------- 1 | (The MIT License) 2 | 3 | Copyright (c) 2014 Douglas Christopher Wilson 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining 6 | a copy of this software and associated documentation files (the 7 | 'Software'), to deal in the Software without restriction, including 8 | without limitation the rights to use, copy, modify, merge, publish, 9 | distribute, sublicense, and/or sell copies of the Software, and to 10 | permit persons to whom the Software is furnished to do so, subject to 11 | the following conditions: 12 | 13 | The above copyright notice and this permission notice shall be 14 | included in all copies or substantial portions of the Software. 15 | 16 | THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, 17 | EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 18 | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. 19 | IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY 20 | CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, 21 | TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE 22 | SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 23 | -------------------------------------------------------------------------------- /deploy/node_modules/vary/LICENSE: -------------------------------------------------------------------------------- 1 | (The MIT License) 2 | 3 | Copyright (c) 2014-2015 Douglas Christopher Wilson 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining 6 | a copy of this software and associated documentation files (the 7 | 'Software'), to deal in the Software without restriction, including 8 | without limitation the rights to use, copy, modify, merge, publish, 9 | distribute, sublicense, and/or sell copies of the Software, and to 10 | permit persons to whom the Software is furnished to do so, subject to 11 | the following conditions: 12 | 13 | The above copyright notice and this permission notice shall be 14 | included in all copies or substantial portions of the Software. 15 | 16 | THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, 17 | EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 18 | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. 19 | IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY 20 | CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, 21 | TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE 22 | SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 23 | -------------------------------------------------------------------------------- /deploy/node_modules/content-type/LICENSE: -------------------------------------------------------------------------------- 1 | (The MIT License) 2 | 3 | Copyright (c) 2015 Douglas Christopher Wilson 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining 6 | a copy of this software and associated documentation files (the 7 | 'Software'), to deal in the Software without restriction, including 8 | without limitation the rights to use, copy, modify, merge, publish, 9 | distribute, sublicense, and/or sell copies of the Software, and to 10 | permit persons to whom the Software is furnished to do so, subject to 11 | the following conditions: 12 | 13 | The above copyright notice and this permission notice shall be 14 | included in all copies or substantial portions of the Software. 15 | 16 | THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, 17 | EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 18 | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. 19 | IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY 20 | CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, 21 | TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE 22 | SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 23 | -------------------------------------------------------------------------------- /deploy/node_modules/fresh/LICENSE: -------------------------------------------------------------------------------- 1 | (The MIT License) 2 | 3 | Copyright (c) 2012 TJ Holowaychuk 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining 6 | a copy of this software and associated documentation files (the 7 | 'Software'), to deal in the Software without restriction, including 8 | without limitation the rights to use, copy, modify, merge, publish, 9 | distribute, sublicense, and/or sell copies of the Software, and to 10 | permit persons to whom the Software is furnished to do so, subject to 11 | the following conditions: 12 | 13 | The above copyright notice and this permission notice shall be 14 | included in all copies or substantial portions of the Software. 15 | 16 | THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, 17 | EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 18 | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. 19 | IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY 20 | CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, 21 | TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE 22 | SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 23 | -------------------------------------------------------------------------------- /deploy/node_modules/media-typer/LICENSE: -------------------------------------------------------------------------------- 1 | (The MIT License) 2 | 3 | Copyright (c) 2014 Douglas Christopher Wilson 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining 6 | a copy of this software and associated documentation files (the 7 | 'Software'), to deal in the Software without restriction, including 8 | without limitation the rights to use, copy, modify, merge, publish, 9 | distribute, sublicense, and/or sell copies of the Software, and to 10 | permit persons to whom the Software is furnished to do so, subject to 11 | the following conditions: 12 | 13 | The above copyright notice and this permission notice shall be 14 | included in all copies or substantial portions of the Software. 15 | 16 | THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, 17 | EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 18 | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. 19 | IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY 20 | CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, 21 | TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE 22 | SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 23 | -------------------------------------------------------------------------------- /deploy/node_modules/content-disposition/LICENSE: -------------------------------------------------------------------------------- 1 | (The MIT License) 2 | 3 | Copyright (c) 2014 Douglas Christopher Wilson 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining 6 | a copy of this software and associated documentation files (the 7 | 'Software'), to deal in the Software without restriction, including 8 | without limitation the rights to use, copy, modify, merge, publish, 9 | distribute, sublicense, and/or sell copies of the Software, and to 10 | permit persons to whom the Software is furnished to do so, subject to 11 | the following conditions: 12 | 13 | The above copyright notice and this permission notice shall be 14 | included in all copies or substantial portions of the Software. 15 | 16 | THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, 17 | EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 18 | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. 19 | IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY 20 | CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, 21 | TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE 22 | SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 23 | -------------------------------------------------------------------------------- /deploy/node_modules/destroy/LICENSE: -------------------------------------------------------------------------------- 1 | 2 | The MIT License (MIT) 3 | 4 | Copyright (c) 2014 Jonathan Ong me@jongleberry.com 5 | 6 | Permission is hereby granted, free of charge, to any person obtaining a copy 7 | of this software and associated documentation files (the "Software"), to deal 8 | in the Software without restriction, including without limitation the rights 9 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 10 | copies of the Software, and to permit persons to whom the Software is 11 | furnished to do so, subject to the following conditions: 12 | 13 | The above copyright notice and this permission notice shall be included in 14 | all copies or substantial portions of the Software. 15 | 16 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 17 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 18 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 19 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 20 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 21 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN 22 | THE SOFTWARE. 23 | -------------------------------------------------------------------------------- /deploy/node_modules/ee-first/LICENSE: -------------------------------------------------------------------------------- 1 | 2 | The MIT License (MIT) 3 | 4 | Copyright (c) 2014 Jonathan Ong me@jongleberry.com 5 | 6 | Permission is hereby granted, free of charge, to any person obtaining a copy 7 | of this software and associated documentation files (the "Software"), to deal 8 | in the Software without restriction, including without limitation the rights 9 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 10 | copies of the Software, and to permit persons to whom the Software is 11 | furnished to do so, subject to the following conditions: 12 | 13 | The above copyright notice and this permission notice shall be included in 14 | all copies or substantial portions of the Software. 15 | 16 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 17 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 18 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 19 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 20 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 21 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN 22 | THE SOFTWARE. 23 | -------------------------------------------------------------------------------- /deploy/node_modules/mime-db/LICENSE: -------------------------------------------------------------------------------- 1 | 2 | The MIT License (MIT) 3 | 4 | Copyright (c) 2014 Jonathan Ong me@jongleberry.com 5 | 6 | Permission is hereby granted, free of charge, to any person obtaining a copy 7 | of this software and associated documentation files (the "Software"), to deal 8 | in the Software without restriction, including without limitation the rights 9 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 10 | copies of the Software, and to permit persons to whom the Software is 11 | furnished to do so, subject to the following conditions: 12 | 13 | The above copyright notice and this permission notice shall be included in 14 | all copies or substantial portions of the Software. 15 | 16 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 17 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 18 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 19 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 20 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 21 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN 22 | THE SOFTWARE. 23 | -------------------------------------------------------------------------------- /deploy/node_modules/statuses/LICENSE: -------------------------------------------------------------------------------- 1 | 2 | The MIT License (MIT) 3 | 4 | Copyright (c) 2014 Jonathan Ong me@jongleberry.com 5 | 6 | Permission is hereby granted, free of charge, to any person obtaining a copy 7 | of this software and associated documentation files (the "Software"), to deal 8 | in the Software without restriction, including without limitation the rights 9 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 10 | copies of the Software, and to permit persons to whom the Software is 11 | furnished to do so, subject to the following conditions: 12 | 13 | The above copyright notice and this permission notice shall be included in 14 | all copies or substantial portions of the Software. 15 | 16 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 17 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 18 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 19 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 20 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 21 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN 22 | THE SOFTWARE. 23 | -------------------------------------------------------------------------------- /deploy/node_modules/array-flatten/LICENSE: -------------------------------------------------------------------------------- 1 | The MIT License (MIT) 2 | 3 | Copyright (c) 2014 Blake Embrey (hello@blakeembrey.com) 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in 13 | all copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN 21 | THE SOFTWARE. 22 | -------------------------------------------------------------------------------- /deploy/node_modules/http-errors/LICENSE: -------------------------------------------------------------------------------- 1 | 2 | The MIT License (MIT) 3 | 4 | Copyright (c) 2014 Jonathan Ong me@jongleberry.com 5 | 6 | Permission is hereby granted, free of charge, to any person obtaining a copy 7 | of this software and associated documentation files (the "Software"), to deal 8 | in the Software without restriction, including without limitation the rights 9 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 10 | copies of the Software, and to permit persons to whom the Software is 11 | furnished to do so, subject to the following conditions: 12 | 13 | The above copyright notice and this permission notice shall be included in 14 | all copies or substantial portions of the Software. 15 | 16 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 17 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 18 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 19 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 20 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 21 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN 22 | THE SOFTWARE. 23 | -------------------------------------------------------------------------------- /deploy/node_modules/path-to-regexp/LICENSE: -------------------------------------------------------------------------------- 1 | The MIT License (MIT) 2 | 3 | Copyright (c) 2014 Blake Embrey (hello@blakeembrey.com) 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in 13 | all copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN 21 | THE SOFTWARE. 22 | -------------------------------------------------------------------------------- /deploy/node_modules/range-parser/LICENSE: -------------------------------------------------------------------------------- 1 | (The MIT License) 2 | 3 | Copyright (c) 2012-2014 TJ Holowaychuk 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining 6 | a copy of this software and associated documentation files (the 7 | 'Software'), to deal in the Software without restriction, including 8 | without limitation the rights to use, copy, modify, merge, publish, 9 | distribute, sublicense, and/or sell copies of the Software, and to 10 | permit persons to whom the Software is furnished to do so, subject to 11 | the following conditions: 12 | 13 | The above copyright notice and this permission notice shall be 14 | included in all copies or substantial portions of the Software. 15 | 16 | THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, 17 | EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 18 | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. 19 | IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY 20 | CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, 21 | TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE 22 | SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 23 | -------------------------------------------------------------------------------- /deploy/node_modules/unpipe/LICENSE: -------------------------------------------------------------------------------- 1 | (The MIT License) 2 | 3 | Copyright (c) 2015 Douglas Christopher Wilson 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining 6 | a copy of this software and associated documentation files (the 7 | 'Software'), to deal in the Software without restriction, including 8 | without limitation the rights to use, copy, modify, merge, publish, 9 | distribute, sublicense, and/or sell copies of the Software, and to 10 | permit persons to whom the Software is furnished to do so, subject to 11 | the following conditions: 12 | 13 | The above copyright notice and this permission notice shall be 14 | included in all copies or substantial portions of the Software. 15 | 16 | THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, 17 | EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 18 | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. 19 | IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY 20 | CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, 21 | TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE 22 | SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 23 | -------------------------------------------------------------------------------- /deploy/node_modules/finalhandler/LICENSE: -------------------------------------------------------------------------------- 1 | (The MIT License) 2 | 3 | Copyright (c) 2014-2015 Douglas Christopher Wilson 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining 6 | a copy of this software and associated documentation files (the 7 | 'Software'), to deal in the Software without restriction, including 8 | without limitation the rights to use, copy, modify, merge, publish, 9 | distribute, sublicense, and/or sell copies of the Software, and to 10 | permit persons to whom the Software is furnished to do so, subject to 11 | the following conditions: 12 | 13 | The above copyright notice and this permission notice shall be 14 | included in all copies or substantial portions of the Software. 15 | 16 | THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, 17 | EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 18 | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. 19 | IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY 20 | CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, 21 | TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE 22 | SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 23 | -------------------------------------------------------------------------------- /deploy/node_modules/send/LICENSE: -------------------------------------------------------------------------------- 1 | (The MIT License) 2 | 3 | Copyright (c) 2012 TJ Holowaychuk 4 | Copyright (c) 2014-2015 Douglas Christopher Wilson 5 | 6 | Permission is hereby granted, free of charge, to any person obtaining 7 | a copy of this software and associated documentation files (the 8 | 'Software'), to deal in the Software without restriction, including 9 | without limitation the rights to use, copy, modify, merge, publish, 10 | distribute, sublicense, and/or sell copies of the Software, and to 11 | permit persons to whom the Software is furnished to do so, subject to 12 | the following conditions: 13 | 14 | The above copyright notice and this permission notice shall be 15 | included in all copies or substantial portions of the Software. 16 | 17 | THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, 18 | EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 19 | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. 20 | IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY 21 | CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, 22 | TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE 23 | SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 24 | -------------------------------------------------------------------------------- /deploy/node_modules/serve-static/node_modules/send/LICENSE: -------------------------------------------------------------------------------- 1 | (The MIT License) 2 | 3 | Copyright (c) 2012 TJ Holowaychuk 4 | Copyright (c) 2014-2015 Douglas Christopher Wilson 5 | 6 | Permission is hereby granted, free of charge, to any person obtaining 7 | a copy of this software and associated documentation files (the 8 | 'Software'), to deal in the Software without restriction, including 9 | without limitation the rights to use, copy, modify, merge, publish, 10 | distribute, sublicense, and/or sell copies of the Software, and to 11 | permit persons to whom the Software is furnished to do so, subject to 12 | the following conditions: 13 | 14 | The above copyright notice and this permission notice shall be 15 | included in all copies or substantial portions of the Software. 16 | 17 | THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, 18 | EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 19 | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. 20 | IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY 21 | CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, 22 | TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE 23 | SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 24 | -------------------------------------------------------------------------------- /deploy/node_modules/accepts/LICENSE: -------------------------------------------------------------------------------- 1 | (The MIT License) 2 | 3 | Copyright (c) 2014 Jonathan Ong 4 | Copyright (c) 2015 Douglas Christopher Wilson 5 | 6 | Permission is hereby granted, free of charge, to any person obtaining 7 | a copy of this software and associated documentation files (the 8 | 'Software'), to deal in the Software without restriction, including 9 | without limitation the rights to use, copy, modify, merge, publish, 10 | distribute, sublicense, and/or sell copies of the Software, and to 11 | permit persons to whom the Software is furnished to do so, subject to 12 | the following conditions: 13 | 14 | The above copyright notice and this permission notice shall be 15 | included in all copies or substantial portions of the Software. 16 | 17 | THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, 18 | EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 19 | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. 20 | IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY 21 | CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, 22 | TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE 23 | SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 24 | -------------------------------------------------------------------------------- /deploy/node_modules/escape-html/LICENSE: -------------------------------------------------------------------------------- 1 | (The MIT License) 2 | 3 | Copyright (c) 2012-2013 TJ Holowaychuk 4 | Copyright (c) 2015 Andreas Lubbe 5 | Copyright (c) 2015 Tiancheng "Timothy" Gu 6 | 7 | Permission is hereby granted, free of charge, to any person obtaining 8 | a copy of this software and associated documentation files (the 9 | 'Software'), to deal in the Software without restriction, including 10 | without limitation the rights to use, copy, modify, merge, publish, 11 | distribute, sublicense, and/or sell copies of the Software, and to 12 | permit persons to whom the Software is furnished to do so, subject to 13 | the following conditions: 14 | 15 | The above copyright notice and this permission notice shall be 16 | included in all copies or substantial portions of the Software. 17 | 18 | THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, 19 | EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 20 | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. 21 | IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY 22 | CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, 23 | TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE 24 | SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 25 | -------------------------------------------------------------------------------- /deploy/node_modules/mime-types/LICENSE: -------------------------------------------------------------------------------- 1 | (The MIT License) 2 | 3 | Copyright (c) 2014 Jonathan Ong 4 | Copyright (c) 2015 Douglas Christopher Wilson 5 | 6 | Permission is hereby granted, free of charge, to any person obtaining 7 | a copy of this software and associated documentation files (the 8 | 'Software'), to deal in the Software without restriction, including 9 | without limitation the rights to use, copy, modify, merge, publish, 10 | distribute, sublicense, and/or sell copies of the Software, and to 11 | permit persons to whom the Software is furnished to do so, subject to 12 | the following conditions: 13 | 14 | The above copyright notice and this permission notice shall be 15 | included in all copies or substantial portions of the Software. 16 | 17 | THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, 18 | EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 19 | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. 20 | IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY 21 | CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, 22 | TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE 23 | SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 24 | -------------------------------------------------------------------------------- /deploy/node_modules/on-finished/LICENSE: -------------------------------------------------------------------------------- 1 | (The MIT License) 2 | 3 | Copyright (c) 2013 Jonathan Ong 4 | Copyright (c) 2014 Douglas Christopher Wilson 5 | 6 | Permission is hereby granted, free of charge, to any person obtaining 7 | a copy of this software and associated documentation files (the 8 | 'Software'), to deal in the Software without restriction, including 9 | without limitation the rights to use, copy, modify, merge, publish, 10 | distribute, sublicense, and/or sell copies of the Software, and to 11 | permit persons to whom the Software is furnished to do so, subject to 12 | the following conditions: 13 | 14 | The above copyright notice and this permission notice shall be 15 | included in all copies or substantial portions of the Software. 16 | 17 | THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, 18 | EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 19 | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. 20 | IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY 21 | CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, 22 | TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE 23 | SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 24 | -------------------------------------------------------------------------------- /deploy/node_modules/path-to-regexp/Readme.md: -------------------------------------------------------------------------------- 1 | # Path-to-RegExp 2 | 3 | Turn an Express-style path string such as `/user/:name` into a regular expression. 4 | 5 | **Note:** This is a legacy branch. You should upgrade to `1.x`. 6 | 7 | ## Usage 8 | 9 | ```javascript 10 | var pathToRegexp = require('path-to-regexp'); 11 | ``` 12 | 13 | ### pathToRegexp(path, keys, options) 14 | 15 | - **path** A string in the express format, an array of such strings, or a regular expression 16 | - **keys** An array to be populated with the keys present in the url. Once the function completes, this will be an array of strings. 17 | - **options** 18 | - **options.sensitive** Defaults to false, set this to true to make routes case sensitive 19 | - **options.strict** Defaults to false, set this to true to make the trailing slash matter. 20 | - **options.end** Defaults to true, set this to false to only match the prefix of the URL. 21 | 22 | ```javascript 23 | var keys = []; 24 | var exp = pathToRegexp('/foo/:bar', keys); 25 | //keys = ['bar'] 26 | //exp = /^\/foo\/(?:([^\/]+?))\/?$/i 27 | ``` 28 | 29 | ## Live Demo 30 | 31 | You can see a live demo of this library in use at [express-route-tester](http://forbeslindesay.github.com/express-route-tester/). 32 | 33 | ## License 34 | 35 | MIT 36 | -------------------------------------------------------------------------------- /deploy/node_modules/type-is/LICENSE: -------------------------------------------------------------------------------- 1 | (The MIT License) 2 | 3 | Copyright (c) 2014 Jonathan Ong 4 | Copyright (c) 2014-2015 Douglas Christopher Wilson 5 | 6 | Permission is hereby granted, free of charge, to any person obtaining 7 | a copy of this software and associated documentation files (the 8 | 'Software'), to deal in the Software without restriction, including 9 | without limitation the rights to use, copy, modify, merge, publish, 10 | distribute, sublicense, and/or sell copies of the Software, and to 11 | permit persons to whom the Software is furnished to do so, subject to 12 | the following conditions: 13 | 14 | The above copyright notice and this permission notice shall be 15 | included in all copies or substantial portions of the Software. 16 | 17 | THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, 18 | EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 19 | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. 20 | IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY 21 | CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, 22 | TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE 23 | SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 24 | -------------------------------------------------------------------------------- /deploy/node_modules/merge-descriptors/LICENSE: -------------------------------------------------------------------------------- 1 | (The MIT License) 2 | 3 | Copyright (c) 2013 Jonathan Ong 4 | Copyright (c) 2015 Douglas Christopher Wilson 5 | 6 | Permission is hereby granted, free of charge, to any person obtaining 7 | a copy of this software and associated documentation files (the 8 | 'Software'), to deal in the Software without restriction, including 9 | without limitation the rights to use, copy, modify, merge, publish, 10 | distribute, sublicense, and/or sell copies of the Software, and to 11 | permit persons to whom the Software is furnished to do so, subject to 12 | the following conditions: 13 | 14 | The above copyright notice and this permission notice shall be 15 | included in all copies or substantial portions of the Software. 16 | 17 | THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, 18 | EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 19 | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. 20 | IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY 21 | CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, 22 | TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE 23 | SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 24 | -------------------------------------------------------------------------------- /deploy/node_modules/parseurl/LICENSE: -------------------------------------------------------------------------------- 1 | 2 | (The MIT License) 3 | 4 | Copyright (c) 2014 Jonathan Ong 5 | Copyright (c) 2014 Douglas Christopher Wilson 6 | 7 | Permission is hereby granted, free of charge, to any person obtaining 8 | a copy of this software and associated documentation files (the 9 | 'Software'), to deal in the Software without restriction, including 10 | without limitation the rights to use, copy, modify, merge, publish, 11 | distribute, sublicense, and/or sell copies of the Software, and to 12 | permit persons to whom the Software is furnished to do so, subject to 13 | the following conditions: 14 | 15 | The above copyright notice and this permission notice shall be 16 | included in all copies or substantial portions of the Software. 17 | 18 | THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, 19 | EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 20 | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. 21 | IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY 22 | CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, 23 | TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE 24 | SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 25 | -------------------------------------------------------------------------------- /deploy/node_modules/methods/LICENSE: -------------------------------------------------------------------------------- 1 | (The MIT License) 2 | 3 | Copyright (c) 2013-2014 TJ Holowaychuk 4 | Copyright (c) 2015-2016 Douglas Christopher Wilson 5 | 6 | Permission is hereby granted, free of charge, to any person obtaining 7 | a copy of this software and associated documentation files (the 8 | 'Software'), to deal in the Software without restriction, including 9 | without limitation the rights to use, copy, modify, merge, publish, 10 | distribute, sublicense, and/or sell copies of the Software, and to 11 | permit persons to whom the Software is furnished to do so, subject to 12 | the following conditions: 13 | 14 | The above copyright notice and this permission notice shall be 15 | included in all copies or substantial portions of the Software. 16 | 17 | THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, 18 | EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 19 | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. 20 | IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY 21 | CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, 22 | TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE 23 | SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 24 | 25 | -------------------------------------------------------------------------------- /deploy/node_modules/negotiator/LICENSE: -------------------------------------------------------------------------------- 1 | (The MIT License) 2 | 3 | Copyright (c) 2012-2014 Federico Romero 4 | Copyright (c) 2012-2014 Isaac Z. Schlueter 5 | Copyright (c) 2014-2015 Douglas Christopher Wilson 6 | 7 | Permission is hereby granted, free of charge, to any person obtaining 8 | a copy of this software and associated documentation files (the 9 | 'Software'), to deal in the Software without restriction, including 10 | without limitation the rights to use, copy, modify, merge, publish, 11 | distribute, sublicense, and/or sell copies of the Software, and to 12 | permit persons to whom the Software is furnished to do so, subject to 13 | the following conditions: 14 | 15 | The above copyright notice and this permission notice shall be 16 | included in all copies or substantial portions of the Software. 17 | 18 | THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, 19 | EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 20 | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. 21 | IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY 22 | CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, 23 | TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE 24 | SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 25 | -------------------------------------------------------------------------------- /deploy/node_modules/cookie/LICENSE: -------------------------------------------------------------------------------- 1 | (The MIT License) 2 | 3 | Copyright (c) 2012-2014 Roman Shtylman 4 | Copyright (c) 2015 Douglas Christopher Wilson 5 | 6 | Permission is hereby granted, free of charge, to any person obtaining 7 | a copy of this software and associated documentation files (the 8 | 'Software'), to deal in the Software without restriction, including 9 | without limitation the rights to use, copy, modify, merge, publish, 10 | distribute, sublicense, and/or sell copies of the Software, and to 11 | permit persons to whom the Software is furnished to do so, subject to 12 | the following conditions: 13 | 14 | The above copyright notice and this permission notice shall be 15 | included in all copies or substantial portions of the Software. 16 | 17 | THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, 18 | EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 19 | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. 20 | IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY 21 | CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, 22 | TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE 23 | SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 24 | 25 | -------------------------------------------------------------------------------- /deploy/node_modules/serve-static/LICENSE: -------------------------------------------------------------------------------- 1 | (The MIT License) 2 | 3 | Copyright (c) 2010 Sencha Inc. 4 | Copyright (c) 2011 LearnBoost 5 | Copyright (c) 2011 TJ Holowaychuk 6 | Copyright (c) 2014-2015 Douglas Christopher Wilson 7 | 8 | Permission is hereby granted, free of charge, to any person obtaining 9 | a copy of this software and associated documentation files (the 10 | 'Software'), to deal in the Software without restriction, including 11 | without limitation the rights to use, copy, modify, merge, publish, 12 | distribute, sublicense, and/or sell copies of the Software, and to 13 | permit persons to whom the Software is furnished to do so, subject to 14 | the following conditions: 15 | 16 | The above copyright notice and this permission notice shall be 17 | included in all copies or substantial portions of the Software. 18 | 19 | THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, 20 | EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 21 | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. 22 | IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY 23 | CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, 24 | TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE 25 | SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 26 | -------------------------------------------------------------------------------- /deploy/node_modules/express/LICENSE: -------------------------------------------------------------------------------- 1 | (The MIT License) 2 | 3 | Copyright (c) 2009-2014 TJ Holowaychuk 4 | Copyright (c) 2013-2014 Roman Shtylman 5 | Copyright (c) 2014-2015 Douglas Christopher Wilson 6 | 7 | Permission is hereby granted, free of charge, to any person obtaining 8 | a copy of this software and associated documentation files (the 9 | 'Software'), to deal in the Software without restriction, including 10 | without limitation the rights to use, copy, modify, merge, publish, 11 | distribute, sublicense, and/or sell copies of the Software, and to 12 | permit persons to whom the Software is furnished to do so, subject to 13 | the following conditions: 14 | 15 | The above copyright notice and this permission notice shall be 16 | included in all copies or substantial portions of the Software. 17 | 18 | THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, 19 | EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 20 | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. 21 | IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY 22 | CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, 23 | TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE 24 | SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 25 | -------------------------------------------------------------------------------- /deploy/node_modules/methods/index.js: -------------------------------------------------------------------------------- 1 | /*! 2 | * methods 3 | * Copyright(c) 2013-2014 TJ Holowaychuk 4 | * Copyright(c) 2015-2016 Douglas Christopher Wilson 5 | * MIT Licensed 6 | */ 7 | 8 | 'use strict'; 9 | 10 | /** 11 | * Module dependencies. 12 | * @private 13 | */ 14 | 15 | var http = require('http'); 16 | 17 | /** 18 | * Module exports. 19 | * @public 20 | */ 21 | 22 | module.exports = getCurrentNodeMethods() || getBasicNodeMethods(); 23 | 24 | /** 25 | * Get the current Node.js methods. 26 | * @private 27 | */ 28 | 29 | function getCurrentNodeMethods() { 30 | return http.METHODS && http.METHODS.map(function lowerCaseMethod(method) { 31 | return method.toLowerCase(); 32 | }); 33 | } 34 | 35 | /** 36 | * Get the "basic" Node.js methods, a snapshot from Node.js 0.10. 37 | * @private 38 | */ 39 | 40 | function getBasicNodeMethods() { 41 | return [ 42 | 'get', 43 | 'post', 44 | 'put', 45 | 'head', 46 | 'delete', 47 | 'options', 48 | 'trace', 49 | 'copy', 50 | 'lock', 51 | 'mkcol', 52 | 'move', 53 | 'purge', 54 | 'propfind', 55 | 'proppatch', 56 | 'unlock', 57 | 'report', 58 | 'mkactivity', 59 | 'checkout', 60 | 'merge', 61 | 'm-search', 62 | 'notify', 63 | 'subscribe', 64 | 'unsubscribe', 65 | 'patch', 66 | 'search', 67 | 'connect' 68 | ]; 69 | } 70 | -------------------------------------------------------------------------------- /deploy/node_modules/range-parser/index.js: -------------------------------------------------------------------------------- 1 | /*! 2 | * range-parser 3 | * Copyright(c) 2012-2014 TJ Holowaychuk 4 | * MIT Licensed 5 | */ 6 | 7 | 'use strict'; 8 | 9 | /** 10 | * Module exports. 11 | * @public 12 | */ 13 | 14 | module.exports = rangeParser; 15 | 16 | /** 17 | * Parse "Range" header `str` relative to the given file `size`. 18 | * 19 | * @param {Number} size 20 | * @param {String} str 21 | * @return {Array} 22 | * @public 23 | */ 24 | 25 | function rangeParser(size, str) { 26 | var valid = true; 27 | var i = str.indexOf('='); 28 | 29 | if (-1 == i) return -2; 30 | 31 | var arr = str.slice(i + 1).split(',').map(function(range){ 32 | var range = range.split('-') 33 | , start = parseInt(range[0], 10) 34 | , end = parseInt(range[1], 10); 35 | 36 | // -nnn 37 | if (isNaN(start)) { 38 | start = size - end; 39 | end = size - 1; 40 | // nnn- 41 | } else if (isNaN(end)) { 42 | end = size - 1; 43 | } 44 | 45 | // limit last-byte-pos to current length 46 | if (end > size - 1) end = size - 1; 47 | 48 | // invalid 49 | if (isNaN(start) 50 | || isNaN(end) 51 | || start > end 52 | || start < 0) valid = false; 53 | 54 | return { 55 | start: start, 56 | end: end 57 | }; 58 | }); 59 | 60 | arr.type = str.slice(0, i); 61 | 62 | return valid ? arr : -1; 63 | } 64 | -------------------------------------------------------------------------------- /deploy/node_modules/destroy/index.js: -------------------------------------------------------------------------------- 1 | /*! 2 | * destroy 3 | * Copyright(c) 2014 Jonathan Ong 4 | * MIT Licensed 5 | */ 6 | 7 | 'use strict' 8 | 9 | /** 10 | * Module dependencies. 11 | * @private 12 | */ 13 | 14 | var ReadStream = require('fs').ReadStream 15 | var Stream = require('stream') 16 | 17 | /** 18 | * Module exports. 19 | * @public 20 | */ 21 | 22 | module.exports = destroy 23 | 24 | /** 25 | * Destroy a stream. 26 | * 27 | * @param {object} stream 28 | * @public 29 | */ 30 | 31 | function destroy(stream) { 32 | if (stream instanceof ReadStream) { 33 | return destroyReadStream(stream) 34 | } 35 | 36 | if (!(stream instanceof Stream)) { 37 | return stream 38 | } 39 | 40 | if (typeof stream.destroy === 'function') { 41 | stream.destroy() 42 | } 43 | 44 | return stream 45 | } 46 | 47 | /** 48 | * Destroy a ReadStream. 49 | * 50 | * @param {object} stream 51 | * @private 52 | */ 53 | 54 | function destroyReadStream(stream) { 55 | stream.destroy() 56 | 57 | if (typeof stream.close === 'function') { 58 | // node.js core bug work-around 59 | stream.on('open', onOpenClose) 60 | } 61 | 62 | return stream 63 | } 64 | 65 | /** 66 | * On open handler to close stream. 67 | * @private 68 | */ 69 | 70 | function onOpenClose() { 71 | if (typeof this.fd === 'number') { 72 | // actually close down the fd 73 | this.close() 74 | } 75 | } 76 | -------------------------------------------------------------------------------- /deploy/node_modules/statuses/index.js: -------------------------------------------------------------------------------- 1 | 2 | var codes = require('./codes.json'); 3 | 4 | module.exports = status; 5 | 6 | // [Integer...] 7 | status.codes = Object.keys(codes).map(function (code) { 8 | code = ~~code; 9 | var msg = codes[code]; 10 | status[code] = msg; 11 | status[msg] = status[msg.toLowerCase()] = code; 12 | return code; 13 | }); 14 | 15 | // status codes for redirects 16 | status.redirect = { 17 | 300: true, 18 | 301: true, 19 | 302: true, 20 | 303: true, 21 | 305: true, 22 | 307: true, 23 | 308: true, 24 | }; 25 | 26 | // status codes for empty bodies 27 | status.empty = { 28 | 204: true, 29 | 205: true, 30 | 304: true, 31 | }; 32 | 33 | // status codes for when you should retry the request 34 | status.retry = { 35 | 502: true, 36 | 503: true, 37 | 504: true, 38 | }; 39 | 40 | function status(code) { 41 | if (typeof code === 'number') { 42 | if (!status[code]) throw new Error('invalid status code: ' + code); 43 | return code; 44 | } 45 | 46 | if (typeof code !== 'string') { 47 | throw new TypeError('code must be a number or string'); 48 | } 49 | 50 | // '403' 51 | var n = parseInt(code, 10) 52 | if (!isNaN(n)) { 53 | if (!status[n]) throw new Error('invalid status code: ' + n); 54 | return n; 55 | } 56 | 57 | n = status[code.toLowerCase()]; 58 | if (!n) throw new Error('invalid status message: "' + code + '"'); 59 | return n; 60 | } 61 | -------------------------------------------------------------------------------- /deploy/node_modules/merge-descriptors/README.md: -------------------------------------------------------------------------------- 1 | # Merge Descriptors 2 | 3 | [![NPM Version][npm-image]][npm-url] 4 | [![NPM Downloads][downloads-image]][downloads-url] 5 | [![Build Status][travis-image]][travis-url] 6 | [![Test Coverage][coveralls-image]][coveralls-url] 7 | 8 | Merge objects using descriptors. 9 | 10 | ```js 11 | var thing = { 12 | get name() { 13 | return 'jon' 14 | } 15 | } 16 | 17 | var animal = { 18 | 19 | } 20 | 21 | merge(animal, thing) 22 | 23 | animal.name === 'jon' 24 | ``` 25 | 26 | ## API 27 | 28 | ### merge(destination, source) 29 | 30 | Redefines `destination`'s descriptors with `source`'s. 31 | 32 | ### merge(destination, source, false) 33 | 34 | Defines `source`'s descriptors on `destination` if `destination` does not have 35 | a descriptor by the same name. 36 | 37 | ## License 38 | 39 | [MIT](LICENSE) 40 | 41 | [npm-image]: https://img.shields.io/npm/v/merge-descriptors.svg 42 | [npm-url]: https://npmjs.org/package/merge-descriptors 43 | [travis-image]: https://img.shields.io/travis/component/merge-descriptors/master.svg 44 | [travis-url]: https://travis-ci.org/component/merge-descriptors 45 | [coveralls-image]: https://img.shields.io/coveralls/component/merge-descriptors/master.svg 46 | [coveralls-url]: https://coveralls.io/r/component/merge-descriptors?branch=master 47 | [downloads-image]: https://img.shields.io/npm/dm/merge-descriptors.svg 48 | [downloads-url]: https://npmjs.org/package/merge-descriptors 49 | -------------------------------------------------------------------------------- /deploy/node_modules/unpipe/README.md: -------------------------------------------------------------------------------- 1 | # unpipe 2 | 3 | [![NPM Version][npm-image]][npm-url] 4 | [![NPM Downloads][downloads-image]][downloads-url] 5 | [![Node.js Version][node-image]][node-url] 6 | [![Build Status][travis-image]][travis-url] 7 | [![Test Coverage][coveralls-image]][coveralls-url] 8 | 9 | Unpipe a stream from all destinations. 10 | 11 | ## Installation 12 | 13 | ```sh 14 | $ npm install unpipe 15 | ``` 16 | 17 | ## API 18 | 19 | ```js 20 | var unpipe = require('unpipe') 21 | ``` 22 | 23 | ### unpipe(stream) 24 | 25 | Unpipes all destinations from a given stream. With stream 2+, this is 26 | equivalent to `stream.unpipe()`. When used with streams 1 style streams 27 | (typically Node.js 0.8 and below), this module attempts to undo the 28 | actions done in `stream.pipe(dest)`. 29 | 30 | ## License 31 | 32 | [MIT](LICENSE) 33 | 34 | [npm-image]: https://img.shields.io/npm/v/unpipe.svg 35 | [npm-url]: https://npmjs.org/package/unpipe 36 | [node-image]: https://img.shields.io/node/v/unpipe.svg 37 | [node-url]: http://nodejs.org/download/ 38 | [travis-image]: https://img.shields.io/travis/stream-utils/unpipe.svg 39 | [travis-url]: https://travis-ci.org/stream-utils/unpipe 40 | [coveralls-image]: https://img.shields.io/coveralls/stream-utils/unpipe.svg 41 | [coveralls-url]: https://coveralls.io/r/stream-utils/unpipe?branch=master 42 | [downloads-image]: https://img.shields.io/npm/dm/unpipe.svg 43 | [downloads-url]: https://npmjs.org/package/unpipe 44 | -------------------------------------------------------------------------------- /deploy/node_modules/unpipe/index.js: -------------------------------------------------------------------------------- 1 | /*! 2 | * unpipe 3 | * Copyright(c) 2015 Douglas Christopher Wilson 4 | * MIT Licensed 5 | */ 6 | 7 | 'use strict' 8 | 9 | /** 10 | * Module exports. 11 | * @public 12 | */ 13 | 14 | module.exports = unpipe 15 | 16 | /** 17 | * Determine if there are Node.js pipe-like data listeners. 18 | * @private 19 | */ 20 | 21 | function hasPipeDataListeners(stream) { 22 | var listeners = stream.listeners('data') 23 | 24 | for (var i = 0; i < listeners.length; i++) { 25 | if (listeners[i].name === 'ondata') { 26 | return true 27 | } 28 | } 29 | 30 | return false 31 | } 32 | 33 | /** 34 | * Unpipe a stream from all destinations. 35 | * 36 | * @param {object} stream 37 | * @public 38 | */ 39 | 40 | function unpipe(stream) { 41 | if (!stream) { 42 | throw new TypeError('argument stream is required') 43 | } 44 | 45 | if (typeof stream.unpipe === 'function') { 46 | // new-style 47 | stream.unpipe() 48 | return 49 | } 50 | 51 | // Node.js 0.8 hack 52 | if (!hasPipeDataListeners(stream)) { 53 | return 54 | } 55 | 56 | var listener 57 | var listeners = stream.listeners('close') 58 | 59 | for (var i = 0; i < listeners.length; i++) { 60 | listener = listeners[i] 61 | 62 | if (listener.name !== 'cleanup' && listener.name !== 'onclose') { 63 | continue 64 | } 65 | 66 | // invoke the listener 67 | listener.call(stream) 68 | } 69 | } 70 | -------------------------------------------------------------------------------- /deploy/node_modules/array-flatten/README.md: -------------------------------------------------------------------------------- 1 | # Array Flatten 2 | 3 | [![NPM version][npm-image]][npm-url] 4 | [![NPM downloads][downloads-image]][downloads-url] 5 | [![Build status][travis-image]][travis-url] 6 | [![Test coverage][coveralls-image]][coveralls-url] 7 | 8 | > Flatten an array of nested arrays into a single flat array. Accepts an optional depth. 9 | 10 | ## Installation 11 | 12 | ``` 13 | npm install array-flatten --save 14 | ``` 15 | 16 | ## Usage 17 | 18 | ```javascript 19 | var flatten = require('array-flatten') 20 | 21 | flatten([1, [2, [3, [4, [5], 6], 7], 8], 9]) 22 | //=> [1, 2, 3, 4, 5, 6, 7, 8, 9] 23 | 24 | flatten([1, [2, [3, [4, [5], 6], 7], 8], 9], 2) 25 | //=> [1, 2, 3, [4, [5], 6], 7, 8, 9] 26 | 27 | (function () { 28 | flatten(arguments) //=> [1, 2, 3] 29 | })(1, [2, 3]) 30 | ``` 31 | 32 | ## License 33 | 34 | MIT 35 | 36 | [npm-image]: https://img.shields.io/npm/v/array-flatten.svg?style=flat 37 | [npm-url]: https://npmjs.org/package/array-flatten 38 | [downloads-image]: https://img.shields.io/npm/dm/array-flatten.svg?style=flat 39 | [downloads-url]: https://npmjs.org/package/array-flatten 40 | [travis-image]: https://img.shields.io/travis/blakeembrey/array-flatten.svg?style=flat 41 | [travis-url]: https://travis-ci.org/blakeembrey/array-flatten 42 | [coveralls-image]: https://img.shields.io/coveralls/blakeembrey/array-flatten.svg?style=flat 43 | [coveralls-url]: https://coveralls.io/r/blakeembrey/array-flatten?branch=master 44 | -------------------------------------------------------------------------------- /deploy/node_modules/cookie-signature/index.js: -------------------------------------------------------------------------------- 1 | /** 2 | * Module dependencies. 3 | */ 4 | 5 | var crypto = require('crypto'); 6 | 7 | /** 8 | * Sign the given `val` with `secret`. 9 | * 10 | * @param {String} val 11 | * @param {String} secret 12 | * @return {String} 13 | * @api private 14 | */ 15 | 16 | exports.sign = function(val, secret){ 17 | if ('string' != typeof val) throw new TypeError("Cookie value must be provided as a string."); 18 | if ('string' != typeof secret) throw new TypeError("Secret string must be provided."); 19 | return val + '.' + crypto 20 | .createHmac('sha256', secret) 21 | .update(val) 22 | .digest('base64') 23 | .replace(/\=+$/, ''); 24 | }; 25 | 26 | /** 27 | * Unsign and decode the given `val` with `secret`, 28 | * returning `false` if the signature is invalid. 29 | * 30 | * @param {String} val 31 | * @param {String} secret 32 | * @return {String|Boolean} 33 | * @api private 34 | */ 35 | 36 | exports.unsign = function(val, secret){ 37 | if ('string' != typeof val) throw new TypeError("Signed cookie string must be provided."); 38 | if ('string' != typeof secret) throw new TypeError("Secret string must be provided."); 39 | var str = val.slice(0, val.lastIndexOf('.')) 40 | , mac = exports.sign(str, secret); 41 | 42 | return sha1(mac) == sha1(val) ? str : false; 43 | }; 44 | 45 | /** 46 | * Private 47 | */ 48 | 49 | function sha1(str){ 50 | return crypto.createHash('sha1').update(str).digest('hex'); 51 | } 52 | -------------------------------------------------------------------------------- /deploy/node_modules/merge-descriptors/index.js: -------------------------------------------------------------------------------- 1 | /*! 2 | * merge-descriptors 3 | * Copyright(c) 2014 Jonathan Ong 4 | * Copyright(c) 2015 Douglas Christopher Wilson 5 | * MIT Licensed 6 | */ 7 | 8 | 'use strict' 9 | 10 | /** 11 | * Module exports. 12 | * @public 13 | */ 14 | 15 | module.exports = merge 16 | 17 | /** 18 | * Module variables. 19 | * @private 20 | */ 21 | 22 | var hasOwnProperty = Object.prototype.hasOwnProperty 23 | 24 | /** 25 | * Merge the property descriptors of `src` into `dest` 26 | * 27 | * @param {object} dest Object to add descriptors to 28 | * @param {object} src Object to clone descriptors from 29 | * @param {boolean} [redefine=true] Redefine `dest` properties with `src` properties 30 | * @returns {object} Reference to dest 31 | * @public 32 | */ 33 | 34 | function merge(dest, src, redefine) { 35 | if (!dest) { 36 | throw new TypeError('argument dest is required') 37 | } 38 | 39 | if (!src) { 40 | throw new TypeError('argument src is required') 41 | } 42 | 43 | if (redefine === undefined) { 44 | // Default to true 45 | redefine = true 46 | } 47 | 48 | Object.getOwnPropertyNames(src).forEach(function forEachOwnPropertyName(name) { 49 | if (!redefine && hasOwnProperty.call(dest, name)) { 50 | // Skip desriptor 51 | return 52 | } 53 | 54 | // Copy descriptor 55 | var descriptor = Object.getOwnPropertyDescriptor(src, name) 56 | Object.defineProperty(dest, name, descriptor) 57 | }) 58 | 59 | return dest 60 | } 61 | -------------------------------------------------------------------------------- /deploy/node_modules/array-flatten/array-flatten.js: -------------------------------------------------------------------------------- 1 | 'use strict' 2 | 3 | /** 4 | * Expose `arrayFlatten`. 5 | */ 6 | module.exports = arrayFlatten 7 | 8 | /** 9 | * Recursive flatten function with depth. 10 | * 11 | * @param {Array} array 12 | * @param {Array} result 13 | * @param {Number} depth 14 | * @return {Array} 15 | */ 16 | function flattenWithDepth (array, result, depth) { 17 | for (var i = 0; i < array.length; i++) { 18 | var value = array[i] 19 | 20 | if (depth > 0 && Array.isArray(value)) { 21 | flattenWithDepth(value, result, depth - 1) 22 | } else { 23 | result.push(value) 24 | } 25 | } 26 | 27 | return result 28 | } 29 | 30 | /** 31 | * Recursive flatten function. Omitting depth is slightly faster. 32 | * 33 | * @param {Array} array 34 | * @param {Array} result 35 | * @return {Array} 36 | */ 37 | function flattenForever (array, result) { 38 | for (var i = 0; i < array.length; i++) { 39 | var value = array[i] 40 | 41 | if (Array.isArray(value)) { 42 | flattenForever(value, result) 43 | } else { 44 | result.push(value) 45 | } 46 | } 47 | 48 | return result 49 | } 50 | 51 | /** 52 | * Flatten an array, with the ability to define a depth. 53 | * 54 | * @param {Array} array 55 | * @param {Number} depth 56 | * @return {Array} 57 | */ 58 | function arrayFlatten (array, depth) { 59 | if (depth == null) { 60 | return flattenForever(array, []) 61 | } 62 | 63 | return flattenWithDepth(array, [], depth) 64 | } 65 | -------------------------------------------------------------------------------- /deploy/node_modules/fresh/index.js: -------------------------------------------------------------------------------- 1 | 2 | /** 3 | * Expose `fresh()`. 4 | */ 5 | 6 | module.exports = fresh; 7 | 8 | /** 9 | * Check freshness of `req` and `res` headers. 10 | * 11 | * When the cache is "fresh" __true__ is returned, 12 | * otherwise __false__ is returned to indicate that 13 | * the cache is now stale. 14 | * 15 | * @param {Object} req 16 | * @param {Object} res 17 | * @return {Boolean} 18 | * @api public 19 | */ 20 | 21 | function fresh(req, res) { 22 | // defaults 23 | var etagMatches = true; 24 | var notModified = true; 25 | 26 | // fields 27 | var modifiedSince = req['if-modified-since']; 28 | var noneMatch = req['if-none-match']; 29 | var lastModified = res['last-modified']; 30 | var etag = res['etag']; 31 | var cc = req['cache-control']; 32 | 33 | // unconditional request 34 | if (!modifiedSince && !noneMatch) return false; 35 | 36 | // check for no-cache cache request directive 37 | if (cc && cc.indexOf('no-cache') !== -1) return false; 38 | 39 | // parse if-none-match 40 | if (noneMatch) noneMatch = noneMatch.split(/ *, */); 41 | 42 | // if-none-match 43 | if (noneMatch) { 44 | etagMatches = noneMatch.some(function (match) { 45 | return match === '*' || match === etag || match === 'W/' + etag; 46 | }); 47 | } 48 | 49 | // if-modified-since 50 | if (modifiedSince) { 51 | modifiedSince = new Date(modifiedSince); 52 | lastModified = new Date(lastModified); 53 | notModified = lastModified <= modifiedSince; 54 | } 55 | 56 | return !! (etagMatches && notModified); 57 | } 58 | -------------------------------------------------------------------------------- /deploy/node_modules/ms/History.md: -------------------------------------------------------------------------------- 1 | 2 | 0.7.1 / 2015-04-20 3 | ================== 4 | 5 | * prevent extraordinary long inputs (@evilpacket) 6 | * Fixed broken readme link 7 | 8 | 0.7.0 / 2014-11-24 9 | ================== 10 | 11 | * add time abbreviations, updated tests and readme for the new units 12 | * fix example in the readme. 13 | * add LICENSE file 14 | 15 | 0.6.2 / 2013-12-05 16 | ================== 17 | 18 | * Adding repository section to package.json to suppress warning from NPM. 19 | 20 | 0.6.1 / 2013-05-10 21 | ================== 22 | 23 | * fix singularization [visionmedia] 24 | 25 | 0.6.0 / 2013-03-15 26 | ================== 27 | 28 | * fix minutes 29 | 30 | 0.5.1 / 2013-02-24 31 | ================== 32 | 33 | * add component namespace 34 | 35 | 0.5.0 / 2012-11-09 36 | ================== 37 | 38 | * add short formatting as default and .long option 39 | * add .license property to component.json 40 | * add version to component.json 41 | 42 | 0.4.0 / 2012-10-22 43 | ================== 44 | 45 | * add rounding to fix crazy decimals 46 | 47 | 0.3.0 / 2012-09-07 48 | ================== 49 | 50 | * fix `ms()` [visionmedia] 51 | 52 | 0.2.0 / 2012-09-03 53 | ================== 54 | 55 | * add component.json [visionmedia] 56 | * add days support [visionmedia] 57 | * add hours support [visionmedia] 58 | * add minutes support [visionmedia] 59 | * add seconds support [visionmedia] 60 | * add ms string support [visionmedia] 61 | * refactor tests to facilitate ms(number) [visionmedia] 62 | 63 | 0.1.0 / 2012-03-07 64 | ================== 65 | 66 | * Initial release 67 | -------------------------------------------------------------------------------- /deploy/node_modules/fresh/README.md: -------------------------------------------------------------------------------- 1 | # fresh 2 | 3 | [![NPM Version][npm-image]][npm-url] 4 | [![NPM Downloads][downloads-image]][downloads-url] 5 | [![Node.js Version][node-version-image]][node-version-url] 6 | [![Build Status][travis-image]][travis-url] 7 | [![Test Coverage][coveralls-image]][coveralls-url] 8 | 9 | HTTP response freshness testing 10 | 11 | ## Installation 12 | 13 | ``` 14 | $ npm install fresh 15 | ``` 16 | 17 | ## API 18 | 19 | ```js 20 | var fresh = require('fresh') 21 | ``` 22 | 23 | ### fresh(req, res) 24 | 25 | Check freshness of `req` and `res` headers. 26 | 27 | When the cache is "fresh" __true__ is returned, 28 | otherwise __false__ is returned to indicate that 29 | the cache is now stale. 30 | 31 | ## Example 32 | 33 | ```js 34 | var req = { 'if-none-match': 'tobi' }; 35 | var res = { 'etag': 'luna' }; 36 | fresh(req, res); 37 | // => false 38 | 39 | var req = { 'if-none-match': 'tobi' }; 40 | var res = { 'etag': 'tobi' }; 41 | fresh(req, res); 42 | // => true 43 | ``` 44 | 45 | ## License 46 | 47 | [MIT](LICENSE) 48 | 49 | [npm-image]: https://img.shields.io/npm/v/fresh.svg 50 | [npm-url]: https://npmjs.org/package/fresh 51 | [node-version-image]: https://img.shields.io/node/v/fresh.svg 52 | [node-version-url]: http://nodejs.org/download/ 53 | [travis-image]: https://img.shields.io/travis/jshttp/fresh/master.svg 54 | [travis-url]: https://travis-ci.org/jshttp/fresh 55 | [coveralls-image]: https://img.shields.io/coveralls/jshttp/fresh/master.svg 56 | [coveralls-url]: https://coveralls.io/r/jshttp/fresh?branch=master 57 | [downloads-image]: https://img.shields.io/npm/dm/fresh.svg 58 | [downloads-url]: https://npmjs.org/package/fresh 59 | -------------------------------------------------------------------------------- /deploy/node_modules/forwarded/README.md: -------------------------------------------------------------------------------- 1 | # forwarded 2 | 3 | [![NPM Version][npm-image]][npm-url] 4 | [![NPM Downloads][downloads-image]][downloads-url] 5 | [![Node.js Version][node-version-image]][node-version-url] 6 | [![Build Status][travis-image]][travis-url] 7 | [![Test Coverage][coveralls-image]][coveralls-url] 8 | 9 | Parse HTTP X-Forwarded-For header 10 | 11 | ## Installation 12 | 13 | ```sh 14 | $ npm install forwarded 15 | ``` 16 | 17 | ## API 18 | 19 | ```js 20 | var forwarded = require('forwarded') 21 | ``` 22 | 23 | ### forwarded(req) 24 | 25 | ```js 26 | var addresses = forwarded(req) 27 | ``` 28 | 29 | Parse the `X-Forwarded-For` header from the request. Returns an array 30 | of the addresses, including the socket address for the `req`. In reverse 31 | order (i.e. index `0` is the socket address and the last index is the 32 | furthest address, typically the end-user). 33 | 34 | ## Testing 35 | 36 | ```sh 37 | $ npm test 38 | ``` 39 | 40 | ## License 41 | 42 | [MIT](LICENSE) 43 | 44 | [npm-image]: https://img.shields.io/npm/v/forwarded.svg?style=flat 45 | [npm-url]: https://npmjs.org/package/forwarded 46 | [node-version-image]: https://img.shields.io/node/v/forwarded.svg?style=flat 47 | [node-version-url]: http://nodejs.org/download/ 48 | [travis-image]: https://img.shields.io/travis/jshttp/forwarded.svg?style=flat 49 | [travis-url]: https://travis-ci.org/jshttp/forwarded 50 | [coveralls-image]: https://img.shields.io/coveralls/jshttp/forwarded.svg?style=flat 51 | [coveralls-url]: https://coveralls.io/r/jshttp/forwarded?branch=master 52 | [downloads-image]: https://img.shields.io/npm/dm/forwarded.svg?style=flat 53 | [downloads-url]: https://npmjs.org/package/forwarded 54 | -------------------------------------------------------------------------------- /deploy/node_modules/cookie-signature/Readme.md: -------------------------------------------------------------------------------- 1 | 2 | # cookie-signature 3 | 4 | Sign and unsign cookies. 5 | 6 | ## Example 7 | 8 | ```js 9 | var cookie = require('cookie-signature'); 10 | 11 | var val = cookie.sign('hello', 'tobiiscool'); 12 | val.should.equal('hello.DGDUkGlIkCzPz+C0B064FNgHdEjox7ch8tOBGslZ5QI'); 13 | 14 | var val = cookie.sign('hello', 'tobiiscool'); 15 | cookie.unsign(val, 'tobiiscool').should.equal('hello'); 16 | cookie.unsign(val, 'luna').should.be.false; 17 | ``` 18 | 19 | ## License 20 | 21 | (The MIT License) 22 | 23 | Copyright (c) 2012 LearnBoost <tj@learnboost.com> 24 | 25 | Permission is hereby granted, free of charge, to any person obtaining 26 | a copy of this software and associated documentation files (the 27 | 'Software'), to deal in the Software without restriction, including 28 | without limitation the rights to use, copy, modify, merge, publish, 29 | distribute, sublicense, and/or sell copies of the Software, and to 30 | permit persons to whom the Software is furnished to do so, subject to 31 | the following conditions: 32 | 33 | The above copyright notice and this permission notice shall be 34 | included in all copies or substantial portions of the Software. 35 | 36 | THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, 37 | EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 38 | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. 39 | IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY 40 | CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, 41 | TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE 42 | SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. -------------------------------------------------------------------------------- /deploy/node_modules/escape-html/index.js: -------------------------------------------------------------------------------- 1 | /*! 2 | * escape-html 3 | * Copyright(c) 2012-2013 TJ Holowaychuk 4 | * Copyright(c) 2015 Andreas Lubbe 5 | * Copyright(c) 2015 Tiancheng "Timothy" Gu 6 | * MIT Licensed 7 | */ 8 | 9 | 'use strict'; 10 | 11 | /** 12 | * Module variables. 13 | * @private 14 | */ 15 | 16 | var matchHtmlRegExp = /["'&<>]/; 17 | 18 | /** 19 | * Module exports. 20 | * @public 21 | */ 22 | 23 | module.exports = escapeHtml; 24 | 25 | /** 26 | * Escape special characters in the given string of html. 27 | * 28 | * @param {string} string The string to escape for inserting into HTML 29 | * @return {string} 30 | * @public 31 | */ 32 | 33 | function escapeHtml(string) { 34 | var str = '' + string; 35 | var match = matchHtmlRegExp.exec(str); 36 | 37 | if (!match) { 38 | return str; 39 | } 40 | 41 | var escape; 42 | var html = ''; 43 | var index = 0; 44 | var lastIndex = 0; 45 | 46 | for (index = match.index; index < str.length; index++) { 47 | switch (str.charCodeAt(index)) { 48 | case 34: // " 49 | escape = '"'; 50 | break; 51 | case 38: // & 52 | escape = '&'; 53 | break; 54 | case 39: // ' 55 | escape = '''; 56 | break; 57 | case 60: // < 58 | escape = '<'; 59 | break; 60 | case 62: // > 61 | escape = '>'; 62 | break; 63 | default: 64 | continue; 65 | } 66 | 67 | if (lastIndex !== index) { 68 | html += str.substring(lastIndex, index); 69 | } 70 | 71 | lastIndex = index + 1; 72 | html += escape; 73 | } 74 | 75 | return lastIndex !== index 76 | ? html + str.substring(lastIndex, index) 77 | : html; 78 | } 79 | -------------------------------------------------------------------------------- /deploy/public/src/style.css: -------------------------------------------------------------------------------- 1 | body{ 2 | background: linear-gradient(#795548, rgb(230, 177, 111)); 3 | } 4 | .content-panes { 5 | display: flex; 6 | justify-content:space-between; 7 | align-items: center; 8 | flex-flow: row wrap; 9 | } 10 | .output-item{ 11 | min-width: 350px; 12 | } 13 | @media all and (min-width: 1070px) { 14 | .output-item{ 15 | flex-grow: 3; 16 | flex-basis: auto; 17 | } 18 | } 19 | @media all and (max-width: 1070px){ 20 | .content-panes{ 21 | flex-flow: column wrap; 22 | } 23 | } 24 | .flex-item{ 25 | margin-top: 10px; 26 | } 27 | .Codemirror{ 28 | height: 300px; 29 | width: 350px; 30 | min-width: 100px; 31 | font-size: 14px; 32 | } 33 | iframe{ 34 | height: 300px; 35 | } 36 | #root{ 37 | height: 300px; 38 | background-color: #fff; 39 | box-sizing: border-box; 40 | } 41 | .output{ 42 | border: none; 43 | } 44 | 45 | .fakeButtons { 46 | height: 10px; 47 | width: 10px; 48 | border-radius: 50%; 49 | border: 1px solid #000; 50 | position: relative; 51 | top: 6px; 52 | left: 6px; 53 | background-color: #ff3b47; 54 | border-color: #9d252b; 55 | display: inline-block; 56 | } 57 | 58 | .fakeMinimize { 59 | left: 11px; 60 | background-color: #ffc100; 61 | border-color: #9d802c; 62 | } 63 | 64 | .fakeZoom { 65 | left: 16px; 66 | background-color: #00d742; 67 | border-color: #049931; 68 | } 69 | 70 | .fakeMenu { 71 | width: 350px; 72 | box-sizing: border-box; 73 | height: 25px; 74 | background-color: #bbb; 75 | margin: 0 auto; 76 | border-top-right-radius: 5px; 77 | border-top-left-radius: 5px; 78 | } 79 | @media all and (min-width: 1070px) { 80 | .fakeMenu{ 81 | width: 100%; 82 | } 83 | } -------------------------------------------------------------------------------- /deploy/node_modules/qs/LICENSE: -------------------------------------------------------------------------------- 1 | Copyright (c) 2014 Nathan LaFreniere and other contributors. 2 | All rights reserved. 3 | 4 | Redistribution and use in source and binary forms, with or without 5 | modification, are permitted provided that the following conditions are met: 6 | * Redistributions of source code must retain the above copyright 7 | notice, this list of conditions and the following disclaimer. 8 | * Redistributions in binary form must reproduce the above copyright 9 | notice, this list of conditions and the following disclaimer in the 10 | documentation and/or other materials provided with the distribution. 11 | * The names of any contributors may not be used to endorse or promote 12 | products derived from this software without specific prior written 13 | permission. 14 | 15 | THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND 16 | ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED 17 | WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 18 | DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDERS AND CONTRIBUTORS BE LIABLE FOR ANY 19 | DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES 20 | (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; 21 | LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND 22 | ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 23 | (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS 24 | SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 25 | 26 | * * * 27 | 28 | The complete list of contributors can be found at: https://github.com/hapijs/qs/graphs/contributors 29 | -------------------------------------------------------------------------------- /deploy/node_modules/etag/HISTORY.md: -------------------------------------------------------------------------------- 1 | 1.7.0 / 2015-06-08 2 | ================== 3 | 4 | * Always include entity length in ETags for hash length extensions 5 | * Generate non-Stats ETags using MD5 only (no longer CRC32) 6 | * Improve stat performance by removing hashing 7 | * Remove base64 padding in ETags to shorten 8 | * Use MD5 instead of MD4 in weak ETags over 1KB 9 | 10 | 1.6.0 / 2015-05-10 11 | ================== 12 | 13 | * Improve support for JXcore 14 | * Remove requirement of `atime` in the stats object 15 | * Support "fake" stats objects in environments without `fs` 16 | 17 | 1.5.1 / 2014-11-19 18 | ================== 19 | 20 | * deps: crc@3.2.1 21 | - Minor fixes 22 | 23 | 1.5.0 / 2014-10-14 24 | ================== 25 | 26 | * Improve string performance 27 | * Slightly improve speed for weak ETags over 1KB 28 | 29 | 1.4.0 / 2014-09-21 30 | ================== 31 | 32 | * Support "fake" stats objects 33 | * Support Node.js 0.6 34 | 35 | 1.3.1 / 2014-09-14 36 | ================== 37 | 38 | * Use the (new and improved) `crc` for crc32 39 | 40 | 1.3.0 / 2014-08-29 41 | ================== 42 | 43 | * Default strings to strong ETags 44 | * Improve speed for weak ETags over 1KB 45 | 46 | 1.2.1 / 2014-08-29 47 | ================== 48 | 49 | * Use the (much faster) `buffer-crc32` for crc32 50 | 51 | 1.2.0 / 2014-08-24 52 | ================== 53 | 54 | * Add support for file stat objects 55 | 56 | 1.1.0 / 2014-08-24 57 | ================== 58 | 59 | * Add fast-path for empty entity 60 | * Add weak ETag generation 61 | * Shrink size of generated ETags 62 | 63 | 1.0.1 / 2014-08-24 64 | ================== 65 | 66 | * Fix behavior of string containing Unicode 67 | 68 | 1.0.0 / 2014-05-18 69 | ================== 70 | 71 | * Initial release 72 | -------------------------------------------------------------------------------- /deploy/node_modules/http-errors/HISTORY.md: -------------------------------------------------------------------------------- 1 | 2015-02-02 / 1.3.1 2 | ================== 3 | 4 | * Fix regression where status can be overwritten in `createError` `props` 5 | 6 | 2015-02-01 / 1.3.0 7 | ================== 8 | 9 | * Construct errors using defined constructors from `createError` 10 | * Fix error names that are not identifiers 11 | - `createError["I'mateapot"]` is now `createError.ImATeapot` 12 | * Set a meaningful `name` property on constructed errors 13 | 14 | 2014-12-09 / 1.2.8 15 | ================== 16 | 17 | * Fix stack trace from exported function 18 | * Remove `arguments.callee` usage 19 | 20 | 2014-10-14 / 1.2.7 21 | ================== 22 | 23 | * Remove duplicate line 24 | 25 | 2014-10-02 / 1.2.6 26 | ================== 27 | 28 | * Fix `expose` to be `true` for `ClientError` constructor 29 | 30 | 2014-09-28 / 1.2.5 31 | ================== 32 | 33 | * deps: statuses@1 34 | 35 | 2014-09-21 / 1.2.4 36 | ================== 37 | 38 | * Fix dependency version to work with old `npm`s 39 | 40 | 2014-09-21 / 1.2.3 41 | ================== 42 | 43 | * deps: statuses@~1.1.0 44 | 45 | 2014-09-21 / 1.2.2 46 | ================== 47 | 48 | * Fix publish error 49 | 50 | 2014-09-21 / 1.2.1 51 | ================== 52 | 53 | * Support Node.js 0.6 54 | * Use `inherits` instead of `util` 55 | 56 | 2014-09-09 / 1.2.0 57 | ================== 58 | 59 | * Fix the way inheriting functions 60 | * Support `expose` being provided in properties argument 61 | 62 | 2014-09-08 / 1.1.0 63 | ================== 64 | 65 | * Default status to 500 66 | * Support provided `error` to extend 67 | 68 | 2014-09-08 / 1.0.1 69 | ================== 70 | 71 | * Fix accepting string message 72 | 73 | 2014-09-08 / 1.0.0 74 | ================== 75 | 76 | * Initial release 77 | -------------------------------------------------------------------------------- /deploy/node_modules/inherits/README.md: -------------------------------------------------------------------------------- 1 | Browser-friendly inheritance fully compatible with standard node.js 2 | [inherits](http://nodejs.org/api/util.html#util_util_inherits_constructor_superconstructor). 3 | 4 | This package exports standard `inherits` from node.js `util` module in 5 | node environment, but also provides alternative browser-friendly 6 | implementation through [browser 7 | field](https://gist.github.com/shtylman/4339901). Alternative 8 | implementation is a literal copy of standard one located in standalone 9 | module to avoid requiring of `util`. It also has a shim for old 10 | browsers with no `Object.create` support. 11 | 12 | While keeping you sure you are using standard `inherits` 13 | implementation in node.js environment, it allows bundlers such as 14 | [browserify](https://github.com/substack/node-browserify) to not 15 | include full `util` package to your client code if all you need is 16 | just `inherits` function. It worth, because browser shim for `util` 17 | package is large and `inherits` is often the single function you need 18 | from it. 19 | 20 | It's recommended to use this package instead of 21 | `require('util').inherits` for any code that has chances to be used 22 | not only in node.js but in browser too. 23 | 24 | ## usage 25 | 26 | ```js 27 | var inherits = require('inherits'); 28 | // then use exactly as the standard one 29 | ``` 30 | 31 | ## note on version ~1.0 32 | 33 | Version ~1.0 had completely different motivation and is not compatible 34 | neither with 2.0 nor with standard node.js `inherits`. 35 | 36 | If you are using version ~1.0 and planning to switch to ~2.0, be 37 | careful: 38 | 39 | * new version uses `super_` instead of `super` for referencing 40 | superclass 41 | * new version overwrites current prototype while old one preserves any 42 | existing fields on it 43 | -------------------------------------------------------------------------------- /deploy/node_modules/range-parser/README.md: -------------------------------------------------------------------------------- 1 | # range-parser 2 | 3 | [![NPM Version][npm-image]][npm-url] 4 | [![NPM Downloads][downloads-image]][downloads-url] 5 | [![Node.js Version][node-version-image]][node-version-url] 6 | [![Build Status][travis-image]][travis-url] 7 | [![Test Coverage][coveralls-image]][coveralls-url] 8 | 9 | Range header field parser. 10 | 11 | ## Installation 12 | 13 | ``` 14 | $ npm install range-parser 15 | ``` 16 | 17 | ## API 18 | 19 | ```js 20 | var parseRange = require('range-parser') 21 | ``` 22 | 23 | ### parseRange(size, header) 24 | 25 | Parse the given `header` string where `size` is the maximum size of the resource. 26 | An array of ranges will be returned or negative numbers indicating an error parsing. 27 | 28 | * `-2` signals a malformed header string 29 | * `-1` signals an invalid range 30 | 31 | ```js 32 | // parse header from request 33 | var range = parseRange(req.headers.range) 34 | 35 | // the type of the range 36 | if (range.type === 'bytes') { 37 | // the ranges 38 | range.forEach(function (r) { 39 | // do something with r.start and r.end 40 | }) 41 | } 42 | ``` 43 | 44 | ## License 45 | 46 | [MIT](LICENSE) 47 | 48 | [npm-image]: https://img.shields.io/npm/v/range-parser.svg 49 | [npm-url]: https://npmjs.org/package/range-parser 50 | [node-version-image]: https://img.shields.io/node/v/range-parser.svg 51 | [node-version-url]: http://nodejs.org/download/ 52 | [travis-image]: https://img.shields.io/travis/jshttp/range-parser.svg 53 | [travis-url]: https://travis-ci.org/jshttp/range-parser 54 | [coveralls-image]: https://img.shields.io/coveralls/jshttp/range-parser.svg 55 | [coveralls-url]: https://coveralls.io/r/jshttp/range-parser 56 | [downloads-image]: https://img.shields.io/npm/dm/range-parser.svg 57 | [downloads-url]: https://npmjs.org/package/range-parser 58 | -------------------------------------------------------------------------------- /src/style.css: -------------------------------------------------------------------------------- 1 | body{ 2 | background: linear-gradient(#795548, rgb(230, 177, 111)); 3 | } 4 | .content-panes { 5 | display: flex; 6 | justify-content:space-between; 7 | align-items: center; 8 | flex-flow: row wrap; 9 | } 10 | .output-item{ 11 | min-width: 350px; 12 | } 13 | .flex-item{ 14 | margin-top: 10px; 15 | } 16 | .Codemirror{ 17 | height: 300px; 18 | width: 350px; 19 | min-width: 100px; 20 | font-size: 14px; 21 | } 22 | iframe{ 23 | height: 300px; 24 | } 25 | #root{ 26 | height: 300px; 27 | background-color: #fff; 28 | box-sizing: border-box; 29 | } 30 | .output{ 31 | border: none; 32 | } 33 | 34 | .fakeButtons { 35 | height: 10px; 36 | width: 10px; 37 | border-radius: 50%; 38 | border: 1px solid #000; 39 | position: relative; 40 | top: 6px; 41 | left: 6px; 42 | background-color: #ff3b47; 43 | border-color: #9d252b; 44 | display: inline-block; 45 | } 46 | 47 | .fakeMinimize { 48 | left: 11px; 49 | background-color: #ffc100; 50 | border-color: #9d802c; 51 | } 52 | 53 | .fakeZoom { 54 | left: 16px; 55 | background-color: #00d742; 56 | border-color: #049931; 57 | } 58 | 59 | .fakeMenu { 60 | width: 350px; 61 | box-sizing: border-box; 62 | height: 25px; 63 | background-color: #bbb; 64 | margin: 0 auto; 65 | border-top-right-radius: 5px; 66 | border-top-left-radius: 5px; 67 | } 68 | @media all and (min-width: 1070px) { 69 | .fakeMenu{ 70 | width: 100%; 71 | } 72 | .output-item{ 73 | flex-grow: 3; 74 | flex-basis: auto; 75 | } 76 | } 77 | 78 | @media all and (max-width: 1070px){ 79 | .content-panes{ 80 | flex-flow: column wrap; 81 | align-items: stretch; 82 | } 83 | .Codemirror{ 84 | width : 100%; 85 | } 86 | .fakeMenu{ 87 | width: 100%; 88 | } 89 | } -------------------------------------------------------------------------------- /deploy/src/style.css: -------------------------------------------------------------------------------- 1 | body{ 2 | background: linear-gradient(#795548, rgb(230, 177, 111)); 3 | } 4 | .content-panes { 5 | display: flex; 6 | justify-content:space-between; 7 | align-items: center; 8 | flex-flow: row wrap; 9 | } 10 | .output-item{ 11 | min-width: 350px; 12 | } 13 | .flex-item{ 14 | margin-top: 10px; 15 | } 16 | .Codemirror{ 17 | height: 300px; 18 | width: 350px; 19 | min-width: 100px; 20 | font-size: 14px; 21 | } 22 | iframe{ 23 | height: 300px; 24 | } 25 | #root{ 26 | height: 300px; 27 | background-color: #fff; 28 | box-sizing: border-box; 29 | } 30 | .output{ 31 | border: none; 32 | } 33 | 34 | .fakeButtons { 35 | height: 10px; 36 | width: 10px; 37 | border-radius: 50%; 38 | border: 1px solid #000; 39 | position: relative; 40 | top: 6px; 41 | left: 6px; 42 | background-color: #ff3b47; 43 | border-color: #9d252b; 44 | display: inline-block; 45 | } 46 | 47 | .fakeMinimize { 48 | left: 11px; 49 | background-color: #ffc100; 50 | border-color: #9d802c; 51 | } 52 | 53 | .fakeZoom { 54 | left: 16px; 55 | background-color: #00d742; 56 | border-color: #049931; 57 | } 58 | 59 | .fakeMenu { 60 | width: 350px; 61 | box-sizing: border-box; 62 | height: 25px; 63 | background-color: #bbb; 64 | margin: 0 auto; 65 | border-top-right-radius: 5px; 66 | border-top-left-radius: 5px; 67 | } 68 | @media all and (min-width: 1070px) { 69 | .fakeMenu{ 70 | width: 100%; 71 | } 72 | .output-item{ 73 | flex-grow: 3; 74 | flex-basis: auto; 75 | } 76 | } 77 | 78 | @media all and (max-width: 1070px){ 79 | .content-panes{ 80 | flex-flow: column wrap; 81 | align-items: stretch; 82 | } 83 | .Codemirror{ 84 | width : 100%; 85 | } 86 | .fakeMenu{ 87 | width: 100%; 88 | } 89 | } -------------------------------------------------------------------------------- /deploy/node_modules/cookie/HISTORY.md: -------------------------------------------------------------------------------- 1 | 0.1.5 / 2015-09-17 2 | ================== 3 | 4 | * Fix regression when setting empty cookie value 5 | - Ease the new restriction, which is just basic header-level validation 6 | * Fix typo in invalid value errors 7 | 8 | 0.1.4 / 2015-09-17 9 | ================== 10 | 11 | * Throw better error for invalid argument to parse 12 | * Throw on invalid values provided to `serialize` 13 | - Ensures the resulting string is a valid HTTP header value 14 | 15 | 0.1.3 / 2015-05-19 16 | ================== 17 | 18 | * Reduce the scope of try-catch deopt 19 | * Remove argument reassignments 20 | 21 | 0.1.2 / 2014-04-16 22 | ================== 23 | 24 | * Remove unnecessary files from npm package 25 | 26 | 0.1.1 / 2014-02-23 27 | ================== 28 | 29 | * Fix bad parse when cookie value contained a comma 30 | * Fix support for `maxAge` of `0` 31 | 32 | 0.1.0 / 2013-05-01 33 | ================== 34 | 35 | * Add `decode` option 36 | * Add `encode` option 37 | 38 | 0.0.6 / 2013-04-08 39 | ================== 40 | 41 | * Ignore cookie parts missing `=` 42 | 43 | 0.0.5 / 2012-10-29 44 | ================== 45 | 46 | * Return raw cookie value if value unescape errors 47 | 48 | 0.0.4 / 2012-06-21 49 | ================== 50 | 51 | * Use encode/decodeURIComponent for cookie encoding/decoding 52 | - Improve server/client interoperability 53 | 54 | 0.0.3 / 2012-06-06 55 | ================== 56 | 57 | * Only escape special characters per the cookie RFC 58 | 59 | 0.0.2 / 2012-06-01 60 | ================== 61 | 62 | * Fix `maxAge` option to not throw error 63 | 64 | 0.0.1 / 2012-05-28 65 | ================== 66 | 67 | * Add more tests 68 | 69 | 0.0.0 / 2012-05-28 70 | ================== 71 | 72 | * Initial release 73 | -------------------------------------------------------------------------------- /deploy/node_modules/negotiator/HISTORY.md: -------------------------------------------------------------------------------- 1 | 0.5.3 / 2015-05-10 2 | ================== 3 | 4 | * Fix media type parameter matching to be case-insensitive 5 | 6 | 0.5.2 / 2015-05-06 7 | ================== 8 | 9 | * Fix comparing media types with quoted values 10 | * Fix splitting media types with quoted commas 11 | 12 | 0.5.1 / 2015-02-14 13 | ================== 14 | 15 | * Fix preference sorting to be stable for long acceptable lists 16 | 17 | 0.5.0 / 2014-12-18 18 | ================== 19 | 20 | * Fix list return order when large accepted list 21 | * Fix missing identity encoding when q=0 exists 22 | * Remove dynamic building of Negotiator class 23 | 24 | 0.4.9 / 2014-10-14 25 | ================== 26 | 27 | * Fix error when media type has invalid parameter 28 | 29 | 0.4.8 / 2014-09-28 30 | ================== 31 | 32 | * Fix all negotiations to be case-insensitive 33 | * Stable sort preferences of same quality according to client order 34 | * Support Node.js 0.6 35 | 36 | 0.4.7 / 2014-06-24 37 | ================== 38 | 39 | * Handle invalid provided languages 40 | * Handle invalid provided media types 41 | 42 | 0.4.6 / 2014-06-11 43 | ================== 44 | 45 | * Order by specificity when quality is the same 46 | 47 | 0.4.5 / 2014-05-29 48 | ================== 49 | 50 | * Fix regression in empty header handling 51 | 52 | 0.4.4 / 2014-05-29 53 | ================== 54 | 55 | * Fix behaviors when headers are not present 56 | 57 | 0.4.3 / 2014-04-16 58 | ================== 59 | 60 | * Handle slashes on media params correctly 61 | 62 | 0.4.2 / 2014-02-28 63 | ================== 64 | 65 | * Fix media type sorting 66 | * Handle media types params strictly 67 | 68 | 0.4.1 / 2014-01-16 69 | ================== 70 | 71 | * Use most specific matches 72 | 73 | 0.4.0 / 2014-01-09 74 | ================== 75 | 76 | * Remove preferred prefix from methods 77 | -------------------------------------------------------------------------------- /deploy/node_modules/depd/lib/browser/index.js: -------------------------------------------------------------------------------- 1 | /*! 2 | * depd 3 | * Copyright(c) 2015 Douglas Christopher Wilson 4 | * MIT Licensed 5 | */ 6 | 7 | 'use strict' 8 | 9 | /** 10 | * Module exports. 11 | * @public 12 | */ 13 | 14 | module.exports = depd 15 | 16 | /** 17 | * Create deprecate for namespace in caller. 18 | */ 19 | 20 | function depd(namespace) { 21 | if (!namespace) { 22 | throw new TypeError('argument namespace is required') 23 | } 24 | 25 | function deprecate(message) { 26 | // no-op in browser 27 | } 28 | 29 | deprecate._file = undefined 30 | deprecate._ignored = true 31 | deprecate._namespace = namespace 32 | deprecate._traced = false 33 | deprecate._warned = Object.create(null) 34 | 35 | deprecate.function = wrapfunction 36 | deprecate.property = wrapproperty 37 | 38 | return deprecate 39 | } 40 | 41 | /** 42 | * Return a wrapped function in a deprecation message. 43 | * 44 | * This is a no-op version of the wrapper, which does nothing but call 45 | * validation. 46 | */ 47 | 48 | function wrapfunction(fn, message) { 49 | if (typeof fn !== 'function') { 50 | throw new TypeError('argument fn must be a function') 51 | } 52 | 53 | return fn 54 | } 55 | 56 | /** 57 | * Wrap property in a deprecation message. 58 | * 59 | * This is a no-op version of the wrapper, which does nothing but call 60 | * validation. 61 | */ 62 | 63 | function wrapproperty(obj, prop, message) { 64 | if (!obj || (typeof obj !== 'object' && typeof obj !== 'function')) { 65 | throw new TypeError('argument obj must be object') 66 | } 67 | 68 | var descriptor = Object.getOwnPropertyDescriptor(obj, prop) 69 | 70 | if (!descriptor) { 71 | throw new TypeError('must call property on owner object') 72 | } 73 | 74 | if (!descriptor.configurable) { 75 | throw new TypeError('property must be configurable') 76 | } 77 | 78 | return 79 | } 80 | -------------------------------------------------------------------------------- /deploy/node_modules/proxy-addr/HISTORY.md: -------------------------------------------------------------------------------- 1 | 1.0.10 / 2015-12-09 2 | =================== 3 | 4 | * deps: ipaddr.js@1.0.5 5 | - Fix regression in `isValid` with non-string arguments 6 | 7 | 1.0.9 / 2015-12-01 8 | ================== 9 | 10 | * deps: ipaddr.js@1.0.4 11 | - Fix accepting some invalid IPv6 addresses 12 | - Reject CIDRs with negative or overlong masks 13 | * perf: enable strict mode 14 | 15 | 1.0.8 / 2015-05-10 16 | ================== 17 | 18 | * deps: ipaddr.js@1.0.1 19 | 20 | 1.0.7 / 2015-03-16 21 | ================== 22 | 23 | * deps: ipaddr.js@0.1.9 24 | - Fix OOM on certain inputs to `isValid` 25 | 26 | 1.0.6 / 2015-02-01 27 | ================== 28 | 29 | * deps: ipaddr.js@0.1.8 30 | 31 | 1.0.5 / 2015-01-08 32 | ================== 33 | 34 | * deps: ipaddr.js@0.1.6 35 | 36 | 1.0.4 / 2014-11-23 37 | ================== 38 | 39 | * deps: ipaddr.js@0.1.5 40 | - Fix edge cases with `isValid` 41 | 42 | 1.0.3 / 2014-09-21 43 | ================== 44 | 45 | * Use `forwarded` npm module 46 | 47 | 1.0.2 / 2014-09-18 48 | ================== 49 | 50 | * Fix a global leak when multiple subnets are trusted 51 | * Support Node.js 0.6 52 | * deps: ipaddr.js@0.1.3 53 | 54 | 1.0.1 / 2014-06-03 55 | ================== 56 | 57 | * Fix links in npm package 58 | 59 | 1.0.0 / 2014-05-08 60 | ================== 61 | 62 | * Add `trust` argument to determine proxy trust on 63 | * Accepts custom function 64 | * Accepts IPv4/IPv6 address(es) 65 | * Accepts subnets 66 | * Accepts pre-defined names 67 | * Add optional `trust` argument to `proxyaddr.all` to 68 | stop at first untrusted 69 | * Add `proxyaddr.compile` to pre-compile `trust` function 70 | to make subsequent calls faster 71 | 72 | 0.0.1 / 2014-05-04 73 | ================== 74 | 75 | * Fix bad npm publish 76 | 77 | 0.0.0 / 2014-05-04 78 | ================== 79 | 80 | * Initial release 81 | -------------------------------------------------------------------------------- /deploy/node_modules/methods/README.md: -------------------------------------------------------------------------------- 1 | # Methods 2 | 3 | [![NPM Version][npm-image]][npm-url] 4 | [![NPM Downloads][downloads-image]][downloads-url] 5 | [![Node.js Version][node-version-image]][node-version-url] 6 | [![Build Status][travis-image]][travis-url] 7 | [![Test Coverage][coveralls-image]][coveralls-url] 8 | 9 | HTTP verbs that Node.js core's HTTP parser supports. 10 | 11 | This module provides an export that is just like `http.METHODS` from Node.js core, 12 | with the following differences: 13 | 14 | * All method names are lower-cased. 15 | * Contains a fallback list of methods for Node.js versions that do not have a 16 | `http.METHODS` export (0.10 and lower). 17 | * Provides the fallback list when using tools like `browserify` without pulling 18 | in the `http` shim module. 19 | 20 | ## Install 21 | 22 | ```bash 23 | $ npm install methods 24 | ``` 25 | 26 | ## API 27 | 28 | ```js 29 | var methods = require('methods') 30 | ``` 31 | 32 | ### methods 33 | 34 | This is an array of lower-cased method names that Node.js supports. If Node.js 35 | provides the `http.METHODS` export, then this is the same array lower-cased, 36 | otherwise it is a snapshot of the verbs from Node.js 0.10. 37 | 38 | ## License 39 | 40 | [MIT](LICENSE) 41 | 42 | [npm-image]: https://img.shields.io/npm/v/methods.svg?style=flat 43 | [npm-url]: https://npmjs.org/package/methods 44 | [node-version-image]: https://img.shields.io/node/v/methods.svg?style=flat 45 | [node-version-url]: https://nodejs.org/en/download/ 46 | [travis-image]: https://img.shields.io/travis/jshttp/methods.svg?style=flat 47 | [travis-url]: https://travis-ci.org/jshttp/methods 48 | [coveralls-image]: https://img.shields.io/coveralls/jshttp/methods.svg?style=flat 49 | [coveralls-url]: https://coveralls.io/r/jshttp/methods?branch=master 50 | [downloads-image]: https://img.shields.io/npm/dm/methods.svg?style=flat 51 | [downloads-url]: https://npmjs.org/package/methods 52 | -------------------------------------------------------------------------------- /index.html: -------------------------------------------------------------------------------- 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 | -------------------------------------------------------------------------------- /deploy/node_modules/depd/lib/compat/index.js: -------------------------------------------------------------------------------- 1 | /*! 2 | * depd 3 | * Copyright(c) 2014-2015 Douglas Christopher Wilson 4 | * MIT Licensed 5 | */ 6 | 7 | 'use strict' 8 | 9 | /** 10 | * Module dependencies. 11 | * @private 12 | */ 13 | 14 | var Buffer = require('buffer') 15 | var EventEmitter = require('events').EventEmitter 16 | 17 | /** 18 | * Module exports. 19 | * @public 20 | */ 21 | 22 | lazyProperty(module.exports, 'bufferConcat', function bufferConcat() { 23 | return Buffer.concat || require('./buffer-concat') 24 | }) 25 | 26 | lazyProperty(module.exports, 'callSiteToString', function callSiteToString() { 27 | var limit = Error.stackTraceLimit 28 | var obj = {} 29 | var prep = Error.prepareStackTrace 30 | 31 | function prepareObjectStackTrace(obj, stack) { 32 | return stack 33 | } 34 | 35 | Error.prepareStackTrace = prepareObjectStackTrace 36 | Error.stackTraceLimit = 2 37 | 38 | // capture the stack 39 | Error.captureStackTrace(obj) 40 | 41 | // slice the stack 42 | var stack = obj.stack.slice() 43 | 44 | Error.prepareStackTrace = prep 45 | Error.stackTraceLimit = limit 46 | 47 | return stack[0].toString ? toString : require('./callsite-tostring') 48 | }) 49 | 50 | lazyProperty(module.exports, 'eventListenerCount', function eventListenerCount() { 51 | return EventEmitter.listenerCount || require('./event-listener-count') 52 | }) 53 | 54 | /** 55 | * Define a lazy property. 56 | */ 57 | 58 | function lazyProperty(obj, prop, getter) { 59 | function get() { 60 | var val = getter() 61 | 62 | Object.defineProperty(obj, prop, { 63 | configurable: true, 64 | enumerable: true, 65 | value: val 66 | }) 67 | 68 | return val 69 | } 70 | 71 | Object.defineProperty(obj, prop, { 72 | configurable: true, 73 | enumerable: true, 74 | get: get 75 | }) 76 | } 77 | 78 | /** 79 | * Call toString() on the obj 80 | */ 81 | 82 | function toString(obj) { 83 | return obj.toString() 84 | } 85 | -------------------------------------------------------------------------------- /deploy/index.html: -------------------------------------------------------------------------------- 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 | -------------------------------------------------------------------------------- /deploy/public/index.html: -------------------------------------------------------------------------------- 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 | -------------------------------------------------------------------------------- /src/handleChange.js: -------------------------------------------------------------------------------- 1 | const {createFrame} = require('./createIFrame'); 2 | const {jsValue,htmlValue,cssValue} = require('./initValue'); 3 | const {debounce} = require('./debounce'); 4 | 5 | let jsEditorEl,cssEditorEl,htmlEditorEl 6 | 7 | const htmlEl = document.querySelector("#htmlContent"), 8 | jsEl = document.querySelector('#jsContent'), 9 | cssEl = document.querySelector('#cssContent'); 10 | 11 | const createEditor = function(){ 12 | 13 | htmlEditorEl = CodeMirror.fromTextArea(htmlEl,{mode:"text/html",theme:'material'}) 14 | 15 | htmlEditorEl.on("change",handleHTMLChange); 16 | htmlEditorEl.doc.setValue(htmlValue) 17 | 18 | jsEditorEl = CodeMirror.fromTextArea(jsEl,{mode:"javascript",theme:'material'}) 19 | 20 | jsEditorEl.on("change",saveAndRender); 21 | jsEditorEl.doc.setValue(jsValue) 22 | 23 | cssEditorEl = CodeMirror.fromTextArea(cssEl,{mode:"css",theme:'material'}) 24 | 25 | cssEditorEl.on("change",handleCSSChange); 26 | cssEditorEl.doc.setValue(cssValue) 27 | } 28 | 29 | const renderPage = () => { 30 | const html = getHTML(), 31 | js = getJS(), 32 | css = getCSS(); 33 | 34 | createFrame({html,js,css}) 35 | 36 | } 37 | 38 | const handleHTMLChange = (el,{from, to, text, removed, origin}) => { 39 | el.save() 40 | renderPage() 41 | } 42 | 43 | const handleJSChange = (el,{from, to, text, removed, origin}) => { 44 | el.save() 45 | renderPage() 46 | } 47 | 48 | const handleCSSChange = (el,{from, to, text, removed, origin}) => { 49 | el.save() 50 | renderPage() 51 | } 52 | 53 | const saveAndRender = debounce((el,{from, to, text, removed, origin}) => { 54 | el.save() 55 | renderPage() 56 | },3000) 57 | 58 | const getHTML = () => { 59 | return htmlEl.value; 60 | } 61 | 62 | const getJS = () => { 63 | return jsEl.value; 64 | } 65 | 66 | const getCSS = () => { 67 | return cssEl.value; 68 | } 69 | 70 | 71 | module.exports = { 72 | createEditor, 73 | renderPage 74 | } -------------------------------------------------------------------------------- /deploy/src/handleChange.js: -------------------------------------------------------------------------------- 1 | const {createFrame} = require('./createIFrame'); 2 | const {jsValue,htmlValue,cssValue} = require('./initValue'); 3 | const {debounce} = require('./debounce'); 4 | 5 | let jsEditorEl,cssEditorEl,htmlEditorEl 6 | 7 | const htmlEl = document.querySelector("#htmlContent"), 8 | jsEl = document.querySelector('#jsContent'), 9 | cssEl = document.querySelector('#cssContent'); 10 | 11 | const createEditor = function(){ 12 | 13 | htmlEditorEl = CodeMirror.fromTextArea(htmlEl,{mode:"text/html",theme:'material'}) 14 | 15 | htmlEditorEl.on("change",handleHTMLChange); 16 | htmlEditorEl.doc.setValue(htmlValue) 17 | 18 | jsEditorEl = CodeMirror.fromTextArea(jsEl,{mode:"javascript",theme:'material'}) 19 | 20 | jsEditorEl.on("change",saveAndRender); 21 | jsEditorEl.doc.setValue(jsValue) 22 | 23 | cssEditorEl = CodeMirror.fromTextArea(cssEl,{mode:"css",theme:'material'}) 24 | 25 | cssEditorEl.on("change",handleCSSChange); 26 | cssEditorEl.doc.setValue(cssValue) 27 | } 28 | 29 | const renderPage = () => { 30 | const html = getHTML(), 31 | js = getJS(), 32 | css = getCSS(); 33 | 34 | createFrame({html,js,css}) 35 | 36 | } 37 | 38 | const handleHTMLChange = (el,{from, to, text, removed, origin}) => { 39 | el.save() 40 | renderPage() 41 | } 42 | 43 | const handleJSChange = (el,{from, to, text, removed, origin}) => { 44 | el.save() 45 | renderPage() 46 | } 47 | 48 | const handleCSSChange = (el,{from, to, text, removed, origin}) => { 49 | el.save() 50 | renderPage() 51 | } 52 | 53 | const saveAndRender = debounce((el,{from, to, text, removed, origin}) => { 54 | el.save() 55 | renderPage() 56 | },3000) 57 | 58 | const getHTML = () => { 59 | return htmlEl.value; 60 | } 61 | 62 | const getJS = () => { 63 | return jsEl.value; 64 | } 65 | 66 | const getCSS = () => { 67 | return cssEl.value; 68 | } 69 | 70 | 71 | module.exports = { 72 | createEditor, 73 | renderPage 74 | } -------------------------------------------------------------------------------- /deploy/public/src/handleChange.js: -------------------------------------------------------------------------------- 1 | const {createFrame} = require('./createIFrame'); 2 | const {jsValue,htmlValue,cssValue} = require('./initValue'); 3 | const {debounce} = require('./debounce'); 4 | 5 | let jsEditorEl,cssEditorEl,htmlEditorEl 6 | 7 | const htmlEl = document.querySelector("#htmlContent"), 8 | jsEl = document.querySelector('#jsContent'), 9 | cssEl = document.querySelector('#cssContent'); 10 | 11 | const createEditor = function(){ 12 | 13 | htmlEditorEl = CodeMirror.fromTextArea(htmlEl,{mode:"text/html",theme:'material'}) 14 | 15 | htmlEditorEl.on("change",handleHTMLChange); 16 | htmlEditorEl.doc.setValue(htmlValue) 17 | 18 | jsEditorEl = CodeMirror.fromTextArea(jsEl,{mode:"javascript",theme:'material'}) 19 | 20 | jsEditorEl.on("change",saveAndRender); 21 | jsEditorEl.doc.setValue(jsValue) 22 | 23 | cssEditorEl = CodeMirror.fromTextArea(cssEl,{mode:"css",theme:'material'}) 24 | 25 | cssEditorEl.on("change",handleCSSChange); 26 | cssEditorEl.doc.setValue(cssValue) 27 | } 28 | 29 | const renderPage = () => { 30 | const html = getHTML(), 31 | js = getJS(), 32 | css = getCSS(); 33 | 34 | createFrame({html,js,css}) 35 | 36 | } 37 | 38 | const handleHTMLChange = (el,{from, to, text, removed, origin}) => { 39 | el.save() 40 | renderPage() 41 | } 42 | 43 | const handleJSChange = (el,{from, to, text, removed, origin}) => { 44 | el.save() 45 | renderPage() 46 | } 47 | 48 | const handleCSSChange = (el,{from, to, text, removed, origin}) => { 49 | el.save() 50 | renderPage() 51 | } 52 | 53 | const saveAndRender = debounce((el,{from, to, text, removed, origin}) => { 54 | el.save() 55 | renderPage() 56 | },3000) 57 | 58 | const getHTML = () => { 59 | return htmlEl.value; 60 | } 61 | 62 | const getJS = () => { 63 | return jsEl.value; 64 | } 65 | 66 | const getCSS = () => { 67 | return cssEl.value; 68 | } 69 | 70 | 71 | module.exports = { 72 | createEditor, 73 | renderPage 74 | } -------------------------------------------------------------------------------- /deploy/node_modules/statuses/codes.json: -------------------------------------------------------------------------------- 1 | { 2 | "100": "Continue", 3 | "101": "Switching Protocols", 4 | "102": "Processing", 5 | "200": "OK", 6 | "201": "Created", 7 | "202": "Accepted", 8 | "203": "Non-Authoritative Information", 9 | "204": "No Content", 10 | "205": "Reset Content", 11 | "206": "Partial Content", 12 | "207": "Multi-Status", 13 | "208": "Already Reported", 14 | "226": "IM Used", 15 | "300": "Multiple Choices", 16 | "301": "Moved Permanently", 17 | "302": "Found", 18 | "303": "See Other", 19 | "304": "Not Modified", 20 | "305": "Use Proxy", 21 | "306": "(Unused)", 22 | "307": "Temporary Redirect", 23 | "308": "Permanent Redirect", 24 | "400": "Bad Request", 25 | "401": "Unauthorized", 26 | "402": "Payment Required", 27 | "403": "Forbidden", 28 | "404": "Not Found", 29 | "405": "Method Not Allowed", 30 | "406": "Not Acceptable", 31 | "407": "Proxy Authentication Required", 32 | "408": "Request Timeout", 33 | "409": "Conflict", 34 | "410": "Gone", 35 | "411": "Length Required", 36 | "412": "Precondition Failed", 37 | "413": "Payload Too Large", 38 | "414": "URI Too Long", 39 | "415": "Unsupported Media Type", 40 | "416": "Range Not Satisfiable", 41 | "417": "Expectation Failed", 42 | "418": "I'm a teapot", 43 | "422": "Unprocessable Entity", 44 | "423": "Locked", 45 | "424": "Failed Dependency", 46 | "425": "Unordered Collection", 47 | "426": "Upgrade Required", 48 | "428": "Precondition Required", 49 | "429": "Too Many Requests", 50 | "431": "Request Header Fields Too Large", 51 | "451": "Unavailable For Legal Reasons", 52 | "500": "Internal Server Error", 53 | "501": "Not Implemented", 54 | "502": "Bad Gateway", 55 | "503": "Service Unavailable", 56 | "504": "Gateway Timeout", 57 | "505": "HTTP Version Not Supported", 58 | "506": "Variant Also Negotiates", 59 | "507": "Insufficient Storage", 60 | "508": "Loop Detected", 61 | "509": "Bandwidth Limit Exceeded", 62 | "510": "Not Extended", 63 | "511": "Network Authentication Required" 64 | } -------------------------------------------------------------------------------- /deploy/node_modules/on-finished/HISTORY.md: -------------------------------------------------------------------------------- 1 | 2.3.0 / 2015-05-26 2 | ================== 3 | 4 | * Add defined behavior for HTTP `CONNECT` requests 5 | * Add defined behavior for HTTP `Upgrade` requests 6 | * deps: ee-first@1.1.1 7 | 8 | 2.2.1 / 2015-04-22 9 | ================== 10 | 11 | * Fix `isFinished(req)` when data buffered 12 | 13 | 2.2.0 / 2014-12-22 14 | ================== 15 | 16 | * Add message object to callback arguments 17 | 18 | 2.1.1 / 2014-10-22 19 | ================== 20 | 21 | * Fix handling of pipelined requests 22 | 23 | 2.1.0 / 2014-08-16 24 | ================== 25 | 26 | * Check if `socket` is detached 27 | * Return `undefined` for `isFinished` if state unknown 28 | 29 | 2.0.0 / 2014-08-16 30 | ================== 31 | 32 | * Add `isFinished` function 33 | * Move to `jshttp` organization 34 | * Remove support for plain socket argument 35 | * Rename to `on-finished` 36 | * Support both `req` and `res` as arguments 37 | * deps: ee-first@1.0.5 38 | 39 | 1.2.2 / 2014-06-10 40 | ================== 41 | 42 | * Reduce listeners added to emitters 43 | - avoids "event emitter leak" warnings when used multiple times on same request 44 | 45 | 1.2.1 / 2014-06-08 46 | ================== 47 | 48 | * Fix returned value when already finished 49 | 50 | 1.2.0 / 2014-06-05 51 | ================== 52 | 53 | * Call callback when called on already-finished socket 54 | 55 | 1.1.4 / 2014-05-27 56 | ================== 57 | 58 | * Support node.js 0.8 59 | 60 | 1.1.3 / 2014-04-30 61 | ================== 62 | 63 | * Make sure errors passed as instanceof `Error` 64 | 65 | 1.1.2 / 2014-04-18 66 | ================== 67 | 68 | * Default the `socket` to passed-in object 69 | 70 | 1.1.1 / 2014-01-16 71 | ================== 72 | 73 | * Rename module to `finished` 74 | 75 | 1.1.0 / 2013-12-25 76 | ================== 77 | 78 | * Call callback when called on already-errored socket 79 | 80 | 1.0.1 / 2013-12-20 81 | ================== 82 | 83 | * Actually pass the error to the callback 84 | 85 | 1.0.0 / 2013-12-20 86 | ================== 87 | 88 | * Initial release 89 | -------------------------------------------------------------------------------- /deploy/node_modules/ee-first/index.js: -------------------------------------------------------------------------------- 1 | /*! 2 | * ee-first 3 | * Copyright(c) 2014 Jonathan Ong 4 | * MIT Licensed 5 | */ 6 | 7 | 'use strict' 8 | 9 | /** 10 | * Module exports. 11 | * @public 12 | */ 13 | 14 | module.exports = first 15 | 16 | /** 17 | * Get the first event in a set of event emitters and event pairs. 18 | * 19 | * @param {array} stuff 20 | * @param {function} done 21 | * @public 22 | */ 23 | 24 | function first(stuff, done) { 25 | if (!Array.isArray(stuff)) 26 | throw new TypeError('arg must be an array of [ee, events...] arrays') 27 | 28 | var cleanups = [] 29 | 30 | for (var i = 0; i < stuff.length; i++) { 31 | var arr = stuff[i] 32 | 33 | if (!Array.isArray(arr) || arr.length < 2) 34 | throw new TypeError('each array member must be [ee, events...]') 35 | 36 | var ee = arr[0] 37 | 38 | for (var j = 1; j < arr.length; j++) { 39 | var event = arr[j] 40 | var fn = listener(event, callback) 41 | 42 | // listen to the event 43 | ee.on(event, fn) 44 | // push this listener to the list of cleanups 45 | cleanups.push({ 46 | ee: ee, 47 | event: event, 48 | fn: fn, 49 | }) 50 | } 51 | } 52 | 53 | function callback() { 54 | cleanup() 55 | done.apply(null, arguments) 56 | } 57 | 58 | function cleanup() { 59 | var x 60 | for (var i = 0; i < cleanups.length; i++) { 61 | x = cleanups[i] 62 | x.ee.removeListener(x.event, x.fn) 63 | } 64 | } 65 | 66 | function thunk(fn) { 67 | done = fn 68 | } 69 | 70 | thunk.cancel = cleanup 71 | 72 | return thunk 73 | } 74 | 75 | /** 76 | * Create the event listener. 77 | * @private 78 | */ 79 | 80 | function listener(event, done) { 81 | return function onevent(arg1) { 82 | var args = new Array(arguments.length) 83 | var ee = this 84 | var err = event === 'error' 85 | ? arg1 86 | : null 87 | 88 | // copy args to prevent arguments escaping scope 89 | for (var i = 0; i < args.length; i++) { 90 | args[i] = arguments[i] 91 | } 92 | 93 | done(err, ee, event, args) 94 | } 95 | } 96 | -------------------------------------------------------------------------------- /deploy/node_modules/cookie/README.md: -------------------------------------------------------------------------------- 1 | # cookie 2 | 3 | [![NPM Version][npm-image]][npm-url] 4 | [![NPM Downloads][downloads-image]][downloads-url] 5 | [![Node.js Version][node-version-image]][node-version-url] 6 | [![Build Status][travis-image]][travis-url] 7 | [![Test Coverage][coveralls-image]][coveralls-url] 8 | 9 | cookie is a basic cookie parser and serializer. It doesn't make assumptions about how you are going to deal with your cookies. It basically just provides a way to read and write the HTTP cookie headers. 10 | 11 | See [RFC6265](http://tools.ietf.org/html/rfc6265) for details about the http header for cookies. 12 | 13 | ## how? 14 | 15 | ``` 16 | npm install cookie 17 | ``` 18 | 19 | ```javascript 20 | var cookie = require('cookie'); 21 | 22 | var hdr = cookie.serialize('foo', 'bar'); 23 | // hdr = 'foo=bar'; 24 | 25 | var cookies = cookie.parse('foo=bar; cat=meow; dog=ruff'); 26 | // cookies = { foo: 'bar', cat: 'meow', dog: 'ruff' }; 27 | ``` 28 | 29 | ## more 30 | 31 | The serialize function takes a third parameter, an object, to set cookie options. See the RFC for valid values. 32 | 33 | ### path 34 | > cookie path 35 | 36 | ### expires 37 | > absolute expiration date for the cookie (Date object) 38 | 39 | ### maxAge 40 | > relative max age of the cookie from when the client receives it (seconds) 41 | 42 | ### domain 43 | > domain for the cookie 44 | 45 | ### secure 46 | > true or false 47 | 48 | ### httpOnly 49 | > true or false 50 | 51 | ## License 52 | 53 | [MIT](LICENSE) 54 | 55 | [npm-image]: https://img.shields.io/npm/v/cookie.svg 56 | [npm-url]: https://npmjs.org/package/cookie 57 | [node-version-image]: https://img.shields.io/node/v/cookie.svg 58 | [node-version-url]: http://nodejs.org/download/ 59 | [travis-image]: https://img.shields.io/travis/jshttp/cookie/master.svg 60 | [travis-url]: https://travis-ci.org/jshttp/cookie 61 | [coveralls-image]: https://img.shields.io/coveralls/jshttp/cookie/master.svg 62 | [coveralls-url]: https://coveralls.io/r/jshttp/cookie?branch=master 63 | [downloads-image]: https://img.shields.io/npm/dm/cookie.svg 64 | [downloads-url]: https://npmjs.org/package/cookie 65 | -------------------------------------------------------------------------------- /deploy/node_modules/depd/History.md: -------------------------------------------------------------------------------- 1 | 1.1.0 / 2015-09-14 2 | ================== 3 | 4 | * Enable strict mode in more places 5 | * Support io.js 3.x 6 | * Support io.js 2.x 7 | * Support web browser loading 8 | - Requires bundler like Browserify or webpack 9 | 10 | 1.0.1 / 2015-04-07 11 | ================== 12 | 13 | * Fix `TypeError`s when under `'use strict'` code 14 | * Fix useless type name on auto-generated messages 15 | * Support io.js 1.x 16 | * Support Node.js 0.12 17 | 18 | 1.0.0 / 2014-09-17 19 | ================== 20 | 21 | * No changes 22 | 23 | 0.4.5 / 2014-09-09 24 | ================== 25 | 26 | * Improve call speed to functions using the function wrapper 27 | * Support Node.js 0.6 28 | 29 | 0.4.4 / 2014-07-27 30 | ================== 31 | 32 | * Work-around v8 generating empty stack traces 33 | 34 | 0.4.3 / 2014-07-26 35 | ================== 36 | 37 | * Fix exception when global `Error.stackTraceLimit` is too low 38 | 39 | 0.4.2 / 2014-07-19 40 | ================== 41 | 42 | * Correct call site for wrapped functions and properties 43 | 44 | 0.4.1 / 2014-07-19 45 | ================== 46 | 47 | * Improve automatic message generation for function properties 48 | 49 | 0.4.0 / 2014-07-19 50 | ================== 51 | 52 | * Add `TRACE_DEPRECATION` environment variable 53 | * Remove non-standard grey color from color output 54 | * Support `--no-deprecation` argument 55 | * Support `--trace-deprecation` argument 56 | * Support `deprecate.property(fn, prop, message)` 57 | 58 | 0.3.0 / 2014-06-16 59 | ================== 60 | 61 | * Add `NO_DEPRECATION` environment variable 62 | 63 | 0.2.0 / 2014-06-15 64 | ================== 65 | 66 | * Add `deprecate.property(obj, prop, message)` 67 | * Remove `supports-color` dependency for node.js 0.8 68 | 69 | 0.1.0 / 2014-06-15 70 | ================== 71 | 72 | * Add `deprecate.function(fn, message)` 73 | * Add `process.on('deprecation', fn)` emitter 74 | * Automatically generate message when omitted from `deprecate()` 75 | 76 | 0.0.1 / 2014-06-15 77 | ================== 78 | 79 | * Fix warning for dynamic calls at singe call site 80 | 81 | 0.0.0 / 2014-06-15 82 | ================== 83 | 84 | * Initial implementation 85 | -------------------------------------------------------------------------------- /deploy/node_modules/http-errors/README.md: -------------------------------------------------------------------------------- 1 | # http-errors 2 | 3 | [![NPM Version][npm-image]][npm-url] 4 | [![NPM Downloads][downloads-image]][downloads-url] 5 | [![Node.js Version][node-version-image]][node-version-url] 6 | [![Build Status][travis-image]][travis-url] 7 | [![Test Coverage][coveralls-image]][coveralls-url] 8 | 9 | Create HTTP errors for Express, Koa, Connect, etc. with ease. 10 | 11 | ## Example 12 | 13 | ```js 14 | var createError = require('http-errors'); 15 | 16 | app.use(function (req, res, next) { 17 | if (!req.user) return next(createError(401, 'Please login to view this page.')); 18 | next(); 19 | }) 20 | ``` 21 | 22 | ## API 23 | 24 | This is the current API, currently extracted from Koa and subject to change. 25 | 26 | ### Error Properties 27 | 28 | - `message` 29 | - `status` and `statusCode` - the status code of the error, defaulting to `500` 30 | 31 | ### createError([status], [message], [properties]) 32 | 33 | ```js 34 | var err = createError(404, 'This video does not exist!'); 35 | ``` 36 | 37 | - `status: 500` - the status code as a number 38 | - `message` - the message of the error, defaulting to node's text for that status code. 39 | - `properties` - custom properties to attach to the object 40 | 41 | ### new createError\[code || name\](\[msg]\)) 42 | 43 | ```js 44 | var err = new createError.NotFound(); 45 | ``` 46 | 47 | - `code` - the status code as a number 48 | - `name` - the name of the error as a "bumpy case", i.e. `NotFound` or `InternalServerError`. 49 | 50 | ## License 51 | 52 | [MIT](LICENSE) 53 | 54 | [npm-image]: https://img.shields.io/npm/v/http-errors.svg?style=flat 55 | [npm-url]: https://npmjs.org/package/http-errors 56 | [node-version-image]: https://img.shields.io/node/v/http-errors.svg?style=flat 57 | [node-version-url]: http://nodejs.org/download/ 58 | [travis-image]: https://img.shields.io/travis/jshttp/http-errors.svg?style=flat 59 | [travis-url]: https://travis-ci.org/jshttp/http-errors 60 | [coveralls-image]: https://img.shields.io/coveralls/jshttp/http-errors.svg?style=flat 61 | [coveralls-url]: https://coveralls.io/r/jshttp/http-errors 62 | [downloads-image]: https://img.shields.io/npm/dm/http-errors.svg?style=flat 63 | [downloads-url]: https://npmjs.org/package/http-errors 64 | -------------------------------------------------------------------------------- /deploy/node_modules/ms/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "_args": [ 3 | [ 4 | { 5 | "raw": "ms@0.7.1", 6 | "scope": null, 7 | "escapedName": "ms", 8 | "name": "ms", 9 | "rawSpec": "0.7.1", 10 | "spec": "0.7.1", 11 | "type": "version" 12 | }, 13 | "/Users/swapnilmishra/Documents/github-repo/jsbin-jsfiddle/deploy/node_modules/debug" 14 | ] 15 | ], 16 | "_from": "ms@0.7.1", 17 | "_id": "ms@0.7.1", 18 | "_inCache": true, 19 | "_installable": true, 20 | "_location": "/ms", 21 | "_nodeVersion": "0.12.2", 22 | "_npmUser": { 23 | "name": "rauchg", 24 | "email": "rauchg@gmail.com" 25 | }, 26 | "_npmVersion": "2.7.5", 27 | "_phantomChildren": {}, 28 | "_requested": { 29 | "raw": "ms@0.7.1", 30 | "scope": null, 31 | "escapedName": "ms", 32 | "name": "ms", 33 | "rawSpec": "0.7.1", 34 | "spec": "0.7.1", 35 | "type": "version" 36 | }, 37 | "_requiredBy": [ 38 | "/debug", 39 | "/send", 40 | "/serve-static/send" 41 | ], 42 | "_resolved": "https://registry.npmjs.org/ms/-/ms-0.7.1.tgz", 43 | "_shasum": "9cd13c03adbff25b65effde7ce864ee952017098", 44 | "_shrinkwrap": null, 45 | "_spec": "ms@0.7.1", 46 | "_where": "/Users/swapnilmishra/Documents/github-repo/jsbin-jsfiddle/deploy/node_modules/debug", 47 | "bugs": { 48 | "url": "https://github.com/guille/ms.js/issues" 49 | }, 50 | "component": { 51 | "scripts": { 52 | "ms/index.js": "index.js" 53 | } 54 | }, 55 | "dependencies": {}, 56 | "description": "Tiny ms conversion utility", 57 | "devDependencies": { 58 | "expect.js": "*", 59 | "mocha": "*", 60 | "serve": "*" 61 | }, 62 | "directories": {}, 63 | "dist": { 64 | "shasum": "9cd13c03adbff25b65effde7ce864ee952017098", 65 | "tarball": "https://registry.npmjs.org/ms/-/ms-0.7.1.tgz" 66 | }, 67 | "gitHead": "713dcf26d9e6fd9dbc95affe7eff9783b7f1b909", 68 | "homepage": "https://github.com/guille/ms.js", 69 | "main": "./index", 70 | "maintainers": [ 71 | { 72 | "name": "rauchg", 73 | "email": "rauchg@gmail.com" 74 | } 75 | ], 76 | "name": "ms", 77 | "optionalDependencies": {}, 78 | "readme": "ERROR: No README data found!", 79 | "repository": { 80 | "type": "git", 81 | "url": "git://github.com/guille/ms.js.git" 82 | }, 83 | "scripts": {}, 84 | "version": "0.7.1" 85 | } 86 | -------------------------------------------------------------------------------- /deploy/node_modules/negotiator/index.js: -------------------------------------------------------------------------------- 1 | 2 | var preferredCharsets = require('./lib/charset'); 3 | var preferredEncodings = require('./lib/encoding'); 4 | var preferredLanguages = require('./lib/language'); 5 | var preferredMediaTypes = require('./lib/mediaType'); 6 | 7 | module.exports = Negotiator; 8 | Negotiator.Negotiator = Negotiator; 9 | 10 | function Negotiator(request) { 11 | if (!(this instanceof Negotiator)) { 12 | return new Negotiator(request); 13 | } 14 | 15 | this.request = request; 16 | } 17 | 18 | Negotiator.prototype.charset = function charset(available) { 19 | var set = this.charsets(available); 20 | return set && set[0]; 21 | }; 22 | 23 | Negotiator.prototype.charsets = function charsets(available) { 24 | return preferredCharsets(this.request.headers['accept-charset'], available); 25 | }; 26 | 27 | Negotiator.prototype.encoding = function encoding(available) { 28 | var set = this.encodings(available); 29 | return set && set[0]; 30 | }; 31 | 32 | Negotiator.prototype.encodings = function encodings(available) { 33 | return preferredEncodings(this.request.headers['accept-encoding'], available); 34 | }; 35 | 36 | Negotiator.prototype.language = function language(available) { 37 | var set = this.languages(available); 38 | return set && set[0]; 39 | }; 40 | 41 | Negotiator.prototype.languages = function languages(available) { 42 | return preferredLanguages(this.request.headers['accept-language'], available); 43 | }; 44 | 45 | Negotiator.prototype.mediaType = function mediaType(available) { 46 | var set = this.mediaTypes(available); 47 | return set && set[0]; 48 | }; 49 | 50 | Negotiator.prototype.mediaTypes = function mediaTypes(available) { 51 | return preferredMediaTypes(this.request.headers.accept, available); 52 | }; 53 | 54 | // Backwards compatibility 55 | Negotiator.prototype.preferredCharset = Negotiator.prototype.charset; 56 | Negotiator.prototype.preferredCharsets = Negotiator.prototype.charsets; 57 | Negotiator.prototype.preferredEncoding = Negotiator.prototype.encoding; 58 | Negotiator.prototype.preferredEncodings = Negotiator.prototype.encodings; 59 | Negotiator.prototype.preferredLanguage = Negotiator.prototype.language; 60 | Negotiator.prototype.preferredLanguages = Negotiator.prototype.languages; 61 | Negotiator.prototype.preferredMediaType = Negotiator.prototype.mediaType; 62 | Negotiator.prototype.preferredMediaTypes = Negotiator.prototype.mediaTypes; 63 | -------------------------------------------------------------------------------- /deploy/node_modules/mime/build/test.js: -------------------------------------------------------------------------------- 1 | /** 2 | * Usage: node test.js 3 | */ 4 | 5 | var mime = require('../mime'); 6 | var assert = require('assert'); 7 | var path = require('path'); 8 | 9 | // 10 | // Test mime lookups 11 | // 12 | 13 | assert.equal('text/plain', mime.lookup('text.txt')); // normal file 14 | assert.equal('text/plain', mime.lookup('TEXT.TXT')); // uppercase 15 | assert.equal('text/plain', mime.lookup('dir/text.txt')); // dir + file 16 | assert.equal('text/plain', mime.lookup('.text.txt')); // hidden file 17 | assert.equal('text/plain', mime.lookup('.txt')); // nameless 18 | assert.equal('text/plain', mime.lookup('txt')); // extension-only 19 | assert.equal('text/plain', mime.lookup('/txt')); // extension-less () 20 | assert.equal('text/plain', mime.lookup('\\txt')); // Windows, extension-less 21 | assert.equal('application/octet-stream', mime.lookup('text.nope')); // unrecognized 22 | assert.equal('fallback', mime.lookup('text.fallback', 'fallback')); // alternate default 23 | 24 | // 25 | // Test extensions 26 | // 27 | 28 | assert.equal('txt', mime.extension(mime.types.text)); 29 | assert.equal('html', mime.extension(mime.types.htm)); 30 | assert.equal('bin', mime.extension('application/octet-stream')); 31 | assert.equal('bin', mime.extension('application/octet-stream ')); 32 | assert.equal('html', mime.extension(' text/html; charset=UTF-8')); 33 | assert.equal('html', mime.extension('text/html; charset=UTF-8 ')); 34 | assert.equal('html', mime.extension('text/html; charset=UTF-8')); 35 | assert.equal('html', mime.extension('text/html ; charset=UTF-8')); 36 | assert.equal('html', mime.extension('text/html;charset=UTF-8')); 37 | assert.equal('html', mime.extension('text/Html;charset=UTF-8')); 38 | assert.equal(undefined, mime.extension('unrecognized')); 39 | 40 | // 41 | // Test node.types lookups 42 | // 43 | 44 | assert.equal('application/font-woff', mime.lookup('file.woff')); 45 | assert.equal('application/octet-stream', mime.lookup('file.buffer')); 46 | assert.equal('audio/mp4', mime.lookup('file.m4a')); 47 | assert.equal('font/opentype', mime.lookup('file.otf')); 48 | 49 | // 50 | // Test charsets 51 | // 52 | 53 | assert.equal('UTF-8', mime.charsets.lookup('text/plain')); 54 | assert.equal(undefined, mime.charsets.lookup(mime.types.js)); 55 | assert.equal('fallback', mime.charsets.lookup('application/octet-stream', 'fallback')); 56 | 57 | console.log('\nAll tests passed'); 58 | -------------------------------------------------------------------------------- /deploy/node_modules/destroy/README.md: -------------------------------------------------------------------------------- 1 | # Destroy 2 | 3 | [![NPM version][npm-image]][npm-url] 4 | [![Build status][travis-image]][travis-url] 5 | [![Test coverage][coveralls-image]][coveralls-url] 6 | [![License][license-image]][license-url] 7 | [![Downloads][downloads-image]][downloads-url] 8 | [![Gittip][gittip-image]][gittip-url] 9 | 10 | Destroy a stream. 11 | 12 | This module is meant to ensure a stream gets destroyed, handling different APIs 13 | and Node.js bugs. 14 | 15 | ## API 16 | 17 | ```js 18 | var destroy = require('destroy') 19 | ``` 20 | 21 | ### destroy(stream) 22 | 23 | Destroy the given stream. In most cases, this is identical to a simple 24 | `stream.destroy()` call. The rules are as follows for a given stream: 25 | 26 | 1. If the `stream` is an instance of `ReadStream`, then call `stream.destroy()` 27 | and add a listener to the `open` event to call `stream.close()` if it is 28 | fired. This is for a Node.js bug that will leak a file descriptor if 29 | `.destroy()` is called before `open`. 30 | 2. If the `stream` is not an instance of `Stream`, then nothing happens. 31 | 3. If the `stream` has a `.destroy()` method, then call it. 32 | 33 | The function returns the `stream` passed in as the argument. 34 | 35 | ## Example 36 | 37 | ```js 38 | var destroy = require('destroy') 39 | 40 | var fs = require('fs') 41 | var stream = fs.createReadStream('package.json') 42 | 43 | // ... and later 44 | destroy(stream) 45 | ``` 46 | 47 | [npm-image]: https://img.shields.io/npm/v/destroy.svg?style=flat-square 48 | [npm-url]: https://npmjs.org/package/destroy 49 | [github-tag]: http://img.shields.io/github/tag/stream-utils/destroy.svg?style=flat-square 50 | [github-url]: https://github.com/stream-utils/destroy/tags 51 | [travis-image]: https://img.shields.io/travis/stream-utils/destroy.svg?style=flat-square 52 | [travis-url]: https://travis-ci.org/stream-utils/destroy 53 | [coveralls-image]: https://img.shields.io/coveralls/stream-utils/destroy.svg?style=flat-square 54 | [coveralls-url]: https://coveralls.io/r/stream-utils/destroy?branch=master 55 | [license-image]: http://img.shields.io/npm/l/destroy.svg?style=flat-square 56 | [license-url]: LICENSE.md 57 | [downloads-image]: http://img.shields.io/npm/dm/destroy.svg?style=flat-square 58 | [downloads-url]: https://npmjs.org/package/destroy 59 | [gittip-image]: https://img.shields.io/gittip/jonathanong.svg?style=flat-square 60 | [gittip-url]: https://www.gittip.com/jonathanong/ 61 | -------------------------------------------------------------------------------- /deploy/node_modules/finalhandler/HISTORY.md: -------------------------------------------------------------------------------- 1 | 0.4.1 / 2015-12-02 2 | ================== 3 | 4 | * deps: escape-html@~1.0.3 5 | - perf: enable strict mode 6 | - perf: optimize string replacement 7 | - perf: use faster string coercion 8 | 9 | 0.4.0 / 2015-06-14 10 | ================== 11 | 12 | * Fix a false-positive when unpiping in Node.js 0.8 13 | * Support `statusCode` property on `Error` objects 14 | * Use `unpipe` module for unpiping requests 15 | * deps: escape-html@1.0.2 16 | * deps: on-finished@~2.3.0 17 | - Add defined behavior for HTTP `CONNECT` requests 18 | - Add defined behavior for HTTP `Upgrade` requests 19 | - deps: ee-first@1.1.1 20 | * perf: enable strict mode 21 | * perf: remove argument reassignment 22 | 23 | 0.3.6 / 2015-05-11 24 | ================== 25 | 26 | * deps: debug@~2.2.0 27 | - deps: ms@0.7.1 28 | 29 | 0.3.5 / 2015-04-22 30 | ================== 31 | 32 | * deps: on-finished@~2.2.1 33 | - Fix `isFinished(req)` when data buffered 34 | 35 | 0.3.4 / 2015-03-15 36 | ================== 37 | 38 | * deps: debug@~2.1.3 39 | - Fix high intensity foreground color for bold 40 | - deps: ms@0.7.0 41 | 42 | 0.3.3 / 2015-01-01 43 | ================== 44 | 45 | * deps: debug@~2.1.1 46 | * deps: on-finished@~2.2.0 47 | 48 | 0.3.2 / 2014-10-22 49 | ================== 50 | 51 | * deps: on-finished@~2.1.1 52 | - Fix handling of pipelined requests 53 | 54 | 0.3.1 / 2014-10-16 55 | ================== 56 | 57 | * deps: debug@~2.1.0 58 | - Implement `DEBUG_FD` env variable support 59 | 60 | 0.3.0 / 2014-09-17 61 | ================== 62 | 63 | * Terminate in progress response only on error 64 | * Use `on-finished` to determine request status 65 | 66 | 0.2.0 / 2014-09-03 67 | ================== 68 | 69 | * Set `X-Content-Type-Options: nosniff` header 70 | * deps: debug@~2.0.0 71 | 72 | 0.1.0 / 2014-07-16 73 | ================== 74 | 75 | * Respond after request fully read 76 | - prevents hung responses and socket hang ups 77 | * deps: debug@1.0.4 78 | 79 | 0.0.3 / 2014-07-11 80 | ================== 81 | 82 | * deps: debug@1.0.3 83 | - Add support for multiple wildcards in namespaces 84 | 85 | 0.0.2 / 2014-06-19 86 | ================== 87 | 88 | * Handle invalid status codes 89 | 90 | 0.0.1 / 2014-06-05 91 | ================== 92 | 93 | * deps: debug@1.0.2 94 | 95 | 0.0.0 / 2014-06-05 96 | ================== 97 | 98 | * Extracted from connect/express 99 | -------------------------------------------------------------------------------- /deploy/node_modules/mime/README.md: -------------------------------------------------------------------------------- 1 | # mime 2 | 3 | Comprehensive MIME type mapping API based on mime-db module. 4 | 5 | ## Install 6 | 7 | Install with [npm](http://github.com/isaacs/npm): 8 | 9 | npm install mime 10 | 11 | ## Contributing / Testing 12 | 13 | npm run test 14 | 15 | ## Command Line 16 | 17 | mime [path_string] 18 | 19 | E.g. 20 | 21 | > mime scripts/jquery.js 22 | application/javascript 23 | 24 | ## API - Queries 25 | 26 | ### mime.lookup(path) 27 | 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. 28 | 29 | ```js 30 | var mime = require('mime'); 31 | 32 | mime.lookup('/path/to/file.txt'); // => 'text/plain' 33 | mime.lookup('file.txt'); // => 'text/plain' 34 | mime.lookup('.TXT'); // => 'text/plain' 35 | mime.lookup('htm'); // => 'text/html' 36 | ``` 37 | 38 | ### mime.default_type 39 | Sets the mime type returned when `mime.lookup` fails to find the extension searched for. (Default is `application/octet-stream`.) 40 | 41 | ### mime.extension(type) 42 | Get the default extension for `type` 43 | 44 | ```js 45 | mime.extension('text/html'); // => 'html' 46 | mime.extension('application/octet-stream'); // => 'bin' 47 | ``` 48 | 49 | ### mime.charsets.lookup() 50 | 51 | Map mime-type to charset 52 | 53 | ```js 54 | mime.charsets.lookup('text/plain'); // => 'UTF-8' 55 | ``` 56 | 57 | (The logic for charset lookups is pretty rudimentary. Feel free to suggest improvements.) 58 | 59 | ## API - Defining Custom Types 60 | 61 | Custom type mappings can be added on a per-project basis via the following APIs. 62 | 63 | ### mime.define() 64 | 65 | Add custom mime/extension mappings 66 | 67 | ```js 68 | mime.define({ 69 | 'text/x-some-format': ['x-sf', 'x-sft', 'x-sfml'], 70 | 'application/x-my-type': ['x-mt', 'x-mtt'], 71 | // etc ... 72 | }); 73 | 74 | mime.lookup('x-sft'); // => 'text/x-some-format' 75 | ``` 76 | 77 | The first entry in the extensions array is returned by `mime.extension()`. E.g. 78 | 79 | ```js 80 | mime.extension('text/x-some-format'); // => 'x-sf' 81 | ``` 82 | 83 | ### mime.load(filepath) 84 | 85 | Load mappings from an Apache ".types" format file 86 | 87 | ```js 88 | mime.load('./my_project.types'); 89 | ``` 90 | The .types file format is simple - See the `types` dir for examples. 91 | -------------------------------------------------------------------------------- /deploy/node_modules/express/lib/express.js: -------------------------------------------------------------------------------- 1 | /*! 2 | * express 3 | * Copyright(c) 2009-2013 TJ Holowaychuk 4 | * Copyright(c) 2013 Roman Shtylman 5 | * Copyright(c) 2014-2015 Douglas Christopher Wilson 6 | * MIT Licensed 7 | */ 8 | 9 | 'use strict'; 10 | 11 | /** 12 | * Module dependencies. 13 | */ 14 | 15 | var EventEmitter = require('events').EventEmitter; 16 | var mixin = require('merge-descriptors'); 17 | var proto = require('./application'); 18 | var Route = require('./router/route'); 19 | var Router = require('./router'); 20 | var req = require('./request'); 21 | var res = require('./response'); 22 | 23 | /** 24 | * Expose `createApplication()`. 25 | */ 26 | 27 | exports = module.exports = createApplication; 28 | 29 | /** 30 | * Create an express application. 31 | * 32 | * @return {Function} 33 | * @api public 34 | */ 35 | 36 | function createApplication() { 37 | var app = function(req, res, next) { 38 | app.handle(req, res, next); 39 | }; 40 | 41 | mixin(app, EventEmitter.prototype, false); 42 | mixin(app, proto, false); 43 | 44 | app.request = { __proto__: req, app: app }; 45 | app.response = { __proto__: res, app: app }; 46 | app.init(); 47 | return app; 48 | } 49 | 50 | /** 51 | * Expose the prototypes. 52 | */ 53 | 54 | exports.application = proto; 55 | exports.request = req; 56 | exports.response = res; 57 | 58 | /** 59 | * Expose constructors. 60 | */ 61 | 62 | exports.Route = Route; 63 | exports.Router = Router; 64 | 65 | /** 66 | * Expose middleware 67 | */ 68 | 69 | exports.query = require('./middleware/query'); 70 | exports.static = require('serve-static'); 71 | 72 | /** 73 | * Replace removed middleware with an appropriate error message. 74 | */ 75 | 76 | [ 77 | 'json', 78 | 'urlencoded', 79 | 'bodyParser', 80 | 'compress', 81 | 'cookieSession', 82 | 'session', 83 | 'logger', 84 | 'cookieParser', 85 | 'favicon', 86 | 'responseTime', 87 | 'errorHandler', 88 | 'timeout', 89 | 'methodOverride', 90 | 'vhost', 91 | 'csrf', 92 | 'directory', 93 | 'limit', 94 | 'multipart', 95 | 'staticCache', 96 | ].forEach(function (name) { 97 | Object.defineProperty(exports, name, { 98 | get: function () { 99 | 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.'); 100 | }, 101 | configurable: true 102 | }); 103 | }); 104 | -------------------------------------------------------------------------------- /lib/material.css: -------------------------------------------------------------------------------- 1 | /* 2 | 3 | Name: material 4 | Author: Michael Kaminsky (http://github.com/mkaminsky11) 5 | 6 | Original material color scheme by Mattia Astorino (https://github.com/equinusocio/material-theme) 7 | 8 | */ 9 | 10 | .cm-s-material { 11 | background-color: #263238; 12 | color: rgba(233, 237, 237, 1); 13 | } 14 | .cm-s-material .CodeMirror-gutters { 15 | background: #263238; 16 | color: rgb(83,127,126); 17 | border: none; 18 | } 19 | .cm-s-material .CodeMirror-guttermarker, .cm-s-material .CodeMirror-guttermarker-subtle, .cm-s-material .CodeMirror-linenumber { color: rgb(83,127,126); } 20 | .cm-s-material .CodeMirror-cursor { border-left: 1px solid #f8f8f0; } 21 | .cm-s-material div.CodeMirror-selected { background: rgba(255, 255, 255, 0.15); } 22 | .cm-s-material.CodeMirror-focused div.CodeMirror-selected { background: rgba(255, 255, 255, 0.10); } 23 | .cm-s-material .CodeMirror-line::selection, .cm-s-material .CodeMirror-line > span::selection, .cm-s-material .CodeMirror-line > span > span::selection { background: rgba(255, 255, 255, 0.10); } 24 | .cm-s-material .CodeMirror-line::-moz-selection, .cm-s-material .CodeMirror-line > span::-moz-selection, .cm-s-material .CodeMirror-line > span > span::-moz-selection { background: rgba(255, 255, 255, 0.10); } 25 | 26 | .cm-s-material .CodeMirror-activeline-background { background: rgba(0, 0, 0, 0); } 27 | .cm-s-material .cm-keyword { color: rgba(199, 146, 234, 1); } 28 | .cm-s-material .cm-operator { color: rgba(233, 237, 237, 1); } 29 | .cm-s-material .cm-variable-2 { color: #80CBC4; } 30 | .cm-s-material .cm-variable-3 { color: #82B1FF; } 31 | .cm-s-material .cm-builtin { color: #DECB6B; } 32 | .cm-s-material .cm-atom { color: #F77669; } 33 | .cm-s-material .cm-number { color: #F77669; } 34 | .cm-s-material .cm-def { color: rgba(233, 237, 237, 1); } 35 | .cm-s-material .cm-string { color: #C3E88D; } 36 | .cm-s-material .cm-string-2 { color: #80CBC4; } 37 | .cm-s-material .cm-comment { color: #546E7A; } 38 | .cm-s-material .cm-variable { color: #82B1FF; } 39 | .cm-s-material .cm-tag { color: #80CBC4; } 40 | .cm-s-material .cm-meta { color: #80CBC4; } 41 | .cm-s-material .cm-attribute { color: #FFCB6B; } 42 | .cm-s-material .cm-property { color: #80CBAE; } 43 | .cm-s-material .cm-qualifier { color: #DECB6B; } 44 | .cm-s-material .cm-variable-3 { color: #DECB6B; } 45 | .cm-s-material .cm-tag { color: rgba(255, 83, 112, 1); } 46 | .cm-s-material .cm-error { 47 | color: rgba(255, 255, 255, 1.0); 48 | background-color: #EC5F67; 49 | } 50 | .cm-s-material .CodeMirror-matchingbracket { 51 | text-decoration: underline; 52 | color: white !important; 53 | } 54 | -------------------------------------------------------------------------------- /deploy/lib/material.css: -------------------------------------------------------------------------------- 1 | /* 2 | 3 | Name: material 4 | Author: Michael Kaminsky (http://github.com/mkaminsky11) 5 | 6 | Original material color scheme by Mattia Astorino (https://github.com/equinusocio/material-theme) 7 | 8 | */ 9 | 10 | .cm-s-material { 11 | background-color: #263238; 12 | color: rgba(233, 237, 237, 1); 13 | } 14 | .cm-s-material .CodeMirror-gutters { 15 | background: #263238; 16 | color: rgb(83,127,126); 17 | border: none; 18 | } 19 | .cm-s-material .CodeMirror-guttermarker, .cm-s-material .CodeMirror-guttermarker-subtle, .cm-s-material .CodeMirror-linenumber { color: rgb(83,127,126); } 20 | .cm-s-material .CodeMirror-cursor { border-left: 1px solid #f8f8f0; } 21 | .cm-s-material div.CodeMirror-selected { background: rgba(255, 255, 255, 0.15); } 22 | .cm-s-material.CodeMirror-focused div.CodeMirror-selected { background: rgba(255, 255, 255, 0.10); } 23 | .cm-s-material .CodeMirror-line::selection, .cm-s-material .CodeMirror-line > span::selection, .cm-s-material .CodeMirror-line > span > span::selection { background: rgba(255, 255, 255, 0.10); } 24 | .cm-s-material .CodeMirror-line::-moz-selection, .cm-s-material .CodeMirror-line > span::-moz-selection, .cm-s-material .CodeMirror-line > span > span::-moz-selection { background: rgba(255, 255, 255, 0.10); } 25 | 26 | .cm-s-material .CodeMirror-activeline-background { background: rgba(0, 0, 0, 0); } 27 | .cm-s-material .cm-keyword { color: rgba(199, 146, 234, 1); } 28 | .cm-s-material .cm-operator { color: rgba(233, 237, 237, 1); } 29 | .cm-s-material .cm-variable-2 { color: #80CBC4; } 30 | .cm-s-material .cm-variable-3 { color: #82B1FF; } 31 | .cm-s-material .cm-builtin { color: #DECB6B; } 32 | .cm-s-material .cm-atom { color: #F77669; } 33 | .cm-s-material .cm-number { color: #F77669; } 34 | .cm-s-material .cm-def { color: rgba(233, 237, 237, 1); } 35 | .cm-s-material .cm-string { color: #C3E88D; } 36 | .cm-s-material .cm-string-2 { color: #80CBC4; } 37 | .cm-s-material .cm-comment { color: #546E7A; } 38 | .cm-s-material .cm-variable { color: #82B1FF; } 39 | .cm-s-material .cm-tag { color: #80CBC4; } 40 | .cm-s-material .cm-meta { color: #80CBC4; } 41 | .cm-s-material .cm-attribute { color: #FFCB6B; } 42 | .cm-s-material .cm-property { color: #80CBAE; } 43 | .cm-s-material .cm-qualifier { color: #DECB6B; } 44 | .cm-s-material .cm-variable-3 { color: #DECB6B; } 45 | .cm-s-material .cm-tag { color: rgba(255, 83, 112, 1); } 46 | .cm-s-material .cm-error { 47 | color: rgba(255, 255, 255, 1.0); 48 | background-color: #EC5F67; 49 | } 50 | .cm-s-material .CodeMirror-matchingbracket { 51 | text-decoration: underline; 52 | color: white !important; 53 | } 54 | -------------------------------------------------------------------------------- /deploy/public/lib/material.css: -------------------------------------------------------------------------------- 1 | /* 2 | 3 | Name: material 4 | Author: Michael Kaminsky (http://github.com/mkaminsky11) 5 | 6 | Original material color scheme by Mattia Astorino (https://github.com/equinusocio/material-theme) 7 | 8 | */ 9 | 10 | .cm-s-material { 11 | background-color: #263238; 12 | color: rgba(233, 237, 237, 1); 13 | } 14 | .cm-s-material .CodeMirror-gutters { 15 | background: #263238; 16 | color: rgb(83,127,126); 17 | border: none; 18 | } 19 | .cm-s-material .CodeMirror-guttermarker, .cm-s-material .CodeMirror-guttermarker-subtle, .cm-s-material .CodeMirror-linenumber { color: rgb(83,127,126); } 20 | .cm-s-material .CodeMirror-cursor { border-left: 1px solid #f8f8f0; } 21 | .cm-s-material div.CodeMirror-selected { background: rgba(255, 255, 255, 0.15); } 22 | .cm-s-material.CodeMirror-focused div.CodeMirror-selected { background: rgba(255, 255, 255, 0.10); } 23 | .cm-s-material .CodeMirror-line::selection, .cm-s-material .CodeMirror-line > span::selection, .cm-s-material .CodeMirror-line > span > span::selection { background: rgba(255, 255, 255, 0.10); } 24 | .cm-s-material .CodeMirror-line::-moz-selection, .cm-s-material .CodeMirror-line > span::-moz-selection, .cm-s-material .CodeMirror-line > span > span::-moz-selection { background: rgba(255, 255, 255, 0.10); } 25 | 26 | .cm-s-material .CodeMirror-activeline-background { background: rgba(0, 0, 0, 0); } 27 | .cm-s-material .cm-keyword { color: rgba(199, 146, 234, 1); } 28 | .cm-s-material .cm-operator { color: rgba(233, 237, 237, 1); } 29 | .cm-s-material .cm-variable-2 { color: #80CBC4; } 30 | .cm-s-material .cm-variable-3 { color: #82B1FF; } 31 | .cm-s-material .cm-builtin { color: #DECB6B; } 32 | .cm-s-material .cm-atom { color: #F77669; } 33 | .cm-s-material .cm-number { color: #F77669; } 34 | .cm-s-material .cm-def { color: rgba(233, 237, 237, 1); } 35 | .cm-s-material .cm-string { color: #C3E88D; } 36 | .cm-s-material .cm-string-2 { color: #80CBC4; } 37 | .cm-s-material .cm-comment { color: #546E7A; } 38 | .cm-s-material .cm-variable { color: #82B1FF; } 39 | .cm-s-material .cm-tag { color: #80CBC4; } 40 | .cm-s-material .cm-meta { color: #80CBC4; } 41 | .cm-s-material .cm-attribute { color: #FFCB6B; } 42 | .cm-s-material .cm-property { color: #80CBAE; } 43 | .cm-s-material .cm-qualifier { color: #DECB6B; } 44 | .cm-s-material .cm-variable-3 { color: #DECB6B; } 45 | .cm-s-material .cm-tag { color: rgba(255, 83, 112, 1); } 46 | .cm-s-material .cm-error { 47 | color: rgba(255, 255, 255, 1.0); 48 | background-color: #EC5F67; 49 | } 50 | .cm-s-material .CodeMirror-matchingbracket { 51 | text-decoration: underline; 52 | color: white !important; 53 | } 54 | -------------------------------------------------------------------------------- /deploy/node_modules/qs/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "_args": [ 3 | [ 4 | { 5 | "raw": "qs@4.0.0", 6 | "scope": null, 7 | "escapedName": "qs", 8 | "name": "qs", 9 | "rawSpec": "4.0.0", 10 | "spec": "4.0.0", 11 | "type": "version" 12 | }, 13 | "/Users/swapnilmishra/Documents/github-repo/jsbin-jsfiddle/deploy/node_modules/express" 14 | ] 15 | ], 16 | "_from": "qs@4.0.0", 17 | "_id": "qs@4.0.0", 18 | "_inCache": true, 19 | "_installable": true, 20 | "_location": "/qs", 21 | "_nodeVersion": "0.12.4", 22 | "_npmUser": { 23 | "name": "nlf", 24 | "email": "quitlahok@gmail.com" 25 | }, 26 | "_npmVersion": "2.12.0", 27 | "_phantomChildren": {}, 28 | "_requested": { 29 | "raw": "qs@4.0.0", 30 | "scope": null, 31 | "escapedName": "qs", 32 | "name": "qs", 33 | "rawSpec": "4.0.0", 34 | "spec": "4.0.0", 35 | "type": "version" 36 | }, 37 | "_requiredBy": [ 38 | "/express" 39 | ], 40 | "_resolved": "https://registry.npmjs.org/qs/-/qs-4.0.0.tgz", 41 | "_shasum": "c31d9b74ec27df75e543a86c78728ed8d4623607", 42 | "_shrinkwrap": null, 43 | "_spec": "qs@4.0.0", 44 | "_where": "/Users/swapnilmishra/Documents/github-repo/jsbin-jsfiddle/deploy/node_modules/express", 45 | "bugs": { 46 | "url": "https://github.com/hapijs/qs/issues" 47 | }, 48 | "dependencies": {}, 49 | "description": "A querystring parser that supports nesting and arrays, with a depth limit", 50 | "devDependencies": { 51 | "browserify": "^10.2.1", 52 | "code": "1.x.x", 53 | "lab": "5.x.x" 54 | }, 55 | "directories": {}, 56 | "dist": { 57 | "shasum": "c31d9b74ec27df75e543a86c78728ed8d4623607", 58 | "tarball": "https://registry.npmjs.org/qs/-/qs-4.0.0.tgz" 59 | }, 60 | "gitHead": "e573dd08eae6cce30d2202704691a102dfa3782a", 61 | "homepage": "https://github.com/hapijs/qs", 62 | "keywords": [ 63 | "querystring", 64 | "qs" 65 | ], 66 | "license": "BSD-3-Clause", 67 | "main": "lib/index.js", 68 | "maintainers": [ 69 | { 70 | "name": "nlf", 71 | "email": "quitlahok@gmail.com" 72 | }, 73 | { 74 | "name": "hueniverse", 75 | "email": "eran@hueniverse.com" 76 | } 77 | ], 78 | "name": "qs", 79 | "optionalDependencies": {}, 80 | "readme": "ERROR: No README data found!", 81 | "repository": { 82 | "type": "git", 83 | "url": "git+https://github.com/hapijs/qs.git" 84 | }, 85 | "scripts": { 86 | "dist": "browserify --standalone Qs lib/index.js > dist/qs.js", 87 | "test": "lab -a code -t 100 -L", 88 | "test-cov-html": "lab -a code -r html -o coverage.html" 89 | }, 90 | "version": "4.0.0" 91 | } 92 | -------------------------------------------------------------------------------- /deploy/node_modules/media-typer/README.md: -------------------------------------------------------------------------------- 1 | # media-typer 2 | 3 | [![NPM Version][npm-image]][npm-url] 4 | [![NPM Downloads][downloads-image]][downloads-url] 5 | [![Node.js Version][node-version-image]][node-version-url] 6 | [![Build Status][travis-image]][travis-url] 7 | [![Test Coverage][coveralls-image]][coveralls-url] 8 | 9 | Simple RFC 6838 media type parser 10 | 11 | ## Installation 12 | 13 | ```sh 14 | $ npm install media-typer 15 | ``` 16 | 17 | ## API 18 | 19 | ```js 20 | var typer = require('media-typer') 21 | ``` 22 | 23 | ### typer.parse(string) 24 | 25 | ```js 26 | var obj = typer.parse('image/svg+xml; charset=utf-8') 27 | ``` 28 | 29 | Parse a media type string. This will return an object with the following 30 | properties (examples are shown for the string `'image/svg+xml; charset=utf-8'`): 31 | 32 | - `type`: The type of the media type (always lower case). Example: `'image'` 33 | 34 | - `subtype`: The subtype of the media type (always lower case). Example: `'svg'` 35 | 36 | - `suffix`: The suffix of the media type (always lower case). Example: `'xml'` 37 | 38 | - `parameters`: An object of the parameters in the media type (name of parameter always lower case). Example: `{charset: 'utf-8'}` 39 | 40 | ### typer.parse(req) 41 | 42 | ```js 43 | var obj = typer.parse(req) 44 | ``` 45 | 46 | Parse the `content-type` header from the given `req`. Short-cut for 47 | `typer.parse(req.headers['content-type'])`. 48 | 49 | ### typer.parse(res) 50 | 51 | ```js 52 | var obj = typer.parse(res) 53 | ``` 54 | 55 | Parse the `content-type` header set on the given `res`. Short-cut for 56 | `typer.parse(res.getHeader('content-type'))`. 57 | 58 | ### typer.format(obj) 59 | 60 | ```js 61 | var obj = typer.format({type: 'image', subtype: 'svg', suffix: 'xml'}) 62 | ``` 63 | 64 | Format an object into a media type string. This will return a string of the 65 | mime type for the given object. For the properties of the object, see the 66 | documentation for `typer.parse(string)`. 67 | 68 | ## License 69 | 70 | [MIT](LICENSE) 71 | 72 | [npm-image]: https://img.shields.io/npm/v/media-typer.svg?style=flat 73 | [npm-url]: https://npmjs.org/package/media-typer 74 | [node-version-image]: https://img.shields.io/badge/node.js-%3E%3D_0.6-brightgreen.svg?style=flat 75 | [node-version-url]: http://nodejs.org/download/ 76 | [travis-image]: https://img.shields.io/travis/jshttp/media-typer.svg?style=flat 77 | [travis-url]: https://travis-ci.org/jshttp/media-typer 78 | [coveralls-image]: https://img.shields.io/coveralls/jshttp/media-typer.svg?style=flat 79 | [coveralls-url]: https://coveralls.io/r/jshttp/media-typer 80 | [downloads-image]: https://img.shields.io/npm/dm/media-typer.svg?style=flat 81 | [downloads-url]: https://npmjs.org/package/media-typer 82 | -------------------------------------------------------------------------------- /deploy/node_modules/vary/README.md: -------------------------------------------------------------------------------- 1 | # vary 2 | 3 | [![NPM Version][npm-image]][npm-url] 4 | [![NPM Downloads][downloads-image]][downloads-url] 5 | [![Node.js Version][node-version-image]][node-version-url] 6 | [![Build Status][travis-image]][travis-url] 7 | [![Test Coverage][coveralls-image]][coveralls-url] 8 | 9 | Manipulate the HTTP Vary header 10 | 11 | ## Installation 12 | 13 | ```sh 14 | $ npm install vary 15 | ``` 16 | 17 | ## API 18 | 19 | ```js 20 | var vary = require('vary') 21 | ``` 22 | 23 | ### vary(res, field) 24 | 25 | Adds the given header `field` to the `Vary` response header of `res`. 26 | This can be a string of a single field, a string of a valid `Vary` 27 | header, or an array of multiple fields. 28 | 29 | This will append the header if not already listed, otherwise leaves 30 | it listed in the current location. 31 | 32 | ```js 33 | // Append "Origin" to the Vary header of the response 34 | vary(res, 'Origin') 35 | ``` 36 | 37 | ### vary.append(header, field) 38 | 39 | Adds the given header `field` to the `Vary` response header string `header`. 40 | This can be a string of a single field, a string of a valid `Vary` header, 41 | or an array of multiple fields. 42 | 43 | This will append the header if not already listed, otherwise leaves 44 | it listed in the current location. The new header string is returned. 45 | 46 | ```js 47 | // Get header string appending "Origin" to "Accept, User-Agent" 48 | vary.append('Accept, User-Agent', 'Origin') 49 | ``` 50 | 51 | ## Examples 52 | 53 | ### Updating the Vary header when content is based on it 54 | 55 | ```js 56 | var http = require('http') 57 | var vary = require('vary') 58 | 59 | http.createServer(function onRequest(req, res) { 60 | // about to user-agent sniff 61 | vary(res, 'User-Agent') 62 | 63 | var ua = req.headers['user-agent'] || '' 64 | var isMobile = /mobi|android|touch|mini/i.test(ua) 65 | 66 | // serve site, depending on isMobile 67 | res.setHeader('Content-Type', 'text/html') 68 | res.end('You are (probably) ' + (isMobile ? '' : 'not ') + 'a mobile user') 69 | }) 70 | ``` 71 | 72 | ## Testing 73 | 74 | ```sh 75 | $ npm test 76 | ``` 77 | 78 | ## License 79 | 80 | [MIT](LICENSE) 81 | 82 | [npm-image]: https://img.shields.io/npm/v/vary.svg 83 | [npm-url]: https://npmjs.org/package/vary 84 | [node-version-image]: https://img.shields.io/node/v/vary.svg 85 | [node-version-url]: http://nodejs.org/download/ 86 | [travis-image]: https://img.shields.io/travis/jshttp/vary/master.svg 87 | [travis-url]: https://travis-ci.org/jshttp/vary 88 | [coveralls-image]: https://img.shields.io/coveralls/jshttp/vary/master.svg 89 | [coveralls-url]: https://coveralls.io/r/jshttp/vary 90 | [downloads-image]: https://img.shields.io/npm/dm/vary.svg 91 | [downloads-url]: https://npmjs.org/package/vary 92 | -------------------------------------------------------------------------------- /deploy/node_modules/ipaddr.js/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "_args": [ 3 | [ 4 | { 5 | "raw": "ipaddr.js@1.0.5", 6 | "scope": null, 7 | "escapedName": "ipaddr.js", 8 | "name": "ipaddr.js", 9 | "rawSpec": "1.0.5", 10 | "spec": "1.0.5", 11 | "type": "version" 12 | }, 13 | "/Users/swapnilmishra/Documents/github-repo/jsbin-jsfiddle/deploy/node_modules/proxy-addr" 14 | ] 15 | ], 16 | "_from": "ipaddr.js@1.0.5", 17 | "_id": "ipaddr.js@1.0.5", 18 | "_inCache": true, 19 | "_installable": true, 20 | "_location": "/ipaddr.js", 21 | "_npmUser": { 22 | "name": "whitequark", 23 | "email": "whitequark@whitequark.org" 24 | }, 25 | "_npmVersion": "1.4.21", 26 | "_phantomChildren": {}, 27 | "_requested": { 28 | "raw": "ipaddr.js@1.0.5", 29 | "scope": null, 30 | "escapedName": "ipaddr.js", 31 | "name": "ipaddr.js", 32 | "rawSpec": "1.0.5", 33 | "spec": "1.0.5", 34 | "type": "version" 35 | }, 36 | "_requiredBy": [ 37 | "/proxy-addr" 38 | ], 39 | "_resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.0.5.tgz", 40 | "_shasum": "5fa78cf301b825c78abc3042d812723049ea23c7", 41 | "_shrinkwrap": null, 42 | "_spec": "ipaddr.js@1.0.5", 43 | "_where": "/Users/swapnilmishra/Documents/github-repo/jsbin-jsfiddle/deploy/node_modules/proxy-addr", 44 | "author": { 45 | "name": "whitequark", 46 | "email": "whitequark@whitequark.org" 47 | }, 48 | "bugs": { 49 | "url": "https://github.com/whitequark/ipaddr.js/issues" 50 | }, 51 | "dependencies": {}, 52 | "description": "A library for manipulating IPv4 and IPv6 addresses in JavaScript.", 53 | "devDependencies": { 54 | "coffee-script": "~1.6", 55 | "nodeunit": ">=0.8.2 <0.8.7", 56 | "uglify-js": "latest" 57 | }, 58 | "directories": { 59 | "lib": "./lib" 60 | }, 61 | "dist": { 62 | "shasum": "5fa78cf301b825c78abc3042d812723049ea23c7", 63 | "tarball": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.0.5.tgz" 64 | }, 65 | "engines": { 66 | "node": ">= 0.10" 67 | }, 68 | "gitHead": "46438c8bfa187505b7007a277f09a4a9e73d5686", 69 | "homepage": "https://github.com/whitequark/ipaddr.js#readme", 70 | "keywords": [ 71 | "ip", 72 | "ipv4", 73 | "ipv6" 74 | ], 75 | "license": "MIT", 76 | "main": "./lib/ipaddr", 77 | "maintainers": [ 78 | { 79 | "name": "whitequark", 80 | "email": "whitequark@whitequark.org" 81 | } 82 | ], 83 | "name": "ipaddr.js", 84 | "optionalDependencies": {}, 85 | "readme": "ERROR: No README data found!", 86 | "repository": { 87 | "type": "git", 88 | "url": "git://github.com/whitequark/ipaddr.js.git" 89 | }, 90 | "scripts": { 91 | "test": "cake build test" 92 | }, 93 | "version": "1.0.5" 94 | } 95 | -------------------------------------------------------------------------------- /deploy/node_modules/depd/lib/compat/callsite-tostring.js: -------------------------------------------------------------------------------- 1 | /*! 2 | * depd 3 | * Copyright(c) 2014 Douglas Christopher Wilson 4 | * MIT Licensed 5 | */ 6 | 7 | 'use strict' 8 | 9 | /** 10 | * Module exports. 11 | */ 12 | 13 | module.exports = callSiteToString 14 | 15 | /** 16 | * Format a CallSite file location to a string. 17 | */ 18 | 19 | function callSiteFileLocation(callSite) { 20 | var fileName 21 | var fileLocation = '' 22 | 23 | if (callSite.isNative()) { 24 | fileLocation = 'native' 25 | } else if (callSite.isEval()) { 26 | fileName = callSite.getScriptNameOrSourceURL() 27 | if (!fileName) { 28 | fileLocation = callSite.getEvalOrigin() 29 | } 30 | } else { 31 | fileName = callSite.getFileName() 32 | } 33 | 34 | if (fileName) { 35 | fileLocation += fileName 36 | 37 | var lineNumber = callSite.getLineNumber() 38 | if (lineNumber != null) { 39 | fileLocation += ':' + lineNumber 40 | 41 | var columnNumber = callSite.getColumnNumber() 42 | if (columnNumber) { 43 | fileLocation += ':' + columnNumber 44 | } 45 | } 46 | } 47 | 48 | return fileLocation || 'unknown source' 49 | } 50 | 51 | /** 52 | * Format a CallSite to a string. 53 | */ 54 | 55 | function callSiteToString(callSite) { 56 | var addSuffix = true 57 | var fileLocation = callSiteFileLocation(callSite) 58 | var functionName = callSite.getFunctionName() 59 | var isConstructor = callSite.isConstructor() 60 | var isMethodCall = !(callSite.isToplevel() || isConstructor) 61 | var line = '' 62 | 63 | if (isMethodCall) { 64 | var methodName = callSite.getMethodName() 65 | var typeName = getConstructorName(callSite) 66 | 67 | if (functionName) { 68 | if (typeName && functionName.indexOf(typeName) !== 0) { 69 | line += typeName + '.' 70 | } 71 | 72 | line += functionName 73 | 74 | if (methodName && functionName.lastIndexOf('.' + methodName) !== functionName.length - methodName.length - 1) { 75 | line += ' [as ' + methodName + ']' 76 | } 77 | } else { 78 | line += typeName + '.' + (methodName || '') 79 | } 80 | } else if (isConstructor) { 81 | line += 'new ' + (functionName || '') 82 | } else if (functionName) { 83 | line += functionName 84 | } else { 85 | addSuffix = false 86 | line += fileLocation 87 | } 88 | 89 | if (addSuffix) { 90 | line += ' (' + fileLocation + ')' 91 | } 92 | 93 | return line 94 | } 95 | 96 | /** 97 | * Get constructor name of reviver. 98 | */ 99 | 100 | function getConstructorName(obj) { 101 | var receiver = obj.receiver 102 | return (receiver.constructor && receiver.constructor.name) || null 103 | } 104 | -------------------------------------------------------------------------------- /deploy/node_modules/utils-merge/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "_args": [ 3 | [ 4 | { 5 | "raw": "utils-merge@1.0.0", 6 | "scope": null, 7 | "escapedName": "utils-merge", 8 | "name": "utils-merge", 9 | "rawSpec": "1.0.0", 10 | "spec": "1.0.0", 11 | "type": "version" 12 | }, 13 | "/Users/swapnilmishra/Documents/github-repo/jsbin-jsfiddle/deploy/node_modules/express" 14 | ] 15 | ], 16 | "_from": "utils-merge@1.0.0", 17 | "_id": "utils-merge@1.0.0", 18 | "_inCache": true, 19 | "_installable": true, 20 | "_location": "/utils-merge", 21 | "_npmUser": { 22 | "name": "jaredhanson", 23 | "email": "jaredhanson@gmail.com" 24 | }, 25 | "_npmVersion": "1.2.25", 26 | "_phantomChildren": {}, 27 | "_requested": { 28 | "raw": "utils-merge@1.0.0", 29 | "scope": null, 30 | "escapedName": "utils-merge", 31 | "name": "utils-merge", 32 | "rawSpec": "1.0.0", 33 | "spec": "1.0.0", 34 | "type": "version" 35 | }, 36 | "_requiredBy": [ 37 | "/express" 38 | ], 39 | "_resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.0.tgz", 40 | "_shasum": "0294fb922bb9375153541c4f7096231f287c8af8", 41 | "_shrinkwrap": null, 42 | "_spec": "utils-merge@1.0.0", 43 | "_where": "/Users/swapnilmishra/Documents/github-repo/jsbin-jsfiddle/deploy/node_modules/express", 44 | "author": { 45 | "name": "Jared Hanson", 46 | "email": "jaredhanson@gmail.com", 47 | "url": "http://www.jaredhanson.net/" 48 | }, 49 | "bugs": { 50 | "url": "http://github.com/jaredhanson/utils-merge/issues" 51 | }, 52 | "dependencies": {}, 53 | "description": "merge() utility function", 54 | "devDependencies": { 55 | "chai": "1.x.x", 56 | "mocha": "1.x.x" 57 | }, 58 | "directories": {}, 59 | "dist": { 60 | "shasum": "0294fb922bb9375153541c4f7096231f287c8af8", 61 | "tarball": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.0.tgz" 62 | }, 63 | "engines": { 64 | "node": ">= 0.4.0" 65 | }, 66 | "homepage": "https://github.com/jaredhanson/utils-merge#readme", 67 | "keywords": [ 68 | "util" 69 | ], 70 | "licenses": [ 71 | { 72 | "type": "MIT", 73 | "url": "http://www.opensource.org/licenses/MIT" 74 | } 75 | ], 76 | "main": "./index", 77 | "maintainers": [ 78 | { 79 | "name": "jaredhanson", 80 | "email": "jaredhanson@gmail.com" 81 | } 82 | ], 83 | "name": "utils-merge", 84 | "optionalDependencies": {}, 85 | "readme": "ERROR: No README data found!", 86 | "repository": { 87 | "type": "git", 88 | "url": "git://github.com/jaredhanson/utils-merge.git" 89 | }, 90 | "scripts": { 91 | "test": "node_modules/.bin/mocha --reporter spec --require test/bootstrap/node test/*.test.js" 92 | }, 93 | "version": "1.0.0" 94 | } 95 | -------------------------------------------------------------------------------- /deploy/node_modules/vary/index.js: -------------------------------------------------------------------------------- 1 | /*! 2 | * vary 3 | * Copyright(c) 2014-2015 Douglas Christopher Wilson 4 | * MIT Licensed 5 | */ 6 | 7 | 'use strict'; 8 | 9 | /** 10 | * Module exports. 11 | */ 12 | 13 | module.exports = vary; 14 | module.exports.append = append; 15 | 16 | /** 17 | * Variables. 18 | */ 19 | 20 | var separators = /[\(\)<>@,;:\\"\/\[\]\?=\{\}\u0020\u0009]/; 21 | 22 | /** 23 | * Append a field to a vary header. 24 | * 25 | * @param {String} header 26 | * @param {String|Array} field 27 | * @return {String} 28 | * @api public 29 | */ 30 | 31 | function append(header, field) { 32 | if (typeof header !== 'string') { 33 | throw new TypeError('header argument is required'); 34 | } 35 | 36 | if (!field) { 37 | throw new TypeError('field argument is required'); 38 | } 39 | 40 | // get fields array 41 | var fields = !Array.isArray(field) 42 | ? parse(String(field)) 43 | : field; 44 | 45 | // assert on invalid fields 46 | for (var i = 0; i < fields.length; i++) { 47 | if (separators.test(fields[i])) { 48 | throw new TypeError('field argument contains an invalid header'); 49 | } 50 | } 51 | 52 | // existing, unspecified vary 53 | if (header === '*') { 54 | return header; 55 | } 56 | 57 | // enumerate current values 58 | var val = header; 59 | var vals = parse(header.toLowerCase()); 60 | 61 | // unspecified vary 62 | if (fields.indexOf('*') !== -1 || vals.indexOf('*') !== -1) { 63 | return '*'; 64 | } 65 | 66 | for (var i = 0; i < fields.length; i++) { 67 | var fld = fields[i].toLowerCase(); 68 | 69 | // append value (case-preserving) 70 | if (vals.indexOf(fld) === -1) { 71 | vals.push(fld); 72 | val = val 73 | ? val + ', ' + fields[i] 74 | : fields[i]; 75 | } 76 | } 77 | 78 | return val; 79 | } 80 | 81 | /** 82 | * Parse a vary header into an array. 83 | * 84 | * @param {String} header 85 | * @return {Array} 86 | * @api private 87 | */ 88 | 89 | function parse(header) { 90 | return header.trim().split(/ *, */); 91 | } 92 | 93 | /** 94 | * Mark that a request is varied on a header field. 95 | * 96 | * @param {Object} res 97 | * @param {String|Array} field 98 | * @api public 99 | */ 100 | 101 | function vary(res, field) { 102 | if (!res || !res.getHeader || !res.setHeader) { 103 | // quack quack 104 | throw new TypeError('res argument is required'); 105 | } 106 | 107 | // get existing header 108 | var val = res.getHeader('Vary') || '' 109 | var header = Array.isArray(val) 110 | ? val.join(', ') 111 | : String(val); 112 | 113 | // set new header 114 | if ((val = append(header, field))) { 115 | res.setHeader('Vary', val); 116 | } 117 | } 118 | -------------------------------------------------------------------------------- /deploy/node_modules/negotiator/lib/charset.js: -------------------------------------------------------------------------------- 1 | module.exports = preferredCharsets; 2 | preferredCharsets.preferredCharsets = preferredCharsets; 3 | 4 | function parseAcceptCharset(accept) { 5 | var accepts = accept.split(','); 6 | 7 | for (var i = 0, j = 0; i < accepts.length; i++) { 8 | var charset = parseCharset(accepts[i].trim(), i); 9 | 10 | if (charset) { 11 | accepts[j++] = charset; 12 | } 13 | } 14 | 15 | // trim accepts 16 | accepts.length = j; 17 | 18 | return accepts; 19 | } 20 | 21 | function parseCharset(s, i) { 22 | var match = s.match(/^\s*(\S+?)\s*(?:;(.*))?$/); 23 | if (!match) return null; 24 | 25 | var charset = match[1]; 26 | var q = 1; 27 | if (match[2]) { 28 | var params = match[2].split(';') 29 | for (var i = 0; i < params.length; i ++) { 30 | var p = params[i].trim().split('='); 31 | if (p[0] === 'q') { 32 | q = parseFloat(p[1]); 33 | break; 34 | } 35 | } 36 | } 37 | 38 | return { 39 | charset: charset, 40 | q: q, 41 | i: i 42 | }; 43 | } 44 | 45 | function getCharsetPriority(charset, accepted, index) { 46 | var priority = {o: -1, q: 0, s: 0}; 47 | 48 | for (var i = 0; i < accepted.length; i++) { 49 | var spec = specify(charset, accepted[i], index); 50 | 51 | if (spec && (priority.s - spec.s || priority.q - spec.q || priority.o - spec.o) < 0) { 52 | priority = spec; 53 | } 54 | } 55 | 56 | return priority; 57 | } 58 | 59 | function specify(charset, spec, index) { 60 | var s = 0; 61 | if(spec.charset.toLowerCase() === charset.toLowerCase()){ 62 | s |= 1; 63 | } else if (spec.charset !== '*' ) { 64 | return null 65 | } 66 | 67 | return { 68 | i: index, 69 | o: spec.i, 70 | q: spec.q, 71 | s: s 72 | } 73 | } 74 | 75 | function preferredCharsets(accept, provided) { 76 | // RFC 2616 sec 14.2: no header = * 77 | var accepts = parseAcceptCharset(accept === undefined ? '*' : accept || ''); 78 | 79 | if (!provided) { 80 | // sorted list of all charsets 81 | return accepts.filter(isQuality).sort(compareSpecs).map(function getCharset(spec) { 82 | return spec.charset; 83 | }); 84 | } 85 | 86 | var priorities = provided.map(function getPriority(type, index) { 87 | return getCharsetPriority(type, accepts, index); 88 | }); 89 | 90 | // sorted list of accepted charsets 91 | return priorities.filter(isQuality).sort(compareSpecs).map(function getCharset(priority) { 92 | return provided[priorities.indexOf(priority)]; 93 | }); 94 | } 95 | 96 | function compareSpecs(a, b) { 97 | return (b.q - a.q) || (b.s - a.s) || (a.o - b.o) || (a.i - b.i) || 0; 98 | } 99 | 100 | function isQuality(spec) { 101 | return spec.q > 0; 102 | } 103 | -------------------------------------------------------------------------------- /deploy/node_modules/escape-html/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "_args": [ 3 | [ 4 | { 5 | "raw": "escape-html@~1.0.3", 6 | "scope": null, 7 | "escapedName": "escape-html", 8 | "name": "escape-html", 9 | "rawSpec": "~1.0.3", 10 | "spec": ">=1.0.3 <1.1.0", 11 | "type": "range" 12 | }, 13 | "/Users/swapnilmishra/Documents/github-repo/jsbin-jsfiddle/deploy/node_modules/express" 14 | ] 15 | ], 16 | "_from": "escape-html@>=1.0.3 <1.1.0", 17 | "_id": "escape-html@1.0.3", 18 | "_inCache": true, 19 | "_installable": true, 20 | "_location": "/escape-html", 21 | "_npmUser": { 22 | "name": "dougwilson", 23 | "email": "doug@somethingdoug.com" 24 | }, 25 | "_npmVersion": "1.4.28", 26 | "_phantomChildren": {}, 27 | "_requested": { 28 | "raw": "escape-html@~1.0.3", 29 | "scope": null, 30 | "escapedName": "escape-html", 31 | "name": "escape-html", 32 | "rawSpec": "~1.0.3", 33 | "spec": ">=1.0.3 <1.1.0", 34 | "type": "range" 35 | }, 36 | "_requiredBy": [ 37 | "/express", 38 | "/finalhandler", 39 | "/send", 40 | "/serve-static", 41 | "/serve-static/send" 42 | ], 43 | "_resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 44 | "_shasum": "0258eae4d3d0c0974de1c169188ef0051d1d1988", 45 | "_shrinkwrap": null, 46 | "_spec": "escape-html@~1.0.3", 47 | "_where": "/Users/swapnilmishra/Documents/github-repo/jsbin-jsfiddle/deploy/node_modules/express", 48 | "bugs": { 49 | "url": "https://github.com/component/escape-html/issues" 50 | }, 51 | "dependencies": {}, 52 | "description": "Escape string for use in HTML", 53 | "devDependencies": { 54 | "beautify-benchmark": "0.2.4", 55 | "benchmark": "1.0.0" 56 | }, 57 | "directories": {}, 58 | "dist": { 59 | "shasum": "0258eae4d3d0c0974de1c169188ef0051d1d1988", 60 | "tarball": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz" 61 | }, 62 | "files": [ 63 | "LICENSE", 64 | "Readme.md", 65 | "index.js" 66 | ], 67 | "gitHead": "7ac2ea3977fcac3d4c5be8d2a037812820c65f28", 68 | "homepage": "https://github.com/component/escape-html", 69 | "keywords": [ 70 | "escape", 71 | "html", 72 | "utility" 73 | ], 74 | "license": "MIT", 75 | "maintainers": [ 76 | { 77 | "name": "tjholowaychuk", 78 | "email": "tj@vision-media.ca" 79 | }, 80 | { 81 | "name": "dougwilson", 82 | "email": "doug@somethingdoug.com" 83 | } 84 | ], 85 | "name": "escape-html", 86 | "optionalDependencies": {}, 87 | "readme": "ERROR: No README data found!", 88 | "repository": { 89 | "type": "git", 90 | "url": "git+https://github.com/component/escape-html.git" 91 | }, 92 | "scripts": { 93 | "bench": "node benchmark/index.js" 94 | }, 95 | "version": "1.0.3" 96 | } 97 | -------------------------------------------------------------------------------- /deploy/node_modules/cookie-signature/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "_args": [ 3 | [ 4 | { 5 | "raw": "cookie-signature@1.0.6", 6 | "scope": null, 7 | "escapedName": "cookie-signature", 8 | "name": "cookie-signature", 9 | "rawSpec": "1.0.6", 10 | "spec": "1.0.6", 11 | "type": "version" 12 | }, 13 | "/Users/swapnilmishra/Documents/github-repo/jsbin-jsfiddle/deploy/node_modules/express" 14 | ] 15 | ], 16 | "_from": "cookie-signature@1.0.6", 17 | "_id": "cookie-signature@1.0.6", 18 | "_inCache": true, 19 | "_installable": true, 20 | "_location": "/cookie-signature", 21 | "_nodeVersion": "0.10.36", 22 | "_npmUser": { 23 | "name": "natevw", 24 | "email": "natevw@yahoo.com" 25 | }, 26 | "_npmVersion": "2.3.0", 27 | "_phantomChildren": {}, 28 | "_requested": { 29 | "raw": "cookie-signature@1.0.6", 30 | "scope": null, 31 | "escapedName": "cookie-signature", 32 | "name": "cookie-signature", 33 | "rawSpec": "1.0.6", 34 | "spec": "1.0.6", 35 | "type": "version" 36 | }, 37 | "_requiredBy": [ 38 | "/express" 39 | ], 40 | "_resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 41 | "_shasum": "e303a882b342cc3ee8ca513a79999734dab3ae2c", 42 | "_shrinkwrap": null, 43 | "_spec": "cookie-signature@1.0.6", 44 | "_where": "/Users/swapnilmishra/Documents/github-repo/jsbin-jsfiddle/deploy/node_modules/express", 45 | "author": { 46 | "name": "TJ Holowaychuk", 47 | "email": "tj@learnboost.com" 48 | }, 49 | "bugs": { 50 | "url": "https://github.com/visionmedia/node-cookie-signature/issues" 51 | }, 52 | "dependencies": {}, 53 | "description": "Sign and unsign cookies", 54 | "devDependencies": { 55 | "mocha": "*", 56 | "should": "*" 57 | }, 58 | "directories": {}, 59 | "dist": { 60 | "shasum": "e303a882b342cc3ee8ca513a79999734dab3ae2c", 61 | "tarball": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz" 62 | }, 63 | "gitHead": "391b56cf44d88c493491b7e3fc53208cfb976d2a", 64 | "homepage": "https://github.com/visionmedia/node-cookie-signature", 65 | "keywords": [ 66 | "cookie", 67 | "sign", 68 | "unsign" 69 | ], 70 | "license": "MIT", 71 | "main": "index", 72 | "maintainers": [ 73 | { 74 | "name": "tjholowaychuk", 75 | "email": "tj@vision-media.ca" 76 | }, 77 | { 78 | "name": "natevw", 79 | "email": "natevw@yahoo.com" 80 | } 81 | ], 82 | "name": "cookie-signature", 83 | "optionalDependencies": {}, 84 | "readme": "ERROR: No README data found!", 85 | "repository": { 86 | "type": "git", 87 | "url": "git+https://github.com/visionmedia/node-cookie-signature.git" 88 | }, 89 | "scripts": { 90 | "test": "mocha --require should --reporter spec" 91 | }, 92 | "version": "1.0.6" 93 | } 94 | -------------------------------------------------------------------------------- /deploy/node_modules/inherits/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "_args": [ 3 | [ 4 | { 5 | "raw": "inherits@~2.0.1", 6 | "scope": null, 7 | "escapedName": "inherits", 8 | "name": "inherits", 9 | "rawSpec": "~2.0.1", 10 | "spec": ">=2.0.1 <2.1.0", 11 | "type": "range" 12 | }, 13 | "/Users/swapnilmishra/Documents/github-repo/jsbin-jsfiddle/deploy/node_modules/http-errors" 14 | ] 15 | ], 16 | "_from": "inherits@>=2.0.1 <2.1.0", 17 | "_id": "inherits@2.0.3", 18 | "_inCache": true, 19 | "_installable": true, 20 | "_location": "/inherits", 21 | "_nodeVersion": "6.5.0", 22 | "_npmOperationalInternal": { 23 | "host": "packages-16-east.internal.npmjs.com", 24 | "tmp": "tmp/inherits-2.0.3.tgz_1473295776489_0.08142363070510328" 25 | }, 26 | "_npmUser": { 27 | "name": "isaacs", 28 | "email": "i@izs.me" 29 | }, 30 | "_npmVersion": "3.10.7", 31 | "_phantomChildren": {}, 32 | "_requested": { 33 | "raw": "inherits@~2.0.1", 34 | "scope": null, 35 | "escapedName": "inherits", 36 | "name": "inherits", 37 | "rawSpec": "~2.0.1", 38 | "spec": ">=2.0.1 <2.1.0", 39 | "type": "range" 40 | }, 41 | "_requiredBy": [ 42 | "/http-errors" 43 | ], 44 | "_resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 45 | "_shasum": "633c2c83e3da42a502f52466022480f4208261de", 46 | "_shrinkwrap": null, 47 | "_spec": "inherits@~2.0.1", 48 | "_where": "/Users/swapnilmishra/Documents/github-repo/jsbin-jsfiddle/deploy/node_modules/http-errors", 49 | "browser": "./inherits_browser.js", 50 | "bugs": { 51 | "url": "https://github.com/isaacs/inherits/issues" 52 | }, 53 | "dependencies": {}, 54 | "description": "Browser-friendly inheritance fully compatible with standard node.js inherits()", 55 | "devDependencies": { 56 | "tap": "^7.1.0" 57 | }, 58 | "directories": {}, 59 | "dist": { 60 | "shasum": "633c2c83e3da42a502f52466022480f4208261de", 61 | "tarball": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz" 62 | }, 63 | "files": [ 64 | "inherits.js", 65 | "inherits_browser.js" 66 | ], 67 | "gitHead": "e05d0fb27c61a3ec687214f0476386b765364d5f", 68 | "homepage": "https://github.com/isaacs/inherits#readme", 69 | "keywords": [ 70 | "inheritance", 71 | "class", 72 | "klass", 73 | "oop", 74 | "object-oriented", 75 | "inherits", 76 | "browser", 77 | "browserify" 78 | ], 79 | "license": "ISC", 80 | "main": "./inherits.js", 81 | "maintainers": [ 82 | { 83 | "name": "isaacs", 84 | "email": "i@izs.me" 85 | } 86 | ], 87 | "name": "inherits", 88 | "optionalDependencies": {}, 89 | "readme": "ERROR: No README data found!", 90 | "repository": { 91 | "type": "git", 92 | "url": "git://github.com/isaacs/inherits.git" 93 | }, 94 | "scripts": { 95 | "test": "node test" 96 | }, 97 | "version": "2.0.3" 98 | } 99 | --------------------------------------------------------------------------------