├── .env.example ├── .gitignore ├── LICENSE ├── README.md ├── config.js ├── core ├── handlers │ └── http │ │ └── get │ │ └── proxy.js └── index.js ├── handlers └── http │ ├── get │ ├── user.js │ └── welcome.js │ └── post │ ├── authenticate.js │ └── user.js ├── middlewares ├── authenticate.js ├── authorize.js ├── config.js └── database.js ├── package-lock.json ├── package.json ├── public └── index.html ├── routes.json └── server.js /.env.example: -------------------------------------------------------------------------------- 1 | PORT=3001 2 | SECRET_KEY=secretkey 3 | DB_DRIVER=mongo 4 | MONGO_URL=mongodb://:@:/ -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | /node_modules 2 | .DS_Store 3 | .env -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | The MIT License (MIT) 2 | 3 | Copyright (c) 2018 Ind 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 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, 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 THE 21 | SOFTWARE. 22 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # Simple RESTful API Gateway 2 | 3 | JSON-based configurable RESTful API Gateway Project. 4 | 5 | You just need to update `routes.json` and put respective logics in `handles/http/` to enable the endpoint. If you need to add a new middleware, please put it in `middlewares` directory. 6 | 7 | > Follow the naming conventions properly. 8 | 9 | See examples here; 10 | 11 | **routes.json** 12 | 13 | ```json 14 | { 15 | "GET": [ 16 | { 17 | "path": "/", 18 | "type": "static", 19 | "entrypoint": "public/" 20 | }, 21 | { 22 | "path": "/api", 23 | "func": "welcome" 24 | }, 25 | { 26 | "path": "/api/user/:id", 27 | "middlewares": ["authorize", "database"], 28 | "func": "user" 29 | }, 30 | { 31 | "path": "/api/users", 32 | "type": "proxy", 33 | "endpoint": "https://jsonplaceholder.typicode.com/users" 34 | } 35 | ], 36 | "POST": [ 37 | { 38 | "path": "/auth", 39 | "middlewares": ["authenticate"], 40 | "func": "authenticate" 41 | }, 42 | { 43 | "path": "/api/user", 44 | "middlewares": ["authorize"], 45 | "func": "user" 46 | } 47 | ], 48 | "PUT": [], 49 | "DELETE": [] 50 | } 51 | ``` 52 | 53 | **handlers/http/get/user.js** 54 | 55 | ```js 56 | const user = (req, res) => { 57 | // Get database instance. 58 | const db = req.database; 59 | 60 | // Access application configs. 61 | const config = req.config; 62 | 63 | // params: id 64 | const userId = req.params.id; 65 | 66 | // TODO: Should get user info by id and return 67 | res.json({ message: `User data of ${userId}`, ...req.params }); 68 | }; 69 | 70 | module.exports = user; 71 | ``` 72 | 73 | **middlewares/authenticate.js** 74 | 75 | ```js 76 | // Mock data 77 | const user = { 78 | _id: 1, 79 | userName: "John Doe", 80 | email: "john.doe@example.com" 81 | }; 82 | 83 | const authenticate = (req, res, next) => { 84 | // TODO: Read headers to authenticate data 85 | // Ex- 86 | // const { headers } = req; 87 | // const userName = headers["user"]; 88 | // const pwd = headers["pwd"]; 89 | // const subscriptionToken = headers["subscriptionToken"]; 90 | 91 | // TODO: Verify user/token in the database and put it in the request if the user is veryfied. 92 | // Otherwise, reject. 93 | // Ex- 94 | // if (!verifiedUser) { 95 | // // Forbidden 96 | // res.status(403).send({ 97 | // status: { 98 | // code: 403, 99 | // message: "Forbidden" 100 | // } 101 | // }); 102 | // } 103 | 104 | // Putting the verified user object with the request 105 | req.user = user; 106 | 107 | next(); 108 | }; 109 | 110 | module.exports = authenticate; 111 | ``` 112 | -------------------------------------------------------------------------------- /config.js: -------------------------------------------------------------------------------- 1 | const path = require("path"); 2 | require("dotenv").config(); 3 | 4 | const config = { 5 | PORT: process.env.PORT, 6 | SECRET_KEY: process.env.SECRET_KEY, 7 | DB_DRIVER: process.env.DB_DRIVER, 8 | DB_CONNECTIONS: [ 9 | { 10 | driver: process.env.DB_DRIVER, 11 | url: process.env.MONGO_URL 12 | } 13 | ], 14 | API_CONFIG_PATH: path.join(__dirname, "routes.json"), 15 | HANDLER_PATH: path.join(__dirname, "handlers", "http"), 16 | CORE_HANDLER_PATH: path.join(__dirname, "core", "handlers", "http"), 17 | MIDDLEWARE_PATH: path.join(__dirname, "middlewares") 18 | }; 19 | 20 | module.exports = config; 21 | -------------------------------------------------------------------------------- /core/handlers/http/get/proxy.js: -------------------------------------------------------------------------------- 1 | const request = require("request"); 2 | 3 | const proxy = ({ endpoint }, req, res) => { 4 | request(endpoint, (error, response, body) => { 5 | const data = JSON.parse(body); 6 | res.json({ message: data, error }); 7 | }); 8 | }; 9 | 10 | module.exports = proxy; 11 | -------------------------------------------------------------------------------- /core/index.js: -------------------------------------------------------------------------------- 1 | // NOTE: Do not change this file unless you know exactly what you do. 2 | 3 | const fs = require("fs"); 4 | const path = require("path"); 5 | 6 | const { 7 | HANDLER_PATH, 8 | CORE_HANDLER_PATH, 9 | MIDDLEWARE_PATH, 10 | API_CONFIG_PATH 11 | } = require("../config"); 12 | 13 | const core = { 14 | getHandlers: () => { 15 | // Core: Fetch and return all http method signatures. 16 | const handlers = {}; 17 | fs.readdirSync(HANDLER_PATH) 18 | .map(dirOrFile => { 19 | if (fs.statSync(path.join(HANDLER_PATH, dirOrFile)).isDirectory()) 20 | return dirOrFile; 21 | }) 22 | .filter(dir => !!dir) 23 | .forEach(method => { 24 | handlers[method] = {}; 25 | fs.readdirSync(path.join(HANDLER_PATH, method)).forEach(fp => { 26 | const func = fp.split(".")[0]; 27 | handlers[method][func] = require(path.join(HANDLER_PATH, method, fp)); 28 | }); 29 | }); 30 | return handlers; 31 | }, 32 | 33 | getCoreHandlers: () => { 34 | const handlers = {}; 35 | fs.readdirSync(CORE_HANDLER_PATH) 36 | .map(dirOrFile => { 37 | if (fs.statSync(path.join(CORE_HANDLER_PATH, dirOrFile)).isDirectory()) 38 | return dirOrFile; 39 | }) 40 | .filter(dir => !!dir) 41 | .forEach(method => { 42 | handlers[method] = {}; 43 | fs.readdirSync(path.join(CORE_HANDLER_PATH, method)).forEach(fp => { 44 | const func = fp.split(".")[0]; 45 | handlers[method][func] = require(path.join( 46 | CORE_HANDLER_PATH, 47 | method, 48 | fp 49 | )); 50 | }); 51 | }); 52 | return handlers; 53 | }, 54 | 55 | getMiddlewares: () => { 56 | // Core: Fetch and return all middleware signatures. 57 | const middlewares = {}; 58 | fs.readdirSync(MIDDLEWARE_PATH).forEach(file => { 59 | const func = file.split(".")[0]; 60 | middlewares[func] = require(path.join(MIDDLEWARE_PATH, file)); 61 | }); 62 | return middlewares; 63 | }, 64 | 65 | getRouteConfigs: () => require(API_CONFIG_PATH) 66 | }; 67 | 68 | module.exports = core; 69 | -------------------------------------------------------------------------------- /handlers/http/get/user.js: -------------------------------------------------------------------------------- 1 | const user = (req, res) => { 2 | // params: id 3 | const userId = req.params.id; 4 | // TODO: Should get user info by id and return 5 | res.json({ message: `User data of ${userId}`, params: req.params }); 6 | }; 7 | 8 | module.exports = user; 9 | -------------------------------------------------------------------------------- /handlers/http/get/welcome.js: -------------------------------------------------------------------------------- 1 | const welcome = (req, res) => { 2 | res.json({ message: "Simple RESTful API Gateway." }); 3 | }; 4 | 5 | module.exports = welcome; 6 | -------------------------------------------------------------------------------- /handlers/http/post/authenticate.js: -------------------------------------------------------------------------------- 1 | const jwt = require("jsonwebtoken"); 2 | 3 | const authenticate = (req, res) => { 4 | const { SECRET_KEY } = req.config; 5 | const user = req.user; 6 | 7 | // jwt.sign({ user }, env.SECRET_KEY, { expiresIn: "30s" }, (err, token) => { 8 | jwt.sign({ user }, SECRET_KEY, (error, token) => { 9 | if (error) { 10 | // Forbidden 11 | res.status(403).send({ status: { code: 403, message: "Forbidden" } }); 12 | } 13 | 14 | res.json({ token }); 15 | }); 16 | }; 17 | 18 | module.exports = authenticate; 19 | -------------------------------------------------------------------------------- /handlers/http/post/user.js: -------------------------------------------------------------------------------- 1 | const user = (req, res) => { 2 | // TODO: Should get user data by reading req.body and create new user 3 | res.json({ 4 | message: `New user created.`, 5 | body: req.body 6 | }); 7 | }; 8 | 9 | module.exports = user; 10 | -------------------------------------------------------------------------------- /middlewares/authenticate.js: -------------------------------------------------------------------------------- 1 | // Mock data 2 | const user = { 3 | _id: 1, 4 | userName: "John Doe", 5 | email: "john.doe@example.com" 6 | }; 7 | 8 | const authenticate = (req, res, next) => { 9 | // TODO: Read headers to authenticate data 10 | // Ex- 11 | // const { headers } = req; 12 | // const userName = headers["user"]; 13 | // const pwd = headers["pwd"]; 14 | // const subscriptionToken = headers["subscriptionToken"]; 15 | 16 | // TODO: Verify user/token in the database and put it in the request if the user is veryfied. 17 | // Otherwise, reject. 18 | // Ex- 19 | // if (!verifiedUser) { 20 | // // Forbidden 21 | // res.status(403).send({ 22 | // status: { 23 | // code: 403, 24 | // message: "Forbidden" 25 | // } 26 | // }); 27 | // } 28 | 29 | // Putting the verified user object with the request 30 | req.user = user; 31 | 32 | next(); 33 | }; 34 | 35 | module.exports = authenticate; 36 | -------------------------------------------------------------------------------- /middlewares/authorize.js: -------------------------------------------------------------------------------- 1 | const jwt = require("jsonwebtoken"); 2 | 3 | const authorize = (req, res, next) => { 4 | // Format: Authorization: Bearer 5 | // Read header for bearerToken 6 | const authHeader = req.headers["authorization"]; 7 | if (typeof authHeader !== "undefined") { 8 | const bearerToken = authHeader.split(" ")[1]; 9 | 10 | // Verify bearerToken 11 | try { 12 | const { SECRET_KEY } = req.config; 13 | const authData = jwt.verify(bearerToken, SECRET_KEY); 14 | // TODO: Get decoded authData and verify it with the database 15 | // If user verified continue. 16 | // Otherwise, teject. 17 | // Ex- 18 | // if (!verifiedUser) { 19 | // // Forbidden 20 | // res.status(403).send({ 21 | // status: { 22 | // code: 403, 23 | // message: "Forbidden" 24 | // } 25 | // }); 26 | // } 27 | 28 | next(); 29 | } catch (error) { 30 | // Forbidden 31 | res.status(403).send({ 32 | status: { 33 | code: 403, 34 | message: "Forbidden" 35 | }, 36 | error 37 | }); 38 | } 39 | } else { 40 | // Forbidden 41 | res.status(403).send({ 42 | status: { 43 | code: 403, 44 | message: "Forbidden" 45 | } 46 | }); 47 | } 48 | }; 49 | 50 | module.exports = authorize; 51 | -------------------------------------------------------------------------------- /middlewares/config.js: -------------------------------------------------------------------------------- 1 | const config = require("../config"); 2 | 3 | module.exports = (req, res, next) => { 4 | req.config = config; 5 | next(); 6 | }; 7 | -------------------------------------------------------------------------------- /middlewares/database.js: -------------------------------------------------------------------------------- 1 | const mongoose = require("mongoose"); 2 | 3 | module.exports = (req, res, next) => { 4 | let database = null; 5 | const { DB_DRIVER, DB_CONNECTIONS } = req.config; 6 | 7 | if (DB_DRIVER && DB_CONNECTIONS) { 8 | // Currently MongoDB Support only. 9 | // TODO: Add other supports as well. 10 | switch (DB_DRIVER) { 11 | case "mongo": 12 | const mongoDb = DB_CONNECTIONS.find(d => d.driver === DB_DRIVER); 13 | mongoose.Promise = global.Promise; 14 | mongoose.connect(mongoDb.url); 15 | database = mongoose.connection; 16 | 17 | db.on("error", console.error.bind(console, "MongoDB error:")); 18 | db.once("open", () => console.log("Connected to MongoDB")); 19 | 20 | default: 21 | database = null; 22 | } 23 | } 24 | 25 | req.database = database; 26 | next(); 27 | }; 28 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "simple-restful-api-gateway", 3 | "version": "1.0.0", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "abbrev": { 8 | "version": "1.1.1", 9 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", 10 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==", 11 | "dev": true 12 | }, 13 | "accepts": { 14 | "version": "1.3.5", 15 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.5.tgz", 16 | "integrity": "sha1-63d99gEXI6OxTopywIBcjoZ0a9I=", 17 | "requires": { 18 | "mime-types": "~2.1.18", 19 | "negotiator": "0.6.1" 20 | } 21 | }, 22 | "ajv": { 23 | "version": "6.5.5", 24 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.5.5.tgz", 25 | "integrity": "sha512-7q7gtRQDJSyuEHjuVgHoUa2VuemFiCMrfQc9Tc08XTAc4Zj/5U1buQJ0HU6i7fKjXU09SVgSmxa4sLvuvS8Iyg==", 26 | "requires": { 27 | "fast-deep-equal": "^2.0.1", 28 | "fast-json-stable-stringify": "^2.0.0", 29 | "json-schema-traverse": "^0.4.1", 30 | "uri-js": "^4.2.2" 31 | } 32 | }, 33 | "ansi-align": { 34 | "version": "2.0.0", 35 | "resolved": "https://registry.npmjs.org/ansi-align/-/ansi-align-2.0.0.tgz", 36 | "integrity": "sha1-w2rsy6VjuJzrVW82kPCx2eNUf38=", 37 | "dev": true, 38 | "requires": { 39 | "string-width": "^2.0.0" 40 | } 41 | }, 42 | "ansi-regex": { 43 | "version": "3.0.0", 44 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", 45 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", 46 | "dev": true 47 | }, 48 | "ansi-styles": { 49 | "version": "3.2.1", 50 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 51 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 52 | "dev": true, 53 | "requires": { 54 | "color-convert": "^1.9.0" 55 | } 56 | }, 57 | "anymatch": { 58 | "version": "2.0.0", 59 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-2.0.0.tgz", 60 | "integrity": "sha512-5teOsQWABXHHBFP9y3skS5P3d/WfWXpv3FUpy+LorMrNYaT9pI4oLMQX7jzQ2KklNpGpWHzdCXTDT2Y3XGlZBw==", 61 | "dev": true, 62 | "requires": { 63 | "micromatch": "^3.1.4", 64 | "normalize-path": "^2.1.1" 65 | } 66 | }, 67 | "arr-diff": { 68 | "version": "4.0.0", 69 | "resolved": "https://registry.npmjs.org/arr-diff/-/arr-diff-4.0.0.tgz", 70 | "integrity": "sha1-1kYQdP6/7HHn4VI1dhoyml3HxSA=", 71 | "dev": true 72 | }, 73 | "arr-flatten": { 74 | "version": "1.1.0", 75 | "resolved": "https://registry.npmjs.org/arr-flatten/-/arr-flatten-1.1.0.tgz", 76 | "integrity": "sha512-L3hKV5R/p5o81R7O02IGnwpDmkp6E982XhtbuwSe3O4qOtMMMtodicASA1Cny2U+aCXcNpml+m4dPsvsJ3jatg==", 77 | "dev": true 78 | }, 79 | "arr-union": { 80 | "version": "3.1.0", 81 | "resolved": "https://registry.npmjs.org/arr-union/-/arr-union-3.1.0.tgz", 82 | "integrity": "sha1-45sJrqne+Gao8gbiiK9jkZuuOcQ=", 83 | "dev": true 84 | }, 85 | "array-flatten": { 86 | "version": "1.1.1", 87 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 88 | "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=" 89 | }, 90 | "array-unique": { 91 | "version": "0.3.2", 92 | "resolved": "https://registry.npmjs.org/array-unique/-/array-unique-0.3.2.tgz", 93 | "integrity": "sha1-qJS3XUvE9s1nnvMkSp/Y9Gri1Cg=", 94 | "dev": true 95 | }, 96 | "asn1": { 97 | "version": "0.2.4", 98 | "resolved": "https://registry.npmjs.org/asn1/-/asn1-0.2.4.tgz", 99 | "integrity": "sha512-jxwzQpLQjSmWXgwaCZE9Nz+glAG01yF1QnWgbhGwHI5A6FRIEY6IVqtHhIepHqI7/kyEyQEagBC5mBEFlIYvdg==", 100 | "requires": { 101 | "safer-buffer": "~2.1.0" 102 | } 103 | }, 104 | "assert-plus": { 105 | "version": "1.0.0", 106 | "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", 107 | "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=" 108 | }, 109 | "assign-symbols": { 110 | "version": "1.0.0", 111 | "resolved": "https://registry.npmjs.org/assign-symbols/-/assign-symbols-1.0.0.tgz", 112 | "integrity": "sha1-WWZ/QfrdTyDMvCu5a41Pf3jsA2c=", 113 | "dev": true 114 | }, 115 | "async": { 116 | "version": "2.6.1", 117 | "resolved": "https://registry.npmjs.org/async/-/async-2.6.1.tgz", 118 | "integrity": "sha512-fNEiL2+AZt6AlAw/29Cr0UDe4sRAHCpEHh54WMz+Bb7QfNcFw4h3loofyJpLeQs4Yx7yuqu/2dLgM5hKOs6HlQ==", 119 | "requires": { 120 | "lodash": "^4.17.10" 121 | } 122 | }, 123 | "async-each": { 124 | "version": "1.0.1", 125 | "resolved": "https://registry.npmjs.org/async-each/-/async-each-1.0.1.tgz", 126 | "integrity": "sha1-GdOGodntxufByF04iu28xW0zYC0=", 127 | "dev": true 128 | }, 129 | "asynckit": { 130 | "version": "0.4.0", 131 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 132 | "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=" 133 | }, 134 | "atob": { 135 | "version": "2.1.2", 136 | "resolved": "https://registry.npmjs.org/atob/-/atob-2.1.2.tgz", 137 | "integrity": "sha512-Wm6ukoaOGJi/73p/cl2GvLjTI5JM1k/O14isD73YML8StrH/7/lRFgmg8nICZgD3bZZvjwCGxtMOD3wWNAu8cg==", 138 | "dev": true 139 | }, 140 | "aws-sign2": { 141 | "version": "0.7.0", 142 | "resolved": "https://registry.npmjs.org/aws-sign2/-/aws-sign2-0.7.0.tgz", 143 | "integrity": "sha1-tG6JCTSpWR8tL2+G1+ap8bP+dqg=" 144 | }, 145 | "aws4": { 146 | "version": "1.8.0", 147 | "resolved": "https://registry.npmjs.org/aws4/-/aws4-1.8.0.tgz", 148 | "integrity": "sha512-ReZxvNHIOv88FlT7rxcXIIC0fPt4KZqZbOlivyWtXLt8ESx84zd3kMC6iK5jVeS2qt+g7ftS7ye4fi06X5rtRQ==" 149 | }, 150 | "balanced-match": { 151 | "version": "1.0.0", 152 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 153 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 154 | "dev": true 155 | }, 156 | "base": { 157 | "version": "0.11.2", 158 | "resolved": "https://registry.npmjs.org/base/-/base-0.11.2.tgz", 159 | "integrity": "sha512-5T6P4xPgpp0YDFvSWwEZ4NoE3aM4QBQXDzmVbraCkFj8zHM+mba8SyqB5DbZWyR7mYHo6Y7BdQo3MoA4m0TeQg==", 160 | "dev": true, 161 | "requires": { 162 | "cache-base": "^1.0.1", 163 | "class-utils": "^0.3.5", 164 | "component-emitter": "^1.2.1", 165 | "define-property": "^1.0.0", 166 | "isobject": "^3.0.1", 167 | "mixin-deep": "^1.2.0", 168 | "pascalcase": "^0.1.1" 169 | }, 170 | "dependencies": { 171 | "define-property": { 172 | "version": "1.0.0", 173 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz", 174 | "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", 175 | "dev": true, 176 | "requires": { 177 | "is-descriptor": "^1.0.0" 178 | } 179 | }, 180 | "is-accessor-descriptor": { 181 | "version": "1.0.0", 182 | "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", 183 | "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", 184 | "dev": true, 185 | "requires": { 186 | "kind-of": "^6.0.0" 187 | } 188 | }, 189 | "is-data-descriptor": { 190 | "version": "1.0.0", 191 | "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", 192 | "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", 193 | "dev": true, 194 | "requires": { 195 | "kind-of": "^6.0.0" 196 | } 197 | }, 198 | "is-descriptor": { 199 | "version": "1.0.2", 200 | "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", 201 | "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", 202 | "dev": true, 203 | "requires": { 204 | "is-accessor-descriptor": "^1.0.0", 205 | "is-data-descriptor": "^1.0.0", 206 | "kind-of": "^6.0.2" 207 | } 208 | } 209 | } 210 | }, 211 | "basic-auth": { 212 | "version": "2.0.1", 213 | "resolved": "https://registry.npmjs.org/basic-auth/-/basic-auth-2.0.1.tgz", 214 | "integrity": "sha512-NF+epuEdnUYVlGuhaxbbq+dvJttwLnGY+YixlXlME5KpQ5W3CnXA5cVTneY3SPbPDRkcjMbifrwmFYcClgOZeg==", 215 | "requires": { 216 | "safe-buffer": "5.1.2" 217 | } 218 | }, 219 | "bcrypt-pbkdf": { 220 | "version": "1.0.2", 221 | "resolved": "https://registry.npmjs.org/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.2.tgz", 222 | "integrity": "sha1-pDAdOJtqQ/m2f/PKEaP2Y342Dp4=", 223 | "requires": { 224 | "tweetnacl": "^0.14.3" 225 | } 226 | }, 227 | "binary-extensions": { 228 | "version": "1.12.0", 229 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-1.12.0.tgz", 230 | "integrity": "sha512-DYWGk01lDcxeS/K9IHPGWfT8PsJmbXRtRd2Sx72Tnb8pcYZQFF1oSDb8hJtS1vhp212q1Rzi5dUf9+nq0o9UIg==", 231 | "dev": true 232 | }, 233 | "bluebird": { 234 | "version": "3.5.1", 235 | "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.5.1.tgz", 236 | "integrity": "sha512-MKiLiV+I1AA596t9w1sQJ8jkiSr5+ZKi0WKrYGUn6d1Fx+Ij4tIj+m2WMQSGczs5jZVxV339chE8iwk6F64wjA==" 237 | }, 238 | "body-parser": { 239 | "version": "1.18.3", 240 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.18.3.tgz", 241 | "integrity": "sha1-WykhmP/dVTs6DyDe0FkrlWlVyLQ=", 242 | "requires": { 243 | "bytes": "3.0.0", 244 | "content-type": "~1.0.4", 245 | "debug": "2.6.9", 246 | "depd": "~1.1.2", 247 | "http-errors": "~1.6.3", 248 | "iconv-lite": "0.4.23", 249 | "on-finished": "~2.3.0", 250 | "qs": "6.5.2", 251 | "raw-body": "2.3.3", 252 | "type-is": "~1.6.16" 253 | } 254 | }, 255 | "boxen": { 256 | "version": "1.3.0", 257 | "resolved": "https://registry.npmjs.org/boxen/-/boxen-1.3.0.tgz", 258 | "integrity": "sha512-TNPjfTr432qx7yOjQyaXm3dSR0MH9vXp7eT1BFSl/C51g+EFnOR9hTg1IreahGBmDNCehscshe45f+C1TBZbLw==", 259 | "dev": true, 260 | "requires": { 261 | "ansi-align": "^2.0.0", 262 | "camelcase": "^4.0.0", 263 | "chalk": "^2.0.1", 264 | "cli-boxes": "^1.0.0", 265 | "string-width": "^2.0.0", 266 | "term-size": "^1.2.0", 267 | "widest-line": "^2.0.0" 268 | } 269 | }, 270 | "brace-expansion": { 271 | "version": "1.1.11", 272 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 273 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 274 | "dev": true, 275 | "requires": { 276 | "balanced-match": "^1.0.0", 277 | "concat-map": "0.0.1" 278 | } 279 | }, 280 | "braces": { 281 | "version": "2.3.2", 282 | "resolved": "https://registry.npmjs.org/braces/-/braces-2.3.2.tgz", 283 | "integrity": "sha512-aNdbnj9P8PjdXU4ybaWLK2IF3jc/EoDYbC7AazW6to3TRsfXxscC9UXOB5iDiEQrkyIbWp2SLQda4+QAa7nc3w==", 284 | "dev": true, 285 | "requires": { 286 | "arr-flatten": "^1.1.0", 287 | "array-unique": "^0.3.2", 288 | "extend-shallow": "^2.0.1", 289 | "fill-range": "^4.0.0", 290 | "isobject": "^3.0.1", 291 | "repeat-element": "^1.1.2", 292 | "snapdragon": "^0.8.1", 293 | "snapdragon-node": "^2.0.1", 294 | "split-string": "^3.0.2", 295 | "to-regex": "^3.0.1" 296 | }, 297 | "dependencies": { 298 | "extend-shallow": { 299 | "version": "2.0.1", 300 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", 301 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", 302 | "dev": true, 303 | "requires": { 304 | "is-extendable": "^0.1.0" 305 | } 306 | } 307 | } 308 | }, 309 | "bson": { 310 | "version": "1.1.0", 311 | "resolved": "https://registry.npmjs.org/bson/-/bson-1.1.0.tgz", 312 | "integrity": "sha512-9Aeai9TacfNtWXOYarkFJRW2CWo+dRon+fuLZYJmvLV3+MiUp0bEI6IAZfXEIg7/Pl/7IWlLaDnhzTsD81etQA==" 313 | }, 314 | "buffer-equal-constant-time": { 315 | "version": "1.0.1", 316 | "resolved": "https://registry.npmjs.org/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz", 317 | "integrity": "sha1-+OcRMvf/5uAaXJaXpMbz5I1cyBk=" 318 | }, 319 | "bytes": { 320 | "version": "3.0.0", 321 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.0.0.tgz", 322 | "integrity": "sha1-0ygVQE1olpn4Wk6k+odV3ROpYEg=" 323 | }, 324 | "cache-base": { 325 | "version": "1.0.1", 326 | "resolved": "https://registry.npmjs.org/cache-base/-/cache-base-1.0.1.tgz", 327 | "integrity": "sha512-AKcdTnFSWATd5/GCPRxr2ChwIJ85CeyrEyjRHlKxQ56d4XJMGym0uAiKn0xbLOGOl3+yRpOTi484dVCEc5AUzQ==", 328 | "dev": true, 329 | "requires": { 330 | "collection-visit": "^1.0.0", 331 | "component-emitter": "^1.2.1", 332 | "get-value": "^2.0.6", 333 | "has-value": "^1.0.0", 334 | "isobject": "^3.0.1", 335 | "set-value": "^2.0.0", 336 | "to-object-path": "^0.3.0", 337 | "union-value": "^1.0.0", 338 | "unset-value": "^1.0.0" 339 | } 340 | }, 341 | "camelcase": { 342 | "version": "4.1.0", 343 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-4.1.0.tgz", 344 | "integrity": "sha1-1UVjW+HjPFQmScaRc+Xeas+uNN0=", 345 | "dev": true 346 | }, 347 | "capture-stack-trace": { 348 | "version": "1.0.1", 349 | "resolved": "https://registry.npmjs.org/capture-stack-trace/-/capture-stack-trace-1.0.1.tgz", 350 | "integrity": "sha512-mYQLZnx5Qt1JgB1WEiMCf2647plpGeQ2NMR/5L0HNZzGQo4fuSPnK+wjfPnKZV0aiJDgzmWqqkV/g7JD+DW0qw==", 351 | "dev": true 352 | }, 353 | "caseless": { 354 | "version": "0.12.0", 355 | "resolved": "https://registry.npmjs.org/caseless/-/caseless-0.12.0.tgz", 356 | "integrity": "sha1-G2gcIf+EAzyCZUMJBolCDRhxUdw=" 357 | }, 358 | "chalk": { 359 | "version": "2.4.1", 360 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.1.tgz", 361 | "integrity": "sha512-ObN6h1v2fTJSmUXoS3nMQ92LbDK9be4TV+6G+omQlGJFdcUX5heKi1LZ1YnRMIgwTLEj3E24bT6tYni50rlCfQ==", 362 | "dev": true, 363 | "requires": { 364 | "ansi-styles": "^3.2.1", 365 | "escape-string-regexp": "^1.0.5", 366 | "supports-color": "^5.3.0" 367 | } 368 | }, 369 | "chokidar": { 370 | "version": "2.0.4", 371 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-2.0.4.tgz", 372 | "integrity": "sha512-z9n7yt9rOvIJrMhvDtDictKrkFHeihkNl6uWMmZlmL6tJtX9Cs+87oK+teBx+JIgzvbX3yZHT3eF8vpbDxHJXQ==", 373 | "dev": true, 374 | "requires": { 375 | "anymatch": "^2.0.0", 376 | "async-each": "^1.0.0", 377 | "braces": "^2.3.0", 378 | "fsevents": "^1.2.2", 379 | "glob-parent": "^3.1.0", 380 | "inherits": "^2.0.1", 381 | "is-binary-path": "^1.0.0", 382 | "is-glob": "^4.0.0", 383 | "lodash.debounce": "^4.0.8", 384 | "normalize-path": "^2.1.1", 385 | "path-is-absolute": "^1.0.0", 386 | "readdirp": "^2.0.0", 387 | "upath": "^1.0.5" 388 | } 389 | }, 390 | "ci-info": { 391 | "version": "1.6.0", 392 | "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-1.6.0.tgz", 393 | "integrity": "sha512-vsGdkwSCDpWmP80ncATX7iea5DWQemg1UgCW5J8tqjU3lYw4FBYuj89J0CTVomA7BEfvSZd84GmHko+MxFQU2A==", 394 | "dev": true 395 | }, 396 | "class-utils": { 397 | "version": "0.3.6", 398 | "resolved": "https://registry.npmjs.org/class-utils/-/class-utils-0.3.6.tgz", 399 | "integrity": "sha512-qOhPa/Fj7s6TY8H8esGu5QNpMMQxz79h+urzrNYN6mn+9BnxlDGf5QZ+XeCDsxSjPqsSR56XOZOJmpeurnLMeg==", 400 | "dev": true, 401 | "requires": { 402 | "arr-union": "^3.1.0", 403 | "define-property": "^0.2.5", 404 | "isobject": "^3.0.0", 405 | "static-extend": "^0.1.1" 406 | }, 407 | "dependencies": { 408 | "define-property": { 409 | "version": "0.2.5", 410 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", 411 | "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", 412 | "dev": true, 413 | "requires": { 414 | "is-descriptor": "^0.1.0" 415 | } 416 | } 417 | } 418 | }, 419 | "cli-boxes": { 420 | "version": "1.0.0", 421 | "resolved": "https://registry.npmjs.org/cli-boxes/-/cli-boxes-1.0.0.tgz", 422 | "integrity": "sha1-T6kXw+WclKAEzWH47lCdplFocUM=", 423 | "dev": true 424 | }, 425 | "collection-visit": { 426 | "version": "1.0.0", 427 | "resolved": "https://registry.npmjs.org/collection-visit/-/collection-visit-1.0.0.tgz", 428 | "integrity": "sha1-S8A3PBZLwykbTTaMgpzxqApZ3KA=", 429 | "dev": true, 430 | "requires": { 431 | "map-visit": "^1.0.0", 432 | "object-visit": "^1.0.0" 433 | } 434 | }, 435 | "color-convert": { 436 | "version": "1.9.3", 437 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 438 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 439 | "dev": true, 440 | "requires": { 441 | "color-name": "1.1.3" 442 | } 443 | }, 444 | "color-name": { 445 | "version": "1.1.3", 446 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 447 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 448 | "dev": true 449 | }, 450 | "combined-stream": { 451 | "version": "1.0.7", 452 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.7.tgz", 453 | "integrity": "sha512-brWl9y6vOB1xYPZcpZde3N9zDByXTosAeMDo4p1wzo6UMOX4vumB+TP1RZ76sfE6Md68Q0NJSrE/gbezd4Ul+w==", 454 | "requires": { 455 | "delayed-stream": "~1.0.0" 456 | } 457 | }, 458 | "component-emitter": { 459 | "version": "1.2.1", 460 | "resolved": "https://registry.npmjs.org/component-emitter/-/component-emitter-1.2.1.tgz", 461 | "integrity": "sha1-E3kY1teCg/ffemt8WmPhQOaUJeY=", 462 | "dev": true 463 | }, 464 | "compressible": { 465 | "version": "2.0.15", 466 | "resolved": "https://registry.npmjs.org/compressible/-/compressible-2.0.15.tgz", 467 | "integrity": "sha512-4aE67DL33dSW9gw4CI2H/yTxqHLNcxp0yS6jB+4h+wr3e43+1z7vm0HU9qXOH8j+qjKuL8+UtkOxYQSMq60Ylw==", 468 | "requires": { 469 | "mime-db": ">= 1.36.0 < 2" 470 | } 471 | }, 472 | "compression": { 473 | "version": "1.7.3", 474 | "resolved": "https://registry.npmjs.org/compression/-/compression-1.7.3.tgz", 475 | "integrity": "sha512-HSjyBG5N1Nnz7tF2+O7A9XUhyjru71/fwgNb7oIsEVHR0WShfs2tIS/EySLgiTe98aOK18YDlMXpzjCXY/n9mg==", 476 | "requires": { 477 | "accepts": "~1.3.5", 478 | "bytes": "3.0.0", 479 | "compressible": "~2.0.14", 480 | "debug": "2.6.9", 481 | "on-headers": "~1.0.1", 482 | "safe-buffer": "5.1.2", 483 | "vary": "~1.1.2" 484 | } 485 | }, 486 | "concat-map": { 487 | "version": "0.0.1", 488 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 489 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 490 | "dev": true 491 | }, 492 | "configstore": { 493 | "version": "3.1.2", 494 | "resolved": "https://registry.npmjs.org/configstore/-/configstore-3.1.2.tgz", 495 | "integrity": "sha512-vtv5HtGjcYUgFrXc6Kx747B83MRRVS5R1VTEQoXvuP+kMI+if6uywV0nDGoiydJRy4yk7h9od5Og0kxx4zUXmw==", 496 | "dev": true, 497 | "requires": { 498 | "dot-prop": "^4.1.0", 499 | "graceful-fs": "^4.1.2", 500 | "make-dir": "^1.0.0", 501 | "unique-string": "^1.0.0", 502 | "write-file-atomic": "^2.0.0", 503 | "xdg-basedir": "^3.0.0" 504 | } 505 | }, 506 | "content-disposition": { 507 | "version": "0.5.2", 508 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.2.tgz", 509 | "integrity": "sha1-DPaLud318r55YcOoUXjLhdunjLQ=" 510 | }, 511 | "content-type": { 512 | "version": "1.0.4", 513 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz", 514 | "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==" 515 | }, 516 | "cookie": { 517 | "version": "0.3.1", 518 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.3.1.tgz", 519 | "integrity": "sha1-5+Ch+e9DtMi6klxcWpboBtFoc7s=" 520 | }, 521 | "cookie-signature": { 522 | "version": "1.0.6", 523 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 524 | "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw=" 525 | }, 526 | "copy-descriptor": { 527 | "version": "0.1.1", 528 | "resolved": "https://registry.npmjs.org/copy-descriptor/-/copy-descriptor-0.1.1.tgz", 529 | "integrity": "sha1-Z29us8OZl8LuGsOpJP1hJHSPV40=", 530 | "dev": true 531 | }, 532 | "core-util-is": { 533 | "version": "1.0.2", 534 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 535 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=" 536 | }, 537 | "cors": { 538 | "version": "2.8.5", 539 | "resolved": "https://registry.npmjs.org/cors/-/cors-2.8.5.tgz", 540 | "integrity": "sha512-KIHbLJqu73RGr/hnbrO9uBeixNGuvSQjul/jdFvS/KFSIH1hWVd1ng7zOHx+YrEfInLG7q4n6GHQ9cDtxv/P6g==", 541 | "requires": { 542 | "object-assign": "^4", 543 | "vary": "^1" 544 | } 545 | }, 546 | "create-error-class": { 547 | "version": "3.0.2", 548 | "resolved": "https://registry.npmjs.org/create-error-class/-/create-error-class-3.0.2.tgz", 549 | "integrity": "sha1-Br56vvlHo/FKMP1hBnHUAbyot7Y=", 550 | "dev": true, 551 | "requires": { 552 | "capture-stack-trace": "^1.0.0" 553 | } 554 | }, 555 | "cross-spawn": { 556 | "version": "5.1.0", 557 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-5.1.0.tgz", 558 | "integrity": "sha1-6L0O/uWPz/b4+UUQoKVUu/ojVEk=", 559 | "dev": true, 560 | "requires": { 561 | "lru-cache": "^4.0.1", 562 | "shebang-command": "^1.2.0", 563 | "which": "^1.2.9" 564 | } 565 | }, 566 | "crypto-random-string": { 567 | "version": "1.0.0", 568 | "resolved": "https://registry.npmjs.org/crypto-random-string/-/crypto-random-string-1.0.0.tgz", 569 | "integrity": "sha1-ojD2T1aDEOFJgAmUB5DsmVRbyn4=", 570 | "dev": true 571 | }, 572 | "dashdash": { 573 | "version": "1.14.1", 574 | "resolved": "https://registry.npmjs.org/dashdash/-/dashdash-1.14.1.tgz", 575 | "integrity": "sha1-hTz6D3y+L+1d4gMmuN1YEDX24vA=", 576 | "requires": { 577 | "assert-plus": "^1.0.0" 578 | } 579 | }, 580 | "debug": { 581 | "version": "2.6.9", 582 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 583 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 584 | "requires": { 585 | "ms": "2.0.0" 586 | } 587 | }, 588 | "decode-uri-component": { 589 | "version": "0.2.0", 590 | "resolved": "https://registry.npmjs.org/decode-uri-component/-/decode-uri-component-0.2.0.tgz", 591 | "integrity": "sha1-6zkTMzRYd1y4TNGh+uBiEGu4dUU=", 592 | "dev": true 593 | }, 594 | "deep-extend": { 595 | "version": "0.6.0", 596 | "resolved": "https://registry.npmjs.org/deep-extend/-/deep-extend-0.6.0.tgz", 597 | "integrity": "sha512-LOHxIOaPYdHlJRtCQfDIVZtfw/ufM8+rVj649RIHzcm/vGwQRXFt6OPqIFWsm2XEMrNIEtWR64sY1LEKD2vAOA==", 598 | "dev": true 599 | }, 600 | "define-property": { 601 | "version": "2.0.2", 602 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-2.0.2.tgz", 603 | "integrity": "sha512-jwK2UV4cnPpbcG7+VRARKTZPUWowwXA8bzH5NP6ud0oeAxyYPuGZUAC7hMugpCdz4BeSZl2Dl9k66CHJ/46ZYQ==", 604 | "dev": true, 605 | "requires": { 606 | "is-descriptor": "^1.0.2", 607 | "isobject": "^3.0.1" 608 | }, 609 | "dependencies": { 610 | "is-accessor-descriptor": { 611 | "version": "1.0.0", 612 | "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", 613 | "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", 614 | "dev": true, 615 | "requires": { 616 | "kind-of": "^6.0.0" 617 | } 618 | }, 619 | "is-data-descriptor": { 620 | "version": "1.0.0", 621 | "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", 622 | "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", 623 | "dev": true, 624 | "requires": { 625 | "kind-of": "^6.0.0" 626 | } 627 | }, 628 | "is-descriptor": { 629 | "version": "1.0.2", 630 | "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", 631 | "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", 632 | "dev": true, 633 | "requires": { 634 | "is-accessor-descriptor": "^1.0.0", 635 | "is-data-descriptor": "^1.0.0", 636 | "kind-of": "^6.0.2" 637 | } 638 | } 639 | } 640 | }, 641 | "delayed-stream": { 642 | "version": "1.0.0", 643 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 644 | "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=" 645 | }, 646 | "depd": { 647 | "version": "1.1.2", 648 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", 649 | "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak=" 650 | }, 651 | "destroy": { 652 | "version": "1.0.4", 653 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz", 654 | "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA=" 655 | }, 656 | "dot-prop": { 657 | "version": "4.2.0", 658 | "resolved": "https://registry.npmjs.org/dot-prop/-/dot-prop-4.2.0.tgz", 659 | "integrity": "sha512-tUMXrxlExSW6U2EXiiKGSBVdYgtV8qlHL+C10TsW4PURY/ic+eaysnSkwB4kA/mBlCyy/IKDJ+Lc3wbWeaXtuQ==", 660 | "dev": true, 661 | "requires": { 662 | "is-obj": "^1.0.0" 663 | } 664 | }, 665 | "dotenv": { 666 | "version": "6.1.0", 667 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-6.1.0.tgz", 668 | "integrity": "sha512-/veDn2ztgRlB7gKmE3i9f6CmDIyXAy6d5nBq+whO9SLX+Zs1sXEgFLPi+aSuWqUuusMfbi84fT8j34fs1HaYUw==", 669 | "dev": true 670 | }, 671 | "duplexer": { 672 | "version": "0.1.1", 673 | "resolved": "http://registry.npmjs.org/duplexer/-/duplexer-0.1.1.tgz", 674 | "integrity": "sha1-rOb/gIwc5mtX0ev5eXessCM0z8E=", 675 | "dev": true 676 | }, 677 | "duplexer3": { 678 | "version": "0.1.4", 679 | "resolved": "https://registry.npmjs.org/duplexer3/-/duplexer3-0.1.4.tgz", 680 | "integrity": "sha1-7gHdHKwO08vH/b6jfcCo8c4ALOI=", 681 | "dev": true 682 | }, 683 | "ecc-jsbn": { 684 | "version": "0.1.2", 685 | "resolved": "https://registry.npmjs.org/ecc-jsbn/-/ecc-jsbn-0.1.2.tgz", 686 | "integrity": "sha1-OoOpBOVDUyh4dMVkt1SThoSamMk=", 687 | "requires": { 688 | "jsbn": "~0.1.0", 689 | "safer-buffer": "^2.1.0" 690 | } 691 | }, 692 | "ecdsa-sig-formatter": { 693 | "version": "1.0.10", 694 | "resolved": "https://registry.npmjs.org/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.10.tgz", 695 | "integrity": "sha1-HFlQAPBKiJffuFAAiSoPTDOvhsM=", 696 | "requires": { 697 | "safe-buffer": "^5.0.1" 698 | } 699 | }, 700 | "ee-first": { 701 | "version": "1.1.1", 702 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 703 | "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0=" 704 | }, 705 | "encodeurl": { 706 | "version": "1.0.2", 707 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 708 | "integrity": "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k=" 709 | }, 710 | "escape-html": { 711 | "version": "1.0.3", 712 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 713 | "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg=" 714 | }, 715 | "escape-string-regexp": { 716 | "version": "1.0.5", 717 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 718 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 719 | "dev": true 720 | }, 721 | "etag": { 722 | "version": "1.8.1", 723 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 724 | "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc=" 725 | }, 726 | "event-stream": { 727 | "version": "3.3.6", 728 | "resolved": "https://registry.npmjs.org/event-stream/-/event-stream-3.3.6.tgz", 729 | "integrity": "sha512-dGXNg4F/FgVzlApjzItL+7naHutA3fDqbV/zAZqDDlXTjiMnQmZKu+prImWKszeBM5UQeGvAl3u1wBiKeDh61g==", 730 | "dev": true, 731 | "requires": { 732 | "duplexer": "^0.1.1", 733 | "flatmap-stream": "^0.1.0", 734 | "from": "^0.1.7", 735 | "map-stream": "0.0.7", 736 | "pause-stream": "^0.0.11", 737 | "split": "^1.0.1", 738 | "stream-combiner": "^0.2.2", 739 | "through": "^2.3.8" 740 | } 741 | }, 742 | "execa": { 743 | "version": "0.7.0", 744 | "resolved": "https://registry.npmjs.org/execa/-/execa-0.7.0.tgz", 745 | "integrity": "sha1-lEvs00zEHuMqY6n68nrVpl/Fl3c=", 746 | "dev": true, 747 | "requires": { 748 | "cross-spawn": "^5.0.1", 749 | "get-stream": "^3.0.0", 750 | "is-stream": "^1.1.0", 751 | "npm-run-path": "^2.0.0", 752 | "p-finally": "^1.0.0", 753 | "signal-exit": "^3.0.0", 754 | "strip-eof": "^1.0.0" 755 | } 756 | }, 757 | "expand-brackets": { 758 | "version": "2.1.4", 759 | "resolved": "https://registry.npmjs.org/expand-brackets/-/expand-brackets-2.1.4.tgz", 760 | "integrity": "sha1-t3c14xXOMPa27/D4OwQVGiJEliI=", 761 | "dev": true, 762 | "requires": { 763 | "debug": "^2.3.3", 764 | "define-property": "^0.2.5", 765 | "extend-shallow": "^2.0.1", 766 | "posix-character-classes": "^0.1.0", 767 | "regex-not": "^1.0.0", 768 | "snapdragon": "^0.8.1", 769 | "to-regex": "^3.0.1" 770 | }, 771 | "dependencies": { 772 | "define-property": { 773 | "version": "0.2.5", 774 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", 775 | "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", 776 | "dev": true, 777 | "requires": { 778 | "is-descriptor": "^0.1.0" 779 | } 780 | }, 781 | "extend-shallow": { 782 | "version": "2.0.1", 783 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", 784 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", 785 | "dev": true, 786 | "requires": { 787 | "is-extendable": "^0.1.0" 788 | } 789 | } 790 | } 791 | }, 792 | "express": { 793 | "version": "4.16.4", 794 | "resolved": "https://registry.npmjs.org/express/-/express-4.16.4.tgz", 795 | "integrity": "sha512-j12Uuyb4FMrd/qQAm6uCHAkPtO8FDTRJZBDd5D2KOL2eLaz1yUNdUB/NOIyq0iU4q4cFarsUCrnFDPBcnksuOg==", 796 | "requires": { 797 | "accepts": "~1.3.5", 798 | "array-flatten": "1.1.1", 799 | "body-parser": "1.18.3", 800 | "content-disposition": "0.5.2", 801 | "content-type": "~1.0.4", 802 | "cookie": "0.3.1", 803 | "cookie-signature": "1.0.6", 804 | "debug": "2.6.9", 805 | "depd": "~1.1.2", 806 | "encodeurl": "~1.0.2", 807 | "escape-html": "~1.0.3", 808 | "etag": "~1.8.1", 809 | "finalhandler": "1.1.1", 810 | "fresh": "0.5.2", 811 | "merge-descriptors": "1.0.1", 812 | "methods": "~1.1.2", 813 | "on-finished": "~2.3.0", 814 | "parseurl": "~1.3.2", 815 | "path-to-regexp": "0.1.7", 816 | "proxy-addr": "~2.0.4", 817 | "qs": "6.5.2", 818 | "range-parser": "~1.2.0", 819 | "safe-buffer": "5.1.2", 820 | "send": "0.16.2", 821 | "serve-static": "1.13.2", 822 | "setprototypeof": "1.1.0", 823 | "statuses": "~1.4.0", 824 | "type-is": "~1.6.16", 825 | "utils-merge": "1.0.1", 826 | "vary": "~1.1.2" 827 | } 828 | }, 829 | "extend": { 830 | "version": "3.0.2", 831 | "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz", 832 | "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==" 833 | }, 834 | "extend-shallow": { 835 | "version": "3.0.2", 836 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-3.0.2.tgz", 837 | "integrity": "sha1-Jqcarwc7OfshJxcnRhMcJwQCjbg=", 838 | "dev": true, 839 | "requires": { 840 | "assign-symbols": "^1.0.0", 841 | "is-extendable": "^1.0.1" 842 | }, 843 | "dependencies": { 844 | "is-extendable": { 845 | "version": "1.0.1", 846 | "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-1.0.1.tgz", 847 | "integrity": "sha512-arnXMxT1hhoKo9k1LZdmlNyJdDDfy2v0fXjFlmok4+i8ul/6WlbVge9bhM74OpNPQPMGUToDtz+KXa1PneJxOA==", 848 | "dev": true, 849 | "requires": { 850 | "is-plain-object": "^2.0.4" 851 | } 852 | } 853 | } 854 | }, 855 | "extglob": { 856 | "version": "2.0.4", 857 | "resolved": "https://registry.npmjs.org/extglob/-/extglob-2.0.4.tgz", 858 | "integrity": "sha512-Nmb6QXkELsuBr24CJSkilo6UHHgbekK5UiZgfE6UHD3Eb27YC6oD+bhcT+tJ6cl8dmsgdQxnWlcry8ksBIBLpw==", 859 | "dev": true, 860 | "requires": { 861 | "array-unique": "^0.3.2", 862 | "define-property": "^1.0.0", 863 | "expand-brackets": "^2.1.4", 864 | "extend-shallow": "^2.0.1", 865 | "fragment-cache": "^0.2.1", 866 | "regex-not": "^1.0.0", 867 | "snapdragon": "^0.8.1", 868 | "to-regex": "^3.0.1" 869 | }, 870 | "dependencies": { 871 | "define-property": { 872 | "version": "1.0.0", 873 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz", 874 | "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", 875 | "dev": true, 876 | "requires": { 877 | "is-descriptor": "^1.0.0" 878 | } 879 | }, 880 | "extend-shallow": { 881 | "version": "2.0.1", 882 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", 883 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", 884 | "dev": true, 885 | "requires": { 886 | "is-extendable": "^0.1.0" 887 | } 888 | }, 889 | "is-accessor-descriptor": { 890 | "version": "1.0.0", 891 | "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", 892 | "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", 893 | "dev": true, 894 | "requires": { 895 | "kind-of": "^6.0.0" 896 | } 897 | }, 898 | "is-data-descriptor": { 899 | "version": "1.0.0", 900 | "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", 901 | "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", 902 | "dev": true, 903 | "requires": { 904 | "kind-of": "^6.0.0" 905 | } 906 | }, 907 | "is-descriptor": { 908 | "version": "1.0.2", 909 | "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", 910 | "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", 911 | "dev": true, 912 | "requires": { 913 | "is-accessor-descriptor": "^1.0.0", 914 | "is-data-descriptor": "^1.0.0", 915 | "kind-of": "^6.0.2" 916 | } 917 | } 918 | } 919 | }, 920 | "extsprintf": { 921 | "version": "1.3.0", 922 | "resolved": "https://registry.npmjs.org/extsprintf/-/extsprintf-1.3.0.tgz", 923 | "integrity": "sha1-lpGEQOMEGnpBT4xS48V06zw+HgU=" 924 | }, 925 | "fast-deep-equal": { 926 | "version": "2.0.1", 927 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-2.0.1.tgz", 928 | "integrity": "sha1-ewUhjd+WZ79/Nwv3/bLLFf3Qqkk=" 929 | }, 930 | "fast-json-stable-stringify": { 931 | "version": "2.0.0", 932 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.0.0.tgz", 933 | "integrity": "sha1-1RQsDK7msRifh9OnYREGT4bIu/I=" 934 | }, 935 | "fill-range": { 936 | "version": "4.0.0", 937 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-4.0.0.tgz", 938 | "integrity": "sha1-1USBHUKPmOsGpj3EAtJAPDKMOPc=", 939 | "dev": true, 940 | "requires": { 941 | "extend-shallow": "^2.0.1", 942 | "is-number": "^3.0.0", 943 | "repeat-string": "^1.6.1", 944 | "to-regex-range": "^2.1.0" 945 | }, 946 | "dependencies": { 947 | "extend-shallow": { 948 | "version": "2.0.1", 949 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", 950 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", 951 | "dev": true, 952 | "requires": { 953 | "is-extendable": "^0.1.0" 954 | } 955 | } 956 | } 957 | }, 958 | "finalhandler": { 959 | "version": "1.1.1", 960 | "resolved": "http://registry.npmjs.org/finalhandler/-/finalhandler-1.1.1.tgz", 961 | "integrity": "sha512-Y1GUDo39ez4aHAw7MysnUD5JzYX+WaIj8I57kO3aEPT1fFRL4sr7mjei97FgnwhAyyzRYmQZaTHb2+9uZ1dPtg==", 962 | "requires": { 963 | "debug": "2.6.9", 964 | "encodeurl": "~1.0.2", 965 | "escape-html": "~1.0.3", 966 | "on-finished": "~2.3.0", 967 | "parseurl": "~1.3.2", 968 | "statuses": "~1.4.0", 969 | "unpipe": "~1.0.0" 970 | } 971 | }, 972 | "flatmap-stream": { 973 | "version": "0.1.1", 974 | "resolved": "https://registry.npmjs.org/flatmap-stream/-/flatmap-stream-0.1.1.tgz", 975 | "integrity": "sha512-lAq4tLbm3sidmdCN8G3ExaxH7cUCtP5mgDvrYowsx84dcYkJJ4I28N7gkxA6+YlSXzaGLJYIDEi9WGfXzMiXdw==", 976 | "dev": true 977 | }, 978 | "for-in": { 979 | "version": "1.0.2", 980 | "resolved": "https://registry.npmjs.org/for-in/-/for-in-1.0.2.tgz", 981 | "integrity": "sha1-gQaNKVqBQuwKxybG4iAMMPttXoA=", 982 | "dev": true 983 | }, 984 | "forever-agent": { 985 | "version": "0.6.1", 986 | "resolved": "https://registry.npmjs.org/forever-agent/-/forever-agent-0.6.1.tgz", 987 | "integrity": "sha1-+8cfDEGt6zf5bFd60e1C2P2sypE=" 988 | }, 989 | "form-data": { 990 | "version": "2.3.3", 991 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.3.3.tgz", 992 | "integrity": "sha512-1lLKB2Mu3aGP1Q/2eCOx0fNbRMe7XdwktwOruhfqqd0rIJWwN4Dh+E3hrPSlDCXnSR7UtZ1N38rVXm+6+MEhJQ==", 993 | "requires": { 994 | "asynckit": "^0.4.0", 995 | "combined-stream": "^1.0.6", 996 | "mime-types": "^2.1.12" 997 | } 998 | }, 999 | "forwarded": { 1000 | "version": "0.1.2", 1001 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.1.2.tgz", 1002 | "integrity": "sha1-mMI9qxF1ZXuMBXPozszZGw/xjIQ=" 1003 | }, 1004 | "fragment-cache": { 1005 | "version": "0.2.1", 1006 | "resolved": "https://registry.npmjs.org/fragment-cache/-/fragment-cache-0.2.1.tgz", 1007 | "integrity": "sha1-QpD60n8T6Jvn8zeZxrxaCr//DRk=", 1008 | "dev": true, 1009 | "requires": { 1010 | "map-cache": "^0.2.2" 1011 | } 1012 | }, 1013 | "fresh": { 1014 | "version": "0.5.2", 1015 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 1016 | "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac=" 1017 | }, 1018 | "from": { 1019 | "version": "0.1.7", 1020 | "resolved": "https://registry.npmjs.org/from/-/from-0.1.7.tgz", 1021 | "integrity": "sha1-g8YK/Fi5xWmXAH7Rp2izqzA6RP4=", 1022 | "dev": true 1023 | }, 1024 | "fsevents": { 1025 | "version": "1.2.4", 1026 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-1.2.4.tgz", 1027 | "integrity": "sha512-z8H8/diyk76B7q5wg+Ud0+CqzcAF3mBBI/bA5ne5zrRUUIvNkJY//D3BqyH571KuAC4Nr7Rw7CjWX4r0y9DvNg==", 1028 | "dev": true, 1029 | "optional": true, 1030 | "requires": { 1031 | "nan": "^2.9.2", 1032 | "node-pre-gyp": "^0.10.0" 1033 | }, 1034 | "dependencies": { 1035 | "abbrev": { 1036 | "version": "1.1.1", 1037 | "bundled": true, 1038 | "dev": true, 1039 | "optional": true 1040 | }, 1041 | "ansi-regex": { 1042 | "version": "2.1.1", 1043 | "bundled": true, 1044 | "dev": true 1045 | }, 1046 | "aproba": { 1047 | "version": "1.2.0", 1048 | "bundled": true, 1049 | "dev": true, 1050 | "optional": true 1051 | }, 1052 | "are-we-there-yet": { 1053 | "version": "1.1.4", 1054 | "bundled": true, 1055 | "dev": true, 1056 | "optional": true, 1057 | "requires": { 1058 | "delegates": "^1.0.0", 1059 | "readable-stream": "^2.0.6" 1060 | } 1061 | }, 1062 | "balanced-match": { 1063 | "version": "1.0.0", 1064 | "bundled": true, 1065 | "dev": true 1066 | }, 1067 | "brace-expansion": { 1068 | "version": "1.1.11", 1069 | "bundled": true, 1070 | "dev": true, 1071 | "requires": { 1072 | "balanced-match": "^1.0.0", 1073 | "concat-map": "0.0.1" 1074 | } 1075 | }, 1076 | "chownr": { 1077 | "version": "1.0.1", 1078 | "bundled": true, 1079 | "dev": true, 1080 | "optional": true 1081 | }, 1082 | "code-point-at": { 1083 | "version": "1.1.0", 1084 | "bundled": true, 1085 | "dev": true 1086 | }, 1087 | "concat-map": { 1088 | "version": "0.0.1", 1089 | "bundled": true, 1090 | "dev": true 1091 | }, 1092 | "console-control-strings": { 1093 | "version": "1.1.0", 1094 | "bundled": true, 1095 | "dev": true 1096 | }, 1097 | "core-util-is": { 1098 | "version": "1.0.2", 1099 | "bundled": true, 1100 | "dev": true, 1101 | "optional": true 1102 | }, 1103 | "debug": { 1104 | "version": "2.6.9", 1105 | "bundled": true, 1106 | "dev": true, 1107 | "optional": true, 1108 | "requires": { 1109 | "ms": "2.0.0" 1110 | } 1111 | }, 1112 | "deep-extend": { 1113 | "version": "0.5.1", 1114 | "bundled": true, 1115 | "dev": true, 1116 | "optional": true 1117 | }, 1118 | "delegates": { 1119 | "version": "1.0.0", 1120 | "bundled": true, 1121 | "dev": true, 1122 | "optional": true 1123 | }, 1124 | "detect-libc": { 1125 | "version": "1.0.3", 1126 | "bundled": true, 1127 | "dev": true, 1128 | "optional": true 1129 | }, 1130 | "fs-minipass": { 1131 | "version": "1.2.5", 1132 | "bundled": true, 1133 | "dev": true, 1134 | "optional": true, 1135 | "requires": { 1136 | "minipass": "^2.2.1" 1137 | } 1138 | }, 1139 | "fs.realpath": { 1140 | "version": "1.0.0", 1141 | "bundled": true, 1142 | "dev": true, 1143 | "optional": true 1144 | }, 1145 | "gauge": { 1146 | "version": "2.7.4", 1147 | "bundled": true, 1148 | "dev": true, 1149 | "optional": true, 1150 | "requires": { 1151 | "aproba": "^1.0.3", 1152 | "console-control-strings": "^1.0.0", 1153 | "has-unicode": "^2.0.0", 1154 | "object-assign": "^4.1.0", 1155 | "signal-exit": "^3.0.0", 1156 | "string-width": "^1.0.1", 1157 | "strip-ansi": "^3.0.1", 1158 | "wide-align": "^1.1.0" 1159 | } 1160 | }, 1161 | "glob": { 1162 | "version": "7.1.2", 1163 | "bundled": true, 1164 | "dev": true, 1165 | "optional": true, 1166 | "requires": { 1167 | "fs.realpath": "^1.0.0", 1168 | "inflight": "^1.0.4", 1169 | "inherits": "2", 1170 | "minimatch": "^3.0.4", 1171 | "once": "^1.3.0", 1172 | "path-is-absolute": "^1.0.0" 1173 | } 1174 | }, 1175 | "has-unicode": { 1176 | "version": "2.0.1", 1177 | "bundled": true, 1178 | "dev": true, 1179 | "optional": true 1180 | }, 1181 | "iconv-lite": { 1182 | "version": "0.4.21", 1183 | "bundled": true, 1184 | "dev": true, 1185 | "optional": true, 1186 | "requires": { 1187 | "safer-buffer": "^2.1.0" 1188 | } 1189 | }, 1190 | "ignore-walk": { 1191 | "version": "3.0.1", 1192 | "bundled": true, 1193 | "dev": true, 1194 | "optional": true, 1195 | "requires": { 1196 | "minimatch": "^3.0.4" 1197 | } 1198 | }, 1199 | "inflight": { 1200 | "version": "1.0.6", 1201 | "bundled": true, 1202 | "dev": true, 1203 | "optional": true, 1204 | "requires": { 1205 | "once": "^1.3.0", 1206 | "wrappy": "1" 1207 | } 1208 | }, 1209 | "inherits": { 1210 | "version": "2.0.3", 1211 | "bundled": true, 1212 | "dev": true 1213 | }, 1214 | "ini": { 1215 | "version": "1.3.5", 1216 | "bundled": true, 1217 | "dev": true, 1218 | "optional": true 1219 | }, 1220 | "is-fullwidth-code-point": { 1221 | "version": "1.0.0", 1222 | "bundled": true, 1223 | "dev": true, 1224 | "requires": { 1225 | "number-is-nan": "^1.0.0" 1226 | } 1227 | }, 1228 | "isarray": { 1229 | "version": "1.0.0", 1230 | "bundled": true, 1231 | "dev": true, 1232 | "optional": true 1233 | }, 1234 | "minimatch": { 1235 | "version": "3.0.4", 1236 | "bundled": true, 1237 | "dev": true, 1238 | "requires": { 1239 | "brace-expansion": "^1.1.7" 1240 | } 1241 | }, 1242 | "minimist": { 1243 | "version": "0.0.8", 1244 | "bundled": true, 1245 | "dev": true 1246 | }, 1247 | "minipass": { 1248 | "version": "2.2.4", 1249 | "bundled": true, 1250 | "dev": true, 1251 | "requires": { 1252 | "safe-buffer": "^5.1.1", 1253 | "yallist": "^3.0.0" 1254 | } 1255 | }, 1256 | "minizlib": { 1257 | "version": "1.1.0", 1258 | "bundled": true, 1259 | "dev": true, 1260 | "optional": true, 1261 | "requires": { 1262 | "minipass": "^2.2.1" 1263 | } 1264 | }, 1265 | "mkdirp": { 1266 | "version": "0.5.1", 1267 | "bundled": true, 1268 | "dev": true, 1269 | "requires": { 1270 | "minimist": "0.0.8" 1271 | } 1272 | }, 1273 | "ms": { 1274 | "version": "2.0.0", 1275 | "bundled": true, 1276 | "dev": true, 1277 | "optional": true 1278 | }, 1279 | "needle": { 1280 | "version": "2.2.0", 1281 | "bundled": true, 1282 | "dev": true, 1283 | "optional": true, 1284 | "requires": { 1285 | "debug": "^2.1.2", 1286 | "iconv-lite": "^0.4.4", 1287 | "sax": "^1.2.4" 1288 | } 1289 | }, 1290 | "node-pre-gyp": { 1291 | "version": "0.10.0", 1292 | "bundled": true, 1293 | "dev": true, 1294 | "optional": true, 1295 | "requires": { 1296 | "detect-libc": "^1.0.2", 1297 | "mkdirp": "^0.5.1", 1298 | "needle": "^2.2.0", 1299 | "nopt": "^4.0.1", 1300 | "npm-packlist": "^1.1.6", 1301 | "npmlog": "^4.0.2", 1302 | "rc": "^1.1.7", 1303 | "rimraf": "^2.6.1", 1304 | "semver": "^5.3.0", 1305 | "tar": "^4" 1306 | } 1307 | }, 1308 | "nopt": { 1309 | "version": "4.0.1", 1310 | "bundled": true, 1311 | "dev": true, 1312 | "optional": true, 1313 | "requires": { 1314 | "abbrev": "1", 1315 | "osenv": "^0.1.4" 1316 | } 1317 | }, 1318 | "npm-bundled": { 1319 | "version": "1.0.3", 1320 | "bundled": true, 1321 | "dev": true, 1322 | "optional": true 1323 | }, 1324 | "npm-packlist": { 1325 | "version": "1.1.10", 1326 | "bundled": true, 1327 | "dev": true, 1328 | "optional": true, 1329 | "requires": { 1330 | "ignore-walk": "^3.0.1", 1331 | "npm-bundled": "^1.0.1" 1332 | } 1333 | }, 1334 | "npmlog": { 1335 | "version": "4.1.2", 1336 | "bundled": true, 1337 | "dev": true, 1338 | "optional": true, 1339 | "requires": { 1340 | "are-we-there-yet": "~1.1.2", 1341 | "console-control-strings": "~1.1.0", 1342 | "gauge": "~2.7.3", 1343 | "set-blocking": "~2.0.0" 1344 | } 1345 | }, 1346 | "number-is-nan": { 1347 | "version": "1.0.1", 1348 | "bundled": true, 1349 | "dev": true 1350 | }, 1351 | "object-assign": { 1352 | "version": "4.1.1", 1353 | "bundled": true, 1354 | "dev": true, 1355 | "optional": true 1356 | }, 1357 | "once": { 1358 | "version": "1.4.0", 1359 | "bundled": true, 1360 | "dev": true, 1361 | "requires": { 1362 | "wrappy": "1" 1363 | } 1364 | }, 1365 | "os-homedir": { 1366 | "version": "1.0.2", 1367 | "bundled": true, 1368 | "dev": true, 1369 | "optional": true 1370 | }, 1371 | "os-tmpdir": { 1372 | "version": "1.0.2", 1373 | "bundled": true, 1374 | "dev": true, 1375 | "optional": true 1376 | }, 1377 | "osenv": { 1378 | "version": "0.1.5", 1379 | "bundled": true, 1380 | "dev": true, 1381 | "optional": true, 1382 | "requires": { 1383 | "os-homedir": "^1.0.0", 1384 | "os-tmpdir": "^1.0.0" 1385 | } 1386 | }, 1387 | "path-is-absolute": { 1388 | "version": "1.0.1", 1389 | "bundled": true, 1390 | "dev": true, 1391 | "optional": true 1392 | }, 1393 | "process-nextick-args": { 1394 | "version": "2.0.0", 1395 | "bundled": true, 1396 | "dev": true, 1397 | "optional": true 1398 | }, 1399 | "rc": { 1400 | "version": "1.2.7", 1401 | "bundled": true, 1402 | "dev": true, 1403 | "optional": true, 1404 | "requires": { 1405 | "deep-extend": "^0.5.1", 1406 | "ini": "~1.3.0", 1407 | "minimist": "^1.2.0", 1408 | "strip-json-comments": "~2.0.1" 1409 | }, 1410 | "dependencies": { 1411 | "minimist": { 1412 | "version": "1.2.0", 1413 | "bundled": true, 1414 | "dev": true, 1415 | "optional": true 1416 | } 1417 | } 1418 | }, 1419 | "readable-stream": { 1420 | "version": "2.3.6", 1421 | "bundled": true, 1422 | "dev": true, 1423 | "optional": true, 1424 | "requires": { 1425 | "core-util-is": "~1.0.0", 1426 | "inherits": "~2.0.3", 1427 | "isarray": "~1.0.0", 1428 | "process-nextick-args": "~2.0.0", 1429 | "safe-buffer": "~5.1.1", 1430 | "string_decoder": "~1.1.1", 1431 | "util-deprecate": "~1.0.1" 1432 | } 1433 | }, 1434 | "rimraf": { 1435 | "version": "2.6.2", 1436 | "bundled": true, 1437 | "dev": true, 1438 | "optional": true, 1439 | "requires": { 1440 | "glob": "^7.0.5" 1441 | } 1442 | }, 1443 | "safe-buffer": { 1444 | "version": "5.1.1", 1445 | "bundled": true, 1446 | "dev": true 1447 | }, 1448 | "safer-buffer": { 1449 | "version": "2.1.2", 1450 | "bundled": true, 1451 | "dev": true, 1452 | "optional": true 1453 | }, 1454 | "sax": { 1455 | "version": "1.2.4", 1456 | "bundled": true, 1457 | "dev": true, 1458 | "optional": true 1459 | }, 1460 | "semver": { 1461 | "version": "5.5.0", 1462 | "bundled": true, 1463 | "dev": true, 1464 | "optional": true 1465 | }, 1466 | "set-blocking": { 1467 | "version": "2.0.0", 1468 | "bundled": true, 1469 | "dev": true, 1470 | "optional": true 1471 | }, 1472 | "signal-exit": { 1473 | "version": "3.0.2", 1474 | "bundled": true, 1475 | "dev": true, 1476 | "optional": true 1477 | }, 1478 | "string-width": { 1479 | "version": "1.0.2", 1480 | "bundled": true, 1481 | "dev": true, 1482 | "requires": { 1483 | "code-point-at": "^1.0.0", 1484 | "is-fullwidth-code-point": "^1.0.0", 1485 | "strip-ansi": "^3.0.0" 1486 | } 1487 | }, 1488 | "string_decoder": { 1489 | "version": "1.1.1", 1490 | "bundled": true, 1491 | "dev": true, 1492 | "optional": true, 1493 | "requires": { 1494 | "safe-buffer": "~5.1.0" 1495 | } 1496 | }, 1497 | "strip-ansi": { 1498 | "version": "3.0.1", 1499 | "bundled": true, 1500 | "dev": true, 1501 | "requires": { 1502 | "ansi-regex": "^2.0.0" 1503 | } 1504 | }, 1505 | "strip-json-comments": { 1506 | "version": "2.0.1", 1507 | "bundled": true, 1508 | "dev": true, 1509 | "optional": true 1510 | }, 1511 | "tar": { 1512 | "version": "4.4.1", 1513 | "bundled": true, 1514 | "dev": true, 1515 | "optional": true, 1516 | "requires": { 1517 | "chownr": "^1.0.1", 1518 | "fs-minipass": "^1.2.5", 1519 | "minipass": "^2.2.4", 1520 | "minizlib": "^1.1.0", 1521 | "mkdirp": "^0.5.0", 1522 | "safe-buffer": "^5.1.1", 1523 | "yallist": "^3.0.2" 1524 | } 1525 | }, 1526 | "util-deprecate": { 1527 | "version": "1.0.2", 1528 | "bundled": true, 1529 | "dev": true, 1530 | "optional": true 1531 | }, 1532 | "wide-align": { 1533 | "version": "1.1.2", 1534 | "bundled": true, 1535 | "dev": true, 1536 | "optional": true, 1537 | "requires": { 1538 | "string-width": "^1.0.2" 1539 | } 1540 | }, 1541 | "wrappy": { 1542 | "version": "1.0.2", 1543 | "bundled": true, 1544 | "dev": true 1545 | }, 1546 | "yallist": { 1547 | "version": "3.0.2", 1548 | "bundled": true, 1549 | "dev": true 1550 | } 1551 | } 1552 | }, 1553 | "get-stream": { 1554 | "version": "3.0.0", 1555 | "resolved": "http://registry.npmjs.org/get-stream/-/get-stream-3.0.0.tgz", 1556 | "integrity": "sha1-jpQ9E1jcN1VQVOy+LtsFqhdO3hQ=", 1557 | "dev": true 1558 | }, 1559 | "get-value": { 1560 | "version": "2.0.6", 1561 | "resolved": "https://registry.npmjs.org/get-value/-/get-value-2.0.6.tgz", 1562 | "integrity": "sha1-3BXKHGcjh8p2vTesCjlbogQqLCg=", 1563 | "dev": true 1564 | }, 1565 | "getpass": { 1566 | "version": "0.1.7", 1567 | "resolved": "https://registry.npmjs.org/getpass/-/getpass-0.1.7.tgz", 1568 | "integrity": "sha1-Xv+OPmhNVprkyysSgmBOi6YhSfo=", 1569 | "requires": { 1570 | "assert-plus": "^1.0.0" 1571 | } 1572 | }, 1573 | "glob-parent": { 1574 | "version": "3.1.0", 1575 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-3.1.0.tgz", 1576 | "integrity": "sha1-nmr2KZ2NO9K9QEMIMr0RPfkGxa4=", 1577 | "dev": true, 1578 | "requires": { 1579 | "is-glob": "^3.1.0", 1580 | "path-dirname": "^1.0.0" 1581 | }, 1582 | "dependencies": { 1583 | "is-glob": { 1584 | "version": "3.1.0", 1585 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-3.1.0.tgz", 1586 | "integrity": "sha1-e6WuJCF4BKxwcHuWkiVnSGzD6Eo=", 1587 | "dev": true, 1588 | "requires": { 1589 | "is-extglob": "^2.1.0" 1590 | } 1591 | } 1592 | } 1593 | }, 1594 | "global-dirs": { 1595 | "version": "0.1.1", 1596 | "resolved": "https://registry.npmjs.org/global-dirs/-/global-dirs-0.1.1.tgz", 1597 | "integrity": "sha1-sxnA3UYH81PzvpzKTHL8FIxJ9EU=", 1598 | "dev": true, 1599 | "requires": { 1600 | "ini": "^1.3.4" 1601 | } 1602 | }, 1603 | "got": { 1604 | "version": "6.7.1", 1605 | "resolved": "http://registry.npmjs.org/got/-/got-6.7.1.tgz", 1606 | "integrity": "sha1-JAzQV4WpoY5WHcG0S0HHY+8ejbA=", 1607 | "dev": true, 1608 | "requires": { 1609 | "create-error-class": "^3.0.0", 1610 | "duplexer3": "^0.1.4", 1611 | "get-stream": "^3.0.0", 1612 | "is-redirect": "^1.0.0", 1613 | "is-retry-allowed": "^1.0.0", 1614 | "is-stream": "^1.0.0", 1615 | "lowercase-keys": "^1.0.0", 1616 | "safe-buffer": "^5.0.1", 1617 | "timed-out": "^4.0.0", 1618 | "unzip-response": "^2.0.1", 1619 | "url-parse-lax": "^1.0.0" 1620 | } 1621 | }, 1622 | "graceful-fs": { 1623 | "version": "4.1.15", 1624 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.1.15.tgz", 1625 | "integrity": "sha512-6uHUhOPEBgQ24HM+r6b/QwWfZq+yiFcipKFrOFiBEnWdy5sdzYoi+pJeQaPI5qOLRFqWmAXUPQNsielzdLoecA==", 1626 | "dev": true 1627 | }, 1628 | "har-schema": { 1629 | "version": "2.0.0", 1630 | "resolved": "https://registry.npmjs.org/har-schema/-/har-schema-2.0.0.tgz", 1631 | "integrity": "sha1-qUwiJOvKwEeCoNkDVSHyRzW37JI=" 1632 | }, 1633 | "har-validator": { 1634 | "version": "5.1.3", 1635 | "resolved": "https://registry.npmjs.org/har-validator/-/har-validator-5.1.3.tgz", 1636 | "integrity": "sha512-sNvOCzEQNr/qrvJgc3UG/kD4QtlHycrzwS+6mfTrrSq97BvaYcPZZI1ZSqGSPR73Cxn4LKTD4PttRwfU7jWq5g==", 1637 | "requires": { 1638 | "ajv": "^6.5.5", 1639 | "har-schema": "^2.0.0" 1640 | } 1641 | }, 1642 | "has-flag": { 1643 | "version": "3.0.0", 1644 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 1645 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 1646 | "dev": true 1647 | }, 1648 | "has-value": { 1649 | "version": "1.0.0", 1650 | "resolved": "https://registry.npmjs.org/has-value/-/has-value-1.0.0.tgz", 1651 | "integrity": "sha1-GLKB2lhbHFxR3vJMkw7SmgvmsXc=", 1652 | "dev": true, 1653 | "requires": { 1654 | "get-value": "^2.0.6", 1655 | "has-values": "^1.0.0", 1656 | "isobject": "^3.0.0" 1657 | } 1658 | }, 1659 | "has-values": { 1660 | "version": "1.0.0", 1661 | "resolved": "https://registry.npmjs.org/has-values/-/has-values-1.0.0.tgz", 1662 | "integrity": "sha1-lbC2P+whRmGab+V/51Yo1aOe/k8=", 1663 | "dev": true, 1664 | "requires": { 1665 | "is-number": "^3.0.0", 1666 | "kind-of": "^4.0.0" 1667 | }, 1668 | "dependencies": { 1669 | "kind-of": { 1670 | "version": "4.0.0", 1671 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-4.0.0.tgz", 1672 | "integrity": "sha1-IIE989cSkosgc3hpGkUGb65y3Vc=", 1673 | "dev": true, 1674 | "requires": { 1675 | "is-buffer": "^1.1.5" 1676 | } 1677 | } 1678 | } 1679 | }, 1680 | "http-errors": { 1681 | "version": "1.6.3", 1682 | "resolved": "http://registry.npmjs.org/http-errors/-/http-errors-1.6.3.tgz", 1683 | "integrity": "sha1-i1VoC7S+KDoLW/TqLjhYC+HZMg0=", 1684 | "requires": { 1685 | "depd": "~1.1.2", 1686 | "inherits": "2.0.3", 1687 | "setprototypeof": "1.1.0", 1688 | "statuses": ">= 1.4.0 < 2" 1689 | } 1690 | }, 1691 | "http-signature": { 1692 | "version": "1.2.0", 1693 | "resolved": "https://registry.npmjs.org/http-signature/-/http-signature-1.2.0.tgz", 1694 | "integrity": "sha1-muzZJRFHcvPZW2WmCruPfBj7rOE=", 1695 | "requires": { 1696 | "assert-plus": "^1.0.0", 1697 | "jsprim": "^1.2.2", 1698 | "sshpk": "^1.7.0" 1699 | } 1700 | }, 1701 | "iconv-lite": { 1702 | "version": "0.4.23", 1703 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.23.tgz", 1704 | "integrity": "sha512-neyTUVFtahjf0mB3dZT77u+8O0QB89jFdnBkd5P1JgYPbPaia3gXXOVL2fq8VyU2gMMD7SaN7QukTB/pmXYvDA==", 1705 | "requires": { 1706 | "safer-buffer": ">= 2.1.2 < 3" 1707 | } 1708 | }, 1709 | "ignore-by-default": { 1710 | "version": "1.0.1", 1711 | "resolved": "https://registry.npmjs.org/ignore-by-default/-/ignore-by-default-1.0.1.tgz", 1712 | "integrity": "sha1-SMptcvbGo68Aqa1K5odr44ieKwk=", 1713 | "dev": true 1714 | }, 1715 | "import-lazy": { 1716 | "version": "2.1.0", 1717 | "resolved": "https://registry.npmjs.org/import-lazy/-/import-lazy-2.1.0.tgz", 1718 | "integrity": "sha1-BWmOPUXIjo1+nZLLBYTnfwlvPkM=", 1719 | "dev": true 1720 | }, 1721 | "imurmurhash": { 1722 | "version": "0.1.4", 1723 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 1724 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 1725 | "dev": true 1726 | }, 1727 | "inherits": { 1728 | "version": "2.0.3", 1729 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 1730 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=" 1731 | }, 1732 | "ini": { 1733 | "version": "1.3.5", 1734 | "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.5.tgz", 1735 | "integrity": "sha512-RZY5huIKCMRWDUqZlEi72f/lmXKMvuszcMBduliQ3nnWbx9X/ZBQO7DijMEYS9EhHBb2qacRUMtC7svLwe0lcw==", 1736 | "dev": true 1737 | }, 1738 | "ipaddr.js": { 1739 | "version": "1.8.0", 1740 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.8.0.tgz", 1741 | "integrity": "sha1-6qM9bd16zo9/b+DJygRA5wZzix4=" 1742 | }, 1743 | "is-accessor-descriptor": { 1744 | "version": "0.1.6", 1745 | "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-0.1.6.tgz", 1746 | "integrity": "sha1-qeEss66Nh2cn7u84Q/igiXtcmNY=", 1747 | "dev": true, 1748 | "requires": { 1749 | "kind-of": "^3.0.2" 1750 | }, 1751 | "dependencies": { 1752 | "kind-of": { 1753 | "version": "3.2.2", 1754 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 1755 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 1756 | "dev": true, 1757 | "requires": { 1758 | "is-buffer": "^1.1.5" 1759 | } 1760 | } 1761 | } 1762 | }, 1763 | "is-binary-path": { 1764 | "version": "1.0.1", 1765 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-1.0.1.tgz", 1766 | "integrity": "sha1-dfFmQrSA8YenEcgUFh/TpKdlWJg=", 1767 | "dev": true, 1768 | "requires": { 1769 | "binary-extensions": "^1.0.0" 1770 | } 1771 | }, 1772 | "is-buffer": { 1773 | "version": "1.1.6", 1774 | "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.6.tgz", 1775 | "integrity": "sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==", 1776 | "dev": true 1777 | }, 1778 | "is-ci": { 1779 | "version": "1.2.1", 1780 | "resolved": "https://registry.npmjs.org/is-ci/-/is-ci-1.2.1.tgz", 1781 | "integrity": "sha512-s6tfsaQaQi3JNciBH6shVqEDvhGut0SUXr31ag8Pd8BBbVVlcGfWhpPmEOoM6RJ5TFhbypvf5yyRw/VXW1IiWg==", 1782 | "dev": true, 1783 | "requires": { 1784 | "ci-info": "^1.5.0" 1785 | } 1786 | }, 1787 | "is-data-descriptor": { 1788 | "version": "0.1.4", 1789 | "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-0.1.4.tgz", 1790 | "integrity": "sha1-C17mSDiOLIYCgueT8YVv7D8wG1Y=", 1791 | "dev": true, 1792 | "requires": { 1793 | "kind-of": "^3.0.2" 1794 | }, 1795 | "dependencies": { 1796 | "kind-of": { 1797 | "version": "3.2.2", 1798 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 1799 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 1800 | "dev": true, 1801 | "requires": { 1802 | "is-buffer": "^1.1.5" 1803 | } 1804 | } 1805 | } 1806 | }, 1807 | "is-descriptor": { 1808 | "version": "0.1.6", 1809 | "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-0.1.6.tgz", 1810 | "integrity": "sha512-avDYr0SB3DwO9zsMov0gKCESFYqCnE4hq/4z3TdUlukEy5t9C0YRq7HLrsN52NAcqXKaepeCD0n+B0arnVG3Hg==", 1811 | "dev": true, 1812 | "requires": { 1813 | "is-accessor-descriptor": "^0.1.6", 1814 | "is-data-descriptor": "^0.1.4", 1815 | "kind-of": "^5.0.0" 1816 | }, 1817 | "dependencies": { 1818 | "kind-of": { 1819 | "version": "5.1.0", 1820 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-5.1.0.tgz", 1821 | "integrity": "sha512-NGEErnH6F2vUuXDh+OlbcKW7/wOcfdRHaZ7VWtqCztfHri/++YKmP51OdWeGPuqCOba6kk2OTe5d02VmTB80Pw==", 1822 | "dev": true 1823 | } 1824 | } 1825 | }, 1826 | "is-extendable": { 1827 | "version": "0.1.1", 1828 | "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-0.1.1.tgz", 1829 | "integrity": "sha1-YrEQ4omkcUGOPsNqYX1HLjAd/Ik=", 1830 | "dev": true 1831 | }, 1832 | "is-extglob": { 1833 | "version": "2.1.1", 1834 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1835 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 1836 | "dev": true 1837 | }, 1838 | "is-fullwidth-code-point": { 1839 | "version": "2.0.0", 1840 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 1841 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 1842 | "dev": true 1843 | }, 1844 | "is-glob": { 1845 | "version": "4.0.0", 1846 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.0.tgz", 1847 | "integrity": "sha1-lSHHaEXMJhCoUgPd8ICpWML/q8A=", 1848 | "dev": true, 1849 | "requires": { 1850 | "is-extglob": "^2.1.1" 1851 | } 1852 | }, 1853 | "is-installed-globally": { 1854 | "version": "0.1.0", 1855 | "resolved": "https://registry.npmjs.org/is-installed-globally/-/is-installed-globally-0.1.0.tgz", 1856 | "integrity": "sha1-Df2Y9akRFxbdU13aZJL2e/PSWoA=", 1857 | "dev": true, 1858 | "requires": { 1859 | "global-dirs": "^0.1.0", 1860 | "is-path-inside": "^1.0.0" 1861 | } 1862 | }, 1863 | "is-npm": { 1864 | "version": "1.0.0", 1865 | "resolved": "https://registry.npmjs.org/is-npm/-/is-npm-1.0.0.tgz", 1866 | "integrity": "sha1-8vtjpl5JBbQGyGBydloaTceTufQ=", 1867 | "dev": true 1868 | }, 1869 | "is-number": { 1870 | "version": "3.0.0", 1871 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-3.0.0.tgz", 1872 | "integrity": "sha1-JP1iAaR4LPUFYcgQJ2r8fRLXEZU=", 1873 | "dev": true, 1874 | "requires": { 1875 | "kind-of": "^3.0.2" 1876 | }, 1877 | "dependencies": { 1878 | "kind-of": { 1879 | "version": "3.2.2", 1880 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 1881 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 1882 | "dev": true, 1883 | "requires": { 1884 | "is-buffer": "^1.1.5" 1885 | } 1886 | } 1887 | } 1888 | }, 1889 | "is-obj": { 1890 | "version": "1.0.1", 1891 | "resolved": "http://registry.npmjs.org/is-obj/-/is-obj-1.0.1.tgz", 1892 | "integrity": "sha1-PkcprB9f3gJc19g6iW2rn09n2w8=", 1893 | "dev": true 1894 | }, 1895 | "is-path-inside": { 1896 | "version": "1.0.1", 1897 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-1.0.1.tgz", 1898 | "integrity": "sha1-jvW33lBDej/cprToZe96pVy0gDY=", 1899 | "dev": true, 1900 | "requires": { 1901 | "path-is-inside": "^1.0.1" 1902 | } 1903 | }, 1904 | "is-plain-object": { 1905 | "version": "2.0.4", 1906 | "resolved": "https://registry.npmjs.org/is-plain-object/-/is-plain-object-2.0.4.tgz", 1907 | "integrity": "sha512-h5PpgXkWitc38BBMYawTYMWJHFZJVnBquFE57xFpjB8pJFiF6gZ+bU+WyI/yqXiFR5mdLsgYNaPe8uao6Uv9Og==", 1908 | "dev": true, 1909 | "requires": { 1910 | "isobject": "^3.0.1" 1911 | } 1912 | }, 1913 | "is-redirect": { 1914 | "version": "1.0.0", 1915 | "resolved": "https://registry.npmjs.org/is-redirect/-/is-redirect-1.0.0.tgz", 1916 | "integrity": "sha1-HQPd7VO9jbDzDCbk+V02/HyH3CQ=", 1917 | "dev": true 1918 | }, 1919 | "is-retry-allowed": { 1920 | "version": "1.1.0", 1921 | "resolved": "https://registry.npmjs.org/is-retry-allowed/-/is-retry-allowed-1.1.0.tgz", 1922 | "integrity": "sha1-EaBgVotnM5REAz0BJaYaINVk+zQ=", 1923 | "dev": true 1924 | }, 1925 | "is-stream": { 1926 | "version": "1.1.0", 1927 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-1.1.0.tgz", 1928 | "integrity": "sha1-EtSj3U5o4Lec6428hBc66A2RykQ=", 1929 | "dev": true 1930 | }, 1931 | "is-typedarray": { 1932 | "version": "1.0.0", 1933 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", 1934 | "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=" 1935 | }, 1936 | "is-windows": { 1937 | "version": "1.0.2", 1938 | "resolved": "https://registry.npmjs.org/is-windows/-/is-windows-1.0.2.tgz", 1939 | "integrity": "sha512-eXK1UInq2bPmjyX6e3VHIzMLobc4J94i4AWn+Hpq3OU5KkrRC96OAcR3PRJ/pGu6m8TRnBHP9dkXQVsT/COVIA==", 1940 | "dev": true 1941 | }, 1942 | "isarray": { 1943 | "version": "1.0.0", 1944 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 1945 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", 1946 | "dev": true 1947 | }, 1948 | "isexe": { 1949 | "version": "2.0.0", 1950 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1951 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 1952 | "dev": true 1953 | }, 1954 | "isobject": { 1955 | "version": "3.0.1", 1956 | "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", 1957 | "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=", 1958 | "dev": true 1959 | }, 1960 | "isstream": { 1961 | "version": "0.1.2", 1962 | "resolved": "https://registry.npmjs.org/isstream/-/isstream-0.1.2.tgz", 1963 | "integrity": "sha1-R+Y/evVa+m+S4VAOaQ64uFKcCZo=" 1964 | }, 1965 | "jsbn": { 1966 | "version": "0.1.1", 1967 | "resolved": "https://registry.npmjs.org/jsbn/-/jsbn-0.1.1.tgz", 1968 | "integrity": "sha1-peZUwuWi3rXyAdls77yoDA7y9RM=" 1969 | }, 1970 | "json-schema": { 1971 | "version": "0.2.3", 1972 | "resolved": "https://registry.npmjs.org/json-schema/-/json-schema-0.2.3.tgz", 1973 | "integrity": "sha1-tIDIkuWaLwWVTOcnvT8qTogvnhM=" 1974 | }, 1975 | "json-schema-traverse": { 1976 | "version": "0.4.1", 1977 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 1978 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==" 1979 | }, 1980 | "json-stringify-safe": { 1981 | "version": "5.0.1", 1982 | "resolved": "https://registry.npmjs.org/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz", 1983 | "integrity": "sha1-Epai1Y/UXxmg9s4B1lcB4sc1tus=" 1984 | }, 1985 | "jsonwebtoken": { 1986 | "version": "8.3.0", 1987 | "resolved": "https://registry.npmjs.org/jsonwebtoken/-/jsonwebtoken-8.3.0.tgz", 1988 | "integrity": "sha512-oge/hvlmeJCH+iIz1DwcO7vKPkNGJHhgkspk8OH3VKlw+mbi42WtD4ig1+VXRln765vxptAv+xT26Fd3cteqag==", 1989 | "requires": { 1990 | "jws": "^3.1.5", 1991 | "lodash.includes": "^4.3.0", 1992 | "lodash.isboolean": "^3.0.3", 1993 | "lodash.isinteger": "^4.0.4", 1994 | "lodash.isnumber": "^3.0.3", 1995 | "lodash.isplainobject": "^4.0.6", 1996 | "lodash.isstring": "^4.0.1", 1997 | "lodash.once": "^4.0.0", 1998 | "ms": "^2.1.1" 1999 | }, 2000 | "dependencies": { 2001 | "ms": { 2002 | "version": "2.1.1", 2003 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 2004 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==" 2005 | } 2006 | } 2007 | }, 2008 | "jsprim": { 2009 | "version": "1.4.1", 2010 | "resolved": "https://registry.npmjs.org/jsprim/-/jsprim-1.4.1.tgz", 2011 | "integrity": "sha1-MT5mvB5cwG5Di8G3SZwuXFastqI=", 2012 | "requires": { 2013 | "assert-plus": "1.0.0", 2014 | "extsprintf": "1.3.0", 2015 | "json-schema": "0.2.3", 2016 | "verror": "1.10.0" 2017 | } 2018 | }, 2019 | "jwa": { 2020 | "version": "1.1.6", 2021 | "resolved": "https://registry.npmjs.org/jwa/-/jwa-1.1.6.tgz", 2022 | "integrity": "sha512-tBO/cf++BUsJkYql/kBbJroKOgHWEigTKBAjjBEmrMGYd1QMBC74Hr4Wo2zCZw6ZrVhlJPvoMrkcOnlWR/DJfw==", 2023 | "requires": { 2024 | "buffer-equal-constant-time": "1.0.1", 2025 | "ecdsa-sig-formatter": "1.0.10", 2026 | "safe-buffer": "^5.0.1" 2027 | } 2028 | }, 2029 | "jws": { 2030 | "version": "3.1.5", 2031 | "resolved": "https://registry.npmjs.org/jws/-/jws-3.1.5.tgz", 2032 | "integrity": "sha512-GsCSexFADNQUr8T5HPJvayTjvPIfoyJPtLQBwn5a4WZQchcrPMPMAWcC1AzJVRDKyD6ZPROPAxgv6rfHViO4uQ==", 2033 | "requires": { 2034 | "jwa": "^1.1.5", 2035 | "safe-buffer": "^5.0.1" 2036 | } 2037 | }, 2038 | "kareem": { 2039 | "version": "2.3.0", 2040 | "resolved": "https://registry.npmjs.org/kareem/-/kareem-2.3.0.tgz", 2041 | "integrity": "sha512-6hHxsp9e6zQU8nXsP+02HGWXwTkOEw6IROhF2ZA28cYbUk4eJ6QbtZvdqZOdD9YPKghG3apk5eOCvs+tLl3lRg==" 2042 | }, 2043 | "kind-of": { 2044 | "version": "6.0.2", 2045 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.2.tgz", 2046 | "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==", 2047 | "dev": true 2048 | }, 2049 | "latest-version": { 2050 | "version": "3.1.0", 2051 | "resolved": "https://registry.npmjs.org/latest-version/-/latest-version-3.1.0.tgz", 2052 | "integrity": "sha1-ogU4P+oyKzO1rjsYq+4NwvNW7hU=", 2053 | "dev": true, 2054 | "requires": { 2055 | "package-json": "^4.0.0" 2056 | } 2057 | }, 2058 | "lodash": { 2059 | "version": "4.17.11", 2060 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.11.tgz", 2061 | "integrity": "sha512-cQKh8igo5QUhZ7lg38DYWAxMvjSAKG0A8wGSVimP07SIUEK2UO+arSRKbRZWtelMtN5V0Hkwh5ryOto/SshYIg==" 2062 | }, 2063 | "lodash.debounce": { 2064 | "version": "4.0.8", 2065 | "resolved": "https://registry.npmjs.org/lodash.debounce/-/lodash.debounce-4.0.8.tgz", 2066 | "integrity": "sha1-gteb/zCmfEAF/9XiUVMArZyk168=", 2067 | "dev": true 2068 | }, 2069 | "lodash.get": { 2070 | "version": "4.4.2", 2071 | "resolved": "https://registry.npmjs.org/lodash.get/-/lodash.get-4.4.2.tgz", 2072 | "integrity": "sha1-LRd/ZS+jHpObRDjVNBSZ36OCXpk=" 2073 | }, 2074 | "lodash.includes": { 2075 | "version": "4.3.0", 2076 | "resolved": "https://registry.npmjs.org/lodash.includes/-/lodash.includes-4.3.0.tgz", 2077 | "integrity": "sha1-YLuYqHy5I8aMoeUTJUgzFISfVT8=" 2078 | }, 2079 | "lodash.isboolean": { 2080 | "version": "3.0.3", 2081 | "resolved": "https://registry.npmjs.org/lodash.isboolean/-/lodash.isboolean-3.0.3.tgz", 2082 | "integrity": "sha1-bC4XHbKiV82WgC/UOwGyDV9YcPY=" 2083 | }, 2084 | "lodash.isinteger": { 2085 | "version": "4.0.4", 2086 | "resolved": "https://registry.npmjs.org/lodash.isinteger/-/lodash.isinteger-4.0.4.tgz", 2087 | "integrity": "sha1-YZwK89A/iwTDH1iChAt3sRzWg0M=" 2088 | }, 2089 | "lodash.isnumber": { 2090 | "version": "3.0.3", 2091 | "resolved": "https://registry.npmjs.org/lodash.isnumber/-/lodash.isnumber-3.0.3.tgz", 2092 | "integrity": "sha1-POdoEMWSjQM1IwGsKHMX8RwLH/w=" 2093 | }, 2094 | "lodash.isplainobject": { 2095 | "version": "4.0.6", 2096 | "resolved": "https://registry.npmjs.org/lodash.isplainobject/-/lodash.isplainobject-4.0.6.tgz", 2097 | "integrity": "sha1-fFJqUtibRcRcxpC4gWO+BJf1UMs=" 2098 | }, 2099 | "lodash.isstring": { 2100 | "version": "4.0.1", 2101 | "resolved": "https://registry.npmjs.org/lodash.isstring/-/lodash.isstring-4.0.1.tgz", 2102 | "integrity": "sha1-1SfftUVuynzJu5XV2ur4i6VKVFE=" 2103 | }, 2104 | "lodash.once": { 2105 | "version": "4.1.1", 2106 | "resolved": "https://registry.npmjs.org/lodash.once/-/lodash.once-4.1.1.tgz", 2107 | "integrity": "sha1-DdOXEhPHxW34gJd9UEyI+0cal6w=" 2108 | }, 2109 | "lowercase-keys": { 2110 | "version": "1.0.1", 2111 | "resolved": "https://registry.npmjs.org/lowercase-keys/-/lowercase-keys-1.0.1.tgz", 2112 | "integrity": "sha512-G2Lj61tXDnVFFOi8VZds+SoQjtQC3dgokKdDG2mTm1tx4m50NUHBOZSBwQQHyy0V12A0JTG4icfZQH+xPyh8VA==", 2113 | "dev": true 2114 | }, 2115 | "lru-cache": { 2116 | "version": "4.1.3", 2117 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.1.3.tgz", 2118 | "integrity": "sha512-fFEhvcgzuIoJVUF8fYr5KR0YqxD238zgObTps31YdADwPPAp82a4M8TrckkWyx7ekNlf9aBcVn81cFwwXngrJA==", 2119 | "dev": true, 2120 | "requires": { 2121 | "pseudomap": "^1.0.2", 2122 | "yallist": "^2.1.2" 2123 | } 2124 | }, 2125 | "make-dir": { 2126 | "version": "1.3.0", 2127 | "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-1.3.0.tgz", 2128 | "integrity": "sha512-2w31R7SJtieJJnQtGc7RVL2StM2vGYVfqUOvUDxH6bC6aJTxPxTF0GnIgCyu7tjockiUWAYQRbxa7vKn34s5sQ==", 2129 | "dev": true, 2130 | "requires": { 2131 | "pify": "^3.0.0" 2132 | } 2133 | }, 2134 | "map-cache": { 2135 | "version": "0.2.2", 2136 | "resolved": "https://registry.npmjs.org/map-cache/-/map-cache-0.2.2.tgz", 2137 | "integrity": "sha1-wyq9C9ZSXZsFFkW7TyasXcmKDb8=", 2138 | "dev": true 2139 | }, 2140 | "map-stream": { 2141 | "version": "0.0.7", 2142 | "resolved": "https://registry.npmjs.org/map-stream/-/map-stream-0.0.7.tgz", 2143 | "integrity": "sha1-ih8HiW2CsQkmvTdEokIACfiJdKg=", 2144 | "dev": true 2145 | }, 2146 | "map-visit": { 2147 | "version": "1.0.0", 2148 | "resolved": "https://registry.npmjs.org/map-visit/-/map-visit-1.0.0.tgz", 2149 | "integrity": "sha1-7Nyo8TFE5mDxtb1B8S80edmN+48=", 2150 | "dev": true, 2151 | "requires": { 2152 | "object-visit": "^1.0.0" 2153 | } 2154 | }, 2155 | "media-typer": { 2156 | "version": "0.3.0", 2157 | "resolved": "http://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 2158 | "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g=" 2159 | }, 2160 | "memory-pager": { 2161 | "version": "1.1.0", 2162 | "resolved": "https://registry.npmjs.org/memory-pager/-/memory-pager-1.1.0.tgz", 2163 | "integrity": "sha512-Mf9OHV/Y7h6YWDxTzX/b4ZZ4oh9NSXblQL8dtPCOomOtZciEHxePR78+uHFLLlsk01A6jVHhHsQZZ/WcIPpnzg==", 2164 | "optional": true 2165 | }, 2166 | "merge-descriptors": { 2167 | "version": "1.0.1", 2168 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 2169 | "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E=" 2170 | }, 2171 | "methods": { 2172 | "version": "1.1.2", 2173 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 2174 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=" 2175 | }, 2176 | "micromatch": { 2177 | "version": "3.1.10", 2178 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-3.1.10.tgz", 2179 | "integrity": "sha512-MWikgl9n9M3w+bpsY3He8L+w9eF9338xRl8IAO5viDizwSzziFEyUzo2xrrloB64ADbTf8uA8vRqqttDTOmccg==", 2180 | "dev": true, 2181 | "requires": { 2182 | "arr-diff": "^4.0.0", 2183 | "array-unique": "^0.3.2", 2184 | "braces": "^2.3.1", 2185 | "define-property": "^2.0.2", 2186 | "extend-shallow": "^3.0.2", 2187 | "extglob": "^2.0.4", 2188 | "fragment-cache": "^0.2.1", 2189 | "kind-of": "^6.0.2", 2190 | "nanomatch": "^1.2.9", 2191 | "object.pick": "^1.3.0", 2192 | "regex-not": "^1.0.0", 2193 | "snapdragon": "^0.8.1", 2194 | "to-regex": "^3.0.2" 2195 | } 2196 | }, 2197 | "mime": { 2198 | "version": "1.4.1", 2199 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.4.1.tgz", 2200 | "integrity": "sha512-KI1+qOZu5DcW6wayYHSzR/tXKCDC5Om4s1z2QJjDULzLcmf3DvzS7oluY4HCTrc+9FiKmWUgeNLg7W3uIQvxtQ==" 2201 | }, 2202 | "mime-db": { 2203 | "version": "1.37.0", 2204 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.37.0.tgz", 2205 | "integrity": "sha512-R3C4db6bgQhlIhPU48fUtdVmKnflq+hRdad7IyKhtFj06VPNVdk2RhiYL3UjQIlso8L+YxAtFkobT0VK+S/ybg==" 2206 | }, 2207 | "mime-types": { 2208 | "version": "2.1.21", 2209 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.21.tgz", 2210 | "integrity": "sha512-3iL6DbwpyLzjR3xHSFNFeb9Nz/M8WDkX33t1GFQnFOllWk8pOrh/LSrB5OXlnlW5P9LH73X6loW/eogc+F5lJg==", 2211 | "requires": { 2212 | "mime-db": "~1.37.0" 2213 | } 2214 | }, 2215 | "minimatch": { 2216 | "version": "3.0.4", 2217 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 2218 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 2219 | "dev": true, 2220 | "requires": { 2221 | "brace-expansion": "^1.1.7" 2222 | } 2223 | }, 2224 | "minimist": { 2225 | "version": "1.2.0", 2226 | "resolved": "http://registry.npmjs.org/minimist/-/minimist-1.2.0.tgz", 2227 | "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=", 2228 | "dev": true 2229 | }, 2230 | "mixin-deep": { 2231 | "version": "1.3.1", 2232 | "resolved": "https://registry.npmjs.org/mixin-deep/-/mixin-deep-1.3.1.tgz", 2233 | "integrity": "sha512-8ZItLHeEgaqEvd5lYBXfm4EZSFCX29Jb9K+lAHhDKzReKBQKj3R+7NOF6tjqYi9t4oI8VUfaWITJQm86wnXGNQ==", 2234 | "dev": true, 2235 | "requires": { 2236 | "for-in": "^1.0.2", 2237 | "is-extendable": "^1.0.1" 2238 | }, 2239 | "dependencies": { 2240 | "is-extendable": { 2241 | "version": "1.0.1", 2242 | "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-1.0.1.tgz", 2243 | "integrity": "sha512-arnXMxT1hhoKo9k1LZdmlNyJdDDfy2v0fXjFlmok4+i8ul/6WlbVge9bhM74OpNPQPMGUToDtz+KXa1PneJxOA==", 2244 | "dev": true, 2245 | "requires": { 2246 | "is-plain-object": "^2.0.4" 2247 | } 2248 | } 2249 | } 2250 | }, 2251 | "mongodb": { 2252 | "version": "3.1.8", 2253 | "resolved": "https://registry.npmjs.org/mongodb/-/mongodb-3.1.8.tgz", 2254 | "integrity": "sha512-yNKwYxQ6m00NV6+pMoWoheFTHSQVv1KkSrfOhRDYMILGWDYtUtQRqHrFqU75rmPIY8hMozVft8zdC4KYMWaM3Q==", 2255 | "requires": { 2256 | "mongodb-core": "3.1.7", 2257 | "safe-buffer": "^5.1.2" 2258 | } 2259 | }, 2260 | "mongodb-core": { 2261 | "version": "3.1.7", 2262 | "resolved": "https://registry.npmjs.org/mongodb-core/-/mongodb-core-3.1.7.tgz", 2263 | "integrity": "sha512-YffpSrLmgFNmrvkGx+yX00KyBNk64C0BalfEn6vHHkXtcMUGXw8nxrMmhq5eXPLLlYeBpD/CsgNxE2Chf0o4zQ==", 2264 | "requires": { 2265 | "bson": "^1.1.0", 2266 | "require_optional": "^1.0.1", 2267 | "safe-buffer": "^5.1.2", 2268 | "saslprep": "^1.0.0" 2269 | } 2270 | }, 2271 | "mongoose": { 2272 | "version": "5.3.11", 2273 | "resolved": "https://registry.npmjs.org/mongoose/-/mongoose-5.3.11.tgz", 2274 | "integrity": "sha512-LrsatxtUfZAerAxyFiaw/8T8M4T9Ff9+6wFkJwfTVDz9skX+HVOs70QOzTDawz0k0Q0I6qt9xv/ZYQi2Paykgw==", 2275 | "requires": { 2276 | "async": "2.6.1", 2277 | "bson": "~1.1.0", 2278 | "kareem": "2.3.0", 2279 | "lodash.get": "4.4.2", 2280 | "mongodb": "3.1.8", 2281 | "mongodb-core": "3.1.7", 2282 | "mongoose-legacy-pluralize": "1.0.2", 2283 | "mpath": "0.5.1", 2284 | "mquery": "3.2.0", 2285 | "ms": "2.0.0", 2286 | "regexp-clone": "0.0.1", 2287 | "safe-buffer": "5.1.2", 2288 | "sliced": "1.0.1" 2289 | } 2290 | }, 2291 | "mongoose-legacy-pluralize": { 2292 | "version": "1.0.2", 2293 | "resolved": "https://registry.npmjs.org/mongoose-legacy-pluralize/-/mongoose-legacy-pluralize-1.0.2.tgz", 2294 | "integrity": "sha512-Yo/7qQU4/EyIS8YDFSeenIvXxZN+ld7YdV9LqFVQJzTLye8unujAWPZ4NWKfFA+RNjh+wvTWKY9Z3E5XM6ZZiQ==" 2295 | }, 2296 | "morgan": { 2297 | "version": "1.9.1", 2298 | "resolved": "https://registry.npmjs.org/morgan/-/morgan-1.9.1.tgz", 2299 | "integrity": "sha512-HQStPIV4y3afTiCYVxirakhlCfGkI161c76kKFca7Fk1JusM//Qeo1ej2XaMniiNeaZklMVrh3vTtIzpzwbpmA==", 2300 | "requires": { 2301 | "basic-auth": "~2.0.0", 2302 | "debug": "2.6.9", 2303 | "depd": "~1.1.2", 2304 | "on-finished": "~2.3.0", 2305 | "on-headers": "~1.0.1" 2306 | } 2307 | }, 2308 | "mpath": { 2309 | "version": "0.5.1", 2310 | "resolved": "https://registry.npmjs.org/mpath/-/mpath-0.5.1.tgz", 2311 | "integrity": "sha512-H8OVQ+QEz82sch4wbODFOz+3YQ61FYz/z3eJ5pIdbMEaUzDqA268Wd+Vt4Paw9TJfvDgVKaayC0gBzMIw2jhsg==" 2312 | }, 2313 | "mquery": { 2314 | "version": "3.2.0", 2315 | "resolved": "https://registry.npmjs.org/mquery/-/mquery-3.2.0.tgz", 2316 | "integrity": "sha512-qPJcdK/yqcbQiKoemAt62Y0BAc0fTEKo1IThodBD+O5meQRJT/2HSe5QpBNwaa4CjskoGrYWsEyjkqgiE0qjhg==", 2317 | "requires": { 2318 | "bluebird": "3.5.1", 2319 | "debug": "3.1.0", 2320 | "regexp-clone": "0.0.1", 2321 | "safe-buffer": "5.1.2", 2322 | "sliced": "1.0.1" 2323 | }, 2324 | "dependencies": { 2325 | "debug": { 2326 | "version": "3.1.0", 2327 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", 2328 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", 2329 | "requires": { 2330 | "ms": "2.0.0" 2331 | } 2332 | } 2333 | } 2334 | }, 2335 | "ms": { 2336 | "version": "2.0.0", 2337 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 2338 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 2339 | }, 2340 | "nan": { 2341 | "version": "2.11.1", 2342 | "resolved": "https://registry.npmjs.org/nan/-/nan-2.11.1.tgz", 2343 | "integrity": "sha512-iji6k87OSXa0CcrLl9z+ZiYSuR2o+c0bGuNmXdrhTQTakxytAFsC56SArGYoiHlJlFoHSnvmhpceZJaXkVuOtA==", 2344 | "dev": true, 2345 | "optional": true 2346 | }, 2347 | "nanomatch": { 2348 | "version": "1.2.13", 2349 | "resolved": "https://registry.npmjs.org/nanomatch/-/nanomatch-1.2.13.tgz", 2350 | "integrity": "sha512-fpoe2T0RbHwBTBUOftAfBPaDEi06ufaUai0mE6Yn1kacc3SnTErfb/h+X94VXzI64rKFHYImXSvdwGGCmwOqCA==", 2351 | "dev": true, 2352 | "requires": { 2353 | "arr-diff": "^4.0.0", 2354 | "array-unique": "^0.3.2", 2355 | "define-property": "^2.0.2", 2356 | "extend-shallow": "^3.0.2", 2357 | "fragment-cache": "^0.2.1", 2358 | "is-windows": "^1.0.2", 2359 | "kind-of": "^6.0.2", 2360 | "object.pick": "^1.3.0", 2361 | "regex-not": "^1.0.0", 2362 | "snapdragon": "^0.8.1", 2363 | "to-regex": "^3.0.1" 2364 | } 2365 | }, 2366 | "negotiator": { 2367 | "version": "0.6.1", 2368 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.1.tgz", 2369 | "integrity": "sha1-KzJxhOiZIQEXeyhWP7XnECrNDKk=" 2370 | }, 2371 | "nodemon": { 2372 | "version": "1.18.6", 2373 | "resolved": "https://registry.npmjs.org/nodemon/-/nodemon-1.18.6.tgz", 2374 | "integrity": "sha512-4pHQNYEZun+IkIC2jCaXEhkZnfA7rQe73i8RkdRyDJls/K+WxR7IpI5uNUsAvQ0zWvYcCDNGD+XVtw2ZG86/uQ==", 2375 | "dev": true, 2376 | "requires": { 2377 | "chokidar": "^2.0.4", 2378 | "debug": "^3.1.0", 2379 | "ignore-by-default": "^1.0.1", 2380 | "minimatch": "^3.0.4", 2381 | "pstree.remy": "^1.1.0", 2382 | "semver": "^5.5.0", 2383 | "supports-color": "^5.2.0", 2384 | "touch": "^3.1.0", 2385 | "undefsafe": "^2.0.2", 2386 | "update-notifier": "^2.3.0" 2387 | }, 2388 | "dependencies": { 2389 | "debug": { 2390 | "version": "3.2.6", 2391 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.6.tgz", 2392 | "integrity": "sha512-mel+jf7nrtEl5Pn1Qx46zARXKDpBbvzezse7p7LqINmdoIk8PYP5SySaxEmYv6TZ0JyEKA1hsCId6DIhgITtWQ==", 2393 | "dev": true, 2394 | "requires": { 2395 | "ms": "^2.1.1" 2396 | } 2397 | }, 2398 | "ms": { 2399 | "version": "2.1.1", 2400 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 2401 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==", 2402 | "dev": true 2403 | } 2404 | } 2405 | }, 2406 | "nopt": { 2407 | "version": "1.0.10", 2408 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-1.0.10.tgz", 2409 | "integrity": "sha1-bd0hvSoxQXuScn3Vhfim83YI6+4=", 2410 | "dev": true, 2411 | "requires": { 2412 | "abbrev": "1" 2413 | } 2414 | }, 2415 | "normalize-path": { 2416 | "version": "2.1.1", 2417 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-2.1.1.tgz", 2418 | "integrity": "sha1-GrKLVW4Zg2Oowab35vogE3/mrtk=", 2419 | "dev": true, 2420 | "requires": { 2421 | "remove-trailing-separator": "^1.0.1" 2422 | } 2423 | }, 2424 | "npm-run-path": { 2425 | "version": "2.0.2", 2426 | "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-2.0.2.tgz", 2427 | "integrity": "sha1-NakjLfo11wZ7TLLd8jV7GHFTbF8=", 2428 | "dev": true, 2429 | "requires": { 2430 | "path-key": "^2.0.0" 2431 | } 2432 | }, 2433 | "oauth-sign": { 2434 | "version": "0.9.0", 2435 | "resolved": "https://registry.npmjs.org/oauth-sign/-/oauth-sign-0.9.0.tgz", 2436 | "integrity": "sha512-fexhUFFPTGV8ybAtSIGbV6gOkSv8UtRbDBnAyLQw4QPKkgNlsH2ByPGtMUqdWkos6YCRmAqViwgZrJc/mRDzZQ==" 2437 | }, 2438 | "object-assign": { 2439 | "version": "4.1.1", 2440 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 2441 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=" 2442 | }, 2443 | "object-copy": { 2444 | "version": "0.1.0", 2445 | "resolved": "https://registry.npmjs.org/object-copy/-/object-copy-0.1.0.tgz", 2446 | "integrity": "sha1-fn2Fi3gb18mRpBupde04EnVOmYw=", 2447 | "dev": true, 2448 | "requires": { 2449 | "copy-descriptor": "^0.1.0", 2450 | "define-property": "^0.2.5", 2451 | "kind-of": "^3.0.3" 2452 | }, 2453 | "dependencies": { 2454 | "define-property": { 2455 | "version": "0.2.5", 2456 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", 2457 | "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", 2458 | "dev": true, 2459 | "requires": { 2460 | "is-descriptor": "^0.1.0" 2461 | } 2462 | }, 2463 | "kind-of": { 2464 | "version": "3.2.2", 2465 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 2466 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 2467 | "dev": true, 2468 | "requires": { 2469 | "is-buffer": "^1.1.5" 2470 | } 2471 | } 2472 | } 2473 | }, 2474 | "object-visit": { 2475 | "version": "1.0.1", 2476 | "resolved": "https://registry.npmjs.org/object-visit/-/object-visit-1.0.1.tgz", 2477 | "integrity": "sha1-95xEk68MU3e1n+OdOV5BBC3QRbs=", 2478 | "dev": true, 2479 | "requires": { 2480 | "isobject": "^3.0.0" 2481 | } 2482 | }, 2483 | "object.pick": { 2484 | "version": "1.3.0", 2485 | "resolved": "https://registry.npmjs.org/object.pick/-/object.pick-1.3.0.tgz", 2486 | "integrity": "sha1-h6EKxMFpS9Lhy/U1kaZhQftd10c=", 2487 | "dev": true, 2488 | "requires": { 2489 | "isobject": "^3.0.1" 2490 | } 2491 | }, 2492 | "on-finished": { 2493 | "version": "2.3.0", 2494 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", 2495 | "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=", 2496 | "requires": { 2497 | "ee-first": "1.1.1" 2498 | } 2499 | }, 2500 | "on-headers": { 2501 | "version": "1.0.1", 2502 | "resolved": "https://registry.npmjs.org/on-headers/-/on-headers-1.0.1.tgz", 2503 | "integrity": "sha1-ko9dD0cNSTQmUepnlLCFfBAGk/c=" 2504 | }, 2505 | "p-finally": { 2506 | "version": "1.0.0", 2507 | "resolved": "https://registry.npmjs.org/p-finally/-/p-finally-1.0.0.tgz", 2508 | "integrity": "sha1-P7z7FbiZpEEjs0ttzBi3JDNqLK4=", 2509 | "dev": true 2510 | }, 2511 | "package-json": { 2512 | "version": "4.0.1", 2513 | "resolved": "https://registry.npmjs.org/package-json/-/package-json-4.0.1.tgz", 2514 | "integrity": "sha1-iGmgQBJTZhxMTKPabCEh7VVfXu0=", 2515 | "dev": true, 2516 | "requires": { 2517 | "got": "^6.7.1", 2518 | "registry-auth-token": "^3.0.1", 2519 | "registry-url": "^3.0.3", 2520 | "semver": "^5.1.0" 2521 | } 2522 | }, 2523 | "parseurl": { 2524 | "version": "1.3.2", 2525 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.2.tgz", 2526 | "integrity": "sha1-/CidTtiZMRlGDBViUyYs3I3mW/M=" 2527 | }, 2528 | "pascalcase": { 2529 | "version": "0.1.1", 2530 | "resolved": "https://registry.npmjs.org/pascalcase/-/pascalcase-0.1.1.tgz", 2531 | "integrity": "sha1-s2PlXoAGym/iF4TS2yK9FdeRfxQ=", 2532 | "dev": true 2533 | }, 2534 | "path-dirname": { 2535 | "version": "1.0.2", 2536 | "resolved": "https://registry.npmjs.org/path-dirname/-/path-dirname-1.0.2.tgz", 2537 | "integrity": "sha1-zDPSTVJeCZpTiMAzbG4yuRYGCeA=", 2538 | "dev": true 2539 | }, 2540 | "path-is-absolute": { 2541 | "version": "1.0.1", 2542 | "resolved": "http://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 2543 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 2544 | "dev": true 2545 | }, 2546 | "path-is-inside": { 2547 | "version": "1.0.2", 2548 | "resolved": "https://registry.npmjs.org/path-is-inside/-/path-is-inside-1.0.2.tgz", 2549 | "integrity": "sha1-NlQX3t5EQw0cEa9hAn+s8HS9/FM=", 2550 | "dev": true 2551 | }, 2552 | "path-key": { 2553 | "version": "2.0.1", 2554 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", 2555 | "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=", 2556 | "dev": true 2557 | }, 2558 | "path-to-regexp": { 2559 | "version": "0.1.7", 2560 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 2561 | "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w=" 2562 | }, 2563 | "pause-stream": { 2564 | "version": "0.0.11", 2565 | "resolved": "http://registry.npmjs.org/pause-stream/-/pause-stream-0.0.11.tgz", 2566 | "integrity": "sha1-/lo0sMvOErWqaitAPuLnO2AvFEU=", 2567 | "dev": true, 2568 | "requires": { 2569 | "through": "~2.3" 2570 | } 2571 | }, 2572 | "performance-now": { 2573 | "version": "2.1.0", 2574 | "resolved": "https://registry.npmjs.org/performance-now/-/performance-now-2.1.0.tgz", 2575 | "integrity": "sha1-Ywn04OX6kT7BxpMHrjZLSzd8nns=" 2576 | }, 2577 | "pify": { 2578 | "version": "3.0.0", 2579 | "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", 2580 | "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=", 2581 | "dev": true 2582 | }, 2583 | "posix-character-classes": { 2584 | "version": "0.1.1", 2585 | "resolved": "https://registry.npmjs.org/posix-character-classes/-/posix-character-classes-0.1.1.tgz", 2586 | "integrity": "sha1-AerA/jta9xoqbAL+q7jB/vfgDqs=", 2587 | "dev": true 2588 | }, 2589 | "prepend-http": { 2590 | "version": "1.0.4", 2591 | "resolved": "https://registry.npmjs.org/prepend-http/-/prepend-http-1.0.4.tgz", 2592 | "integrity": "sha1-1PRWKwzjaW5BrFLQ4ALlemNdxtw=", 2593 | "dev": true 2594 | }, 2595 | "process-nextick-args": { 2596 | "version": "2.0.0", 2597 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.0.tgz", 2598 | "integrity": "sha512-MtEC1TqN0EU5nephaJ4rAtThHtC86dNN9qCuEhtshvpVBkAW5ZO7BASN9REnF9eoXGcRub+pFuKEpOHE+HbEMw==", 2599 | "dev": true 2600 | }, 2601 | "proxy-addr": { 2602 | "version": "2.0.4", 2603 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.4.tgz", 2604 | "integrity": "sha512-5erio2h9jp5CHGwcybmxmVqHmnCBZeewlfJ0pex+UW7Qny7OOZXTtH56TGNyBizkgiOwhJtMKrVzDTeKcySZwA==", 2605 | "requires": { 2606 | "forwarded": "~0.1.2", 2607 | "ipaddr.js": "1.8.0" 2608 | } 2609 | }, 2610 | "ps-tree": { 2611 | "version": "1.1.0", 2612 | "resolved": "https://registry.npmjs.org/ps-tree/-/ps-tree-1.1.0.tgz", 2613 | "integrity": "sha1-tCGyQUDWID8e08dplrRCewjowBQ=", 2614 | "dev": true, 2615 | "requires": { 2616 | "event-stream": "~3.3.0" 2617 | } 2618 | }, 2619 | "pseudomap": { 2620 | "version": "1.0.2", 2621 | "resolved": "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz", 2622 | "integrity": "sha1-8FKijacOYYkX7wqKw0wa5aaChrM=", 2623 | "dev": true 2624 | }, 2625 | "psl": { 2626 | "version": "1.1.29", 2627 | "resolved": "https://registry.npmjs.org/psl/-/psl-1.1.29.tgz", 2628 | "integrity": "sha512-AeUmQ0oLN02flVHXWh9sSJF7mcdFq0ppid/JkErufc3hGIV/AMa8Fo9VgDo/cT2jFdOWoFvHp90qqBH54W+gjQ==" 2629 | }, 2630 | "pstree.remy": { 2631 | "version": "1.1.0", 2632 | "resolved": "https://registry.npmjs.org/pstree.remy/-/pstree.remy-1.1.0.tgz", 2633 | "integrity": "sha512-q5I5vLRMVtdWa8n/3UEzZX7Lfghzrg9eG2IKk2ENLSofKRCXVqMvMUHxCKgXNaqH/8ebhBxrqftHWnyTFweJ5Q==", 2634 | "dev": true, 2635 | "requires": { 2636 | "ps-tree": "^1.1.0" 2637 | } 2638 | }, 2639 | "punycode": { 2640 | "version": "2.1.1", 2641 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 2642 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==" 2643 | }, 2644 | "qs": { 2645 | "version": "6.5.2", 2646 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.2.tgz", 2647 | "integrity": "sha512-N5ZAX4/LxJmF+7wN74pUD6qAh9/wnvdQcjq9TZjevvXzSUo7bfmw91saqMjzGS2xq91/odN2dW/WOl7qQHNDGA==" 2648 | }, 2649 | "range-parser": { 2650 | "version": "1.2.0", 2651 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.0.tgz", 2652 | "integrity": "sha1-9JvmtIeJTdxA3MlKMi9hEJLgDV4=" 2653 | }, 2654 | "raw-body": { 2655 | "version": "2.3.3", 2656 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.3.3.tgz", 2657 | "integrity": "sha512-9esiElv1BrZoI3rCDuOuKCBRbuApGGaDPQfjSflGxdy4oyzqghxu6klEkkVIvBje+FF0BX9coEv8KqW6X/7njw==", 2658 | "requires": { 2659 | "bytes": "3.0.0", 2660 | "http-errors": "1.6.3", 2661 | "iconv-lite": "0.4.23", 2662 | "unpipe": "1.0.0" 2663 | } 2664 | }, 2665 | "rc": { 2666 | "version": "1.2.8", 2667 | "resolved": "https://registry.npmjs.org/rc/-/rc-1.2.8.tgz", 2668 | "integrity": "sha512-y3bGgqKj3QBdxLbLkomlohkvsA8gdAiUQlSBJnBhfn+BPxg4bc62d8TcBW15wavDfgexCgccckhcZvywyQYPOw==", 2669 | "dev": true, 2670 | "requires": { 2671 | "deep-extend": "^0.6.0", 2672 | "ini": "~1.3.0", 2673 | "minimist": "^1.2.0", 2674 | "strip-json-comments": "~2.0.1" 2675 | } 2676 | }, 2677 | "readable-stream": { 2678 | "version": "2.3.6", 2679 | "resolved": "http://registry.npmjs.org/readable-stream/-/readable-stream-2.3.6.tgz", 2680 | "integrity": "sha512-tQtKA9WIAhBF3+VLAseyMqZeBjW0AHJoxOtYqSUZNJxauErmLbVm2FW1y+J/YA9dUrAC39ITejlZWhVIwawkKw==", 2681 | "dev": true, 2682 | "requires": { 2683 | "core-util-is": "~1.0.0", 2684 | "inherits": "~2.0.3", 2685 | "isarray": "~1.0.0", 2686 | "process-nextick-args": "~2.0.0", 2687 | "safe-buffer": "~5.1.1", 2688 | "string_decoder": "~1.1.1", 2689 | "util-deprecate": "~1.0.1" 2690 | } 2691 | }, 2692 | "readdirp": { 2693 | "version": "2.2.1", 2694 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-2.2.1.tgz", 2695 | "integrity": "sha512-1JU/8q+VgFZyxwrJ+SVIOsh+KywWGpds3NTqikiKpDMZWScmAYyKIgqkO+ARvNWJfXeXR1zxz7aHF4u4CyH6vQ==", 2696 | "dev": true, 2697 | "requires": { 2698 | "graceful-fs": "^4.1.11", 2699 | "micromatch": "^3.1.10", 2700 | "readable-stream": "^2.0.2" 2701 | } 2702 | }, 2703 | "regex-not": { 2704 | "version": "1.0.2", 2705 | "resolved": "https://registry.npmjs.org/regex-not/-/regex-not-1.0.2.tgz", 2706 | "integrity": "sha512-J6SDjUgDxQj5NusnOtdFxDwN/+HWykR8GELwctJ7mdqhcyy1xEc4SRFHUXvxTp661YaVKAjfRLZ9cCqS6tn32A==", 2707 | "dev": true, 2708 | "requires": { 2709 | "extend-shallow": "^3.0.2", 2710 | "safe-regex": "^1.1.0" 2711 | } 2712 | }, 2713 | "regexp-clone": { 2714 | "version": "0.0.1", 2715 | "resolved": "https://registry.npmjs.org/regexp-clone/-/regexp-clone-0.0.1.tgz", 2716 | "integrity": "sha1-p8LgmJH9vzj7sQ03b7cwA+aKxYk=" 2717 | }, 2718 | "registry-auth-token": { 2719 | "version": "3.3.2", 2720 | "resolved": "https://registry.npmjs.org/registry-auth-token/-/registry-auth-token-3.3.2.tgz", 2721 | "integrity": "sha512-JL39c60XlzCVgNrO+qq68FoNb56w/m7JYvGR2jT5iR1xBrUA3Mfx5Twk5rqTThPmQKMWydGmq8oFtDlxfrmxnQ==", 2722 | "dev": true, 2723 | "requires": { 2724 | "rc": "^1.1.6", 2725 | "safe-buffer": "^5.0.1" 2726 | } 2727 | }, 2728 | "registry-url": { 2729 | "version": "3.1.0", 2730 | "resolved": "https://registry.npmjs.org/registry-url/-/registry-url-3.1.0.tgz", 2731 | "integrity": "sha1-PU74cPc93h138M+aOBQyRE4XSUI=", 2732 | "dev": true, 2733 | "requires": { 2734 | "rc": "^1.0.1" 2735 | } 2736 | }, 2737 | "remove-trailing-separator": { 2738 | "version": "1.1.0", 2739 | "resolved": "https://registry.npmjs.org/remove-trailing-separator/-/remove-trailing-separator-1.1.0.tgz", 2740 | "integrity": "sha1-wkvOKig62tW8P1jg1IJJuSN52O8=", 2741 | "dev": true 2742 | }, 2743 | "repeat-element": { 2744 | "version": "1.1.3", 2745 | "resolved": "https://registry.npmjs.org/repeat-element/-/repeat-element-1.1.3.tgz", 2746 | "integrity": "sha512-ahGq0ZnV5m5XtZLMb+vP76kcAM5nkLqk0lpqAuojSKGgQtn4eRi4ZZGm2olo2zKFH+sMsWaqOCW1dqAnOru72g==", 2747 | "dev": true 2748 | }, 2749 | "repeat-string": { 2750 | "version": "1.6.1", 2751 | "resolved": "https://registry.npmjs.org/repeat-string/-/repeat-string-1.6.1.tgz", 2752 | "integrity": "sha1-jcrkcOHIirwtYA//Sndihtp15jc=", 2753 | "dev": true 2754 | }, 2755 | "request": { 2756 | "version": "2.88.0", 2757 | "resolved": "https://registry.npmjs.org/request/-/request-2.88.0.tgz", 2758 | "integrity": "sha512-NAqBSrijGLZdM0WZNsInLJpkJokL72XYjUpnB0iwsRgxh7dB6COrHnTBNwN0E+lHDAJzu7kLAkDeY08z2/A0hg==", 2759 | "requires": { 2760 | "aws-sign2": "~0.7.0", 2761 | "aws4": "^1.8.0", 2762 | "caseless": "~0.12.0", 2763 | "combined-stream": "~1.0.6", 2764 | "extend": "~3.0.2", 2765 | "forever-agent": "~0.6.1", 2766 | "form-data": "~2.3.2", 2767 | "har-validator": "~5.1.0", 2768 | "http-signature": "~1.2.0", 2769 | "is-typedarray": "~1.0.0", 2770 | "isstream": "~0.1.2", 2771 | "json-stringify-safe": "~5.0.1", 2772 | "mime-types": "~2.1.19", 2773 | "oauth-sign": "~0.9.0", 2774 | "performance-now": "^2.1.0", 2775 | "qs": "~6.5.2", 2776 | "safe-buffer": "^5.1.2", 2777 | "tough-cookie": "~2.4.3", 2778 | "tunnel-agent": "^0.6.0", 2779 | "uuid": "^3.3.2" 2780 | } 2781 | }, 2782 | "require_optional": { 2783 | "version": "1.0.1", 2784 | "resolved": "https://registry.npmjs.org/require_optional/-/require_optional-1.0.1.tgz", 2785 | "integrity": "sha512-qhM/y57enGWHAe3v/NcwML6a3/vfESLe/sGM2dII+gEO0BpKRUkWZow/tyloNqJyN6kXSl3RyyM8Ll5D/sJP8g==", 2786 | "requires": { 2787 | "resolve-from": "^2.0.0", 2788 | "semver": "^5.1.0" 2789 | } 2790 | }, 2791 | "resolve-from": { 2792 | "version": "2.0.0", 2793 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-2.0.0.tgz", 2794 | "integrity": "sha1-lICrIOlP+h2egKgEx+oUdhGWa1c=" 2795 | }, 2796 | "resolve-url": { 2797 | "version": "0.2.1", 2798 | "resolved": "https://registry.npmjs.org/resolve-url/-/resolve-url-0.2.1.tgz", 2799 | "integrity": "sha1-LGN/53yJOv0qZj/iGqkIAGjiBSo=", 2800 | "dev": true 2801 | }, 2802 | "ret": { 2803 | "version": "0.1.15", 2804 | "resolved": "https://registry.npmjs.org/ret/-/ret-0.1.15.tgz", 2805 | "integrity": "sha512-TTlYpa+OL+vMMNG24xSlQGEJ3B/RzEfUlLct7b5G/ytav+wPrplCpVMFuwzXbkecJrb6IYo1iFb0S9v37754mg==", 2806 | "dev": true 2807 | }, 2808 | "safe-buffer": { 2809 | "version": "5.1.2", 2810 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 2811 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 2812 | }, 2813 | "safe-regex": { 2814 | "version": "1.1.0", 2815 | "resolved": "http://registry.npmjs.org/safe-regex/-/safe-regex-1.1.0.tgz", 2816 | "integrity": "sha1-QKNmnzsHfR6UPURinhV91IAjvy4=", 2817 | "dev": true, 2818 | "requires": { 2819 | "ret": "~0.1.10" 2820 | } 2821 | }, 2822 | "safer-buffer": { 2823 | "version": "2.1.2", 2824 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 2825 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 2826 | }, 2827 | "saslprep": { 2828 | "version": "1.0.2", 2829 | "resolved": "https://registry.npmjs.org/saslprep/-/saslprep-1.0.2.tgz", 2830 | "integrity": "sha512-4cDsYuAjXssUSjxHKRe4DTZC0agDwsCqcMqtJAQPzC74nJ7LfAJflAtC1Zed5hMzEQKj82d3tuzqdGNRsLJ4Gw==", 2831 | "optional": true, 2832 | "requires": { 2833 | "sparse-bitfield": "^3.0.3" 2834 | } 2835 | }, 2836 | "semver": { 2837 | "version": "5.6.0", 2838 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.6.0.tgz", 2839 | "integrity": "sha512-RS9R6R35NYgQn++fkDWaOmqGoj4Ek9gGs+DPxNUZKuwE183xjJroKvyo1IzVFeXvUrvmALy6FWD5xrdJT25gMg==" 2840 | }, 2841 | "semver-diff": { 2842 | "version": "2.1.0", 2843 | "resolved": "https://registry.npmjs.org/semver-diff/-/semver-diff-2.1.0.tgz", 2844 | "integrity": "sha1-S7uEN8jTfksM8aaP1ybsbWRdbTY=", 2845 | "dev": true, 2846 | "requires": { 2847 | "semver": "^5.0.3" 2848 | } 2849 | }, 2850 | "send": { 2851 | "version": "0.16.2", 2852 | "resolved": "https://registry.npmjs.org/send/-/send-0.16.2.tgz", 2853 | "integrity": "sha512-E64YFPUssFHEFBvpbbjr44NCLtI1AohxQ8ZSiJjQLskAdKuriYEP6VyGEsRDH8ScozGpkaX1BGvhanqCwkcEZw==", 2854 | "requires": { 2855 | "debug": "2.6.9", 2856 | "depd": "~1.1.2", 2857 | "destroy": "~1.0.4", 2858 | "encodeurl": "~1.0.2", 2859 | "escape-html": "~1.0.3", 2860 | "etag": "~1.8.1", 2861 | "fresh": "0.5.2", 2862 | "http-errors": "~1.6.2", 2863 | "mime": "1.4.1", 2864 | "ms": "2.0.0", 2865 | "on-finished": "~2.3.0", 2866 | "range-parser": "~1.2.0", 2867 | "statuses": "~1.4.0" 2868 | } 2869 | }, 2870 | "serve-static": { 2871 | "version": "1.13.2", 2872 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.13.2.tgz", 2873 | "integrity": "sha512-p/tdJrO4U387R9oMjb1oj7qSMaMfmOyd4j9hOFoxZe2baQszgHcSWjuya/CiT5kgZZKRudHNOA0pYXOl8rQ5nw==", 2874 | "requires": { 2875 | "encodeurl": "~1.0.2", 2876 | "escape-html": "~1.0.3", 2877 | "parseurl": "~1.3.2", 2878 | "send": "0.16.2" 2879 | } 2880 | }, 2881 | "set-value": { 2882 | "version": "2.0.0", 2883 | "resolved": "https://registry.npmjs.org/set-value/-/set-value-2.0.0.tgz", 2884 | "integrity": "sha512-hw0yxk9GT/Hr5yJEYnHNKYXkIA8mVJgd9ditYZCe16ZczcaELYYcfvaXesNACk2O8O0nTiPQcQhGUQj8JLzeeg==", 2885 | "dev": true, 2886 | "requires": { 2887 | "extend-shallow": "^2.0.1", 2888 | "is-extendable": "^0.1.1", 2889 | "is-plain-object": "^2.0.3", 2890 | "split-string": "^3.0.1" 2891 | }, 2892 | "dependencies": { 2893 | "extend-shallow": { 2894 | "version": "2.0.1", 2895 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", 2896 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", 2897 | "dev": true, 2898 | "requires": { 2899 | "is-extendable": "^0.1.0" 2900 | } 2901 | } 2902 | } 2903 | }, 2904 | "setprototypeof": { 2905 | "version": "1.1.0", 2906 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.0.tgz", 2907 | "integrity": "sha512-BvE/TwpZX4FXExxOxZyRGQQv651MSwmWKZGqvmPcRIjDqWub67kTKuIMx43cZZrS/cBBzwBcNDWoFxt2XEFIpQ==" 2908 | }, 2909 | "shebang-command": { 2910 | "version": "1.2.0", 2911 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", 2912 | "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", 2913 | "dev": true, 2914 | "requires": { 2915 | "shebang-regex": "^1.0.0" 2916 | } 2917 | }, 2918 | "shebang-regex": { 2919 | "version": "1.0.0", 2920 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", 2921 | "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=", 2922 | "dev": true 2923 | }, 2924 | "signal-exit": { 2925 | "version": "3.0.2", 2926 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", 2927 | "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=", 2928 | "dev": true 2929 | }, 2930 | "sliced": { 2931 | "version": "1.0.1", 2932 | "resolved": "https://registry.npmjs.org/sliced/-/sliced-1.0.1.tgz", 2933 | "integrity": "sha1-CzpmK10Ewxd7GSa+qCsD+Dei70E=" 2934 | }, 2935 | "snapdragon": { 2936 | "version": "0.8.2", 2937 | "resolved": "https://registry.npmjs.org/snapdragon/-/snapdragon-0.8.2.tgz", 2938 | "integrity": "sha512-FtyOnWN/wCHTVXOMwvSv26d+ko5vWlIDD6zoUJ7LW8vh+ZBC8QdljveRP+crNrtBwioEUWy/4dMtbBjA4ioNlg==", 2939 | "dev": true, 2940 | "requires": { 2941 | "base": "^0.11.1", 2942 | "debug": "^2.2.0", 2943 | "define-property": "^0.2.5", 2944 | "extend-shallow": "^2.0.1", 2945 | "map-cache": "^0.2.2", 2946 | "source-map": "^0.5.6", 2947 | "source-map-resolve": "^0.5.0", 2948 | "use": "^3.1.0" 2949 | }, 2950 | "dependencies": { 2951 | "define-property": { 2952 | "version": "0.2.5", 2953 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", 2954 | "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", 2955 | "dev": true, 2956 | "requires": { 2957 | "is-descriptor": "^0.1.0" 2958 | } 2959 | }, 2960 | "extend-shallow": { 2961 | "version": "2.0.1", 2962 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", 2963 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", 2964 | "dev": true, 2965 | "requires": { 2966 | "is-extendable": "^0.1.0" 2967 | } 2968 | } 2969 | } 2970 | }, 2971 | "snapdragon-node": { 2972 | "version": "2.1.1", 2973 | "resolved": "https://registry.npmjs.org/snapdragon-node/-/snapdragon-node-2.1.1.tgz", 2974 | "integrity": "sha512-O27l4xaMYt/RSQ5TR3vpWCAB5Kb/czIcqUFOM/C4fYcLnbZUc1PkjTAMjof2pBWaSTwOUd6qUHcFGVGj7aIwnw==", 2975 | "dev": true, 2976 | "requires": { 2977 | "define-property": "^1.0.0", 2978 | "isobject": "^3.0.0", 2979 | "snapdragon-util": "^3.0.1" 2980 | }, 2981 | "dependencies": { 2982 | "define-property": { 2983 | "version": "1.0.0", 2984 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz", 2985 | "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", 2986 | "dev": true, 2987 | "requires": { 2988 | "is-descriptor": "^1.0.0" 2989 | } 2990 | }, 2991 | "is-accessor-descriptor": { 2992 | "version": "1.0.0", 2993 | "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", 2994 | "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", 2995 | "dev": true, 2996 | "requires": { 2997 | "kind-of": "^6.0.0" 2998 | } 2999 | }, 3000 | "is-data-descriptor": { 3001 | "version": "1.0.0", 3002 | "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", 3003 | "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", 3004 | "dev": true, 3005 | "requires": { 3006 | "kind-of": "^6.0.0" 3007 | } 3008 | }, 3009 | "is-descriptor": { 3010 | "version": "1.0.2", 3011 | "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", 3012 | "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", 3013 | "dev": true, 3014 | "requires": { 3015 | "is-accessor-descriptor": "^1.0.0", 3016 | "is-data-descriptor": "^1.0.0", 3017 | "kind-of": "^6.0.2" 3018 | } 3019 | } 3020 | } 3021 | }, 3022 | "snapdragon-util": { 3023 | "version": "3.0.1", 3024 | "resolved": "https://registry.npmjs.org/snapdragon-util/-/snapdragon-util-3.0.1.tgz", 3025 | "integrity": "sha512-mbKkMdQKsjX4BAL4bRYTj21edOf8cN7XHdYUJEe+Zn99hVEYcMvKPct1IqNe7+AZPirn8BCDOQBHQZknqmKlZQ==", 3026 | "dev": true, 3027 | "requires": { 3028 | "kind-of": "^3.2.0" 3029 | }, 3030 | "dependencies": { 3031 | "kind-of": { 3032 | "version": "3.2.2", 3033 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 3034 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 3035 | "dev": true, 3036 | "requires": { 3037 | "is-buffer": "^1.1.5" 3038 | } 3039 | } 3040 | } 3041 | }, 3042 | "source-map": { 3043 | "version": "0.5.7", 3044 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", 3045 | "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=", 3046 | "dev": true 3047 | }, 3048 | "source-map-resolve": { 3049 | "version": "0.5.2", 3050 | "resolved": "https://registry.npmjs.org/source-map-resolve/-/source-map-resolve-0.5.2.tgz", 3051 | "integrity": "sha512-MjqsvNwyz1s0k81Goz/9vRBe9SZdB09Bdw+/zYyO+3CuPk6fouTaxscHkgtE8jKvf01kVfl8riHzERQ/kefaSA==", 3052 | "dev": true, 3053 | "requires": { 3054 | "atob": "^2.1.1", 3055 | "decode-uri-component": "^0.2.0", 3056 | "resolve-url": "^0.2.1", 3057 | "source-map-url": "^0.4.0", 3058 | "urix": "^0.1.0" 3059 | } 3060 | }, 3061 | "source-map-url": { 3062 | "version": "0.4.0", 3063 | "resolved": "https://registry.npmjs.org/source-map-url/-/source-map-url-0.4.0.tgz", 3064 | "integrity": "sha1-PpNdfd1zYxuXZZlW1VEo6HtQhKM=", 3065 | "dev": true 3066 | }, 3067 | "sparse-bitfield": { 3068 | "version": "3.0.3", 3069 | "resolved": "https://registry.npmjs.org/sparse-bitfield/-/sparse-bitfield-3.0.3.tgz", 3070 | "integrity": "sha1-/0rm5oZWBWuks+eSqzM004JzyhE=", 3071 | "optional": true, 3072 | "requires": { 3073 | "memory-pager": "^1.0.2" 3074 | } 3075 | }, 3076 | "split": { 3077 | "version": "1.0.1", 3078 | "resolved": "https://registry.npmjs.org/split/-/split-1.0.1.tgz", 3079 | "integrity": "sha512-mTyOoPbrivtXnwnIxZRFYRrPNtEFKlpB2fvjSnCQUiAA6qAZzqwna5envK4uk6OIeP17CsdF3rSBGYVBsU0Tkg==", 3080 | "dev": true, 3081 | "requires": { 3082 | "through": "2" 3083 | } 3084 | }, 3085 | "split-string": { 3086 | "version": "3.1.0", 3087 | "resolved": "https://registry.npmjs.org/split-string/-/split-string-3.1.0.tgz", 3088 | "integrity": "sha512-NzNVhJDYpwceVVii8/Hu6DKfD2G+NrQHlS/V/qgv763EYudVwEcMQNxd2lh+0VrUByXN/oJkl5grOhYWvQUYiw==", 3089 | "dev": true, 3090 | "requires": { 3091 | "extend-shallow": "^3.0.0" 3092 | } 3093 | }, 3094 | "sshpk": { 3095 | "version": "1.15.2", 3096 | "resolved": "https://registry.npmjs.org/sshpk/-/sshpk-1.15.2.tgz", 3097 | "integrity": "sha512-Ra/OXQtuh0/enyl4ETZAfTaeksa6BXks5ZcjpSUNrjBr0DvrJKX+1fsKDPpT9TBXgHAFsa4510aNVgI8g/+SzA==", 3098 | "requires": { 3099 | "asn1": "~0.2.3", 3100 | "assert-plus": "^1.0.0", 3101 | "bcrypt-pbkdf": "^1.0.0", 3102 | "dashdash": "^1.12.0", 3103 | "ecc-jsbn": "~0.1.1", 3104 | "getpass": "^0.1.1", 3105 | "jsbn": "~0.1.0", 3106 | "safer-buffer": "^2.0.2", 3107 | "tweetnacl": "~0.14.0" 3108 | } 3109 | }, 3110 | "static-extend": { 3111 | "version": "0.1.2", 3112 | "resolved": "https://registry.npmjs.org/static-extend/-/static-extend-0.1.2.tgz", 3113 | "integrity": "sha1-YICcOcv/VTNyJv1eC1IPNB8ftcY=", 3114 | "dev": true, 3115 | "requires": { 3116 | "define-property": "^0.2.5", 3117 | "object-copy": "^0.1.0" 3118 | }, 3119 | "dependencies": { 3120 | "define-property": { 3121 | "version": "0.2.5", 3122 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", 3123 | "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", 3124 | "dev": true, 3125 | "requires": { 3126 | "is-descriptor": "^0.1.0" 3127 | } 3128 | } 3129 | } 3130 | }, 3131 | "statuses": { 3132 | "version": "1.4.0", 3133 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.4.0.tgz", 3134 | "integrity": "sha512-zhSCtt8v2NDrRlPQpCNtw/heZLtfUDqxBM1udqikb/Hbk52LK4nQSwr10u77iopCW5LsyHpuXS0GnEc48mLeew==" 3135 | }, 3136 | "stream-combiner": { 3137 | "version": "0.2.2", 3138 | "resolved": "http://registry.npmjs.org/stream-combiner/-/stream-combiner-0.2.2.tgz", 3139 | "integrity": "sha1-rsjLrBd7Vrb0+kec7YwZEs7lKFg=", 3140 | "dev": true, 3141 | "requires": { 3142 | "duplexer": "~0.1.1", 3143 | "through": "~2.3.4" 3144 | } 3145 | }, 3146 | "string-width": { 3147 | "version": "2.1.1", 3148 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", 3149 | "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", 3150 | "dev": true, 3151 | "requires": { 3152 | "is-fullwidth-code-point": "^2.0.0", 3153 | "strip-ansi": "^4.0.0" 3154 | } 3155 | }, 3156 | "string_decoder": { 3157 | "version": "1.1.1", 3158 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 3159 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 3160 | "dev": true, 3161 | "requires": { 3162 | "safe-buffer": "~5.1.0" 3163 | } 3164 | }, 3165 | "strip-ansi": { 3166 | "version": "4.0.0", 3167 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 3168 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 3169 | "dev": true, 3170 | "requires": { 3171 | "ansi-regex": "^3.0.0" 3172 | } 3173 | }, 3174 | "strip-eof": { 3175 | "version": "1.0.0", 3176 | "resolved": "http://registry.npmjs.org/strip-eof/-/strip-eof-1.0.0.tgz", 3177 | "integrity": "sha1-u0P/VZim6wXYm1n80SnJgzE2Br8=", 3178 | "dev": true 3179 | }, 3180 | "strip-json-comments": { 3181 | "version": "2.0.1", 3182 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 3183 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", 3184 | "dev": true 3185 | }, 3186 | "supports-color": { 3187 | "version": "5.5.0", 3188 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 3189 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 3190 | "dev": true, 3191 | "requires": { 3192 | "has-flag": "^3.0.0" 3193 | } 3194 | }, 3195 | "term-size": { 3196 | "version": "1.2.0", 3197 | "resolved": "https://registry.npmjs.org/term-size/-/term-size-1.2.0.tgz", 3198 | "integrity": "sha1-RYuDiH8oj8Vtb/+/rSYuJmOO+mk=", 3199 | "dev": true, 3200 | "requires": { 3201 | "execa": "^0.7.0" 3202 | } 3203 | }, 3204 | "through": { 3205 | "version": "2.3.8", 3206 | "resolved": "http://registry.npmjs.org/through/-/through-2.3.8.tgz", 3207 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=", 3208 | "dev": true 3209 | }, 3210 | "timed-out": { 3211 | "version": "4.0.1", 3212 | "resolved": "https://registry.npmjs.org/timed-out/-/timed-out-4.0.1.tgz", 3213 | "integrity": "sha1-8y6srFoXW+ol1/q1Zas+2HQe9W8=", 3214 | "dev": true 3215 | }, 3216 | "to-object-path": { 3217 | "version": "0.3.0", 3218 | "resolved": "https://registry.npmjs.org/to-object-path/-/to-object-path-0.3.0.tgz", 3219 | "integrity": "sha1-KXWIt7Dn4KwI4E5nL4XB9JmeF68=", 3220 | "dev": true, 3221 | "requires": { 3222 | "kind-of": "^3.0.2" 3223 | }, 3224 | "dependencies": { 3225 | "kind-of": { 3226 | "version": "3.2.2", 3227 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 3228 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 3229 | "dev": true, 3230 | "requires": { 3231 | "is-buffer": "^1.1.5" 3232 | } 3233 | } 3234 | } 3235 | }, 3236 | "to-regex": { 3237 | "version": "3.0.2", 3238 | "resolved": "https://registry.npmjs.org/to-regex/-/to-regex-3.0.2.tgz", 3239 | "integrity": "sha512-FWtleNAtZ/Ki2qtqej2CXTOayOH9bHDQF+Q48VpWyDXjbYxA4Yz8iDB31zXOBUlOHHKidDbqGVrTUvQMPmBGBw==", 3240 | "dev": true, 3241 | "requires": { 3242 | "define-property": "^2.0.2", 3243 | "extend-shallow": "^3.0.2", 3244 | "regex-not": "^1.0.2", 3245 | "safe-regex": "^1.1.0" 3246 | } 3247 | }, 3248 | "to-regex-range": { 3249 | "version": "2.1.1", 3250 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-2.1.1.tgz", 3251 | "integrity": "sha1-fIDBe53+vlmeJzZ+DU3VWQFB2zg=", 3252 | "dev": true, 3253 | "requires": { 3254 | "is-number": "^3.0.0", 3255 | "repeat-string": "^1.6.1" 3256 | } 3257 | }, 3258 | "touch": { 3259 | "version": "3.1.0", 3260 | "resolved": "https://registry.npmjs.org/touch/-/touch-3.1.0.tgz", 3261 | "integrity": "sha512-WBx8Uy5TLtOSRtIq+M03/sKDrXCLHxwDcquSP2c43Le03/9serjQBIztjRz6FkJez9D/hleyAXTBGLwwZUw9lA==", 3262 | "dev": true, 3263 | "requires": { 3264 | "nopt": "~1.0.10" 3265 | } 3266 | }, 3267 | "tough-cookie": { 3268 | "version": "2.4.3", 3269 | "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.4.3.tgz", 3270 | "integrity": "sha512-Q5srk/4vDM54WJsJio3XNn6K2sCG+CQ8G5Wz6bZhRZoAe/+TxjWB/GlFAnYEbkYVlON9FMk/fE3h2RLpPXo4lQ==", 3271 | "requires": { 3272 | "psl": "^1.1.24", 3273 | "punycode": "^1.4.1" 3274 | }, 3275 | "dependencies": { 3276 | "punycode": { 3277 | "version": "1.4.1", 3278 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.4.1.tgz", 3279 | "integrity": "sha1-wNWmOycYgArY4esPpSachN1BhF4=" 3280 | } 3281 | } 3282 | }, 3283 | "tunnel-agent": { 3284 | "version": "0.6.0", 3285 | "resolved": "https://registry.npmjs.org/tunnel-agent/-/tunnel-agent-0.6.0.tgz", 3286 | "integrity": "sha1-J6XeoGs2sEoKmWZ3SykIaPD8QP0=", 3287 | "requires": { 3288 | "safe-buffer": "^5.0.1" 3289 | } 3290 | }, 3291 | "tweetnacl": { 3292 | "version": "0.14.5", 3293 | "resolved": "https://registry.npmjs.org/tweetnacl/-/tweetnacl-0.14.5.tgz", 3294 | "integrity": "sha1-WuaBd/GS1EViadEIr6k/+HQ/T2Q=" 3295 | }, 3296 | "type-is": { 3297 | "version": "1.6.16", 3298 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.16.tgz", 3299 | "integrity": "sha512-HRkVv/5qY2G6I8iab9cI7v1bOIdhm94dVjQCPFElW9W+3GeDOSHmy2EBYe4VTApuzolPcmgFTN3ftVJRKR2J9Q==", 3300 | "requires": { 3301 | "media-typer": "0.3.0", 3302 | "mime-types": "~2.1.18" 3303 | } 3304 | }, 3305 | "undefsafe": { 3306 | "version": "2.0.2", 3307 | "resolved": "https://registry.npmjs.org/undefsafe/-/undefsafe-2.0.2.tgz", 3308 | "integrity": "sha1-Il9rngM3Zj4Njnz9aG/Cg2zKznY=", 3309 | "dev": true, 3310 | "requires": { 3311 | "debug": "^2.2.0" 3312 | } 3313 | }, 3314 | "union-value": { 3315 | "version": "1.0.0", 3316 | "resolved": "https://registry.npmjs.org/union-value/-/union-value-1.0.0.tgz", 3317 | "integrity": "sha1-XHHDTLW61dzr4+oM0IIHulqhrqQ=", 3318 | "dev": true, 3319 | "requires": { 3320 | "arr-union": "^3.1.0", 3321 | "get-value": "^2.0.6", 3322 | "is-extendable": "^0.1.1", 3323 | "set-value": "^0.4.3" 3324 | }, 3325 | "dependencies": { 3326 | "extend-shallow": { 3327 | "version": "2.0.1", 3328 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", 3329 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", 3330 | "dev": true, 3331 | "requires": { 3332 | "is-extendable": "^0.1.0" 3333 | } 3334 | }, 3335 | "set-value": { 3336 | "version": "0.4.3", 3337 | "resolved": "https://registry.npmjs.org/set-value/-/set-value-0.4.3.tgz", 3338 | "integrity": "sha1-fbCPnT0i3H945Trzw79GZuzfzPE=", 3339 | "dev": true, 3340 | "requires": { 3341 | "extend-shallow": "^2.0.1", 3342 | "is-extendable": "^0.1.1", 3343 | "is-plain-object": "^2.0.1", 3344 | "to-object-path": "^0.3.0" 3345 | } 3346 | } 3347 | } 3348 | }, 3349 | "unique-string": { 3350 | "version": "1.0.0", 3351 | "resolved": "https://registry.npmjs.org/unique-string/-/unique-string-1.0.0.tgz", 3352 | "integrity": "sha1-nhBXzKhRq7kzmPizOuGHuZyuwRo=", 3353 | "dev": true, 3354 | "requires": { 3355 | "crypto-random-string": "^1.0.0" 3356 | } 3357 | }, 3358 | "unpipe": { 3359 | "version": "1.0.0", 3360 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 3361 | "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=" 3362 | }, 3363 | "unset-value": { 3364 | "version": "1.0.0", 3365 | "resolved": "https://registry.npmjs.org/unset-value/-/unset-value-1.0.0.tgz", 3366 | "integrity": "sha1-g3aHP30jNRef+x5vw6jtDfyKtVk=", 3367 | "dev": true, 3368 | "requires": { 3369 | "has-value": "^0.3.1", 3370 | "isobject": "^3.0.0" 3371 | }, 3372 | "dependencies": { 3373 | "has-value": { 3374 | "version": "0.3.1", 3375 | "resolved": "https://registry.npmjs.org/has-value/-/has-value-0.3.1.tgz", 3376 | "integrity": "sha1-ex9YutpiyoJ+wKIHgCVlSEWZXh8=", 3377 | "dev": true, 3378 | "requires": { 3379 | "get-value": "^2.0.3", 3380 | "has-values": "^0.1.4", 3381 | "isobject": "^2.0.0" 3382 | }, 3383 | "dependencies": { 3384 | "isobject": { 3385 | "version": "2.1.0", 3386 | "resolved": "https://registry.npmjs.org/isobject/-/isobject-2.1.0.tgz", 3387 | "integrity": "sha1-8GVWEJaj8dou9GJy+BXIQNh+DIk=", 3388 | "dev": true, 3389 | "requires": { 3390 | "isarray": "1.0.0" 3391 | } 3392 | } 3393 | } 3394 | }, 3395 | "has-values": { 3396 | "version": "0.1.4", 3397 | "resolved": "https://registry.npmjs.org/has-values/-/has-values-0.1.4.tgz", 3398 | "integrity": "sha1-bWHeldkd/Km5oCCJrThL/49it3E=", 3399 | "dev": true 3400 | } 3401 | } 3402 | }, 3403 | "unzip-response": { 3404 | "version": "2.0.1", 3405 | "resolved": "https://registry.npmjs.org/unzip-response/-/unzip-response-2.0.1.tgz", 3406 | "integrity": "sha1-0vD3N9FrBhXnKmk17QQhRXLVb5c=", 3407 | "dev": true 3408 | }, 3409 | "upath": { 3410 | "version": "1.1.0", 3411 | "resolved": "https://registry.npmjs.org/upath/-/upath-1.1.0.tgz", 3412 | "integrity": "sha512-bzpH/oBhoS/QI/YtbkqCg6VEiPYjSZtrHQM6/QnJS6OL9pKUFLqb3aFh4Scvwm45+7iAgiMkLhSbaZxUqmrprw==", 3413 | "dev": true 3414 | }, 3415 | "update-notifier": { 3416 | "version": "2.5.0", 3417 | "resolved": "https://registry.npmjs.org/update-notifier/-/update-notifier-2.5.0.tgz", 3418 | "integrity": "sha512-gwMdhgJHGuj/+wHJJs9e6PcCszpxR1b236igrOkUofGhqJuG+amlIKwApH1IW1WWl7ovZxsX49lMBWLxSdm5Dw==", 3419 | "dev": true, 3420 | "requires": { 3421 | "boxen": "^1.2.1", 3422 | "chalk": "^2.0.1", 3423 | "configstore": "^3.0.0", 3424 | "import-lazy": "^2.1.0", 3425 | "is-ci": "^1.0.10", 3426 | "is-installed-globally": "^0.1.0", 3427 | "is-npm": "^1.0.0", 3428 | "latest-version": "^3.0.0", 3429 | "semver-diff": "^2.0.0", 3430 | "xdg-basedir": "^3.0.0" 3431 | } 3432 | }, 3433 | "uri-js": { 3434 | "version": "4.2.2", 3435 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.2.2.tgz", 3436 | "integrity": "sha512-KY9Frmirql91X2Qgjry0Wd4Y+YTdrdZheS8TFwvkbLWf/G5KNJDCh6pKL5OZctEW4+0Baa5idK2ZQuELRwPznQ==", 3437 | "requires": { 3438 | "punycode": "^2.1.0" 3439 | } 3440 | }, 3441 | "urix": { 3442 | "version": "0.1.0", 3443 | "resolved": "https://registry.npmjs.org/urix/-/urix-0.1.0.tgz", 3444 | "integrity": "sha1-2pN/emLiH+wf0Y1Js1wpNQZ6bHI=", 3445 | "dev": true 3446 | }, 3447 | "url-parse-lax": { 3448 | "version": "1.0.0", 3449 | "resolved": "https://registry.npmjs.org/url-parse-lax/-/url-parse-lax-1.0.0.tgz", 3450 | "integrity": "sha1-evjzA2Rem9eaJy56FKxovAYJ2nM=", 3451 | "dev": true, 3452 | "requires": { 3453 | "prepend-http": "^1.0.1" 3454 | } 3455 | }, 3456 | "use": { 3457 | "version": "3.1.1", 3458 | "resolved": "https://registry.npmjs.org/use/-/use-3.1.1.tgz", 3459 | "integrity": "sha512-cwESVXlO3url9YWlFW/TA9cshCEhtu7IKJ/p5soJ/gGpj7vbvFrAY/eIioQ6Dw23KjZhYgiIo8HOs1nQ2vr/oQ==", 3460 | "dev": true 3461 | }, 3462 | "util-deprecate": { 3463 | "version": "1.0.2", 3464 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 3465 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=", 3466 | "dev": true 3467 | }, 3468 | "utils-merge": { 3469 | "version": "1.0.1", 3470 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 3471 | "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=" 3472 | }, 3473 | "uuid": { 3474 | "version": "3.3.2", 3475 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.3.2.tgz", 3476 | "integrity": "sha512-yXJmeNaw3DnnKAOKJE51sL/ZaYfWJRl1pK9dr19YFCu0ObS231AB1/LbqTKRAQ5kw8A90rA6fr4riOUpTZvQZA==" 3477 | }, 3478 | "vary": { 3479 | "version": "1.1.2", 3480 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 3481 | "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=" 3482 | }, 3483 | "verror": { 3484 | "version": "1.10.0", 3485 | "resolved": "https://registry.npmjs.org/verror/-/verror-1.10.0.tgz", 3486 | "integrity": "sha1-OhBcoXBTr1XW4nDB+CiGguGNpAA=", 3487 | "requires": { 3488 | "assert-plus": "^1.0.0", 3489 | "core-util-is": "1.0.2", 3490 | "extsprintf": "^1.2.0" 3491 | } 3492 | }, 3493 | "which": { 3494 | "version": "1.3.1", 3495 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 3496 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 3497 | "dev": true, 3498 | "requires": { 3499 | "isexe": "^2.0.0" 3500 | } 3501 | }, 3502 | "widest-line": { 3503 | "version": "2.0.1", 3504 | "resolved": "https://registry.npmjs.org/widest-line/-/widest-line-2.0.1.tgz", 3505 | "integrity": "sha512-Ba5m9/Fa4Xt9eb2ELXt77JxVDV8w7qQrH0zS/TWSJdLyAwQjWoOzpzj5lwVftDz6n/EOu3tNACS84v509qwnJA==", 3506 | "dev": true, 3507 | "requires": { 3508 | "string-width": "^2.1.1" 3509 | } 3510 | }, 3511 | "write-file-atomic": { 3512 | "version": "2.3.0", 3513 | "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-2.3.0.tgz", 3514 | "integrity": "sha512-xuPeK4OdjWqtfi59ylvVL0Yn35SF3zgcAcv7rBPFHVaEapaDr4GdGgm3j7ckTwH9wHL7fGmgfAnb0+THrHb8tA==", 3515 | "dev": true, 3516 | "requires": { 3517 | "graceful-fs": "^4.1.11", 3518 | "imurmurhash": "^0.1.4", 3519 | "signal-exit": "^3.0.2" 3520 | } 3521 | }, 3522 | "xdg-basedir": { 3523 | "version": "3.0.0", 3524 | "resolved": "https://registry.npmjs.org/xdg-basedir/-/xdg-basedir-3.0.0.tgz", 3525 | "integrity": "sha1-SWsswQnsqNus/i3HK2A8F8WHCtQ=", 3526 | "dev": true 3527 | }, 3528 | "yallist": { 3529 | "version": "2.1.2", 3530 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-2.1.2.tgz", 3531 | "integrity": "sha1-HBH5IY8HYImkfdUS+TxmmaaoHVI=", 3532 | "dev": true 3533 | } 3534 | } 3535 | } 3536 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "simple-restful-api-gateway", 3 | "version": "1.0.0", 4 | "description": "Simple RESTful API Gateway", 5 | "main": "index.js", 6 | "scripts": { 7 | "start": "node ./server.js", 8 | "dev": "nodemon ./server.js" 9 | }, 10 | "author": "thinkholic ", 11 | "license": "MIT", 12 | "dependencies": { 13 | "body-parser": "^1.18.3", 14 | "compression": "^1.7.3", 15 | "cors": "^2.8.5", 16 | "express": "^4.16.4", 17 | "jsonwebtoken": "^8.3.0", 18 | "mongoose": "^5.3.11", 19 | "morgan": "^1.9.1", 20 | "request": "^2.88.0" 21 | }, 22 | "devDependencies": { 23 | "dotenv": "^6.1.0", 24 | "nodemon": "^1.18.6" 25 | } 26 | } 27 | -------------------------------------------------------------------------------- /public/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | Landing page 5 | 6 | 7 | 8 |

Landing page - Simple RESTful API Gateway

9 | 10 | 11 | -------------------------------------------------------------------------------- /routes.json: -------------------------------------------------------------------------------- 1 | { 2 | "GET": [ 3 | { 4 | "path": "/", 5 | "type": "static", 6 | "entrypoint": "public/" 7 | }, 8 | { 9 | "path": "/api", 10 | "func": "welcome" 11 | }, 12 | { 13 | "path": "/api/user/:id", 14 | "middlewares": ["authorize", "database"], 15 | "func": "user" 16 | }, 17 | { 18 | "path": "/api/users", 19 | "type": "proxy", 20 | "endpoint": "https://jsonplaceholder.typicode.com/users" 21 | } 22 | ], 23 | "POST": [ 24 | { 25 | "path": "/auth", 26 | "middlewares": ["authenticate"], 27 | "func": "authenticate" 28 | }, 29 | { 30 | "path": "/api/user", 31 | "middlewares": ["authorize"], 32 | "func": "user" 33 | } 34 | ], 35 | "PUT": [], 36 | "DELETE": [] 37 | } 38 | -------------------------------------------------------------------------------- /server.js: -------------------------------------------------------------------------------- 1 | const express = require("express"); 2 | const logger = require("morgan"); 3 | const bodyParser = require("body-parser"); 4 | const cors = require("cors"); 5 | const compression = require("compression"); 6 | const urlPath = require("path"); 7 | 8 | const { 9 | getHandlers, 10 | getCoreHandlers, 11 | getMiddlewares, 12 | getRouteConfigs 13 | } = require("./core"); 14 | const { PORT } = require("./config"); 15 | 16 | // Create app instance. 17 | const app = express(); 18 | 19 | const middlewares = getMiddlewares(); 20 | const routeConfigs = getRouteConfigs(); 21 | const handlers = getHandlers(); 22 | const coreHandlers = getCoreHandlers(); 23 | 24 | // Initializing default middlewares 25 | app.use(cors()); 26 | app.use(compression()); 27 | app.use(logger("dev")); 28 | app.use(middlewares.config); 29 | app.use(bodyParser.json()); 30 | app.use( 31 | bodyParser.urlencoded({ 32 | extended: true 33 | }) 34 | ); 35 | 36 | // TODO: Optimize below code block for readablity and scalability. 37 | const methods = Object.keys(routeConfigs); 38 | 39 | methods.forEach(methodKey => { 40 | const method = routeConfigs[methodKey]; 41 | method.forEach(config => { 42 | const { path, type, func } = config; 43 | const funcHandler = methodKey.toLowerCase(); 44 | 45 | if (!type || type === "default") { 46 | const configMiddlewares = config.middlewares || []; 47 | const middlewareArray = configMiddlewares.map(m => middlewares[m]); 48 | app[funcHandler](path, middlewareArray, handlers[funcHandler][func]); 49 | } 50 | 51 | if (type === "proxy") { 52 | const { endpoint } = config; 53 | app[funcHandler]( 54 | path, 55 | coreHandlers[funcHandler].proxy.bind(null, config) 56 | ); 57 | } 58 | 59 | if (type === "static") { 60 | const { entrypoint } = config; 61 | app.use(path, express.static(urlPath.join(__dirname, entrypoint))); 62 | } 63 | }); 64 | }); 65 | 66 | // Server 67 | app.listen(PORT, () => console.log(`Server started on port ${PORT}`)); 68 | --------------------------------------------------------------------------------